        /* ═══════════════════════════════════════════════════════════════
           SEASONAL TEMPLATE RULES
           ═══════════════════════════════════════════════════════════════ */

        .calendar-seasonal-btn {
            font-size: var(--text-caption);
            white-space: nowrap;
        }

        /* Auto-assigned indicator on month cards */
        .month-card-template.auto-assigned {
            color: var(--primary);
            font-style: italic;
        }

        /* Seasonal rules modal overlay */
        .seasonal-rules-overlay {
            position: fixed;
            inset: 0;
            z-index: 10000;
            display: flex;
            align-items: center;
            justify-content: center;
            background: rgba(0,0,0,0.5);
            backdrop-filter: blur(8px);
            -webkit-backdrop-filter: blur(8px);
            opacity: 0;
            visibility: hidden;
            transition: opacity 0.25s ease, visibility 0.25s ease;
        }

        .seasonal-rules-overlay.show {
            opacity: 1;
            visibility: visible;
        }

        .seasonal-rules-modal {
            background: var(--glass-bg);
            backdrop-filter: blur(var(--glass-blur));
            -webkit-backdrop-filter: blur(var(--glass-blur));
            border: 1px solid var(--glass-border);
            border-radius: var(--radius-xl);
            box-shadow: var(--glass-shadow);
            padding: var(--space-lg);
            max-width: 480px;
            width: 90vw;
            max-height: 85vh;
            overflow-y: auto;
            transform: scale(0.95);
            transition: transform 0.25s ease;
        }

        .seasonal-rules-overlay.show .seasonal-rules-modal {
            transform: scale(1);
        }

        .seasonal-rules-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: var(--space-xs);
        }

        .seasonal-rules-header h3 {
            font-size: var(--text-title);
            font-weight: var(--font-bold);
            color: var(--text-primary);
            margin: 0;
        }

        .seasonal-rules-desc {
            font-size: var(--text-caption);
            color: var(--text-secondary);
            margin-bottom: var(--space-md);
            line-height: 1.4;
        }

        .seasonal-rules-footer {
            display: flex;
            justify-content: flex-end;
            margin-top: var(--space-md);
        }

        /* Rule cards */
        .seasonal-rule-card {
            background: var(--bg-secondary);
            border-radius: var(--radius-md);
            padding: var(--space-sm) var(--space-md);
            margin-bottom: var(--space-xs);
        }

        .seasonal-rule-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
        }

        .seasonal-rule-template {
            font-weight: var(--font-semibold);
            color: var(--primary);
            font-size: var(--text-body);
        }

        .seasonal-rule-delete {
            background: none;
            border: none;
            font-size: 1.2rem;
            color: var(--text-secondary);
            cursor: pointer;
            padding: 2px 6px;
            border-radius: var(--radius-sm);
            min-width: 44px;
            min-height: 44px;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .seasonal-rule-delete:hover {
            color: var(--danger);
            background: var(--danger-light);
        }

        .seasonal-rule-months {
            font-size: var(--text-caption);
            color: var(--text-secondary);
            margin-top: 2px;
        }

        /* Empty state */
        .seasonal-empty {
            text-align: center;
            padding: var(--space-xl) var(--space-md);
        }

        .seasonal-empty-icon {
            font-size: 2rem;
            margin-bottom: var(--space-sm);
        }

        .seasonal-empty-text {
            font-size: var(--text-caption);
            color: var(--text-secondary);
            line-height: 1.5;
        }

        /* Add rule form */
        .seasonal-add-rule {
            border-top: 1px solid var(--glass-border);
            padding-top: var(--space-md);
            margin-top: var(--space-sm);
        }

        .seasonal-add-title {
            font-weight: var(--font-semibold);
            color: var(--text-primary);
            font-size: var(--text-body);
            margin-bottom: var(--space-sm);
        }

        .seasonal-add-form {
            display: flex;
            flex-direction: column;
            gap: var(--space-sm);
        }

        .seasonal-select {
            width: 100%;
            padding: var(--space-sm);
            border: 1px solid var(--glass-border);
            border-radius: var(--radius-md);
            background: var(--bg-secondary);
            color: var(--text-primary);
            font-size: var(--text-body);
            -webkit-appearance: none;
            appearance: none;
        }

        .seasonal-month-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: var(--space-xs);
        }

        .seasonal-month-checkbox {
            display: flex;
            align-items: center;
            gap: 4px;
            padding: var(--space-xs);
            border-radius: var(--radius-sm);
            cursor: pointer;
            font-size: var(--text-caption);
            color: var(--text-primary);
            transition: background 0.15s ease;
        }

        .seasonal-month-checkbox:hover {
            background: var(--bg-secondary);
        }

        .seasonal-month-checkbox input[type="checkbox"] {
            accent-color: var(--primary);
        }

        .seasonal-quick-presets {
            display: flex;
            gap: var(--space-xs);
            flex-wrap: wrap;
        }

        .seasonal-quick-presets .btn {
            font-size: 11px;
            padding: 2px 8px;
        }

        .seasonal-add-btn {
            align-self: flex-end;
        }

        @media (prefers-reduced-motion: reduce) {
            .seasonal-rules-overlay,
            .seasonal-rules-modal {
                transition: none;
            }
        }

        /* ═══════════════════════════════════════════════════════════════
           BUDGET vs ACTUAL — CALENDAR MONTH CARD INTEGRATION
           ═══════════════════════════════════════════════════════════════ */

        .month-card-actions {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-top: auto;
        }

        .month-card-actuals-btn {
            background: none;
            border: 1px solid var(--border-light);
            border-radius: var(--radius-sm);
            padding: 3px 8px;
            font-size: var(--text-micro, 10px);
            font-weight: var(--font-medium);
            color: var(--person-0);
            cursor: pointer;
            transition: all var(--duration-fast);
            white-space: nowrap;
            min-height: var(--touch-target);
            display: flex;
            align-items: center;
        }

        .month-card-actuals-btn:hover {
            background: var(--person-0-light);
            border-color: var(--person-0);
        }

        @media (max-width: 480px) {
            .month-card-actions {
                flex-direction: column;
                gap: 4px;
            }

            .month-card-actuals-btn {
                width: 100%;
                justify-content: center;
            }
        }

        /* ═══════════════════════════════════════════════════════════════
           BUDGET vs ACTUAL COMPARISON VIEW
           ═══════════════════════════════════════════════════════════════ */

        .actuals-modal-overlay {
            display: none;
            position: fixed;
            inset: 0;
            z-index: 1000;
            background: rgba(0,0,0,0.5);
            backdrop-filter: blur(8px);
            -webkit-backdrop-filter: blur(8px);
            justify-content: center;
            align-items: center;
        }

        .actuals-modal-overlay.show {
            display: flex;
        }

        .actuals-modal {
            background: var(--bg-primary);
            border-radius: var(--radius-lg);
            box-shadow: var(--shadow-xl);
            width: 92%;
            max-width: 780px;
            max-height: 90vh;
            overflow-y: auto;
            padding: var(--space-lg);
            display: flex;
            flex-direction: column;
        }

        .actuals-modal-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            position: sticky;
            top: calc(-1 * var(--space-lg));
            margin: calc(-1 * var(--space-lg)) calc(-1 * var(--space-lg)) var(--space-md) calc(-1 * var(--space-lg));
            padding: var(--space-lg) var(--space-lg) var(--space-sm);
            background: var(--bg-primary);
            z-index: 2;
            border-bottom: 1px solid var(--border-light);
        }

        .actuals-modal-header-left {
            display: flex;
            align-items: center;
            gap: var(--space-sm);
        }

        .actuals-modal-header h2 {
            font-size: var(--text-heading);
            font-weight: var(--font-bold);
            margin: 0;
        }

        .actuals-adherence-badge {
            display: inline-flex;
            align-items: center;
            padding: 2px 10px;
            border-radius: var(--radius-full);
            font-size: var(--text-small);
            font-weight: var(--font-semibold);
            white-space: nowrap;
        }

        .actuals-adherence-badge.excellent {
            background: var(--success-light);
            color: var(--success);
        }

        .actuals-adherence-badge.good {
            background: var(--success-light);
            color: var(--success);
        }

        .actuals-adherence-badge.fair {
            background: var(--warning-light);
            color: var(--warning);
        }

        .actuals-adherence-badge.poor {
            background: var(--danger-light);
            color: var(--danger);
        }

        /* Month card adherence badge */
        .month-adherence-badge {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            padding: 1px 6px;
            border-radius: var(--radius-full);
            font-size: var(--text-micro, 10px);
            font-weight: var(--font-semibold);
            margin-top: 4px;
        }

        .month-adherence-badge.excellent,
        .month-adherence-badge.good {
            background: var(--success-light);
            color: var(--success);
        }

        .month-adherence-badge.fair {
            background: var(--warning-light);
            color: var(--warning);
        }

        .month-adherence-badge.poor {
            background: var(--danger-light);
            color: var(--danger);
        }

        /* Summary Cards */
        .actuals-summary-row {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: var(--space-sm);
            margin-bottom: var(--space-md);
        }

        .actuals-summary-card {
            text-align: center;
            padding: var(--space-sm);
            background: var(--glass-bg);
            backdrop-filter: blur(var(--glass-blur));
            -webkit-backdrop-filter: blur(var(--glass-blur));
            border: 1px solid var(--glass-border);
            border-radius: var(--radius-md);
            box-shadow: var(--glass-shadow);
        }

        .actuals-summary-label {
            font-size: var(--text-small);
            color: var(--text-secondary);
            margin-bottom: 4px;
        }

        .actuals-summary-value {
            font-size: var(--text-lg);
            font-weight: var(--font-bold);
            font-variant-numeric: tabular-nums;
        }

        /* Bulk Actions */
        .actuals-bulk-actions {
            display: flex;
            justify-content: flex-end;
            gap: var(--space-sm);
            margin-bottom: var(--space-sm);
        }

        /* Person Toggle */
        .actuals-person-toggle {
            display: flex;
            justify-content: flex-end;
            margin-bottom: var(--space-sm);
        }

        .actuals-toggle-btn {
            font-size: var(--text-small);
            padding: 4px 12px;
        }

        .actuals-toggle-btn.active {
            background: var(--person-0-light);
            color: var(--person-0);
            border-color: var(--person-0);
        }

        .solo-mode .actuals-person-toggle {
            display: none;
        }

        /* Column Headers */
        .actuals-column-headers {
            display: grid;
            grid-template-columns: 1fr 100px 140px 110px;
            gap: var(--space-xs);
            padding: var(--space-xs) 0;
            font-size: var(--text-small);
            font-weight: var(--font-semibold);
            color: var(--text-tertiary);
            text-transform: uppercase;
            letter-spacing: 0.5px;
            border-bottom: 2px solid var(--border-light);
            margin-bottom: var(--space-sm);
        }

        .actuals-column-headers div:nth-child(n+2) {
            text-align: right;
        }

        /* Type Section Header */
        .actuals-type-header {
            font-size: var(--text-small);
            font-weight: var(--font-bold);
            color: var(--text-secondary);
            text-transform: uppercase;
            letter-spacing: 0.5px;
            padding: var(--space-sm) 0 var(--space-xs);
            margin-top: var(--space-sm);
        }

        .actuals-type-header:first-child {
            margin-top: 0;
        }

        /* Category */
        .actuals-category {
            margin-bottom: var(--space-xs);
        }

        .actuals-category.collapsed .actuals-category-items {
            display: none;
        }

        .actuals-category.collapsed .actuals-expand-icon {
            transform: rotate(-90deg);
        }

        .actuals-category-header {
            display: grid;
            grid-template-columns: 1fr 100px 100px 110px 20px;
            gap: var(--space-xs);
            align-items: center;
            padding: var(--space-xs) 0;
            font-weight: var(--font-semibold);
            font-size: var(--text-body);
            cursor: pointer;
            border-bottom: 1px solid var(--border-light);
            user-select: none;
            transition: background var(--duration-fast);
            border-radius: var(--radius-xs);
        }

        .actuals-category-header:hover {
            background: var(--bg-secondary);
        }

        .actuals-category-planned,
        .actuals-category-actual {
            text-align: right;
            font-variant-numeric: tabular-nums;
            font-size: var(--text-small);
            color: var(--text-secondary);
        }

        .actuals-category-variance {
            text-align: right;
            font-variant-numeric: tabular-nums;
            font-size: var(--text-small);
            font-weight: var(--font-semibold);
            display: flex;
            flex-direction: column;
            align-items: flex-end;
        }

        .actuals-pct {
            font-size: var(--text-micro, 10px);
            opacity: 0.7;
        }

        .actuals-expand-icon {
            text-align: center;
            font-size: var(--text-small);
            color: var(--text-muted);
            transition: transform var(--duration-fast);
        }

        /* Items */
        .actuals-item {
            display: grid;
            grid-template-columns: 1fr 100px 140px 110px;
            gap: var(--space-xs);
            align-items: center;
            padding: var(--space-xs) 0;
            font-size: var(--text-body);
        }

        .actuals-item-name {
            font-weight: var(--font-medium);
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
            padding-left: var(--space-md);
        }

        .actuals-item-planned {
            color: var(--text-secondary);
            font-size: var(--text-small);
            white-space: nowrap;
            text-align: right;
            font-variant-numeric: tabular-nums;
        }

        .actuals-item-actual {
            display: flex;
            align-items: center;
            gap: 4px;
        }

        .actuals-input {
            flex: 1;
            min-width: 0;
            padding: 6px 8px;
            border: 1px solid var(--border-light);
            border-radius: var(--radius-sm);
            font-size: var(--text-body);
            font-variant-numeric: tabular-nums;
            text-align: right;
            background: var(--bg-secondary);
            color: var(--text-primary);
            box-sizing: border-box;
            transition: border-color var(--duration-fast), box-shadow var(--duration-fast);
        }

        .actuals-input:focus {
            border-color: var(--person-0);
            box-shadow: 0 0 0 3px var(--person-0-light);
            outline: none;
        }

        .actuals-as-planned {
            min-width: 32px;
            min-height: 32px;
            padding: 4px 8px;
            border: 1px solid var(--border-light);
            border-radius: var(--radius-sm);
            background: var(--bg-tertiary);
            color: var(--text-secondary);
            font-size: var(--text-small);
            font-weight: var(--font-medium);
            cursor: pointer;
            transition: all var(--duration-fast);
            flex-shrink: 0;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .actuals-as-planned:hover {
            background: var(--success-light);
            border-color: var(--success);
            color: var(--success);
        }

        .actuals-as-planned.active {
            background: var(--success-light);
            border-color: var(--success);
            color: var(--success);
        }

        /* Variance color coding */
        .actuals-item-variance,
        .actuals-category-variance,
        .actuals-person-variance {
            font-variant-numeric: tabular-nums;
            text-align: right;
            white-space: nowrap;
        }

        .actuals-item-variance.under,
        .actuals-category-variance.under,
        .actuals-person-variance.under {
            color: var(--success);
        }

        .actuals-item-variance.on-budget,
        .actuals-category-variance.on-budget,
        .actuals-person-variance.on-budget {
            color: var(--success);
        }

        .actuals-item-variance.warning,
        .actuals-category-variance.warning,
        .actuals-person-variance.warning {
            color: var(--warning);
        }

        .actuals-item-variance.over,
        .actuals-category-variance.over,
        .actuals-person-variance.over {
            color: var(--danger);
        }

        .actuals-no-data {
            color: var(--text-muted);
        }

        /* Per-person breakdown rows */
        .actuals-person-breakdown {
            padding-left: calc(var(--space-md) + var(--space-sm));
        }

        .actuals-person-row {
            display: grid;
            grid-template-columns: 1fr 100px 100px 110px;
            gap: var(--space-xs);
            align-items: center;
            padding: 2px 0;
            font-size: var(--text-small);
        }

        .actuals-person-name {
            font-weight: var(--font-medium);
        }

        .actuals-person-planned,
        .actuals-person-actual {
            text-align: right;
            font-variant-numeric: tabular-nums;
            color: var(--text-secondary);
        }

        .solo-mode .actuals-person-breakdown {
            display: none !important;
        }

        /* Review Section */
        .actuals-review-section {
            margin-top: var(--space-lg);
            padding-top: var(--space-md);
            border-top: 1px solid var(--border-light);
        }

        .actuals-review-section label {
            display: block;
            font-size: var(--text-small);
            font-weight: var(--font-semibold);
            color: var(--text-secondary);
            margin-bottom: var(--space-xs);
        }

        .actuals-review-notes {
            width: 100%;
            padding: var(--space-sm);
            border: 1px solid var(--border-light);
            border-radius: var(--radius-sm);
            font-size: var(--text-body);
            font-family: inherit;
            background: var(--bg-secondary);
            color: var(--text-primary);
            resize: vertical;
            box-sizing: border-box;
        }

        .actuals-review-notes:focus {
            border-color: var(--person-0);
            box-shadow: 0 0 0 3px var(--person-0-light);
            outline: none;
        }

        /* Actions Bar */
        .actuals-actions {
            display: flex;
            align-items: center;
            gap: var(--space-sm);
            margin-top: var(--space-md);
            padding-top: var(--space-md);
            border-top: 1px solid var(--border-light);
        }

        .actuals-actions .btn:first-child {
            margin-right: auto;
        }

        /* Trend Chart Section */
        .actuals-trend-section {
            margin-top: var(--space-lg);
            padding-top: var(--space-md);
            border-top: 1px solid var(--border-light);
        }

        .actuals-trend-title {
            font-size: var(--text-body);
            font-weight: var(--font-semibold);
            color: var(--text-primary);
            margin-bottom: var(--space-sm);
        }

        .actuals-trend-chart-container {
            height: 140px;
            position: relative;
        }

        .actuals-trend-empty {
            display: flex;
            align-items: center;
            justify-content: center;
            height: 100%;
            color: var(--text-muted);
            font-size: var(--text-small);
        }

        /* Responsive */
        @media (max-width: 768px) {
            .actuals-modal {
                width: 100%;
                max-width: 100%;
                height: 100%;
                max-height: 100%;
                border-radius: 0;
            }

            .actuals-column-headers {
                grid-template-columns: 1fr 70px 110px 80px;
                font-size: var(--text-micro, 10px);
            }

            .actuals-item {
                grid-template-columns: 1fr 70px 110px 80px;
            }

            .actuals-category-header {
                grid-template-columns: 1fr 70px 70px 80px 20px;
            }

            .actuals-person-row {
                grid-template-columns: 1fr 70px 70px 80px;
            }

            .actuals-summary-row {
                grid-template-columns: 1fr;
                gap: var(--space-xs);
            }

            .actuals-summary-card {
                display: flex;
                justify-content: space-between;
                align-items: center;
                text-align: left;
            }

            .actuals-item-name {
                padding-left: var(--space-sm);
            }
        }

        @media (max-width: 480px) {
            .actuals-column-headers {
                grid-template-columns: 1fr 60px 90px 70px;
            }

            .actuals-item {
                grid-template-columns: 1fr 60px 90px 70px;
            }

            .actuals-category-header {
                grid-template-columns: 1fr 60px 60px 70px 16px;
                font-size: var(--text-small);
            }

            .actuals-input {
                padding: 4px 6px;
                font-size: var(--text-small);
            }

            .actuals-as-planned {
                min-width: 28px;
                min-height: 28px;
                padding: 2px 6px;
            }
        }

        @media (prefers-reduced-motion: reduce) {
            .actuals-modal-overlay,
            .actuals-modal,
            .actuals-expand-icon,
            .actuals-input,
            .actuals-as-planned,
            .actuals-category-header {
                transition: none;
            }
        }

