    :root {
        --bg-primary: #f8fafc;
        --bg-secondary: #f1f5f9;
        --bg-tertiary: #e2e8f0;
        --bg-card: #ffffff;
        --text-primary: #111827;
        --text-secondary: #374151;
        --text-muted: #6b7280;
        --border: #cbd5e1;
        --border-light: #e2e8f0;
        --border-strong: #94a3b8;
        --accent-blue: #2563eb;
        --accent-green: #16a34a;
        --accent-amber: #d97706;
        --accent-red: #dc2626;
        --hover-bg: #f3f4f6;
        /* UI extras */
    --scrollbar-thumb: #94a3b8; /* brighter grey (slate 400) */
    --scrollbar-thumb-hover: #64748b; /* slightly darker on hover (slate 500) */
        
        /* Light mode shadows for depth */
        --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
        --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.07);
        --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.1);
        --shadow-card: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.24);
    }

    /* Simple checkbox row styles for task description editor */
    .checkbox-row { display:flex; align-items:center; margin:6px 0; }
    .checkbox-toggle {
        width:18px; height:18px; border:1px solid var(--border); border-radius:3px; background:#ffffff; cursor:pointer; display:inline-flex; align-items:center; justify-content:center; font-size:12px; line-height:1; color:transparent;
    }
    .checkbox-toggle.checked, .checkbox-toggle[aria-pressed="true"] { background:var(--accent-blue); border-color:var(--accent-blue); color:#fff; }

    .check-text { flex:1; min-height:18px; outline:none; padding-left:8px; }

    /* Variant 1: modern rounded filled blue with SVG check */
    .checkbox-toggle.variant-1 {
        width:18px; height:18px; border-radius:5px;
        border:1px solid var(--border);
        background:#fff; color:transparent;
        display:inline-flex; align-items:center; justify-content:center;
        font-size:12px; line-height:1; cursor:pointer;
    }
    .checkbox-toggle.variant-1[aria-pressed="true"], .checkbox-toggle.variant-1.checked {
        background: var(--accent-blue);
        border-color: var(--accent-blue);
        color: #fff; /* show the literal '✔' text clearly */
        background-image: none;
    }



    [data-theme="dark"] {
        /* Dark theme */
        --bg-primary: #0f1419;
        --bg-secondary: #1c1f2b;
        --bg-tertiary: #252a36;
        --bg-card: #1a1f2e;

        --text-primary: #f9fafb;
        --text-secondary: #d1d5db;
        --text-muted: #9ca3af;

        --border: #374151;
        --border-light: #2d3340;
        --border-strong: #4b5563;
        --hover-bg: #2d3340;

        --accent-blue: #3b82f6;
        /* Dark accents for badges in dark mode (strong and stronger variants) */
        --accent-green: #0ea36a; /* base dark green */
        --accent-amber: #d18b06; /* base dark amber */
    --accent-green-strong: #0c5036; /* slightly darker green (nudge) */
    --accent-amber-strong: #4f2500; /* slightly darker amber (nudge) */
        --accent-red: #ef4444;

        /* Dark mode shadows */
        --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.4);
        --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.5);
        --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.6);
        --shadow-card: 0 2px 4px rgba(0, 0, 0, 0.3), 0 1px 2px rgba(0, 0, 0, 0.4);
        /* UI extras */
        --scrollbar-thumb: #475569; /* lighter for visibility in dark mode */
        --scrollbar-thumb-hover: #334155; /* slightly darker on hover */
    }


    .resizer {
        width: 4px;
        background: var(--border);
        cursor: col-resize;
        transition: background 0.2s;
        position: relative;
        user-select: none;
    }

    .resizer:hover, .resizer.dragging {
        background: var(--accent-blue);
    }

    .app {
        display: flex;
        height: 100vh;
        overflow: hidden;
    }

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

    body {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
        background: var(--bg-primary);
        color: var(--text-primary);
        line-height: 1.6;
    }

    .app { display: flex; height: 100vh; }

    .sidebar {
        width: 280px;
        background: var(--bg-secondary);
        border-right: 1px solid var(--border);
        display: flex;
        flex-direction: column;
    }

    .sidebar-header {
        padding: 24px 20px;
        border-bottom: 1px solid var(--border);
    }

    .workspace-title {
        display: flex;
        align-items: center;
        gap: 12px;
        font-size: 18px;
        font-weight: 600;
    }

    .workspace-icon {
        width: 32px;
        height: 32px;
        background: linear-gradient(135deg, #3b82f6, #1d4ed8);
        border-radius: 8px;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 16px;
    }

    .nav-section {
        padding: 16px 0;
    }

    .nav-section-title {
        font-size: 11px;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 1px;
        color: var(--text-muted);
        margin: 0 20px 12px;
    }

    .nav-item {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 10px 20px;
        cursor: pointer;
        transition: all 0.2s;
        border-left: 3px solid transparent;
        color: var(--text-secondary);
    }

    .nav-item:hover {
        background: var(--hover-bg);
        color: var(--text-primary);
    }

    .nav-item.active {
        background: var(--bg-tertiary);
        color: var(--text-primary);
        border-left-color: var(--accent-blue);
    }

    .nav-icon {
        font-size: 18px;
        width: 20px;
        text-align: center;
    }

    .nav-count {
        margin-left: auto;
        background: var(--bg-tertiary);
        color: var(--text-muted);
        padding: 2px 8px;
        border-radius: 12px;
        font-size: 12px;
    }

    .new-project-btn {
        margin: 16px 20px;
        padding: 12px 16px;
        background: var(--accent-blue);
        color: white;
        border: none;
        border-radius: 8px;
        font-weight: 500;
        cursor: pointer;
        transition: all 0.2s;
    }

    .main-content {
        flex: 1;
        display: flex;
        flex-direction: column;
    }

    .page {
        display: none;
        flex-direction: column;
        height: 100vh;
    }

    .page.active {
        display: flex;
    }

    .page-header {
        padding: 12px 32px;
        border-bottom: 1px solid var(--border);
        background: var(--bg-secondary);
        display: flex;
        justify-content: space-between;
        align-items: center;
        position: relative;
        z-index: 1;
    }

    .page-title {
        font-size: 22px;
        font-weight: 600;
        margin-bottom: 2px;
    }

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

    .page-content {
        flex: 1;
        padding: 32px;
        overflow-y: auto;
        position: relative;
        background: var(--bg-primary);
    }

    .project-details-view .page-content {
        flex: 1;
        padding: 32px;
        overflow-y: auto;
        min-height: 0;
        height: calc(100vh - 80px);
    }

    /* Dashboard Header Actions */
    .dashboard-actions {
        display: flex;
        gap: 12px;
        margin-right: 50px;
    }

    .action-btn {
        display: flex;
        align-items: center;
        gap: 8px;
        padding: 10px 16px;
        border: none;
        border-radius: 8px;
        font-weight: 500;
        cursor: pointer;
        transition: all 0.2s;
        font-size: 14px;
    }

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

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

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

    /* Dashboard Content Layout */
    .dashboard-content {
        padding: 24px;
        background: linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);
    }

    /* Hero Stats Section */
    .hero-stats {
        display: none;
    }

    /* Hide the insights pill */
    .research-insights .insights-pill {
        display: none;
    }

    /* Activity date styling */
    .activity-item {
        display: flex;
        align-items: center;
        gap: 12px;
    }
    
    .activity-date {
        margin-left: auto;
        font-size: 12px;
        color: var(--text-muted);
        white-space: nowrap;
    }
    
    /* Full activity page */
    #activity-page {
        display: none;
    }
    
    .activity-page-header {
        display: flex;
        align-items: center;
        gap: 16px;
        margin-bottom: 24px;
        padding-bottom: 16px;
        border-bottom: 1px solid var(--border);
    }
    
    .activity-item-full {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 16px;
        border-bottom: 1px solid var(--border-light);
        font-size: 16px;
    }
    
    .activity-full-date {
        margin-left: auto;
        font-size: 14px;
        color: var(--text-secondary);
        white-space: nowrap;
    }
    
    .activity-item {
        font-size: 15px;
    }
    
    .activity-text {
        font-size: 15px;
    }
    
    .all-activity-list {
        max-height: 70vh;
        overflow-y: auto;
    }

    .hero-stat-card {
        background: var(--bg-card);
        border: 1px solid var(--border);
        border-radius: 16px;
        padding: 32px;
        display: flex;
        justify-content: space-between;
        align-items: center;
        box-shadow: var(--shadow-lg);
        transition: all 0.3s ease;
        position: relative;
        overflow: hidden;
    }

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

    .hero-stat-card.primary {
        background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
        color: white;
        border: none;
    }

    .hero-stat-card.success {
        background: linear-gradient(135deg, #11998e 0%, #38ef7d 100%);
        color: white;
        border: none;
    }

    .hero-stat-number {
        font-size: 48px;
        font-weight: 800;
        line-height: 1;
        margin-bottom: 8px;
    }

    .hero-stat-label {
        font-size: 16px;
        opacity: 0.9;
        margin-bottom: 4px;
    }

    .hero-stat-trend {
        font-size: 14px;
        opacity: 0.8;
    }

    .hero-stat-visual {
        width: 120px;
        height: 80px;
    }

    .completion-ring {
        position: relative;
        width: 80px;
        height: 80px;
    }

    .completion-ring svg {
        width: 100%;
        height: 100%;
        transform: rotate(-90deg);
    }

    .progress-circle {
        transition: stroke-dashoffset 1s ease;
        stroke-linecap: round;
    }

    .ring-percentage {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        font-size: 18px;
        font-weight: 700;
    }

    /* Main Dashboard Grid */
    .dashboard-grid {
        display: grid;
        grid-template-columns: 2fr 1fr;
        gap: 24px;
    }

    /* Stats Section */
    .stats-section {
        grid-column: 1 / -1;
    }

    .stats-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 20px;
    }

    .stats-header h3 {
        font-size: 20px;
        font-weight: 600;
        color: var(--text-primary);
    }

    .time-filter {
        display: flex;
        gap: 8px;
    }

    .filter-chip {
        padding: 6px 12px;
        border: 1px solid var(--border);
        background: var(--bg-secondary);
        color: var(--text-secondary);
        border-radius: 20px;
        font-size: 12px;
        cursor: pointer;
        transition: all 0.2s;
    }

    .filter-chip.active,
    .filter-chip:hover {
        background: var(--accent-blue);
        color: white;
        border-color: var(--accent-blue);
    }

    .enhanced-stats-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
        gap: 16px;
    }

    .enhanced-stat-card {
        background: var(--bg-card);
        border: 1px solid var(--border);
        border-radius: 12px;
        padding: 20px;
        display: flex;
        align-items: center;
        gap: 16px;
        transition: all 0.2s;
        cursor: pointer;
    }

    .enhanced-stat-card:hover {
        transform: translateY(-2px);
        box-shadow: var(--shadow-md);
        border-color: var(--accent-blue);
    }

    .stat-icon-new {
        width: 48px;
        height: 48px;
        border-radius: 12px;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 20px;
        flex-shrink: 0;
    }

    .stat-icon-new.blue { background: rgba(59, 130, 246, 0.15); color: var(--accent-blue); }
    .stat-icon-new.amber { background: rgba(245, 158, 11, 0.15); color: var(--accent-amber); }
    .stat-icon-new.green { background: rgba(16, 185, 129, 0.15); color: var(--accent-green); }
    .stat-icon-new.red { background: rgba(239, 68, 68, 0.15); color: var(--accent-red); }
    .stat-icon-new.purple { background: rgba(147, 51, 234, 0.15); color: #9333ea; }
    .stat-icon-new.teal { background: rgba(20, 184, 166, 0.15); color: #14b8a6; }

    .stat-content {
        flex: 1;
    }

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

    .stat-title {
        font-size: 14px;
        color: var(--text-muted);
        margin-bottom: 2px;
    }

    .stat-change {
        font-size: 12px;
        font-weight: 500;
    }

    .stat-change.positive { color: var(--accent-green); }
    .stat-change.negative { color: var(--accent-red); }
    .stat-change.neutral { color: var(--text-muted); }

    /* Card Base Styles */
    .progress-overview-card,
    .activity-feed-card,
    .insights-card,
    .quick-actions-card {
        background: var(--bg-card);
        border: 1px solid var(--border);
        border-radius: 16px;
        padding: 24px;
        box-shadow: var(--shadow-sm);
        transition: all 0.2s;
    }

    .insights-card {
        padding: 20px;
    }

    .card-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 20px;
        padding-bottom: 12px;
        border-bottom: 1px solid var(--border-light);
    }

    .insights-card .card-header {
        margin-bottom: 16px;
        padding-bottom: 10px;
    }

    .card-header h3 {
        font-size: 18px;
        font-weight: 600;
        color: var(--text-primary);
    }

    /* Clickable Project Items */
    .clickable-project:hover {
        background: var(--hover-bg);
        border-radius: 8px;
        padding: 12px;
        margin: -4px -12px 16px -12px;
        transform: translateY(-1px);
        box-shadow: var(--shadow-sm);
    }

    .clickable-project:active {
        transform: translateY(0);
        background: var(--bg-tertiary);
    }

    /* Progress Overview */
    .progress-legend {
        display: flex;
        gap: 16px;
        font-size: 12px;
    }

    .legend-item {
        display: flex;
        align-items: center;
        gap: 6px;
    }

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

    .dot.todo { background: #6B7280; }
    .dot.progress { background: var(--accent-blue); }
    .dot.review { background: var(--accent-amber); }
    .dot.done { background: var(--accent-green); }

    .progress-visualization {
        margin-top: 16px;
    }

    /* Activity Feed */
    .view-all-btn {
        padding: 6px 12px;
        background: var(--bg-tertiary);
        border: 1px solid var(--border);
        border-radius: 6px;
        color: var(--text-secondary);
        font-size: 12px;
        cursor: pointer;
        transition: all 0.2s;
    }

    .view-all-btn:hover {
        background: var(--accent-blue);
        color: white;
        border-color: var(--accent-blue);
    }

    .activity-feed {
        max-height: 300px;
        overflow-y: auto;
    }

    .activity-item {
        display: flex;
        align-items: flex-start;
        gap: 12px;
        padding: 12px 0;
        border-bottom: 1px solid var(--border-light);
    }

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

    .activity-icon {
        width: 32px;
        height: 32px;
        border-radius: 8px;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 14px;
        flex-shrink: 0;
    }

    .activity-icon.completed { background: rgba(16, 185, 129, 0.15); color: var(--accent-green); }
    .activity-icon.created { background: rgba(59, 130, 246, 0.15); color: var(--accent-blue); }
    .activity-icon.updated { background: rgba(245, 158, 11, 0.15); color: var(--accent-amber); }

    .activity-content {
        flex: 1;
    }

    .activity-text {
        font-size: 14px;
        color: var(--text-primary);
        margin-bottom: 2px;
    }

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

    /* Insights */
    .insights-badge {
        background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
        color: white;
        padding: 4px 8px;
        border-radius: 12px;
        font-size: 11px;
        font-weight: 600;
    }

    .insights-list {
        display: flex;
        flex-direction: column;
        gap: 8px;
    }

    .insight-item {
        display: flex;
        align-items: flex-start;
        gap: 12px;
        padding: 12px;
        border-radius: 12px;
        border-left: 4px solid;
    }

    .insight-item.priority {
        background: rgba(59, 130, 246, 0.12);
        border-left-color: var(--accent-blue);
    }

    .insight-item.success {
        background: rgba(16, 185, 129, 0.12);
        border-left-color: var(--accent-green);
    }

    .insight-item.warning {
        background: rgba(245, 158, 11, 0.12);
        border-left-color: var(--accent-amber);
    }

    /* Dark mode insight improvements */
    [data-theme="dark"] .insight-item.priority {
        background: rgba(59, 130, 246, 0.08);
        border-left-color: #60a5fa;
    }

    [data-theme="dark"] .insight-item.success {
        background: rgba(16, 185, 129, 0.08);
        border-left-color: #34d399;
    }

    [data-theme="dark"] .insight-item.warning {
        background: rgba(245, 158, 11, 0.08);
        border-left-color: #fbbf24;
    }

    .insight-icon {
        font-size: 16px;
        margin-top: 2px;
    }

    .insight-title {
        font-size: 14px;
        font-weight: 600;
        color: var(--text-primary);
        margin-bottom: 4px;
    }

    .insight-desc {
        font-size: 13px;
        color: var(--text-secondary);
        line-height: 1.4;
    }

    /* Quick Actions */
    .quick-actions-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 12px;
    }

    .quick-action {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 8px;
        padding: 20px 16px;
        background: var(--bg-secondary);
        border: 1px solid var(--border);
        border-radius: 12px;
        cursor: pointer;
        transition: all 0.2s;
        text-align: center;
        color: var(--text-primary);
    }

    .quick-action:hover {
        background: var(--accent-blue);
        color: white;
        transform: translateY(-2px);
        box-shadow: var(--shadow-md);
    }
    
    .quick-action:hover .qa-text,
    .quick-action:hover .qa-icon {
        color: white;
    }

    .qa-icon {
        font-size: 24px;
        color: inherit;
    }

    .qa-text {
        font-size: 12px;
        font-weight: 500;
        color: inherit;
    }



    /* Responsive Design */
    @media (max-width: 1200px) {
        .dashboard-grid {
            grid-template-columns: 1fr;
        }
        
        .hero-stats {
            grid-template-columns: 1fr;
        }
    }

    @media (max-width: 768px) {
        .enhanced-stats-grid {
            grid-template-columns: 1fr;
        }
        
        .quick-actions-grid {
            grid-template-columns: 1fr;
        }
        
        .dashboard-actions {
            flex-direction: column;
        }
    }

    .projects-header {
        display: flex;
        align-items: center;
        margin-bottom: 24px;
        gap: 16px;
    }

    /* Projects header layout: left = search + chips + sort, right = new project */
    .projects-left { display:flex; align-items:center; gap:12px; }
    .projects-filters-toolbar { display:flex; align-items:center; gap:12px; background: var(--bg-secondary); border: 1px solid var(--border); border-radius: 12px; padding: 10px 14px; flex: 0 1 auto; }
    .projects-right { display:flex; align-items:center; margin-left: auto; }

    .projects-search {
        padding:8px 12px; border-radius:10px; border:1px solid var(--border); background:var(--bg-card); color:var(--text-primary);
        min-width:360px; font-size:14px; box-shadow:var(--shadow-sm);
    }
    .projects-search:focus { outline:none; box-shadow:var(--shadow-md); border-color:var(--accent-blue); }

    .projects-filters { display:flex; gap:8px; }
    .pf-chip { padding:6px 10px; border-radius:999px; background:transparent; border:1px solid var(--border); color:var(--text-secondary); cursor:pointer; font-size:13px; }
    .pf-chip.active { background: linear-gradient(90deg, rgba(59,130,246,0.06), rgba(16,185,129,0.03)); border-color:var(--accent-blue); color:var(--text-primary); box-shadow:var(--shadow-sm); }

    .projects-sort select { padding:8px 10px; border-radius:8px; border:1px solid var(--border); background:var(--bg-card); color:var(--text-primary); }

    /* Projects sort button (replaces select) */
    .projects-filters { display:flex; gap:8px; align-items:center; }

    .projects-sort-standalone { position: relative; display:flex; align-items:center; margin: 0; flex: 0 0 auto; }

    /* Projects sort button: filled pill similar to All Tasks sort button */
    .sort-btn {
        padding:8px 16px; border-radius:8px; background:var(--bg-tertiary); color:var(--text-secondary); cursor:pointer; display:inline-flex; align-items:center; gap:8px; border: 1px solid var(--border);
        transition: all 0.15s;
    }
    .sort-btn:hover {
        background: var(--hover-bg);
        color: var(--text-primary);
    }
    .sort-btn.manual {
        background: var(--accent-blue);
        color: white;
    }
    .sort-btn.disabled { opacity:0.6; cursor:default; }

    .projects-sort-panel {
        position: absolute; z-index:40; top:calc(100% + 8px); left:0; background:var(--bg-card); border:1px solid var(--border); border-radius:8px; box-shadow:var(--shadow-md); display:none; min-width:200px;
    }
    .projects-sort-panel[aria-hidden="false"] { display:block; }
    .projects-sort-panel .dropdown-list { list-style:none; margin:0; padding:8px; }
    .projects-sort-panel .dropdown-list li { margin:0; }
    .projects-sort-panel .projects-sort-option { width:100%; text-align:left; padding:8px 10px; background:none; border:none; color:var(--text-primary); cursor:pointer; border-radius:6px; }
    .projects-sort-panel .projects-sort-option:hover { background:var(--bg-tertiary); }

/* Ensure Projects sort button looks like the filled pill used in All Tasks.
   Higher specificity to avoid being overridden by the generic .sort-btn rules. */
.projects-sort-standalone .sort-btn {
    padding:16px 14px; border-radius:12px; background:var(--bg-secondary); color:var(--text-secondary); cursor:pointer; display:inline-flex; align-items:center; gap:8px; border: 1px solid var(--border);
    transition: all 0.15s;
}
.projects-sort-standalone .sort-btn:hover { background: var(--hover-bg); color: var(--text-primary); }
.projects-sort-standalone .sort-btn.manual { background: var(--accent-blue); color: white; }
.projects-sort-standalone .sort-btn.disabled, .projects-sort-standalone .sort-btn[disabled] { opacity:0.6; cursor:default; color:var(--text-muted); background: transparent; }

    /* Dark mode tweaks for Projects header only */
    [data-theme="dark"] .projects-search { background:var(--bg-secondary); border-color:var(--border-light); color:var(--text-primary); box-shadow:none; }
    [data-theme="dark"] .pf-chip { border-color:var(--border-light); color:var(--text-secondary); }
    [data-theme="dark"] .pf-chip.active { background: linear-gradient(90deg, rgba(59,130,246,0.08), rgba(16,185,129,0.03)); }

    /* Inline sort control for Projects view (compact and theme-aware) */
    .projects-controls-inline { display:flex; align-items:center; gap:8px; }
    .projects-sort select {
        padding:8px 10px; border-radius:8px; border:1px solid var(--border); background:var(--bg-card); color:var(--text-primary); font-size:13px;
        box-shadow: var(--shadow-sm);
    }
    .projects-sort select:focus { outline: none; box-shadow: var(--shadow-md); border-color: var(--accent-blue); }

    .add-btn {
        padding: 10px 16px;
        background: var(--accent-blue);
        color: white;
        border: none;
        border-radius: 8px;
        cursor: pointer;
        font-weight: 500;
        transition: all 0.2s;
        height: 48px; /* Fixed height */
        flex-shrink: 0;
    }

    .project-grid {
        display: grid;
        gap: 16px;
    }

    .project-card {
        background: var(--bg-card);
        border: 1px solid var(--border);
        border-radius: 12px;
        padding: 24px;
        cursor: pointer;
        transition: all 0.2s;
        box-shadow: var(--shadow-card);
    }

    .project-card:hover {
        transform: translateY(-2px);
        border-color: var(--accent-blue);
        box-shadow: var(--shadow-lg);
    }

    .project-title {
        font-size: 18px;
        font-weight: 600;
        margin-bottom: 8px;
    }

    .project-description {
        color: var(--text-secondary);
        font-size: 14px;
        margin-bottom: 16px;
    }

    .project-meta {
        display: flex;
        justify-content: space-between;
        align-items: center;
        font-size: 12px;
        color: var(--text-muted);
    }

    .project-stats {
        display: flex;
        gap: 16px;
    }

    /* Mini multi-segment progress bar inside project cards */
    .mini-progress-wrapper {
        display: flex;
        align-items: center;
        gap: 12px;
        margin-bottom: 12px;
    }

    .mini-progress {
        flex: 1 1 auto;
        height: 8px;
        background: var(--bg-tertiary);
        border-radius: 6px;
        overflow: hidden;
        display: flex;
        align-items: stretch;
    }

    .mini-segment {
        height: 100%;
        transition: width 0.4s ease;
    }

    .mini-segment.done { background: var(--accent-green); }
    .mini-segment.progress { background: var(--accent-blue); }
    .mini-segment.review { background: var(--accent-amber); }
    .mini-segment.todo { background: var(--text-muted); }

    .mini-progress-meta {
        white-space: nowrap;
        color: var(--text-muted);
        font-size: 12px;
        flex: 0 0 auto;
    }

    /* Project card header layout */
    .project-card-top {
        display: flex;
        align-items: center;
        gap: 12px;
        margin-bottom: 8px;
    }

    .project-swatch {
        width: 36px;
        height: 36px;
        border-radius: 8px;
        flex: 0 0 auto;
        box-shadow: 0 2px 8px rgba(0,0,0,0.25);
    }

    .project-headline {
        flex: 1 1 auto;
        min-width: 0;
    }

    .project-title {
        font-size: 16px;
        font-weight: 700;
        color: var(--text-primary);
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .project-dates {
        font-size: 12px;
        color: var(--text-muted);
        margin-top: 2px;
    }

    .project-count {
        font-size: 13px;
        color: var(--text-muted);
        flex: 0 0 auto;
    }

    .project-dates-pair {
        margin-bottom: 10px; /* extra space before description */
    }
    /* Square total task count */
    .project-count.square {
        background: var(--bg-tertiary);
        margin-bottom: 12px; /* reduced breathing room to save height */
        width: 40px; /* slightly smaller */
        height: 28px; /* slightly smaller */
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: 6px;
        font-weight: 700;
        color: var(--text-primary);
        box-shadow: var(--shadow-sm);
        font-size: 13px;
        padding: 0 4px;
    }

    /* Elegant date pill */
    .date-pill {
        display: inline-block;
        padding: 6px 10px;
        background: var(--bg-tertiary);
        border-radius: 999px;
        border: 1px solid var(--border-light);
        color: var(--text-muted);
        font-size: 12px;
    }

    .date-sep {
        color: var(--text-muted);
        margin: 0 8px;
        font-size: 14px;
    }

    .project-legend {
        display: flex;
        gap: 12px;
        margin-top: 8px; /* smaller gap */
        align-items: center;
        color: var(--text-muted);
        font-size: 13px;
    }

    .legend-left { display: flex; align-items: center; margin-right: 8px; }

    .project-count.legend-left {
        background: linear-gradient(180deg, rgba(0,0,0,0.03), rgba(0,0,0,0.01));
        border: 1px solid var(--border-strong);
        min-width: 44px;
        height: 28px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: 8px;
        font-weight: 800;
        color: var(--text-primary);
        padding: 0 8px;
        font-size: 13px;
    }

    .project-count.legend-right {
        background: linear-gradient(180deg, rgba(0,0,0,0.03), rgba(0,0,0,0.01));
        border: 1px solid var(--border-strong);
        min-width: 44px;
        height: 28px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: 8px;
        font-weight: 800;
        color: var(--text-primary);
        padding: 0 8px;
        font-size: 13px;
    }

    .project-count.legend-right { margin-left: 8px; }

    /* Inline smaller total count that sits at the end of the legend row */
    .project-count.inline {
        background: var(--bg-tertiary);
        border: 1px solid var(--border-light);
        min-width: 36px;
        height: 24px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: 6px;
        font-weight: 700;
        color: var(--text-primary);
        padding: 0 6px;
        font-size: 12px;
    }

    /* De-emphasize variant for inline count: lower contrast and smaller size */
    .project-count.inline[tabindex] {
        background: transparent;
        border: 1px solid rgba(0,0,0,0.06);
        color: var(--text-muted);
        box-shadow: none;
        font-weight: 600;
        padding: 0 6px;
    }

    [data-theme="dark"] .project-count.inline[tabindex] {
        border-color: rgba(255,255,255,0.04);
        color: var(--text-muted);
    }

    .legend-item {
        display: flex;
        align-items: center;
        gap: 8px;
    }

    .legend-dot {
        width: 12px;
        height: 12px;
        border-radius: 3px;
        display: inline-block;
    }

    .legend-dot.progress { background: var(--accent-blue); }
    .legend-dot.review { background: var(--accent-amber); }
    .legend-dot.todo { background: var(--text-muted); }
    .legend-dot.done { background: var(--accent-green); }

    .legend-label { color: var(--text-muted); font-weight: 600; font-size: 13px; }

    /* Highlight percent at the end of the mini progress */
    .mini-progress-percent {
        background: var(--bg-tertiary);
        color: var(--text-primary);
        padding: 6px 8px;
        border-radius: 8px;
        font-weight: 700;
        font-size: 12px;
        border: 1px solid var(--border-light);
        box-shadow: var(--shadow-sm);
    }

    .project-status-wrap { display: flex; align-items: center; }

    /* space between status badge and count */
    .project-card-top > div:last-child { margin-left: 12px; }

    /* Dark theme tweaks: make date pills slightly lighter for readability */
    [data-theme="dark"] .date-pill {
        /* brighten a touch for better contrast in dark theme */
        background: rgba(255,255,255,0.04);
        border-color: rgba(255,255,255,0.06);
        color: var(--text-secondary);
    }

    /* Slightly lighter date-pill in light mode as well for visibility */
    .project-card .date-pill { opacity: 0.95; }

    .kanban-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 24px;
    }

    /* When calendar view is active we want the Add Task button to align left like Projects */
    .kanban-header.calendar-mode {
        justify-content: flex-start;
        gap: 16px;
        align-items: center;
    }

    .kanban-header.calendar-mode .add-btn {
        margin-left: 0;
    }

    .view-toggle {
        display: flex;
        background: var(--bg-tertiary);
        border-radius: 8px;
        padding: 4px;
    }

    .view-btn {
        padding: 8px 16px;
        border: none;
        background: transparent;
        color: var(--text-secondary);
        border-radius: 6px;
        cursor: pointer;
        transition: all 0.2s;
    }

    .view-btn.active {
        background: var(--accent-blue);
        color: white;
    }

    .kanban-board {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: 16px;
        min-height: 500px;
    }

    .kanban-board.hidden {
        display: none;
    }
    .kanban-column {
        background: var(--bg-card);
        border: 1px solid var(--border);
        border-radius: 12px;
        padding: 12px;
        box-shadow: 0 2px 6px rgba(0,0,0,0.04); /* subtle depth in light mode */
        transition: box-shadow 0.2s;
    }

    [data-theme="dark"] .kanban-column {
        background: var(--bg-secondary);
        border: 1px solid var(--border);
        box-shadow: inset 0 0 0 1px rgba(255,255,255,0.05); /* subtle glow inside */
    }

    .kanban-column:hover {
        box-shadow: 0 4px 10px rgba(0,0,0,0.08);
    }

    /* Sort toggle button next to view toggle */
    .sort-toggle {
        display: flex;
        background: var(--bg-tertiary);
        border-radius: 8px;
        padding: 4px;
    }

    .sort-btn {
        padding: 8px 16px;
        border: none;
        background: transparent;
        color: var(--text-secondary);
        border-radius: 6px;
        cursor: pointer;
        transition: all 0.15s;
        display: flex;
        align-items: center;
        gap: 8px;
        font-size: 14px;
    }

    .sort-btn:hover {
        background: var(--hover-bg);
        color: var(--text-primary);
    }

    .sort-btn.manual {
        background: var(--accent-blue);
        color: white;
    }

    .sort-btn.disabled,
    .sort-btn[disabled] {
        opacity: 0.5;
        cursor: default;
        color: var(--text-muted);
        background: transparent;
        pointer-events: none;
    }

    /* Dragging card effect */
    .task-card.dragging {
        opacity: 0.5;
        transform: scale(0.98);
        cursor: grabbing;
    }

    /* Remove old blue insertion lines */
    .task-card.drag-over-top::before,
    .task-card.drag-over-bottom::after { 
        display: none !important; 
    }

    /* Drag placeholder - shows where card will land */
    .drag-placeholder {
        box-sizing: border-box;
        width: 100%;
        height: 0;
        margin: 0;
        border-radius: 8px;
        background: linear-gradient(135deg, rgba(99,102,241,0.08), rgba(139,92,246,0.05));
        border: 2px dashed rgba(99,102,241,0.4);
        overflow: hidden;
        transition: height 200ms cubic-bezier(0.4,0,0.2,1), 
                    margin 200ms cubic-bezier(0.4,0,0.2,1), 
                    opacity 160ms ease;
        opacity: 0;
        pointer-events: none;
    }

    .drag-placeholder.active {
        height: 90px; /* Adjust to match your actual task card height */
        margin: 8px 0;
        opacity: 1;
    }

    @keyframes pulse {
        0%,100% { opacity: 0.6; }
        50% { opacity: 1; }
    }



    @media (prefers-reduced-motion: reduce) {
        .task-card.drag-over-top::before,
        .task-card.drag-over-bottom::after {
            transition: none;
        }
    }

    .task-card.drag-over-top::before,
    .task-card.drag-over-bottom::after {
        display: none;
    }

    .task-card.drag-over-top { 
        border-top: none;
    }

    .task-card.drag-over-bottom { 
        border-bottom: none;
    }

    .column-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 12px;
    }

    .column-title {
        font-weight: 600;
        display: flex;
        align-items: center;
        gap: 8px;
    }

    .column-count {
        background: var(--bg-tertiary);
        color: var(--text-muted);
        padding: 2px 8px;
        border-radius: 12px;
        font-size: 12px;
    }

    .task-card {
        background: var(--bg-card);
        border: 1px solid var(--border);
        border-radius: 8px;
        padding: 12px;
        margin-bottom: 8px;
        cursor: pointer;
        transition: all 0.2s;
        box-shadow: var(--shadow-sm);
    }

    .task-card:hover {
        transform: translateY(-1px);
        box-shadow: var(--shadow-md);
        border-color: var(--border-strong);
    }

    .task-title {
        font-weight: 500;
        margin-bottom: 6px;
    }

    .task-description {
        font-size: 13px;
        color: var(--text-secondary);
        margin-bottom: 8px;
    }

    .task-meta {
        /* Default (Kanban/task-card): keep the flexible two-side layout to avoid affecting card flow */
        display: flex;
        justify-content: space-between;
        align-items: center;
        font-size: 12px;
        gap: 8px;
    }

    .task-due {
        color: var(--text-muted);
    }

    .task-priority {
        padding: 2px 8px;
        border-radius: 4px;
        font-size: 11px;
        font-weight: 500;
        min-width: 70px;
        text-align: center;
        display: inline-block;
    }

    /* Use a two-column grid layout only in list view and project task lists */
    .list-view .task-meta,
    .project-task-item .task-meta {
        display: grid;
        grid-template-columns: 1fr 220px;
        align-items: center;
        gap: 8px;
        font-size: 12px;
    }

    .list-view .task-priority,
    .project-task-item .task-priority {
        padding: 4px 10px;
        border-radius: 6px;
        font-size: 12px;
        font-weight: 700;
        min-width: 80px;
        text-align: center;
        justify-self: center;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 100%;
        max-width: 120px;
    }

    .priority-high { background: rgba(239, 68, 68, 0.2); color: var(--accent-red); }
    .priority-medium { background: rgba(245, 158, 11, 0.2); color: var(--accent-amber); }
    .priority-low { background: rgba(16, 185, 129, 0.2); color: var(--accent-green); }

    .modal {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(0, 0, 0, 0.7);
        display: none;
        align-items: center;
        justify-content: center;
        z-index: 1000;
    }

    .modal.active {
        display: flex;
    }

    .modal-content {
        background: var(--bg-card);
        border-radius: 16px;
        padding: 32px;
        width: 90%;
        max-width: 900px;
        max-height: 90vh;
        overflow: visible;
        border: 1px solid var(--border);
        box-shadow: var(--shadow-lg);
    }

    .modal-body {
        display: grid;
        grid-template-columns: 2fr 1fr;
        gap: 32px;
        margin-bottom: 24px;
        align-items: start;
        min-height: 400px;
    }

    .modal-left {
        display: flex;
        flex-direction: column;
        min-width: 0;
    }

    .modal-right {
        display: flex;
        flex-direction: column;
        gap: 16px;
        min-width: 280px;
    }

    .modal-right .form-group {
        margin-bottom: 16px;
    }

    .modal-right .form-group:last-child {
        margin-bottom: 0;
    }

    .rich-editor {
        border: 1px solid var(--border);
        border-radius: 8px;
        background: var(--bg-tertiary);
        min-height: 250px;
        overflow: hidden;
        flex: 1;
    }

    .editor-content {
        padding: 12px;
        min-height: 200px;
        outline: none;
        color: var(--text-primary);
        line-height: 1.5;
        overflow-y: auto;
    }

    /* Description editor: contained scroll with themed scrollbars */
    .rich-editor .editor-content {
        /* Keep content within modal height and enable vertical scroll */
        max-height: 40vh;
        overflow-y: auto;
        overflow-x: hidden;
        overscroll-behavior: contain;
        /* Prevent horizontal overflow from long tokens */
        word-break: break-word;
        overflow-wrap: anywhere;
        /* Smooth scroll feel */
        scroll-behavior: smooth;
        /* Firefox scrollbar */
        scrollbar-width: thin;
        scrollbar-color: var(--scrollbar-thumb) var(--bg-tertiary);
    }

    /* WebKit-based browsers (Chrome, Edge, Safari) */
    .rich-editor .editor-content::-webkit-scrollbar {
        width: 10px;
        height: 10px;
    }

    .rich-editor .editor-content::-webkit-scrollbar-track {
        background: var(--bg-tertiary);
        border-radius: 8px;
    }

    .rich-editor .editor-content::-webkit-scrollbar-thumb {
        background: var(--scrollbar-thumb);
        border-radius: 8px;
        border: 2px solid var(--bg-tertiary);
        box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.1);
    }

    .rich-editor .editor-content::-webkit-scrollbar-thumb:hover {
        background: var(--scrollbar-thumb-hover);
    }

    .modal-right .modal-actions {
        margin-top: auto;
    }

    .task-title-display {
        font-size: 24px;
        font-weight: 600;
        margin-bottom: 16px;
        color: var(--text-primary);
    }

    .task-description-display {
        color: var(--text-secondary);
        line-height: 1.6;
        margin-bottom: 20px;
    }

    .status-buttons {
        display: flex;
        gap: 8px;
        margin-bottom: 16px;
    }

    .status-btn {
        padding: 8px 16px;
        border-radius: 20px;
        border: none;
        font-size: 12px;
        font-weight: 500;
        cursor: pointer;
        transition: all 0.2s;
        opacity: 0.6;
    }

    .status-btn.active {
        opacity: 1;
    }

    .status-btn.todo { background: rgba(75, 85, 99, 0.32); color: var(--text-muted); }
    .status-btn.todo.active { background: #4B5563; color: white; }

    .status-btn.progress { background: rgba(59, 130, 246, 0.2); color: var(--accent-blue); }
    .status-btn.progress.active { background: var(--accent-blue); color: white; }

    .status-btn.review { background: rgba(245, 158, 11, 0.2); color: var(--accent-amber); }
    .status-btn.review.active { background: var(--accent-amber); color: white; }

    .status-btn.done { background: rgba(16, 185, 129, 0.2); color: var(--accent-green); }
    .status-btn.done.active { background: var(--accent-green); color: white; }

    .field-group {
        display: flex;
        flex-direction: column;
    }

    .field-label {
        font-size: 12px;
        font-weight: 500;
        color: var(--text-muted);
        margin-bottom: 8px;
        text-transform: uppercase;
        letter-spacing: 0.5px;
    }

    .field-value {
        padding: 12px 16px;
        background: var(--bg-tertiary);
        border: 1px solid var(--border);
        border-radius: 8px;
        color: var(--text-primary);
        font-size: 14px;
    }

    .form-group {
        margin-bottom: 20px;
    }

    .form-label {
        display: block;
        margin-bottom: 8px;
        font-weight: 500;
        color: var(--text-secondary);
    }

    .form-input, .form-textarea, .form-select {
        width: 100%;
        padding: 12px 16px;
        background: var(--bg-tertiary);
        border: 1px solid var(--border);
        border-radius: 8px;
        color: var(--text-primary);
        font-size: 14px;
    }

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

    .modal-actions {
        display: flex;
        gap: 12px;
        justify-content: flex-end;
    }

    .btn-secondary {
        padding: 10px 16px;
        background: var(--bg-tertiary);
        color: var(--text-secondary);
        border: 1px solid var(--border);
        border-radius: 8px;
        cursor: pointer;
    }

    .btn-primary {
        padding: 10px 16px;
        background: var(--accent-blue);
        color: white;
        border: none;
        border-radius: 8px;
        cursor: pointer;
    }

    .empty-state {
        text-align: center;
        padding: 60px 20px;
        color: var(--text-muted);
    }

    .confirm-modal {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(0, 0, 0, 0.8);
        display: none;
        align-items: center;
        justify-content: center;
        z-index: 2000;
    }

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

    .confirm-content {
        background: var(--bg-card);
        border-radius: 12px;
        padding: 24px;
        width: 400px;
        border: 1px solid var(--accent-red);
    }

    .confirm-title {
        color: var(--accent-red);
        font-weight: 600;
        margin-bottom: 16px;
    }

    .confirm-input {
        width: 100%;
        padding: 12px;
        background: var(--bg-tertiary);
        border: 1px solid var(--border);
        border-radius: 6px;
        color: var(--text-primary);
        margin: 12px 0;
    }

    .confirm-actions {
        display: flex;
        gap: 12px;
        justify-content: flex-end;
        margin-top: 16px;
    }

    .options-menu {
        position: absolute;
        right: 0;
        top: 40px;
        background: var(--bg-card);
        border: 1px solid var(--border);
        border-radius: 8px;
        padding: 8px 0;
        display: none;
        z-index: 1001;
        min-width: 160px;
        box-shadow: 0 4px 12px rgba(0,0,0,0.3);
    }

    .delete-btn {
        width: 100%;
        padding: 8px 16px;
        background: none;
        border: none;
        color: var(--accent-red);
        cursor: pointer;
        text-align: left;
        font-size: 14px;
    }    

    .status-dropdown {
        position: relative;
    }

    .status-current {
        width: 100%;
        padding: 12px 16px;
        background: var(--bg-tertiary);
        border: 1px solid var(--border);
        border-radius: 8px;
        color: var(--text-primary);
        display: flex;
        align-items: center;
        cursor: pointer;
        transition: all 0.2s;
        gap: 8px;
    }
    
    .status-current .dropdown-arrow {
        margin-left: auto;
    }

    .status-current:hover {
        border-color: var(--accent-blue);
    }

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

    .status-dot.todo { background: #6B7280; }
    .status-dot.progress { background: var(--accent-blue); }
    .status-dot.review { background: var(--accent-amber); }
    .status-dot.done { background: var(--accent-green); }



    /* Status Badges - Jira-like button style */
    .status-badge {
        display: inline-block;
        padding: 4px 12px;
        border-radius: 4px;
        font-size: 11px;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.5px;
        border: none;
        cursor: default;
    }

    .status-badge.todo { 
        background: #4B5563; 
        color: white;
    }
    .status-badge.progress { 
        background: var(--accent-blue); 
        color: white;
    }
    .status-badge.review { 
        background: var(--accent-amber);
        color: white;
    }
    .status-badge.done { 
        background: var(--accent-green);
        color: white;
    }

    /* Ensure task-status-badge (table/list style) uses stronger colors in dark mode */
    /* Use the stronger dark amber/green variables for dark-mode badges; text uses theme-aware color */
    [data-theme="dark"] .task-status-badge.review { background: var(--accent-amber-strong); color: white; }
    [data-theme="dark"] .task-status-badge.done { background: var(--accent-green-strong); color: white; }

    /* Priority Dots - Clean circles */
    .priority-dot {
        width: 12px;
        height: 12px;
        border-radius: 50%;
        display: inline-block;
        vertical-align: middle;
        margin-right: 6px;
    }

    .priority-dot.high { background: var(--accent-red); }
    .priority-dot.medium { background: var(--accent-amber); }
    .priority-dot.low { background: var(--accent-green); }

    /* Priority dots - same styling as status dots */
    .priority-dot {
        width: 12px;
        height: 12px;
        border-radius: 50%;
        display: inline-block;
        vertical-align: middle;
        margin-right: 8px;
    }

    .priority-dot.high { background: var(--accent-red); }
    .priority-dot.medium { background: var(--accent-amber); }
    .priority-dot.low { background: var(--accent-green); }

    /* Priority dropdown - copy status dropdown styling */
    .priority-dropdown {
        position: relative;
    }

    .priority-current {
        width: 100%;
        padding: 12px 16px;
        background: var(--bg-tertiary);
        border: 1px solid var(--border);
        border-radius: 8px;
        color: var(--text-primary);
        display: flex;
        align-items: center;
        cursor: pointer;
        transition: all 0.2s;
        gap: 8px;
    }
    
    .priority-current .dropdown-arrow {
        margin-left: auto;
    }

    .priority-current:hover {
        border-color: var(--accent-blue);
    }

    .priority-dropdown.active .dropdown-arrow {
        transform: rotate(180deg);
    }

    .priority-options {
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background: var(--bg-tertiary);
        border: 1px solid var(--border);
        border-radius: 8px;
        margin-top: 4px;
        display: none;
        z-index: 1500;
    }

    .priority-dropdown.active .priority-options {
        display: block;
    }

    .priority-option {
        padding: 12px 16px;
        cursor: pointer;
        display: flex;
        align-items: center;
        color: var(--text-primary);
        transition: background-color 0.2s;
    }

    .priority-option:hover {
        background: var(--hover-bg);
    }

    .priority-option:first-child {
        border-radius: 8px 8px 0 0;
    }

    .priority-option:last-child {
        border-radius: 0 0 8px 8px;
    }

    .status-text {
        flex: 1;
        text-align: left;
    }

    .dropdown-arrow {
        font-size: 10px;
        transition: transform 0.2s;
    }

    .status-dropdown.active .dropdown-arrow {
        transform: rotate(180deg);
    }

    .status-options {
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background: var(--bg-tertiary);
        border: 1px solid var(--border);
        border-radius: 8px;
        margin-top: 4px;
        display: none;
        z-index: 1500;
    }

    .status-dropdown.active .status-options {
        display: block;
    }

    .status-option {
        padding: 12px 16px;
        display: flex;
        align-items: center;
        gap: 12px;
        cursor: pointer;
        transition: background 0.2s;
    }

    .status-option:hover {
        background: var(--hover-bg);
    }

    .status-option:first-child {
        border-top-left-radius: 8px;
        border-top-right-radius: 8px;
    }

    .status-option:last-child {
        border-bottom-left-radius: 8px;
        border-bottom-right-radius: 8px;
    }

    .editor-toolbar {
        padding: 8px 12px;
        border-bottom: 1px solid var(--border);
        display: flex;
        gap: 4px;
        flex-wrap: wrap;
    }

    .editor-btn {
        padding: 4px 8px;
        background: transparent;
        border: 1px solid transparent;
        border-radius: 4px;
        color: var(--text-secondary);
        cursor: pointer;
        font-size: 14px;
        transition: all 0.2s;
    }

    .editor-btn:hover {
        background: var(--hover-bg);
        color: var(--text-primary);
    }

    .editor-btn.active {
        background: var(--accent-blue);
        color: white;
    }


    .editor-content h1, .editor-content h2, .editor-content h3 {
        margin: 8px 0 4px 0;
        color: var(--text-primary);
    }

    .editor-content ul, .editor-content ol {
        margin: 8px 0;
        padding-left: 24px;
    }

    .editor-content hr {
        margin: 12px 0;
        border: none;
        border-top: 1px solid var(--border);
    }

    .tasks-table {
            width: 100%;
            border-collapse: collapse;
            margin-top: 16px;
        }

        .tasks-table th {
            background: var(--bg-secondary);
            padding: 12px 16px;
            text-align: left;
            font-size: 12px;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            color: var(--text-muted);
            border-bottom: 2px solid var(--border);
        }

        .tasks-table td {
            padding: 16px;
            border-bottom: 1px solid var(--border);
            color: var(--text-secondary);
        }

        .tasks-table td:nth-child(3) {
            text-align: left;
        }

        .tasks-table tr {
            transition: background 0.2s;
        }

        .tasks-table tbody tr:hover {
            background: var(--bg-secondary);
            cursor: pointer;
        }

        .task-status-badge {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            padding: 4px 12px;
            border-radius: 12px;
            font-size: 12px;
            font-weight: 500;
            min-width: 110px;  /* Add this */
            justify-content: center;  /* Add this */
        }

    .task-status-badge.todo { background: rgba(75, 85, 99, 0.32); color: #D1D5DB; }
        .task-status-badge.progress { background: rgba(59, 130, 246, 0.2); color: var(--accent-blue); }
        .task-status-badge.review { background: rgba(245, 158, 11, 0.2); color: var(--accent-amber); }
        .task-status-badge.done { background: rgba(16, 185, 129, 0.2); color: var(--accent-green); }

        .list-view {
            display: none;
        }

        .list-view.active {
            display: block;
        }

        .tasks-table th:hover {
            background: var(--bg-tertiary);
        }

        .tasks-table th span {
            font-size: 10px;
            opacity: 0.5;
            margin-left: 4px;
        }

        .calendar-view {
            display: none;
        }

        .calendar-view.active {
            display: block;
        }

        /* When preparing, render calendar offscreen/inert until ready */
        .calendar-view.preparing {
            display: block;            /* ensure it can be measured */
            opacity: 0;                /* invisible during prep */
            pointer-events: none;      /* don't intercept input */
        }

        .calendar-container {
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 12px;
            padding: 24px;
        }

        .calendar-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 24px;
        }

        .calendar-nav {
            display: flex;
            align-items: center;
            gap: 16px;
        }

        .calendar-nav button {
            padding: 8px 12px;
            background: var(--bg-tertiary);
            border: 1px solid var(--border);
            border-radius: 6px;
            color: var(--text-secondary);
            cursor: pointer;
            transition: all 0.2s;
        }

        .calendar-nav button:hover {
            background: var(--hover-bg);
            color: var(--text-primary);
        }

        .calendar-month-year {
            font-size: 20px;
            font-weight: 600;
            min-width: 180px;
            text-align: center;
        }

        .calendar-grid {
            display: grid;
            grid-template-columns: repeat(7, 1fr);
            gap: 1px;
            background: var(--border);
            border: 1px solid var(--border);
            border-radius: 8px;
            overflow: hidden;
        }

        /* Ensure overlay sits above grid for absolute-positioned project bars */
        .project-overlay {
            position: absolute;
            inset: 0;
            pointer-events: none; /* bars re-enable pointer-events individually */
            opacity: 0; /* hidden until bars are placed to avoid flicker */
            transition: opacity 120ms ease;
            max-width: 100%;
            overflow: hidden;
        }

        .calendar-day-header {
            background: var(--bg-secondary);
            padding: 12px 8px;
            text-align: center;
            font-size: 12px;
            font-weight: 600;
            text-transform: uppercase;
            color: var(--text-muted);
        }

        .calendar-day {
            background: var(--bg-primary);
            min-height: 100px;
            padding: 8px;
            position: relative;
            cursor: pointer;
            transition: all 0.2s;
            display: flex;
            flex-direction: column;
            border: 1px solid var(--border-light);
        }

        .calendar-day:hover {
            background: var(--bg-secondary);
            border-color: var(--border);
            box-shadow: var(--shadow-sm);
        }

        .calendar-day.other-month {
            opacity: 0.3;
        }

        .calendar-day.today {
            background: rgba(59, 130, 246, 0.1);
            border: 2px solid var(--accent-blue);
        }

        .calendar-day.today .calendar-day-number {
            color: var(--accent-blue);
            font-weight: 700;
            font-size: 14px;
        }

        .calendar-day-number {
            font-size: 14px;
            font-weight: 500;
            margin-bottom: 4px;
        }

        /* Container where day tasks live; spacing now handled by a dynamic spacer element */
        .tasks-container { margin-top: 4px; }

        .calendar-task {
            background: var(--bg-card);
            border: 1px solid var(--border-light);
            border-left: 3px solid var(--accent-blue);
            border-radius: 4px;
            box-shadow: var(--shadow-sm);
            padding: 2px 6px;
            margin: 3px 0;  /* Proper spacing between tasks */
            font-size: 11px;
            color: var(--text-secondary);
            cursor: pointer;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            transition: all 0.2s;
            position: relative;
            z-index: 20;  /* Below project bars */
        }

        .calendar-task:hover {
            background: var(--bg-tertiary);
            color: var(--text-primary);
        }

        .calendar-task.priority-high {
            border-left-color: var(--accent-red);
        }

        .calendar-task.priority-medium {
            border-left-color: var(--accent-amber);
        }

        .calendar-task.priority-low {
            border-left-color: var(--accent-green);
        }

        .calendar-task.done {
            opacity: 0.5;
            text-decoration: line-through;
        }

        .calendar-more {
            font-size: 10px;
            color: var(--accent-blue);
            margin-top: 2px;
            cursor: pointer;
        }

        .calendar-today-btn {
            padding: 8px 16px;
            background: var(--accent-blue);
            color: white;
            border: none;
            border-radius: 6px;
            cursor: pointer;
            font-weight: 500;
            transition: all 0.2s;
        }

        .calendar-today-btn:hover {
            background: var(--accent-blue);
            opacity: 0.9;
        }

        .project-details-view {
            display: none;
        }

        .project-details-view.active {
            display: flex;
            flex-direction: column;
            height: 100vh;
        }

        .project-details-container {
            display: flex;
            flex-direction: column;
            gap: 24px;
            max-width: none;
            margin: 0;
            width: 100%;
        }

        .project-details-header {
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 12px;
            padding: 32px;
            margin-bottom: 24px;
        }

        .project-details-title {
            font-size: 32px;
            font-weight: 700;
            margin-bottom: 16px;
            display: flex;
            align-items: center;
            gap: 16px;
        }

        .project-status-badge {
            font-size: 14px;
            padding: 6px 16px;
            border-radius: 20px;
            font-weight: 500;
            cursor: pointer;
            transition: all 0.2s;
        }

        .project-status-badge.todo {
            background: rgba(107, 114, 128, 0.2);
            color: var(--text-muted);
        }

        .project-status-badge.active {
            background: rgba(59, 130, 246, 0.2);
            color: var(--accent-blue);
        }

        .project-status-badge.planning {
            background: rgba(107, 114, 128, 0.2);
            color: var(--text-muted);
        }

        .project-status-badge.completed {
            background: rgba(16, 185, 129, 0.2);  /* Green for completed */
            color: var(--accent-green);
        }

        .project-details-description {
            font-size: 16px;
            line-height: 1.6;
            color: var(--text-secondary);
            margin-bottom: 24px;
        }

        .project-timeline {
            display: flex;
            gap: 32px;
            padding-top: 24px;
            border-top: 1px solid var(--border);
        }

        .timeline-item {
            flex: 1;
        }

        .timeline-label {
            font-size: 12px;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            color: var(--text-muted);
            margin-bottom: 8px;
        }

        .timeline-value {
            font-size: 18px;
            font-weight: 600;
            color: var(--text-primary);
        }

        .project-progress-section {
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 12px;
            padding: 24px;
            margin-bottom: 24px;
        }

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

        .progress-title {
            font-size: 18px;
            font-weight: 600;
        }

        .progress-percentage {
            font-size: 24px;
            font-weight: 700;
            color: var(--accent-green);
        }

        .progress-bar-container {
            background: var(--bg-tertiary);
            height: 12px;
            border-radius: 6px;
            overflow: hidden;
            margin-bottom: 24px;
        }

        .progress-bar-fill {
            height: 100%;
            background: linear-gradient(90deg, var(--accent-blue), var(--accent-green));
            transition: width 0.3s ease;
        }

        .progress-stats {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 16px;
        }

        .progress-stat {
            text-align: center;
            padding: 16px;
            background: var(--bg-tertiary);
            border-radius: 8px;
        }

        .progress-stat.clickable {
            cursor: pointer;
            transition: background 0.2s ease;
        }

        .progress-stat.clickable:hover {
            background: var(--accent-blue);
            color: white !important;
        }
        
        .progress-stat.clickable:hover .progress-stat-number,
        .progress-stat.clickable:hover .progress-stat-label {
            color: white !important;
        }

        .progress-stat-number {
            font-size: 24px;
            font-weight: 700;
            margin-bottom: 4px;
        }

        .progress-stat-label {
            font-size: 12px;
            color: var(--text-muted);
            text-transform: uppercase;
        }

        .project-tasks-section {
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 12px;
            padding: 24px;
        }

        .section-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 24px;
        }

        .section-title {
            font-size: 18px;
            font-weight: 600;
        }

        .back-btn {
            padding: 8px 24px;
            background: #6366f1;
            border: 1px solid #5b21b6;
            border-radius: 8px;
            color: white;
            cursor: pointer;
            font-size: 14px;
            transition: all 0.2s;
        }

        .back-btn:hover {
            background: #5b21b6;
            color: white;
        }

        .project-task-item {
            background: var(--bg-secondary);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 16px;
            margin-bottom: 12px;
            display: grid;
            /* Match the same right column width used in task-meta for symmetry */
            grid-template-columns: 1fr 220px;
            align-items: center;
            gap: 12px;
            cursor: pointer;
            transition: all 0.2s;
        }

        .project-task-item:hover {
            transform: translateX(4px);
            border-color: var(--accent-blue);
        }

        .project-task-info {
            flex: 1;
        }

        .project-task-title {
            font-weight: 500;
            margin-bottom: 4px;
        }

        .project-task-meta {
            font-size: 12px;
            color: var(--text-muted);
            justify-self: start;
        }

        .project-task-status {
            display: flex;
            gap: 12px;
            align-items: center;
            justify-self: center;
            min-width: 220px;
            justify-content: center;
        }

        /* Make badges inside project-task-status equal width and centered */
        .project-task-status > .task-priority,
        .project-task-status > .status-badge {
            min-width: 100px;
            max-width: 120px;
            display: inline-flex;
            align-items: center;
            justify-content: center;
        }

        /* Responsive: stack meta on small screens */
        @media (max-width: 900px) {
            .task-meta, .project-task-item { grid-template-columns: 1fr; }
            .project-task-status { justify-self: start; }
        }
        .user-menu {
            position: fixed;
            top: 24px;
            right: 32px;
            z-index: 2000;
            display: inline-block;
        }
        .user-avatar {
            width: 32px;
            height: 32px;
            background: var(--accent-blue);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            font-size: 14px;
            font-weight: 600;
            color: white;
            transition: all 0.2s;
        }

        .user-avatar:hover {
            background: var(--accent-blue);
            opacity: 0.9;
            transform: scale(1.05);
        }

        .user-dropdown {
            position: absolute;
            top: 100%;
            right: 0;
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 8px;
            min-width: 180px;
            display: none;
            z-index: 1000;
            box-shadow: 0 4px 12px rgba(0,0,0,0.15);
            margin-top: 8px;
        }

        .user-dropdown.active {
            display: block;
        }

        .dropdown-header {
            padding: 12px 16px;
            border-bottom: 1px solid var(--border);
        }

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

        .user-email {
            font-size: 12px;
            color: var(--text-muted);
            margin-top: 2px;
        }

        .dropdown-item {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 10px 16px;
            cursor: pointer;
            font-size: 14px;
            color: var(--text-secondary);
            transition: background 0.2s;
        }

        .dropdown-item:hover {
            background: var(--hover-bg);
            color: var(--text-primary);
        }

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

        .editable-description {
            width: 100%;
            min-height: 80px;
            padding: 12px;
            border: 1px solid var(--border);
            border-radius: 8px;
            background: var(--bg-tertiary);
            color: var(--text-primary);
            font-family: inherit;
            font-size: 16px;
            line-height: 1.6;
            resize: vertical;
        }

        .editable-date {
            padding: 8px 12px;
            border: 1px solid var(--border);
            border-radius: 6px;
            background: var(--bg-tertiary);
            color: var(--text-primary);
            font-size: 18px;
            font-weight: 600;
        }

        .calendar-project {
            background: linear-gradient(90deg, #6366f1, #8b5cf6);
            color: white;
            border-radius: 4px;
            padding: 2px 6px;
            margin: 2px 0;
            font-size: 10px;
            font-weight: 500;
            cursor: pointer;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            transition: all 0.2s;
            position: relative;
        }

        .calendar-project-span {
            background: linear-gradient(90deg, #6366f1, #8b5cf6);
            color: white;
            border-radius: 8px;
            padding: 4px 8px;
            font-size: 11px;
            font-weight: 500;
            cursor: pointer;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            transition: all 0.2s;
            box-shadow: 0 2px 4px rgba(0,0,0,0.1);
        }

        .calendar-project-span:hover {
            background: linear-gradient(90deg, #5b21b6, #7c3aed);
            transform: translateY(-1px);
            box-shadow: 0 4px 8px rgba(0,0,0,0.2);
        }
        
        .calendar-project:hover {
            background: linear-gradient(90deg, #5b21b6, #7c3aed);
            transform: translateY(-1px);
        }

        .calendar-project-start {
            border-top-left-radius: 8px;
            border-bottom-left-radius: 8px;
            border-top-right-radius: 2px;
            border-bottom-right-radius: 2px;
        }

        .calendar-project-end {
            border-top-left-radius: 2px;
            border-bottom-left-radius: 2px;
            border-top-right-radius: 8px;
            border-bottom-right-radius: 8px;
            background: linear-gradient(90deg, #8b5cf6, #a855f7);
        }

        .calendar-project-middle {
            border-radius: 2px;
            background: linear-gradient(90deg, #7c3aed, #8b5cf6);
        }

        .calendar-project-start::before {
            content: '';
            position: absolute;
            left: 0;
            top: 0;
            bottom: 0;
            width: 3px;
            background: #4c1d95;
            border-radius: 8px 0 0 8px;
        }

        .project-overlay {
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            pointer-events: none;
            z-index: 25;  /* Above tasks (z-index: 20) */
        }

        .project-bar {
            position: absolute;
            background: linear-gradient(90deg, #6366f1, #8b5cf6);
            color: white;
            border-radius: 4px;
            padding: 2px 8px;
            font-size: 10px;
            font-weight: 500;
            height: 18px;
            display: flex;
            align-items: center;
            box-shadow: 0 2px 4px rgba(0,0,0,0.3);
            pointer-events: auto;
            z-index: 30;  /* Highest priority */
            cursor: pointer;
        }

        /* === Global Filters Toolbar === */
        .filters-toolbar {
            display: flex;
            flex-wrap: wrap;
            gap: 12px;
            align-items: center;
            background: var(--bg-secondary);
            border: 1px solid var(--border);
            border-radius: 12px;
            padding: 12px 16px;
            margin-bottom: 16px;
        }

        /* Projects filters toolbar — visually matches .filters-toolbar used by All Tasks but scoped to Projects */
        .projects-filters-toolbar {
            display: flex;
            flex-wrap: wrap;
            gap: 12px;
            align-items: center;
            background: var(--bg-secondary);
            border: 1px solid var(--border);
            border-radius: 12px;
            padding: 10px 14px;
            margin-right: 12px;
        }
        .projects-filters-toolbar .projects-search {
            padding: 8px 12px; background: var(--bg-tertiary); border: 1px solid var(--border); border-radius: 8px; color: var(--text-primary); font-size: 14px; min-width: 260px;
        }
        .projects-filters-toolbar .pf-chip { padding: 6px 10px; background: var(--bg-tertiary); border: 1px solid var(--border); border-radius: 8px; color: var(--text-secondary); }
        .projects-filters-toolbar .pf-chip.active { background: linear-gradient(90deg, rgba(59,130,246,0.12), rgba(16,185,129,0.06)); border-color:var(--accent-blue); color:var(--text-primary); }
        .filter-input {
            padding: 8px 12px;
            background: var(--bg-tertiary);
            border: 1px solid var(--border);
            border-radius: 8px;
            color: var(--text-primary);
            font-size: 14px;
            min-width: 320px;  /* Increased from 220px */
        }
        .filter-group {
            position: relative;
        }
        .filter-button {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            padding: 8px 12px;
            background: var(--bg-tertiary);
            border: 1px solid var(--border);
            border-radius: 8px;
            color: var(--text-secondary);
            cursor: pointer;
            font-size: 14px;
        }
        .filter-button:hover { background: var(--hover-bg); color: var(--text-primary); }
        .filter-count-badge {
            background: var(--bg-secondary);
            border: 1px solid var(--border);
            border-radius: 10px;
            padding: 0 6px;
            font-size: 11px;
            color: var(--text-muted);
        }
        .dropdown-panel {
            position: absolute;
            top: calc(100% + 6px);
            left: 0;
            min-width: 240px;
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 10px;
            box-shadow: var(--shadow-lg);
            z-index: 1200;
            display: none;
            padding: 8px 0;
        }
        .filter-group.open .dropdown-panel { display: block; }
        .dropdown-section-title {
            font-size: 12px;
            color: var(--text-muted);
            padding: 6px 12px;
            text-transform: uppercase;
            letter-spacing: 0.3px;
        }
        .dropdown-list {
            max-height: 240px;
            overflow-y: auto;
        }
        .dropdown-list li {
            list-style: none;
            padding: 0;
            display: block;
        }

        .dropdown-list li label {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 8px 12px;
            cursor: pointer;
            font-size: 14px;
            color: var(--text-secondary);
            transition: background 0.2s, color 0.2s;
        }

        .dropdown-list li label:hover {
            background: var(--hover-bg);
        }

        .dropdown-list input[type="checkbox"] {
            cursor: pointer;
            flex-shrink: 0;
        }                    

        .dropdown-list li:hover { background: var(--hover-bg); }
        .dropdown-list input[type="checkbox"] { cursor: pointer; }
        .active-filters {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
            margin: 8px 0 16px 0;
        }
        /* === Active filter chips (dark + light mode) === */
        .filter-chip {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 4px 10px;
            border-radius: 16px;
            font-size: 12px;
            font-weight: 500;
            background: rgba(37, 99, 235, 0.15); /* subtle blue highlight */
            border: 1px solid var(--accent-blue);
            color: var(--accent-blue);
            transition: background 0.2s, color 0.2s;
        }

        .filter-chip .chip-remove {
            background: none;
            border: none;
            cursor: pointer;
            font-size: 14px;
            color: var(--accent-blue);
            line-height: 1;
        }

        .filter-chip:hover {
            background: rgba(37, 99, 235, 0.25); /* slightly stronger on hover */
        }

        /* small colored dots for status chips */
        .dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
        .dot.todo { background: var(--text-muted); }
        .dot.progress { background: var(--accent-blue); }
        .dot.review { background: var(--accent-amber); }
        .dot.done { background: var(--accent-green); }
        .dot.high { background: var(--accent-red); }
        .dot.medium { background: var(--accent-amber); }
        .dot.low { background: var(--accent-green); }

        /* === Priority badges (adaptable to dark/light mode) === */
        .priority-badge {
            display: inline-block;
            padding: 4px 8px;
            border-radius: 4px;
            font-size: 11px;
            font-weight: 500;
            min-width: 70px;
            text-align: center;
            text-transform: uppercase;
        }

        .priority-high {
            background: rgba(239, 68, 68, 0.2); /* accent red, semi-transparent */
            color: var(--accent-red);
        }

        .priority-medium {
            background: rgba(245, 158, 11, 0.2); /* accent amber */
            color: var(--accent-amber);
        }

        .priority-low {
            background: rgba(16, 185, 129, 0.2); /* green */
            color: var(--accent-green);
        }

        .select-all-row {
            border-bottom: 1px solid var(--border);
            margin-bottom: 6px;
            padding-bottom: 6px;
        }
        .select-all-row strong {
            font-size: 12px;
            color: var(--accent-blue);
        }

        /* === Clear Filters Button === */
        .btn-clear-filters {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 6px;
            padding: 6px 12px; /* Match other filters */
            font-size: 14px;
            line-height: 20px;
            font-weight: 500;
            border-radius: 8px;
            border: 1px solid transparent;
            cursor: pointer;
            transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, opacity 0.2s ease;
        }

        /* --- Dark Mode --- */
        body[data-theme="dark"] .btn-clear-filters {
            background: #9b1c31; /* deeper, slightly muted red */
            color: #ffffff;
            border-color: #9b1c31;
        }

        body[data-theme="dark"] .btn-clear-filters:hover {
            background: #e63063;
            border-color: #e63063;
        }

        /* Light mode Kanban lanes */
        body:not([data-theme="dark"]) .kanban-column {
            background: var(--bg-card);
            border: 2px solid var(--border);
            border-radius: 12px;
            padding: 16px;
            box-shadow: var(--shadow-sm);
            transition: all 0.2s ease;
        }
        body:not([data-theme="dark"]) .kanban-column:hover {
            box-shadow: var(--shadow-md);
            transform: translateY(-2px);
        }

        /* Dark mode flatpickr fixes */
        [data-theme="dark"] .flatpickr-prev-month svg,
        [data-theme="dark"] .flatpickr-next-month svg {
            fill: var(--text-primary) !important;
        }
        [data-theme="dark"] .flatpickr-weekday {
            color: var(--text-muted) !important;
        }


        /* Icon inside the button */
        .btn-clear-filters .filter-icon {
            font-size: 16px;
            line-height: 1;
        }

        .view-toggle.hidden {
            display: none;
        }        

   /* === Flatpickr Dark-Mode Theme & Date-Input Styling === */

        /* Calendar container */
        .flatpickr-calendar {
            background: var(--bg-card) !important;
            border: 1px solid var(--border) !important;
            box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
            color: var(--text-primary) !important;
            font-family: inherit;
            font-size: 14px;
        }

        /* Arrow triangles */
        .flatpickr-calendar.arrowTop:before,
        .flatpickr-calendar.arrowTop:after {
            border-bottom-color: var(--border) !important;
        }
        .flatpickr-calendar.arrowTop:after {
            border-bottom-color: var(--bg-card) !important;
        }

        /* Month header bar */
        .flatpickr-months {
            background: var(--bg-secondary) !important;
            padding: 6px 8px;
        }

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

        /* Prev/Next arrows */
        .flatpickr-prev-month,
        .flatpickr-next-month {
            color: var(--text-primary) !important;
            fill: var(--text-primary) !important;
        }

        .flatpickr-prev-month svg,
        .flatpickr-next-month svg {
            fill: var(--text-primary) !important;
        }

        /* Month & year selectors */
        .flatpickr-current-month {
            color: var(--text-primary) !important;
        }

        .flatpickr-monthDropdown-months {
            background: var(--bg-tertiary) !important;
            color: var(--text-primary) !important;
        }

        .flatpickr-monthDropdown-months option {
            background: var(--bg-tertiary) !important;
            color: var(--text-primary) !important;
        }

        .numInput.cur-year {
            background: var(--bg-tertiary) !important;
            color: var(--text-primary) !important;
            border-color: var(--border) !important;
        }

        /* Weekday labels */
        .flatpickr-weekdays {
            background: var(--bg-secondary) !important;
        }

        .flatpickr-weekday {
            color: var(--text-muted) !important;
        }

        /* Days container */
        .flatpickr-days {
            background: var(--bg-card) !important;
        }

        /* Individual day cells - THE FIX */
        .flatpickr-day {
            background: transparent !important;
            color: var(--text-primary) !important;
            border: none !important;
        }

        /* Hover state */
        .flatpickr-day:hover:not(.selected):not(.today) {
            background: var(--hover-bg) !important;
            border: 1px solid var(--accent-blue) !important;
        }

        /* Today */
        .flatpickr-day.today {
            background: transparent !important;
            border: 1px solid var(--accent-blue) !important;
            color: var(--accent-blue) !important;
        }

        .flatpickr-day.today:hover {
            background: var(--hover-bg) !important;
        }

        /* Selected day */
        .flatpickr-day.selected,
        .flatpickr-day.startRange,
        .flatpickr-day.endRange {
            background: var(--accent-blue) !important;
            color: #fff !important;
            border: 1px solid var(--accent-blue) !important;
        }

        /* In-range days */
        .flatpickr-day.inRange {
            background: rgba(59, 130, 246, 0.15) !important;
            border: none !important;
        }

        /* Disabled days */
        .flatpickr-day.disabled,
        .flatpickr-day.disabled:hover {
            background: transparent !important;
            color: var(--text-muted) !important;
            opacity: 0.4 !important;
            cursor: not-allowed !important;
        }

        /* Previous/next month days */
        .flatpickr-day.prevMonthDay,
        .flatpickr-day.nextMonthDay {
            color: var(--text-muted) !important;
            opacity: 0.5 !important;
        }

        /* Date input wrapper */
        .date-input-wrapper {
            position: relative;
            width: 100%;
        }

        .date-input-wrapper input {
            box-sizing: border-box;
        }

        .date-input-wrapper .date-display {
            width: 100%;
            padding: 10px 14px;
            background: var(--bg-tertiary);
            border: 1px solid var(--border);
            border-radius: 6px;
            color: var(--text-primary);
            font-size: 14px;
            cursor: text;
        }

        /* Form element borders */
        .form-input,
        .form-textarea,
        .form-select,
        .modal-content,
        .task-card,
        .project-card,
        .kanban-column,
        .dropdown-panel {
            border: 1px solid var(--border-strong);
        }     

        .feedback-input-bar {
            display: flex;
            gap: 12px;
            margin-bottom: 24px;
            align-items: stretch; /* Changed from center to stretch */
        }

        .feedback-type-select {
            padding: 12px 16px;
            padding-right: 40px;
            background: var(--bg-tertiary);
            border: 1px solid var(--border);
            border-radius: 8px;
            color: var(--text-primary);
            font-size: 14px;
            cursor: pointer;
            min-width: 140px;
            height: 48px;
            /* Remove default arrow */
            appearance: none;
            -webkit-appearance: none;
            -moz-appearance: none;
            /* Add custom arrow */
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23d1d5db' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
            background-repeat: no-repeat;
            background-position: right 16px center;
        } 

        [data-theme="dark"] .feedback-type-select {
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239ca3af' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
        }        

        .feedback-input {
            flex: 1;
            padding: 12px 16px;
            background: var(--bg-tertiary);
            border: 1px solid var(--border);
            border-radius: 8px;
            color: var(--text-primary);
            font-size: 14px;
            height: 48px; /* Fixed height */
        }

        .feedback-item {
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 16px;
            margin-bottom: 12px;
            display: flex;
            align-items: center;
            gap: 16px;
            transition: all 0.2s;
        }

        .feedback-item.done {
            opacity: 0.5;
        }

        .feedback-item:hover {
            border-color: var(--accent-blue);
        }

        .feedback-checkbox {
            width: 20px;
            height: 20px;
            cursor: pointer;
        }

        .feedback-type-icon {
            font-size: 20px;
        }

        .feedback-description {
            flex: 1;
            color: var(--text-primary);
        }

        .feedback-item.done .feedback-description {
            text-decoration: line-through;
        }

        .feedback-date {
            font-size: 12px;
            color: var(--text-muted);
        }        

        .screenshot-link {
            padding: 12px 16px;
            background: var(--bg-tertiary);
            border: 1px solid var(--border);
            border-radius: 8px;
            color: var(--text-primary);
            text-decoration: none;
            font-size: 18px;
            transition: all 0.2s;
            display: flex;
            align-items: center;
            justify-content: center;
            height: 48px; /* Fixed height */
            width: 48px; /* Make it square */
            flex-shrink: 0;
        }

        .screenshot-link:hover {
            background: var(--hover-bg);
            border-color: var(--accent-blue);
        }

        .feedback-item {
            position: relative;
        }

        .feedback-delete-btn {
            margin-left: auto;
            background: none;
            color: var(--text-muted);
            border: none;
            padding: 4px 8px;
            cursor: pointer;
            font-size: 16px;
            opacity: 0;
            transition: opacity 0.2s;
        }

        .feedback-item:hover .feedback-delete-btn {
            opacity: 1;
        }

        .feedback-delete-btn:hover {
            color: var(--accent-red);
        }

        .feedback-screenshot-link {
            color: var(--accent-blue);
            text-decoration: none;
            font-size: 16px;
            margin-left: 8px;
            margin-right: 8px;
        }

        .feedback-screenshot-link:hover {
            opacity: 0.7;
        }   

        .camera-divider {
            font-size: 20px;
            color: var(--text-muted);
            display: flex;
            align-items: center;
            flex-shrink: 0;
        }

        .screenshot-upload-link {
            padding: 12px 16px;
            background: var(--bg-tertiary);
            border: 1px solid var(--border);
            border-radius: 8px;
            color: var(--text-secondary);
            text-decoration: none;
            font-size: 14px;
            transition: all 0.2s;
            display: flex;
            align-items: center;
            justify-content: center;
            height: 48px;
            width: 48px;
            flex-shrink: 0;
        }

        .screenshot-upload-link:hover {
            background: var(--hover-bg);
            border-color: var(--accent-blue);
            color: var(--text-primary);
        }        

        .editable-project-title {
            background: transparent;
            border: none;
            font-size: 32px;
            font-weight: 700;
            color: var(--text-primary);
            padding: 0;
            margin: 0;
            outline: none;
            border-bottom: 2px solid transparent;
            transition: border-color 0.2s;
        }

        .editable-project-title:hover,
        .editable-project-title:focus {
            border-bottom-color: var(--accent-blue);
        }        

        .project-details-title {
            font-size: 32px;
            font-weight: 700;
            margin-bottom: 16px;
            display: flex;
            align-items: center;
            gap: 16px;
        }

        #project-title-display {
            cursor: pointer;
            border-bottom: 2px solid transparent;
            transition: border-color 0.2s;
        }

        #project-title-display:hover {
            border-bottom-color: var(--accent-blue);
        }

        #project-title-edit {
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .editable-project-title {
            background: var(--bg-tertiary);
            border: 1px solid var(--border);
            border-radius: 6px;
            font-size: 32px;
            font-weight: 700;
            color: var(--text-primary);
            padding: 4px 12px;
            outline: none;
        }

        .title-edit-btn {
            padding: 8px 12px;
            border: none;
            border-radius: 6px;
            cursor: pointer;
            font-size: 18px;
            font-weight: 600;
            transition: all 0.2s;
        }

        .title-edit-btn.confirm {
            background: var(--accent-green);
            color: white;
        }

        .title-edit-btn.cancel {
            background: var(--accent-red);
            color: white;
        }

        .title-edit-btn:hover {
            opacity: 0.8;
        } 

        .task-card.selected {
            border: 2px solid var(--accent-blue);
            background: rgba(59, 130, 246, 0.1);
        }        

        .attachment-item {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 8px 12px;
            background: var(--bg-tertiary);
            border: 1px solid var(--border);
            border-radius: 6px;
            margin-bottom: 6px;
            transition: all 0.2s;
        }

        .attachment-item:hover {
            border-color: var(--accent-blue);
        }

        .attachment-link {
            display: flex;
            align-items: center;
            gap: 8px;
            flex: 1;
            text-decoration: none;
            color: var(--text-primary);
            font-size: 13px;
        }

        .attachment-icon {
            font-size: 16px;
        }

        .attachment-name {
            flex: 1;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }

        .attachment-external {
            font-size: 12px;
            color: var(--accent-blue);
        }

        .attachment-remove {
            background: none;
            border: none;
            color: var(--text-muted);
            cursor: pointer;
            padding: 4px;
            opacity: 0;
            transition: opacity 0.2s;
        }

        .attachment-item:hover .attachment-remove {
            opacity: 1;
        }

        .attachment-remove:hover {
            color: var(--accent-red);
        }        

        .modal-content {
            display: flex;
            flex-direction: column;
            max-height: 90vh;  /* keep modal inside viewport */
        }

        .modal-body {
            flex: 1;
            overflow-y: auto;  /* scroll body only */
            display: grid;
            grid-template-columns: 2fr 1fr;
            gap: 32px;
            min-height: 300px;
        }

        /* New sticky footer */
        .modal-footer {
            display: flex;
            justify-content: flex-end;
            gap: 12px;
            padding: 16px 0 0 0;
            border-top: 1px solid var(--border);
            background: var(--bg-card);
            position: sticky;
            bottom: 0;
            z-index: 10;
        }

        /* unifies all <select class="form-select"> arrows */
        .form-select {
        appearance: none;
        -webkit-appearance: none;
        -moz-appearance: none;
        padding-right: 40px;                 /* room for the arrow */
        background-repeat: no-repeat;
        background-position: right 16px center;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23d1d5db' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
        border-radius: 8px !important;       /* force rounded corners */
        }

        [data-theme="dark"] .form-select {
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239ca3af' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
        }
        
        .form-input:focus,
        .form-textarea:focus,
        .form-select:focus {
            outline: none;                      /* remove default browser outline */
            border-color: var(--accent-blue);   /* highlight border with theme color */
            box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.4); /* subtle glow */
            background: var(--bg-tertiary);     /* keep same background */
            color: var(--text-primary);
        }        

        .confirm-error {
            background: rgba(239, 68, 68, 0.1);
            border: 1px solid var(--accent-red);
            color: var(--accent-red);
            padding: 10px 12px;
            border-radius: 6px;
            font-size: 13px;
            margin-top: 12px;
            display: none;
        }

        .confirm-error.show {
            display: block;
        }        

        /* Custom Project Dropdown */
        .project-dropdown {
            position: relative;
            width: 100%;
        }
        
        .project-current {
            width: 100%;
            padding: 12px 16px;
            background: var(--bg-tertiary);
            border: 1px solid var(--border);
            border-radius: 8px;
            color: var(--text-primary);
            font-size: 14px;
            font-family: inherit;
            cursor: pointer;
            display: flex;
            justify-content: space-between;
            align-items: center;
            transition: all 0.2s;
            text-align: left;
        }
        
        .project-current:hover {
            border-color: var(--accent-blue);
        }

        .project-current .dropdown-arrow {
            margin-left: auto;
            font-size: 10px;
            transition: transform 0.2s;
        }
        
        .project-dropdown.active .project-current {
            border-color: var(--accent-blue);
            box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.4);
        }
        
        .project-dropdown.active .dropdown-arrow {
            transform: rotate(180deg);
        }
        
        .project-options {
            position: absolute;
            top: 100%;
            left: 0;
            right: 0;
            background: var(--bg-tertiary);
            border: 1px solid var(--border);
            border-radius: 8px;
            margin-top: 4px;
            display: none;
            z-index: 1500;
            max-height: 200px;
            overflow-y: auto;
        }
        
        /* Disable inline project options display; portal handles rendering */
        .project-dropdown.active .project-options {
            display: none;
        }
        
        .project-option {
            padding: 12px 16px;
            cursor: pointer;
            transition: background 0.2s;
            color: var(--text-primary);
        }
        
        .project-option:hover {
            background: var(--hover-bg);
        }
        
        .project-option:first-child {
            border-top-left-radius: 8px;
            border-top-right-radius: 8px;
        }
        
        .project-option:last-child {
            border-bottom-left-radius: 8px;
            border-bottom-right-radius: 8px;
        }

        /* Floating portal for Project dropdown (renders at <body> level) */
        .project-options-portal {
            position: fixed;
            background: var(--bg-tertiary);
            border: 1px solid var(--border);
            border-radius: 8px;
            margin-top: 4px; /* visual spacing when shown below */
            z-index: 3000; /* above modal (1000) and user menu (2000) */
            max-height: 200px; /* match .project-options */
            overflow-y: auto;
            box-shadow: var(--shadow-lg);
            scroll-behavior: smooth;
            box-sizing: border-box; /* include border in width to align with trigger */
        }

        .project-portal-search {
            position: sticky;
            top: 0;
            background: var(--bg-tertiary);
            padding: 8px;
            border-bottom: 1px solid var(--border);
            z-index: 1;
        }
        .project-portal-search .form-input {
            width: 100%;
            padding: 8px 10px;
            font-size: 13px;
        }

        /* Themed scrollbar (WebKit) */
        .project-options-portal::-webkit-scrollbar {
            width: 10px;
        }
        .project-options-portal::-webkit-scrollbar-track {
            background: var(--bg-tertiary);
            border-left: 1px solid var(--border);
            border-radius: 0 8px 8px 0;
        }
        .project-options-portal::-webkit-scrollbar-thumb {
            background: var(--hover-bg);
            border: 2px solid var(--bg-tertiary);
            border-radius: 8px;
        }
        .project-options-portal::-webkit-scrollbar-thumb:hover {
            background: rgba(255,255,255,0.12);
        }

        /* Themed scrollbar (Firefox) */
        .project-options-portal { 
            scrollbar-width: thin; 
            scrollbar-color: var(--hover-bg) var(--bg-tertiary);
        }

        .day-items-modal {
            display: none;
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: rgba(0, 0, 0, 0.7);
            z-index: 1000;
            align-items: center;
            justify-content: center;
        }

        .day-items-modal.active {
            display: flex;
        }

        .day-items-content {
            background: var(--bg-secondary);
            border-radius: 12px;
            padding: 32px;
            max-width: 600px;
            width: 90%;
            max-height: 80vh;
            overflow-y: auto;
            box-shadow: var(--shadow-lg);
            border: 1px solid var(--border);
        }

        .day-items-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 24px;
            padding-bottom: 16px;
            border-bottom: 1px solid var(--border);
        }

        .day-items-title {
            font-size: 20px;
            font-weight: 600;
            color: var(--text-primary);
        }

        .day-items-close {
            background: none;
            border: none;
            font-size: 24px;
            cursor: pointer;
            color: var(--text-muted);
            padding: 4px;
            line-height: 1;
        }

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

        .day-items-section {
            margin-bottom: 24px;
        }

        .day-items-section:last-child {
            margin-bottom: 0;
        }

        .day-items-section-title {
            font-size: 14px;
            font-weight: 600;
            color: var(--text-secondary);
            margin-bottom: 12px;
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }

        .day-item {
            background: var(--bg-tertiary);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 12px 16px;
            margin-bottom: 8px;
            cursor: pointer;
            transition: all 0.2s;
            box-shadow: var(--shadow-sm);
        }

        .day-item:hover {
            background: var(--hover-bg);
            border-color: var(--accent-blue);
            box-shadow: var(--shadow-md);
        }

        .day-item-title {
            font-size: 15px;
            font-weight: 500;
            color: var(--text-primary);
            margin-bottom: 4px;
        }

        .day-item-meta {
            font-size: 13px;
            color: var(--text-muted);
        }

        .day-items-empty {
            text-align: center;
            padding: 40px 20px;
            color: var(--text-muted);
        }

        .day-items-empty-icon {
            font-size: 48px;
            margin-bottom: 16px;
            opacity: 0.5;
        }        /* Priority LOW = BLUE - Updated 10/04/2025 16:16:47 */

.enhanced-stat-card:active { transform: translateY(0px) scale(0.98); }