/* Ubuntu Farming Dashboard Styles */

:root {
    /* Ubuntu Farming Brand Colors */
    --primary-color: #4a6741;          /* Forest green - main brand */
    --secondary-color: #5c7a52;        /* Olive green - secondary */
    --accent-color: #7a9b71;           /* Light green - accents */

    /* Text Colors */
    --text-primary: #3d2817;           /* Dark brown - primary text */
    --text-secondary: #6b5d4f;         /* Mid brown - secondary text */
    --text-light: #8a7d6f;             /* Light brown - subtle text */

    /* Background Colors */
    --bg-primary: #ffffff;             /* White - cards/panels */
    --bg-secondary: #f5f2ed;           /* Warm white - page background */
    --bg-sidebar: #3d2817;             /* Dark brown - sidebar */
    --bg-cream: #e8e3db;               /* Cream - alternative background */

    /* Border & Dividers */
    --border-color: #cdc5b8;           /* Tan - borders */
    --divider-color: #e8e3db;          /* Cream - dividers */

    /* Shadows */
    --shadow: 0 1px 3px 0 rgba(61, 40, 23, 0.1), 0 1px 2px 0 rgba(61, 40, 23, 0.06);
    --shadow-lg: 0 10px 15px -3px rgba(61, 40, 23, 0.1), 0 4px 6px -2px rgba(61, 40, 23, 0.05);

    /* Border Radius */
    --radius: 0.5rem;
    --radius-lg: 0.75rem;

    /* Status Colors */
    --error-color: #c73e1d;            /* Warm red */
    --success-color: #4a6741;          /* Brand green */
    --warning-color: #d4a056;          /* Warm amber */
    --info-color: #5c7a52;             /* Olive green */
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    width: 100%;
    height: 100%;
}

body {
    font-family: 'Inter', sans-serif;
    background-color: var(--bg-secondary);
    color: var(--text-primary);
    line-height: 1.6;
    width: 100%;
    min-height: 100%;
}

/* Sidebar Styles */
.sidebar {
    position: fixed;
    top: 0;
    left: 0;
    width: 280px;
    height: 100vh;
    background: var(--bg-sidebar);
    color: white;
    z-index: 1000;
    transition: transform 0.3s ease;
    overflow-y: auto;
}

.sidebar-header {
    padding: 1.75rem 1.5rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.logo {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--accent-color);
}

.logo i {
    font-size: 2rem;
}

/* Logo image styling - compatible with SVG, JPG, and PNG formats */
.logo-image {
    height: 60px;
    width: auto;
    max-width: 180px;
    object-fit: contain;
    display: block;
    background-color: #ffffff;
    padding: 10px 16px;
    border-radius: 10px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

/* SVG-specific optimizations */
.logo-image[src$=".svg"] {
    height: 60px;
    width: auto;
}

/* PNG logo with white background */
.logo-image[src$=".png"] {
    height: 50px;
    padding: 12px 18px;
}

/* Sidebar logo adjustments - larger logo for dashboard */
.sidebar-header .logo-image {
    height: 175px;
    width: auto;
    max-width: 280px;
    background-color: #ffffff;
    padding: 20px 28px;
    border-radius: 14px;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.12);
}

/* PNG sidebar logo */
.sidebar-header .logo-image[src$=".png"] {
    height: 150px;
    padding: 24px 32px;
}

/* JPG logo styling */
.logo-image[src$=".jpg"],
.logo-image[src$=".jpeg"] {
    height: 50px;
    padding: 10px 16px;
    border-radius: 10px;
}

/* JPG sidebar logo */
.sidebar-header .logo-image[src$=".jpg"],
.sidebar-header .logo-image[src$=".jpeg"] {
    height: 150px;
    padding: 20px 28px;
}

.sidebar-toggle {
    background: none;
    border: none;
    color: white;
    font-size: 1.25rem;
    cursor: pointer;
    display: none;
}

.sidebar-nav {
    padding: 1rem 0;
}

.nav-menu {
    list-style: none;
}

.nav-item {
    margin-bottom: 0.25rem;
}

.nav-link {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.875rem 1.5rem;
    color: rgba(255, 255, 255, 0.8);
    text-decoration: none;
    transition: all 0.3s ease;
    border-left: 3px solid transparent;
}

.nav-link:hover {
    background: rgba(255, 255, 255, 0.1);
    color: white;
}

.nav-item.active .nav-link {
    background: rgba(74, 103, 65, 0.2);
    color: var(--accent-color);
    border-left-color: var(--accent-color);
}

.nav-link i {
    width: 20px;
    text-align: center;
}

/* Main Content */
.main-content {
    margin-left: 280px;
    width: calc(100% - 280px);
    min-height: 100vh;
    transition: margin-left 0.3s ease, width 0.3s ease;
}

/* Impersonation Banner - Compact floating style */
.impersonation-banner {
    position: fixed;
    top: 12px;
    right: 20px;
    left: auto;
    background: linear-gradient(135deg, var(--warning-color, #d4a056) 0%, #c48d3f 100%);
    color: #ffffff;
    padding: 0.5rem 1rem;
    border-radius: 8px;
    z-index: 10004;
    box-shadow: 0 4px 12px rgba(196, 141, 63, 0.4), 0 2px 4px rgba(0, 0, 0, 0.1);
    max-width: 400px;
    animation: slideInRight 0.3s ease-out;
}

@keyframes slideInRight {
    from {
        transform: translateX(100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

.impersonation-content {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 0.85rem;
    font-weight: 500;
}

.impersonation-content i.fa-user-secret {
    font-size: 1rem;
    opacity: 0.9;
}

.impersonation-content strong {
    font-weight: 600;
}

.btn-end-impersonation {
    background: rgba(255, 255, 255, 0.25);
    color: #ffffff;
    border: 1px solid rgba(255, 255, 255, 0.4);
    padding: 4px 10px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.75rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 4px;
    margin-left: 8px;
    transition: all 0.2s ease;
    white-space: nowrap;
}

.btn-end-impersonation:hover {
    background: rgba(255, 255, 255, 0.4);
    border-color: #ffffff;
}

.btn-end-impersonation i {
    font-size: 0.8rem;
}

/* End Session button in impersonation banner */
.impersonation-end-btn {
    background: rgba(255, 255, 255, 0.25);
    color: #ffffff;
    border: 1px solid rgba(255, 255, 255, 0.4);
    padding: 6px 12px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.8rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 6px;
    transition: all 0.2s ease;
    white-space: nowrap;
}

.impersonation-end-btn:hover {
    background: rgba(255, 255, 255, 0.4);
    border-color: #ffffff;
}

.impersonation-end-btn i {
    font-size: 0.75rem;
}

@media (max-width: 768px) {
    .impersonation-banner {
        top: auto;
        bottom: 70px;
        right: 10px;
        left: 10px;
        max-width: none;
    }
}

/* Header */
.header {
    width: 100%;
    background: var(--bg-primary);
    padding: 1rem 2rem;
    box-shadow: var(--shadow);
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: sticky;
    top: 0;
    z-index: 100;
}

.header-left {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.menu-toggle {
    background: none;
    border: none;
    font-size: 1.25rem;
    color: var(--text-primary);
    cursor: pointer;
    display: none;
}

.search-box {
    position: relative;
    display: flex;
    align-items: center;
}

.search-box i {
    position: absolute;
    left: 1rem;
    color: var(--text-light);
}

.search-box input {
    padding: 0.75rem 1rem 0.75rem 2.5rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    background: #ffffff;
    color: #1f2937;
    width: 300px;
    font-size: 0.875rem;
}

.search-box input::placeholder {
    color: #9ca3af;
}

.search-box input:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.1);
}

.header-right {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.notifications {
    position: relative;
}

.notification-btn {
    background: none;
    border: none;
    font-size: 1.25rem;
    color: var(--text-primary);
    cursor: pointer;
    position: relative;
}

.notification-badge {
    position: absolute;
    top: -5px;
    right: -5px;
    background: var(--error-color);
    color: white;
    font-size: 0.75rem;
    padding: 0.25rem 0.5rem;
    border-radius: 50%;
    min-width: 20px;
    text-align: center;
}

/* Notification Dropdown Panel */
.notification-dropdown {
    position: absolute;
    top: 100%;
    right: 0;
    width: 360px;
    max-height: 480px;
    background: #ffffff;
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
    z-index: 1100;
    display: none;
    overflow: hidden;
    margin-top: 10px;
}

.notification-dropdown.show {
    display: block;
    animation: slideDown 0.2s ease;
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.notification-dropdown-header {
    padding: 16px 20px;
    border-bottom: 1px solid #e5e7eb;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: #f9fafb;
}

.notification-dropdown-header h3 {
    font-size: 16px;
    font-weight: 600;
    color: #1f2937;
    margin: 0;
}

.notification-dropdown-header .mark-all-read {
    font-size: 13px;
    color: var(--primary-color);
    cursor: pointer;
    background: none;
    border: none;
    padding: 4px 8px;
    border-radius: 4px;
    transition: background 0.2s;
}

.notification-dropdown-header .mark-all-read:hover {
    background: rgba(30, 58, 95, 0.1);
}

.notification-dropdown-list {
    max-height: 360px;
    overflow-y: auto;
}

.notification-dropdown-item {
    padding: 14px 20px;
    border-bottom: 1px solid #f3f4f6;
    cursor: pointer;
    transition: background 0.2s;
    display: flex;
    gap: 12px;
    align-items: flex-start;
}

.notification-dropdown-item:hover {
    background: #f9fafb;
}

.notification-dropdown-item.unread {
    background: #eff6ff;
}

.notification-dropdown-item.unread:hover {
    background: #dbeafe;
}

.notification-dropdown-item .notification-icon {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 14px;
}

.notification-dropdown-item .notification-icon.info {
    background: #dbeafe;
    color: #2563eb;
}

.notification-dropdown-item .notification-icon.success {
    background: #d1fae5;
    color: #059669;
}

.notification-dropdown-item .notification-icon.warning {
    background: #fef3c7;
    color: #d97706;
}

.notification-dropdown-item .notification-icon.alert {
    background: #fee2e2;
    color: #dc2626;
}

.notification-dropdown-item .notification-content {
    flex: 1;
    min-width: 0;
}

.notification-dropdown-item .notification-title {
    font-size: 14px;
    font-weight: 500;
    color: #1f2937;
    margin-bottom: 4px;
    line-height: 1.4;
}

.notification-dropdown-item .notification-message {
    font-size: 13px;
    color: #6b7280;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.notification-dropdown-item .notification-time {
    font-size: 11px;
    color: #9ca3af;
    margin-top: 6px;
}

.notification-dropdown-empty {
    padding: 40px 20px;
    text-align: center;
    color: #9ca3af;
}

.notification-dropdown-empty i {
    font-size: 40px;
    margin-bottom: 12px;
    color: #d1d5db;
}

.notification-dropdown-empty p {
    font-size: 14px;
}

.notification-dropdown-footer {
    padding: 12px 20px;
    border-top: 1px solid #e5e7eb;
    text-align: center;
    background: #f9fafb;
}

.notification-dropdown-footer a {
    font-size: 13px;
    color: var(--primary-color);
    text-decoration: none;
    font-weight: 500;
}

.notification-dropdown-footer a:hover {
    text-decoration: underline;
}

/* Notification Dropdown - Responsive */
@media (max-width: 480px) {
    .notification-dropdown {
        position: fixed;
        top: auto;
        bottom: 0;
        left: 0;
        right: 0;
        width: 100%;
        max-height: 70vh;
        border-radius: 16px 16px 0 0;
        margin-top: 0;
    }

    .notification-dropdown-header {
        padding: 12px 16px;
    }

    .notification-dropdown-header h3 {
        font-size: 15px;
    }

    .notification-dropdown-item {
        padding: 12px 16px;
    }

    .notification-dropdown-item .notification-icon {
        width: 32px;
        height: 32px;
        font-size: 14px;
    }

    .notification-dropdown-item .notification-title {
        font-size: 13px;
    }

    .notification-dropdown-item .notification-message {
        font-size: 12px;
    }
}

@media (min-width: 481px) and (max-width: 768px) {
    .notification-dropdown {
        width: min(360px, calc(100vw - 40px));
        right: 10px;
    }
}

.user-profile {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    cursor: pointer;
    padding: 0.5rem;
    border-radius: var(--radius);
    transition: background 0.3s ease;
    position: relative;
}

.user-profile:hover {
    background: var(--bg-secondary);
}

.user-profile:hover .user-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.user-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    overflow: hidden;
}

.avatar-placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.25rem;
}

.user-info {
    display: flex;
    flex-direction: column;
}

.user-name {
    font-weight: 600;
    font-size: 0.875rem;
}

.user-role {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

/* User Dropdown */
.user-dropdown {
    position: absolute;
    top: 100%;
    right: 0;
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
    min-width: 240px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all 0.3s ease;
    z-index: 1100;
    margin-top: 0.5rem;
    overflow: hidden;
    border: 1px solid var(--border-color);
}

/* Dropdown Header with User Info */
.dropdown-header {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    padding: 1rem;
    background: linear-gradient(135deg, rgba(74, 103, 65, 0.08), rgba(92, 122, 82, 0.04));
}

.dropdown-avatar {
    width: 42px;
    height: 42px;
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1rem;
}

.dropdown-user-details {
    display: flex;
    flex-direction: column;
}

.dropdown-user-name {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--text-primary);
}

.dropdown-user-role {
    font-size: 0.75rem;
    color: var(--text-secondary);
    text-transform: capitalize;
}

.dropdown-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 0.875rem;
    color: var(--text-primary);
}

.dropdown-item:hover {
    background: var(--bg-secondary);
}

.dropdown-item i {
    width: 18px;
    text-align: center;
    color: var(--text-secondary);
    font-size: 0.9rem;
}

.dropdown-item:hover i {
    color: var(--primary-color);
}

/* Impersonation Item */
.dropdown-item-impersonation {
    background: linear-gradient(135deg, #fef3c7, #fde68a);
    color: #92400e !important;
    border-top: 1px solid #fcd34d;
    border-bottom: 1px solid #fcd34d;
}

.dropdown-item-impersonation i {
    color: #d97706 !important;
}

.dropdown-item-impersonation:hover {
    background: linear-gradient(135deg, #fde68a, #fcd34d);
}

/* Logout Item */
.dropdown-item-logout {
    color: var(--error-color);
}

.dropdown-item-logout i {
    color: var(--error-color);
}

.dropdown-item-logout:hover {
    background: #fef2f2;
}

.dropdown-divider {
    height: 1px;
    background: var(--border-color);
    margin: 0;
}

/* Content */
.content {
    width: 100%;
    padding: 2rem;
    max-width: 1600px;
    margin-left: auto;
    margin-right: auto;
    overflow-x: hidden;
    box-sizing: border-box;
}

.content-section {
    display: none;
    width: 100%;
}

.content-section.active {
    display: block;
    width: 100%;
}

.page-header {
    margin-bottom: 2rem;
}

.page-header h1 {
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
}

.page-header p {
    color: var(--text-secondary);
    font-size: 1rem;
}

/* Stats Grid */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(250px, 100%), 1fr));
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.stat-card {
    background: var(--bg-primary);
    padding: 1.5rem;
    border-radius: 16px;
    border: 1px solid var(--border-color);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
    display: flex;
    align-items: center;
    gap: 1rem;
    position: relative;
    overflow: hidden;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.stat-card::before {
    content: '';
    display: block;
    height: 4px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
}

.stats-grid .stat-card:nth-child(6n+1)::before { background: linear-gradient(90deg, #0ea5e9, #06b6d4); }
.stats-grid .stat-card:nth-child(6n+2)::before { background: linear-gradient(90deg, #f59e0b, #fbbf24); }
.stats-grid .stat-card:nth-child(6n+3)::before { background: linear-gradient(90deg, #8b5cf6, #a78bfa); }
.stats-grid .stat-card:nth-child(6n+4)::before { background: linear-gradient(90deg, #10b981, #34d399); }
.stats-grid .stat-card:nth-child(6n+5)::before { background: linear-gradient(90deg, #ec4899, #f472b6); }
.stats-grid .stat-card:nth-child(6n+6)::before { background: linear-gradient(90deg, #6366f1, #818cf8); }

.stat-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.1);
}

.stat-icon {
    width: 60px;
    height: 60px;
    min-width: 60px;
    flex-shrink: 0;
    background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.5rem;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
}

.stat-content h3 {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
    font-weight: 500;
}

.stat-number {
    font-size: 2rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
}

.stat-change {
    font-size: 0.75rem;
    font-weight: 500;
}

.stat-change.positive {
    color: var(--primary-color);
}

.stat-change.warning {
    color: var(--warning-color);
}

.stat-change.info {
    color: var(--info-color);
}

/* Empty state styling for stat cards */
.stat-card.empty-data {
    opacity: 0.85;
    border: 2px dashed var(--border-color);
}

.stat-card.empty-data .stat-icon {
    background: linear-gradient(135deg, #9ca3af, #6b7280);
    opacity: 0.7;
}

.stat-card.empty-data .stat-number {
    color: #9ca3af;
    font-style: italic;
}

.stat-change.empty {
    color: #9ca3af;
    font-style: italic;
}

/* ========== Vibrant Card System (shared across dashboards) ========== */

.vibrant-empty,
.content-section .empty-state:not(.empty-state-message) {
    text-align: center;
    padding: 2.5rem 1.5rem;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    border-radius: 14px;
    border: 1px dashed var(--border-color);
}

.vibrant-empty i,
.content-section .empty-state:not(.empty-state-message) i {
    font-size: 2.25rem;
    margin-bottom: 1rem;
    opacity: 0.35;
    display: block;
    color: #0ea5e9;
}

.vibrant-empty p,
.content-section .empty-state:not(.empty-state-message) p {
    margin: 0 0 0.35rem;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
}

.vibrant-empty span,
.content-section .empty-state:not(.empty-state-message) span {
    font-size: 0.85rem;
    opacity: 0.8;
}

/* Vibrant panel cards (overview sections, chart wrappers) */
.vibrant-panel,
.chart-card,
.analytics-card,
.role-dashboard .card,
.overview-card {
    position: relative;
    overflow: hidden;
    background: var(--bg-primary);
    border-radius: 16px;
    border: 1px solid var(--border-color);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.vibrant-panel::before,
.chart-card::before,
.analytics-card::before,
.role-dashboard .card::before,
.overview-card::before {
    content: '';
    display: block;
    height: 4px;
    background: linear-gradient(90deg, #0ea5e9, #06b6d4);
}

.chart-card:hover,
.analytics-card:hover,
.role-dashboard .card:hover,
.overview-card:hover {
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

/* Vibrant entity cards (people, orgs, listings) */
.vibrant-entity-card,
.hr-domain-card,
.employee-card,
.region-summary-card,
#chief-field-officer-dashboard .officer-card {
    position: relative;
    overflow: hidden;
    background: var(--bg-primary);
    border-radius: 18px;
    border: 1px solid var(--border-color);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.vibrant-entity-card::before,
.hr-domain-card::before,
.employee-card::before,
.region-summary-card::before,
#chief-field-officer-dashboard .officer-card::before {
    content: '';
    display: block;
    height: 4px;
    background: linear-gradient(90deg, #0ea5e9, #06b6d4);
}

.vibrant-entity-card:hover,
.hr-domain-card:hover,
.employee-card:hover,
.region-summary-card:hover,
#chief-field-officer-dashboard .officer-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 28px rgba(14, 165, 233, 0.12);
    border-color: rgba(14, 165, 233, 0.25);
}

/* Dashboard accent overrides */
#hr-dashboard .hr-domain-card::before { background: linear-gradient(90deg, #ec4899, #f472b6); }
#hr-dashboard .hr-domain-card:hover { box-shadow: 0 12px 28px rgba(236, 72, 153, 0.12); border-color: rgba(236, 72, 153, 0.25); }

#chief-field-officer-dashboard .officer-card::before { background: linear-gradient(90deg, #0d9488, #14b8a6); }
#chief-field-officer-dashboard .officer-card:hover { box-shadow: 0 12px 28px rgba(13, 148, 136, 0.15); border-color: rgba(13, 148, 136, 0.3); }

#board-dashboard .region-summary-card::before { background: linear-gradient(90deg, #6366f1, #818cf8); }
#board-dashboard .region-summary-card:hover { box-shadow: 0 12px 28px rgba(99, 102, 241, 0.12); border-color: rgba(99, 102, 241, 0.25); }

#cooperative_dashboard .overview-card::before,
#cooperative_dashboard .cooperative-card::before { background: linear-gradient(90deg, #b45309, #f59e0b); }

#vendor_dashboard .overview-card::before { background: linear-gradient(90deg, #d97706, #f59e0b); }

#ceo_dashboard .role-dashboard .card::before { background: linear-gradient(90deg, #8b5cf6, #a78bfa); }

#admin-dashboard .chart-card::before { background: linear-gradient(90deg, #6366f1, #818cf8); }

/* Empty state general styling */
.empty-state-message {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    text-align: center;
    color: var(--text-secondary);
}

.empty-state-message i {
    font-size: 3rem;
    color: #d1d5db;
    margin-bottom: 1rem;
}

.empty-state-message h4 {
    color: #6b7280;
    margin-bottom: 0.5rem;
    font-weight: 500;
}

.empty-state-message p {
    color: #9ca3af;
    font-size: 0.875rem;
}

/* Weather forecast empty state */
.weather-forecast.empty-data {
    background: #f9fafb;
    border: 2px dashed var(--border-color);
    border-radius: var(--radius-md);
    min-height: 100px;
}

.weather-forecast.empty-data .weather-day {
    display: none;
}

/* Recent activities empty state */
.recent-activities.empty-data .activities-list,
.activities-list.empty-data {
    background: #f9fafb;
    border: 2px dashed var(--border-color);
    border-radius: var(--radius-md);
    min-height: 150px;
}

/* Chart empty state styling */
.chart-container.empty-data {
    background: #f9fafb;
    border: 2px dashed var(--border-color);
}

.chart-container.empty-data canvas {
    opacity: 0.5;
}

/* Dashboard Grid */
.dashboard-grid {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.chart-container {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow: hidden;
}

.chart-header {
    padding: 1.5rem;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.chart-header h3 {
    font-size: 1.125rem;
    font-weight: 600;
}

.chart-controls select {
    padding: 0.5rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    background: var(--bg-primary);
    font-size: 0.875rem;
}

.chart-placeholder {
    padding: 1.5rem;
    height: 300px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-secondary);
}

/* Weather Forecast */
.weather-forecast {
    padding: 1.5rem;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}

.weather-day {
    text-align: center;
    padding: 1rem;
    background: var(--bg-secondary);
    border-radius: var(--radius);
}

.day {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
}

.weather-icon {
    font-size: 2rem;
    margin-bottom: 0.5rem;
}

.temp {
    font-size: 1.125rem;
    font-weight: 600;
}

/* Activities Section */
.activities-section {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow: hidden;
}

.section-header {
    padding: 1.5rem;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.section-header h3 {
    font-size: 1.125rem;
    font-weight: 600;
}

.view-all {
    color: var(--primary-color);
    text-decoration: none;
    font-size: 0.875rem;
    font-weight: 500;
}

.view-all:hover {
    text-decoration: underline;
}

.activities-list {
    padding: 1.5rem;
}

.activity-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 0;
    border-bottom: 1px solid var(--border-color);
}

.activity-item:last-child {
    border-bottom: none;
}

.activity-icon {
    width: 40px;
    height: 40px;
    background: var(--bg-secondary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--primary-color);
}

.activity-content {
    flex: 1;
}

.activity-content h4 {
    font-size: 0.875rem;
    font-weight: 600;
    margin-bottom: 0.25rem;
}

.activity-content p {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.activity-status {
    padding: 0.25rem 0.75rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 500;
}

.activity-status.success {
    background: rgba(16, 185, 129, 0.1);
    color: var(--primary-color);
}

.activity-status.warning {
    background: rgba(245, 158, 11, 0.1);
    color: var(--warning-color);
}

.activity-status.info {
    background: rgba(59, 130, 246, 0.1);
    color: var(--info-color);
}

/* Coming Soon */
.coming-soon {
    text-align: center;
    padding: 4rem 2rem;
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
}

.coming-soon i {
    font-size: 4rem;
    color: var(--primary-color);
    margin-bottom: 1rem;
}

.coming-soon h2 {
    font-size: 1.5rem;
    margin-bottom: 1rem;
}

.coming-soon p {
    color: var(--text-secondary);
    max-width: 400px;
    margin: 0 auto;
}

/* Responsive Design */
@media (max-width: 1024px) {
    .dashboard-grid {
        grid-template-columns: 1fr;
    }
    
    .weather-forecast {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .sidebar {
        transform: translateX(-100%);
    }

    .sidebar.open {
        transform: translateX(0);
    }

    .main-content {
        margin-left: 0;
        width: 100%;
    }

    .sidebar-header {
        padding: 1rem;
    }

    .sidebar-header .logo-image {
        height: 100px;
        max-width: 200px;
    }

    .sidebar-header .logo-image[src$=".png"] {
        height: 90px;
        padding: 12px 16px;
    }

    .menu-toggle {
        display: block;
    }

    .sidebar-toggle {
        display: block;
    }

    .search-box input {
        width: 200px;
    }

    .stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .weather-forecast {
        grid-template-columns: 1fr;
    }

    .content {
        padding: 1rem;
        width: 100%;
    }

    .header {
        padding: 1rem;
    }
}

@media (max-width: 480px) {
    .stats-grid {
        grid-template-columns: 1fr;
    }

    .search-box input {
        width: 140px;
    }
}

/* Button Styles */
.btn {
    padding: 0.75rem 1.5rem;
    border: none;
    border-radius: var(--radius);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: background-color 0.3s ease, color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    text-decoration: none;
}

.btn:focus-visible {
    outline: 2px solid var(--primary-color);
    outline-offset: 2px;
}

.btn-primary {
    background: var(--primary-color);
    color: white;
}

.btn-primary:hover {
    background: var(--secondary-color);
    transform: translateY(-1px);
}

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

.btn-secondary:hover {
    background: var(--border-color);
}

.btn-icon {
    background: none;
    border: none;
    padding: 0.5rem;
    border-radius: var(--radius);
    cursor: pointer;
    color: var(--text-secondary);
    transition: all 0.3s ease;
}

.btn-icon:hover {
    background: var(--bg-secondary);
    color: var(--primary-color);
}

/* Section Actions */
.section-actions {
    display: flex;
    gap: 1rem;
    margin-bottom: 2rem;
    align-items: center;
    flex-wrap: wrap;
}

/* Crops Grid */
.crops-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
    gap: 1.5rem;
    margin-top: 2rem;
}

.crop-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.crop-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.crop-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border-color);
}

.crop-header h1 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-primary);
    margin: 0;
    flex: 1;
}

.plant-id-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    background: linear-gradient(135deg, #22c55e, #16a34a);
    color: white;
    border-radius: 50%;
    font-size: 0.75rem;
    margin-left: 8px;
    box-shadow: 0 2px 4px rgba(22, 163, 74, 0.3);
}

.crop-details {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.crop-details .detail-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem 0;
}

.crop-details .detail-item .label {
    font-weight: 500;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.crop-details .detail-item .value {
    color: var(--text-primary);
    font-weight: 600;
    font-size: 0.875rem;
}

.crop-actions {
    display: flex;
    gap: 0.75rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
    justify-content: flex-end;
}

.crop-image {
    width: 60px;
    height: 60px;
    min-width: 60px;
    background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.5rem;
    flex-shrink: 0;
}

.crop-info {
    flex: 1;
    min-width: 0;
}

.crop-info h3 {
    font-size: 1.125rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
    color: var(--text-primary);
}

.crop-info p {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 0.75rem;
    line-height: 1.5;
}

.crop-status {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.status-badge {
    padding: 0.25rem 0.75rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 500;
}

.status-badge.growing {
    background: rgba(16, 185, 129, 0.1);
    color: var(--primary-color);
}

.status-badge.ready {
    background: rgba(245, 158, 11, 0.1);
    color: var(--warning-color);
}

.status-badge.planted {
    background: rgba(59, 130, 246, 0.1);
    color: var(--info-color);
}

.status-badge.healthy {
    background: rgba(16, 185, 129, 0.1);
    color: var(--primary-color);
}

.status-badge.sick {
    background: rgba(239, 68, 68, 0.1);
    color: var(--error-color);
}

.status-badge.active {
    background: rgba(16, 185, 129, 0.1);
    color: var(--primary-color);
}

.status-badge.maintenance {
    background: rgba(245, 158, 11, 0.1);
    color: var(--warning-color);
}

.progress-text {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.crop-actions {
    display: flex;
    gap: 0.5rem;
}

/* Livestock Stats */
.livestock-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(250px, 100%), 1fr));
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.livestock-stat {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
    display: flex;
    align-items: center;
    gap: 1rem;
}

.livestock-stat .stat-icon {
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.5rem;
}

.stat-info h3 {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 0.25rem;
}

.stat-info .stat-number {
    font-size: 2rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
}

.stat-detail {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.livestock-dashboard-panel {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow: hidden;
}

.livestock-cards-header {
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.livestock-cards-header h3 {
    font-size: 1.125rem;
    margin: 0 0 0.25rem 0;
}

.livestock-cards-header p {
    margin: 0;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.livestock-cards-actions {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.livestock-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1rem;
    padding: 1.25rem;
}

.livestock-card {
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 1rem;
    background: #ffffff;
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.livestock-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.livestock-card-title {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.livestock-card-title i {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    background: rgba(16, 185, 129, 0.14);
    color: #10b981;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.livestock-card-title h4 {
    margin: 0;
    font-size: 1rem;
    color: var(--text-primary);
}

.livestock-card-title p {
    margin: 0;
    color: var(--text-secondary);
    font-size: 0.8rem;
}

.livestock-card-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
}

.livestock-card-meta .detail-item {
    margin: 0;
    padding: 0.55rem 0.6rem;
    border-radius: 8px;
    background: #f9fafb;
}

.livestock-card-meta .label {
    display: block;
    font-size: 0.72rem;
    color: var(--text-secondary);
    margin-bottom: 0.2rem;
}

.livestock-card-meta .value {
    color: var(--text-primary);
    font-size: 0.88rem;
    font-weight: 600;
}

.livestock-note-preview {
    padding: 0.65rem;
    border-radius: 8px;
    border: 1px dashed #d1d5db;
    background: #f9fafb;
}

.livestock-note-preview .note-title {
    font-size: 0.78rem;
    color: var(--text-secondary);
    margin-bottom: 0.25rem;
}

.livestock-note-preview .note-body {
    font-size: 0.84rem;
    color: var(--text-primary);
    margin: 0;
}

.livestock-card-actions {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.livestock-notes-list {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    margin-top: 0.65rem;
}

.livestock-note-item {
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    background: #f9fafb;
    padding: 0.65rem 0.75rem;
}

.livestock-note-item .meta {
    color: #6b7280;
    font-size: 0.75rem;
    margin-bottom: 0.25rem;
}

/* Crop details dashboard — modal scroll area & sections */
.crop-management-modal .crop-dashboard-body {
    flex: 1;
    overflow: auto;
    padding: 1.25rem 1.5rem;
    background: var(--bg-secondary);
}

.crop-dashboard-description-banner {
    margin-bottom: 1rem;
    padding: 0.85rem 1rem;
    border-radius: var(--radius);
    border: 1px solid var(--border-color);
    border-left: 4px solid var(--primary-color);
    background: var(--bg-primary);
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(0, 0, 0, 0.06));
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.crop-dashboard-description-banner strong {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-secondary);
}

.crop-dashboard-description-banner span {
    font-size: 0.9rem;
    color: var(--text-primary);
    line-height: 1.45;
}

.crop-dashboard-card {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 1.15rem 1.25rem;
    margin-bottom: 1rem;
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(0, 0, 0, 0.06));
}

.crop-dashboard-card:last-child {
    margin-bottom: 0;
}

.crop-dashboard-section-title {
    margin: 0 0 1rem;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.crop-dashboard-section-title i {
    width: 32px;
    height: 32px;
    border-radius: 10px;
    background: rgba(16, 185, 129, 0.14);
    color: #10b981;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
}

.crop-dashboard-metric-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.crop-dashboard-metric {
    padding: 0.85rem 1rem;
    border-radius: var(--radius);
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
}

.crop-dashboard-metric-label {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    margin-bottom: 0.35rem;
}

.crop-dashboard-metric-value {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--text-primary);
}

.crop-dashboard-detail-panel {
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--bg-primary);
}

.crop-dashboard-detail-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 1rem;
    padding: 0.65rem 1rem;
    border-bottom: 1px solid var(--border-color);
}

.crop-dashboard-detail-row--last {
    border-bottom: none;
}

.crop-dashboard-detail-label {
    font-size: 0.875rem;
    color: var(--text-secondary);
    flex-shrink: 0;
}

.crop-dashboard-detail-value {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text-primary);
    text-align: right;
}

.crop-dashboard-unit-form {
    margin: 0;
}

.crop-dashboard-form-row-responsive {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1rem;
}

.crop-dashboard-form-group-compact {
    margin-bottom: 0;
}

.crop-dashboard-form-actions-inline {
    margin-top: 0.75rem;
    justify-content: flex-start;
}

.crop-dashboard-select {
    width: 100%;
    max-width: 140px;
    padding: 0.35rem 0.5rem;
    border-radius: var(--radius);
    border: 1px solid var(--border-color);
    font-size: 0.8125rem;
    background: #fff;
    color: #1f2937;
}

.crop-dashboard-select:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(16, 185, 129, 0.15);
}

.crop-dashboard-table-card .crop-dashboard-section-title {
    margin-bottom: 0.75rem;
}

.crop-dashboard-table-scroll {
    max-height: 280px;
    overflow: auto;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    background: var(--bg-secondary);
}

.crop-dashboard-table {
    margin: 0;
}

.crop-dashboard-table-empty {
    text-align: center;
    color: var(--text-secondary);
    padding: 1.25rem !important;
}

.crop-dashboard-health-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
    gap: 0.65rem;
}

.crop-dashboard-health-tile {
    padding: 0.85rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    background: var(--bg-secondary);
}

.crop-dashboard-health-label {
    font-size: 0.8rem;
    color: var(--text-secondary);
    text-transform: capitalize;
    margin-bottom: 0.25rem;
}

.crop-dashboard-health-count {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--text-primary);
}

.crop-dashboard-timeline {
    max-height: 320px;
    overflow-y: auto;
    padding-right: 0.25rem;
}

.crop-dashboard-timeline-item {
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--border-color);
}

.crop-dashboard-timeline-item:last-child {
    border-bottom: none;
}

.crop-dashboard-timeline-title {
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
}

.crop-dashboard-timeline-meta {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.crop-dashboard-note-block {
    padding: 0.75rem 0.85rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    margin-bottom: 0.65rem;
    background: var(--bg-secondary);
}

.crop-dashboard-note-meta {
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-bottom: 0.35rem;
}

.crop-dashboard-note-body {
    font-size: 0.875rem;
    color: var(--text-primary);
    line-height: 1.45;
}

.crop-dashboard-notes-form .crop-dashboard-form-actions-inline {
    margin-top: 0.65rem;
}

.crop-dashboard-notes-list {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.crop-dashboard-empty-msg {
    margin: 0;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.crop-dashboard-hint {
    margin-bottom: 1rem;
}

.crop-dashboard-hint p {
    margin: 0;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

@media (max-width: 640px) {
    .crop-dashboard-detail-row {
        flex-direction: column;
        align-items: flex-start;
    }

    .crop-dashboard-detail-value {
        text-align: left;
    }
}

/* Tables */
.livestock-table,
.equipment-table {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow: hidden;
}

.table-header {
    padding: 1.5rem;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.table-header h3 {
    font-size: 1.125rem;
    font-weight: 600;
}

.table-container {
    overflow-x: auto;
}

table {
    width: 100%;
    border-collapse: collapse;
}

table th,
table td {
    padding: 1rem;
    text-align: left;
    border-bottom: 1px solid var(--border-color);
}

table th {
    background: var(--bg-secondary);
    font-weight: 600;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

table td {
    font-size: 0.875rem;
}

table tr:hover {
    background: var(--bg-secondary);
}

/* Weather Grid */
.weather-grid {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 1.5rem;
    margin-bottom: 2rem;
}

/* Farm location weather cards (per GPS on farm record) */
.weather-farms-section {
    margin-bottom: 1.75rem;
}

.weather-farms-header h3 {
    font-size: 1.125rem;
    font-weight: 600;
    margin: 0 0 0.35rem 0;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.weather-farms-header h3 i {
    color: var(--primary-color);
}

.weather-farms-sub {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin: 0 0 1rem 0;
    max-width: 48rem;
    line-height: 1.5;
}

.weather-farm-cards {
    min-height: 4rem;
}

.weather-farm-cards-inner {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 1rem;
}

.weather-farm-cards-state {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem 1.25rem;
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    color: var(--text-secondary);
    font-size: 0.9rem;
}

.weather-farm-cards-state.weather-farm-cards-empty {
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
}

.weather-farm-cards-empty i {
    font-size: 1.5rem;
    color: var(--primary-color);
    margin-bottom: 0.25rem;
}

.weather-farm-cards-empty p {
    margin: 0;
    max-width: 36rem;
    line-height: 1.5;
}

.weather-farm-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1rem 1.1rem 0.85rem;
    border: 1px solid rgba(74, 103, 65, 0.12);
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.weather-farm-card--error {
    border-color: rgba(220, 38, 38, 0.25);
}

.weather-farm-card-top {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.weather-farm-card-title {
    font-size: 1rem;
    font-weight: 600;
    margin: 0;
    color: var(--text-primary);
    line-height: 1.25;
}

.weather-farm-card-coords {
    font-size: 0.7rem;
    color: var(--text-secondary);
    font-family: ui-monospace, monospace;
}

.weather-farm-card-body {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.weather-farm-card-icon {
    font-size: 2.5rem;
    line-height: 1;
}

.weather-farm-card-temp-block {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    min-width: 0;
}

.weather-farm-card-temp {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--text-primary);
}

.weather-farm-card-desc {
    font-size: 0.8rem;
    color: var(--text-secondary);
    line-height: 1.3;
}

.weather-farm-card-hilo {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.weather-farm-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.weather-farm-card-meta span {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.weather-farm-card-meta i {
    color: var(--primary-color);
    width: 0.9rem;
}

.weather-farm-card .btn-weather-farm-use {
    margin-top: 0.15rem;
    width: 100%;
    justify-content: center;
    font-size: 0.8rem;
}

.weather-farm-card-error-msg {
    margin: 0;
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.current-weather {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
}

.weather-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.5rem;
}

.weather-header h3 {
    font-size: 1.125rem;
    font-weight: 600;
}

.location {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.weather-main {
    text-align: center;
    margin-bottom: 1.5rem;
}

.weather-icon-large {
    font-size: 4rem;
    margin-bottom: 0.5rem;
}

.weather-temp {
    font-size: 3rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
}

.weather-desc {
    font-size: 1.125rem;
    color: var(--text-secondary);
}

.weather-details {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

.detail-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.detail-item i {
    color: var(--primary-color);
}

/* Weather Alerts */
.weather-alerts {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
}

.alert-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1rem;
}

.alert-header h3 {
    font-size: 1.125rem;
    font-weight: 600;
}

.alert-count {
    background: var(--error-color);
    color: white;
    padding: 0.25rem 0.75rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
}

.alert-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.alert-item {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 1rem;
    border-radius: var(--radius);
}

.alert-item.warning {
    background: rgba(245, 158, 11, 0.1);
    border-left: 3px solid var(--warning-color);
}

.alert-item.info {
    background: rgba(59, 130, 246, 0.1);
    border-left: 3px solid var(--info-color);
}

.alert-item i {
    font-size: 1.25rem;
    margin-top: 0.25rem;
}

.alert-item.warning i {
    color: var(--warning-color);
}

.alert-item.info i {
    color: var(--info-color);
}

.alert-content h4 {
    font-size: 0.875rem;
    font-weight: 600;
    margin-bottom: 0.25rem;
}

.alert-content p {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

/* Forecast Section */
.forecast-section {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
}

.forecast-section h3 {
    font-size: 1.125rem;
    font-weight: 600;
    margin-bottom: 1.5rem;
}

.forecast-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 1rem;
}

.forecast-day {
    text-align: center;
    padding: 1rem;
    background: var(--bg-secondary);
    border-radius: var(--radius);
    transition: transform 0.3s ease;
}

.forecast-day:hover {
    transform: translateY(-2px);
}

.day-name {
    font-size: 0.875rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.forecast-icon {
    font-size: 2rem;
    margin-bottom: 0.5rem;
}

.forecast-temps {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    margin-bottom: 0.25rem;
}

.high {
    font-weight: 600;
    color: var(--text-primary);
}

.low {
    color: var(--text-secondary);
}

.forecast-desc {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

/* Weather Farm Location Selector */
.weather-location-selector {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1rem 1.5rem;
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    flex-wrap: wrap;
}

.location-selector-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 600;
    color: var(--text-primary);
}

.location-selector-header i {
    color: var(--primary-color);
    font-size: 1.125rem;
}

.location-selector-controls {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex: 1;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.location-selector-controls select {
    padding: 0.625rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    background: var(--bg-secondary);
    color: var(--text-primary);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    min-width: 200px;
    max-width: 300px;
}

.location-selector-controls select:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(34, 197, 94, 0.2);
}

.selected-location-info {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.5rem 1rem;
    background: rgba(34, 197, 94, 0.1);
    border-radius: var(--radius);
    font-size: 0.813rem;
}

.location-detail {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    color: var(--text-secondary);
}

.location-detail:first-child {
    color: var(--primary-color);
    font-weight: 500;
}

@media (max-width: 768px) {
    .weather-location-selector {
        flex-direction: column;
        align-items: stretch;
    }

    .location-selector-controls {
        justify-content: stretch;
    }

    .location-selector-controls select {
        min-width: 100%;
        max-width: 100%;
    }

    .selected-location-info {
        justify-content: center;
    }
}

/* Weather Time Navigation */
.weather-time-nav {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1rem 1.5rem;
    margin-bottom: 1.5rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.time-nav-controls {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.time-nav-btn {
    width: 36px;
    height: 36px;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    border-radius: var(--radius);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    color: var(--text-primary);
}

.time-nav-btn:hover {
    background: var(--primary-color);
    color: white;
    border-color: var(--primary-color);
}

.time-nav-display {
    display: flex;
    gap: 0.5rem;
}

.time-nav-display select {
    padding: 0.5rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    background: var(--bg-secondary);
    color: var(--text-primary);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    min-width: 120px;
}

.time-nav-display select:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(34, 197, 94, 0.2);
}

.time-nav-quick {
    display: flex;
    gap: 0.5rem;
}

.quick-nav-btn {
    padding: 0.5rem 1rem;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    border-radius: var(--radius);
    font-size: 0.813rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--text-primary);
}

.quick-nav-btn:hover {
    background: var(--primary-color);
    color: white;
    border-color: var(--primary-color);
}

.quick-nav-btn.active {
    background: var(--primary-color);
    color: white;
    border-color: var(--primary-color);
}

/* Weather Period Indicator */
.weather-period-indicator {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    background: rgba(34, 197, 94, 0.1);
    border-left: 3px solid var(--primary-color);
    border-radius: var(--radius);
    margin-bottom: 1.5rem;
    font-size: 0.875rem;
}

.period-label {
    color: var(--text-secondary);
}

.period-value {
    font-weight: 600;
    color: var(--primary-color);
}

/* Monthly Summary Section */
.monthly-summary-section {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
    margin-top: 1.5rem;
}

.monthly-summary-section h3 {
    font-size: 1.125rem;
    font-weight: 600;
    margin-bottom: 1.5rem;
}

.monthly-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.monthly-stat-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    background: var(--bg-secondary);
    border-radius: var(--radius);
}

.monthly-stat-card .stat-icon {
    width: 48px;
    height: 48px;
    border-radius: var(--radius);
    background: rgba(34, 197, 94, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--primary-color);
    font-size: 1.25rem;
}

.monthly-stat-card .stat-info {
    display: flex;
    flex-direction: column;
}

.monthly-stat-card .stat-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.monthly-stat-card .stat-value {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--text-primary);
}

/* Monthly Weather Calendar */
.monthly-calendar {
    background: var(--bg-secondary);
    border-radius: var(--radius);
    padding: 1rem;
}

.calendar-header {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 0.5rem;
    margin-bottom: 0.5rem;
    text-align: center;
}

.calendar-header span {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    padding: 0.5rem;
}

.calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 0.5rem;
}

.calendar-day {
    aspect-ratio: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 0.5rem;
    border-radius: var(--radius);
    background: var(--bg-primary);
    cursor: pointer;
    transition: all 0.2s ease;
    min-height: 60px;
}

.calendar-day:hover {
    transform: scale(1.05);
    box-shadow: var(--shadow);
}

.calendar-day.today {
    border: 2px solid var(--primary-color);
}

.calendar-day.has-data {
    background: rgba(34, 197, 94, 0.05);
}

.calendar-day .date {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-primary);
}

.calendar-day .weather-icon {
    font-size: 1.25rem;
}

.calendar-day .temp {
    font-size: 0.625rem;
    color: var(--text-secondary);
}

.calendar-day.empty {
    background: transparent;
    cursor: default;
}

.calendar-day.empty:hover {
    transform: none;
    box-shadow: none;
}

/* Extended Forecast Section */
.extended-forecast-section {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
    margin-top: 1.5rem;
}

.extended-forecast-section h3 {
    font-size: 1.125rem;
    font-weight: 600;
    margin-bottom: 1.5rem;
}

.extended-forecast-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

.extended-month-card {
    background: var(--bg-secondary);
    border-radius: var(--radius);
    padding: 1.5rem;
    text-align: center;
}

.extended-month-card .month-name {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 1rem;
    color: var(--text-primary);
}

.extended-month-card .month-icon {
    font-size: 3rem;
    margin-bottom: 1rem;
}

.extended-month-card .month-temp {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
}

.extended-month-card .month-range {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 1rem;
}

.extended-month-card .month-details {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    font-size: 0.813rem;
    color: var(--text-secondary);
}

.extended-month-card .month-details span {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}

/* Responsive Weather Time Nav */
@media (max-width: 768px) {
    .weather-time-nav {
        flex-direction: column;
        align-items: stretch;
    }

    .time-nav-controls {
        justify-content: center;
    }

    .time-nav-quick {
        justify-content: center;
        flex-wrap: wrap;
    }

    .monthly-stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .extended-forecast-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    .time-nav-display select {
        min-width: 90px;
        padding: 0.5rem;
        font-size: 0.813rem;
    }

    .quick-nav-btn {
        padding: 0.5rem 0.75rem;
        font-size: 0.75rem;
    }

    .monthly-stats-grid {
        grid-template-columns: 1fr;
    }
}

/* Marketplace Tabs */
.marketplace-tabs {
    display: flex;
    gap: 0.75rem;
    margin-bottom: 2rem;
    background: var(--bg-primary);
    padding: 0.5rem;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.tab-btn {
    padding: 0.75rem 1.25rem;
    border: none;
    background: none;
    border-radius: var(--radius);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
    color: var(--text-secondary);
    white-space: nowrap;
    flex-shrink: 0;
}

.tab-btn.active {
    background: var(--primary-color);
    color: white;
}

.tab-content {
    display: none;
}

.tab-content.active {
    display: block;
}

/* Products Grid */
.products-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
    gap: 1.5rem;
}

.product-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.product-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.product-image {
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.5rem;
    margin-bottom: 1rem;
}

.product-info h3 {
    font-size: 1.125rem;
    font-weight: 600;
    margin-bottom: 0.25rem;
}

.product-info p {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
}

.product-price {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--primary-color);
    margin-bottom: 0.25rem;
}

.product-seller {
    font-size: 0.75rem;
    color: var(--text-light);
    margin-bottom: 1rem;
}

.product-actions {
    display: flex;
    gap: 0.5rem;
}

/* Sell Form */
.sell-form {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 2rem;
    max-width: 600px;
}

.sell-form h3 {
    font-size: 1.25rem;
    font-weight: 600;
    margin-bottom: 1.5rem;
}

.form-group {
    margin-bottom: 1.5rem;
}

.form-group label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    margin-bottom: 0.5rem;
    color: var(--text-primary);
}

.form-group input,
.form-group select,
.form-group textarea {
    width: 100%;
    padding: 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    font-size: 0.875rem;
    background: var(--bg-primary);
    color: #1f2937;
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(74, 103, 65, 0.1);
}

/* Ensure all form inputs have contrasting text color */
input,
select,
textarea {
    color: #1f2937;
}

input::placeholder,
textarea::placeholder {
    color: #6b7280;
    opacity: 1;
}

/* Specific overrides for various input backgrounds */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="tel"],
input[type="date"],
input[type="time"],
input[type="datetime-local"],
input[type="search"],
input[type="url"],
select,
textarea {
    background-color: #ffffff;
    color: #1f2937;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.1);
}

.form-group textarea {
    resize: vertical;
    min-height: 100px;
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.form-actions {
    display: flex;
    gap: 1rem;
    justify-content: flex-end;
    margin-top: 1.5rem;
}

.form-group small {
    display: block;
    margin-top: 0.25rem;
    color: var(--text-secondary);
    font-size: 0.75rem;
}

/* Equipment Grid */
.equipment-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(350px, 100%), 1fr));
    gap: 1.5rem;
}

.equipment-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.equipment-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.equipment-image {
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.5rem;
    margin-bottom: 1rem;
}

.equipment-info h3 {
    font-size: 1.125rem;
    font-weight: 600;
    margin-bottom: 0.25rem;
}

.equipment-info p {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
}

.equipment-price {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--primary-color);
    margin-bottom: 0.25rem;
}

.equipment-seller {
    font-size: 0.75rem;
    color: var(--text-light);
    margin-bottom: 1rem;
}

.equipment-actions {
    display: flex;
    gap: 0.5rem;
}

/* Analytics Grid */
.analytics-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(400px, 100%), 1fr));
    gap: 1.5rem;
}

.analytics-card {
    background: var(--bg-primary);
    border-radius: 16px;
    border: 1px solid var(--border-color);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
    overflow: hidden;
    position: relative;
}

.analytics-card::before {
    content: '';
    display: block;
    height: 4px;
    background: linear-gradient(90deg, #6366f1, #818cf8);
}

.analytics-header {
    padding: 1.5rem;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.analytics-header h3 {
    font-size: 1.125rem;
    font-weight: 600;
}

.analytics-header select {
    padding: 0.5rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    background: var(--bg-primary);
    font-size: 0.875rem;
}

.analytics-chart {
    padding: 1.5rem;
    height: 300px;
}

/* Equipment Overview */
.equipment-overview {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(250px, 100%), 1fr));
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.equipment-stat {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
    display: flex;
    align-items: center;
    gap: 1rem;
}

.equipment-stat .stat-icon {
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.5rem;
}

/* Reports Grid */
.reports-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
    gap: 1.5rem;
}

.report-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.report-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.report-icon {
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.5rem;
    margin-bottom: 1rem;
}

.report-info h3 {
    font-size: 1.125rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.report-info p {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 1rem;
}

.report-actions {
    display: flex;
    gap: 0.5rem;
}

/* Settings Grid */
.settings-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(350px, 100%), 1fr));
    gap: 1.5rem;
}

.settings-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow: hidden;
}

.settings-header {
    padding: 1.5rem;
    border-bottom: 1px solid var(--border-color);
    background: var(--bg-secondary);
}

.settings-header h3 {
    font-size: 1.125rem;
    font-weight: 600;
}

.settings-content {
    padding: 1.5rem;
}

.setting-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 0;
    border-bottom: 1px solid var(--border-color);
}

.setting-item:last-child {
    border-bottom: none;
}

/* Switch Toggle */
.switch {
    position: relative;
    display: inline-block;
    width: 50px;
    height: 24px;
}

.switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: var(--border-color);
    transition: 0.3s;
    border-radius: 24px;
}

.slider:before {
    position: absolute;
    content: "";
    height: 18px;
    width: 18px;
    left: 3px;
    bottom: 3px;
    background-color: white;
    transition: 0.3s;
    border-radius: 50%;
}

input:checked + .slider {
    background-color: var(--primary-color);
}

input:checked + .slider:before {
    transform: translateX(26px);
}

/* Responsive Design Updates */
@media (max-width: 1024px) {
    .dashboard-grid {
        grid-template-columns: 1fr;
    }
    
    .weather-grid {
        grid-template-columns: 1fr;
    }
    
    .forecast-grid {
        grid-template-columns: repeat(4, 1fr);
    }
    
    .analytics-grid {
        grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
    }
}

@media (max-width: 768px) {
    .sidebar {
        transform: translateX(-100%);
    }
    
    .sidebar.open {
        transform: translateX(0);
    }
    
    .main-content {
        margin-left: 0;
        width: 100%;
    }

    .menu-toggle {
        display: block;
    }

    .sidebar-toggle {
        display: block;
    }

    .search-box input {
        width: 200px;
    }

    .stats-grid {
        grid-template-columns: 1fr;
    }

    .weather-forecast {
        grid-template-columns: repeat(2, 1fr);
    }

    .forecast-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .content {
        padding: 1rem;
        width: 100%;
    }
    
    .header {
        padding: 1rem;
    }
    
    .crops-grid {
        grid-template-columns: 1fr;
    }
    
    .livestock-stats {
        grid-template-columns: 1fr;
    }

    .livestock-cards-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .livestock-cards-grid {
        grid-template-columns: 1fr;
    }
    
    .products-grid {
        grid-template-columns: 1fr;
    }
    
    .equipment-grid {
        grid-template-columns: 1fr;
    }
    
    .analytics-grid {
        grid-template-columns: 1fr;
    }
    
    .equipment-overview {
        grid-template-columns: 1fr;
    }
    
    .reports-grid {
        grid-template-columns: 1fr;
    }
    
    .settings-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    .search-box {
        display: none;
    }
    
    .user-info {
        display: none;
    }
    
    .stats-grid {
        gap: 1rem;
    }
    
    .stat-card {
        padding: 1rem;
    }
    
    .stat-icon {
        width: 50px;
        height: 50px;
        font-size: 1.25rem;
    }
    
    .stat-number {
        font-size: 1.5rem;
    }
    
    .forecast-grid {
        grid-template-columns: 1fr;
    }
    
    .weather-details {
        grid-template-columns: 1fr;
    }
    
    .section-actions {
        flex-direction: column;
    }
    
    .marketplace-tabs {
        flex-direction: column;
    }
    
    .product-actions,
    .equipment-actions,
    .report-actions {
        flex-direction: column;
    }
}

/* Farms Grid */
.farms-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(400px, 100%), 1fr));
    gap: 1.5rem;
    margin-top: 2rem;
}

.farm-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.farm-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.farm-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1rem;
}

.farm-header h3 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

.farm-map {
    border-radius: var(--radius);
    overflow: hidden;
    margin: 1rem 0;
}

.farm-details {
    margin: 1rem 0;
}

.farm-details .detail-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.farm-details .detail-item i {
    color: var(--primary-color);
    width: 20px;
}

.crop-details-modal {
    margin-top: 0.5rem;
    border-radius: 12px;
    overflow: hidden;
}

.crop-details-header {
    padding: 18px 20px;
    border-bottom: 2px solid #e5e7eb;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
    color: #ffffff;
}

.crop-details-header h2 {
    margin: 0 0 8px 0;
    font-size: 1.15rem;
    font-weight: 700;
}

.crop-details-header-meta {
    display: flex;
    gap: 14px;
    font-size: 0.86rem;
    opacity: 0.95;
    flex-wrap: wrap;
}

.crop-details-header-meta i {
    margin-right: 5px;
}

.crop-details-status {
    display: inline-block;
    margin-top: 2px;
    padding: 4px 12px;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 12px;
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: capitalize;
}

.crop-details-tabs-nav {
    display: flex;
    border-bottom: 2px solid #e5e7eb;
    background: #f9fafb;
    overflow-x: auto;
    flex-wrap: nowrap;
}

.crop-details-tab-btn {
    white-space: nowrap;
    padding: 12px 16px;
    border: none;
    background: transparent;
    cursor: pointer;
    color: #6b7280;
    font-weight: 500;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
}

.crop-details-tab-btn.active {
    background: #ffffff;
    color: #10b981;
    border-bottom: 2px solid #10b981;
    font-weight: 600;
}

.crop-details-tab-content {
    padding: 20px;
    background: #ffffff;
}

.farm-description {
    margin: 1rem 0;
    padding: 1rem;
    background: var(--bg-secondary);
    border-radius: var(--radius);
}

.farm-description p {
    color: var(--text-secondary);
    font-size: 0.875rem;
    margin: 0;
}

.farm-actions {
    display: flex;
    gap: 0.75rem;
    margin-top: 1rem;
}

.farm-actions .btn {
    flex: 1;
    justify-content: center;
}

/* Training Module Styles */
.training-dashboard {
    padding: 2rem 0;
}

.training-tiers {
    margin-top: 2rem;
}

.tier-section {
    margin-bottom: 3rem;
}

.tier-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.5rem;
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    margin-bottom: 1.5rem;
    box-shadow: var(--shadow);
}

.tier-header h2 {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 600;
}

.tier-badge {
    padding: 0.5rem 1rem;
    border-radius: var(--radius);
    color: white;
    font-weight: 600;
    font-size: 0.875rem;
}

.modules-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(320px, 100%), 1fr));
    gap: 1.5rem;
}

.module-card {
    background: var(--bg-primary);
    border-radius: 16px;
    border: 1px solid var(--border-color);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
    padding: 1.5rem;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
    cursor: pointer;
    position: relative;
    overflow: hidden;
}

.module-card::before {
    content: '';
    display: block;
    height: 4px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    background: linear-gradient(90deg, #8b5cf6, #a78bfa);
}

.module-card:hover:not(.locked) {
    transform: translateY(-4px);
    box-shadow: 0 12px 28px rgba(139, 92, 246, 0.15);
}

.module-card.locked {
    opacity: 0.6;
    cursor: not-allowed;
}

.module-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1rem;
}

.module-number {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-weight: 700;
    font-size: 1.25rem;
}

.module-lock {
    color: var(--text-secondary);
    font-size: 1.5rem;
}

.module-content h3 {
    margin: 0 0 0.5rem 0;
    font-size: 1.125rem;
    font-weight: 600;
}

.module-content p {
    color: var(--text-secondary);
    font-size: 0.875rem;
    margin-bottom: 1rem;
}

.module-progress {
    margin-top: 1rem;
}

.progress-bar {
    width: 100%;
    height: 8px;
    background: var(--bg-secondary);
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 0.5rem;
}

.progress-fill {
    height: 100%;
    transition: width 0.3s ease;
    border-radius: 4px;
}

.progress-text {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.module-footer {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
}

.module-timeline {
    font-size: 0.75rem;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

/* Module Detail Styles */
.module-detail-header {
    margin-bottom: 2rem;
}

.module-detail-title {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-top: 1rem;
}

.module-tier-badge {
    padding: 0.75rem 1.5rem;
    border-radius: var(--radius);
    color: white;
    font-weight: 700;
    font-size: 1.25rem;
}

.module-detail-title h1 {
    margin: 0;
}

.programs-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.program-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.program-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.program-info h3 {
    margin: 0 0 0.5rem 0;
    font-size: 1.25rem;
}

.program-info p {
    color: var(--text-secondary);
    margin-bottom: 1rem;
}

.program-meta {
    display: flex;
    gap: 1.5rem;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.program-meta span {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* Program Detail Styles */
.program-detail-header {
    margin-bottom: 2rem;
}

.program-progress-card {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    background: var(--bg-primary);
    padding: 1.5rem;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    margin-top: 1rem;
}

.progress-circle {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1.5rem;
    color: white;
}

.lessons-section, .assessment-section {
    margin-top: 2rem;
}

.lessons-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 1rem;
}

.lesson-item {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    cursor: pointer;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.lesson-item:hover {
    transform: translateX(4px);
    box-shadow: var(--shadow-lg);
}

.lesson-item.completed {
    border-left: 4px solid var(--primary-color);
}

.lesson-number {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--bg-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    color: var(--text-primary);
    flex-shrink: 0;
}

.lesson-content {
    flex: 1;
}

.lesson-content h4 {
    margin: 0 0 0.5rem 0;
}

.lesson-meta {
    display: flex;
    gap: 1rem;
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.lesson-complete {
    color: var(--primary-color);
    font-size: 1.5rem;
}

.lesson-play {
    color: var(--text-secondary);
    font-size: 1.5rem;
}

/* Lesson Viewer Styles */
.lesson-viewer-header {
    margin-bottom: 1.5rem;
}

.lesson-content-viewer {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 2rem;
}

.lesson-content-viewer h1 {
    margin-bottom: 1.5rem;
}

.lesson-text-content {
    line-height: 1.8;
    color: var(--text-primary);
}

.lesson-text-content h3 {
    margin-top: 1.5rem;
    margin-bottom: 0.75rem;
}

.lesson-actions {
    margin-top: 2rem;
    display: flex;
    gap: 1rem;
}

/* Assessment Styles */
.assessment-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10000;
    padding: 2rem;
}

.assessment-content {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    padding: 2rem;
    max-width: 800px;
    max-height: 90vh;
    overflow-y: auto;
    width: 100%;
}

.assessment-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2rem;
    padding-bottom: 1rem;
    border-bottom: 2px solid var(--border-color);
}

.question-item {
    margin-bottom: 2rem;
    padding: 1.5rem;
    background: var(--bg-secondary);
    border-radius: var(--radius);
}

.question-item h4 {
    margin-bottom: 1rem;
}

.question-options {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-top: 1rem;
}

.radio-option, .checkbox-option {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem;
    background: var(--bg-primary);
    border-radius: var(--radius);
    cursor: pointer;
    transition: background 0.2s ease;
}

.radio-option:hover, .checkbox-option:hover {
    background: var(--border-color);
}

.radio-option input, .checkbox-option input {
    cursor: pointer;
}

.assessment-actions {
    display: flex;
    gap: 1rem;
    margin-top: 2rem;
    justify-content: flex-end;
}

/* Certificate Styles */
.certificates-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(300px, 100%), 1fr));
    gap: 1.5rem;
    margin-top: 1.5rem;
}

.certificate-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.certificate-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.certificate-icon {
    font-size: 4rem;
    color: var(--primary-color);
    margin-bottom: 1rem;
}

.certificate-info {
    flex: 1;
}

.certificate-info h3 {
    margin-bottom: 0.5rem;
}

.certificate-info p {
    color: var(--text-secondary);
    font-size: 0.875rem;
    margin: 0.25rem 0;
}

.certificate-actions {
    margin-top: 1rem;
}

/* Offline Content Styles */
.offline-content-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 1.5rem;
}

.offline-item {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.offline-info {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex: 1;
}

.offline-info i {
    font-size: 2rem;
    color: var(--primary-color);
}

.offline-info h4 {
    margin: 0 0 0.25rem 0;
}

.offline-info p {
    margin: 0.25rem 0;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

/* Responsive adjustments for training */
@media (max-width: 768px) {
    .modules-grid {
        grid-template-columns: 1fr;
    }
    
    .program-card {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .program-meta {
        flex-direction: column;
        gap: 0.5rem;
    }
    
    .assessment-content {
        padding: 1rem;
        max-height: 95vh;
    }
}

/* ============================================
   LEADERBOARD & COMMUNITY CHAT STYLES
   ============================================ */

/* Leaderboard Container */
.leaderboard-container {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
}

.leaderboard-tabs {
    display: flex;
    gap: 0.75rem;
    margin-bottom: 2rem;
    border-bottom: 2px solid var(--border-color);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
}

.leaderboard-tabs .tab-btn {
    padding: 1rem 1.5rem;
    background: none;
    border: none;
    border-bottom: 3px solid transparent;
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    white-space: nowrap;
    flex-shrink: 0;
    align-items: center;
    gap: 0.5rem;
}

.leaderboard-tabs .tab-btn:hover {
    color: var(--primary-color);
}

.leaderboard-tabs .tab-btn.active {
    color: var(--primary-color);
    border-bottom-color: var(--primary-color);
}

/* Leaderboard Filters */
.leaderboard-filters,
.progress-filters {
    display: flex;
    gap: 1rem;
    margin-bottom: 1.5rem;
    align-items: center;
}

.filter-select {
    padding: 0.625rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    font-size: 0.875rem;
    background: #ffffff;
    color: #1f2937;
    cursor: pointer;
    flex: 1;
    max-width: 300px;
}

/* Leaderboard List */
.leaderboard-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.leaderboard-entry {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.5rem;
    background: var(--bg-secondary);
    border-radius: var(--radius);
    transition: all 0.3s ease;
}

.leaderboard-entry:hover {
    background: #f3f4f6;
    transform: translateX(5px);
}

.leaderboard-entry.top-three {
    background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
    border: 2px solid #f59e0b;
}

.leaderboard-entry.current-user {
    background: linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);
    border: 2px solid var(--primary-color);
}

.entry-rank {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-secondary);
    min-width: 50px;
    text-align: center;
}

.entry-avatar {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
}

.entry-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.entry-avatar .avatar-placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.25rem;
}

.entry-info {
    flex: 1;
}

.entry-name {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.you-badge {
    background: var(--primary-color);
    color: white;
    font-size: 0.75rem;
    padding: 0.125rem 0.5rem;
    border-radius: 12px;
    font-weight: 500;
}

.entry-farm {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.entry-score {
    text-align: right;
}

.score-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--primary-color);
}

.score-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
    text-transform: uppercase;
}

.entry-actions {
    display: flex;
    gap: 0.5rem;
}

/* ============================================
   COMMONS DASHBOARD STYLES
   ============================================ */

/* Commons Container */
.commons-container {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 1.5rem;
}

.commons-tabs {
    display: flex;
    gap: 0.75rem;
    margin-bottom: 2rem;
    border-bottom: 2px solid var(--border-color);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
}

.commons-tabs .tab-btn {
    padding: 1rem 1.5rem;
    background: none;
    border: none;
    border-bottom: 3px solid transparent;
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    white-space: nowrap;
    flex-shrink: 0;
    align-items: center;
    gap: 0.5rem;
    position: relative;
}

.commons-tabs .tab-btn:hover {
    color: var(--primary-color);
}

.commons-tabs .tab-btn.active {
    color: var(--primary-color);
    border-bottom-color: var(--primary-color);
}

.commons-tabs .unread-badge {
    background: var(--error-color, #c73e1d);
    color: white;
    font-size: 0.75rem;
    padding: 0.125rem 0.5rem;
    border-radius: 10px;
    min-width: 20px;
    text-align: center;
}

/* Bulletin Board Styles */
.bulletin-create-panel {
    margin-bottom: 1.5rem;
    padding: 1rem;
    background: var(--bg-secondary);
    border-radius: var(--radius);
    display: flex;
    justify-content: flex-end;
}

.bulletin-filters {
    display: flex;
    gap: 1rem;
    margin-bottom: 1.5rem;
    align-items: center;
    flex-wrap: wrap;
}

.bulletin-pinned {
    margin-bottom: 2rem;
}

.section-subtitle {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.announcements-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.announcement-card {
    background: var(--bg-primary);
    border-radius: 14px;
    padding: 1.25rem;
    transition: all 0.25s ease;
    border: 1px solid var(--border-color);
    border-left: 4px solid var(--border-color);
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
    position: relative;
    overflow: hidden;
}

.announcement-card::before {
    content: '';
    display: block;
    height: 3px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    background: linear-gradient(90deg, #0ea5e9, #06b6d4);
    opacity: 0;
    transition: opacity 0.2s ease;
}

.announcement-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.08);
}

.announcement-card:hover::before {
    opacity: 1;
}

.announcement-card.unread {
    background: linear-gradient(135deg, #eff6ff 0%, #e0e7ff 100%);
    border-left-color: var(--primary-color);
}

.announcement-card.priority-high {
    border-left-color: var(--error-color, #c73e1d);
    background: linear-gradient(135deg, #fef2f2 0%, #fee2e2 100%);
}

.announcement-card.priority-low {
    border-left-color: var(--text-light, #9ca3af);
}

.announcement-header {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    margin-bottom: 0.75rem;
    flex-wrap: wrap;
}

.pin-badge {
    color: var(--warning-color, #f59e0b);
    font-size: 0.875rem;
}

.announcement-scope-badge {
    font-size: 0.75rem;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    font-weight: 500;
    text-transform: uppercase;
}

.scope-system {
    background: #dbeafe;
    color: #1e40af;
}

.scope-territory {
    background: #d1fae5;
    color: #065f46;
}

.scope-assigned_farmers {
    background: #fef3c7;
    color: #92400e;
}

.priority-badge {
    font-size: 0.75rem;
    color: var(--error-color, #c73e1d);
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.announcement-title {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 0.5rem 0;
}

.announcement-content {
    color: var(--text-secondary);
    font-size: 0.9375rem;
    line-height: 1.5;
    margin: 0 0 1rem 0;
}

.announcement-footer {
    display: flex;
    gap: 1rem;
    align-items: center;
    font-size: 0.8125rem;
    color: var(--text-light, #9ca3af);
    flex-wrap: wrap;
}

.announcement-author,
.announcement-date {
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.announcement-actions {
    margin-left: auto;
    display: flex;
    gap: 0.5rem;
}

.announcement-actions .btn-ghost {
    background: transparent;
    border: none;
    color: var(--text-secondary);
    padding: 0.25rem 0.5rem;
    cursor: pointer;
    transition: color 0.2s;
    border-radius: var(--radius);
}

.announcement-actions .btn-ghost:hover {
    color: var(--primary-color);
    background: var(--bg-primary);
}

/* Messaging Container */
.messaging-container {
    display: grid;
    grid-template-columns: 350px 1fr;
    gap: 1rem;
    height: 600px;
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.messaging-sidebar {
    background: var(--bg-primary);
    border-right: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
}

.messaging-main {
    display: flex;
    flex-direction: column;
}

/* Role Filter Tabs */
.role-filter-tabs {
    display: flex;
    padding: 0.5rem;
    gap: 0.25rem;
    border-bottom: 1px solid var(--border-color);
}

.role-filter-btn {
    flex: 1;
    padding: 0.5rem;
    border: none;
    background: transparent;
    color: var(--text-secondary);
    font-size: 0.8125rem;
    cursor: pointer;
    border-radius: var(--radius);
    transition: all 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
}

.role-filter-btn:hover {
    background: var(--bg-secondary);
}

.role-filter-btn.active {
    background: var(--primary-color);
    color: white;
}

/* Broadcast Panel */
.broadcast-panel {
    padding: 0.75rem;
    border-bottom: 1px solid var(--border-color);
}

.broadcast-panel .btn {
    width: 100%;
}

/* Role Badges in Messaging */
.role-badge {
    font-size: 0.625rem;
    padding: 0.125rem 0.375rem;
    border-radius: 3px;
    margin-left: 0.25rem;
    display: inline-flex;
    align-items: center;
}

.role-badge.farmer {
    background: #dcfce7;
    color: #166534;
}

.role-badge.field_officer {
    background: #dbeafe;
    color: #1e40af;
}

.role-badge.chief_field_officer {
    background: #e0e7ff;
    color: #4338ca;
}

.role-badge.admin {
    background: #fef3c7;
    color: #92400e;
}

.role-badge.ceo {
    background: #fce7f3;
    color: #9d174d;
}

/* Medal Icons for Leaderboard */
.leaderboard-entry .fa-medal {
    font-size: 1.25rem;
}

.leaderboard-entry .fa-medal.gold {
    color: #fbbf24;
}

.leaderboard-entry .fa-medal.silver {
    color: #9ca3af;
}

.leaderboard-entry .fa-medal.bronze {
    color: #d97706;
}

/* Modal Styles for Commons Dashboard */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10000;
}

.modal-container {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    max-width: 600px;
    width: 90%;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: var(--shadow-lg, 0 25px 50px -12px rgba(0,0,0,0.25));
}

.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.5rem;
    border-bottom: 1px solid var(--border-color);
}

.modal-header h2 {
    margin: 0;
    font-size: 1.25rem;
    font-weight: 600;
}

.modal-close {
    background: none;
    border: none;
    font-size: 1.5rem;
    cursor: pointer;
    color: var(--text-secondary);
    padding: 0;
    line-height: 1;
}

.modal-close:hover {
    color: var(--text-primary);
}

.modal-content {
    padding: 1.5rem;
}

/* Responsive Styles for Commons Dashboard */
@media (max-width: 1024px) {
    .messaging-container {
        grid-template-columns: 300px 1fr;
    }
}

@media (max-width: 768px) {
    .commons-container {
        padding: 1rem;
    }

    .commons-tabs {
        gap: 0.5rem;
        margin-bottom: 1rem;
        padding-bottom: 0.5rem;
    }

    .commons-tabs .tab-btn {
        padding: 0.625rem 1rem;
        font-size: 0.85rem;
    }

    .bulletin-filters {
        flex-direction: column;
        align-items: stretch;
    }

    .bulletin-filters .filter-select {
        max-width: none;
    }

    .messaging-container {
        grid-template-columns: 1fr;
        height: auto;
        min-height: 500px;
    }

    .messaging-sidebar {
        border-right: none;
        border-bottom: 1px solid var(--border-color);
        max-height: 250px;
    }

    .messaging-main {
        min-height: 400px;
    }

    .announcement-footer {
        flex-direction: column;
        align-items: flex-start;
    }

    .announcement-actions {
        margin-left: 0;
        margin-top: 0.5rem;
    }
}

/* Chat Container */
.chat-container {
    display: grid;
    grid-template-columns: 350px 1fr;
    gap: 1rem;
    height: 600px;
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

/* Chat Sidebar */
.chat-sidebar {
    background: var(--bg-primary);
    border-right: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
}

.chat-search {
    padding: 1rem;
    border-bottom: 1px solid var(--border-color);
    position: relative;
}

.chat-search i {
    position: absolute;
    left: 1.5rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-secondary);
}

.chat-search input {
    width: 100%;
    padding: 0.625rem 1rem 0.625rem 2.5rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    font-size: 0.875rem;
    background: #ffffff;
    color: #1f2937;
}

.chat-search input::placeholder {
    color: #9ca3af;
}

.chat-users-list {
    flex: 1;
    overflow-y: auto;
    padding: 0.5rem;
}

.chat-user-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    border-radius: var(--radius);
    cursor: pointer;
    transition: all 0.3s ease;
    margin-bottom: 0.5rem;
}

.chat-user-item:hover {
    background: var(--bg-secondary);
}

.chat-user-item.has-unread {
    background: #eff6ff;
    border-left: 3px solid var(--primary-color);
}

.chat-user-item .user-avatar {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
    position: relative;
}

.chat-user-item .user-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.chat-user-item .user-avatar .avatar-placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.25rem;
}

.unread-badge {
    position: absolute;
    top: -5px;
    right: -5px;
    background: var(--error-color);
    color: white;
    font-size: 0.75rem;
    padding: 0.25rem 0.5rem;
    border-radius: 12px;
    font-weight: 600;
    min-width: 20px;
    text-align: center;
}

.chat-user-item .user-info {
    flex: 1;
    min-width: 0;
}

.chat-user-item .user-name {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
}

.chat-user-item .user-farm {
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-bottom: 0.25rem;
}

.chat-user-item .last-message {
    font-size: 0.8125rem;
    color: var(--text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.chat-user-item .last-message-time {
    font-size: 0.75rem;
    color: var(--text-light);
    margin-top: 0.25rem;
}

/* Chat Main */
.chat-main {
    display: flex;
    flex-direction: column;
    background: var(--bg-primary);
}

.chat-header {
    padding: 1rem 1.5rem;
    border-bottom: 1px solid var(--border-color);
    background: var(--bg-primary);
}

.chat-header-content {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.chat-header .user-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    overflow: hidden;
}

.chat-header .user-details {
    flex: 1;
}

.chat-header .user-name {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
}

.chat-header .user-farm {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.chat-messages {
    flex: 1;
    overflow-y: auto;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.chat-welcome {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    text-align: center;
    color: var(--text-secondary);
}

.chat-welcome i {
    font-size: 4rem;
    margin-bottom: 1rem;
    color: var(--text-light);
}

.chat-welcome h3 {
    font-size: 1.5rem;
    margin-bottom: 0.5rem;
    color: var(--text-primary);
}

.chat-message {
    display: flex;
    margin-bottom: 1rem;
}

.chat-message.sent {
    justify-content: flex-end;
}

.chat-message.received {
    justify-content: flex-start;
}

.message-content {
    max-width: 70%;
    padding: 0.75rem 1rem;
    border-radius: var(--radius-lg);
    background: var(--bg-secondary);
}

.chat-message.sent .message-content {
    background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
    color: white;
}

.chat-message.received .message-content {
    background: var(--bg-secondary);
    color: var(--text-primary);
}

.message-text {
    margin-bottom: 0.25rem;
    word-wrap: break-word;
}

.message-time {
    font-size: 0.75rem;
    opacity: 0.7;
    text-align: right;
}

.chat-input-container {
    padding: 1rem 1.5rem;
    border-top: 1px solid var(--border-color);
    background: var(--bg-primary);
}

.chat-input {
    display: flex;
    gap: 0.5rem;
}

.chat-input input {
    flex: 1;
    padding: 0.75rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    font-size: 0.9375rem;
    background: #ffffff;
    color: #1f2937;
}

.chat-input input::placeholder {
    color: #9ca3af;
}

.chat-input button {
    padding: 0.75rem 1.5rem;
}

/* Progress Comparison */
.progress-comparison {
    padding: 1rem 0;
}

.progress-chart-container {
    height: 300px;
    margin: 2rem 0;
    padding: 1rem;
    background: var(--bg-secondary);
    border-radius: var(--radius);
}

.progress-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.progress-entry {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.5rem;
    background: var(--bg-secondary);
    border-radius: var(--radius);
}

.progress-entry.current-user {
    background: linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);
    border: 2px solid var(--primary-color);
}

.progress-rank {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text-secondary);
    min-width: 40px;
}

.progress-avatar {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    overflow: hidden;
}

.progress-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.progress-info {
    flex: 1;
}

.progress-name {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
}

.progress-farm {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.progress-bar-container {
    flex: 1;
    max-width: 300px;
    position: relative;
}

.progress-bar {
    height: 30px;
    background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
    border-radius: var(--radius);
    transition: width 0.3s ease;
    position: relative;
}

.progress-score {
    position: absolute;
    right: 0.5rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text-primary);
    z-index: 1;
}

/* Empty and Loading States */
.loading,
.empty-state,
.error-state {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--text-secondary);
}

.empty-state i,
.error-state i {
    font-size: 3rem;
    margin-bottom: 1rem;
    color: var(--text-light);
}

.empty-state h3,
.error-state h3 {
    font-size: 1.25rem;
    margin-bottom: 0.5rem;
    color: var(--text-primary);
}

/* Responsive Design for Leaderboard */
@media (max-width: 1024px) {
    .chat-container {
        grid-template-columns: 300px 1fr;
    }
}

@media (max-width: 768px) {
    .leaderboard-container {
        padding: 1rem;
    }

    .leaderboard-tabs {
        gap: 0.5rem;
        margin-bottom: 1rem;
        padding-bottom: 0.5rem;
    }

    .leaderboard-tabs .tab-btn {
        padding: 0.625rem 1rem;
        font-size: 0.85rem;
    }

    .leaderboard-entry {
        flex-wrap: wrap;
        padding: 1rem;
    }

    .entry-actions {
        width: 100%;
        margin-top: 0.5rem;
    }

    .entry-actions button {
        width: 100%;
    }

    .chat-container {
        grid-template-columns: 1fr;
        height: auto;
        min-height: 500px;
    }

    .chat-sidebar {
        border-right: none;
        border-bottom: 1px solid var(--border-color);
        max-height: 200px;
    }

    .chat-main {
        min-height: 400px;
    }

    .leaderboard-filters,
    .progress-filters {
        flex-direction: column;
    }

    .filter-select {
        max-width: 100%;
    }

    .progress-bar-container {
        max-width: 100%;
    }

    .message-content {
        max-width: 85%;
    }
}

/* ============================================
   NEW FEATURES STYLES
   ============================================ */

/* Media Gallery Styles */
.media-gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(250px, 100%), 1fr));
    gap: 1.5rem;
    margin-top: 2rem;
}

.media-item {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.media-item:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.media-thumbnail {
    position: relative;
    width: 100%;
    padding-top: 75%; /* 4:3 aspect ratio */
    overflow: hidden;
    background: var(--bg-secondary);
}

.media-thumbnail img,
.media-thumbnail video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.media-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.media-item:hover .media-overlay {
    opacity: 1;
}

.media-info {
    padding: 1rem;
}

.media-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}

.tag {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    background: var(--bg-secondary);
    border-radius: 1rem;
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.media-meta {
    display: flex;
    gap: 1rem;
    font-size: 0.875rem;
    color: var(--text-light);
}

/* Plant Identification Styles */
.plant-id-container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    margin-top: 2rem;
}

.plant-id-upload {
    grid-column: 1 / -1;
}

.upload-area {
    border: 2px dashed var(--border-color);
    border-radius: var(--radius-lg);
    padding: 3rem;
    text-align: center;
    cursor: pointer;
    transition: all 0.3s ease;
    background: var(--bg-primary);
}

.upload-area:hover {
    border-color: var(--primary-color);
    background: var(--bg-secondary);
}

.plant-id-results {
    grid-column: 1 / -1;
    margin-top: 2rem;
}

.plant-analysis-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    padding: 2rem;
    box-shadow: var(--shadow);
}

.analysis-section {
    margin-bottom: 1.5rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--border-color);
}

.analysis-section:last-child {
    border-bottom: none;
}

.analysis-section h4 {
    color: var(--text-primary);
    margin-bottom: 0.75rem;
}

.analysis-section h5 {
    color: var(--text-secondary);
    margin-top: 1rem;
    margin-bottom: 0.5rem;
    font-size: 0.875rem;
}

.problem-item {
    margin: 0.5rem 0;
    padding: 0.75rem;
    background: rgba(245, 158, 11, 0.1);
    border-left: 3px solid var(--warning-color);
    border-radius: 4px;
}

.plant-id-history {
    grid-column: 1 / -1;
    margin-top: 2rem;
}

.analysis-history-item {
    display: flex;
    gap: 1rem;
    padding: 1rem;
    background: var(--bg-primary);
    border-radius: var(--radius);
    margin-bottom: 1rem;
    cursor: pointer;
    transition: background 0.3s ease;
    box-shadow: var(--shadow);
}

.analysis-history-item:hover {
    background: var(--bg-secondary);
}

.analysis-thumbnail {
    width: 80px;
    height: 80px;
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--bg-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.analysis-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.analysis-thumbnail i {
    font-size: 2rem;
    color: var(--text-light);
}

.analysis-info {
    flex: 1;
}

.analysis-info h4 {
    margin-bottom: 0.25rem;
    color: var(--text-primary);
}

.analysis-info p {
    margin: 0.25rem 0;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

/* Recommendations Styles */
.recommendations-list {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    margin-top: 2rem;
}

.recommendation-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    box-shadow: var(--shadow);
    border-left: 4px solid var(--primary-color);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.recommendation-card:hover {
    transform: translateX(4px);
    box-shadow: var(--shadow-lg);
}

.recommendation-card.urgent {
    border-left-color: var(--error-color);
    background: linear-gradient(to right, #fef2f2, var(--bg-primary));
}

.recommendation-card.routine {
    border-left-color: var(--warning-color);
}

.recommendation-card.info {
    border-left-color: var(--info-color);
}

.recommendation-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1rem;
}

.recommendation-header h3 {
    margin: 0;
    color: var(--text-primary);
    flex: 1;
}

.recommendation-badges {
    display: flex;
    gap: 0.5rem;
}

.recommendation-content {
    margin-bottom: 1rem;
}

.recommendation-content p {
    color: var(--text-secondary);
    line-height: 1.6;
}

.recommendation-meta {
    display: flex;
    gap: 1rem;
    font-size: 0.875rem;
    color: var(--text-light);
    margin-top: 0.5rem;
}

.recommendation-actions {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.pending-recommendations-list {
    margin-top: 1rem;
}

/* Modal Styles */
.modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10000;
    padding: 1rem;
}

.modal-content {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    max-width: 600px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: var(--shadow-lg);
}

.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.5rem;
    border-bottom: 1px solid var(--border-color);
}

.modal-header h2 {
    margin: 0;
    color: var(--text-primary);
}

.modal-close {
    background: none;
    border: none;
    font-size: 1.5rem;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 0;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: background 0.3s ease;
}

.modal-close:hover {
    background: var(--bg-secondary);
}

.modal-body {
    padding: 1.5rem;
}

#viewLivestockModal .modal-content {
    max-width: min(960px, 98vw);
    width: 100%;
}

/* ===============================================
   Organization Form Styles
   =============================================== */

/* Organization Modal Container - using standard modal structure */
#addOrgModal.modal {
    display: flex;
}

#addOrgModal .modal-content {
    max-width: 550px;
    width: 95%;
}

/* Form Row for two-column layouts */
.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-bottom: 0;
}

.form-row .form-group {
    margin-bottom: 1rem;
}

/* Color Picker Wrapper */
.color-picker-wrapper {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.color-picker-wrapper input[type="color"] {
    width: 50px;
    height: 38px;
    padding: 2px;
    border: 2px solid var(--border-color);
    border-radius: var(--radius);
    cursor: pointer;
    background: var(--bg-primary);
    flex-shrink: 0;
}

.color-picker-wrapper input[type="color"]:hover {
    border-color: var(--primary-color);
}

.color-picker-wrapper .color-preview {
    font-family: monospace;
    font-size: 0.85rem;
    font-weight: 500;
    text-transform: uppercase;
}

/* Legacy color picker support */
.org-color-picker {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.org-color-picker input[type="color"],
#addOrgForm input[type="color"] {
    width: 50px;
    height: 38px;
    padding: 2px;
    border: 2px solid var(--border-color);
    border-radius: var(--radius);
    cursor: pointer;
    background: var(--bg-primary);
}

.org-color-picker input[type="color"]:hover,
#addOrgForm input[type="color"]:hover {
    border-color: var(--primary-color);
}

.org-color-preview {
    width: 32px;
    height: 32px;
    border-radius: var(--radius);
    border: 1px solid var(--border-color);
}

/* Organization Info Display */
.org-info {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.org-color-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    flex-shrink: 0;
}

.org-slug {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

/* Status Badges for Organizations */
.status-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.75rem;
    border-radius: 1rem;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: capitalize;
}

.status-badge.status-active {
    background: rgba(74, 103, 65, 0.15);
    color: var(--success-color);
}

.status-badge.status-inactive {
    background: rgba(107, 93, 79, 0.15);
    color: var(--text-secondary);
}

.status-badge.status-suspended {
    background: rgba(199, 62, 29, 0.15);
    color: var(--error-color);
}

.status-badge.status-pending {
    background: rgba(212, 160, 86, 0.15);
    color: var(--warning-color);
}

/* Subscription Plan Badges */
.subscription-badge {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    border-radius: 1rem;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: capitalize;
}

.subscription-badge.subscription-free {
    background: rgba(107, 93, 79, 0.1);
    color: var(--text-secondary);
}

.subscription-badge.subscription-basic {
    background: rgba(74, 103, 65, 0.1);
    color: var(--primary-color);
}

.subscription-badge.subscription-premium {
    background: rgba(212, 160, 86, 0.15);
    color: #b8860b;
}

.subscription-badge.subscription-enterprise {
    background: rgba(139, 92, 246, 0.15);
    color: #8b5cf6;
}

/* Organization Badge in User Table */
.org-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.25rem 0.6rem;
    background: rgba(74, 103, 65, 0.1);
    color: var(--primary-color);
    border-radius: var(--radius);
    font-size: 0.75rem;
    font-weight: 500;
}

.org-badge i {
    font-size: 0.65rem;
}

/* Unassigned User Indicator */
.unassigned-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.25rem 0.6rem;
    background: rgba(212, 160, 86, 0.15);
    color: var(--warning-color);
    border-radius: var(--radius);
    font-size: 0.75rem;
    font-weight: 500;
}

.unassigned-badge i {
    font-size: 0.7rem;
}

/* Unassigned Users Notice */
.unassigned-users-notice {
    background: rgba(212, 160, 86, 0.1);
    border: 1px dashed var(--warning-color);
    border-radius: var(--radius);
    padding: 1rem;
    margin-top: 1rem;
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.unassigned-users-notice i {
    color: var(--warning-color);
    font-size: 1.25rem;
}

.unassigned-users-notice span {
    color: var(--text-primary);
    font-size: 0.875rem;
}

/* Organization Member Assignment Section */
.org-member-assignment {
    background: var(--bg-secondary);
    border-radius: var(--radius);
    padding: 1.25rem;
    margin-top: 1.5rem;
}

.org-member-assignment h4 {
    margin: 0 0 1rem 0;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.org-member-assignment h4 i {
    color: var(--primary-color);
}

.org-member-list {
    max-height: 200px;
    overflow-y: auto;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    background: var(--bg-primary);
}

.org-member-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 1rem;
    border-bottom: 1px solid var(--divider-color);
    transition: background 0.2s ease;
}

.org-member-item:last-child {
    border-bottom: none;
}

.org-member-item:hover {
    background: var(--bg-secondary);
}

.org-member-info {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.org-member-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--primary-color);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 0.8rem;
}

.org-member-details {
    display: flex;
    flex-direction: column;
}

.org-member-name {
    font-weight: 500;
    color: var(--text-primary);
    font-size: 0.875rem;
}

.org-member-role {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.org-member-actions {
    display: flex;
    gap: 0.5rem;
}

.org-member-actions .btn-icon {
    width: 28px;
    height: 28px;
    font-size: 0.75rem;
}

/* Organization Filter in Admin */
.filter-group select.org-filter {
    min-width: 180px;
}

/* Unassigned Users Stat Card */
.stat-card.warning {
    border-left: 4px solid var(--warning-color);
}

.stat-card.warning .stat-icon {
    background: var(--warning-color) !important;
}

/* Responsive Organization Form */
@media (max-width: 768px) {
    .org-form-grid,
    .form-row {
        grid-template-columns: 1fr;
    }

    #addOrgModal .modal {
        max-width: 95%;
        margin: 1rem;
    }

    .org-member-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.75rem;
    }

    .org-member-actions {
        width: 100%;
        justify-content: flex-end;
    }
}

/* Loading Overlay */
.loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255, 255, 255, 0.9);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10003;
}

.loading-spinner {
    text-align: center;
}

.loading-spinner i {
    font-size: 3rem;
    color: var(--primary-color);
    margin-bottom: 1rem;
}

.loading-spinner p {
    color: var(--text-secondary);
    font-size: 1.125rem;
}

/* Camera Container */
.camera-container {
    text-align: center;
}

.camera-controls {
    display: flex;
    gap: 1rem;
    justify-content: center;
    margin-top: 1rem;
}

/* Badge Styles */
.badge {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    border-radius: 1rem;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
}

.badge.urgent {
    background: rgba(239, 68, 68, 0.1);
    color: var(--error-color);
}

.badge.routine {
    background: rgba(245, 158, 11, 0.1);
    color: var(--warning-color);
}

.badge.info {
    background: rgba(59, 130, 246, 0.1);
    color: var(--info-color);
}

.badge.success {
    background: rgba(16, 185, 129, 0.1);
    color: var(--success-color);
}

.badge.error {
    background: rgba(239, 68, 68, 0.1);
    color: var(--error-color);
}

.badge.warning {
    background: rgba(245, 158, 11, 0.1);
    color: var(--warning-color);
}

.badge.pending {
    background: #e5e7eb;
    color: var(--text-secondary);
}

/* Filter Select */
.filter-select {
    padding: 0.5rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    background: var(--bg-primary);
    color: var(--text-primary);
    font-size: 0.875rem;
}

.filter-select:focus {
    outline: none;
    border-color: var(--primary-color);
}

/* Responsive Design for New Features */
@media (max-width: 768px) {
    .media-gallery-grid {
        grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
        gap: 1rem;
    }

    .plant-id-container {
        grid-template-columns: 1fr;
    }

    .recommendation-header {
        flex-direction: column;
        gap: 0.5rem;
    }

    .recommendation-badges {
        width: 100%;
        justify-content: flex-start;
    }

    .modal-content {
        margin: 1rem;
        max-height: calc(100vh - 2rem);
    }
}

/* ========================================
   ADMIN DASHBOARD STYLES
   ======================================== */

/* Admin Tabs */
.admin-tabs {
    display: flex;
    gap: 0.75rem;
    margin: 2rem 0 1.5rem;
    border-bottom: 2px solid var(--border-color);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.admin-tabs .tab-btn {
    background: none;
    border: none;
    padding: 1rem 1.5rem;
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--text-secondary);
    cursor: pointer;
    position: relative;
    white-space: nowrap;
    transition: all 0.3s ease;
}

.admin-tabs .tab-btn:hover {
    color: var(--primary-color);
}

.admin-tabs .tab-btn.active {
    color: var(--primary-color);
}

.admin-tabs .tab-btn.active::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--primary-color);
}

.admin-tabs .tab-btn i {
    margin-right: 0.5rem;
}

/* Admin Tab Content */
.admin-tab-content {
    display: none;
    animation: fadeIn 0.3s ease;
}

.admin-tab-content.active {
    display: block;
}

/* Filters Bar */
.filters-bar {
    display: flex;
    gap: 1rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
    background: var(--bg-primary);
    padding: 1rem;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    align-items: flex-end;
}

.filter-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    min-width: 200px;
}

.filter-group label {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-secondary);
}

.filter-group input,
.filter-group select {
    padding: 0.5rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    font-size: 0.875rem;
}

.filter-group input:focus,
.filter-group select:focus {
    outline: none;
    border-color: var(--primary-color);
}

/* Admin Table */
.table-container {
    background: var(--bg-primary);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    overflow-x: auto;
    width: 100%;
}

.admin-table {
    width: 100%;
    border-collapse: collapse;
}

.admin-table thead {
    background: var(--bg-secondary);
}

.admin-table th {
    padding: 1rem;
    text-align: left;
    font-weight: 600;
    font-size: 0.875rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.admin-table td {
    padding: 1rem;
    border-top: 1px solid var(--border-color);
    font-size: 0.875rem;
}

.admin-table tbody tr:hover {
    background: var(--bg-secondary);
}

.admin-table .action-buttons {
    display: flex;
    gap: 0.5rem;
}

.admin-table .btn-icon {
    background: none;
    border: none;
    padding: 0.5rem;
    cursor: pointer;
    color: var(--text-secondary);
    border-radius: var(--radius);
    transition: all 0.2s ease;
}

.admin-table .btn-icon:hover {
    background: var(--bg-secondary);
    color: var(--primary-color);
}

.admin-table .btn-icon.danger:hover {
    color: var(--error-color);
}

.admin-table .btn-icon.success:hover {
    color: var(--primary-color);
}

/* Serializer configuration tab */
.serializer-toolbar {
    align-items: flex-end;
}

.serializer-org-picker select {
    min-width: 260px;
}

.serializer-org-code {
    display: inline-flex;
    align-items: center;
    min-height: 2.5rem;
    padding: 0.35rem 0.75rem;
    border-radius: var(--radius);
    background: var(--bg-secondary);
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-weight: 600;
    color: var(--text-primary);
}

.serializer-config-container {
    margin-top: 1rem;
}

.serializer-config-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow);
}

.serializer-config-table th,
.serializer-config-table td {
    padding: 0.85rem 1rem;
    border-bottom: 1px solid var(--border-color);
    vertical-align: middle;
}

.serializer-config-table th {
    text-align: left;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-secondary);
    background: var(--bg-secondary);
}

.serializer-config-table tbody tr:hover {
    background: rgba(74, 103, 65, 0.04);
}

.serializer-config-table input[type="text"],
.serializer-config-table input[type="number"] {
    width: 100%;
    min-width: 72px;
    padding: 0.45rem 0.6rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    background: var(--bg-primary);
}

.serializer-config-table input[type="checkbox"] {
    width: 1rem;
    height: 1rem;
}

.serializer-preview-cell {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-weight: 600;
    color: var(--primary-color);
    white-space: nowrap;
}

.serializer-preview-cell.is-disabled {
    color: var(--text-light);
    font-style: italic;
    font-weight: 400;
}

.serializer-entity-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 600;
}

.serializer-entity-label i {
    color: var(--primary-color);
}

/* Role Badge */
.role-badge {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
    white-space: nowrap;
}

/* Organization Info Cell */
.org-info {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.org-color {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    flex-shrink: 0;
}

.org-slug {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

/* Subscription Badge */
.subscription-badge {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
    white-space: nowrap;
    text-transform: capitalize;
}

.subscription-badge.subscription-free {
    background: #f3f4f6;
    color: #6b7280;
}

.subscription-badge.subscription-basic {
    background: #dbeafe;
    color: #1d4ed8;
}

.subscription-badge.subscription-premium {
    background: #fef3c7;
    color: #d97706;
}

.subscription-badge.subscription-enterprise {
    background: #ede9fe;
    color: #7c3aed;
}

/* Status Badge - Organization Specific */
.status-badge.status-inactive {
    background: #f3f4f6;
    color: #6b7280;
}

.status-badge.status-suspended {
    background: #fee2e2;
    color: #dc2626;
}

/* Organization Detail Grid */
.org-detail-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1.5rem;
}

.detail-section {
    background: var(--bg-secondary);
    padding: 1rem;
    border-radius: var(--radius);
}

.detail-section h3 {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.detail-section p {
    margin: 0.5rem 0;
    font-size: 0.875rem;
}

/* Manage Actions */
.manage-actions {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.btn-full {
    width: 100%;
    justify-content: center;
}

/* Mini Stat Cards */
.stat-card.mini {
    padding: 1rem;
}

.stat-card.mini .stat-content h3 {
    font-size: 0.75rem;
    margin-bottom: 0.25rem;
}

.stat-card.mini .stat-number {
    font-size: 1.5rem;
}

/* Bulk Operations Grid */
.bulk-operations-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
    gap: 1.5rem;
    margin-top: 1.5rem;
}

.bulk-op-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow: hidden;
}

.bulk-op-header {
    background: var(--primary-color);
    color: white;
    padding: 1rem 1.5rem;
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.bulk-op-header i {
    font-size: 1.5rem;
}

.bulk-op-header h3 {
    font-size: 1rem;
    font-weight: 600;
    margin: 0;
}

.bulk-op-body {
    padding: 1.5rem;
}

.bulk-op-body p {
    color: var(--text-secondary);
    margin-bottom: 1rem;
}

/* Upload Area */
.upload-area {
    border: 2px dashed var(--border-color);
    border-radius: var(--radius);
    padding: 2rem;
    text-align: center;
    cursor: pointer;
    transition: all 0.3s ease;
    margin: 1rem 0;
}

.upload-area:hover {
    border-color: var(--primary-color);
    background: var(--bg-secondary);
}

.upload-area i {
    font-size: 3rem;
    color: var(--text-light);
    display: block;
    margin-bottom: 1rem;
}

.upload-area p {
    color: var(--text-secondary);
}

/* System Health Grid */
.system-health-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(250px, 100%), 1fr));
    gap: 1.5rem;
    margin-top: 1.5rem;
}

.health-card {
    background: var(--bg-primary);
    padding: 1.5rem;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
}

.health-card h3 {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 1rem;
    color: var(--text-secondary);
}

.health-status {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-primary);
}

.health-status i {
    margin-right: 0.5rem;
}

/* Territories */
.territories-container {
    margin-top: 1.5rem;
}

#territoriesGrid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(300px, 100%), 1fr));
    gap: 1.5rem;
}

.territory-card {
    background: var(--bg-primary);
    padding: 1.5rem;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
}

.territory-card h3 {
    font-size: 1.125rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.territory-card p {
    color: var(--text-secondary);
    margin-bottom: 1rem;
}

.territory-stats {
    display: flex;
    gap: 1rem;
    margin-bottom: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
}

.territory-stats span {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.territory-stats i {
    color: var(--primary-color);
}

.territory-actions {
    display: flex;
    gap: 0.5rem;
}

/* Empty State */
.empty-state {
    text-align: center;
    padding: 3rem;
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
}

.empty-state i {
    font-size: 4rem;
    color: var(--text-light);
    margin-bottom: 1rem;
}

.empty-state h3 {
    font-size: 1.25rem;
    margin-bottom: 0.5rem;
}

.empty-state p {
    color: var(--text-secondary);
}

/* Section Header */
.section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
}

.section-header h2 {
    font-size: 1.5rem;
    font-weight: 600;
}

.section-actions {
    display: flex;
    gap: 0.75rem;
}

/* Responsive Admin Dashboard */
@media (max-width: 992px) {
    .admin-tabs {
        gap: 0.5rem;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
    }

    .admin-tabs .tab-btn {
        padding: 0.75rem 1.25rem;
        font-size: 0.875rem;
    }
}

@media (max-width: 768px) {
    .admin-tabs {
        margin: 1rem 0;
        padding-bottom: 0.5rem;
    }

    .admin-tabs .tab-btn {
        padding: 0.625rem 1rem;
        font-size: 0.8rem;
    }

    .admin-tabs .tab-btn i {
        margin-right: 0.375rem;
        font-size: 0.85rem;
    }

    .filters-bar {
        flex-direction: column;
    }

    .filter-group {
        min-width: 100%;
    }

    .admin-table {
        font-size: 0.75rem;
    }

    .admin-table th,
    .admin-table td {
        padding: 0.75rem 0.5rem;
    }

    .bulk-operations-grid {
        grid-template-columns: 1fr;
    }

    .section-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 1rem;
    }
}

@media (max-width: 480px) {
    .admin-tabs {
        flex-wrap: nowrap;
        gap: 0.5rem;
    }

    .admin-tabs .tab-btn {
        padding: 0.5rem 0.75rem;
        font-size: 0.75rem;
        flex-shrink: 0;
    }

    .admin-tabs .tab-btn i {
        display: none;
    }
}

/* ===============================================
   Admin Dashboard — Vibrant Interactive UI
   =============================================== */
#admin-dashboard {
    animation: fadeIn 0.35s ease;
}

#admin-dashboard .admin-hero-header {
    background: linear-gradient(135deg, #4338ca 0%, #6366f1 45%, #818cf8 100%);
    color: #fff;
    padding: 2rem 2.25rem;
    border-radius: 18px;
    margin-bottom: 1.75rem;
    box-shadow: 0 10px 32px rgba(99, 102, 241, 0.28);
    position: relative;
    overflow: hidden;
}

#admin-dashboard .admin-hero-header::before,
#admin-dashboard .admin-hero-header::after {
    content: '';
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    background: rgba(255, 255, 255, 0.08);
}

#admin-dashboard .admin-hero-header::before {
    width: 260px;
    height: 260px;
    top: -45%;
    right: -5%;
}

#admin-dashboard .admin-hero-header::after {
    width: 180px;
    height: 180px;
    bottom: -40%;
    left: 8%;
}

#admin-dashboard .admin-hero-content {
    position: relative;
    z-index: 1;
}

#admin-dashboard .admin-hero-header h1 {
    margin: 0 0 0.5rem;
    font-size: 1.85rem;
    font-weight: 800;
    color: #fff;
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

#admin-dashboard .admin-hero-header p {
    margin: 0;
    color: rgba(255, 255, 255, 0.92);
    font-size: 1rem;
}

#admin-dashboard .stats-grid {
    margin-bottom: 1.75rem;
}

#admin-dashboard .stat-card {
    border-radius: 16px;
    border: 1px solid var(--border-color);
    transition: transform 0.22s ease, box-shadow 0.22s ease;
}

#admin-dashboard .stat-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 32px rgba(15, 23, 42, 0.12);
}

#admin-dashboard .stat-card .stat-icon {
    border-radius: 14px;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.15);
}

#admin-dashboard .admin-tabs {
    display: flex;
    flex-wrap: nowrap;
    gap: 0.5rem;
    padding: 0.45rem;
    margin: 0 0 1.5rem;
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    box-shadow: var(--shadow);
    overflow-x: auto;
    scrollbar-width: thin;
    border-bottom: none;
}

#admin-dashboard .admin-tabs .tab-btn {
    padding: 0.7rem 1rem;
    border-radius: 12px;
    border: none;
    background: transparent;
    color: var(--text-secondary);
    font-weight: 600;
    font-size: 0.8125rem;
    white-space: nowrap;
    flex-shrink: 0;
}

#admin-dashboard .admin-tabs .tab-btn::after {
    display: none;
}

#admin-dashboard .admin-tabs .tab-btn:hover {
    background: var(--bg-secondary);
    color: var(--text-primary);
}

#admin-dashboard .admin-tabs .tab-btn.active {
    background: linear-gradient(135deg, #6366f1, #818cf8);
    color: #fff;
    box-shadow: 0 6px 16px rgba(99, 102, 241, 0.35);
}

#admin-dashboard .admin-tab-content {
    animation: adminTabIn 0.35s ease;
}

#admin-dashboard .admin-tab-content.active {
    display: block;
}

@keyframes adminTabIn {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

#admin-dashboard .section-header h2 {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 1.25rem;
}

#admin-dashboard .section-header h2::before {
    content: '';
    width: 4px;
    height: 1.25rem;
    border-radius: 999px;
    background: linear-gradient(180deg, #6366f1, #818cf8);
}

#admin-dashboard .admin-info-banner {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.9rem 1rem;
    margin-bottom: 1rem;
    border-radius: 12px;
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.08), rgba(129, 140, 248, 0.06));
    border: 1px solid rgba(99, 102, 241, 0.18);
    color: #4338ca;
}

#admin-dashboard .admin-info-banner i {
    margin-top: 0.15rem;
    font-size: 1rem;
}

#admin-dashboard .admin-info-banner p {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.55;
    color: #374151;
}

#admin-dashboard .admin-info-banner a {
    color: #4338ca;
    font-weight: 600;
}

#admin-dashboard .admin-vibrant-panel {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 1.25rem 1.35rem;
    box-shadow: var(--shadow);
    max-width: 760px;
    position: relative;
    overflow: hidden;
}

#admin-dashboard .admin-vibrant-panel::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, #6366f1, #818cf8, #a5b4fc);
}

#admin-dashboard .admin-panel-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

#admin-dashboard .admin-panel-icon {
    width: 42px;
    height: 42px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(99, 102, 241, 0.12);
    color: #6366f1;
}

#admin-dashboard .admin-panel-header h3 {
    margin: 0;
    font-size: 1.05rem;
}

#admin-dashboard .filters-bar {
    border: 1px solid var(--border-color);
    border-radius: 14px;
    transition: box-shadow 0.2s ease;
}

#admin-dashboard .filters-bar:focus-within {
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.12);
}

#admin-dashboard .table-container {
    border: 1px solid var(--border-color);
    border-radius: 14px;
    overflow: hidden;
}

#admin-dashboard .admin-table tbody tr {
    transition: background 0.18s ease, transform 0.18s ease;
}

#admin-dashboard .admin-table tbody tr:hover {
    background: rgba(99, 102, 241, 0.04);
}

#admin-dashboard .admin-table .btn-icon {
    border: 1px solid transparent;
}

#admin-dashboard .admin-table .btn-icon:hover {
    background: rgba(99, 102, 241, 0.1);
    border-color: rgba(99, 102, 241, 0.2);
    transform: scale(1.06);
}

#admin-dashboard .stat-card.mini {
    border-radius: 14px;
    padding: 1rem 1.1rem;
    border: 1px solid var(--border-color);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#admin-dashboard .stat-card.mini:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

#admin-dashboard .bulk-op-card {
    border: 1px solid var(--border-color);
    transition: transform 0.22s ease, box-shadow 0.22s ease;
}

#admin-dashboard .bulk-op-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.1);
}

#admin-dashboard .upload-area:hover {
    border-color: #6366f1;
    background: rgba(99, 102, 241, 0.04);
}

#admin-dashboard .territory-card {
    border: 1px solid var(--border-color);
    position: relative;
    overflow: hidden;
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

#admin-dashboard .territory-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, #6366f1, #818cf8);
}

#admin-dashboard .territory-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 30px rgba(99, 102, 241, 0.14);
    border-color: rgba(99, 102, 241, 0.25);
}

#admin-dashboard .territory-card h3 {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

#admin-dashboard .territory-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin: 0.75rem 0 1rem;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

#admin-dashboard .empty-state {
    grid-column: 1 / -1;
    text-align: center;
    padding: 3rem 1.5rem;
    border-radius: 16px;
    border: 1px dashed var(--border-color);
    background: var(--bg-secondary);
}

#admin-dashboard .empty-state i {
    font-size: 2.5rem;
    color: #a5b4fc;
    margin-bottom: 0.75rem;
}

#admin-dashboard .health-card {
    border: 1px solid var(--border-color);
    position: relative;
    overflow: hidden;
    transition: transform 0.22s ease, box-shadow 0.22s ease;
}

#admin-dashboard .health-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, #6366f1, #818cf8);
}

#admin-dashboard .health-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-lg);
}

#admin-dashboard .health-card.health-ok::before { background: linear-gradient(90deg, #10b981, #34d399); }
#admin-dashboard .health-card.health-warn::before { background: linear-gradient(90deg, #f59e0b, #fbbf24); }
#admin-dashboard .health-card.health-error::before { background: linear-gradient(90deg, #ef4444, #f87171); }

#admin-dashboard .health-card-top {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.85rem;
}

#admin-dashboard .health-card-top h3 {
    margin: 0;
    font-size: 0.95rem;
}

#admin-dashboard .health-card-icon {
    width: 40px;
    height: 40px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
}

#admin-dashboard .health-icon-database { background: rgba(99, 102, 241, 0.12); color: #6366f1; }
#admin-dashboard .health-icon-storage { background: rgba(14, 165, 233, 0.12); color: #0284c7; }
#admin-dashboard .health-icon-sessions { background: rgba(16, 185, 129, 0.12); color: #059669; }
#admin-dashboard .health-icon-errors { background: rgba(239, 68, 68, 0.12); color: #dc2626; }

#admin-dashboard .health-progress {
    height: 8px;
    border-radius: 999px;
    background: #e5e7eb;
    margin-top: 0.85rem;
    overflow: hidden;
}

#admin-dashboard .health-progress-fill {
    height: 100%;
    border-radius: 999px;
    background: linear-gradient(90deg, #6366f1, #818cf8);
    transition: width 0.6s ease;
}

#admin-dashboard .health-card.health-warn .health-progress-fill {
    background: linear-gradient(90deg, #f59e0b, #fbbf24);
}

#admin-dashboard .health-card.health-error .health-progress-fill {
    background: linear-gradient(90deg, #ef4444, #f87171);
}

#admin-dashboard .admin-report-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1rem;
    margin-bottom: 1.25rem;
}

#admin-dashboard .admin-report-card {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    padding: 1rem 1.1rem;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

#admin-dashboard .admin-report-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 26px rgba(99, 102, 241, 0.14);
    border-color: rgba(99, 102, 241, 0.3);
}

#admin-dashboard .admin-report-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.65rem;
}

#admin-dashboard .admin-report-card-icon {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(99, 102, 241, 0.12);
    color: #6366f1;
}

#admin-dashboard .admin-report-card h4 {
    margin: 0 0 0.35rem;
    font-size: 0.95rem;
}

#admin-dashboard .admin-report-card p {
    margin: 0;
    font-size: 0.8125rem;
    color: var(--text-secondary);
    line-height: 1.45;
}

#admin-dashboard .admin-report-card-action {
    margin-top: 0.75rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: #6366f1;
}

#admin-dashboard .admin-reports-table {
    margin-top: 0.5rem;
}

#admin-dashboard .audit-action-badge {
    display: inline-block;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: capitalize;
}

#admin-dashboard .audit-action-login { background: rgba(59, 130, 246, 0.12); color: #2563eb; }
#admin-dashboard .audit-action-create { background: rgba(16, 185, 129, 0.12); color: #059669; }
#admin-dashboard .audit-action-update { background: rgba(245, 158, 11, 0.12); color: #d97706; }
#admin-dashboard .audit-action-delete { background: rgba(239, 68, 68, 0.12); color: #dc2626; }
#admin-dashboard .audit-action-default { background: rgba(107, 114, 128, 0.12); color: #4b5563; }

#admin-dashboard .admin-users-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem 1.25rem;
    margin-bottom: 1rem;
    padding: 0.75rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    background: var(--bg-primary);
}

#admin-dashboard .admin-users-select-all {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text-primary);
    cursor: pointer;
    user-select: none;
}

#admin-dashboard .admin-users-selection-count {
    font-size: 0.8125rem;
    font-weight: 600;
    color: #6366f1;
}

#admin-dashboard .admin-users-result-count {
    margin-left: auto;
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

#admin-dashboard .admin-users-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 1rem;
}

#admin-dashboard .admin-user-card {
    position: relative;
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 1rem 1rem 0.85rem;
    box-shadow: var(--shadow);
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
    overflow: hidden;
}

#admin-dashboard .admin-user-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, #6366f1, #818cf8);
    opacity: 0;
    transition: opacity 0.2s ease;
}

#admin-dashboard .admin-user-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 28px rgba(99, 102, 241, 0.12);
    border-color: rgba(99, 102, 241, 0.25);
}

#admin-dashboard .admin-user-card:hover::before,
#admin-dashboard .admin-user-card.selected::before {
    opacity: 1;
}

#admin-dashboard .admin-user-card.selected {
    border-color: rgba(99, 102, 241, 0.45);
    background: linear-gradient(180deg, rgba(99, 102, 241, 0.04) 0%, var(--bg-primary) 100%);
}

#admin-dashboard .admin-user-card-select {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    cursor: pointer;
}

#admin-dashboard .admin-user-card-select input {
    width: 1rem;
    height: 1rem;
    accent-color: #6366f1;
    cursor: pointer;
}

#admin-dashboard .admin-user-card-header {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding-right: 1.5rem;
    margin-bottom: 0.75rem;
}

#admin-dashboard .admin-user-card-avatar {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    object-fit: cover;
    flex-shrink: 0;
}

#admin-dashboard .admin-user-card-avatar--initials {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 700;
    font-size: 0.95rem;
}

#admin-dashboard .admin-user-card-identity {
    flex: 1;
    min-width: 0;
}

#admin-dashboard .admin-user-card-identity h4 {
    margin: 0 0 0.2rem;
    font-size: 1rem;
    color: var(--text-primary);
    line-height: 1.3;
    word-break: break-word;
}

#admin-dashboard .admin-user-card-email {
    margin: 0;
    font-size: 0.8125rem;
    color: var(--text-secondary);
    word-break: break-all;
}

#admin-dashboard .admin-user-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 0.85rem;
}

#admin-dashboard .admin-user-card-footer {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--border-color);
}

#admin-dashboard .admin-user-card-login {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

#admin-dashboard .admin-user-card-login i {
    margin-right: 0.25rem;
    color: #9ca3af;
}

#admin-dashboard .admin-user-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

#admin-dashboard .admin-user-card-actions .btn-icon {
    border: 1px solid var(--border-color);
    border-radius: 8px;
    background: var(--bg-secondary);
}

#admin-dashboard .admin-user-card-actions .btn-icon:hover {
    background: rgba(99, 102, 241, 0.1);
    border-color: rgba(99, 102, 241, 0.25);
}

#admin-dashboard .admin-users-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 3rem 1.5rem;
    border-radius: 16px;
    border: 1px dashed var(--border-color);
    background: var(--bg-secondary);
}

#admin-dashboard .admin-users-empty i {
    font-size: 2.5rem;
    color: #a5b4fc;
    margin-bottom: 0.75rem;
}

#admin-dashboard .admin-users-empty h3 {
    margin: 0 0 0.35rem;
    color: var(--text-primary);
}

#admin-dashboard .admin-users-empty p {
    margin: 0;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

/* Shared admin list cards (organizations, vendors, marketplace, etc.) */
#admin-dashboard .admin-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 1rem;
}

#admin-dashboard .admin-list-card {
    position: relative;
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 1rem 1.1rem;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

#admin-dashboard .admin-list-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    border-radius: 16px 16px 0 0;
    background: linear-gradient(90deg, #6366f1, #818cf8);
    opacity: 0;
    transition: opacity 0.2s ease;
}

#admin-dashboard .admin-list-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 28px rgba(99, 102, 241, 0.12);
    border-color: rgba(99, 102, 241, 0.25);
}

#admin-dashboard .admin-list-card:hover::before {
    opacity: 1;
}

#admin-dashboard .admin-list-card-header {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
}

#admin-dashboard .admin-list-card-icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(99, 102, 241, 0.1);
    color: #6366f1;
    flex-shrink: 0;
    font-size: 1.1rem;
}

#admin-dashboard .admin-list-card-identity {
    flex: 1;
    min-width: 0;
}

#admin-dashboard .admin-list-card-identity h4 {
    margin: 0 0 0.2rem;
    font-size: 1rem;
    color: var(--text-primary);
    line-height: 1.3;
}

#admin-dashboard .admin-list-card-identity p {
    margin: 0;
    font-size: 0.8125rem;
    color: var(--text-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#admin-dashboard .admin-list-card-kicker {
    display: inline-block;
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #6366f1;
    margin-bottom: 0.15rem;
}

#admin-dashboard .admin-list-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

#admin-dashboard .admin-list-card-meta i {
    margin-right: 0.3rem;
    color: #9ca3af;
}

#admin-dashboard .admin-list-card-detail {
    font-size: 0.8125rem;
    color: var(--text-secondary);
    line-height: 1.45;
}

#admin-dashboard .admin-list-card-detail strong {
    display: block;
    color: var(--text-primary);
    margin-bottom: 0.15rem;
}

#admin-dashboard .admin-list-card-muted {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

#admin-dashboard .admin-list-card-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

#admin-dashboard .admin-list-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-top: auto;
    padding-top: 0.5rem;
    border-top: 1px solid var(--border-color);
}

#admin-dashboard .admin-list-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    justify-content: flex-end;
}

#admin-dashboard .admin-list-card-actions--wrap {
    flex-wrap: wrap;
}

#admin-dashboard .admin-list-card-actions .btn-icon {
    border: 1px solid var(--border-color);
    border-radius: 8px;
    background: var(--bg-secondary);
}

#admin-dashboard .admin-list-card-actions .btn-icon:hover {
    background: rgba(99, 102, 241, 0.1);
    border-color: rgba(99, 102, 241, 0.25);
}

#admin-dashboard .admin-cards-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 3rem 1.5rem;
    border-radius: 16px;
    border: 1px dashed var(--border-color);
    background: var(--bg-secondary);
}

#admin-dashboard .admin-cards-empty i {
    font-size: 2.5rem;
    color: #a5b4fc;
    margin-bottom: 0.75rem;
}

#admin-dashboard .admin-cards-empty h3,
#admin-dashboard .admin-cards-empty p {
    margin: 0;
    color: var(--text-secondary);
}

#admin-dashboard .admin-cards-empty h3 {
    color: var(--text-primary);
    margin-bottom: 0.35rem;
}

#admin-dashboard #adminTabAssignments .admin-list-card {
    min-height: 0;
}

#admin-dashboard #adminTabAssignments .admin-cards-grid {
    margin-top: 0.5rem;
}

#admin-dashboard #adminTabAssignments .assignment-tabs {
    border-bottom: none;
    padding: 0.35rem;
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    margin-bottom: 1rem;
}

#admin-dashboard #adminTabAssignments .assignment-tab-btn {
    border-radius: 10px;
    border-bottom: none;
}

#admin-dashboard #adminTabAssignments .assignment-tab-btn:hover {
    color: #6366f1;
    background: rgba(99, 102, 241, 0.08);
}

#admin-dashboard #adminTabAssignments .assignment-tab-btn.active {
    color: #fff;
    background: linear-gradient(135deg, #6366f1, #818cf8);
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.28);
}

#admin-dashboard #adminTabAssignments .officer-summary-card,
#admin-dashboard #adminTabAssignments .stat-card {
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#admin-dashboard #adminTabAssignments .officer-summary-card:hover,
#admin-dashboard #adminTabAssignments .stat-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-lg);
}

@media (max-width: 768px) {
    #admin-dashboard .admin-hero-header {
        padding: 1.5rem;
    }

    #admin-dashboard .admin-hero-header h1 {
        font-size: 1.45rem;
    }
}

@media (max-width: 480px) {
    #admin-dashboard .admin-tabs .tab-btn i {
        display: inline-block;
    }
}

/* ===============================================
   Chief Field Officer Dashboard Styles
   =============================================== */

/* Officer Cards Grid */
.officers-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(300px, 100%), 1fr));
    gap: 1.5rem;
    margin-top: 1.5rem;
}

.officer-card {
    background: var(--bg-primary);
    padding: 1.5rem;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow);
    transition: all 0.3s ease;
}

.officer-card:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    transform: translateY(-2px);
}

/* Analytics Container */
.analytics-container {
    margin-top: 1.5rem;
}

.charts-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}

.chart-card {
    background: var(--bg-primary);
    padding: 1.5rem;
    border-radius: 16px;
    border: 1px solid var(--border-color);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
    position: relative;
    overflow: hidden;
}

.chart-card::before {
    content: '';
    display: block;
    height: 4px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    background: linear-gradient(90deg, #0ea5e9, #06b6d4);
}

.chart-card h3 {
    margin: 0 0 1rem 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
}

.chart-card canvas {
    height: 300px !important;
}

/* Bulk Actions Bar */
.bulk-actions-bar {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    background: var(--bg-secondary);
    border-radius: 0.5rem;
    border: 1px solid var(--border-color);
}

.bulk-actions-bar span {
    flex: 1;
    font-weight: 500;
    color: var(--text-primary);
}

/* Recommendation Detail Modal */
.recommendation-detail .detail-section {
    margin-bottom: 1.5rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--border-color);
}

.recommendation-detail .detail-section:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.recommendation-detail h4 {
    margin: 0 0 0.5rem 0;
    font-size: 0.875rem;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--text-secondary);
    letter-spacing: 0.05em;
}

/* Badge Styles */
.badge {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

.badge-low {
    background: rgba(59, 130, 246, 0.1);
    color: #1e40af;
}

.badge-medium {
    background: rgba(245, 158, 11, 0.1);
    color: var(--warning-color);
}

.badge-high {
    background: rgba(239, 68, 68, 0.1);
    color: var(--error-color);
}

.badge-pending {
    background: rgba(245, 158, 11, 0.1);
    color: var(--warning-color);
}

.badge-approved {
    background: rgba(16, 185, 129, 0.1);
    color: var(--success-color);
}

.badge-rejected {
    background: rgba(239, 68, 68, 0.1);
    color: var(--error-color);
}

.badge-success {
    background: rgba(16, 185, 129, 0.1);
    color: var(--success-color);
}

.badge-danger {
    background: rgba(239, 68, 68, 0.1);
    color: var(--error-color);
}

/* Button Variants */
.btn-success {
    background: var(--success-color);
    color: white;
    border: none;
}

.btn-success:hover {
    background: var(--secondary-color);
}

.btn-danger {
    background: var(--error-color);
    color: white;
    border: none;
}

.btn-danger:hover {
    background: #a52f1a;  /* Darker warm red for Ubuntu Farming palette */
}

.btn-warning {
    background: var(--warning-color);
    color: white;
    border: none;
}

.btn-warning:hover {
    background: #c08a3a;  /* Darker warm amber for Ubuntu Farming palette */
}

.btn-sm {
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
}

.btn-icon-danger {
    color: var(--error-color);
    background: transparent;
    border: none;
    padding: 0.5rem;
    cursor: pointer;
    transition: all 0.2s;
    border-radius: 4px;
}

.btn-icon-danger:hover {
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
}

/* Officer Performance Modal */
.officer-performance {
    padding: 1rem 0;
}

/* ========================================
   DETAIL VIEW STYLES
   ======================================== */
.detail-section {
    margin-bottom: 1.5rem;
}

.detail-section h3 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 1rem;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid var(--border-color);
}

.detail-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(250px, 100%), 1fr));
    gap: 1rem;
}

.detail-item {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.detail-item .label {
    font-weight: 600;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.detail-item .value {
    color: var(--text-primary);
    font-size: 1rem;
}

.farm-details-view,
.equipment-details-view,
.crop-details-view,
.livestock-details-view {
    padding: 0.5rem 0;
}

.form-actions {
    display: flex;
    justify-content: flex-end;
    gap: 1rem;
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
}

/* ========================================
   CEO DASHBOARD STYLES
   ======================================== */

/* CEO Dashboard Tabs */
.dashboard-tabs {
    display: flex;
    gap: 0.75rem;
    margin: 2rem 0 1.5rem;
    border-bottom: 2px solid var(--border-color);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.dashboard-tabs .tab-button {
    background: none;
    border: none;
    padding: 1rem 1.5rem;
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--text-secondary);
    cursor: pointer;
    position: relative;
    white-space: nowrap;
    transition: all 0.3s ease;
}

.dashboard-tabs .tab-button:hover {
    color: var(--primary-color);
}

.dashboard-tabs .tab-button.active {
    color: var(--primary-color);
}

.dashboard-tabs .tab-button.active::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--primary-color);
}

.dashboard-tabs .tab-button i {
    margin-right: 0.5rem;
}

/* CEO Tab Content */
.tabs-container {
    margin-top: 1.5rem;
}

.tabs-container .tab-content {
    display: none;
    animation: fadeIn 0.3s ease;
}

.tabs-container .tab-content.active {
    display: block;
}

/* CEO Dashboard Specific Elements */
.role-dashboard .card {
    background: var(--bg-primary);
    padding: 1.5rem;
    border-radius: 16px;
    border: 1px solid var(--border-color);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
    margin-bottom: 1.5rem;
    position: relative;
    overflow: hidden;
}

.role-dashboard .card::before {
    content: '';
    display: block;
    height: 4px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    background: linear-gradient(90deg, #8b5cf6, #a78bfa);
}

.role-dashboard .card h3 {
    font-size: 1.125rem;
    font-weight: 600;
    margin-bottom: 1rem;
    color: var(--text-primary);
}

.data-table {
    width: 100%;
    border-collapse: collapse;
}

.data-table thead {
    background: var(--bg-secondary);
}

.data-table th {
    padding: 0.75rem 1rem;
    text-align: left;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: 2px solid var(--border-color);
}

.data-table td {
    padding: 1rem;
    border-bottom: 1px solid var(--border-color);
    color: var(--text-primary);
}

.data-table tbody tr:hover {
    background: var(--bg-secondary);
}

/* Responsive Design for Chief Dashboard */
@media (max-width: 768px) {
    .officers-grid {
        grid-template-columns: 1fr;
    }

    .charts-grid {
        grid-template-columns: 1fr;
    }

    .bulk-actions-bar {
        flex-direction: column;
        align-items: stretch;
    }

    .bulk-actions-bar span {
        text-align: center;
    }

    .dashboard-tabs {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .dashboard-tabs .tab-button {
        padding: 0.75rem 1rem;
        font-size: 0.875rem;
    }
}

/* ============================================
   FARM MANAGEMENT SYSTEM STYLES
   ============================================ */

/* Farm Management Modal */
.farm-management-modal .farm-management-container {
    background: white;
    border-radius: 12px;
    width: 95%;
    max-width: 1400px;
    height: 90vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0,0,0,0.3);
}

.farm-management-modal .farm-header {
    padding: 24px;
    border-bottom: 2px solid var(--border-color);
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--secondary-color) 100%);
    color: white;
}

.farm-management-modal .actions-bar {
    padding: 16px 24px;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    background: var(--bg-secondary);
}

.farm-management-modal .filters-panel {
    padding: 16px 24px;
    border-bottom: 1px solid var(--border-color);
    background: var(--bg-secondary);
}

.farm-management-modal .spreadsheet-container {
    flex: 1;
    overflow: auto;
    padding: 24px;
    background: var(--bg-secondary);
}

/* Plant Table Styles */
.plant-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--bg-primary);
    box-shadow: var(--shadow);
    border-radius: var(--radius);
    overflow: hidden;
}

.plant-table thead {
    background: var(--bg-secondary);
    position: sticky;
    top: 0;
    z-index: 10;
}

.plant-table th {
    padding: 12px;
    text-align: left;
    font-weight: 600;
    color: var(--text-primary);
    cursor: pointer;
    white-space: nowrap;
    user-select: none;
}

.plant-table th:hover {
    background: var(--border-color);
}

.plant-table tbody tr {
    border-bottom: 1px solid var(--border-color);
    transition: background 0.2s;
}

.plant-table tbody tr:hover {
    background: var(--bg-secondary);
}

.plant-table td {
    padding: 12px;
    color: var(--text-primary);
}

/* Plant Detail Modal */
.plant-detail-modal .plant-info-card {
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.05) 0%, rgba(16, 185, 129, 0.1) 100%);
    border: 2px solid var(--primary-color);
    border-radius: var(--radius-lg);
    padding: 24px;
    margin-bottom: 24px;
}

.plant-detail-modal .timeline {
    position: relative;
    padding-left: 40px;
}

.plant-detail-modal .timeline-item {
    position: relative;
    padding-bottom: 24px;
}

.plant-detail-modal .timeline-item:last-child {
    padding-bottom: 0;
}

/* Activity Logger Modal */
.activity-logger-modal form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.activity-logger-modal label {
    display: block;
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--text-primary);
}

.activity-logger-modal input[type="text"],
.activity-logger-modal input[type="date"],
.activity-logger-modal input[type="time"],
.activity-logger-modal input[type="number"],
.activity-logger-modal input[type="file"],
.activity-logger-modal select,
.activity-logger-modal textarea {
    width: 100%;
    padding: 10px;
    border: 2px solid var(--border-color);
    border-radius: var(--radius);
    font-size: 1rem;
    font-family: inherit;
    background: #ffffff;
    color: #1f2937;
    transition: border-color 0.2s;
}

.activity-logger-modal input::placeholder,
.activity-logger-modal textarea::placeholder {
    color: #9ca3af;
}

.activity-logger-modal input:focus,
.activity-logger-modal select:focus,
.activity-logger-modal textarea:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.1);
}

.activity-logger-modal textarea {
    resize: vertical;
    min-height: 80px;
}

/* Search and Filter Inputs */
.search-input,
.filter-select {
    padding: 8px 12px;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    font-size: 0.875rem;
    background: #ffffff;
    color: #1f2937;
    transition: border-color 0.2s;
}

.search-input::placeholder {
    color: #9ca3af;
}

.search-input:focus,
.filter-select:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.1);
}

.search-input {
    width: 250px;
}

.filter-select {
    min-width: 150px;
}

/* Pagination Styles */
.pagination-bar {
    padding: 16px 24px;
    border-top: 1px solid var(--border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--bg-primary);
}

#pagination-controls {
    display: flex;
    gap: 8px;
    align-items: center;
}

#pagination-controls button {
    min-width: 36px;
    height: 36px;
    padding: 0.5rem;
}

#pagination-controls button:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Status Badges */
.status-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 12px;
    border-radius: 12px;
    font-size: 0.875rem;
    font-weight: 500;
}

/* Button Danger Styles - Consolidated */
.btn-danger {
    background: var(--error-color);
    color: white;
    border: none;
}

.btn-danger:hover {
    background: #dc2626;
}

/* View Plants Button on Farm Cards */
.farm-card .farm-actions .view-plants-btn {
    width: 100%;
    margin-top: 8px;
}

.farm-card.enhanced {
    cursor: pointer;
    transition: transform 0.2s, box-shadow 0.2s;
}

.farm-card.enhanced:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

/* Empty State Styles - Consolidated */
.empty-state {
    text-align: center;
    padding: 40px 20px;
    color: var(--text-secondary);
}

.empty-state i {
    font-size: 3rem;
    margin-bottom: 12px;
    opacity: 0.3;
    display: block;
    color: var(--text-light);
}

.empty-state p {
    margin: 8px 0;
}

/* Loading State */
.loading-state {
    text-align: center;
    padding: 40px;
    color: var(--text-secondary);
}

.loading-state i {
    font-size: 2rem;
    margin-bottom: 12px;
}

/* Mobile Responsive Styles for Farm Management */
@media (max-width: 768px) {
    .farm-management-modal .farm-management-container {
        width: 100%;
        height: 100vh;
        border-radius: 0;
    }

    .farm-management-modal .actions-bar {
        flex-direction: column;
        align-items: stretch;
    }

    .search-input {
        width: 100%;
    }

    .plant-table {
        font-size: 0.875rem;
    }

    .plant-table th,
    .plant-table td {
        padding: 8px;
    }

    .plant-table th {
        font-size: 0.8rem;
    }

    /* Hide some columns on mobile */
    .plant-table th:nth-child(6),
    .plant-table td:nth-child(6),
    .plant-table th:nth-child(7),
    .plant-table td:nth-child(7) {
        display: none;
    }

    .pagination-bar {
        flex-direction: column;
        gap: 12px;
    }

    #pagination-controls {
        width: 100%;
        justify-content: center;
        flex-wrap: wrap;
    }

    .activity-logger-modal input,
    .activity-logger-modal select,
    .activity-logger-modal textarea {
        font-size: 16px; /* Prevents zoom on iOS */
    }
}

/* Print Styles */
@media print {
    .farm-management-modal .actions-bar,
    .farm-management-modal .pagination-bar,
    .plant-table th:last-child,
    .plant-table td:last-child,
    .sidebar,
    .header {
        display: none;
    }

    .farm-management-modal .farm-management-container {
        height: auto;
        box-shadow: none;
    }

    .plant-table {
        box-shadow: none;
    }

    .main-content {
        margin-left: 0;
    }
}

/* Accessibility Improvements */
.btn:focus,
.search-input:focus,
.filter-select:focus,
input:focus,
select:focus,
textarea:focus {
    outline: 2px solid var(--primary-color);
    outline-offset: 2px;
}

/* Smooth Transitions */
.modal,
.plant-table tbody tr,
.btn,
.search-input,
.filter-select,
.stat-card,
.crop-card,
.farm-card {
    transition: all 0.2s ease;
}

/* Z-Index Management */
.farm-management-modal {
    z-index: 10000;
}

.plant-detail-modal {
    z-index: 10001;
}

.activity-logger-modal {
    z-index: 10002;
}

/* Scrollbar Styling */
.spreadsheet-container::-webkit-scrollbar,
.content::-webkit-scrollbar,
.sidebar::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

.spreadsheet-container::-webkit-scrollbar-track,
.content::-webkit-scrollbar-track,
.sidebar::-webkit-scrollbar-track {
    background: var(--bg-secondary);
    border-radius: 4px;
}

.spreadsheet-container::-webkit-scrollbar-thumb,
.content::-webkit-scrollbar-thumb,
.sidebar::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 4px;
}

.spreadsheet-container::-webkit-scrollbar-thumb:hover,
.content::-webkit-scrollbar-thumb:hover,
.sidebar::-webkit-scrollbar-thumb:hover {
    background: var(--text-secondary);
}

/* ===== Submenu Navigation ===== */
.nav-item.has-submenu {
    position: relative;
}

.nav-item.has-submenu > .nav-link {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.submenu-arrow {
    font-size: 0.75rem;
    transition: transform 0.3s ease;
    margin-left: auto;
}

.nav-item.has-submenu.open > .nav-link .submenu-arrow {
    transform: rotate(180deg);
}

.submenu {
    display: none;
    list-style: none;
    padding: 0;
    margin: 0;
    background: rgba(0, 0, 0, 0.1);
    border-radius: 8px;
    margin-top: 0.5rem;
    overflow: hidden;
}

.nav-item.has-submenu.open .submenu {
    display: block;
    animation: slideDown 0.3s ease-out;
}

.submenu .nav-item {
    margin: 0;
}

.submenu .nav-link {
    padding: 0.75rem 1rem 0.75rem 2.5rem;
    font-size: 0.875rem;
}

.submenu .nav-link i {
    font-size: 0.875rem;
    width: 1.25rem;
}

@keyframes slideDown {
    from {
        opacity: 0;
        max-height: 0;
    }
    to {
        opacity: 1;
        max-height: 500px;
    }
}

/* ============================================
   ECONOMIC TRENDS ANALYSIS STYLES
   ============================================ */

.economic-trends-section {
    background: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);
    border: 1px solid #a7f3d0;
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    margin-top: 1rem;
}

.economic-trends-section h3 {
    color: #059669;
}

.economic-trends-section h4 {
    color: #374151;
    border-bottom: 2px solid #d1fae5;
    padding-bottom: 0.5rem;
}

/* Commodity Cards */
.economic-trends-section .prediction-card {
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.economic-trends-section .prediction-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.15);
}

/* Market Timing Badges */
.market-timing-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.25rem 0.75rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
}

.market-timing-badge.sell-now {
    background: #d1fae5;
    color: #059669;
    border: 1px solid #059669;
}

.market-timing-badge.hold {
    background: #fef3c7;
    color: #d97706;
    border: 1px solid #d97706;
}

.market-timing-badge.wait {
    background: #fee2e2;
    color: #dc2626;
    border: 1px solid #dc2626;
}

/* Price Trend Indicators */
.price-trend-up {
    color: #059669;
}

.price-trend-down {
    color: #dc2626;
}

.price-trend-stable {
    color: #d97706;
}

/* Economic Outlook Cards */
.economic-outlook-positive {
    background: #d1fae5;
    border-color: #059669;
}

.economic-outlook-neutral {
    background: #fef3c7;
    border-color: #d97706;
}

.economic-outlook-cautious {
    background: #fee2e2;
    border-color: #dc2626;
}

/* Cost Saving Opportunities */
.cost-saving-card {
    background: #ecfdf5;
    border-left: 4px solid #10b981;
    padding: 1rem;
    border-radius: 0.5rem;
}

.cost-saving-card ul {
    margin: 0.5rem 0 0 1rem;
    padding: 0;
}

.cost-saving-card li {
    color: #374151;
    margin-bottom: 0.25rem;
}

/* Responsive adjustments for economic trends */
@media (max-width: 768px) {
    .economic-trends-section {
        padding: 1rem;
    }

    .economic-trends-section .prediction-card > div[style*="grid-template-columns: 1fr 1fr 1fr"] {
        grid-template-columns: 1fr !important;
    }

    .economic-trends-section .prediction-card > div[style*="grid-template-columns: repeat(3, 1fr)"] {
        grid-template-columns: 1fr !important;
    }
}

/* ========================================
   UNIFIED NOTIFICATION SYSTEM
   All notifications appear in top-right, consistent with impersonation banner
   ======================================== */

/* Notification Container - stacks notifications vertically */
.notification-container {
    position: fixed;
    top: 60px; /* Below the impersonation banner when visible */
    right: 20px;
    z-index: 10005;
    display: flex;
    flex-direction: column;
    gap: 10px;
    max-width: 400px;
    pointer-events: none;
}

/* When impersonation banner is hidden, notifications move up */
body:not(.impersonation-active) .notification-container {
    top: 12px;
}

/* Toast Notification Styles - Aligned with header profile section */
.notification {
    position: fixed;
    top: 70px; /* Below the header, aligned with profile area */
    right: 20px;
    left: auto;
    transform: translateX(120%);
    background: var(--success-color, #4a6741);
    color: white;
    padding: 0.75rem 1rem;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25), 0 2px 4px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease-out, opacity 0.3s ease, top 0.3s ease;
    z-index: 10005;
    max-width: min(400px, calc(100vw - 40px));
    min-width: min(300px, calc(100vw - 40px));
    text-align: left;
    font-size: 0.9rem;
    font-weight: 500;
    line-height: 1.4;
    letter-spacing: 0.01em;
    overflow: hidden;
    pointer-events: auto;
}

/* Progress bar animation for auto-dismiss */
.notification::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    height: 3px;
    width: 100%;
    background: rgba(255, 255, 255, 0.5);
    animation: notification-progress 5s linear forwards;
}

/* Longer progress bar for error notifications (8s) */
.notification.error::after {
    animation: notification-progress 8s linear forwards;
}

/* Longer progress bar for warning notifications (7s) */
.notification.warning::after {
    animation: notification-progress 7s linear forwards;
    background: rgba(0, 0, 0, 0.25);
}

@keyframes notification-progress {
    from { width: 100%; }
    to { width: 0%; }
}

/* Slide in from right when shown */
.notification.show {
    transform: translateX(0);
}

/* Stack multiple notifications - positioned below header */
.notification:nth-child(2) { top: 120px; }
.notification:nth-child(3) { top: 170px; }
.notification:nth-child(4) { top: 220px; }

/* Error notification - using app color scheme */
.notification.error {
    background: linear-gradient(135deg, var(--error-color, #c73e1d) 0%, #a83519 100%);
}

/* Warning notification - using app color scheme */
.notification.warning {
    background: linear-gradient(135deg, var(--warning-color, #d4a056) 0%, #c08a3e 100%);
    color: #1a1a1a;
}

/* Info notification - using app color scheme */
.notification.info {
    background: linear-gradient(135deg, var(--info-color, #5c7a52) 0%, #4a6341 100%);
}

/* Success notification - using app color scheme */
.notification.success {
    background: linear-gradient(135deg, var(--primary-color, #4a6741) 0%, #3d5636 100%);
}

/* Impersonation-specific notification style */
.notification.impersonation {
    background: linear-gradient(135deg, var(--warning-color, #d4a056) 0%, #c48d3f 100%);
    color: #ffffff;
}

.notification-content {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.5rem;
}

.notification-icon {
    font-size: 1rem;
    opacity: 0.9;
    flex-shrink: 0;
}

.notification-message {
    flex: 1;
    font-weight: 500;
}

.notification-close {
    background: rgba(255, 255, 255, 0.2);
    border: none;
    color: inherit;
    cursor: pointer;
    padding: 0;
    opacity: 0.9;
    font-size: 0.85rem;
    border-radius: 50%;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s ease;
    flex-shrink: 0;
    margin-left: 0.5rem;
}

.notification-close:hover {
    opacity: 1;
    background: rgba(255, 255, 255, 0.35);
}

.notification.warning .notification-close {
    background: rgba(0, 0, 0, 0.1);
}

.notification.warning .notification-close:hover {
    background: rgba(0, 0, 0, 0.2);
}

@media (max-width: 768px) {
    .notification {
        top: auto;
        bottom: 150px; /* Above FAB (80px) + FAB height (56px) + margin */
        right: 10px;
        left: 10px;
        min-width: unset;
        max-width: none;
        transform: translateY(150px);
        font-size: 0.85rem;
        padding: 0.625rem 0.875rem;
    }

    .notification.show {
        transform: translateY(0);
    }

    .notification:nth-child(2) { top: auto; bottom: 205px; }
    .notification:nth-child(3) { top: auto; bottom: 260px; }
    /* Limit to 3 visible notifications on mobile to prevent overflow */
    .notification:nth-child(n+4) { display: none; }
}

@media (max-width: 480px) {
    .notification {
        bottom: 140px;
        font-size: 0.8rem;
        padding: 0.5rem 0.75rem;
    }

    .notification:nth-child(2) { bottom: 190px; }
    /* Limit to 2 visible notifications on small screens */
    .notification:nth-child(n+3) { display: none; }
}

/* ========================================
   SYNC INDICATOR
   Shows when data is being synced
   ======================================== */
.sync-indicator {
    position: fixed;
    top: 12px;
    right: 20px;
    background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%);
    color: white;
    padding: 0.5rem 1rem;
    border-radius: 8px;
    z-index: 9997;
    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.4);
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.85rem;
    font-weight: 500;
    animation: slideInRight 0.3s ease-out;
    overflow: hidden;
}

.sync-indicator.hidden {
    transform: translateX(120%);
    opacity: 0;
    transition: transform 0.3s ease, opacity 0.3s ease;
}

.sync-indicator i {
    animation: spin 1s linear infinite;
}

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.sync-indicator .sync-progress {
    position: absolute;
    bottom: 0;
    left: 0;
    height: 3px;
    background: rgba(255, 255, 255, 0.5);
    transition: width 0.3s ease;
}

/* Adjust notification position when sync indicator or impersonation banner is visible */
body.syncing .notification,
body.impersonation-active .notification {
    top: 120px;
}

body.syncing.impersonation-active .notification {
    top: 170px;
}

/* ========================================
   PROFILE SUMMARY STYLES
   ======================================== */

.profile-summary-container {
    max-width: 1200px;
    margin: 0 auto;
}

/* Profile Header Card */
.profile-header-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg, 12px);
    box-shadow: var(--shadow);
    padding: 2rem;
    display: flex;
    align-items: center;
    gap: 2rem;
    margin-bottom: 2rem;
    flex-wrap: wrap;
}

.profile-avatar-large {
    flex-shrink: 0;
}

.avatar-placeholder-large {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-dark, #3d5636) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 3rem;
    box-shadow: 0 4px 12px rgba(74, 103, 65, 0.3);
}

.profile-header-info {
    flex: 1;
    min-width: 200px;
}

.profile-header-info h2 {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 0.5rem;
}

.profile-role-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-dark, #3d5636) 100%);
    color: white;
    padding: 0.375rem 0.875rem;
    border-radius: 20px;
    font-size: 0.85rem;
    font-weight: 500;
    margin-bottom: 0.75rem;
}

.profile-email {
    color: var(--text-secondary);
    font-size: 0.95rem;
    margin-bottom: 0.5rem;
}

.profile-member-since {
    color: var(--text-secondary);
    font-size: 0.85rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.profile-member-since i {
    color: var(--primary-color);
}

.profile-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.profile-actions .btn-outline {
    background: transparent;
    border: 1px solid var(--border-color);
    color: var(--text-primary);
}

.profile-actions .btn-outline:hover {
    background: var(--bg-secondary);
    border-color: var(--primary-color);
    color: var(--primary-color);
}

/* Profile Details Grid */
.profile-details-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
    gap: 1.5rem;
}

.profile-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg, 12px);
    box-shadow: var(--shadow);
    overflow: hidden;
}

.profile-card-header {
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-primary) 100%);
    padding: 1rem 1.25rem;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    border-bottom: 1px solid var(--border-color);
}

.profile-card-header i {
    color: var(--primary-color);
    font-size: 1.1rem;
}

.profile-card-header h3 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

.profile-card-content {
    padding: 1.25rem;
}

.profile-info-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--border-color);
}

.profile-info-row:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.profile-info-row:first-child {
    padding-top: 0;
}

.profile-info-row label {
    color: var(--text-secondary);
    font-size: 0.875rem;
    font-weight: 500;
}

.profile-info-row span {
    color: var(--text-primary);
    font-weight: 500;
    text-align: right;
    max-width: 60%;
    word-break: break-word;
}

.profile-info-row .profile-id {
    font-family: monospace;
    font-size: 0.8rem;
    background: var(--bg-secondary);
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
}

.status-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.25rem 0.625rem;
    border-radius: 12px;
    font-size: 0.8rem;
    font-weight: 500;
}

.status-badge.status-active {
    background: rgba(16, 185, 129, 0.1);
    color: #059669;
}

.status-badge.status-inactive {
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
}

/* Profile Stats Grid */
.profile-stats-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

.profile-stat {
    text-align: center;
    padding: 1rem;
    background: var(--bg-secondary);
    border-radius: var(--radius);
}

.profile-stat .stat-value {
    display: block;
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--primary-color);
    margin-bottom: 0.25rem;
}

.profile-stat .stat-label {
    font-size: 0.8rem;
    color: var(--text-secondary);
    font-weight: 500;
}

/* Responsive Profile Styles */
@media (max-width: 768px) {
    .profile-header-card {
        flex-direction: column;
        text-align: center;
        padding: 1.5rem;
    }

    .profile-header-info {
        text-align: center;
    }

    .profile-member-since {
        justify-content: center;
    }

    .profile-actions {
        justify-content: center;
        width: 100%;
    }

    .profile-actions .btn {
        flex: 1;
        min-width: 120px;
    }

    .profile-details-grid {
        grid-template-columns: 1fr;
    }

    .avatar-placeholder-large {
        width: 100px;
        height: 100px;
        font-size: 2.5rem;
    }

    .profile-header-info h2 {
        font-size: 1.5rem;
    }
}

/* ========================================
   HR DASHBOARD STYLES
   ======================================== */

/* HR Tab Navigation - Support both .tab-btn and .tab-button */
.dashboard-tabs .tab-btn {
    background: none;
    border: none;
    padding: 1rem 1.5rem;
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--text-secondary);
    cursor: pointer;
    position: relative;
    white-space: nowrap;
    transition: all 0.3s ease;
}

.dashboard-tabs .tab-btn:hover {
    color: var(--primary-color);
    background: var(--bg-secondary);
}

.dashboard-tabs .tab-btn.active {
    color: var(--primary-color);
    font-weight: 600;
}

.dashboard-tabs .tab-btn.active::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--primary-color);
}

.dashboard-tabs .tab-btn i {
    margin-right: 0.5rem;
}

/* HR Tab Content */
.hr-tab-content {
    display: none;
    animation: fadeIn 0.3s ease;
    margin-top: 1.5rem;
}

.hr-tab-content.active {
    display: block;
}

.hr-accordion-toggle {
    display: none;
}

.hr-accordion-panel {
    display: block;
}

/* HR Table (Complaints Queue) */
.hr-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow);
}

.hr-table thead {
    background: var(--bg-secondary);
}

.hr-table th {
    padding: 1rem;
    text-align: left;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: 2px solid var(--border-color);
}

.hr-table td {
    padding: 1rem;
    border-bottom: 1px solid var(--border-color);
    color: var(--text-primary);
    vertical-align: middle;
}

.hr-table tbody tr:hover {
    background: var(--bg-secondary);
}

.hr-table .complainant-cell {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.hr-table .complainant-cell strong {
    color: var(--text-primary);
}

.hr-table .complainant-cell small {
    color: var(--text-secondary);
    font-size: 0.75rem;
}

.hr-table .action-buttons {
    display: flex;
    gap: 0.5rem;
}

.hr-table .btn-icon {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    width: 32px;
    height: 32px;
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
}

.hr-table .btn-icon:hover {
    background: var(--primary-color);
    color: white;
    border-color: var(--primary-color);
}

/* SLA Indicators */
.sla-met {
    color: var(--primary-color);
    font-weight: 500;
    font-size: 0.875rem;
}

.sla-ok {
    color: #10b981;
    font-weight: 500;
    font-size: 0.875rem;
    background: rgba(16, 185, 129, 0.1);
    padding: 0.25rem 0.5rem;
    border-radius: var(--radius);
}

.sla-warning {
    color: #f59e0b;
    font-weight: 600;
    font-size: 0.875rem;
    background: rgba(245, 158, 11, 0.1);
    padding: 0.25rem 0.5rem;
    border-radius: var(--radius);
}

.sla-overdue {
    color: #dc2626;
    font-weight: 600;
    font-size: 0.875rem;
    background: rgba(220, 38, 38, 0.1);
    padding: 0.25rem 0.5rem;
    border-radius: var(--radius);
}

/* Badge Variants for HR */
.badge {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 9999px;
    text-transform: capitalize;
}

.badge-info {
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
}

.badge-warning {
    background: rgba(245, 158, 11, 0.1);
    color: #d97706;
}

.badge-danger {
    background: rgba(220, 38, 38, 0.1);
    color: #dc2626;
}

.badge-success {
    background: rgba(16, 185, 129, 0.1);
    color: #059669;
}

.badge-secondary {
    background: var(--bg-secondary);
    color: var(--text-secondary);
}

/* Role-based badge colors */
.badge-admin,
.badge-ceo {
    background: rgba(139, 92, 246, 0.1);
    color: #7c3aed;
}

.badge-board {
    background: rgba(99, 102, 241, 0.1);
    color: #6366f1;
}

.badge-hr {
    background: rgba(236, 72, 153, 0.1);
    color: #db2777;
}

.badge-chief_field_officer {
    background: rgba(20, 184, 166, 0.1);
    color: #0d9488;
}

.badge-field_officer {
    background: rgba(59, 130, 246, 0.1);
    color: #2563eb;
}

.badge-user,
.badge-farmer {
    background: rgba(74, 103, 65, 0.1);
    color: var(--primary-color);
}

/* Status-based badge colors */
.badge-active {
    background: rgba(16, 185, 129, 0.1);
    color: #059669;
}

.badge-inactive {
    background: rgba(156, 163, 175, 0.1);
    color: #6b7280;
}

.badge-suspended {
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
}

/* Investigation Cards */
.investigations-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(320px, 100%), 1fr));
    gap: 1.5rem;
}

.investigation-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.investigation-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.investigation-header {
    padding: 1rem 1.25rem;
    background: var(--bg-secondary);
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--border-color);
}

.investigation-header h4 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

.investigation-body {
    padding: 1.25rem;
}

.investigation-body p {
    margin: 0.5rem 0;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.investigation-body p strong {
    color: var(--text-primary);
    font-weight: 500;
}

.investigation-actions {
    padding: 1rem 1.25rem;
    border-top: 1px solid var(--border-color);
    background: var(--bg-secondary);
}

/* Employee Directory Grid */
.employees-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(300px, 100%), 1fr));
    gap: 1.5rem;
}

/* HR Domain Dashboards (farmers, cooperatives, vendors, trainers) */
.hr-domain-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(320px, 100%), 1fr));
    gap: 1.5rem;
}

.hr-domain-card {
    overflow: hidden;
}

.hr-domain-header {
    display: flex;
    gap: 0.9rem;
    align-items: center;
    padding: 1.1rem 1.2rem;
    border-bottom: 1px solid var(--border-color);
    background: linear-gradient(135deg, rgba(236, 72, 153, 0.08) 0%, rgba(244, 114, 182, 0.04) 100%);
}

.hr-domain-avatar {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: linear-gradient(135deg, #db2777, #ec4899);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    box-shadow: 0 4px 12px rgba(236, 72, 153, 0.28);
    font-size: 1rem;
}

.hr-domain-header h4 {
    margin: 0;
    font-size: 1rem;
    color: var(--text-primary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.hr-domain-header p {
    margin: 0.2rem 0 0;
    color: var(--text-secondary);
    font-size: 0.85rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.hr-domain-metrics {
    padding: 1rem 1.2rem 1.2rem;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.hr-domain-metrics .metric-item {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    padding: 0.65rem 0.75rem;
    min-width: 0;
    text-align: center;
}

.hr-domain-metrics .metric-item.full-width {
    grid-column: 1 / -1;
}

.hr-domain-metrics .metric-label {
    display: block;
    color: var(--text-secondary);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 0.25rem;
}

.hr-domain-metrics .metric-value {
    display: block;
    color: var(--text-primary);
    font-weight: 600;
    font-size: 0.9rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.employee-card {
    overflow: hidden;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.employee-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 28px rgba(14, 165, 233, 0.12);
}

.employee-header {
    padding: 1.25rem;
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    border-bottom: 1px solid var(--border-color);
}

.employee-avatar {
    width: 50px;
    height: 50px;
    background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.25rem;
    flex-shrink: 0;
}

.employee-info {
    flex: 1;
    min-width: 0;
}

.employee-info h4 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 0.25rem 0;
}

.employee-info p {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin: 0 0 0.5rem 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.employee-info .badge {
    margin-right: 0.5rem;
}

.employee-stats {
    padding: 1rem 1.25rem;
    display: flex;
    gap: 1rem;
    background: var(--bg-secondary);
}

.employee-stats .stat-item {
    flex: 1;
    text-align: center;
}

.employee-stats .stat-label {
    display: block;
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-bottom: 0.25rem;
}

.employee-stats .stat-value {
    display: block;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
}

.employee-actions {
    padding: 1rem 1.25rem;
    border-top: 1px solid var(--border-color);
}

/* Analytics Card Enhancements */
.analytics-card {
    background: var(--bg-primary);
    border-radius: 16px;
    border: 1px solid var(--border-color);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
    padding: 1.5rem;
    min-height: 320px;
    display: flex;
    flex-direction: column;
    position: relative;
    overflow: hidden;
}

.analytics-card::before {
    content: '';
    display: block;
    height: 4px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    background: linear-gradient(90deg, #6366f1, #818cf8);
}

.analytics-card h3 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 1rem 0;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--border-color);
    flex-shrink: 0;
}

.analytics-card canvas {
    flex: 1;
    min-height: 200px;
    max-height: 280px;
    width: 100% !important;
}

.analytics-card.full-width {
    grid-column: 1 / -1;
}

.analytics-card.full-width canvas {
    max-height: 320px;
}

/* Resolution Rate Metric Display */
.metric-display {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 200px;
    text-align: center;
}

.metric-value {
    font-size: 3rem;
    font-weight: 700;
    color: var(--primary-color);
    margin-bottom: 0.5rem;
}

.metric-label {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 1.5rem;
}

.metric-progress {
    width: 100%;
    max-width: 200px;
    height: 8px;
    background: var(--bg-secondary);
    border-radius: 9999px;
    overflow: hidden;
}

.metric-progress .progress-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--primary-color), var(--accent-color));
    border-radius: 9999px;
    transition: width 0.5s ease;
}

/* Filter Tabs (Officer Applications) */
.filter-tabs {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.filter-tab {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-secondary);
    border-radius: var(--radius);
    cursor: pointer;
    transition: all 0.2s ease;
}

.filter-tab:hover {
    background: var(--bg-primary);
    border-color: var(--primary-color);
    color: var(--primary-color);
}

.filter-tab.active {
    background: var(--primary-color);
    border-color: var(--primary-color);
    color: white;
}

.filter-tab i {
    margin-right: 0.5rem;
}

.applications-overview-card {
    background: linear-gradient(135deg, rgba(74, 103, 65, 0.1), rgba(89, 127, 77, 0.12));
    border: 1px solid rgba(74, 103, 65, 0.2);
    border-radius: var(--radius-lg);
    padding: 1rem 1.25rem;
    margin-bottom: 1.2rem;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 0.75rem;
}

.applications-overview-card .overview-item {
    background: rgba(255, 255, 255, 0.65);
    border: 1px solid rgba(74, 103, 65, 0.15);
    border-radius: var(--radius);
    padding: 0.75rem;
}

.applications-overview-card .overview-label {
    display: block;
    color: var(--text-secondary);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.applications-overview-card .overview-value {
    display: block;
    color: var(--text-primary);
    font-size: 1.4rem;
    font-weight: 700;
    margin-top: 0.35rem;
}

/* Complaint Details Modal */
.complaint-details {
    padding: 0.5rem;
}

.complaint-details .complaint-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border-color);
}

.complaint-details .complaint-header h3 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

.complaint-meta {
    margin-bottom: 1.5rem;
}

.complaint-meta .meta-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
}

.complaint-meta .meta-item {
    background: var(--bg-secondary);
    padding: 0.75rem 1rem;
    border-radius: var(--radius);
}

.complaint-meta .meta-item label {
    display: block;
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-bottom: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.complaint-meta .meta-item span {
    font-size: 0.9rem;
    color: var(--text-primary);
    font-weight: 500;
}

.complaint-description,
.complaint-additional,
.complaint-notes,
.complaint-resolution {
    margin-bottom: 1.5rem;
}

.complaint-description h4,
.complaint-additional h4,
.complaint-notes h4,
.complaint-resolution h4 {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 0.5rem 0;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.complaint-description p,
.complaint-additional p,
.complaint-notes p,
.complaint-resolution p {
    font-size: 0.9rem;
    color: var(--text-secondary);
    line-height: 1.6;
    margin: 0;
    background: var(--bg-secondary);
    padding: 1rem;
    border-radius: var(--radius);
}

.complaint-resolution small {
    display: block;
    margin-top: 0.5rem;
    color: var(--text-light);
    font-size: 0.75rem;
}

.complaint-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
}

/* Employee History Modal */
.employee-history .employee-profile {
    background: var(--bg-secondary);
    padding: 1.25rem;
    border-radius: var(--radius-lg);
    margin-bottom: 1.5rem;
}

.employee-history .employee-profile h3 {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 0.5rem 0;
}

.employee-history .employee-profile p {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin: 0.25rem 0;
}

.employee-history .complaint-history h4 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 1rem 0;
}

.employee-history .history-table {
    width: 100%;
    border-collapse: collapse;
}

.employee-history .history-table th,
.employee-history .history-table td {
    padding: 0.75rem;
    text-align: left;
    border-bottom: 1px solid var(--border-color);
}

.employee-history .history-table th {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    background: var(--bg-secondary);
}

.employee-history .history-table td {
    font-size: 0.875rem;
    color: var(--text-primary);
}

/* Empty State */
.empty-state {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--text-secondary);
}

.empty-state i {
    font-size: 3rem;
    margin-bottom: 1rem;
    opacity: 0.5;
}

.empty-state p {
    font-size: 1rem;
    margin: 0;
}

/* Table Container */
.table-container {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow-x: auto;
}

/* Section Header */
.section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
    gap: 1rem;
}

.section-header h2 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

.section-description {
    color: var(--text-secondary);
    font-size: 0.9rem;
    margin-top: 0.25rem;
}

.section-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    align-items: center;
}

.filter-select {
    padding: 0.5rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    background: var(--bg-primary);
    color: var(--text-primary);
    font-size: 0.875rem;
    cursor: pointer;
}

.filter-select:focus {
    outline: none;
    border-color: var(--primary-color);
}

.search-input {
    padding: 0.5rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    background: var(--bg-primary);
    color: var(--text-primary);
    font-size: 0.875rem;
    min-width: 200px;
}

.search-input:focus {
    outline: none;
    border-color: var(--primary-color);
}

/* Button Small Size */
.btn-sm {
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
}

/* Form Styles for HR Modals */
.form-group {
    margin-bottom: 1.25rem;
}

.form-group label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-primary);
    margin-bottom: 0.5rem;
}

.form-group input,
.form-group select,
.form-group textarea {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    background: var(--bg-primary);
    color: var(--text-primary);
    font-size: 0.9rem;
    transition: border-color 0.2s ease;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    outline: none;
    border-color: var(--primary-color);
}

.form-group textarea {
    resize: vertical;
    min-height: 100px;
}

.form-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
}

/* HR Dashboard Responsive */
@media (max-width: 1024px) {
    .analytics-grid {
        grid-template-columns: 1fr;
    }

    .investigations-grid {
        grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    }

    .employees-grid {
        grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    }

    .hr-domain-grid {
        grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    }
}

@media (max-width: 768px) {
    #hr-dashboard .dashboard-tabs {
        display: none;
    }

    #hr-dashboard .hr-tab-content {
        display: block;
        margin-top: 0.75rem;
        border: 1px solid var(--border-color);
        border-radius: var(--radius-lg);
        background: var(--bg-primary);
        overflow: hidden;
        box-shadow: var(--shadow-sm);
    }

    #hr-dashboard .hr-accordion-toggle {
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
        background: var(--bg-secondary);
        border: none;
        border-bottom: 1px solid transparent;
        padding: 0.875rem 1rem;
        font-size: 0.9rem;
        font-weight: 600;
        color: var(--text-primary);
        text-align: left;
        cursor: pointer;
    }

    #hr-dashboard .hr-accordion-toggle i {
        margin-right: 0.5rem;
    }

    #hr-dashboard .hr-tab-content.active .hr-accordion-toggle {
        color: var(--primary-color);
        border-bottom-color: var(--border-color);
    }

    #hr-dashboard .hr-tab-content .hr-accordion-panel {
        display: none;
        padding: 1rem;
    }

    #hr-dashboard .hr-tab-content.active .hr-accordion-panel {
        display: block;
    }

    .dashboard-tabs {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 0.5rem;
    }

    .dashboard-tabs .tab-btn {
        padding: 0.75rem 1rem;
        font-size: 0.85rem;
    }

    .section-header {
        flex-direction: column;
        align-items: stretch;
    }

    .section-actions {
        flex-direction: column;
    }

    .filter-select,
    .search-input {
        width: 100%;
    }

    .hr-table {
        font-size: 0.85rem;
    }

    .hr-table th,
    .hr-table td {
        padding: 0.75rem 0.5rem;
    }

    .investigation-card,
    .employee-card {
        margin: 0;
    }

    .complaint-meta .meta-row {
        grid-template-columns: 1fr;
    }

    .filter-tabs {
        flex-wrap: nowrap;
        overflow-x: auto;
    }

    .metric-value {
        font-size: 2.5rem;
    }

    .applications-overview-card {
        grid-template-columns: 1fr;
    }
}

/* ========================================
   FIELD OFFICER DASHBOARD STYLES
   ======================================== */

/* Field Officer Page Header */
#field-officer-dashboard .page-header {
    background: linear-gradient(135deg, #0369a1 0%, #0ea5e9 100%);
    color: white;
    padding: 2rem 2.5rem;
    border-radius: 16px;
    margin-bottom: 1.5rem;
    box-shadow: 0 4px 20px rgba(14, 165, 233, 0.25);
    position: relative;
    overflow: hidden;
}

#field-officer-dashboard .page-header::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -10%;
    width: 300px;
    height: 300px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 50%;
    pointer-events: none;
}

#field-officer-dashboard .page-header::after {
    content: '';
    position: absolute;
    bottom: -30%;
    left: 10%;
    width: 200px;
    height: 200px;
    background: rgba(255, 255, 255, 0.05);
    border-radius: 50%;
    pointer-events: none;
}

#field-officer-dashboard .page-header h1 {
    margin: 0 0 0.5rem 0;
    font-size: 1.75rem;
    font-weight: 700;
    color: white;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    position: relative;
    z-index: 1;
}

#field-officer-dashboard .page-header h1 i {
    font-size: 1.5rem;
    color: white;
    opacity: 0.9;
}

#field-officer-dashboard .page-header p {
    margin: 0;
    color: white;
    opacity: 0.9;
    font-size: 1rem;
    position: relative;
    z-index: 1;
}

/* Field Officer Stats Grid */
#field-officer-dashboard .stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
    margin-bottom: 1.5rem;
}

#field-officer-dashboard .stat-card {
    background: var(--bg-primary);
    border-radius: 16px;
    padding: 1.5rem;
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
    border: 1px solid var(--border-color);
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}

#field-officer-dashboard .stat-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

#field-officer-dashboard .stat-card .stat-icon {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    color: white;
    flex-shrink: 0;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

#field-officer-dashboard .stat-card .stat-content {
    flex: 1;
    min-width: 0;
}

#field-officer-dashboard .stat-card .stat-content h3 {
    margin: 0 0 0.25rem 0;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

#field-officer-dashboard .stat-card .stat-number {
    font-size: 2rem;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.2;
    margin-bottom: 0.25rem;
}

#field-officer-dashboard .stat-card .stat-detail {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

/* Field Officer Tab Navigation */
#field-officer-dashboard .dashboard-tabs {
    display: flex;
    gap: 0.5rem;
    background: var(--bg-secondary);
    padding: 0.375rem;
    border-radius: 14px;
    margin-bottom: 1.5rem;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

#field-officer-dashboard .dashboard-tabs::-webkit-scrollbar {
    height: 4px;
}

#field-officer-dashboard .dashboard-tabs::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 2px;
}

#field-officer-dashboard .dashboard-tabs .tab-btn {
    padding: 0.875rem 1.5rem;
    border: none;
    background: transparent;
    border-radius: 10px;
    cursor: pointer;
    font-weight: 500;
    font-size: 0.9rem;
    color: var(--text-secondary);
    transition: all 0.2s ease;
    white-space: nowrap;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    position: relative;
}

#field-officer-dashboard .dashboard-tabs .tab-btn:hover {
    color: var(--primary-color);
    background: rgba(14, 165, 233, 0.08);
}

#field-officer-dashboard .dashboard-tabs .tab-btn.active {
    background: var(--bg-primary);
    color: #0ea5e9;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    font-weight: 600;
}

#field-officer-dashboard .dashboard-tabs .tab-btn.active::after {
    display: none;
}

#field-officer-dashboard .dashboard-tabs .tab-btn i {
    font-size: 1rem;
    opacity: 0.8;
}

/* Field Officer Tab Content */
#field-officer-dashboard .fo-tab-content {
    display: none;
    animation: foFadeIn 0.3s ease;
}

#field-officer-dashboard .fo-tab-content.active {
    display: block;
}

@keyframes foFadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Field Officer Dashboard Grid */
#field-officer-dashboard .dashboard-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
}

#field-officer-dashboard .dashboard-grid .full-width {
    grid-column: 1 / -1;
}

/* Field Officer Dashboard Cards */
#field-officer-dashboard .dashboard-card {
    background: var(--bg-primary);
    border-radius: 16px;
    border: 1px solid var(--border-color);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
    overflow: hidden;
    transition: box-shadow 0.3s ease;
}

#field-officer-dashboard .dashboard-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

#field-officer-dashboard .dashboard-card .card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--border-color);
    background: var(--bg-secondary);
}

#field-officer-dashboard .dashboard-card .card-header h3 {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

#field-officer-dashboard .dashboard-card .card-header h3 i {
    color: #0ea5e9;
    font-size: 1.1rem;
}

#field-officer-dashboard .dashboard-card .card-header .badge {
    background: linear-gradient(135deg, #0ea5e9, #06b6d4);
    color: white;
    padding: 0.25rem 0.75rem;
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: 600;
}

#field-officer-dashboard .dashboard-card .card-body {
    padding: 1.5rem;
    max-height: 350px;
    overflow-y: auto;
}

#field-officer-dashboard .dashboard-card .card-body::-webkit-scrollbar {
    width: 6px;
}

#field-officer-dashboard .dashboard-card .card-body::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 3px;
}

/* Empty State Styling */
#field-officer-dashboard .empty-state {
    text-align: center;
    padding: 2rem;
    color: var(--text-secondary);
    font-style: italic;
}

/* Task Items */
#field-officer-dashboard .task-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    background: var(--bg-secondary);
    border-radius: 10px;
    margin-bottom: 0.75rem;
    border-left: 4px solid #0ea5e9;
    transition: all 0.2s ease;
}

#field-officer-dashboard .task-item:last-child {
    margin-bottom: 0;
}

#field-officer-dashboard .task-item:hover {
    transform: translateX(4px);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

#field-officer-dashboard .task-item.priority-high {
    border-left-color: var(--error-color, #c73e1d);
}

#field-officer-dashboard .task-item.priority-medium {
    border-left-color: #f59e0b;
}

#field-officer-dashboard .task-item.priority-low {
    border-left-color: #10b981;
}

#field-officer-dashboard .task-item i {
    width: 36px;
    height: 36px;
    min-width: 36px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(14, 165, 233, 0.1);
    color: #0ea5e9;
    border-radius: 8px;
    font-size: 0.9rem;
}

#field-officer-dashboard .task-item span {
    flex: 1;
    min-width: 0;
    font-size: 0.9rem;
    color: var(--text-primary);
    line-height: 1.4;
    overflow-wrap: anywhere;
}

/* Visit Preview Cards */
#field-officer-dashboard .visit-preview {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    background: var(--bg-secondary);
    border-radius: 10px;
    margin-bottom: 0.75rem;
    cursor: pointer;
    transition: all 0.2s ease;
    min-width: 0;
}

#field-officer-dashboard .visit-preview:hover {
    background: rgba(14, 165, 233, 0.08);
    transform: translateX(4px);
}

#field-officer-dashboard .visit-preview .visit-date {
    text-align: center;
    padding: 0.75rem;
    background: linear-gradient(135deg, #0ea5e9, #06b6d4);
    color: white;
    border-radius: 10px;
    min-width: 60px;
    flex-shrink: 0;
}

#field-officer-dashboard .visit-preview .visit-date .day {
    font-size: 1.25rem;
    font-weight: 700;
    display: block;
}

#field-officer-dashboard .visit-preview .visit-date .month {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

#field-officer-dashboard .visit-preview .visit-info {
    flex: 1;
    min-width: 0;
}

#field-officer-dashboard .visit-preview .visit-info strong {
    display: block;
    font-size: 0.95rem;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#field-officer-dashboard .visit-preview .visit-info span {
    display: block;
    font-size: 0.8rem;
    color: var(--text-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Activity Items */
#field-officer-dashboard .activity-item {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1rem 0;
    border-bottom: 1px solid var(--border-color);
}

#field-officer-dashboard .activity-item:last-child {
    border-bottom: none;
}

#field-officer-dashboard .activity-item i {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-secondary);
    color: #0ea5e9;
    border-radius: 10px;
    font-size: 1rem;
    flex-shrink: 0;
}

#field-officer-dashboard .activity-item .activity-content {
    flex: 1;
    min-width: 0;
}

#field-officer-dashboard .activity-item .activity-content p {
    margin: 0 0 0.25rem 0;
    font-size: 0.9rem;
    color: var(--text-primary);
    line-height: 1.4;
    overflow-wrap: anywhere;
}

#field-officer-dashboard .activity-item .activity-time {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

#field-officer-dashboard .activity-item .badge {
    padding: 0.25rem 0.625rem;
    border-radius: 6px;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
}

/* Overview Section — Vibrant Cards */
#field-officer-dashboard .fo-overview-grid {
    gap: 1.75rem;
}

#field-officer-dashboard .fo-overview-card {
    border: none;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
    overflow: visible;
}

#field-officer-dashboard .fo-overview-card::before {
    content: '';
    display: block;
    height: 4px;
    border-radius: 16px 16px 0 0;
}

#field-officer-dashboard .fo-overview-tasks::before {
    background: linear-gradient(90deg, #f59e0b, #fbbf24);
}

#field-officer-dashboard .fo-overview-visits::before {
    background: linear-gradient(90deg, #0ea5e9, #06b6d4);
}

#field-officer-dashboard .fo-overview-activity::before {
    background: linear-gradient(90deg, #8b5cf6, #a78bfa);
}

#field-officer-dashboard .fo-overview-card .card-header {
    padding: 1.5rem 1.75rem;
    border-bottom: none;
    background: transparent;
    align-items: flex-start;
    gap: 1rem;
}

#field-officer-dashboard .fo-overview-tasks .card-header {
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.08) 0%, rgba(251, 191, 36, 0.04) 100%);
}

#field-officer-dashboard .fo-overview-visits .card-header {
    background: linear-gradient(135deg, rgba(14, 165, 233, 0.1) 0%, rgba(6, 182, 212, 0.05) 100%);
}

#field-officer-dashboard .fo-overview-activity .card-header {
    background: linear-gradient(135deg, rgba(139, 92, 246, 0.08) 0%, rgba(167, 139, 250, 0.04) 100%);
}

#field-officer-dashboard .fo-card-title-group h3 {
    margin-bottom: 0.25rem;
}

#field-officer-dashboard .fo-card-subtitle {
    margin: 0;
    font-size: 0.8rem;
    color: var(--text-secondary);
    font-weight: 400;
}

#field-officer-dashboard .fo-overview-tasks .card-header h3 i { color: #f59e0b; }
#field-officer-dashboard .fo-overview-visits .card-header h3 i { color: #0ea5e9; }
#field-officer-dashboard .fo-overview-activity .card-header h3 i { color: #8b5cf6; }

#field-officer-dashboard .fo-count-badge {
    background: linear-gradient(135deg, #f59e0b, #fbbf24);
    padding: 0.35rem 0.85rem;
    font-size: 0.85rem;
    min-width: 2rem;
    text-align: center;
}

#field-officer-dashboard .fo-schedule-btn {
    background: linear-gradient(135deg, #0ea5e9, #06b6d4);
    border: none;
    box-shadow: 0 4px 12px rgba(14, 165, 233, 0.3);
    white-space: nowrap;
}

#field-officer-dashboard .fo-schedule-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(14, 165, 233, 0.4);
}

#field-officer-dashboard .fo-card-body-spaced {
    padding: 0.5rem 1.75rem 1.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.875rem;
}

#field-officer-dashboard .fo-empty-state {
    text-align: center;
    padding: 2.5rem 1.5rem;
    color: var(--text-secondary);
}

#field-officer-dashboard .fo-empty-state i {
    font-size: 2.25rem;
    margin-bottom: 1rem;
    opacity: 0.35;
    display: block;
}

#field-officer-dashboard .fo-overview-tasks .fo-empty-state i { color: #f59e0b; }
#field-officer-dashboard .fo-overview-visits .fo-empty-state i { color: #0ea5e9; }
#field-officer-dashboard .fo-overview-activity .fo-empty-state i { color: #8b5cf6; }

#field-officer-dashboard .fo-empty-state p {
    margin: 0 0 0.35rem;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    font-style: normal;
}

#field-officer-dashboard .fo-empty-state span {
    font-size: 0.85rem;
    opacity: 0.8;
}

#field-officer-dashboard .fo-overview-card .task-item {
    padding: 1.125rem 1.25rem;
    margin-bottom: 0;
    border-radius: 12px;
    gap: 1.125rem;
}

#field-officer-dashboard .fo-overview-card .visit-preview {
    padding: 1.125rem 1.25rem;
    margin-bottom: 0;
    border-radius: 12px;
    border: 1px solid transparent;
}

#field-officer-dashboard .fo-overview-card .visit-preview:hover {
    border-color: rgba(14, 165, 233, 0.25);
    box-shadow: 0 4px 12px rgba(14, 165, 233, 0.12);
}

#field-officer-dashboard .fo-overview-card .activity-item {
    padding: 1.125rem 1.25rem;
    margin: 0;
    background: var(--bg-secondary);
    border-radius: 12px;
    border-bottom: none;
}

#field-officer-dashboard .fo-overview-card .activity-item + .activity-item {
    margin-top: 0;
}

/* Field Officer Overview Modals */
.fo-modal {
    overflow-y: auto;
    align-items: flex-start;
    padding-top: max(1rem, env(safe-area-inset-top, 0px));
    padding-bottom: max(1rem, env(safe-area-inset-bottom, 0px));
}

.fo-modal .modal-content {
    max-width: 560px;
    width: 100%;
    max-height: min(90vh, calc(100dvh - 2rem));
    border-radius: 20px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: 0 24px 48px rgba(3, 105, 161, 0.2);
    border: 1px solid rgba(14, 165, 233, 0.15);
    margin: auto;
}

.fo-modal .modal-header {
    background: linear-gradient(135deg, #0369a1 0%, #0ea5e9 50%, #06b6d4 100%);
    border-bottom: none;
    padding: 1.5rem 1.75rem;
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
}

.fo-modal .modal-header::before {
    content: '';
    position: absolute;
    top: -40%;
    right: -5%;
    width: 160px;
    height: 160px;
    background: rgba(255, 255, 255, 0.12);
    border-radius: 50%;
    pointer-events: none;
}

.fo-modal .modal-header h2 {
    color: white;
    font-size: 1.25rem;
    font-weight: 700;
    position: relative;
    z-index: 1;
}

.fo-modal .modal-close {
    color: white;
    background: rgba(255, 255, 255, 0.15);
    position: relative;
    z-index: 1;
}

.fo-modal .modal-close:hover {
    background: rgba(255, 255, 255, 0.25);
}

.fo-modal .modal-body {
    padding: 1.75rem;
    overflow-y: auto;
    overflow-x: hidden;
    flex: 1 1 auto;
    min-height: 0;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
}

.fo-modal .modal-body::-webkit-scrollbar {
    width: 6px;
}

.fo-modal .modal-body::-webkit-scrollbar-track {
    background: transparent;
}

.fo-modal .modal-body::-webkit-scrollbar-thumb {
    background: rgba(14, 165, 233, 0.35);
    border-radius: 3px;
}

.fo-modal .modal-body::-webkit-scrollbar-thumb:hover {
    background: rgba(14, 165, 233, 0.55);
}

.fo-modal-form .fo-form-intro {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1rem 1.25rem;
    background: linear-gradient(135deg, rgba(14, 165, 233, 0.08), rgba(6, 182, 212, 0.04));
    border-radius: 12px;
    margin-bottom: 1.5rem;
    border-left: 4px solid #0ea5e9;
}

.fo-modal-form .fo-form-intro i {
    font-size: 1.25rem;
    color: #0ea5e9;
    margin-top: 0.15rem;
}

.fo-modal-form .fo-form-intro p {
    margin: 0;
    font-size: 0.875rem;
    color: var(--text-secondary);
    line-height: 1.5;
}

.fo-modal-form .fo-form-section {
    margin-bottom: 1.5rem;
}

.fo-modal-form .fo-form-section-title {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #0ea5e9;
    margin: 0 0 1rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid rgba(14, 165, 233, 0.15);
}

.fo-modal-form .form-group {
    margin-bottom: 1.25rem;
}

.fo-modal-form .form-group label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: 600;
    font-size: 0.875rem;
    color: var(--text-primary);
}

.fo-modal-form .form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.25rem;
}

.fo-modal-form .form-actions {
    display: flex;
    gap: 0.875rem;
    justify-content: flex-end;
    margin-top: 1.75rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border-color);
    position: sticky;
    bottom: 0;
    z-index: 2;
    margin-left: -1.75rem;
    margin-right: -1.75rem;
    margin-bottom: -1.75rem;
    padding-left: 1.75rem;
    padding-right: 1.75rem;
    padding-bottom: 1.75rem;
    background: linear-gradient(to top, var(--bg-primary) 75%, rgba(255, 255, 255, 0));
}

.fo-visit-details .fo-visit-hero {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    padding: 1.25rem 1.5rem;
    background: linear-gradient(135deg, rgba(14, 165, 233, 0.1), rgba(6, 182, 212, 0.05));
    border-radius: 14px;
    margin-bottom: 1.5rem;
}

.fo-visit-details .fo-visit-hero-icon {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    background: linear-gradient(135deg, #0ea5e9, #06b6d4);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.35rem;
    flex-shrink: 0;
    box-shadow: 0 4px 12px rgba(14, 165, 233, 0.35);
}

.fo-visit-details .fo-visit-hero-info h3 {
    margin: 0 0 0.5rem;
    font-size: 1.15rem;
    color: var(--text-primary);
}

.fo-visit-details .fo-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.fo-visit-details .fo-detail-tile {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    padding: 1rem 1.125rem;
    background: var(--bg-secondary);
    border-radius: 12px;
    border: 1px solid var(--border-color);
}

.fo-visit-details .fo-detail-tile i {
    color: #0ea5e9;
    font-size: 0.9rem;
    margin-bottom: 0.25rem;
}

.fo-visit-details .fo-detail-tile .fo-detail-label {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
}

.fo-visit-details .fo-detail-tile .fo-detail-value {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text-primary);
    line-height: 1.4;
}

.fo-visit-details .fo-detail-section {
    padding: 1.125rem 1.25rem;
    background: var(--bg-secondary);
    border-radius: 12px;
    margin-bottom: 1rem;
    border-left: 4px solid #8b5cf6;
}

.fo-visit-details .fo-detail-section h4 {
    margin: 0 0 0.625rem;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #8b5cf6;
}

.fo-visit-details .fo-detail-section p {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.6;
    color: var(--text-primary);
}

.fo-visit-details .fo-detail-section.fo-section-notes {
    border-left-color: #0ea5e9;
}

.fo-visit-details .fo-detail-section.fo-section-notes h4 {
    color: #0ea5e9;
}

.fo-visit-details .fo-detail-section.fo-section-summary {
    border-left-color: #10b981;
}

.fo-visit-details .fo-detail-section.fo-section-summary h4 {
    color: #10b981;
}

.fo-visit-details .fo-detail-section.fo-section-outcome {
    border-left-color: #f59e0b;
}

.fo-visit-details .fo-detail-section.fo-section-outcome h4 {
    color: #f59e0b;
}

.fo-visit-details .visit-actions {
    margin-top: 1.5rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--border-color);
    display: flex;
    justify-content: flex-end;
    position: sticky;
    bottom: 0;
    z-index: 2;
    margin-left: -1.75rem;
    margin-right: -1.75rem;
    margin-bottom: -1.75rem;
    padding-left: 1.75rem;
    padding-right: 1.75rem;
    padding-bottom: 1.75rem;
    background: linear-gradient(to top, var(--bg-primary) 75%, rgba(255, 255, 255, 0));
}

.fo-visit-details .badge {
    display: inline-block;
    padding: 0.3rem 0.75rem;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: capitalize;
}

.fo-visit-details .badge-scheduled {
    background: rgba(14, 165, 233, 0.15);
    color: #0369a1;
}

.fo-visit-details .badge-completed {
    background: rgba(16, 185, 129, 0.15);
    color: #047857;
}

/* Wide field-officer modals (farmer details, etc.) */
.fo-modal.fo-modal-wide .modal-content {
    max-width: min(720px, 96vw);
}

.fo-modal-form .fo-required,
.fo-farmer-details .fo-required {
    color: #ef4444;
}

.fo-modal-form .fo-gps-row {
    display: flex;
    gap: 0.875rem;
    align-items: flex-start;
    flex-wrap: wrap;
}

.fo-modal-form .fo-gps-row > div {
    flex: 1;
    min-width: 120px;
}

.fo-modal-form .fo-gps-hint {
    display: block;
    margin-top: 0.375rem;
    color: var(--text-secondary);
    font-size: 0.8rem;
}

/* Shared detail-view layout (recommendations, visits) */
.fo-detail-view .fo-detail-hero,
.fo-recommendation-details .fo-detail-hero {
    display: flex;
    align-items: flex-start;
    gap: 1.25rem;
    padding: 1.25rem 1.5rem;
    background: linear-gradient(135deg, rgba(14, 165, 233, 0.1), rgba(6, 182, 212, 0.05));
    border-radius: 14px;
    margin-bottom: 1.5rem;
}

.fo-detail-view .fo-detail-hero-icon,
.fo-recommendation-details .fo-detail-hero-icon {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    background: linear-gradient(135deg, #0ea5e9, #06b6d4);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.35rem;
    flex-shrink: 0;
    box-shadow: 0 4px 12px rgba(14, 165, 233, 0.35);
}

.fo-detail-view .fo-detail-hero-info h3,
.fo-recommendation-details .fo-detail-hero-info h3 {
    margin: 0 0 0.5rem;
    font-size: 1.15rem;
    color: var(--text-primary);
    line-height: 1.35;
}

.fo-recommendation-details .fo-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.fo-recommendation-details .fo-detail-tile {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    padding: 1rem 1.125rem;
    background: var(--bg-secondary);
    border-radius: 12px;
    border: 1px solid var(--border-color);
}

.fo-recommendation-details .fo-detail-tile i {
    color: #0ea5e9;
    font-size: 0.9rem;
    margin-bottom: 0.25rem;
}

.fo-recommendation-details .fo-detail-label {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
}

.fo-recommendation-details .fo-detail-value {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text-primary);
    line-height: 1.4;
    text-transform: capitalize;
}

.fo-recommendation-details .fo-detail-section {
    padding: 1.125rem 1.25rem;
    background: var(--bg-secondary);
    border-radius: 12px;
    margin-bottom: 1rem;
    border-left: 4px solid #8b5cf6;
}

.fo-recommendation-details .fo-detail-section h4 {
    margin: 0 0 0.625rem;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #8b5cf6;
}

.fo-recommendation-details .fo-detail-section p {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.6;
    color: var(--text-primary);
}

.fo-recommendation-details .fo-section-content { border-left-color: #0ea5e9; }
.fo-recommendation-details .fo-section-content h4 { color: #0ea5e9; }
.fo-recommendation-details .fo-section-outcome { border-left-color: #10b981; }
.fo-recommendation-details .fo-section-outcome h4 { color: #10b981; }
.fo-recommendation-details .fo-section-notes { border-left-color: #f59e0b; }
.fo-recommendation-details .fo-section-notes h4 { color: #f59e0b; }
.fo-recommendation-details .fo-section-chief { border-left-color: #6366f1; }
.fo-recommendation-details .fo-section-chief h4 { color: #6366f1; }

/* Farmer details modal */
.fo-farmer-details .fo-farmer-detail-tabs {
    display: flex;
    gap: 0.25rem;
    padding: 0.25rem;
    background: var(--bg-secondary);
    border-radius: 12px;
    margin-bottom: 1.5rem;
}

.fo-farmer-details .fo-detail-tab-btn {
    flex: 1;
    padding: 0.75rem 0.5rem;
    background: transparent;
    border: none;
    border-radius: 10px;
    cursor: pointer;
    font-weight: 500;
    font-size: 0.8rem;
    color: var(--text-secondary);
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
}

.fo-farmer-details .fo-detail-tab-btn:hover {
    color: #0ea5e9;
    background: rgba(14, 165, 233, 0.08);
}

.fo-farmer-details .fo-detail-tab-btn.active {
    background: var(--bg-primary);
    color: #0ea5e9;
    font-weight: 600;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.fo-farmer-details .fo-farmer-tab-panel {
    display: none;
}

.fo-farmer-details .fo-farmer-tab-panel.active {
    display: block;
}

.fo-farmer-details .fo-farmer-profile {
    display: flex;
    gap: 1.25rem;
    align-items: center;
    margin-bottom: 1.5rem;
    padding: 1.25rem;
    background: linear-gradient(135deg, rgba(14, 165, 233, 0.08), rgba(6, 182, 212, 0.04));
    border-radius: 14px;
}

.fo-farmer-details .fo-profile-avatar {
    width: 80px;
    height: 80px;
    background: linear-gradient(135deg, #0369a1, #0ea5e9);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    flex-shrink: 0;
    box-shadow: 0 4px 12px rgba(14, 165, 233, 0.3);
}

.fo-farmer-details .fo-profile-info h2 {
    margin: 0 0 0.5rem;
    font-size: 1.25rem;
    color: var(--text-primary);
}

.fo-farmer-details .fo-profile-info p {
    margin: 0.25rem 0;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.fo-farmer-details .fo-profile-info p i {
    width: 1.25rem;
    color: #0ea5e9;
}

.fo-farmer-details .fo-status-badge {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
    margin-top: 0.5rem;
    text-transform: capitalize;
}

.fo-farmer-details .fo-status-badge.active {
    background: rgba(16, 185, 129, 0.15);
    color: #047857;
}

.fo-farmer-details .fo-status-badge.inactive {
    background: rgba(239, 68, 68, 0.12);
    color: #b91c1c;
}

.fo-farmer-details .fo-profile-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.fo-farmer-details .fo-stat-box {
    background: var(--bg-secondary);
    padding: 1rem;
    border-radius: 12px;
    text-align: center;
    border: 1px solid var(--border-color);
}

.fo-farmer-details .fo-stat-box i {
    font-size: 1.35rem;
    color: #0ea5e9;
    margin-bottom: 0.5rem;
}

.fo-farmer-details .fo-stat-value {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--text-primary);
}

.fo-farmer-details .fo-stat-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.fo-farmer-details .fo-profile-section {
    margin-bottom: 1.5rem;
}

.fo-farmer-details .fo-profile-section h3 {
    margin: 0 0 0.75rem;
    font-size: 0.95rem;
    color: var(--text-primary);
}

.fo-farmer-details .fo-rec-list {
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
}

.fo-farmer-details .fo-rec-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.875rem 1rem;
    background: var(--bg-secondary);
    border-radius: 10px;
    gap: 0.75rem;
}

.fo-farmer-details .fo-profile-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.fo-farmer-details .fo-profile-actions .btn {
    flex: 1;
    min-width: 140px;
}

.fo-farmer-details .fo-assets-section {
    margin-bottom: 1.5rem;
}

.fo-farmer-details .fo-assets-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.75rem;
}

.fo-farmer-details .fo-assets-header h3 {
    margin: 0;
    font-size: 0.95rem;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.fo-farmer-details .fo-assets-header h3 i.fa-home { color: #0ea5e9; }
.fo-farmer-details .fo-assets-header h3 i.fa-seedling { color: #10b981; }
.fo-farmer-details .fo-assets-header h3 i.fa-paw { color: #f59e0b; }
.fo-farmer-details .fo-assets-header h3 i.fa-tools { color: #6366f1; }

.fo-farmer-details .fo-assets-list {
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
    max-height: 160px;
    overflow-y: auto;
    padding-right: 0.25rem;
}

.fo-farmer-details .fo-asset-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 1rem;
    background: var(--bg-secondary);
    border-radius: 10px;
    gap: 0.75rem;
}

.fo-farmer-details .fo-asset-item.fo-asset-farm { border-left: 3px solid #0ea5e9; }
.fo-farmer-details .fo-asset-item.fo-asset-crop { border-left: 3px solid #10b981; }
.fo-farmer-details .fo-asset-item.fo-asset-livestock { border-left: 3px solid #f59e0b; }
.fo-farmer-details .fo-asset-item.fo-asset-equipment { border-left: 3px solid #6366f1; }

.fo-farmer-details .fo-asset-item strong {
    display: block;
    font-size: 0.85rem;
    color: var(--text-primary);
}

.fo-farmer-details .fo-asset-item span.fo-asset-meta {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.fo-farmer-details .fo-asset-actions {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    flex-shrink: 0;
}

.fo-farmer-details .fo-asset-tag {
    font-size: 0.7rem;
    padding: 0.15rem 0.5rem;
    border-radius: 10px;
    font-weight: 600;
}

.fo-farmer-details .fo-btn-xs {
    padding: 0.25rem 0.5rem;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.7rem;
    color: white;
}

.fo-farmer-details .fo-btn-xs.fo-btn-edit { background: #3b82f6; }
.fo-farmer-details .fo-btn-xs.fo-btn-delete { background: #ef4444; }
.fo-farmer-details .fo-btn-xs.fo-btn-add {
    padding: 0.375rem 0.75rem;
    font-size: 0.75rem;
    border-radius: 8px;
    color: white;
    border: none;
    cursor: pointer;
}

.fo-farmer-details .fo-btn-add-farm { background: #0ea5e9; }
.fo-farmer-details .fo-btn-add-crop { background: #10b981; }
.fo-farmer-details .fo-btn-add-livestock { background: #f59e0b; }
.fo-farmer-details .fo-btn-add-equipment { background: #6366f1; }

.fo-farmer-details .fo-empty-asset {
    color: var(--text-secondary);
    font-style: italic;
    font-size: 0.85rem;
    padding: 0.5rem;
}

.fo-farmer-details .fo-modal-form .form-actions {
    margin-left: 0;
    margin-right: 0;
    margin-bottom: 0;
    padding-left: 0;
    padding-right: 0;
}

/* Visit details tabs & asset picker */
.fo-visit-details-tabbed .fo-visit-detail-tabs {
    display: flex;
    gap: 0.25rem;
    padding: 0.25rem;
    background: var(--bg-secondary);
    border-radius: 12px;
    margin-bottom: 1.5rem;
}

.fo-visit-details-tabbed .fo-detail-tab-btn {
    flex: 1;
    padding: 0.75rem 0.5rem;
    background: transparent;
    border: none;
    border-radius: 10px;
    cursor: pointer;
    font-weight: 500;
    font-size: 0.8rem;
    color: var(--text-secondary);
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
}

.fo-visit-details-tabbed .fo-detail-tab-btn:hover {
    color: #0ea5e9;
    background: rgba(14, 165, 233, 0.08);
}

.fo-visit-details-tabbed .fo-detail-tab-btn.active {
    background: var(--bg-primary);
    color: #0ea5e9;
    font-weight: 600;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.fo-visit-details-tabbed .fo-visit-tab-panel {
    display: none;
}

.fo-visit-details-tabbed .fo-visit-tab-panel.active {
    display: block;
}

.fo-visit-details-tabbed .visit-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.625rem;
    justify-content: flex-end;
}

.fo-visit-details-tabbed .visit-actions .btn {
    min-width: 130px;
}

.fo-visit-details .fo-section-field-notes {
    border-left-color: #8b5cf6;
}

.fo-visit-details .fo-section-field-notes h4 {
    color: #8b5cf6;
}

.fo-visit-details .fo-section-linked {
    border-left-color: #6366f1;
}

.fo-visit-details .fo-section-linked h4 {
    color: #6366f1;
}

.fo-visit-linked-group {
    margin-bottom: 0.875rem;
}

.fo-visit-linked-group:last-child {
    margin-bottom: 0;
}

.fo-visit-linked-group h5 {
    margin: 0 0 0.5rem;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

.fo-visit-linked-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.fo-visit-linked-tag {
    display: inline-block;
    padding: 0.3rem 0.65rem;
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-primary);
}

.fo-visit-asset-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    max-height: 180px;
    overflow-y: auto;
    padding-right: 0.25rem;
}

.fo-visit-asset-option {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.75rem 0.875rem;
    background: var(--bg-secondary);
    border-radius: 10px;
    border: 1px solid var(--border-color);
    cursor: pointer;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.fo-visit-asset-option:hover {
    border-color: rgba(14, 165, 233, 0.35);
}

.fo-visit-asset-option input {
    margin-top: 0.2rem;
    flex-shrink: 0;
    accent-color: #0ea5e9;
}

.fo-visit-asset-option:has(input:checked) {
    border-color: #0ea5e9;
    box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.12);
    background: rgba(14, 165, 233, 0.05);
}

.fo-visit-asset-option.fo-asset-crop:has(input:checked) { border-left: 3px solid #10b981; }
.fo-visit-asset-option.fo-asset-livestock:has(input:checked) { border-left: 3px solid #f59e0b; }
.fo-visit-asset-option.fo-asset-equipment:has(input:checked) { border-left: 3px solid #6366f1; }

.fo-visit-asset-option-body {
    display: flex;
    align-items: flex-start;
    gap: 0.625rem;
    flex: 1;
}

.fo-visit-asset-option-body i {
    margin-top: 0.1rem;
    color: #0ea5e9;
}

.fo-visit-asset-option.fo-asset-crop .fo-visit-asset-option-body i { color: #10b981; }
.fo-visit-asset-option.fo-asset-livestock .fo-visit-asset-option-body i { color: #f59e0b; }
.fo-visit-asset-option.fo-asset-equipment .fo-visit-asset-option-body i { color: #6366f1; }

.fo-visit-asset-option-body strong {
    display: block;
    font-size: 0.875rem;
    color: var(--text-primary);
}

.fo-visit-asset-option-body small {
    display: block;
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-top: 0.15rem;
}

.fo-visit-details-tabbed .fo-modal-form .form-actions {
    margin-left: 0;
    margin-right: 0;
    margin-bottom: 0;
    padding-left: 0;
    padding-right: 0;
}

@media (max-width: 640px) {
    #field-officer-dashboard .fo-overview-card .card-header {
        flex-direction: column;
        align-items: stretch;
    }

    .fo-modal-form .form-row,
    .fo-visit-details .fo-detail-grid,
    .fo-recommendation-details .fo-detail-grid,
    .fo-farmer-details .fo-profile-stats {
        grid-template-columns: 1fr;
    }

    .fo-farmer-details .fo-farmer-profile {
        flex-direction: column;
        text-align: center;
    }

    .fo-visit-details-tabbed .fo-visit-detail-tabs {
        flex-direction: column;
    }

    .fo-visit-details-tabbed .visit-actions {
        flex-direction: column;
    }

    .fo-visit-details-tabbed .visit-actions .btn {
        width: 100%;
    }
}

/* Section Header */
#field-officer-dashboard .section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
    gap: 1rem;
}

#field-officer-dashboard .section-header h2 {
    margin: 0;
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-primary);
}

#field-officer-dashboard .section-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

#field-officer-dashboard .section-actions .search-input,
#field-officer-dashboard .section-actions .filter-select,
#field-officer-dashboard .section-actions .filter-input {
    padding: 0.625rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    font-size: 0.9rem;
    background: var(--bg-primary);
    color: var(--text-primary);
    transition: all 0.2s ease;
}

#field-officer-dashboard .section-actions .search-input:focus,
#field-officer-dashboard .section-actions .filter-select:focus,
#field-officer-dashboard .section-actions .filter-input:focus {
    outline: none;
    border-color: #0ea5e9;
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.15);
}

#field-officer-dashboard .section-actions .search-input {
    min-width: 200px;
}

/* My Farmers tab */
#field-officer-dashboard .fo-farmers-header {
    align-items: flex-start;
}

#field-officer-dashboard .fo-section-title-group h2 {
    margin-bottom: 0.25rem;
}

#field-officer-dashboard .fo-section-subtitle {
    margin: 0;
    font-size: 0.85rem;
    color: var(--text-secondary);
}

#field-officer-dashboard .fo-farmer-actions-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-bottom: 1.25rem;
    padding: 1rem 1.25rem;
    background: linear-gradient(135deg, rgba(14, 165, 233, 0.08), rgba(6, 182, 212, 0.04));
    border: 1px solid rgba(14, 165, 233, 0.15);
    border-radius: 14px;
}

#field-officer-dashboard .fo-farmer-actions-bar .btn-primary {
    background: linear-gradient(135deg, #0ea5e9, #06b6d4);
    border: none;
}

#field-officer-dashboard .fo-farmers-empty {
    grid-column: 1 / -1;
    padding: 3rem 1.5rem;
}

#field-officer-dashboard .fo-farmers-empty i {
    color: #0ea5e9;
}

/* Farmers Grid */
#field-officer-dashboard .farmers-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(340px, 100%), 1fr));
    gap: 1.5rem;
}

#field-officer-dashboard .farmer-card.fo-farmer-card {
    background: var(--bg-primary);
    border-radius: 18px;
    border: 1px solid var(--border-color);
    overflow: hidden;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
    display: flex;
    flex-direction: column;
    min-width: 0;
}

#field-officer-dashboard .fo-farmer-card::before {
    content: '';
    display: block;
    height: 4px;
    background: linear-gradient(90deg, #0ea5e9, #06b6d4);
}

#field-officer-dashboard .fo-farmer-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 28px rgba(14, 165, 233, 0.15);
    border-color: rgba(14, 165, 233, 0.35);
}

#field-officer-dashboard .fo-farmer-card .farmer-card-clickable {
    cursor: pointer;
    padding: 1.25rem 1.25rem 1rem;
    flex: 1;
    min-width: 0;
    transition: background 0.2s ease;
}

#field-officer-dashboard .fo-farmer-card .farmer-card-clickable:hover {
    background: rgba(14, 165, 233, 0.03);
}

#field-officer-dashboard .fo-farmer-card .farmer-card-top {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
}

#field-officer-dashboard .fo-farmer-card .farmer-avatar {
    width: 54px;
    height: 54px;
    min-width: 54px;
    background: linear-gradient(135deg, #0369a1, #0ea5e9);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.2rem;
    box-shadow: 0 4px 12px rgba(14, 165, 233, 0.28);
}

#field-officer-dashboard .fo-farmer-card .farmer-identity {
    flex: 1;
    min-width: 0;
}

#field-officer-dashboard .fo-farmer-card .farmer-identity h4 {
    margin: 0 0 0.4rem;
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

#field-officer-dashboard .fo-farmer-card .farmer-status-badge {
    display: inline-block;
    padding: 0.2rem 0.65rem;
    border-radius: 20px;
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

#field-officer-dashboard .fo-farmer-card .farmer-status-badge.active {
    background: rgba(16, 185, 129, 0.15);
    color: #047857;
}

#field-officer-dashboard .fo-farmer-card .farmer-status-badge.inactive {
    background: rgba(239, 68, 68, 0.12);
    color: #b91c1c;
}

#field-officer-dashboard .fo-farmer-card .farmer-contact-list {
    list-style: none;
    margin: 0 0 1rem;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

#field-officer-dashboard .fo-farmer-card .farmer-contact-list li {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    min-width: 0;
}

#field-officer-dashboard .fo-farmer-card .farmer-contact-icon {
    width: 28px;
    height: 28px;
    min-width: 28px;
    border-radius: 8px;
    background: var(--bg-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #0ea5e9;
    font-size: 0.75rem;
}

#field-officer-dashboard .fo-farmer-card .farmer-contact-text {
    flex: 1;
    min-width: 0;
    font-size: 0.82rem;
    color: var(--text-secondary);
    line-height: 1.35;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#field-officer-dashboard .fo-farmer-card .farmer-metrics {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.625rem;
}

#field-officer-dashboard .fo-farmer-card .farmer-metric {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.2rem;
    padding: 0.75rem 0.35rem;
    background: var(--bg-secondary);
    border-radius: 12px;
    border: 1px solid var(--border-color);
    min-width: 0;
}

#field-officer-dashboard .fo-farmer-card .farmer-metric-icon {
    width: 26px;
    height: 26px;
    border-radius: 8px;
    background: rgba(14, 165, 233, 0.12);
    color: #0ea5e9;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.7rem;
    margin-bottom: 0.15rem;
}

#field-officer-dashboard .fo-farmer-card .farmer-metric-value {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.2;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#field-officer-dashboard .fo-farmer-card .farmer-metric-value.farmer-metric-date {
    font-size: 0.72rem;
    font-weight: 600;
    line-height: 1.15;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
}

#field-officer-dashboard .fo-farmer-card .farmer-metric-label {
    font-size: 0.62rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    line-height: 1.15;
    max-width: 100%;
    white-space: normal;
    overflow-wrap: anywhere;
}

#field-officer-dashboard .fo-farmer-card .farmer-actions {
    display: flex;
    gap: 0.375rem;
    padding: 0.875rem 1rem 1rem;
    background: var(--bg-secondary);
    border-top: 1px solid var(--border-color);
}

#field-officer-dashboard .fo-farmer-card .fo-farmer-action-btn {
    flex: 1;
    min-width: 0;
    padding: 0.5rem 0.35rem;
    border-radius: 10px;
    font-size: 0.68rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 0.3rem;
    line-height: 1.1;
    min-height: 40px;
}

#field-officer-dashboard .fo-farmer-card .fo-farmer-action-btn span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
}

#field-officer-dashboard .fo-farmer-card .fo-farmer-action-btn i {
    font-size: 0.8rem;
    flex-shrink: 0;
}

#field-officer-dashboard .fo-farmer-card .fo-farmer-action-btn.btn-primary {
    background: linear-gradient(135deg, #0ea5e9, #06b6d4);
    color: white;
    border: none;
}

#field-officer-dashboard .fo-farmer-card .fo-farmer-action-btn.btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(14, 165, 233, 0.35);
}

#field-officer-dashboard .fo-farmer-card .fo-farmer-action-btn.btn-secondary {
    background: var(--bg-primary);
    color: var(--text-primary);
    border: 1px solid var(--border-color);
}

#field-officer-dashboard .fo-farmer-card .fo-farmer-action-btn.btn-secondary:hover {
    border-color: #0ea5e9;
    color: #0ea5e9;
    background: rgba(14, 165, 233, 0.06);
}

#field-officer-dashboard .fo-farmer-card .fo-farmer-view-btn {
    border-color: rgba(14, 165, 233, 0.25);
}

/* Farmer card responsive adjustments */
@media (max-width: 576px) {
    #field-officer-dashboard .farmers-grid {
        grid-template-columns: 1fr;
    }

    #field-officer-dashboard .fo-farmer-card .farmer-card-clickable {
        padding: 1rem;
    }

    #field-officer-dashboard .fo-farmer-card .farmer-metrics {
        grid-template-columns: 1fr;
    }

    #field-officer-dashboard .fo-farmer-card .farmer-metric {
        flex-direction: row;
        justify-content: flex-start;
        text-align: left;
        padding: 0.75rem 0.875rem;
        gap: 0.75rem;
    }

    #field-officer-dashboard .fo-farmer-card .farmer-metric-icon {
        margin-bottom: 0;
    }

    #field-officer-dashboard .fo-farmer-card .farmer-metric-value,
    #field-officer-dashboard .fo-farmer-card .farmer-metric-label {
        white-space: normal;
    }

    #field-officer-dashboard .fo-farmer-card .farmer-actions {
        flex-direction: column;
    }

    #field-officer-dashboard .fo-farmer-card .fo-farmer-action-btn {
        justify-content: center;
        min-height: auto;
        padding: 0.65rem 0.75rem;
    }
}


@media (min-width: 577px) and (max-width: 992px) {
    #field-officer-dashboard .farmers-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 993px) {
    #field-officer-dashboard .farmers-grid {
        grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    }
}

/* Field Officer Table */
#field-officer-dashboard .recommendations-table-container {
    overflow-x: auto;
    border-radius: 16px;
    border: 1px solid var(--border-color);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

#field-officer-dashboard .fo-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--bg-primary);
}

#field-officer-dashboard .fo-table thead {
    background: var(--bg-secondary);
}

#field-officer-dashboard .fo-table th {
    padding: 1rem 1.25rem;
    text-align: left;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: 2px solid var(--border-color);
    white-space: nowrap;
}

#field-officer-dashboard .fo-table td {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--border-color);
    color: var(--text-primary);
    vertical-align: middle;
}

#field-officer-dashboard .fo-table tbody tr {
    transition: background 0.2s ease;
}

#field-officer-dashboard .fo-table tbody tr:hover {
    background: rgba(14, 165, 233, 0.04);
}

#field-officer-dashboard .fo-table tbody tr:last-child td {
    border-bottom: none;
}

#field-officer-dashboard .fo-table td strong {
    display: block;
    font-weight: 600;
    color: var(--text-primary);
}

#field-officer-dashboard .fo-table td small {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

#field-officer-dashboard .fo-table .btn-icon {
    width: 32px;
    height: 32px;
    padding: 0;
    border: none;
    background: var(--bg-secondary);
    border-radius: 8px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    transition: all 0.2s ease;
    margin-right: 0.375rem;
}

#field-officer-dashboard .fo-table .btn-icon:hover {
    background: #0ea5e9;
    color: white;
    transform: translateY(-2px);
}

#field-officer-dashboard .fo-table .btn-icon:last-child {
    margin-right: 0;
}

/* Badges in Table */
#field-officer-dashboard .fo-table .badge {
    padding: 0.375rem 0.75rem;
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: capitalize;
}

#field-officer-dashboard .fo-table .badge-draft {
    background: #f3f4f6;
    color: #6b7280;
}

#field-officer-dashboard .fo-table .badge-pending {
    background: #fef3c7;
    color: #92400e;
}

#field-officer-dashboard .fo-table .badge-approved {
    background: #d1fae5;
    color: #065f46;
}

#field-officer-dashboard .fo-table .badge-rejected {
    background: #fee2e2;
    color: #991b1b;
}

#field-officer-dashboard .fo-table .badge-info {
    background: #dbeafe;
    color: #1e40af;
}

#field-officer-dashboard .fo-table .badge-high {
    background: #fee2e2;
    color: #991b1b;
}

#field-officer-dashboard .fo-table .badge-medium {
    background: #fef3c7;
    color: #92400e;
}

#field-officer-dashboard .fo-table .badge-low {
    background: #d1fae5;
    color: #065f46;
}

/* Calendar Container */
#field-officer-dashboard .calendar-container {
    background: var(--bg-primary);
    border-radius: 16px;
    border: 1px solid var(--border-color);
    padding: 1.5rem;
    margin-bottom: 1.5rem;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

/* Visits List */
#field-officer-dashboard .visits-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(300px, 100%), 1fr));
    gap: 1rem;
}

#field-officer-dashboard .visits-list h3 {
    grid-column: 1 / -1;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 1rem 0 0.5rem 0;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--border-color);
}

#field-officer-dashboard .visit-item {
    background: var(--bg-primary);
    border-radius: 12px;
    border: 1px solid var(--border-color);
    padding: 1.25rem;
    transition: all 0.3s ease;
}

#field-officer-dashboard .visit-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    border-color: #0ea5e9;
}

#field-officer-dashboard .visit-item h4 {
    margin: 0 0 0.5rem 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
}

#field-officer-dashboard .visit-item p {
    margin: 0 0 0.75rem 0;
    font-size: 0.85rem;
    color: var(--text-secondary);
}

#field-officer-dashboard .visit-item .visit-date {
    font-size: 0.8rem;
    color: #0ea5e9;
    font-weight: 500;
}

#field-officer-dashboard .visit-item .visit-actions {
    display: flex;
    gap: 0.5rem;
    margin-top: 1rem;
}

/* Performance Grid */
#field-officer-dashboard .performance-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
    margin-bottom: 1.5rem;
}

#field-officer-dashboard .performance-card {
    background: var(--bg-primary);
    border-radius: 16px;
    border: 1px solid var(--border-color);
    padding: 1.5rem;
    text-align: center;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
    transition: all 0.3s ease;
}

#field-officer-dashboard .performance-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
}

#field-officer-dashboard .performance-card h3 {
    margin: 0 0 0.75rem 0;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

#field-officer-dashboard .performance-card .metric-value {
    font-size: 2.5rem;
    font-weight: 700;
    color: #0ea5e9;
    line-height: 1.1;
    margin-bottom: 0.5rem;
}

#field-officer-dashboard .performance-card .metric-label {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin-bottom: 1rem;
}

#field-officer-dashboard .performance-card .metric-progress {
    height: 8px;
    background: var(--bg-secondary);
    border-radius: 4px;
    overflow: hidden;
}

#field-officer-dashboard .performance-card .metric-progress .progress-bar {
    height: 100%;
    background: linear-gradient(90deg, #0ea5e9, #06b6d4);
    border-radius: 4px;
    transition: width 0.5s ease;
}

/* Charts Container */
#field-officer-dashboard .charts-container {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
}

#field-officer-dashboard .chart-card {
    background: var(--bg-primary);
    border-radius: 16px;
    border: 1px solid var(--border-color);
    padding: 1.5rem;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

#field-officer-dashboard .chart-card h3 {
    margin: 0 0 1.25rem 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
}

#field-officer-dashboard .chart-card canvas {
    max-height: 250px;
}

/* Field Officer Responsive Styles */
@media (max-width: 1200px) {
    #field-officer-dashboard .stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    #field-officer-dashboard .performance-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 992px) {
    #field-officer-dashboard .dashboard-grid {
        grid-template-columns: 1fr;
    }

    #field-officer-dashboard .charts-container {
        grid-template-columns: 1fr;
    }

    #field-officer-dashboard .farmers-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    #field-officer-dashboard .page-header {
        padding: 1.5rem;
        border-radius: 12px;
    }

    #field-officer-dashboard .page-header h1 {
        font-size: 1.5rem;
    }

    #field-officer-dashboard .stats-grid {
        grid-template-columns: 1fr;
        gap: 1rem;
    }

    #field-officer-dashboard .stat-card {
        padding: 1.25rem;
    }

    #field-officer-dashboard .stat-card .stat-number {
        font-size: 1.75rem;
    }

    #field-officer-dashboard .dashboard-tabs {
        padding: 0.25rem;
        border-radius: 10px;
    }

    #field-officer-dashboard .dashboard-tabs .tab-btn {
        padding: 0.75rem 1rem;
        font-size: 0.85rem;
    }

    #field-officer-dashboard .section-header {
        flex-direction: column;
        align-items: stretch;
    }

    #field-officer-dashboard .section-actions {
        flex-direction: column;
    }

    #field-officer-dashboard .section-actions .search-input {
        min-width: 100%;
    }

    #field-officer-dashboard .performance-grid {
        grid-template-columns: 1fr;
    }

    #field-officer-dashboard .performance-card .metric-value {
        font-size: 2rem;
    }

    #field-officer-dashboard .visits-list {
        grid-template-columns: 1fr;
    }

    #field-officer-dashboard .fo-table {
        font-size: 0.85rem;
    }

    #field-officer-dashboard .fo-table th,
    #field-officer-dashboard .fo-table td {
        padding: 0.75rem;
    }
}

/* ============================================
   Chief Field Officer Dashboard Styles
   ============================================ */

/* Stat Icon Color Variants - Using Brand Palette */
.stat-icon.stat-icon-warning {
    background: linear-gradient(135deg, var(--warning-color), #e8b676);
}

.stat-icon.stat-icon-success {
    background: linear-gradient(135deg, var(--success-color), var(--accent-color));
}

.stat-icon.stat-icon-info {
    background: linear-gradient(135deg, var(--info-color), var(--accent-color));
}

.stat-icon.stat-icon-primary {
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
}

.stat-icon.stat-icon-accent {
    background: linear-gradient(135deg, var(--accent-color), #9db894);
}

.stat-icon.stat-icon-error {
    background: linear-gradient(135deg, var(--error-color), #d65f44);
}

/* CFO Dashboard Container */
#chief-field-officer-dashboard {
    animation: fadeIn 0.3s ease;
}

#chief-field-officer-dashboard .page-header {
    margin-bottom: 2rem;
}

#chief-field-officer-dashboard .page-header h1 {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    color: var(--text-primary);
}

#chief-field-officer-dashboard .page-header h1 i {
    color: var(--primary-color);
}

#chief-field-officer-dashboard .page-header p {
    color: var(--text-secondary);
    margin-top: 0.5rem;
}

/* CFO Stats Grid Enhancement */
#chief-field-officer-dashboard .stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1.25rem;
    margin-bottom: 2rem;
}

#chief-field-officer-dashboard .stat-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    padding: 1.25rem;
    box-shadow: var(--shadow);
    border: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    gap: 1rem;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#chief-field-officer-dashboard .stat-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

#chief-field-officer-dashboard .stat-card .stat-icon {
    width: 56px;
    height: 56px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: white;
    flex-shrink: 0;
}

#chief-field-officer-dashboard .stat-card .stat-content h3 {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--text-secondary);
    margin-bottom: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

#chief-field-officer-dashboard .stat-card .stat-number {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.2;
}

#chief-field-officer-dashboard .stat-card .stat-detail {
    font-size: 0.75rem;
    color: var(--text-light);
    margin-top: 0.25rem;
}

/* CFO Admin Tabs */
#chief-field-officer-dashboard .admin-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    padding: 0.5rem;
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    margin-bottom: 1.5rem;
    border: 1px solid var(--border-color);
}

#chief-field-officer-dashboard .admin-tabs .tab-btn {
    padding: 0.75rem 1.25rem;
    border: none;
    background: transparent;
    color: var(--text-secondary);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    border-radius: var(--radius);
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

#chief-field-officer-dashboard .admin-tabs .tab-btn:hover {
    background: var(--bg-secondary);
    color: var(--text-primary);
}

#chief-field-officer-dashboard .admin-tabs .tab-btn.active {
    background: var(--primary-color);
    color: white;
}

#chief-field-officer-dashboard .admin-tabs .tab-btn i {
    font-size: 0.9rem;
}

/* CFO Section Header */
#chief-field-officer-dashboard .section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
    gap: 1rem;
}

#chief-field-officer-dashboard .section-header h2 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-primary);
}

#chief-field-officer-dashboard .section-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

/* CFO Filters Bar */
#chief-field-officer-dashboard .filters-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    padding: 1rem;
    background: var(--bg-primary);
    border-radius: var(--radius);
    border: 1px solid var(--border-color);
    margin-bottom: 1.5rem;
}

#chief-field-officer-dashboard .filters-bar .filter-group {
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
}

#chief-field-officer-dashboard .filters-bar .filter-group label {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

#chief-field-officer-dashboard .filters-bar select,
#chief-field-officer-dashboard .filters-bar input[type="text"] {
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    font-size: 0.875rem;
    color: var(--text-primary);
    background: var(--bg-secondary);
    min-width: 150px;
    transition: border-color 0.2s ease;
}

#chief-field-officer-dashboard .filters-bar select:focus,
#chief-field-officer-dashboard .filters-bar input[type="text"]:focus {
    outline: none;
    border-color: var(--primary-color);
    background: var(--bg-primary);
}

/* CFO Table Styles */
#chief-field-officer-dashboard .table-container {
    overflow-x: auto;
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-color);
}

#chief-field-officer-dashboard .admin-table {
    width: 100%;
    border-collapse: collapse;
}

#chief-field-officer-dashboard .admin-table th,
#chief-field-officer-dashboard .admin-table td {
    padding: 0.875rem 1rem;
    text-align: left;
    border-bottom: 1px solid var(--divider-color);
}

#chief-field-officer-dashboard .admin-table th {
    background: var(--bg-secondary);
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

#chief-field-officer-dashboard .admin-table td {
    font-size: 0.875rem;
    color: var(--text-primary);
}

#chief-field-officer-dashboard .admin-table tbody tr:hover {
    background: var(--bg-secondary);
}

#chief-field-officer-dashboard .admin-table tbody tr:last-child td {
    border-bottom: none;
}

/* CFO Bulk Actions Bar */
#chief-field-officer-dashboard .bulk-actions-bar {
    display: none;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    background: var(--bg-cream);
    border-radius: var(--radius);
    border: 1px solid var(--border-color);
    margin-top: 1rem;
}

#chief-field-officer-dashboard .bulk-actions-bar.show {
    display: flex;
}

#chief-field-officer-dashboard .bulk-actions-bar span {
    font-weight: 500;
    color: var(--text-primary);
    flex: 1;
}

/* CFO Territory Stats Grid */
#chief-field-officer-dashboard .territory-stats-grid {
    margin-bottom: 2rem;
}

/* CFO Territories Grid */
#chief-field-officer-dashboard .territories-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(300px, 100%), 1fr));
    gap: 1.25rem;
}

#chief-field-officer-dashboard .territory-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#chief-field-officer-dashboard .territory-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

#chief-field-officer-dashboard .territory-card h3 {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 0.5rem;
}

#chief-field-officer-dashboard .territory-card p {
    color: var(--text-secondary);
    font-size: 0.875rem;
    margin-bottom: 1rem;
}

/* CFO Officers Grid */
#chief-field-officer-dashboard .officers-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.25rem;
}

#chief-field-officer-dashboard .officer-card {
    background: var(--bg-primary);
    border-radius: 18px;
    padding: 0;
    border: 1px solid var(--border-color);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

#chief-field-officer-dashboard .officer-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 28px rgba(13, 148, 136, 0.15);
    border-color: rgba(13, 148, 136, 0.3);
}

#chief-field-officer-dashboard .cfo-officer-body {
    padding: 1.25rem;
    flex: 1;
}

#chief-field-officer-dashboard .cfo-officer-top {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
}

#chief-field-officer-dashboard .cfo-officer-avatar {
    width: 50px;
    height: 50px;
    min-width: 50px;
    background: linear-gradient(135deg, #0f766e, #14b8a6);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1rem;
    font-weight: 700;
    box-shadow: 0 4px 12px rgba(13, 148, 136, 0.28);
}

#chief-field-officer-dashboard .cfo-officer-identity {
    flex: 1;
    min-width: 0;
}

#chief-field-officer-dashboard .cfo-officer-identity h4 {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#chief-field-officer-dashboard .cfo-officer-identity p {
    margin: 0.25rem 0 0;
    font-size: 0.82rem;
    color: var(--text-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#chief-field-officer-dashboard .cfo-officer-metrics {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

#chief-field-officer-dashboard .cfo-officer-metric {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    padding: 0.65rem 0.75rem;
}

#chief-field-officer-dashboard .cfo-officer-metric small {
    display: block;
    color: var(--text-secondary);
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    margin-bottom: 0.2rem;
}

#chief-field-officer-dashboard .cfo-officer-metric p {
    margin: 0;
    font-size: 0.88rem;
    font-weight: 600;
}

#chief-field-officer-dashboard .cfo-officer-actions {
    display: flex;
    gap: 0.5rem;
    padding: 0.875rem 1rem 1rem;
    background: var(--bg-secondary);
    border-top: 1px solid var(--border-color);
}

#chief-field-officer-dashboard .cfo-officer-actions .btn-primary {
    flex: 1;
    background: linear-gradient(135deg, #0d9488, #14b8a6);
    border: none;
}

/* CFO Visits & Notes */
#chief-field-officer-dashboard .cfo-visits-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(340px, 100%), 1fr));
    gap: 1.25rem;
}

#chief-field-officer-dashboard .cfo-visit-card {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
    display: flex;
    flex-direction: column;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
    position: relative;
}

#chief-field-officer-dashboard .cfo-visit-card::before {
    content: '';
    display: block;
    height: 4px;
    background: linear-gradient(90deg, #0d9488, #14b8a6);
}

#chief-field-officer-dashboard .cfo-visit-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 28px rgba(13, 148, 136, 0.15);
    border-color: rgba(13, 148, 136, 0.3);
}

#chief-field-officer-dashboard .cfo-visit-card-main {
    padding: 1.25rem;
    flex: 1;
    min-width: 0;
}

#chief-field-officer-dashboard .cfo-visit-card-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

#chief-field-officer-dashboard .cfo-visit-card-top h4 {
    margin: 0 0 0.25rem;
    font-size: 1rem;
    font-weight: 700;
}

#chief-field-officer-dashboard .cfo-visit-officer {
    margin: 0;
    font-size: 0.82rem;
    color: var(--text-secondary);
}

#chief-field-officer-dashboard .cfo-visit-meta {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    margin-bottom: 0.75rem;
    font-size: 0.82rem;
    color: var(--text-secondary);
}

#chief-field-officer-dashboard .cfo-visit-meta span {
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

#chief-field-officer-dashboard .cfo-visit-notes-preview {
    margin: 0;
    font-size: 0.85rem;
    color: var(--text-primary);
    line-height: 1.45;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

#chief-field-officer-dashboard .cfo-visit-comment-count {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-top: 0.75rem;
    font-size: 0.75rem;
    font-weight: 600;
    color: #0d9488;
}

#chief-field-officer-dashboard .cfo-visit-card-actions {
    padding: 0.875rem 1rem 1rem;
    background: var(--bg-secondary);
    border-top: 1px solid var(--border-color);
}

/* CFO Visit Review Modal (rendered on document.body) */
.cfo-visit-modal.fo-modal .modal-header::before {
    background: linear-gradient(90deg, #0d9488, #14b8a6);
}

.cfo-visit-modal.fo-modal .modal-content {
    max-width: 720px;
}

.cfo-visit-review .cfo-visit-hero {
    background: linear-gradient(135deg, rgba(13, 148, 136, 0.12), rgba(20, 184, 166, 0.05));
}

.cfo-visit-review .cfo-visit-hero-icon {
    background: linear-gradient(135deg, #0f766e, #14b8a6);
    box-shadow: 0 4px 12px rgba(13, 148, 136, 0.35);
}

.cfo-visit-review .cfo-visit-review-officer {
    margin: 0.25rem 0 0.65rem;
    font-size: 0.85rem;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

.cfo-visit-review .cfo-visit-hero-badges {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.cfo-visit-review .cfo-visit-feedback-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.2rem 0.65rem;
    border-radius: 999px;
    background: rgba(13, 148, 136, 0.12);
    color: #0f766e;
    font-size: 0.72rem;
    font-weight: 700;
}

.cfo-visit-review .cfo-visit-detail-tabs {
    margin-bottom: 1.25rem;
}

.cfo-visit-review .fo-detail-tab-btn.active {
    color: #0f766e;
    border-bottom-color: #14b8a6;
    background: rgba(13, 148, 136, 0.08);
}

.cfo-visit-review .fo-detail-tile i {
    color: #0d9488;
}

.cfo-visit-review .fo-detail-section h4 {
    display: flex;
    align-items: center;
    gap: 0.45rem;
}

.cfo-visit-review .fo-detail-section h4 i {
    color: #0d9488;
    font-size: 0.9rem;
}

.cfo-visit-review .fo-section-summary {
    border-left-color: #10b981;
}

.cfo-visit-review .fo-section-outcome {
    border-left-color: #0d9488;
}

.cfo-visit-review .fo-section-followup {
    border-left-color: #6366f1;
}

.cfo-visit-review .cfo-linked-assets {
    border-left-color: #8b5cf6;
}

.cfo-visit-review .cfo-visit-overview-hint {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    padding: 0.875rem 1rem;
    background: rgba(13, 148, 136, 0.08);
    border: 1px dashed rgba(13, 148, 136, 0.35);
    border-radius: 12px;
    font-size: 0.85rem;
    color: var(--text-secondary);
    line-height: 1.45;
}

.cfo-visit-review .cfo-visit-overview-hint i {
    color: #0d9488;
    margin-top: 0.15rem;
    flex-shrink: 0;
}

.cfo-visit-review .cfo-note-panels {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.cfo-visit-review .cfo-note-panel {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.cfo-visit-review .cfo-note-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.875rem 1rem;
    background: linear-gradient(135deg, rgba(13, 148, 136, 0.08), rgba(20, 184, 166, 0.03));
    border-bottom: 1px solid var(--border-color);
}

.cfo-visit-review .cfo-note-panel-title {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    min-width: 0;
}

.cfo-visit-review .cfo-note-panel-title h5 {
    margin: 0;
    font-size: 0.92rem;
    font-weight: 700;
    color: var(--text-primary);
}

.cfo-visit-review .cfo-note-panel-icon {
    width: 32px;
    height: 32px;
    min-width: 32px;
    border-radius: 9px;
    background: rgba(13, 148, 136, 0.14);
    color: #0d9488;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
}

.cfo-visit-review .cfo-comment-count {
    background: rgba(13, 148, 136, 0.12);
    color: #0d9488;
    font-size: 0.72rem;
    font-weight: 700;
    padding: 0.15rem 0.55rem;
    border-radius: 999px;
    flex-shrink: 0;
}

.cfo-visit-review .cfo-note-panel-body {
    padding: 1rem 1rem 0.875rem;
}

.cfo-visit-review .cfo-note-content {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.55;
    color: var(--text-primary);
    white-space: pre-wrap;
    word-break: break-word;
}

.cfo-visit-review .cfo-note-empty,
.cfo-visit-review .cfo-note-hint {
    margin: 0;
    font-size: 0.85rem;
    color: var(--text-secondary);
    line-height: 1.45;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.cfo-visit-review .cfo-note-empty i {
    opacity: 0.45;
}

.cfo-visit-review .cfo-note-panel-comments {
    padding: 0.875rem 1rem 1rem;
    background: var(--bg-secondary);
    border-top: 1px solid var(--border-color);
}

.cfo-visit-review .cfo-note-panel-comments-label {
    margin: 0 0 0.65rem;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
}

.cfo-visit-review .cfo-comments-list {
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
    margin-bottom: 0.75rem;
    max-height: 180px;
    overflow-y: auto;
}

.cfo-visit-review .cfo-comment-item {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    padding: 0.7rem 0.75rem;
}

.cfo-visit-review .cfo-comment-meta {
    display: flex;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.3rem;
    font-size: 0.72rem;
}

.cfo-visit-review .cfo-comment-meta strong {
    color: var(--text-primary);
}

.cfo-visit-review .cfo-comment-meta span {
    color: var(--text-secondary);
    white-space: nowrap;
}

.cfo-visit-review .cfo-comment-item p {
    margin: 0;
    font-size: 0.84rem;
    line-height: 1.45;
    color: var(--text-primary);
}

.cfo-visit-review .cfo-comments-empty {
    margin: 0 0 0.75rem;
    font-size: 0.82rem;
    color: var(--text-secondary);
    font-style: italic;
}

.cfo-visit-review .cfo-comment-form {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.cfo-visit-review .cfo-comment-form textarea {
    width: 100%;
    min-height: 68px;
    padding: 0.65rem 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: 10px;
    font-family: inherit;
    font-size: 0.85rem;
    resize: vertical;
    background: var(--bg-primary);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.cfo-visit-review .cfo-comment-form textarea:focus {
    outline: none;
    border-color: rgba(13, 148, 136, 0.5);
    box-shadow: 0 0 0 3px rgba(13, 148, 136, 0.12);
}

.cfo-visit-review .cfo-comment-form-actions {
    display: flex;
    justify-content: flex-end;
}

.cfo-visit-review .cfo-comment-submit {
    background: linear-gradient(135deg, #0d9488, #14b8a6);
    border: none;
}

.cfo-visit-review .cfo-visit-modal-footer {
    display: flex;
    justify-content: flex-end;
    padding-top: 1.25rem;
    margin-top: 0.5rem;
    border-top: 1px solid var(--border-color);
}

.cfo-visit-review .cfo-note-panel--planningNotes .cfo-note-panel-icon { background: rgba(245, 158, 11, 0.15); color: #d97706; }
.cfo-visit-review .cfo-note-panel--fieldNotes .cfo-note-panel-icon { background: rgba(16, 185, 129, 0.15); color: #059669; }
.cfo-visit-review .cfo-note-panel--summary .cfo-note-panel-icon { background: rgba(99, 102, 241, 0.15); color: #6366f1; }
.cfo-visit-review .cfo-note-panel--visit .cfo-note-panel-icon { background: rgba(13, 148, 136, 0.15); color: #0d9488; }

@media (max-width: 576px) {
    .cfo-visit-modal.fo-modal .modal-content {
        max-width: calc(100vw - 1rem);
    }

    .cfo-visit-review .fo-detail-grid {
        grid-template-columns: 1fr;
    }

    .cfo-visit-review .cfo-visit-detail-tabs {
        flex-direction: column;
    }

    .cfo-visit-review .fo-detail-tab-btn {
        justify-content: center;
    }
}

#field-officer-dashboard .fo-section-chief-comments {
    border-left: 4px solid #0d9488;
    background: rgba(13, 148, 136, 0.05);
}

#field-officer-dashboard .fo-section-chief-comments h4 {
    color: #0f766e;
}

#field-officer-dashboard .fo-chief-comments-list {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

#field-officer-dashboard .fo-chief-comment-item {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    padding: 0.75rem;
}

#field-officer-dashboard .fo-chief-comment-meta {
    display: flex;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.35rem;
    font-size: 0.75rem;
    color: var(--text-secondary);
}

#field-officer-dashboard .fo-chief-comment-target {
    font-weight: 700;
    color: #0d9488;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

#field-officer-dashboard .fo-chief-comment-item p {
    margin: 0 0 0.35rem;
    font-size: 0.85rem;
    line-height: 1.45;
}

#field-officer-dashboard .fo-chief-comment-item small {
    color: var(--text-secondary);
    font-size: 0.75rem;
}

/* CFO Analytics Container */
#chief-field-officer-dashboard .analytics-container {
    padding: 0;
}

#chief-field-officer-dashboard .charts-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}

#chief-field-officer-dashboard .chart-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow);
}

#chief-field-officer-dashboard .chart-card h3 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 1rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--divider-color);
}

#chief-field-officer-dashboard .chart-card canvas {
    max-height: 280px;
}

/* CFO Reports Bulk Operations Grid */
#chief-field-officer-dashboard .bulk-operations-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.5rem;
}

#chief-field-officer-dashboard .bulk-op-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow);
    overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#chief-field-officer-dashboard .bulk-op-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

#chief-field-officer-dashboard .bulk-op-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem 1.25rem;
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    color: white;
}

#chief-field-officer-dashboard .bulk-op-header i {
    font-size: 1.25rem;
}

#chief-field-officer-dashboard .bulk-op-header h3 {
    font-size: 1rem;
    font-weight: 600;
    margin: 0;
}

#chief-field-officer-dashboard .bulk-op-body {
    padding: 1.25rem;
}

#chief-field-officer-dashboard .bulk-op-body p {
    color: var(--text-secondary);
    font-size: 0.875rem;
    margin-bottom: 1rem;
    line-height: 1.5;
}

#chief-field-officer-dashboard .bulk-op-body .form-group {
    margin-bottom: 1rem;
}

#chief-field-officer-dashboard .bulk-op-body .form-group label {
    display: block;
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
    margin-bottom: 0.375rem;
}

#chief-field-officer-dashboard .bulk-op-body .form-group input,
#chief-field-officer-dashboard .bulk-op-body .form-group select {
    width: 100%;
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    font-size: 0.875rem;
    color: var(--text-primary);
    background: var(--bg-secondary);
    transition: border-color 0.2s ease;
}

#chief-field-officer-dashboard .bulk-op-body .form-group input:focus,
#chief-field-officer-dashboard .bulk-op-body .form-group select:focus {
    outline: none;
    border-color: var(--primary-color);
    background: var(--bg-primary);
}

#chief-field-officer-dashboard .bulk-op-body .form-group span {
    display: inline-block;
    padding: 0 0.5rem;
    color: var(--text-secondary);
}

/* CFO Button Enhancements */
#chief-field-officer-dashboard .btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem 1rem;
    font-size: 0.875rem;
    font-weight: 500;
    border-radius: var(--radius);
    border: none;
    cursor: pointer;
    transition: all 0.2s ease;
}

#chief-field-officer-dashboard .btn-primary {
    background: var(--primary-color);
    color: white;
}

#chief-field-officer-dashboard .btn-primary:hover {
    background: var(--secondary-color);
}

#chief-field-officer-dashboard .btn-secondary {
    background: var(--bg-secondary);
    color: var(--text-primary);
    border: 1px solid var(--border-color);
}

#chief-field-officer-dashboard .btn-secondary:hover {
    background: var(--bg-cream);
}

#chief-field-officer-dashboard .btn-success {
    background: var(--success-color);
    color: white;
}

#chief-field-officer-dashboard .btn-success:hover {
    background: var(--secondary-color);
}

#chief-field-officer-dashboard .btn-danger {
    background: var(--error-color);
    color: white;
}

#chief-field-officer-dashboard .btn-danger:hover {
    background: #b53518;
}

/* CFO Responsive Styles */
@media (max-width: 1200px) {
    #chief-field-officer-dashboard .charts-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 992px) {
    #chief-field-officer-dashboard .stats-grid {
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    }

    #chief-field-officer-dashboard .admin-tabs {
        justify-content: center;
    }
}

@media (max-width: 768px) {
    #chief-field-officer-dashboard .stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    #chief-field-officer-dashboard .stat-card {
        padding: 1rem;
    }

    #chief-field-officer-dashboard .stat-card .stat-icon {
        width: 48px;
        height: 48px;
        font-size: 1.1rem;
    }

    #chief-field-officer-dashboard .stat-card .stat-number {
        font-size: 1.5rem;
    }

    #chief-field-officer-dashboard .admin-tabs .tab-btn {
        padding: 0.625rem 0.875rem;
        font-size: 0.8rem;
    }

    #chief-field-officer-dashboard .admin-tabs .tab-btn i {
        display: none;
    }

    #chief-field-officer-dashboard .filters-bar {
        flex-direction: column;
    }

    #chief-field-officer-dashboard .filters-bar .filter-group {
        width: 100%;
    }

    #chief-field-officer-dashboard .filters-bar select,
    #chief-field-officer-dashboard .filters-bar input[type="text"] {
        width: 100%;
    }

    #chief-field-officer-dashboard .section-header {
        flex-direction: column;
        align-items: stretch;
    }

    #chief-field-officer-dashboard .section-actions {
        justify-content: center;
    }

    #chief-field-officer-dashboard .bulk-actions-bar {
        flex-direction: column;
        text-align: center;
    }

    #chief-field-officer-dashboard .bulk-operations-grid {
        grid-template-columns: 1fr;
    }

    #chief-field-officer-dashboard .territories-grid,
    #chief-field-officer-dashboard .officers-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    #chief-field-officer-dashboard .stats-grid {
        grid-template-columns: 1fr;
    }

    #chief-field-officer-dashboard .admin-tabs {
        flex-wrap: nowrap;
        gap: 0.5rem;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 0.5rem;
    }

    #chief-field-officer-dashboard .admin-tabs .tab-btn {
        flex-shrink: 0;
        padding: 0.5rem 0.75rem;
        font-size: 0.75rem;
    }

    #chief-field-officer-dashboard .admin-tabs .tab-btn i {
        display: none;
    }
}

/* ============================================
   Board of Directors Dashboard Styles
   ============================================ */

/* Fade In Animation */
@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(5px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Board Dashboard Container */
#board-dashboard {
    animation: fadeIn 0.3s ease;
}

#board-dashboard .page-header {
    margin-bottom: 2rem;
}

#board-dashboard .page-header h1 {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    color: var(--text-primary);
    font-size: 1.75rem;
}

#board-dashboard .page-header h1 i {
    color: var(--primary-color);
}

#board-dashboard .page-header p {
    color: var(--text-secondary);
    margin-top: 0.5rem;
}

/* Board Controls */
#board-dashboard .board-controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 1rem;
    margin-bottom: 2rem;
    padding: 1rem 1.25rem;
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow);
}

#board-dashboard .time-range-selector {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

#board-dashboard .time-range-selector label {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-secondary);
}

#board-dashboard .filter-select {
    padding: 0.5rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    font-size: 0.875rem;
    color: var(--text-primary);
    background: var(--bg-secondary);
    cursor: pointer;
    transition: border-color 0.2s ease;
}

#board-dashboard .filter-select:focus {
    outline: none;
    border-color: var(--primary-color);
    background: var(--bg-primary);
}

#board-dashboard .board-actions {
    display: flex;
    gap: 0.75rem;
}

/* Board KPI Grid */
#board-dashboard .board-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1.25rem;
    margin-bottom: 2rem;
}

#board-dashboard .kpi-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    padding: 1.25rem;
    box-shadow: var(--shadow);
    border: 1px solid var(--border-color);
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    position: relative;
    overflow: hidden;
}

#board-dashboard .kpi-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: auto;
    height: 4px;
}

#board-dashboard .kpi-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.1);
}

/* KPI Card Color Variants */
#board-dashboard .kpi-card.primary::before {
    background: linear-gradient(90deg, var(--primary-color), var(--secondary-color));
}

#board-dashboard .kpi-card.primary .kpi-icon {
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
}

#board-dashboard .kpi-card.success::before {
    background: linear-gradient(90deg, var(--success-color), var(--accent-color));
}

#board-dashboard .kpi-card.success .kpi-icon {
    background: linear-gradient(135deg, var(--success-color), var(--accent-color));
}

#board-dashboard .kpi-card.warning::before {
    background: linear-gradient(90deg, var(--warning-color), #e8b676);
}

#board-dashboard .kpi-card.warning .kpi-icon {
    background: linear-gradient(135deg, var(--warning-color), #e8b676);
}

#board-dashboard .kpi-card.info::before {
    background: linear-gradient(90deg, var(--info-color), var(--accent-color));
}

#board-dashboard .kpi-card.info .kpi-icon {
    background: linear-gradient(135deg, var(--info-color), var(--accent-color));
}

#board-dashboard .kpi-card.danger::before {
    background: linear-gradient(90deg, var(--error-color), #d65f44);
}

#board-dashboard .kpi-card.danger .kpi-icon {
    background: linear-gradient(135deg, var(--error-color), #d65f44);
}

#board-dashboard .kpi-card.secondary::before {
    background: linear-gradient(90deg, var(--text-secondary), var(--text-light));
}

#board-dashboard .kpi-card.secondary .kpi-icon {
    background: linear-gradient(135deg, var(--text-secondary), var(--text-light));
}

#board-dashboard .kpi-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.125rem;
    flex-shrink: 0;
}

#board-dashboard .kpi-content {
    flex: 1;
    min-width: 0;
}

#board-dashboard .kpi-content h3 {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-secondary);
    margin-bottom: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

#board-dashboard .kpi-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.2;
    margin-bottom: 0.25rem;
}

#board-dashboard .kpi-change {
    font-size: 0.75rem;
    color: var(--text-light);
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

#board-dashboard .kpi-change i {
    font-size: 0.625rem;
}

#board-dashboard .kpi-change .fa-arrow-up {
    color: var(--success-color);
}

#board-dashboard .kpi-change .fa-arrow-down {
    color: var(--error-color);
}

/* Board Regional Summary Cards */
#board-dashboard .regional-summary .region-card {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(260px, 100%), 1fr));
    gap: 1.25rem;
    margin-bottom: 1.5rem;
}

#board-dashboard .region-summary-card {
    padding: 1.25rem;
}

#board-dashboard .region-summary-card h4 {
    margin: 0 0 1rem;
    font-size: 1rem;
    font-weight: 700;
    color: var(--text-primary);
}

#board-dashboard .region-stats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.625rem;
}

#board-dashboard .region-stat {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    padding: 0.65rem 0.75rem;
    text-align: center;
}

#board-dashboard .region-stat .stat-label {
    display: block;
    font-size: 0.68rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--text-secondary);
    margin-bottom: 0.2rem;
}

#board-dashboard .region-stat .stat-value {
    display: block;
    font-size: 1rem;
    font-weight: 700;
    color: var(--text-primary);
}

/* Board Dashboard Tabs */
#board-dashboard .dashboard-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    padding: 0.5rem;
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    margin-bottom: 1.5rem;
    border: 1px solid var(--border-color);
}

#board-dashboard .dashboard-tabs .tab-btn {
    padding: 0.75rem 1.25rem;
    border: none;
    background: transparent;
    color: var(--text-secondary);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    border-radius: var(--radius);
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

#board-dashboard .dashboard-tabs .tab-btn:hover {
    background: var(--bg-secondary);
    color: var(--text-primary);
}

#board-dashboard .dashboard-tabs .tab-btn.active {
    background: var(--primary-color);
    color: white;
    box-shadow: 0 2px 8px rgba(74, 103, 65, 0.3);
}

/* Remove any inherited ::after pseudo-elements */
#board-dashboard .dashboard-tabs .tab-btn::after {
    display: none !important;
}

#board-dashboard .dashboard-tabs .tab-btn i {
    font-size: 0.9rem;
}

/* Board Tab Content - Critical: Hide non-active tabs */
#board-dashboard .board-tab-content {
    display: none !important;
    visibility: hidden;
    opacity: 0;
    height: 0;
    overflow: hidden;
}

#board-dashboard .board-tab-content.active {
    display: block !important;
    visibility: visible;
    opacity: 1;
    height: auto;
    overflow: visible;
    animation: fadeIn 0.3s ease;
}

#board-dashboard .board-section {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow);
}

#board-dashboard .board-section h2 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 1.5rem;
    padding-bottom: 0.75rem;
    border-bottom: 2px solid var(--primary-color);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

#board-dashboard .board-section h2::before {
    content: '';
    width: 4px;
    height: 1.25rem;
    background: var(--primary-color);
    border-radius: 2px;
}

/* Board Chart Grid */
#board-dashboard .chart-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}

#board-dashboard .chart-card {
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow);
}

#board-dashboard .chart-card h3 {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 1.25rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--divider-color);
}

#board-dashboard .chart-card canvas {
    max-height: 280px;
    width: 100% !important;
}

/* Board Metrics Row */
#board-dashboard .metrics-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1.25rem;
}

#board-dashboard .metric-box {
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    border: 1px solid var(--border-color);
    text-align: center;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#board-dashboard .metric-box:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow);
}

#board-dashboard .metric-box h4 {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

#board-dashboard .metric-box .metric-value {
    font-size: 2.25rem;
    font-weight: 700;
    color: var(--primary-color);
    margin-bottom: 0.5rem;
    line-height: 1;
}

#board-dashboard .metric-box .metric-detail {
    font-size: 0.8rem;
    color: var(--text-light);
}

#board-dashboard .metric-box .metric-detail span {
    font-weight: 600;
    color: var(--primary-color);
}

/* Board Performance Table */
#board-dashboard .performance-table {
    margin-top: 1.5rem;
}

#board-dashboard .performance-table h3 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 1rem;
}

#board-dashboard .board-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--border-color);
}

#board-dashboard .board-table th,
#board-dashboard .board-table td {
    padding: 1rem 1.25rem;
    text-align: left;
    border-bottom: 1px solid var(--divider-color);
}

#board-dashboard .board-table th {
    background: linear-gradient(135deg, var(--bg-cream), var(--bg-secondary));
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.075em;
}

#board-dashboard .board-table td {
    font-size: 0.9rem;
    color: var(--text-primary);
}

#board-dashboard .board-table tbody tr {
    transition: background-color 0.15s ease;
}

#board-dashboard .board-table tbody tr:hover {
    background: var(--bg-secondary);
}

#board-dashboard .board-table tbody tr:last-child td {
    border-bottom: none;
}

#board-dashboard .board-table .empty-state {
    text-align: center;
    color: var(--text-light);
    padding: 3rem;
    font-style: italic;
}

/* Board Financial Cards */
#board-dashboard .financial-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.25rem;
    margin-bottom: 1.5rem;
}

#board-dashboard .financial-card {
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    border-radius: var(--radius-lg);
    padding: 1.75rem;
    color: white;
    text-align: center;
    box-shadow: 0 4px 12px rgba(74, 103, 65, 0.25);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#board-dashboard .financial-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 16px rgba(74, 103, 65, 0.35);
}

#board-dashboard .financial-card h3 {
    font-size: 0.75rem;
    font-weight: 600;
    opacity: 0.9;
    margin-bottom: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

#board-dashboard .financial-value {
    font-size: 2.25rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
    line-height: 1;
}

#board-dashboard .financial-trend {
    font-size: 0.85rem;
    opacity: 0.9;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
}

#board-dashboard .financial-trend i {
    font-size: 0.75rem;
}

#board-dashboard .financial-trend .text-success {
    color: #90EE90;
}

/* Board Health Metrics */
#board-dashboard .health-metrics {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.25rem;
    margin-bottom: 1.5rem;
}

#board-dashboard .health-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    border: 1px solid var(--border-color);
    display: flex;
    align-items: flex-start;
    gap: 1.25rem;
    box-shadow: var(--shadow);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#board-dashboard .health-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

#board-dashboard .health-icon {
    width: 52px;
    height: 52px;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.25rem;
    flex-shrink: 0;
    box-shadow: 0 4px 8px rgba(74, 103, 65, 0.2);
}

#board-dashboard .health-content {
    flex: 1;
}

#board-dashboard .health-content h3 {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

#board-dashboard .health-score {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--primary-color);
    margin-bottom: 0.75rem;
    line-height: 1;
}

#board-dashboard .health-bar {
    height: 8px;
    background: var(--bg-cream);
    border-radius: 4px;
    overflow: hidden;
}

#board-dashboard .health-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--primary-color), var(--accent-color));
    border-radius: 4px;
    transition: width 0.6s ease;
}

#board-dashboard .health-detail {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin-top: 0.5rem;
}

/* Board Regional Summary */
#board-dashboard .regional-summary {
    margin-bottom: 1.5rem;
}

#board-dashboard .region-card {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 1rem;
}

#board-dashboard .regional-table {
    margin-top: 1.5rem;
}

#board-dashboard .regional-table h3 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 1rem;
}

/* Board Button Styles */
#board-dashboard .btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem 1rem;
    font-size: 0.875rem;
    font-weight: 500;
    border-radius: var(--radius);
    border: none;
    cursor: pointer;
    transition: all 0.2s ease;
}

#board-dashboard .btn-primary {
    background: var(--primary-color);
    color: white;
}

#board-dashboard .btn-primary:hover {
    background: var(--secondary-color);
}

#board-dashboard .btn-secondary {
    background: var(--bg-secondary);
    color: var(--text-primary);
    border: 1px solid var(--border-color);
}

#board-dashboard .btn-secondary:hover {
    background: var(--bg-cream);
}

/* Board Dashboard Responsive Styles */
@media (max-width: 1200px) {
    #board-dashboard .chart-grid {
        grid-template-columns: 1fr;
    }

    #board-dashboard .board-kpi-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 992px) {
    #board-dashboard .board-kpi-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    #board-dashboard .dashboard-tabs {
        justify-content: center;
    }

    #board-dashboard .financial-cards {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    #board-dashboard .board-controls {
        flex-direction: column;
        align-items: stretch;
    }

    #board-dashboard .time-range-selector {
        justify-content: center;
    }

    #board-dashboard .board-actions {
        justify-content: center;
    }

    #board-dashboard .board-kpi-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    #board-dashboard .kpi-card {
        padding: 1rem;
    }

    #board-dashboard .kpi-icon {
        width: 40px;
        height: 40px;
        font-size: 1rem;
    }

    #board-dashboard .kpi-value {
        font-size: 1.25rem;
    }

    #board-dashboard .dashboard-tabs .tab-btn {
        padding: 0.625rem 0.875rem;
        font-size: 0.8rem;
    }

    #board-dashboard .dashboard-tabs .tab-btn i {
        display: none;
    }

    #board-dashboard .board-section {
        padding: 1rem;
    }

    #board-dashboard .metrics-row {
        grid-template-columns: 1fr;
    }

    #board-dashboard .health-metrics {
        grid-template-columns: 1fr;
    }

    #board-dashboard .financial-cards {
        grid-template-columns: 1fr;
    }

    #board-dashboard .board-table {
        font-size: 0.8rem;
    }

    #board-dashboard .board-table th,
    #board-dashboard .board-table td {
        padding: 0.625rem 0.75rem;
    }
}

@media (max-width: 480px) {
    #board-dashboard .board-kpi-grid {
        grid-template-columns: 1fr;
    }

    #board-dashboard .dashboard-tabs {
        flex-wrap: nowrap;
        gap: 0.5rem;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 0.5rem;
    }

    #board-dashboard .dashboard-tabs .tab-btn {
        flex-shrink: 0;
        padding: 0.5rem 0.75rem;
        font-size: 0.75rem;
    }

    #board-dashboard .dashboard-tabs .tab-btn i {
        display: none;
    }

    #board-dashboard .metric-box .metric-value {
        font-size: 1.5rem;
    }

    #board-dashboard .financial-value {
        font-size: 1.5rem;
    }
}

/* ============================================
   UNIVERSAL FORM INPUT STYLING
   Ensures ALL form inputs have black text and white backgrounds
   ============================================ */
input,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="tel"],
input[type="date"],
input[type="time"],
input[type="datetime-local"],
input[type="search"],
input[type="url"],
input[type="file"],
select,
textarea,
.form-control,
.form-group input,
.form-group select,
.form-group textarea {
    background-color: #ffffff !important;
    color: #1f2937 !important;
    -webkit-text-fill-color: #1f2937 !important;
    caret-color: #1f2937 !important;
}

/* Ensure placeholders are visible but muted */
input::placeholder,
textarea::placeholder,
select::placeholder,
.form-control::placeholder {
    color: #6b7280 !important;
    -webkit-text-fill-color: #6b7280 !important;
    opacity: 1 !important;
}

/* Handle autofill styling */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active,
select:-webkit-autofill,
textarea:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 30px #ffffff inset !important;
    -webkit-text-fill-color: #1f2937 !important;
    background-color: #ffffff !important;
}

/* Modal form inputs */
.modal input,
.modal select,
.modal textarea,
.modal-body input,
.modal-body select,
.modal-body textarea,
.modal-content input,
.modal-content select,
.modal-content textarea {
    background-color: #ffffff !important;
    color: #1f2937 !important;
    -webkit-text-fill-color: #1f2937 !important;
    caret-color: #1f2937 !important;
}

/* Farm management modal inputs */
.farm-management-modal input,
.farm-management-modal select,
.farm-management-modal textarea,
.farm-management-container input,
.farm-management-container select,
.farm-management-container textarea {
    background-color: #ffffff !important;
    color: #1f2937 !important;
    -webkit-text-fill-color: #1f2937 !important;
    caret-color: #1f2937 !important;
    border: 1px solid #d1d5db !important;
}

/* Dashboard form inputs */
#admin-dashboard input,
#admin-dashboard select,
#admin-dashboard textarea,
#ceo-dashboard input,
#ceo-dashboard select,
#ceo-dashboard textarea,
#field-officer-dashboard input,
#field-officer-dashboard select,
#field-officer-dashboard textarea,
#chief-field-officer-dashboard input,
#chief-field-officer-dashboard select,
#chief-field-officer-dashboard textarea,
#board-dashboard input,
#board-dashboard select,
#board-dashboard textarea,
#hr-dashboard input,
#hr-dashboard select,
#hr-dashboard textarea {
    background-color: #ffffff !important;
    color: #1f2937 !important;
    -webkit-text-fill-color: #1f2937 !important;
    caret-color: #1f2937 !important;
}

/* Activity logger modal inputs */
.activity-logger-modal input,
.activity-logger-modal select,
.activity-logger-modal textarea {
    background-color: #ffffff !important;
    color: #1f2937 !important;
    -webkit-text-fill-color: #1f2937 !important;
    caret-color: #1f2937 !important;
}

/* Plant form inputs */
.plant-form-container input,
.plant-form-container select,
.plant-form-container textarea {
    background-color: #ffffff !important;
    color: #1f2937 !important;
    -webkit-text-fill-color: #1f2937 !important;
    caret-color: #1f2937 !important;
}

/* Inline-styled inputs override */
input[style],
select[style],
textarea[style] {
    color: #1f2937 !important;
    -webkit-text-fill-color: #1f2937 !important;
    caret-color: #1f2937 !important;
}

/* Dropdown/select options */
select option {
    background-color: #ffffff !important;
    color: #1f2937 !important;
}

/* ========================================
   ENHANCED EDIT USER MODAL STYLES
   ======================================== */

/* Wider modal for edit user */
#editUserModal .modal-content {
    max-width: 900px;
}

/* Edit User Tabs */
.edit-user-tabs {
    display: flex;
    gap: 0;
    border-bottom: 2px solid var(--border-color);
    margin-bottom: 1.5rem;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.edit-user-tab-btn {
    background: none;
    border: none;
    padding: 0.875rem 1rem;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--text-secondary);
    cursor: pointer;
    position: relative;
    white-space: nowrap;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.edit-user-tab-btn:hover {
    color: var(--primary-color);
    background: var(--bg-secondary);
}

.edit-user-tab-btn.active {
    color: var(--primary-color);
}

.edit-user-tab-btn.active::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--primary-color);
}

.edit-user-tab-btn i {
    font-size: 0.875rem;
}

/* Tab Content */
.edit-user-tab-content {
    display: none;
    animation: fadeIn 0.3s ease;
    max-height: 60vh;
    overflow-y: auto;
    padding-right: 0.5rem;
}

.edit-user-tab-content.active {
    display: block;
}

/* Item Cards (farms, livestock, equipment, listings) */
.edit-user-item-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.edit-user-item-card {
    background: var(--bg-secondary);
    border-radius: var(--radius);
    overflow: hidden;
    border: 1px solid var(--border-color);
}

.edit-user-item-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    cursor: pointer;
    transition: background 0.2s ease;
}

.edit-user-item-header:hover {
    background: var(--bg-primary);
}

.edit-user-item-info h4 {
    margin: 0 0 0.25rem;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text-primary);
}

.edit-user-item-meta {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.edit-user-item-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.edit-user-item-details {
    padding: 1rem;
    border-top: 1px solid var(--border-color);
    background: var(--bg-primary);
}

.edit-user-detail-row {
    padding: 0.375rem 0;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.edit-user-detail-row strong {
    color: var(--text-primary);
    margin-right: 0.5rem;
}

.edit-user-expand-icon {
    transition: transform 0.2s ease;
    color: var(--text-secondary);
}

/* Empty State */
.edit-user-empty-state {
    text-align: center;
    padding: 2rem;
    color: var(--text-secondary);
}

.edit-user-empty-state i {
    font-size: 2.5rem;
    margin-bottom: 1rem;
    opacity: 0.5;
}

.edit-user-empty-state p {
    margin-bottom: 1rem;
}

/* Farm/Livestock Groups */
.edit-user-group {
    margin-bottom: 1.5rem;
}

.edit-user-group-header {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.edit-user-group-header i {
    color: var(--primary-color);
}

/* Password Section */
.edit-user-password-section {
    background: var(--bg-secondary);
    padding: 1.5rem;
    border-radius: var(--radius);
    margin-bottom: 1rem;
}

.edit-user-password-section h4 {
    margin: 0 0 1rem;
    font-size: 1rem;
    color: var(--text-primary);
}

.password-requirements {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin-top: 0.5rem;
}

/* Status Badges */
.edit-user-status-badge {
    display: inline-block;
    padding: 0.125rem 0.5rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 500;
}

.edit-user-status-active {
    background: rgba(34, 197, 94, 0.1);
    color: #16a34a;
}

.edit-user-status-pending {
    background: rgba(234, 179, 8, 0.1);
    color: #ca8a04;
}

.edit-user-status-sold {
    background: rgba(59, 130, 246, 0.1);
    color: #2563eb;
}

.edit-user-status-expired,
.edit-user-status-inactive {
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
}

/* Button Icon Style */
.btn-icon-sm {
    padding: 0.375rem;
    min-width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius);
    border: none;
    cursor: pointer;
    background: transparent;
    color: var(--text-secondary);
    transition: all 0.2s ease;
}

.btn-icon-sm:hover {
    background: var(--bg-secondary);
    color: var(--primary-color);
}

.btn-icon-sm.btn-danger:hover {
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
}

/* Form row for edit modals */
.edit-user-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

@media (max-width: 768px) {
    .edit-user-form-row {
        grid-template-columns: 1fr;
    }

    #editUserModal .modal-content {
        max-width: 100%;
    }

    .edit-user-tabs {
        flex-wrap: nowrap;
        overflow-x: auto;
    }

    .edit-user-tab-btn {
        padding: 0.75rem 0.875rem;
        font-size: 0.8rem;
    }
}

/* Form labels should also be clearly visible */
label,
.form-group label,
.form-label {
    color: #1f2937 !important;
}

/* Ensure focus state also has visible text */
input:focus,
select:focus,
textarea:focus {
    color: #1f2937 !important;
    -webkit-text-fill-color: #1f2937 !important;
    caret-color: #1f2937 !important;
    outline-color: #4a6741 !important;
}

/* =============================================================================
   Equipment section host (index.html) — layout bridge with main shell
   Uses assets/css/equipment-dashboard.css for dashboard chrome.
   ============================================================================= */

#equipment.equipment-page-section {
    padding: 0;
    margin: 0;
    background: transparent;
}

.equipment-dashboard-host {
    width: 100%;
    box-sizing: border-box;
    border-radius: var(--radius-lg, 12px);
    background: var(--bg-primary, #fff);
    border: 1px solid var(--border-color, #e5e7eb);
    box-shadow: var(--shadow-sm, 0 1px 2px rgba(0, 0, 0, 0.05));
    overflow: hidden;
    min-height: 220px;
}

.equipment-initial-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2.5rem 1.5rem;
    background: linear-gradient(180deg, rgba(74, 103, 65, 0.06) 0%, transparent 100%);
}

.equipment-initial-loading-inner {
    text-align: center;
    max-width: 360px;
}

.equipment-initial-loading-icon {
    color: var(--primary-color, #4a6741);
    margin-bottom: 1rem;
    opacity: 0.85;
}

.equipment-initial-title {
    margin: 0 0 0.35rem;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text-primary, #1f2937);
}

.equipment-initial-loading-text p {
    margin: 0;
    color: var(--text-secondary, #6b7280);
    font-size: 0.95rem;
}

.equipment-initial-progress {
    margin-top: 1.25rem;
    height: 4px;
    border-radius: 999px;
    background: var(--bg-secondary, #e5e7eb);
    overflow: hidden;
}

.equipment-initial-progress-bar {
    display: block;
    width: 40%;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #4a6741, #7a9b71);
    animation: equipment-host-shimmer 1.2s ease-in-out infinite alternate;
}

@keyframes equipment-host-shimmer {
    from {
        transform: translateX(-20%);
        opacity: 0.7;
    }
    to {
        transform: translateX(120%);
        opacity: 1;
    }
}

/* ========== Post-login Welcome Loader ========== */
html.welcome-loading .sidebar,
html.welcome-loading .main-content,
html.welcome-loading #impersonationBanner {
    visibility: hidden;
}

.welcome-loader-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 20000;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    background: linear-gradient(145deg, #1a3a2f 0%, #2d5a47 40%, #4a6741 100%);
    transition: opacity 0.45s ease, visibility 0.45s ease;
}

html.welcome-loading .welcome-loader-overlay {
    display: flex !important;
}

.welcome-loader-overlay.welcome-loader--done {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

.welcome-loader-card {
    width: min(480px, 100%);
    text-align: center;
    padding: 2.5rem 2rem 2rem;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.97);
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.28);
    border: 1px solid rgba(255, 255, 255, 0.35);
    animation: welcome-loader-in 0.5s ease;
}

@keyframes welcome-loader-in {
    from {
        opacity: 0;
        transform: translateY(16px) scale(0.98);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.welcome-loader-brand {
    margin-bottom: 1.5rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 0.75rem;
}

.welcome-loader-logo {
    height: clamp(120px, 22vw, 160px);
    width: auto;
    max-width: min(320px, 88vw);
    object-fit: contain;
    background: #ffffff;
    padding: 18px 28px;
    border-radius: 14px;
    box-shadow: 0 4px 14px rgba(61, 40, 23, 0.12);
}

.welcome-loader-system-name {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 700;
    color: #4a6741;
    letter-spacing: 0.01em;
}

/* Admin organization switcher + grouped dashboard sections */
.admin-org-switcher {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-right: 0.75rem;
}

.admin-org-switcher-label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary, #6b5d4f);
    white-space: nowrap;
}

.admin-org-switcher-select {
    min-width: 190px;
    max-width: 240px;
    padding: 0.45rem 0.75rem;
    border: 1px solid var(--border-color, #cdc5b8);
    border-radius: 999px;
    background: #fff;
    color: var(--text-primary, #3d2817);
    font-size: 0.8125rem;
    font-weight: 600;
}

.admin-org-scope-banner {
    margin: 0 0 0.75rem;
    padding: 0.65rem 0.85rem;
    border-radius: 10px;
    background: #ecfdf5;
    border: 1px solid #a7f3d0;
    color: #065f46;
    font-size: 0.8125rem;
    line-height: 1.45;
}

.admin-org-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin: 1.5rem 0 0.85rem;
    padding: 0.85rem 1rem;
    border-radius: 12px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
}

.admin-org-section-header:first-child {
    margin-top: 0;
}

.admin-org-section-header h3 {
    margin: 0 0 0.15rem;
    font-size: 1rem;
    color: #0f172a;
}

.admin-org-section-header p {
    margin: 0;
    font-size: 0.8125rem;
    color: #64748b;
}

.admin-org-badge,
.admin-org-inline-label,
.org-scope-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 600;
    line-height: 1.2;
    background: #ecfeff;
    color: #0e7490;
    border: 1px solid #67e8f9;
    vertical-align: middle;
}

.admin-org-inline-label {
    margin-left: 0.35rem;
}

.admin-org-section-body {
    margin-bottom: 1rem;
}

.admin-org-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
}

.welcome-loader-greeting {
    margin: 0 0 0.35rem;
    font-size: 0.95rem;
    font-weight: 600;
    color: #4a6741;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.welcome-loader-name {
    margin: 0 0 0.5rem;
    font-size: clamp(1.75rem, 5vw, 2.15rem);
    font-weight: 800;
    color: #1f2937;
    line-height: 1.15;
}

.welcome-loader-subtitle {
    margin: 0 0 1.5rem;
    font-size: 0.9rem;
    color: #6b7280;
}

.welcome-loader-progress-track {
    height: 8px;
    border-radius: 999px;
    background: #e5e7eb;
    overflow: hidden;
    margin-bottom: 0.65rem;
}

.welcome-loader-progress-fill {
    height: 100%;
    width: 0%;
    border-radius: 999px;
    background: linear-gradient(90deg, #4a6741, #6b8f5e, #10b981);
    transition: width 0.35s ease;
    box-shadow: 0 0 12px rgba(16, 185, 129, 0.35);
}

.welcome-loader-progress-meta {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 0.78rem;
}

.welcome-loader-percent {
    font-weight: 700;
    color: #4a6741;
}

/* ========== CEO Dashboard — Visits & Partner Cards ========== */
#ceo_dashboard .ceo-visits-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.25rem;
}

#ceo_dashboard .ceo-visits-subtitle {
    margin: 0.35rem 0 0;
    color: #6b7280;
    font-size: 0.875rem;
}

#ceo_dashboard .ceo-visit-stats {
    margin-bottom: 1rem;
}

#ceo_dashboard .ceo-visit-filters {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 0.75rem;
    margin-bottom: 1rem;
}

#ceo_dashboard .ceo-visit-filters select,
#ceo_dashboard .ceo-visit-filters input {
    width: 100%;
    padding: 0.65rem 0.75rem;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    font-size: 0.875rem;
    background: #fff;
}

#ceo_dashboard .ceo-visits-list {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

#ceo_dashboard .ceo-visit-card {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.1rem;
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    background: linear-gradient(180deg, #ffffff 0%, #f9fafb 100%);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

#ceo_dashboard .ceo-visit-card:hover {
    border-color: #c7d2fe;
    box-shadow: 0 8px 24px rgba(59, 130, 246, 0.08);
}

#ceo_dashboard .ceo-visit-card-main {
    flex: 1;
    min-width: 0;
}

#ceo_dashboard .ceo-visit-card-top {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    align-items: flex-start;
    margin-bottom: 0.5rem;
}

#ceo_dashboard .ceo-visit-card-top h4 {
    margin: 0;
    font-size: 1rem;
    color: #111827;
}

#ceo_dashboard .ceo-visit-officer {
    margin: 0.25rem 0 0;
    font-size: 0.8125rem;
    color: #6b7280;
}

#ceo_dashboard .ceo-visit-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem 1rem;
    margin-bottom: 0.5rem;
    font-size: 0.8125rem;
    color: #4b5563;
}

#ceo_dashboard .ceo-visit-notes-preview {
    margin: 0;
    font-size: 0.875rem;
    color: #374151;
    line-height: 1.5;
}

#ceo_dashboard .ceo-visit-comment-count {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-top: 0.65rem;
    font-size: 0.75rem;
    font-weight: 600;
    color: #7c3aed;
}

#ceo_dashboard .ceo-visit-card-actions {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

#ceo_dashboard .ceo-visits-empty {
    text-align: center;
    padding: 2.5rem 1rem;
    color: #6b7280;
}

#ceo_dashboard .ceo-visits-empty i {
    font-size: 2rem;
    color: #9ca3af;
    margin-bottom: 0.75rem;
}

#ceo_dashboard .ceo-visits-empty p {
    margin: 0 0 0.35rem;
    font-weight: 600;
    color: #374151;
}

#ceo_dashboard .ceo-partner-card {
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
    border: 1px solid transparent;
}

#ceo_dashboard .ceo-partner-card:hover,
#ceo_dashboard .ceo-partner-card:focus {
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.12);
    border-color: rgba(59, 130, 246, 0.25);
    outline: none;
}

#ceo_dashboard .ceo-partner-card-action {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-top: 0.5rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: #2563eb;
}

.ceo-partner-dashboard .ceo-partner-kpis {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 0.75rem;
    margin-bottom: 1.25rem;
}

.ceo-partner-dashboard .ceo-partner-kpi {
    padding: 0.85rem 1rem;
    border-radius: 12px;
    background: #f8fafc;
    border: 1px solid #e5e7eb;
}

.ceo-partner-dashboard .ceo-partner-kpi span {
    display: block;
    font-size: 0.75rem;
    color: #6b7280;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 0.25rem;
}

.ceo-partner-dashboard .ceo-partner-kpi strong {
    font-size: 1.25rem;
    color: #111827;
}

.ceo-partner-dashboard .ceo-partner-section {
    margin-bottom: 1.25rem;
}

.ceo-partner-dashboard .ceo-partner-section h4 {
    margin: 0 0 0.75rem;
    font-size: 0.95rem;
    color: #111827;
}

.ceo-partner-dashboard .ceo-partner-empty,
.ceo-partner-dashboard .ceo-partner-hint {
    margin: 0;
    color: #6b7280;
    font-size: 0.875rem;
}

.fo-chief-oversight-toolbar,
.chief-rec-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin: 0 0 1.25rem;
    padding: 1rem 1.1rem;
    border-radius: 14px;
    background: linear-gradient(135deg, #ecfdf5 0%, #f0fdfa 100%);
    border: 1px solid #99f6e4;
}

.fo-chief-oversight-copy {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.fo-chief-oversight-copy strong {
    color: #115e59;
}

.fo-chief-oversight-copy span,
.chief-rec-toolbar label {
    color: #0f766e;
    font-size: 0.875rem;
}

.fo-chief-oversight-controls,
.chief-rec-toolbar .filter-group {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.chief-rec-toolbar:not([hidden]) {
    display: flex;
}

#chief-field-officer-dashboard .cfo-overview-hero {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.5rem;
    margin-bottom: 1.5rem;
    padding: 1.75rem 2rem;
    border-radius: 18px;
    background: linear-gradient(135deg, #064e3b 0%, #0d9488 55%, #14b8a6 100%);
    color: #ecfdf5;
    box-shadow: 0 12px 32px rgba(6, 78, 59, 0.22);
}

#chief-field-officer-dashboard .cfo-overview-hero-main h2 {
    margin: 0.35rem 0 0.65rem;
    font-size: 1.65rem;
    color: #fff;
}

#chief-field-officer-dashboard .cfo-overview-hero-main p {
    margin: 0;
    max-width: 42rem;
    color: rgba(236, 253, 245, 0.88);
    line-height: 1.55;
}

#chief-field-officer-dashboard .cfo-overview-eyebrow {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(236, 253, 245, 0.75);
}

#chief-field-officer-dashboard .cfo-overview-quick-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

#chief-field-officer-dashboard .cfo-quick-action {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.65rem 1rem;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s ease, transform 0.2s ease;
}

#chief-field-officer-dashboard .cfo-quick-action:hover {
    background: rgba(255, 255, 255, 0.2);
    transform: translateY(-1px);
}

#chief-field-officer-dashboard .cfo-overview-stats {
    margin-bottom: 1.5rem;
}

#chief-field-officer-dashboard .cfo-stat-card {
    border: none;
    overflow: hidden;
    position: relative;
}

#chief-field-officer-dashboard .cfo-stat-card::before {
    content: '';
    position: absolute;
    inset: 0 auto 0 0;
    width: 4px;
    background: var(--cfo-stat-accent, #16a34a);
}

#chief-field-officer-dashboard .cfo-stat-pending { --cfo-stat-accent: #f59e0b; }
#chief-field-officer-dashboard .cfo-stat-approved { --cfo-stat-accent: #16a34a; }
#chief-field-officer-dashboard .cfo-stat-officers { --cfo-stat-accent: #0d9488; }
#chief-field-officer-dashboard .cfo-stat-farmers { --cfo-stat-accent: #6366f1; }

#chief-field-officer-dashboard .cfo-stat-card .stat-icon {
    background: color-mix(in srgb, var(--cfo-stat-accent, #16a34a) 14%, transparent);
    color: var(--cfo-stat-accent, #16a34a);
}

#chief-field-officer-dashboard .cfo-overview-card-accent {
    border-color: rgba(245, 158, 11, 0.25);
    background: linear-gradient(180deg, rgba(255, 251, 235, 0.65) 0%, var(--bg-primary) 100%);
}

#chief-field-officer-dashboard .cfo-overview-empty-state {
    text-align: center;
    padding: 1.75rem 1rem;
    color: var(--text-secondary);
}

#chief-field-officer-dashboard .cfo-overview-empty-state i {
    display: block;
    font-size: 1.75rem;
    margin-bottom: 0.65rem;
    opacity: 0.45;
}

#chief-field-officer-dashboard .cfo-overview-empty-state p {
    margin: 0;
    font-size: 0.9rem;
}

#chief-field-officer-dashboard .cfo-overview-list-leading {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    min-width: 0;
}

#chief-field-officer-dashboard .cfo-overview-icon {
    width: 38px;
    height: 38px;
    border-radius: 11px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

#chief-field-officer-dashboard .cfo-overview-icon-warning {
    background: #fef3c7;
    color: #d97706;
}

#chief-field-officer-dashboard .cfo-overview-icon-visit {
    background: #dbeafe;
    color: #2563eb;
}

#chief-field-officer-dashboard .cfo-overview-list-item-clickable {
    cursor: pointer;
    border-radius: 10px;
    margin: 0 -0.35rem;
    padding-left: 0.35rem;
    padding-right: 0.35rem;
    transition: background 0.15s ease;
}

#chief-field-officer-dashboard .cfo-overview-list-item-clickable:hover {
    background: var(--bg-secondary);
}

#chief-field-officer-dashboard .cfo-overview-officer-chip-clickable {
    cursor: pointer;
    border-radius: 10px;
    margin: 0 -0.35rem;
    padding-left: 0.35rem;
    padding-right: 0.35rem;
    transition: background 0.15s ease;
}

#chief-field-officer-dashboard .cfo-overview-officer-chip-clickable:hover {
    background: var(--bg-secondary);
}

#chief-field-officer-dashboard .cfo-overview-chevron {
    margin-left: auto;
    color: var(--text-secondary);
    font-size: 0.75rem;
}

#chief-field-officer-dashboard .cfo-assignment-headline {
    margin-bottom: 0.85rem;
}

#chief-field-officer-dashboard .cfo-assignment-headline strong {
    display: block;
    font-size: 2rem;
    line-height: 1.1;
    color: #16a34a;
}

#chief-field-officer-dashboard .cfo-assignment-headline span {
    color: var(--text-secondary);
    font-size: 0.875rem;
}

#chief-field-officer-dashboard .cfo-overview-visit-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.25rem;
    flex-shrink: 0;
}

#chief-field-officer-dashboard .cfo-overview-visit-meta small {
    color: var(--text-secondary);
    font-size: 0.75rem;
}

#chief-field-officer-dashboard .cfo-overview-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.25rem;
}

#chief-field-officer-dashboard .cfo-overview-card-wide {
    grid-column: 1 / -1;
}

#chief-field-officer-dashboard .cfo-overview-card .card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

#chief-field-officer-dashboard .cfo-overview-card .card-header h3 {
    margin: 0;
    font-size: 1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

#chief-field-officer-dashboard .cfo-overview-list-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.85rem 0;
    border-bottom: 1px solid var(--border-color);
}

#chief-field-officer-dashboard .cfo-overview-list-item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

#chief-field-officer-dashboard .cfo-overview-list-item strong {
    display: block;
    color: var(--text-primary);
}

#chief-field-officer-dashboard .cfo-overview-list-item span,
#chief-field-officer-dashboard .cfo-overview-empty {
    color: var(--text-secondary);
    font-size: 0.875rem;
}

#chief-field-officer-dashboard .cfo-overview-officer-chip {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--border-color);
}

#chief-field-officer-dashboard .cfo-overview-officer-chip:last-child {
    border-bottom: none;
}

#chief-field-officer-dashboard .cfo-overview-officer-avatar {
    width: 42px;
    height: 42px;
    border-radius: 12px;
    background: #0d948820;
    color: #0d9488;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
}

#chief-field-officer-dashboard .cfo-assignment-bar {
    height: 10px;
    border-radius: 999px;
    background: #e5e7eb;
    overflow: hidden;
    margin-bottom: 1rem;
}

#chief-field-officer-dashboard .cfo-assignment-bar-fill {
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #16a34a, #0d9488);
}

#chief-field-officer-dashboard .cfo-assignment-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

#chief-field-officer-dashboard .cfo-assignment-stats div {
    text-align: center;
}

#chief-field-officer-dashboard .cfo-assignment-stats strong {
    display: block;
    font-size: 1.35rem;
}

#chief-field-officer-dashboard .cfo-farmers-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1.25rem;
}

#chief-field-officer-dashboard .cfo-mini-stat {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    padding: 1rem;
    text-align: center;
}

#chief-field-officer-dashboard .cfo-mini-stat-value {
    display: block;
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--text-primary);
}

#chief-field-officer-dashboard .cfo-mini-stat-label {
    display: block;
    margin-top: 0.25rem;
    font-size: 0.8rem;
    color: var(--text-secondary);
}

#chief-field-officer-dashboard .chief-farmers-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.25rem;
}

#chief-field-officer-dashboard .chief-farmer-card {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 1.1rem;
    box-shadow: var(--shadow);
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

#chief-field-officer-dashboard .chief-farmer-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
    border-color: rgba(22, 163, 74, 0.35);
}

#chief-field-officer-dashboard .chief-farmer-card-header {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
    margin-bottom: 1rem;
}

#chief-field-officer-dashboard .chief-farmer-card-avatar {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    background: #16a34a20;
    color: #16a34a;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    flex-shrink: 0;
}

#chief-field-officer-dashboard .chief-farmer-card-identity {
    flex: 1;
    min-width: 0;
}

#chief-field-officer-dashboard .chief-farmer-card-identity h4 {
    margin: 0 0 0.2rem;
    font-size: 1rem;
}

#chief-field-officer-dashboard .chief-farmer-card-email {
    display: block;
    color: var(--text-secondary);
    font-size: 0.82rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#chief-field-officer-dashboard .chief-farmer-status {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    padding: 0.25rem 0.55rem;
    border-radius: 999px;
}

#chief-field-officer-dashboard .chief-farmer-status.active {
    background: #dcfce7;
    color: #166534;
}

#chief-field-officer-dashboard .chief-farmer-status.inactive {
    background: #fee2e2;
    color: #991b1b;
}

#chief-field-officer-dashboard .chief-farmer-meta-row {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    color: var(--text-secondary);
    font-size: 0.875rem;
    margin-bottom: 0.55rem;
}

#chief-field-officer-dashboard .chief-farmer-meta-row i {
    width: 16px;
    color: #16a34a;
}

#chief-field-officer-dashboard .chief-farmer-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
}

#chief-field-officer-dashboard .chief-farmer-assignment-badge {
    font-size: 0.75rem;
    font-weight: 700;
    padding: 0.3rem 0.65rem;
    border-radius: 999px;
}

#chief-field-officer-dashboard .chief-farmer-assignment-badge.assigned {
    background: #dcfce7;
    color: #166534;
}

#chief-field-officer-dashboard .chief-farmer-assignment-badge.unassigned {
    background: #ffedd5;
    color: #c2410c;
}

#chief-field-officer-dashboard .chief-cards-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 3rem 1rem;
    color: var(--text-secondary);
}

#chief-field-officer-dashboard .chief-cards-empty i {
    font-size: 2rem;
    margin-bottom: 0.75rem;
    opacity: 0.6;
}

@media (max-width: 900px) {
    #chief-field-officer-dashboard .cfo-overview-grid,
    #chief-field-officer-dashboard .cfo-farmers-stats {
        grid-template-columns: 1fr;
    }

    #chief-field-officer-dashboard .cfo-overview-hero {
        padding: 1.35rem 1.25rem;
    }
}

/* CFO farmer details dashboard modal */
.cfo-farmer-modal.fo-modal-wide .modal-content {
    max-width: 980px;
    width: min(980px, calc(100vw - 2rem));
}

.cfo-farmer-dashboard {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.cfo-farmer-dash-header {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border-color);
}

.cfo-farmer-dash-avatar {
    width: 72px;
    height: 72px;
    border-radius: 18px;
    background: #16a34a20;
    color: #16a34a;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    font-weight: 700;
    flex-shrink: 0;
}

.cfo-farmer-dash-identity {
    flex: 1;
    min-width: 0;
}

.cfo-farmer-dash-identity h3 {
    margin: 0 0 0.35rem;
    font-size: 1.35rem;
}

.cfo-farmer-dash-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem 1.25rem;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.cfo-farmer-dash-meta span {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.cfo-farmer-dash-assignment {
    margin-top: 0.65rem;
}

.cfo-farmer-dash-stats {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 0.75rem;
}

.cfo-farmer-dash-stat {
    text-align: center;
    padding: 0.85rem 0.5rem;
    border-radius: 12px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
}

.cfo-farmer-dash-stat strong {
    display: block;
    font-size: 1.35rem;
    color: var(--text-primary);
}

.cfo-farmer-dash-stat span {
    display: block;
    margin-top: 0.2rem;
    font-size: 0.72rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.cfo-farmer-dash-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    padding-bottom: 0.25rem;
    border-bottom: 1px solid var(--border-color);
}

.cfo-farmer-dash-tab {
    border: 1px solid transparent;
    background: transparent;
    color: var(--text-secondary);
    padding: 0.55rem 0.85rem;
    border-radius: 999px;
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.cfo-farmer-dash-tab:hover {
    background: var(--bg-secondary);
    color: var(--text-primary);
}

.cfo-farmer-dash-tab.active {
    background: #ecfdf5;
    border-color: #6ee7b7;
    color: #047857;
}

.cfo-farmer-dash-panel {
    min-height: 220px;
}

.cfo-farmer-dash-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.cfo-farmer-dash-card {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    padding: 1rem;
}

.cfo-farmer-dash-card h4 {
    margin: 0 0 0.75rem;
    font-size: 0.95rem;
    display: flex;
    align-items: center;
    gap: 0.45rem;
}

.cfo-farmer-dash-card h4 i {
    color: #16a34a;
}

.cfo-farmer-asset-list {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.cfo-farmer-asset-item {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 0.85rem 1rem;
}

.cfo-farmer-asset-item-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.35rem;
}

.cfo-farmer-asset-item-header strong {
    color: var(--text-primary);
}

.cfo-farmer-asset-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
    font-size: 0.82rem;
    color: var(--text-secondary);
}

.cfo-farmer-asset-note {
    margin-top: 0.65rem;
    padding-top: 0.65rem;
    border-top: 1px dashed var(--border-color);
    font-size: 0.85rem;
    color: var(--text-secondary);
    line-height: 1.5;
}

.cfo-farmer-note-feed {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.cfo-farmer-note-item {
    border: 1px solid var(--border-color);
    border-left: 4px solid #2563eb;
    border-radius: 12px;
    padding: 0.9rem 1rem;
    background: var(--bg-primary);
}

.cfo-farmer-note-item.cfo-farmer-note-visit { border-left-color: #0d9488; }
.cfo-farmer-note-item.cfo-farmer-note-crop { border-left-color: #16a34a; }
.cfo-farmer-note-item.cfo-farmer-note-field { border-left-color: #ca8a04; }
.cfo-farmer-note-item.cfo-farmer-note-livestock { border-left-color: #ea580c; }
.cfo-farmer-note-item.cfo-farmer-note-equipment { border-left-color: #6366f1; }

.cfo-farmer-note-head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.45rem;
}

.cfo-farmer-note-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.cfo-farmer-note-badge {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    background: #eff6ff;
    color: #1d4ed8;
}

.cfo-farmer-note-badge.visit { background: #ecfdf5; color: #047857; }
.cfo-farmer-note-badge.crop { background: #dcfce7; color: #166534; }
.cfo-farmer-note-badge.field { background: #fef9c3; color: #a16207; }
.cfo-farmer-note-badge.livestock { background: #ffedd5; color: #c2410c; }
.cfo-farmer-note-badge.equipment { background: #eef2ff; color: #4338ca; }

.cfo-farmer-note-meta {
    font-size: 0.78rem;
    color: var(--text-secondary);
}

.cfo-farmer-note-body {
    margin: 0;
    color: var(--text-primary);
    line-height: 1.55;
    font-size: 0.9rem;
}

.cfo-farmer-dash-empty {
    text-align: center;
    padding: 2.5rem 1rem;
    color: var(--text-secondary);
}

.cfo-farmer-dash-empty i {
    font-size: 2rem;
    opacity: 0.35;
    margin-bottom: 0.75rem;
}

.cfo-farmer-dash-empty h4 {
    margin: 0 0 0.35rem;
    color: var(--text-primary);
}

.cfo-farmer-dash-empty p {
    margin: 0;
    font-size: 0.9rem;
}

.cfo-farmer-dash-footer {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    padding-top: 0.5rem;
    border-top: 1px solid var(--border-color);
}

.cfo-farmer-dash-loading {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--text-secondary);
}

.cfo-farmer-dash-loading i {
    font-size: 1.75rem;
    margin-bottom: 0.75rem;
    color: #0d9488;
}

@media (max-width: 900px) {
    .cfo-farmer-dash-stats {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .cfo-farmer-dash-grid {
        grid-template-columns: 1fr;
    }
}
