/* Swiss Minimalism Design System for Business & Clients Flow */
:root {
    /* Refined Brand & Accent Colors - Muted for Premium SaaS */
    --primary-blue: #2563EB; /* modern digital blue, lower saturation */
    --primary-blue-hover: #3B82F6; /* lighter blue hover */
    --accent-yellow: #E2E8F0; /* neutral color for active navigation backgrounds */
    --accent-yellow-brand: #F59E0B; /* warm amber for selected highlights */
    --bg-base: #F4F6FA; /* soft gray-blue/off-white background */
    --bg-surface: #FFFFFF;
    --bg-table-header: #F8FAFC;
    --text-primary: #101828; /* Midnight Navy */
    --text-secondary: #475569; /* Slate 600 */
    --text-muted: #94A3B8; /* Slate 400 */
    --border-color: #E5E7EB; /* Light Gray */
    
    /* Primary Accent Text */
    --primary-blue-text: var(--primary-blue);

    /* Sidebar Navigation Tokens (Light Mode - Pale Blue Sidebar) */
    --sidebar-bg: #F0F4F8; /* soft pale navy/blue-gray */
    --sidebar-text: #475569; /* Slate 600 */
    --sidebar-text-hover: #101828; /* Midnight Navy */
    --sidebar-text-muted: #94A3B8; /* Slate 400 */
    --sidebar-border: 1px solid #E2E8F0;
    --sidebar-active-bg: rgba(37, 99, 235, 0.08); /* soft blue highlight */
    --sidebar-active-text: var(--primary-blue);
    --sidebar-active-border: rgba(37, 99, 235, 0.1);
    --sidebar-active-shadow: none;
    --sidebar-active-icon: var(--primary-blue);
    --sidebar-logo-sub: #64748B;

    /* Button Tokens (Light Mode) */
    --btn-primary-bg: var(--primary-blue);
    --btn-primary-hover: var(--primary-blue-hover);
    --btn-primary-text: #FFFFFF;
    --btn-secondary-bg: var(--bg-surface);
    --btn-secondary-border: var(--border-color);
    --btn-secondary-text: var(--text-secondary);
    --btn-secondary-hover: var(--bg-base);

    /* Payment Status Chips (Light Mode) */
    --chip-no-deposit-bg: #F3F4F6;
    --chip-no-deposit-text: #6B7280;
    --chip-no-deposit-dot: #9CA3AF;
    --chip-overdue-border: #FCA5A5;

    --chip-deposited-50-bg: #EFF6FF;
    --chip-deposited-50-text: #1E40AF;
    --chip-deposited-50-dot: #3B82F6;

    --chip-partial-paid-bg: #FFFBEB;
    --chip-partial-paid-text: #92400E;
    --chip-partial-paid-dot: #F59E0B;

    --chip-paid-bg: #ECFDF5;
    --chip-paid-text: #065F46;
    --chip-paid-dot: #10B981;

    --chip-overdue-bg: #FEF2F2;
    --chip-overdue-text: #991B1B;
    --chip-overdue-dot: #EF4444;

    /* Deal Stage Badges (Light Mode) */
    --badge-discovery-bg: #EEF2F6;
    --badge-discovery-text: #6366F1;
    --badge-discovery-border: #E2E8F0;

    --badge-proposal-bg: #FFFBEB;
    --badge-proposal-text: #D97706;
    --badge-proposal-border: #FEF3C7;

    --badge-negotiation-bg: #F5F3FF;
    --badge-negotiation-text: #7C3AED;
    --badge-negotiation-border: #EDE9FE;

    --badge-won-bg: #ECFEFF;
    --badge-won-text: #0891B2;
    --badge-won-border: #CFFAFE;

    --badge-in-production-bg: #EFF6FF;
    --badge-in-production-text: #1D4ED8;
    --badge-in-production-border: #DBEAFE;

    --badge-review-bg: #FDF2F8;
    --badge-review-text: #BE185D;
    --badge-review-border: #FCE7F3;

    --badge-delivered-bg: var(--success-bg);
    --badge-delivered-text: var(--success);
    --badge-delivered-border: #D1FADF;

    /* Semantic Colors - Muted for Premium SaaS Aesthetic */
    --success: #137333; /* Muted Green */
    --success-bg: #E6F4EA;
    --warning: #B06000; /* Muted Amber */
    --warning-bg: #FEF7E0;
    --danger: #C5221F; /* Muted Red */
    --danger-bg: #FCE8E6;
    --info: #1A73E8; /* Muted Blue */
    --info-bg: #E8F0FE;
    
    /* Layout Tokens */
    --sidebar-width: 260px;
    --radius-lg: 16px;
    --radius-md: 12px;
    --radius-sm: 8px; /* unified interactive radius */
    --transition-smooth: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    
    /* Fine-tuned, soft SaaS shadow scale */
    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.03), 0 1px 1px -1px rgba(0, 0, 0, 0.02);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.04), 0 2px 4px -2px rgba(0, 0, 0, 0.03);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.04), 0 4px 6px -4px rgba(0, 0, 0, 0.03);

    /* Footer Banner variables (Light Mode) */
    --footer-bg: linear-gradient(90deg, #EFF6FF 0%, #DBEAFE 100%);
    --footer-text: #1E3A8A;
    --footer-accent: #2563EB;
    --footer-border: #BFDBFE;
}

/* Dark Mode Overrides */
[data-theme="dark"] {
    --bg-base: #0B0F19; /* deep navy base */
    --bg-surface: #0F172A; /* soft charcoal-navy surface */
    --bg-table-header: #1E293B; /* Slate 800 */
    --text-primary: #F8FAFC; /* Slate 50 */
    --text-secondary: #CBD5E1; /* Slate 300 - AAA contrast */
    --text-muted: #94A3B8; /* Slate 400 - AA contrast */
    --border-color: #1E293B; /* Slate 800 */
    
    /* Primary Accent Text */
    --primary-blue-text: #60A5FA;

    /* Sidebar Navigation Tokens (Dark Mode - Deeper Navy-Black) */
    --sidebar-bg: #06080F; /* dark navy-black for layout separation */
    --sidebar-text: #94A3B8; /* Slate 400 */
    --sidebar-text-hover: #F8FAFC; /* Slate 50 */
    --sidebar-text-muted: #475569; /* Slate 600 */
    --sidebar-border: 1px solid rgba(255, 255, 255, 0.05);
    --sidebar-active-bg: rgba(255, 255, 255, 0.05); /* translucent */
    --sidebar-active-text: #FFFFFF;
    --sidebar-active-border: rgba(255, 255, 255, 0.08);
    --sidebar-active-shadow: 0 0 10px rgba(59, 130, 246, 0.15); /* subtle navy glow */
    --sidebar-active-icon: #60A5FA;
    --sidebar-logo-sub: rgba(255, 255, 255, 0.4);

    /* Button Tokens (Dark Mode) */
    --btn-primary-bg: var(--primary-blue);
    --btn-primary-hover: var(--primary-blue-hover);
    --btn-primary-text: #FFFFFF;
    --btn-secondary-bg: var(--bg-surface);
    --btn-secondary-border: var(--border-color);
    --btn-secondary-text: var(--text-secondary);
    --btn-secondary-hover: var(--bg-base);

    /* Payment Status Chips (Dark Mode) */
    --chip-no-deposit-bg: #1E293B;
    --chip-no-deposit-text: #CBD5E1; /* Slate 300 - AAA contrast (8.8:1) */
    --chip-no-deposit-dot: #94A3B8;
    --chip-overdue-border: rgba(239, 68, 68, 0.3);

    --chip-deposited-50-bg: rgba(59, 130, 246, 0.15);
    --chip-deposited-50-text: #93C5FD; /* Light Blue - AAA contrast */
    --chip-deposited-50-dot: #3B82F6;

    --chip-partial-paid-bg: rgba(245, 158, 11, 0.15);
    --chip-partial-paid-text: #FDE047; /* Warm Yellow - AAA contrast */
    --chip-partial-paid-dot: #F59E0B;

    --chip-paid-bg: rgba(16, 185, 129, 0.15);
    --chip-paid-text: #34D399; /* Mint Green - AAA contrast */
    --chip-paid-dot: #10B981;

    --chip-overdue-bg: rgba(239, 68, 68, 0.15);
    --chip-overdue-text: #FCA5A5; /* Light Red - AAA contrast */
    --chip-overdue-dot: #F87171;

    /* Deal Stage Badges (Dark Mode) */
    --badge-discovery-bg: rgba(99, 102, 241, 0.15);
    --badge-discovery-text: #C7D2FE; /* Lavender Indigo - AAA contrast (9.3:1) */
    --badge-discovery-border: rgba(99, 102, 241, 0.3);

    --badge-proposal-bg: rgba(217, 119, 6, 0.15);
    --badge-proposal-text: #FBBF24; /* Warm Gold - AAA contrast (7.7:1) */
    --badge-proposal-border: rgba(217, 119, 6, 0.3);

    --badge-negotiation-bg: rgba(124, 58, 237, 0.15);
    --badge-negotiation-text: #E9D5FF; /* Soft Purple - AAA contrast (9.3:1) */
    --badge-negotiation-border: rgba(124, 58, 237, 0.3);

    --badge-won-bg: rgba(6, 182, 212, 0.15);
    --badge-won-text: #22D3EE; /* Soft Cyan - AAA contrast (7.7:1) */
    --badge-won-border: rgba(6, 182, 212, 0.3);

    --badge-in-production-bg: rgba(59, 130, 246, 0.15);
    --badge-in-production-text: #93C5FD; /* Soft Sky Blue - AAA contrast (9.88:1) */
    --badge-in-production-border: rgba(59, 130, 246, 0.3);

    --badge-review-bg: rgba(236, 72, 153, 0.15);
    --badge-review-text: #FBCFE8; /* Soft Pink - AAA contrast (9.3:1) */
    --badge-review-border: rgba(236, 72, 153, 0.3);

    --badge-delivered-bg: rgba(16, 185, 129, 0.15);
    --badge-delivered-text: #34D399; /* Mint Green - AAA contrast (8.37:1) */
    --badge-delivered-border: rgba(16, 185, 129, 0.3);

    /* Semantic Colors for Dark Mode - Muted */
    --success: #34D399;
    --success-bg: rgba(16, 185, 129, 0.1);
    --warning: #FBBF24;
    --warning-bg: rgba(245, 158, 11, 0.1);
    --danger: #F87171;
    --danger-bg: rgba(239, 68, 68, 0.1);
    --info: #22D3EE;
    --info-bg: rgba(6, 182, 212, 0.1);
    
    /* Fine-tuned shadows for dark mode */
    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.3);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.4), 0 2px 4px -2px rgba(0, 0, 0, 0.3);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.5), 0 4px 6px -4px rgba(0, 0, 0, 0.4);

    /* Footer Banner variables (Dark Mode) */
    --footer-bg: linear-gradient(90deg, #1E293B 0%, #0F172A 100%);
    --footer-text: #FFFFFF;
    --footer-accent: #FBBF24;
    --footer-border: rgba(255, 255, 255, 0.05);
}

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

/* Icon System Stroke Consistency */
svg:not(.spark-svg):not(.spark-svg *) {
    stroke-width: 1.5 !important;
}

html, body {
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    overflow: hidden;
}

body {
    font-family: 'Inter', 'Outfit', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    background-color: var(--bg-base);
    color: var(--text-primary);
    display: flex;
    -webkit-font-smoothing: antialiased;
}

/* Custom Scrollbar */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}
::-webkit-scrollbar-track {
    background: transparent;
}
::-webkit-scrollbar-thumb {
    background: rgba(16, 24, 40, 0.08);
    border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
    background: rgba(16, 24, 40, 0.16);
}

/* Main full screen container wrapper */
.glass-container {
    width: 100%;
    height: 100%;
    background: var(--bg-surface);
    display: flex;
    overflow: hidden;
}

/* Sidebar Styling: Premium Operational SaaS Sidebar */
.sidebar {
    width: var(--sidebar-width);
    background: var(--sidebar-bg);
    display: flex;
    flex-direction: column;
    padding: 24px 16px;
    color: var(--sidebar-text);
    border-right: var(--sidebar-border);
    transition: width 0.2s cubic-bezier(0.4, 0, 0.2, 1), padding 0.2s ease, background 0.2s ease;
    overflow-x: hidden;
    flex-shrink: 0;
}

.sidebar.collapsed {
    width: 74px;
    padding: 24px 12px;
}

.sidebar-init-collapsed .sidebar {
    width: 74px;
    padding: 24px 12px;
}

.logo {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 24px;
    padding-bottom: 16px;
    border-bottom: var(--sidebar-border);
    transition: all 0.2s ease;
}

.logo-img {
    height: 36px;
    object-fit: contain;
    background: #FFFFFF;
    border-radius: var(--radius-sm);
    padding: 2px;
    border: 1px solid var(--border-color);
}

.sub-logo {
    font-size: 9px;
    color: var(--sidebar-logo-sub);
    font-weight: 600;
    letter-spacing: 1.5px;
    line-height: 1.2;
}

.menu-container {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    gap: 20px;
    overflow-y: auto;
    padding-right: 4px;
}

.menu-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.menu-group-label {
    font-size: 10px;
    font-weight: 600;
    color: var(--sidebar-text-muted);
    letter-spacing: 1px;
    margin-bottom: 8px;
    padding-left: 12px;
    text-transform: uppercase;
    transition: opacity 0.2s ease;
}

.menu-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 12px;
    color: var(--sidebar-text);
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    border-radius: var(--radius-sm);
    transition: var(--transition-smooth);
    border: 1px solid transparent;
}

.menu-item svg {
    width: 16px;
    height: 16px;
    stroke: currentColor;
    stroke-width: 1.5; /* Muted thin stroke */
    fill: none;
    flex-shrink: 0;
    transition: var(--transition-smooth);
}

.menu-item:hover {
    color: var(--sidebar-text-hover);
    background: var(--sidebar-active-bg);
}

.menu-item.active {
    color: var(--sidebar-active-text);
    background: var(--sidebar-active-bg);
    font-weight: 500;
    box-shadow: var(--sidebar-active-shadow);
    border: 1px solid var(--sidebar-active-border);
}

.menu-item.active svg {
    color: var(--sidebar-active-icon);
}

/* Collapse Toggle Button inside Sidebar */
.collapse-toggle-btn {
    background: transparent;
    border: none;
    color: var(--sidebar-text-muted);
    cursor: pointer;
    padding: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: auto;
    margin-bottom: 8px;
    border-radius: var(--radius-sm);
    transition: var(--transition-smooth);
    outline: none;
}

.collapse-toggle-btn:hover {
    background: var(--sidebar-active-bg);
    color: var(--sidebar-text-hover);
}

.collapse-toggle-btn svg {
    transition: transform 0.2s ease;
}

/* User Card inside Sidebar */
.sidebar-user {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 8px;
    padding-top: 16px;
    border-top: var(--sidebar-border);
    transition: all 0.2s ease;
}

.user-avatar-circle {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--sidebar-active-bg);
    color: var(--sidebar-active-text);
    font-weight: 600;
    font-size: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--sidebar-active-border);
}

.user-meta {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.user-name {
    font-size: 13px;
    font-weight: 600;
    color: var(--sidebar-text-hover);
}

.user-role {
    font-size: 10px;
    color: var(--sidebar-text-muted);
}

.dropdown-chevron {
    font-size: 9px;
    color: var(--sidebar-text-muted);
    cursor: pointer;
}

/* CSS Hiding Rules for Sidebar Collapse Mode */
.sidebar.collapsed .sub-logo,
.sidebar-init-collapsed .sidebar .sub-logo {
    display: none;
}

.sidebar.collapsed .menu-text,
.sidebar-init-collapsed .sidebar .menu-text {
    display: none;
}

.sidebar.collapsed .menu-group-label,
.sidebar-init-collapsed .sidebar .menu-group-label {
    display: none;
}

.sidebar.collapsed .user-meta,
.sidebar-init-collapsed .sidebar .user-meta,
.sidebar.collapsed .dropdown-chevron,
.sidebar-init-collapsed .sidebar .dropdown-chevron {
    display: none;
}

.sidebar.collapsed .sidebar-user,
.sidebar-init-collapsed .sidebar .sidebar-user {
    justify-content: center;
    border-top-color: transparent;
    padding-top: 0;
}

.sidebar.collapsed .logo,
.sidebar-init-collapsed .sidebar .logo {
    justify-content: center;
    border-bottom-color: transparent;
    padding-bottom: 0;
    margin-bottom: 16px;
}

.sidebar.collapsed .collapse-toggle-btn svg,
.sidebar-init-collapsed .sidebar .collapse-toggle-btn svg {
    transform: rotate(180deg);
}

.sidebar.collapsed .collapse-toggle-btn,
.sidebar-init-collapsed .sidebar .collapse-toggle-btn {
    align-self: center;
    margin-top: auto;
}

/* Main Content Area */
.content-area {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    padding: 24px;
    background-color: var(--bg-base);
    overflow-y: auto;
}

/* Top Header */
.top-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 28px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--border-color);
}

.header-title h1 {
    font-size: 20px;
    font-weight: 600;
    letter-spacing: -0.3px;
    color: var(--text-primary);
}

.header-subtitle {
    font-size: 12px;
    color: var(--text-secondary);
    display: block;
    margin-top: 4px;
}

.header-right {
    display: flex;
    align-items: center;
    gap: 16px;
}

.search-bar {
    position: relative;
    width: 280px;
}

.search-icon {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    align-items: center;
    color: var(--text-muted);
    opacity: 0.6; /* subtle opacity */
}

.search-icon svg {
    width: 14px;
    height: 14px;
    stroke: currentColor;
    stroke-width: 1.5; /* consistent stroke weight */
    fill: none;
}

.search-bar input {
    width: 100%;
    background: var(--bg-base); /* soft background */
    border: 1px solid transparent; /* blend naturally */
    border-radius: var(--radius-sm);
    padding: 8px 12px 8px 36px;
    font-family: inherit;
    font-size: 12px;
    outline: none;
    color: var(--text-primary);
    transition: var(--transition-smooth);
}

.search-bar input:focus {
    background: var(--bg-surface);
    border-color: var(--primary-blue);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.08);
}

.search-bar input::placeholder {
    color: var(--text-muted);
    font-size: 11.5px;
}

.notification-bell {
    position: relative;
    cursor: pointer;
    display: flex;
    align-items: center;
    color: var(--text-secondary);
    padding: 8px; /* balanced padding */
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-color);
    background: var(--bg-surface);
    transition: var(--transition-smooth);
}

.notification-bell:hover {
    background: var(--bg-base);
    color: var(--text-primary);
}

.notification-bell svg {
    width: 16px; /* unified icon size */
    height: 16px;
    stroke: currentColor;
    stroke-width: 1.5; /* unified optical stroke weight */
    fill: none;
    opacity: 0.8;
}

.badge-count {
    position: absolute;
    top: -2px; /* adjusted position */
    right: -2px;
    background: var(--primary-blue);
    color: white;
    font-size: 8px;
    font-weight: 700;
    border-radius: 50%;
    width: 12px;
    height: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* User Profile module (Premium SaaS replacement) */
.user-profile-module {
    position: relative;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 6px 12px;
    background: var(--btn-secondary-bg);
    border: 1px solid var(--btn-secondary-border);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: var(--transition-smooth);
    user-select: none;
}

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

.profile-avatar {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--bg-base);
    color: var(--text-primary);
    font-weight: 600;
    font-size: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--border-color);
}

.profile-info {
    display: flex;
    flex-direction: column;
    text-align: left;
}

.profile-name {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-primary);
    line-height: 1.2;
}

.profile-role {
    font-size: 9.5px;
    color: var(--text-muted);
    line-height: 1.2;
    margin-top: 1px;
}

.profile-chevron {
    color: var(--text-muted);
    margin-left: 6px;
    transition: var(--transition-smooth);
}

.user-profile-module:hover .profile-chevron {
    color: var(--text-secondary);
}

.hidden-select-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
    -webkit-appearance: none;
    appearance: none;
}

/* General Card Design */
.card {
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 20px;
    box-shadow: var(--shadow-sm);
    transition: var(--transition-smooth);
}

.card:hover {
    box-shadow: var(--shadow-md);
}

/* Buttons */
.btn {
    padding: 8px 16px;
    border-radius: var(--radius-sm); /* unified border-radius */
    font-family: inherit;
    font-weight: 600;
    font-size: 13px;
    cursor: pointer;
    border: 1px solid transparent;
    transition: var(--transition-smooth);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.btn-primary {
    background: var(--btn-primary-bg);
    color: var(--btn-primary-text);
    box-shadow: var(--shadow-sm);
}

.btn-primary:hover {
    background: var(--btn-primary-hover);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

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

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

/* Theme Toggle Button - matches secondary button visuals */
.theme-toggle-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: var(--btn-secondary-bg);
    border: 1px solid var(--btn-secondary-border);
    border-radius: var(--radius-sm);
    color: var(--text-secondary);
    cursor: pointer;
    transition: var(--transition-smooth);
    padding: 0;
    outline: none;
}

.theme-toggle-btn:hover {
    background: var(--btn-secondary-hover);
    color: var(--text-primary);
    border-color: var(--border-color);
}

.theme-toggle-btn svg {
    width: 16px;
    height: 16px;
    stroke: currentColor;
    stroke-width: 1.5; /* unified optical stroke weight */
    fill: none;
    transition: var(--transition-smooth);
}

.view-header-actions {
    margin-bottom: 18px;
    display: flex;
    justify-content: flex-end;
}

/* Views toggle */
.app-view {
    display: none;
    flex-grow: 1;
    flex-direction: column;
}

.app-view.active {
    display: flex;
}

/* KPI Summary Cards Layout */
.summary-cards {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 24px;
}

.summary-card {
    display: flex;
    flex-direction: column;
}

.kpi-header-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.summary-card h3 {
    font-size: 11px;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.trend-lbl {
    font-size: 11px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 12px;
}

.trend-lbl.up { background: var(--success-bg); color: var(--success); }
.trend-lbl.neutral { background: var(--warning-bg); color: var(--warning); }
.trend-lbl.down { background: var(--danger-bg); color: var(--danger); }

.summary-card .card-value {
    font-size: 20px;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 10px;
}

.kpi-sparkline {
    height: 24px;
    margin-bottom: 8px;
}

.spark-svg {
    width: 100%;
    height: 100%;
}

.card-subtitle {
    font-size: 11px;
    color: var(--text-muted);
}

/* Grid Layouts for Sections */
.grid-two-cols {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 16px;
    margin-bottom: 24px;
}

.grid-three-cols {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 16px;
    margin-bottom: 24px;
}

/* Project Pipeline Flow Chart styles */
.pipeline-card {
    display: flex;
    flex-direction: column;
}

.pipeline-card h3, .activities-card h3, .dashboard-widget h3 {
    font-size: 14px;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 16px;
}

.pipeline-flow {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 20px 0;
    flex-grow: 1;
}

.pipeline-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    position: relative;
    width: 70px;
}

.step-icon {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    margin-bottom: 8px;
}

.step-icon svg {
    width: 18px;
    height: 18px;
    stroke: currentColor;
    stroke-width: 2;
    fill: none;
}

.step-lead { background: #EEF2F6; color: #6366F1; }
.step-meeting { background: #EEF2F6; color: #EC4899; }
.step-quote { background: #EEF2F6; color: #F59E0B; }
.step-won { background: #EEF2F6; color: #10B981; }
.step-prod { background: #EEF2F6; color: #8B5CF6; }
.step-deliv { background: #EEF2F6; color: #3B82F6; }

.step-name {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 2px;
}

.step-num {
    font-size: 13px;
    font-weight: 700;
    color: var(--text-primary);
}

.step-pct {
    font-size: 10px;
    color: var(--text-muted);
}

.pipeline-line {
    flex-grow: 1;
    height: 2px;
    background: #E5E7EB;
    margin-top: -30px;
}

.view-link {
    font-size: 12px;
    color: var(--primary-blue);
    text-decoration: none;
    font-weight: 600;
    margin-top: 10px;
    display: inline-block;
}

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

.card-header-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.card-header-row h3 {
    margin-bottom: 0;
}

.view-link-sm {
    font-size: 11px;
    color: var(--primary-blue);
    text-decoration: none;
    font-weight: 600;
}

/* Recent Activities Widget */
.activity-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.activity-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid #F3F4F6;
}

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

.activity-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    color: white;
    font-weight: 700;
    font-size: 11px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.bg-avatar-1 { background: #3B82F6; }
.bg-avatar-2 { background: #F59E0B; }
.bg-avatar-3 { background: #10B981; }
.bg-avatar-4 { background: #8B5CF6; }

.activity-info {
    flex-grow: 1;
}

.activity-text {
    font-size: 12.5px;
    color: var(--text-primary);
}

.activity-time {
    font-size: 10px;
    color: var(--text-muted);
}

.status-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
}

.status-dot.green { background: var(--success); }
.status-dot.yellow { background: var(--warning); }
.status-dot.blue { background: var(--primary-blue); }

/* Tasks Checklist Widget */
.checklist {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.checklist-item {
    display: flex;
    align-items: center;
    gap: 12px;
    position: relative;
    cursor: pointer;
    user-select: none;
}

.checklist-item input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
}

.checkmark {
    position: relative;
    height: 18px;
    width: 18px;
    background-color: #FFFFFF;
    border: 1px solid var(--border-color);
    border-radius: 50%;
    transition: var(--transition-smooth);
}

.checklist-item input:checked ~ .checkmark {
    background-color: var(--primary-blue);
    border-color: var(--primary-blue);
}

.checkmark:after {
    content: "";
    position: absolute;
    display: none;
    left: 6px;
    top: 3px;
    width: 4px;
    height: 8px;
    border: solid white;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.checklist-item input:checked ~ .checkmark:after {
    display: block;
}

.task-details {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}

.task-title {
    font-size: 12.5px;
    color: var(--text-primary);
}

.checklist-item input:checked ~ .task-details .task-title {
    text-decoration: line-through;
    color: var(--text-muted);
}

.task-time {
    font-size: 10px;
    color: var(--text-muted);
}

.prio-tag {
    font-size: 9px;
    font-weight: 700;
    padding: 1px 6px;
    border-radius: 4px;
    text-transform: uppercase;
}

.prio-tag.high { background: var(--danger-bg); color: var(--danger); }
.prio-tag.med { background: var(--warning-bg); color: var(--warning); }
.prio-tag.low { background: #EEF2F6; color: var(--text-secondary); }

/* Projects In Progress progress lists */
.progress-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.progress-item {
    display: flex;
    align-items: center;
    gap: 12px;
}

.proj-thumb {
    width: 32px;
    height: 32px;
    border-radius: 6px;
    background: #EEF2F6;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
}

.proj-thumb svg {
    width: 16px;
    height: 16px;
    stroke: var(--text-secondary);
    stroke-width: 2;
    fill: none;
}

.proj-info {
    flex-grow: 1;
}

.proj-title-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.proj-name {
    font-size: 12.5px;
    font-weight: 600;
    color: var(--text-primary);
}

.proj-pct-val {
    font-size: 11px;
    font-weight: 700;
    color: var(--text-primary);
}

.proj-stage {
    font-size: 10px;
    color: var(--text-muted);
    display: block;
    margin-bottom: 4px;
}

.progress-bar-bg {
    width: 100%;
    height: 4px;
    background: #EEF2F6;
    border-radius: 2px;
    overflow: hidden;
}

.progress-bar-fill {
    height: 100%;
    background: var(--primary-blue);
    border-radius: 2px;
}

/* Mini Calendar Widget */
.cal-mini {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.cal-month-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 5px;
}

.cal-nav-btn {
    font-size: 10px;
    color: var(--text-muted);
    cursor: pointer;
    padding: 2px;
}

.cal-month-title {
    font-size: 12px;
    font-weight: 700;
    color: var(--text-primary);
}

.cal-days-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    text-align: center;
    font-size: 11px;
    row-gap: 6px;
    margin-bottom: 10px;
}

.cal-days-grid div {
    padding: 2px;
}

.cal-days-grid div.muted {
    color: var(--text-muted);
}

.cal-active {
    background: var(--primary-blue);
    color: white;
    border-radius: 50%;
    font-weight: 700;
}

.cal-events {
    display: flex;
    flex-direction: column;
    gap: 8px;
    border-top: 1px dashed var(--border-color);
    padding-top: 10px;
}

.cal-event-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 11px;
}

.cal-event-dot {
    width: 5px;
    height: 5px;
    border-radius: 50%;
}

.cal-event-dot.blue { background: var(--primary-blue); }
.cal-event-dot.yellow { background: var(--warning); }

.cal-event-meta {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}

.cal-event-title {
    font-weight: 600;
    color: var(--text-primary);
}

.cal-event-time {
    color: var(--text-muted);
    font-size: 9px;
}

.cal-event-loc {
    color: var(--text-muted);
}

/* Footer Banner Card */
.footer-banner-card {
    background: var(--footer-bg);
    border: 1px solid var(--footer-border);
    color: var(--footer-text);
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 24px;
    transition: var(--transition-smooth);
}

.footer-banner-left {
    display: flex;
    align-items: center;
    gap: 16px;
}

.footer-banner-logo {
    height: 48px;
    object-fit: contain;
    background: white;
    padding: 4px;
    border-radius: 8px;
    border: 1px solid var(--border-color);
}

.footer-banner-text {
    display: flex;
    flex-direction: column;
    position: relative;
}

.banner-title {
    font-size: 18px;
    font-weight: 700;
    letter-spacing: -0.5px;
}

.banner-subtitle {
    font-size: 14px;
    font-weight: 400;
    opacity: 0.8;
}

.banner-line-art {
    height: 2px;
    background: var(--footer-accent);
    width: 80px;
    margin-top: 4px;
}

.footer-banner-right {
    display: flex;
    gap: 30px;
}

.banner-stat {
    display: flex;
    flex-direction: column;
    text-align: right;
}

.stat-num {
    font-size: 22px;
    font-weight: 800;
    color: var(--footer-accent);
}

.stat-lbl {
    font-size: 11px;
    font-weight: 700;
}

.stat-desc {
    font-size: 9px;
    opacity: 0.6;
}

/* Tables and Data list */
.table-container {
    background: var(--bg-surface);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-color);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}

.data-table {
    width: 100%;
    border-collapse: collapse;
    text-align: left;
}

.data-table th, .data-table td {
    padding: 14px 18px;
    font-size: 13px;
}

.data-table th {
    background: var(--bg-table-header);
    color: var(--text-secondary);
    font-weight: 500;
    text-transform: uppercase;
    font-size: 10.5px;
    letter-spacing: 0.5px;
    border-bottom: 1px solid var(--border-color);
}

.data-table td {
    border-bottom: 1px solid var(--border-color);
    color: var(--text-primary);
}

.data-table tr:last-child td {
    border-bottom: none;
}

.data-table tbody tr:hover td {
    background: var(--bg-base);
}

/* Status Badges */
.badge {
    padding: 3px 8px;
    border-radius: 6px;
    font-size: 10.5px;
    font-weight: 500;
    display: inline-block;
}

.badge-overdue { background: var(--danger-bg); color: var(--danger); border: 1px solid rgba(240, 68, 56, 0.2); }
.badge-due-soon { background: var(--warning-bg); color: var(--warning); border: 1px solid rgba(247, 144, 9, 0.2); }
.badge-on-track { background: var(--success-bg); color: var(--success); border: 1px solid rgba(18, 183, 106, 0.2); }

#view-kanban .view-header-actions {
    justify-content: space-between;
    align-items: center;
    gap: 20px;
}

.kanban-guide {
    display: flex;
    align-items: center;
    gap: 10px;
    background: rgba(10, 51, 255, 0.03);
    border: 1px solid rgba(10, 51, 255, 0.12);
    padding: 8px 16px;
    border-radius: var(--radius-md);
    font-size: 12px;
    color: var(--text-secondary);
    max-width: 75%;
    box-shadow: var(--shadow-sm);
    backdrop-filter: blur(4px);
}

.kanban-guide .guide-icon {
    font-size: 15px;
    display: flex;
    align-items: center;
}

.kanban-guide strong {
    color: var(--primary-blue);
    font-weight: 700;
}

/* Kanban Board Leads */
.kanban-board {
    display: flex;
    gap: 15px;
    flex-grow: 1;
    padding-bottom: 15px;
    align-items: stretch;
    width: 100%;
    overflow-x: auto;
}

.kanban-column {
    background: var(--bg-surface);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    padding: 12px;
    box-shadow: var(--shadow-sm);
    box-sizing: border-box;
    transition: var(--transition-smooth);
}

/* Kanban column width optimizations based on operational phase */
.kanban-column[data-stage="Discovery"],
.kanban-column[data-stage="Proposal & Negotiation"] {
    flex: 1.3 1 180px; /* Wider active columns, dynamically scaling */
    min-width: 160px;
    max-width: 360px;
}

.kanban-column[data-stage="Won"],
.kanban-column[data-stage="In Production"],
.kanban-column[data-stage="Review"],
.kanban-column[data-stage="Delivered"] {
    flex: 1 1 140px; /* Standard columns, dynamically scaling */
    min-width: 120px;
    max-width: 260px;
}

.column-header {
    font-size: 12px;
    font-weight: 700;
    padding: 8px 12px;
    border-radius: 6px;
    margin-bottom: 12px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.column-header .count {
    background: rgba(16, 24, 40, 0.08);
    padding: 2px 6px;
    border-radius: 20px;
    font-size: 10px;
    color: var(--text-primary);
}

.column-desc {
    font-size: 10px;
    color: var(--text-muted);
    margin-top: -6px;
    margin-bottom: 10px;
    padding: 0 4px;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.lead-color { background: var(--badge-discovery-bg); color: var(--badge-discovery-text); border: 1px solid var(--badge-discovery-border); }
.qualified-color { background: var(--badge-in-production-bg); color: var(--badge-in-production-text); border: 1px solid var(--badge-in-production-border); }
.meeting-color { background: var(--badge-review-bg); color: var(--badge-review-text); border: 1px solid var(--badge-review-border); }
.proposal-negotiation-color { background: linear-gradient(135deg, var(--badge-proposal-bg) 0%, var(--badge-negotiation-bg) 100%); color: var(--text-primary); border: 1px solid var(--border-color); }
.won-color { background: var(--badge-delivered-bg); color: var(--badge-delivered-text); border: 1px solid var(--badge-delivered-border); }
.lost-color { background: var(--danger-bg); color: var(--danger); border: 1px solid var(--border-color); }

.column-cards {
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex-grow: 1;
    min-height: 150px;
    overflow-y: auto;
}

.deal-card {
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    border-left: 4px solid #E2E8F0; /* default fallback left border */
    border-radius: var(--radius-md);
    padding: 14px;
    cursor: grab;
    transition: var(--transition-smooth);
    box-shadow: var(--shadow-sm);
    position: relative; /* for sub-stage badge positioning */
}

/* Card left border colors based on Deal Status */
.deal-card.sub-stage-discovery { border-left-color: var(--badge-discovery-text); }
.deal-card.sub-stage-proposal { border-left-color: var(--badge-proposal-text); }
.deal-card.sub-stage-negotiation { border-left-color: var(--badge-negotiation-text); }
.deal-card.sub-stage-won { border-left-color: var(--badge-won-text); }
.deal-card.sub-stage-in-production { border-left-color: var(--badge-in-production-text); }
.deal-card.sub-stage-review { border-left-color: var(--badge-review-text); }
.deal-card.sub-stage-delivered { border-left-color: var(--badge-delivered-text); }

/* Deal Status pill badges */
.sub-stage-badge {
    display: inline-block;
    font-size: 8px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 12px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}
.sub-stage-badge.badge-discovery { background: var(--badge-discovery-bg); color: var(--badge-discovery-text); border: 1px solid var(--badge-discovery-border); }
.sub-stage-badge.badge-proposal { background: var(--badge-proposal-bg); color: var(--badge-proposal-text); border: 1px solid var(--badge-proposal-border); }
.sub-stage-badge.badge-negotiation { background: var(--badge-negotiation-bg); color: var(--badge-negotiation-text); border: 1px solid var(--badge-negotiation-border); }
.sub-stage-badge.badge-won { background: var(--badge-won-bg); color: var(--badge-won-text); border: 1px solid var(--badge-won-border); }
.sub-stage-badge.badge-in-production { background: var(--badge-in-production-bg); color: var(--badge-in-production-text); border: 1px solid var(--badge-in-production-border); }
.sub-stage-badge.badge-review { background: var(--badge-review-bg); color: var(--badge-review-text); border: 1px solid var(--badge-review-border); }
.sub-stage-badge.badge-delivered { background: var(--badge-delivered-bg); color: var(--badge-delivered-text); border: 1px solid var(--badge-delivered-border); }

/* Payment Status Secondary Chips (top-right of cards) */
.payment-status-chip {
    position: absolute;
    top: 10px;
    right: 10px;
    font-size: 8px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    gap: 4px;
    text-transform: uppercase;
}

.payment-status-chip .dot {
    width: 5px;
    height: 5px;
    border-radius: 50%;
    display: inline-block;
}

.chip-no-deposit { background: var(--chip-no-deposit-bg); color: var(--chip-no-deposit-text); }
.chip-no-deposit .dot { background: var(--chip-no-deposit-dot); }

.chip-deposited-50 { background: var(--chip-deposited-50-bg); color: var(--chip-deposited-50-text); }
.chip-deposited-50 .dot { background: var(--chip-deposited-50-dot); }

.chip-partial-paid { background: var(--chip-partial-paid-bg); color: var(--chip-partial-paid-text); }
.chip-partial-paid .dot { background: var(--chip-partial-paid-dot); }

.chip-paid { background: var(--chip-paid-bg); color: var(--chip-paid-text); }
.chip-paid .dot { background: var(--chip-paid-dot); }

.chip-overdue { background: var(--chip-overdue-bg); color: var(--chip-overdue-text); border: 1px solid var(--chip-overdue-border); }
.chip-overdue .dot { background: var(--chip-overdue-dot); animation: pulse-blink 1.5s infinite; }

@keyframes pulse-blink {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.4; transform: scale(1.2); }
}

.deal-card:hover {
    transform: translateY(-2px);
    border-color: var(--primary-blue-text);
    box-shadow: var(--shadow-md);
}

.deal-card.dragging {
    opacity: 0.4;
    cursor: grabbing;
}

.deal-card h4 {
    font-size: 13px;
    font-weight: 700;
    margin-bottom: 4px;
    color: var(--text-primary);
    padding-right: 85px; /* Prevent text overlap with payment chip */
}

.deal-card .card-status-row {
    margin-top: 8px;
    margin-bottom: 8px;
}

.deal-card .customer-lbl {
    font-size: 11px;
    color: var(--primary-blue-text);
    font-weight: 600;
    margin-bottom: 8px;
    display: block;
}

.deal-card .rev-lbl {
    font-size: 12.5px;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 6px;
}

.deal-card .card-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 10px;
    color: var(--text-muted);
    border-top: 1px solid var(--border-color);
    padding-top: 8px;
    margin-top: 8px;
}

/* Modals layout */
.modal-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(16, 24, 40, 0.4);
    backdrop-filter: blur(4px);
    z-index: 1000;
    justify-content: center;
    align-items: center;
}

.modal-overlay.active {
    display: flex;
}

.modal-content {
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    width: 90%;
    max-width: 600px;
    padding: 24px;
    box-shadow: 0 20px 24px -4px rgba(16, 24, 40, 0.1), 0 8px 8px -4px rgba(16, 24, 40, 0.04);
    position: relative;
    color: var(--text-primary);
}

.modal-close {
    position: absolute;
    top: 16px;
    right: 20px;
    font-size: 20px;
    cursor: pointer;
    color: var(--text-muted);
}

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

.modal-content h3 {
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 16px;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 10px;
}

/* Forms layout */
.form-group {
    margin-bottom: 14px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.form-row {
    display: flex;
    gap: 12px;
}

.form-row .form-group {
    flex: 1;
}

label {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
}

input, select, textarea {
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    padding: 8px 12px;
    color: var(--text-primary);
    font-family: inherit;
    font-size: 13px;
    outline: none;
    transition: var(--transition-smooth);
}

input:focus, select:focus, textarea:focus {
    border-color: var(--primary-blue);
    box-shadow: 0 0 0 3px rgba(10, 51, 255, 0.1);
}

.modal-footer {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 20px;
    border-top: 1px solid var(--border-color);
    padding-top: 12px;
}

/* Placeholders view cards */
.placeholder-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 60px 40px;
    height: 100%;
}

.placeholder-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
    color: var(--text-muted);
}

.placeholder-icon svg {
    width: 48px;
    height: 48px;
    stroke: currentColor;
    stroke-width: 1.5;
    fill: none;
}

.placeholder-card h2 {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 8px;
}

.placeholder-card p {
    font-size: 13px;
    color: var(--text-secondary);
    max-width: 400px;
    margin-bottom: 16px;
}

/* Payroll selector and dashboards */
.payroll-selector-bar {
    display: flex;
    gap: 16px;
    align-items: flex-end;
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 16px;
    margin-bottom: 24px;
    box-shadow: var(--shadow-sm);
}

.payroll-selector-bar .inline-group {
    margin-bottom: 0;
    flex-grow: 1;
    max-width: 250px;
}

.payroll-dashboard {
    display: flex;
    flex-direction: column;
}

.detail-card {
    background: var(--bg-surface);
}

.detail-card h3 {
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 14px;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 8px;
}

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

.breakdown-table td {
    padding: 10px 0;
    font-size: 13px;
    color: var(--text-secondary);
    border-bottom: 1px solid #F3F4F6;
}

.breakdown-table td:last-child {
    color: var(--text-primary);
    font-weight: 600;
}

.breakdown-table tr.total-row td {
    font-size: 13.5px;
    font-weight: 700;
    color: var(--text-primary);
    border-bottom: none;
    border-top: 2px solid var(--border-color);
    padding-top: 12px;
}

.breakdown-table tr.total-row td:last-child {
    font-size: 16px;
}

.color-red { color: var(--danger) !important; }
.color-gold { color: var(--warning) !important; }
.color-blue { color: var(--primary-blue) !important; }
.color-green { color: var(--success) !important; }

.payroll-notice {
    margin-top: 16px;
    background: #FAFAFA;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 12px;
}

.payroll-notice p {
    font-size: 12px;
    margin-bottom: 6px;
    font-weight: 600;
}

.payroll-notice ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.payroll-notice li {
    font-size: 11px;
    color: var(--text-secondary);
    position: relative;
    padding-left: 12px;
}

.payroll-notice li::before {
    content: "•";
    color: var(--primary-blue);
    position: absolute;
    left: 0;
    font-weight: bold;
}

/* ==========================================================================
   Phase 2 Small Team Mode Additional Styles
   ========================================================================== */

/* Login overlay & Form */
.login-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(11, 15, 25, 0.6);
    backdrop-filter: blur(16px);
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
    transition: opacity 0.3s ease;
}
.login-overlay.active {
    display: flex;
}
.login-box {
    width: 100%;
    max-width: 400px;
    padding: 40px;
    border-radius: var(--radius-lg);
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-lg);
    display: flex;
    flex-direction: column;
    align-items: stretch;
}
.login-logo {
    height: 48px;
    object-fit: contain;
    margin: 0 auto 16px auto;
    background: #FFFFFF;
    border-radius: var(--radius-sm);
    padding: 4px;
    border: 1px solid var(--border-color);
}
.login-box h2 {
    font-size: 22px;
    font-weight: 700;
    text-align: center;
    margin-bottom: 6px;
    color: var(--text-primary);
}
.login-subtitle {
    font-size: 13.5px;
    color: var(--text-secondary);
    text-align: center;
    margin-bottom: 28px;
}
.login-error-msg {
    margin-bottom: 16px;
    font-size: 12.5px;
    color: var(--danger);
    background: var(--danger-bg);
    border: 1px solid rgba(197, 34, 31, 0.2);
    padding: 10px 14px;
    border-radius: var(--radius-sm);
    text-align: center;
}
.login-error-msg.hidden {
    display: none;
}
.btn-block {
    width: 100%;
    justify-content: center;
    padding: 11px;
}

/* User profile Dropdown Menu */
.user-profile-module {
    position: relative;
}
.user-dropdown-menu {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 160px;
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-lg);
    display: none;
    flex-direction: column;
    padding: 6px 0;
    z-index: 100;
}
.user-dropdown-menu.active {
    display: flex;
}
.user-dropdown-menu a {
    padding: 10px 16px;
    font-size: 13px;
    color: var(--text-primary);
    text-decoration: none;
    transition: var(--transition-smooth);
    display: flex;
    align-items: center;
    gap: 8px;
}
.user-dropdown-menu a:hover {
    background: var(--bg-base);
}

/* Notification panel dropdown */
.notification-bell {
    position: relative;
}
.notif-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    width: 340px;
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    display: none;
    flex-direction: column;
    z-index: 100;
    overflow: hidden;
}
.notif-dropdown.active {
    display: flex;
}
.notif-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    border-bottom: 1px solid var(--border-color);
    background: var(--bg-table-header);
}
.notif-header h4 {
    font-size: 13.5px;
    font-weight: 600;
    color: var(--text-primary);
}
.notif-header a {
    font-size: 11.5px;
    color: var(--primary-blue);
    text-decoration: none;
    font-weight: 500;
}
.notif-list {
    max-height: 280px;
    overflow-y: auto;
}
.notif-empty {
    padding: 24px;
    text-align: center;
    color: var(--text-muted);
    font-size: 12.5px;
}
.notif-item {
    padding: 12px 16px;
    border-bottom: 1px solid var(--border-color);
    cursor: pointer;
    transition: var(--transition-smooth);
}
.notif-item:hover {
    background: var(--bg-base);
}
.notif-item:last-child {
    border-bottom: none;
}
.notif-title {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 2px;
}
.notif-content {
    font-size: 11.5px;
    color: var(--text-secondary);
    line-height: 1.4;
}
.notif-time {
    font-size: 10px;
    color: var(--text-muted);
    margin-top: 4px;
    display: block;
}

/* CRM Project Drawer */
.crm-drawer {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 2000;
    display: none;
}
.crm-drawer.active {
    display: block;
}
.crm-drawer-backdrop {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(15, 23, 42, 0.4);
    backdrop-filter: blur(4px);
}
.crm-drawer-content {
    position: absolute;
    top: 0;
    right: 0;
    width: 500px;
    height: 100%;
    background: var(--bg-surface);
    border-left: 1px solid var(--border-color);
    box-shadow: var(--shadow-lg);
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.crm-drawer.active .crm-drawer-content {
    transform: translateX(0);
}
.crm-drawer-header {
    padding: 20px 24px;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.crm-drawer-title-group h2 {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-primary);
}
.crm-drawer-close-btn {
    background: none;
    border: none;
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    color: var(--text-secondary);
    padding: 4px;
    border-radius: var(--radius-sm);
    transition: var(--transition-smooth);
}
.crm-drawer-close-btn:hover {
    background: var(--bg-base);
    color: var(--text-primary);
}
.crm-drawer-body {
    flex-grow: 1;
    overflow-y: auto;
    padding: 24px;
    display: flex;
    flex-direction: column;
}
.drawer-tabs {
    display: flex;
    gap: 16px;
    border-bottom: 1px solid var(--border-color);
    margin-bottom: 20px;
}
.drawer-tab-btn {
    background: none;
    border: none;
    padding: 8px 4px 12px 4px;
    font-size: 13px;
    font-weight: 500;
    color: var(--text-secondary);
    cursor: pointer;
    position: relative;
    transition: var(--transition-smooth);
}
.drawer-tab-btn:hover {
    color: var(--text-primary);
}
.drawer-tab-btn.active {
    color: var(--primary-blue);
    font-weight: 600;
}
.drawer-tab-btn.active::after {
    content: "";
    position: absolute;
    bottom: -1px;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--primary-blue);
}
.drawer-tab-content {
    display: none;
}
.drawer-tab-content.active {
    display: block;
}
.detail-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}
.detail-item {
    font-size: 13.5px;
    color: var(--text-primary);
}
.detail-item strong {
    display: block;
    font-size: 10.5px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--text-muted);
    margin-bottom: 4px;
}

/* Comments section UI */
.comments-feed {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 16px;
    max-height: 380px;
    overflow-y: auto;
    padding-right: 4px;
}
.comment-bubble {
    padding: 12px;
    border-radius: var(--radius-md);
    background: var(--bg-base);
    max-width: 85%;
    align-self: flex-start;
    border: 1px solid var(--border-color);
}
.comment-bubble.self {
    background: rgba(37, 99, 235, 0.08);
    border-color: rgba(37, 99, 235, 0.15);
    align-self: flex-end;
}
.comment-meta {
    display: flex;
    justify-content: space-between;
    font-size: 10.5px;
    color: var(--text-muted);
    margin-bottom: 4px;
    gap: 16px;
}
.comment-meta .author {
    font-weight: 600;
    color: var(--text-secondary);
}
.comment-body {
    font-size: 12.5px;
    color: var(--text-primary);
    line-height: 1.4;
    word-break: break-word;
}
.comment-form-inline {
    display: flex;
    gap: 8px;
    margin-top: 16px;
}
.comment-form-inline textarea {
    flex-grow: 1;
    padding: 10px 12px;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    font-family: inherit;
    font-size: 12.5px;
    outline: none;
    resize: none;
    background: var(--bg-surface);
    color: var(--text-primary);
}
.comment-form-inline textarea:focus {
    border-color: var(--primary-blue);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.08);
}

/* File Reviews UI */
.reviews-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.review-item {
    padding: 16px;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    background: var(--bg-surface);
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.review-item-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.review-item-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-primary);
}
.review-item-version {
    font-size: 11px;
    background: var(--bg-base);
    padding: 2px 6px;
    border-radius: var(--radius-sm);
    font-weight: 600;
    color: var(--text-secondary);
}
.review-item-url {
    font-size: 12px;
    color: var(--primary-blue);
    text-decoration: none;
    word-break: break-all;
    font-weight: 500;
}
.review-item-url:hover {
    text-decoration: underline;
}
.review-item-notes {
    font-size: 12px;
    color: var(--text-secondary);
    font-style: italic;
    background: var(--bg-base);
    padding: 6px 10px;
    border-radius: var(--radius-sm);
    border-left: 3px solid var(--border-color);
}
.review-item-actions {
    display: flex;
    gap: 8px;
    margin-top: 8px;
}

/* Projects grid and project cards */
.projects-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
    padding-top: 10px;
}
.project-card {
    padding: 20px;
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    transition: var(--transition-smooth);
    cursor: pointer;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.project-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}
.project-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
.project-card-name {
    font-size: 15px;
    font-weight: 700;
    color: var(--text-primary);
}
.project-card-id {
    font-size: 10.5px;
    color: var(--text-muted);
    font-weight: 600;
}
.project-card-service {
    font-size: 13px;
    color: var(--text-secondary);
}
.project-card-meta {
    display: flex;
    justify-content: space-between;
    font-size: 11px;
    color: var(--text-muted);
}
.project-card-progress {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.project-card-progress-bar {
    height: 6px;
    background: var(--bg-base);
    border-radius: 3px;
    overflow: hidden;
}
.project-card-progress-fill {
    height: 100%;
    background: var(--primary-blue);
    border-radius: 3px;
    transition: width 0.3s ease;
}
.project-card-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-top: 1px solid var(--border-color);
    padding-top: 10px;
    font-size: 11.5px;
}
.project-card-owner {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--text-secondary);
    font-weight: 500;
}

/* Kanban task boards (view-tasks) */
.tasks-workspace-layout {
    display: flex;
    gap: 20px;
    height: calc(100vh - 180px);
    overflow: hidden;
    padding-top: 10px;
}
.tasks-col {
    flex: 1;
    background: var(--bg-base);
    border-radius: var(--radius-lg);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border: 1px solid var(--border-color);
}
.tasks-col-header {
    padding: 16px 20px;
    font-size: 14px;
    font-weight: 600;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--bg-surface);
    color: var(--text-primary);
}
.tasks-col-header .count {
    background: var(--border-color);
    color: var(--text-secondary);
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 20px;
    font-weight: 700;
}
.tasks-list {
    flex-grow: 1;
    overflow-y: auto;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.task-card {
    padding: 16px;
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    cursor: pointer;
    transition: var(--transition-smooth);
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.task-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-1px);
}
.task-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
.task-card-project {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--text-muted);
    font-weight: 600;
}
.task-card-title {
    font-size: 13.5px;
    font-weight: 600;
    color: var(--text-primary);
}
.task-card-desc {
    font-size: 12px;
    color: var(--text-secondary);
    line-height: 1.4;
}
.task-card-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-top: 1px solid var(--border-color);
    padding-top: 8px;
    font-size: 11px;
    color: var(--text-muted);
}
.task-card-due {
    display: flex;
    align-items: center;
    gap: 4px;
}
.task-card-assignee {
    display: flex;
    align-items: center;
    gap: 4px;
    font-weight: 500;
    color: var(--text-secondary);
}
.task-card-prio-badge {
    font-size: 10px;
    padding: 2px 6px;
    border-radius: var(--radius-sm);
    font-weight: 600;
}
.task-card-prio-badge.high {
    background: var(--danger-bg);
    color: var(--danger);
}
.task-card-prio-badge.medium {
    background: var(--warning-bg);
    color: var(--warning);
}
.task-card-prio-badge.low {
    background: var(--info-bg);
    color: var(--info);
}

/* Calendar Workspace Grid */
.calendar-workspace {
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 20px;
    height: 100%;
}
.calendar-header-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.calendar-header-bar h2 {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-primary);
}
.calendar-grid-container {
    display: flex;
    flex-direction: column;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    overflow: hidden;
}
.calendar-grid-header {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    background: var(--bg-table-header);
    border-bottom: 1px solid var(--border-color);
    text-align: center;
    font-size: 12px;
    font-weight: 600;
    color: var(--text-secondary);
}
.calendar-grid-header div {
    padding: 12px 0;
}
.calendar-grid-days {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    grid-auto-rows: minmax(100px, 1fr);
    background: var(--border-color);
    gap: 1px;
}
.calendar-day-cell {
    background: var(--bg-surface);
    padding: 8px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    overflow: hidden;
}
.calendar-day-cell.other-month {
    background: var(--bg-base);
}
.calendar-day-cell.other-month .day-num {
    color: var(--text-muted);
}
.calendar-day-cell.today {
    background: rgba(37, 99, 235, 0.03);
}
.calendar-day-cell.today .day-num {
    background: var(--primary-blue);
    color: white;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
}
.day-num {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-secondary);
    align-self: flex-start;
}
.calendar-events-list {
    display: flex;
    flex-direction: column;
    gap: 4px;
    overflow-y: auto;
    flex-grow: 1;
}
.calendar-event-item {
    font-size: 10.5px;
    padding: 4px 6px;
    border-radius: var(--radius-sm);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-weight: 500;
    cursor: pointer;
}
.calendar-event-item.onset {
    background: rgba(16, 185, 129, 0.1);
    color: #065F46;
    border-left: 3px solid #10B981;
}
.calendar-event-item.due {
    background: rgba(239, 68, 68, 0.1);
    color: #991B1B;
    border-left: 3px solid #EF4444;
}
.calendar-event-item.task {
    background: rgba(37, 99, 235, 0.1);
    color: #1E40AF;
    border-left: 3px solid #3B82F6;
}

/* --- Leads Spreadsheet Excel-like View --- */
.hidden {
    display: none !important;
}

.spreadsheet-container {
    animation: fadeIn 0.25s ease-in-out;
}

.excel-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
    background: var(--bg-card);
}

.excel-table th {
    padding: 10px 12px;
    font-weight: 600;
    color: var(--text-primary);
    border-bottom: 2px solid var(--border-color);
    border-right: 1px solid var(--border-color);
    text-transform: uppercase;
    font-size: 11px;
    letter-spacing: 0.5px;
}

.excel-table th:last-child {
    border-right: none;
}

.excel-table td {
    padding: 8px 12px;
    border-bottom: 1px solid var(--border-color);
    border-right: 1px solid var(--border-color);
    color: var(--text-secondary);
    vertical-align: middle;
    transition: background 0.15s ease;
    position: relative;
}

.excel-table td:last-child {
    border-right: none;
}

.excel-table tr:hover td {
    background: rgba(37, 99, 235, 0.02);
}

/* Excel-like cell editing styles */
.excel-table td.editable-cell {
    cursor: cell;
}

.excel-table td.editable-cell:hover {
    background: rgba(37, 99, 235, 0.05) !important;
    outline: 1px dashed var(--primary-blue) !important;
}

.excel-table td.editing {
    padding: 0 !important;
    background: var(--bg-surface) !important;
    outline: 2px solid var(--primary-blue) !important;
    z-index: 10;
}

.excel-table td.editing input,
.excel-table td.editing select {
    width: 100%;
    height: 100%;
    border: none;
    outline: none;
    padding: 8px 12px;
    font-size: 13px;
    font-family: inherit;
    background: transparent;
    color: var(--text-primary);
    box-sizing: border-box;
}

.excel-table td.editing input[type="date"] {
    padding: 6px 10px;
}

.excel-table td.editing select {
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'></polyline></svg>");
    background-repeat: no-repeat;
    background-position: right 8px center;
    background-size: 12px;
    padding-right: 24px;
}

/* Indicators */
#excel-save-indicator {
    transition: all 0.2s ease;
    font-size: 12px;
}
#excel-save-indicator.saving {
    color: var(--primary-blue);
}
#excel-save-indicator.success {
    color: #10B981;
}
#excel-save-indicator.error {
    color: #EF4444;
}

/* Switch styling active state */
.view-toggle-container button {
    background: transparent;
    color: var(--text-secondary);
    transition: all 0.2s ease;
}
.view-toggle-container button:hover {
    background: rgba(37, 99, 235, 0.05);
}
.view-toggle-container button.active {
    background: var(--primary-blue) !important;
    color: #FFFFFF !important;
}


/* ========================================================================
   Payroll v4 polish — hero NET card, accent colors, section structure
   ======================================================================== */
#view-payroll {
    gap: 0;
}

/* — Selector bar: form-group layout label-on-top + inputs-inline, buttons pushed right — */
#view-payroll .payroll-selector-bar {
    background: linear-gradient(135deg, #FFFFFF 0%, #FAFBFC 100%);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    padding: 14px 18px;
    margin-bottom: 24px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04), 0 8px 24px rgba(0,0,0,0.03);
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0;
}
/* Mỗi form-group là 1 nhóm: label trên (full width) + inputs hàng dưới (flex row).
   KHÔNG dùng !important trên `display` để inline style="display:none" (vd team-rev-field
   khi nhân sự không phải Manager) vẫn ẩn được. */
#view-payroll .payroll-selector-bar .form-group {
    margin: 0 !important;
    padding: 4px 18px;
    border-right: 1px solid #F0F1F3;
    flex: 0 0 auto !important;
    max-width: none !important;
    min-width: 0;
    display: flex;
    flex-direction: row !important;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
}
/* Ẩn cứng team-rev-field khi inline display:none — tránh CSS specificity ghi đè */
#view-payroll #team-rev-field[style*="display:none"],
#view-payroll #team-rev-field[style*="display: none"] {
    display: none !important;
}
#view-payroll .payroll-selector-bar .form-group:first-child { padding-left: 4px; }
#view-payroll .payroll-selector-bar .form-group > label {
    flex-basis: 100%;
    margin: 0 0 6px 0;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.7px;
    color: #9CA3AF;
    line-height: 1;
}
#view-payroll .payroll-selector-bar select,
#view-payroll .payroll-selector-bar input[type="month"],
#view-payroll .payroll-selector-bar input[type="number"] {
    border: 1px solid #E5E7EB;
    border-radius: 8px;
    padding: 8px 12px;
    font-size: 13px;
    font-weight: 600;
    color: #111827;
    background: #FFFFFF;
    transition: border-color 0.15s, box-shadow 0.15s;
    outline: none;
    line-height: 1.2;
    height: 38px;
    box-sizing: border-box;
    margin: 0;
}
#view-payroll .payroll-selector-bar select:hover,
#view-payroll .payroll-selector-bar input:hover {
    border-color: var(--primary-blue);
}
#view-payroll .payroll-selector-bar select:focus,
#view-payroll .payroll-selector-bar input:focus {
    border-color: var(--primary-blue);
    box-shadow: 0 0 0 3px rgba(10,51,255,0.12);
}
/* "Số ngày công" group: inputs nhỏ + divider gọn */
#view-payroll .payroll-selector-bar .form-group input[type="number"] {
    width: 56px !important;
    text-align: center;
    padding: 8px 6px;
}
#view-payroll .payroll-selector-bar .form-group > span {
    line-height: 1 !important;
    padding: 0 2px !important;
    color: #9CA3AF;
    font-size: 13px;
    font-weight: 600;
}
/* Wrapper 2 buttons: cùng 1 flex item → không tách dòng dù bar wrap */
#view-payroll .payroll-actions {
    margin-left: auto;
    display: flex;
    gap: 10px;
    flex: 0 0 auto;
    align-items: center;
    padding-left: 18px;
}
#view-payroll #btn-calc-payroll {
    background: linear-gradient(135deg, var(--primary-blue) 0%, #2745EB 100%);
    color: #FFFFFF;
    border: none;
    padding: 10px 20px;
    border-radius: 10px;
    font-size: 13px;
    font-weight: 600;
    height: 40px;
    box-shadow: 0 2px 8px rgba(10,51,255,0.25);
    transition: transform 0.12s, box-shadow 0.12s;
    cursor: pointer;
    white-space: nowrap;
}
#view-payroll #btn-calc-payroll:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(10,51,255,0.35);
}
#view-payroll #btn-print-payslip {
    background: linear-gradient(135deg, #FCD34D 0%, #F59E0B 100%);
    color: #422006;
    border: none;
    padding: 10px 20px;
    border-radius: 10px;
    font-size: 13px;
    font-weight: 700;
    height: 40px;
    box-shadow: 0 2px 8px rgba(245,158,11,0.30);
    transition: transform 0.12s, box-shadow 0.12s;
    cursor: pointer;
    white-space: nowrap;
}
#view-payroll #btn-print-payslip:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(245,158,11,0.42);
}

/* — 4 Summary cards: NET as hero, others as accents — */
#view-payroll .summary-cards {
    grid-template-columns: 1.4fr 1fr 1fr 1fr;
    gap: 18px;
    margin-bottom: 28px;
}
#view-payroll .summary-card {
    position: relative;
    border-radius: 16px;
    padding: 22px 24px;
    background: #FFFFFF;
    border: 1px solid #EDEEF1;
    box-shadow: 0 1px 2px rgba(0,0,0,0.03), 0 12px 28px rgba(0,0,0,0.04);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
    overflow: hidden;
}
#view-payroll .summary-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0,0,0,0.05), 0 16px 36px rgba(0,0,0,0.07);
}
#view-payroll .summary-card::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: #E5E7EB;
}
#view-payroll .summary-card h3 {
    font-size: 11px;
    font-weight: 700;
    color: #6B7280;
    text-transform: uppercase;
    letter-spacing: 0.7px;
    margin-bottom: 10px;
}
#view-payroll .summary-card .card-value {
    font-size: 26px;
    font-weight: 800;
    line-height: 1.15;
    margin-bottom: 8px;
    letter-spacing: -0.5px;
    font-variant-numeric: tabular-nums;
}
#view-payroll .summary-card .card-subtitle {
    font-size: 11px;
    color: #6B7280;
    line-height: 1.5;
}

/* NET card — hero, gold gradient */
#view-payroll .summary-card.gold-border {
    background: linear-gradient(135deg, #FFFBEB 0%, #FEF3C7 100%);
    border: 1px solid #FCD34D;
}
#view-payroll .summary-card.gold-border::before {
    background: linear-gradient(90deg, #F59E0B, #FBBF24);
    height: 5px;
}
#view-payroll .summary-card.gold-border h3 {
    color: #92400E;
}
#view-payroll .summary-card.gold-border .card-value {
    font-size: 32px;
    color: #B45309;
    text-shadow: 0 1px 0 rgba(255,255,255,0.5);
}
#view-payroll .summary-card.gold-border .card-subtitle {
    color: #78350F;
    font-weight: 500;
}

/* Card 2 — Doanh thu (blue accent) */
#view-payroll .summary-card:nth-child(2)::before { background: linear-gradient(90deg, #3B82F6, #60A5FA); }
#view-payroll .summary-card:nth-child(2) .card-value { color: #1D4ED8; }

/* Card 3 — KPI (green accent) */
#view-payroll .summary-card:nth-child(3)::before { background: linear-gradient(90deg, #10B981, #34D399); }
#view-payroll .summary-card:nth-child(3) .card-value { color: #047857; }

/* Card 4 — BHXH (indigo accent) */
#view-payroll .summary-card:nth-child(4)::before { background: linear-gradient(90deg, #6366F1, #818CF8); }
#view-payroll .summary-card:nth-child(4) .card-value { color: #4338CA; }

/* KPI progress bar — taller, smoother */
#view-payroll .kpi-progress-wrap {
    height: 14px !important;
    background: linear-gradient(90deg, #F3F4F6, #E5E7EB) !important;
    border-radius: 10px !important;
    margin: 12px 0 8px !important;
    box-shadow: inset 0 1px 2px rgba(0,0,0,0.06);
}
#view-payroll #kpi-progress-bar {
    border-radius: 10px !important;
    box-shadow: 0 0 8px rgba(16,185,129,0.20);
}

/* — Breakdown section: 2 columns with section icons — */
#view-payroll .breakdown-section {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
}
#view-payroll .breakdown-column { width: 100%; }
#view-payroll .breakdown-column .card {
    background: #FFFFFF;
    border: 1px solid #EDEEF1;
    border-radius: 16px;
    padding: 22px 24px;
    box-shadow: 0 1px 2px rgba(0,0,0,0.03), 0 8px 20px rgba(0,0,0,0.03);
}
#view-payroll .detail-card h3 {
    font-size: 15px;
    font-weight: 700;
    color: #111827;
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 2px solid #F3F4F6;
    display: flex;
    align-items: center;
    gap: 8px;
}
#view-payroll .detail-card:nth-of-type(1) h3::before { content: "💰"; font-size: 18px; }

/* Breakdown table — better rows + zebra hover */
#view-payroll .breakdown-table tr { transition: background-color 0.12s; }
#view-payroll .breakdown-table tbody tr:hover {
    background: rgba(10,51,255,0.025);
}
#view-payroll .breakdown-table td {
    padding: 12px 8px;
    font-size: 13px;
    color: #374151;
    border-bottom: 1px solid #F3F4F6;
}
#view-payroll .breakdown-table td:last-child {
    color: #111827;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
}
#view-payroll .breakdown-table tr.commission-detail-row td {
    background: rgba(99,102,241,0.04) !important;
    color: #4B5563;
}
#view-payroll .breakdown-table tr.total-row td {
    font-size: 14px;
    font-weight: 700;
    color: #111827;
    border-top: 2px solid #111827;
    border-bottom: none;
    padding-top: 14px;
    padding-bottom: 14px;
}
#view-payroll .breakdown-table tr.total-row td:last-child {
    font-size: 18px;
    color: #B45309;
}

/* Deductions card — red accent header */
#view-payroll .breakdown-column:nth-child(2) .detail-card h3::before { content: "📉"; font-size: 18px; }
#view-payroll .breakdown-table .color-red { color: #DC2626 !important; }

/* Notice box */
#view-payroll .payroll-notice {
    margin-top: 20px;
    background: linear-gradient(135deg, #EFF6FF 0%, #DBEAFE 100%);
    border: 1px solid #BFDBFE;
    border-radius: 12px;
    padding: 14px 16px;
}
#view-payroll .payroll-notice p {
    font-size: 12px;
    font-weight: 700;
    color: #1E40AF;
    margin-bottom: 8px;
}
#view-payroll .payroll-notice li {
    font-size: 12px;
    color: #1E3A8A;
    line-height: 1.6;
}
#view-payroll .payroll-notice li::before {
    content: "✓";
    color: #2563EB;
    font-weight: 700;
}

/* Responsive: stack at narrow */
@media (max-width: 1100px) {
    #view-payroll .summary-cards {
        grid-template-columns: 1fr 1fr;
    }
    #view-payroll .breakdown-section {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 700px) {
    #view-payroll .summary-cards {
        grid-template-columns: 1fr;
    }
    #view-payroll .payroll-selector-bar > * {
        border-right: none;
        border-bottom: 1px solid #F0F1F3;
        padding-bottom: 12px;
    }
    #view-payroll .payroll-selector-bar > *:last-child {
        border-bottom: none;
    }
}

/* ========================================================================
   Month employment status colors — gray/yellow/green per month option
   ======================================================================== */
#month-scope-select option.month-opt-pre {
    background-color: #F3F4F6;
    color: #6B7280;
}
#month-scope-select option.month-opt-probation {
    background-color: #FEF3C7;
    color: #92400E;
}
#month-scope-select option.month-opt-official {
    background-color: #D1FAE5;
    color: #047857;
}
/* Status badge bên cạnh input "Tháng tính lương" — override generic span CSS */
#view-payroll #payroll-month-status-badge {
    padding: 5px 10px !important;
    line-height: 1.2 !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    border-radius: 6px;
    color: inherit;
    box-shadow: 0 1px 2px rgba(0,0,0,0.04);
    margin-left: 6px;
    white-space: nowrap;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}
