/**
 * Billing Section Styles
 * Simplified billing tab with staff summary table
 * BEM methodology: Block__Element--Modifier
 */

/* ============================================================================
   BASE CONTAINER
   ============================================================================ */

.billing-section {
    padding: 16px;
    padding-bottom: 32px;
    max-width: 900px;
    margin: 0 auto;
}

.billing-section--loading,
.billing-section--error {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 48px;
    color: var(--color-text-muted);
}

.billing-section--error {
    color: var(--color-danger);
}

.billing-section__spinner {
    width: 32px;
    height: 32px;
    border: 3px solid var(--color-border);
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: billing-spin 0.8s linear infinite;
}

@keyframes billing-spin {
    to { transform: rotate(360deg); }
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

/* ============================================================================
   STATUS PIPELINE - Modern Sleek Design
   ============================================================================ */

.billing-pipeline {
    position: relative;
    padding: 12px 16px;
    margin-bottom: 20px;
}

.billing-pipeline__track {
    position: absolute;
    top: 50%;
    left: 32px;
    right: 32px;
    height: 3px;
    background: var(--color-border);
    border-radius: 2px;
    transform: translateY(-50%);
    margin-top: -8px;
}

.billing-pipeline__progress {
    height: 100%;
    background: linear-gradient(90deg, var(--color-success), var(--color-success-light, var(--color-success)));
    border-radius: 2px;
    transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
}

.billing-pipeline__progress::after {
    content: '';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translate(50%, -50%);
    width: 8px;
    height: 8px;
    background: var(--color-success);
    border-radius: 50%;
    box-shadow: 0 0 8px var(--color-success);
    opacity: 0;
    animation: pipeline-pulse 2s ease-in-out infinite;
}

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

.billing-pipeline__steps {
    display: flex;
    justify-content: space-between;
    position: relative;
    z-index: 1;
}

.billing-pipeline__step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    flex: 1;
    max-width: 80px;
}

.billing-pipeline__marker {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--color-card-bg);
    border: 2px solid var(--color-border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 9px;
    color: var(--color-text-muted);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.billing-pipeline__step--complete .billing-pipeline__marker {
    background: var(--color-success);
    border-color: var(--color-success);
    color: white;
    transform: scale(1);
}

.billing-pipeline__step--current .billing-pipeline__marker {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: white;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 25%, transparent);
    transform: scale(1.1);
}

.billing-pipeline__step--future .billing-pipeline__marker {
    background: var(--color-card-bg);
    border-color: var(--color-border);
    color: var(--color-text-muted);
}

.billing-pipeline__label {
    font-size: 10px;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.3px;
    white-space: nowrap;
    transition: color 0.2s ease;
}

.billing-pipeline__step--current .billing-pipeline__label {
    color: var(--color-primary);
}

.billing-pipeline__step--complete .billing-pipeline__label {
    color: var(--color-success);
}

/* Hover effects */
.billing-pipeline__step:hover .billing-pipeline__marker {
    transform: scale(1.15);
}

.billing-pipeline__step--current:hover .billing-pipeline__marker {
    transform: scale(1.2);
}

/* ============================================================================
   SECTION HEADERS
   ============================================================================ */

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

.billing-section__title {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text);
    display: flex;
    align-items: center;
    gap: 8px;
}

.billing-section__title-icon {
    color: var(--color-primary);
    font-size: 14px;
}

.billing-section__subtitle {
    font-size: 13px;
    color: var(--color-text-muted);
    margin-top: 4px;
}

/* ============================================================================
   STAFF SUMMARY TABLE
   ============================================================================ */

.billing-section__staff-table-container {
    background: var(--color-card-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: 16px;
    display: inline-block;
    min-width: 100%;
    max-width: 100%;
}

.billing-section__staff-table {
    width: auto;
    min-width: 100%;
    border-collapse: collapse;
    font-size: 12px;
    table-layout: auto;
}

/* Column width constraints */
.billing-section__staff-table th:first-child,
.billing-section__staff-table td:first-child {
    width: auto;
    min-width: 120px;
    max-width: 200px;
}

.billing-section__staff-table th:nth-child(n+2),
.billing-section__staff-table td:nth-child(n+2) {
    width: auto;
    white-space: nowrap;
}

.billing-section__staff-table th {
    background: var(--color-surface);
    padding: 8px 10px;
    text-align: left;
    font-weight: 600;
    color: var(--color-text);
    border-bottom: 1px solid var(--color-border);
    white-space: nowrap;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.billing-section__staff-table th:last-child {
    text-align: right;
}

.billing-section__staff-table td {
    padding: 8px 10px;
    border-bottom: 1px solid var(--color-border);
    color: var(--color-text);
    vertical-align: middle;
}

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

.billing-section__staff-table tbody tr:hover {
    background: var(--color-surface-hover);
}

/* Staff name cell */
.billing-section__staff-name {
    font-weight: 500;
    color: var(--color-text);
}

.billing-section__staff-role {
    font-size: 11px;
    color: var(--color-text-muted);
    margin-top: 2px;
}

/* Numeric cells */
.billing-section__staff-table td.billing-section__cell--numeric {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

/* Editable cells */
.billing-section__cell--editable {
    padding: 8px 12px;
}

.billing-section__inline-input {
    width: 70px;
    padding: 6px 8px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 12px;
    text-align: right;
    background: var(--color-card-bg);
    color: var(--color-text);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    -moz-appearance: textfield;
}

/* Hide number input spinners */
.billing-section__inline-input::-webkit-outer-spin-button,
.billing-section__inline-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.billing-section__inline-input:hover {
    border-color: var(--color-border);
}

.billing-section__inline-input:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px var(--color-primary-bg);
}

.billing-section__inline-input--hours {
    width: 60px;
}

.billing-section__inline-input--amount {
    width: 80px;
}

.billing-section__inline-input:disabled {
    background: var(--color-surface);
    color: var(--color-text-muted);
    cursor: not-allowed;
}

/* Computed/calculated cells */
.billing-section__cell--computed {
    color: var(--color-text-muted);
    font-style: italic;
}

/* Comparison cells */
.billing-section__cell--comparison {
    font-size: 12px;
}

.billing-section__comparison-value {
    display: block;
}

.billing-section__comparison-value--over {
    color: var(--color-danger);
}

.billing-section__comparison-value--under {
    color: var(--color-success);
}

.billing-section__comparison-na {
    color: var(--color-text-muted);
    font-style: italic;
}

/* Row states */
.billing-section__staff-table tbody tr.billing-section__row--confirmed {
    background: var(--color-success-bg);
}

.billing-section__staff-table tbody tr.billing-section__row--adjusted {
    background: var(--color-warning-bg);
}

/* Loading row (optimistic UI) */
.billing-section__staff-table tbody tr.billing-section__row--loading {
    opacity: 0.7;
}

.billing-section__staff-table tbody tr.billing-section__row--loading td {
    position: relative;
}

.billing-section__cell--loading {
    color: var(--color-text-muted);
}

.billing-section__loading-spinner {
    margin-right: 8px;
    color: var(--color-primary);
}

/* Footer row (totals) */
.billing-section__staff-table tfoot td {
    background: var(--color-surface);
    font-weight: 600;
    border-top: 2px solid var(--color-border);
    padding: 8px 10px;
}

/* Actions cell */
.billing-section__cell--actions {
    text-align: right;
    white-space: nowrap;
}

.billing-section__row-action {
    padding: 6px 10px;
    border: none;
    background: transparent;
    color: var(--color-text-muted);
    cursor: pointer;
    border-radius: var(--radius-sm);
    transition: all var(--transition-fast);
    font-size: 12px;
}

.billing-section__row-action:hover {
    background: var(--color-surface);
    color: var(--color-text);
}

.billing-section__row-action--remove:hover {
    background: rgba(220, 38, 38, 0.1);
    color: var(--color-danger);
}

/* ============================================================================
   COSTS TABLE
   ============================================================================ */

.billing-section__costs-container {
    background: var(--color-card-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: 24px;
}

.billing-section__costs-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.billing-section__costs-table th {
    background: var(--color-surface);
    padding: 12px 16px;
    text-align: left;
    font-weight: 600;
    color: var(--color-text);
    border-bottom: 1px solid var(--color-border);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.billing-section__costs-table th:last-child {
    text-align: right;
}

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

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

.billing-section__costs-table tbody tr:hover {
    background: var(--color-surface-hover);
}

.billing-section__costs-table td:last-child {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.billing-section__cost-type {
    display: inline-block;
    padding: 4px 10px;
    background: var(--color-surface);
    border-radius: 12px;
    font-size: 11px;
    font-weight: 500;
    color: var(--color-text-muted);
    text-transform: uppercase;
}

.billing-section__costs-table tfoot td {
    background: var(--color-surface);
    font-weight: 600;
    border-top: 2px solid var(--color-border);
}

.billing-section__costs-empty {
    text-align: center;
    padding: 24px;
    color: var(--color-text-muted);
    font-style: italic;
}

/* ============================================================================
   ACTION BUTTONS
   ============================================================================ */

.billing-section__actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    padding-top: 16px;
    border-top: 1px solid var(--color-border);
}

.billing-section__action-btn {
    padding: 10px 20px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all var(--transition-fast);
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--color-card-bg);
    color: var(--color-text);
}

.billing-section__action-btn:hover {
    background: var(--color-surface);
    border-color: var(--color-border);
}

.billing-section__action-btn--primary {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-card-bg);
}

.billing-section__action-btn--primary:hover {
    background: var(--color-primary-hover);
    border-color: var(--color-primary-hover);
}

.billing-section__action-btn--success {
    background: var(--color-success);
    border-color: var(--color-success);
    color: var(--color-card-bg);
}

.billing-section__action-btn--success:hover {
    background: var(--color-success-hover);
    border-color: var(--color-success-hover);
}

.billing-section__action-btn--danger {
    color: var(--color-danger);
    border-color: var(--color-danger);
}

.billing-section__action-btn--danger:hover {
    background: rgba(220, 38, 38, 0.1);
}

.billing-section__action-btn:disabled,
.billing-section__action-btn--disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

.billing-section__action-btn--disabled.billing-section__action-btn--primary {
    background: var(--color-text-muted);
    border-color: var(--color-text-muted);
}

/* ============================================================================
   ADD STAFF BUTTON & MODAL
   ============================================================================ */

.billing-section__add-staff-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: var(--color-card-bg);
    border: 1px dashed var(--color-border);
    border-radius: var(--radius-lg);
    color: var(--color-text-muted);
    font-size: 13px;
    cursor: pointer;
    transition: all var(--transition-fast);
    margin-bottom: 16px;
}

.billing-section__add-staff-btn:hover {
    background: var(--color-surface);
    border-color: var(--color-primary);
    color: var(--color-primary);
}

.billing-section__add-staff-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.billing-section__add-staff-btn i {
    font-size: 12px;
}

/* Add Staff Modal */
.billing-section__modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--transition-fast), visibility var(--transition-fast);
}

.billing-section__modal-overlay--visible {
    opacity: 1;
    visibility: visible;
}

.billing-section__modal {
    background: var(--color-card-bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-default);
    width: 100%;
    max-width: 420px;
    transform: scale(0.95);
    transition: transform var(--transition-fast);
}

.billing-section__modal-overlay--visible .billing-section__modal {
    transform: scale(1);
}

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

.billing-section__modal-title {
    font-size: 18px;
    font-weight: 600;
    color: var(--color-text);
    margin: 0;
}

.billing-section__modal-body {
    padding: 24px;
}

.billing-section__form-group {
    margin-bottom: 20px;
}

.billing-section__form-group:last-child {
    margin-bottom: 0;
}

.billing-section__form-label {
    display: block;
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text);
    margin-bottom: 6px;
}

.billing-section__form-select,
.billing-section__form-input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 14px;
    color: var(--color-text);
    background: var(--color-card-bg);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.billing-section__form-select:focus,
.billing-section__form-input:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px var(--color-primary-bg);
}

.billing-section__form-help {
    font-size: 12px;
    color: var(--color-text-muted);
    margin-top: 4px;
}

.billing-section__form-row {
    display: flex;
    gap: 16px;
}

.billing-section__form-group--flex {
    flex: 1;
    min-width: 0;
}

.billing-section__form-textarea {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 14px;
    color: var(--color-text);
    background: var(--color-card-bg);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    resize: vertical;
    min-height: 60px;
    font-family: inherit;
}

.billing-section__form-textarea:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px var(--color-primary-bg);
}

.billing-section__modal-footer {
    padding: 16px 24px;
    border-top: 1px solid var(--color-border);
    display: flex;
    justify-content: flex-end;
    gap: 12px;
}

/* Wide modal variant */
.billing-section__modal--wide {
    max-width: 600px;
}

/* ============================================================================
   MANAGE TIME MODAL
   ============================================================================ */

.manage-time__intro {
    font-size: 13px;
    color: var(--color-text-muted);
    margin: 0 0 16px 0;
}

.manage-time__section {
    margin-bottom: 16px;
    padding: 12px;
    background: var(--color-surface);
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
}

.manage-time__section--other {
    border-style: dashed;
}

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

.manage-time__check-all {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}

.manage-time__check-all input[type="checkbox"] {
    width: 16px;
    height: 16px;
    cursor: pointer;
}

.manage-time__section-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--color-text);
}

.manage-time__section-total {
    font-size: 12px;
    font-weight: 600;
    color: var(--color-text-muted);
    font-variant-numeric: tabular-nums;
}

.manage-time__section-hint {
    font-size: 11px;
    color: var(--color-text-muted);
    margin: 0 0 8px 0;
    font-style: italic;
}

.manage-time__entries {
    display: flex;
    flex-direction: column;
    gap: 4px;
    max-height: 200px;
    overflow-y: auto;
}

.manage-time__entry {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 6px 8px;
    background: var(--color-card-bg);
    border-radius: var(--radius-sm);
    font-size: 12px;
}

.manage-time__entry-check input[type="checkbox"] {
    width: 14px;
    height: 14px;
    cursor: pointer;
}

.manage-time__entry-details {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
    min-width: 0;
}

.manage-time__entry-user {
    font-weight: 500;
    color: var(--color-text);
    white-space: nowrap;
}

.manage-time__entry-date {
    color: var(--color-text-muted);
    white-space: nowrap;
}

.manage-time__entry-task {
    color: var(--color-text-muted);
    font-size: 11px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.manage-time__entry-values {
    display: flex;
    align-items: center;
    gap: 12px;
    text-align: right;
}

.manage-time__entry-hours {
    font-weight: 500;
    color: var(--color-text);
    font-variant-numeric: tabular-nums;
    min-width: 40px;
}

.manage-time__entry-amount {
    color: var(--color-text-muted);
    font-variant-numeric: tabular-nums;
    min-width: 60px;
}

.manage-time__empty {
    padding: 16px;
    text-align: center;
    color: var(--color-text-muted);
    font-size: 12px;
    font-style: italic;
}

/* ============================================================================
   EMPTY STATE
   ============================================================================ */

.billing-section__empty {
    text-align: center;
    padding: 48px 24px;
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    margin-bottom: 24px;
}

.billing-section__empty-icon {
    font-size: 48px;
    color: var(--color-text-muted);
    margin-bottom: 16px;
}

.billing-section__empty-title {
    font-size: 18px;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 8px;
}

.billing-section__empty-text {
    font-size: 14px;
    color: var(--color-text-muted);
    margin-bottom: 20px;
}

/* ============================================================================
   NOT STARTED STATE
   ============================================================================ */

.billing-section__start {
    text-align: center;
    padding: 48px 24px;
    background: var(--color-surface);
    border-radius: var(--radius-lg);
}

.billing-section__start-icon {
    font-size: 64px;
    color: var(--color-primary);
    margin-bottom: 20px;
    opacity: 0.6;
}

.billing-section__start-title {
    font-size: 20px;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 12px;
}

.billing-section__start-text {
    font-size: 14px;
    color: var(--color-text-muted);
    margin-bottom: 24px;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
}

.billing-section__start-btn {
    padding: 12px 32px;
    background: var(--color-primary);
    color: var(--color-card-bg);
    border: none;
    border-radius: var(--radius-lg);
    font-size: 15px;
    font-weight: 500;
    cursor: pointer;
    transition: background var(--transition-fast);
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.billing-section__start-btn:hover {
    background: var(--color-primary-hover);
}

/* ============================================================================
   BILLED VIA PARENT STATE
   ============================================================================ */

.billing-section__parent-notice {
    text-align: center;
    padding: 32px 24px;
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
}

.billing-section__parent-icon {
    font-size: 40px;
    color: var(--color-text-muted);
    margin-bottom: 16px;
}

.billing-section__parent-text {
    font-size: 14px;
    color: var(--color-text-muted);
    margin-bottom: 16px;
}

.billing-section__parent-link {
    color: var(--color-primary);
    text-decoration: none;
    font-weight: 500;
}

.billing-section__parent-link:hover {
    text-decoration: underline;
}

/* ============================================================================
   VARIANCE WARNING
   ============================================================================ */

.billing-section__variance-warning {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 16px;
    background: var(--color-warning-bg);
    border: 1px solid var(--color-warning-border);
    border-radius: var(--radius-lg);
    margin-bottom: 24px;
}

.billing-section__variance-icon {
    color: var(--color-warning);
    font-size: 18px;
    flex-shrink: 0;
    margin-top: 2px;
}

.billing-section__variance-content {
    flex: 1;
}

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

.billing-section__variance-text {
    font-size: 13px;
    color: var(--color-warning-text);
}

.billing-section__variance-input {
    margin-top: 12px;
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--color-warning-border);
    border-radius: var(--radius-sm);
    font-size: 13px;
    background: var(--color-card-bg);
    resize: vertical;
    min-height: 80px;
}

.billing-section__variance-input:focus {
    outline: none;
    border-color: var(--color-warning);
}

/* ============================================================================
   INVOICE SECTION
   ============================================================================ */

.billing-section__invoice {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 20px 24px;
    margin-bottom: 24px;
}

.billing-section__invoice-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 16px;
}

.billing-section__invoice-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text);
}

.billing-section__invoice-icon {
    color: var(--color-primary);
}

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

.billing-section__invoice-field {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.billing-section__invoice-label {
    font-size: 12px;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.billing-section__invoice-value {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text);
}

/* ============================================================================
   REFRESH BUTTON
   ============================================================================ */

.billing-section__refresh-btn {
    padding: 6px 12px;
    background: transparent;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    color: var(--color-text-muted);
    font-size: 12px;
    cursor: pointer;
    transition: all var(--transition-fast);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.billing-section__refresh-btn:hover {
    background: var(--color-surface);
    color: var(--color-text);
    border-color: var(--color-border);
}

.billing-section__refresh-btn--spinning i {
    animation: billing-spin 0.8s linear infinite;
}

/* ============================================================================
   RESPONSIVE
   ============================================================================ */

@media (max-width: 1200px) {
    .billing-section__staff-table {
        font-size: 12px;
    }

    .billing-section__staff-table th,
    .billing-section__staff-table td {
        padding: 10px 12px;
    }

    .billing-section__inline-input {
        width: 70px;
        padding: 6px 8px;
        font-size: 12px;
    }

    .billing-section__inline-input--amount {
        width: 85px;
    }
}

@media (max-width: 768px) {
    .billing-section {
        padding: 12px;
        padding-bottom: 24px;
    }

    /* New pipeline responsive styles */
    .billing-pipeline {
        padding: 8px 12px;
    }

    .billing-pipeline__track {
        left: 20px;
        right: 20px;
    }

    .billing-pipeline__marker {
        width: 20px;
        height: 20px;
        font-size: 8px;
    }

    .billing-pipeline__label {
        font-size: 8px;
        letter-spacing: 0;
    }

    .billing-pipeline__step {
        max-width: 60px;
    }

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

    .billing-section__staff-table {
        min-width: 900px;
    }

    .billing-section__totals {
        padding: 16px;
    }

    .billing-section__actions {
        flex-direction: column;
    }

    .billing-section__action-btn {
        width: 100%;
        justify-content: center;
    }
}

/* ============================================================================
   PRINT STYLES
   ============================================================================ */

@media print {
    .billing-section {
        padding: 0;
    }

    .billing-section__actions,
    .billing-section__add-staff-btn,
    .billing-section__refresh-btn {
        display: none;
    }

    .billing-section__staff-table th,
    .billing-section__staff-table td {
        padding: 8px 12px;
    }

    .billing-section__inline-input {
        border: none;
        padding: 0;
        background: transparent;
    }
}

/* ============================================================================
   SIMPLIFIED BILLING - COMPACT TABLE (6 COLUMNS)
   ============================================================================ */

.billing-section__staff-table--compact {
    font-size: 13px;
}

.billing-section__staff-table--compact th {
    font-size: 11px;
    padding: 10px 12px;
}

.billing-section__staff-table th.billing-section__th--numeric {
    text-align: right;
}

/* Ensure all numeric columns align right */
.billing-section__staff-table--compact th:nth-child(n+2),
.billing-section__staff-table--compact td:nth-child(n+2) {
    text-align: right;
}

.billing-section__staff-table--compact tfoot td:first-child {
    text-align: left;
}

.billing-section__cell--cost {
    min-width: 100px;
}

.billing-section__cell--override {
    min-width: 140px;
}

.billing-section__override-cell {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
}

.billing-section__override-amount {
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    color: var(--color-warning);
}

.billing-section__cost-cell {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
}

.billing-section__cost-amount {
    font-weight: 600;
    font-variant-numeric: tabular-nums;
}

.billing-section__cost-amount--adjusted {
    color: var(--color-warning);
}

/* ============================================================================
   DELTA BADGES (Budget & Prior Year Comparison)
   ============================================================================ */

.billing-section__delta-badges {
    display: flex;
    flex-direction: column;
    gap: 2px;
    align-items: flex-end;
}

.billing-section__delta-badge {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 10px;
    padding: 2px 6px;
    border-radius: 10px;
    white-space: nowrap;
    cursor: help;
}

.billing-section__delta-badge--over {
    background: rgba(220, 38, 38, 0.1);
    color: var(--color-danger);
}

.billing-section__delta-badge--under {
    background: rgba(22, 163, 74, 0.1);
    color: var(--color-success);
}

/* ============================================================================
   COMPARISON SUMMARY BAR
   ============================================================================ */

.billing-section__comparison-bar {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    padding: 12px 16px;
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    margin-top: 12px;
    border: 1px solid var(--color-border);
}

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

.billing-section__comparison-item--actual {
    padding: 0 16px;
    border-left: 1px solid var(--color-border);
    border-right: 1px solid var(--color-border);
}

.billing-section__comparison-label {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--color-text-muted);
    font-weight: 600;
}

.billing-section__comparison-amount {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text);
    font-variant-numeric: tabular-nums;
}

.billing-section__comparison-item--actual .billing-section__comparison-amount {
    color: var(--color-primary);
    font-size: 16px;
}

.billing-section__comparison-variance {
    font-size: 11px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 10px;
}

.billing-section__comparison-variance--over {
    background: rgba(220, 38, 38, 0.1);
    color: var(--color-danger);
}

.billing-section__comparison-variance--under {
    background: rgba(22, 163, 74, 0.1);
    color: var(--color-success);
}

/* ============================================================================
   SIMPLIFIED COSTS SECTION
   ============================================================================ */

.billing-section__costs-section {
    margin-top: 12px;
    padding: 8px 10px;
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
}

.billing-section__costs-section--empty {
    padding: 6px 10px;
}

.billing-section__costs-section--empty .billing-section__costs-header {
    margin-bottom: 0;
}

.billing-section__costs-section--empty .billing-section__costs-content {
    display: none;
}

/* Minimized state (user collapsed) */
.billing-section__costs-section--minimized {
    padding: 6px 10px;
}

.billing-section__costs-section--minimized .billing-section__costs-header {
    margin-bottom: 0;
}

.billing-section__costs-section--minimized .billing-section__costs-content {
    display: none;
}

.billing-section__costs-header {
    display: flex;
    align-items: center;
    margin-bottom: 6px;
    gap: 6px;
}

.billing-section__costs-header .billing-section__title--compact {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 6px;
}

/* Toggle button */
.billing-section__costs-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    padding: 0;
    background: transparent;
    border: none;
    color: var(--color-text-muted);
    cursor: pointer;
    border-radius: var(--radius-sm);
    transition: all 0.15s ease;
    flex-shrink: 0;
}

.billing-section__costs-toggle:hover {
    background: var(--color-border);
    color: var(--color-text);
}

.billing-section__costs-toggle i {
    font-size: 10px;
}

/* Costs summary shown when minimized */
.billing-section__costs-summary {
    margin-left: 6px;
    font-size: 11px;
    font-weight: 600;
    color: var(--color-text-secondary);
}

.billing-section__title--compact {
    font-size: 12px;
}

.billing-section__title--compact .billing-section__title-icon {
    font-size: 11px;
}

.billing-section__add-cost-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    background: var(--color-primary);
    color: var(--color-card-bg);
    border: none;
    border-radius: var(--radius-lg);
    font-size: 11px;
    font-weight: 500;
    cursor: pointer;
    transition: background var(--transition-fast);
}

.billing-section__add-cost-btn:hover {
    background: var(--color-primary-hover);
}

.billing-section__add-cost-btn--compact {
    padding: 6px 10px;
    font-size: 11px;
    background: transparent;
    color: var(--color-text-muted);
    border: 1px dashed var(--color-border);
}

.billing-section__add-cost-btn--compact:hover {
    background: var(--color-surface);
    border-color: var(--color-primary);
    color: var(--color-primary);
}

.billing-section__add-cost-btn i {
    font-size: 10px;
}

.billing-section__costs-list {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.billing-section__cost-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 5px 8px;
    background: var(--color-card-bg);
    border-radius: var(--radius-sm);
    border: 1px solid var(--color-border);
}

.billing-section__cost-desc {
    font-size: 12px;
    color: var(--color-text);
}

.billing-section__cost-category {
    font-weight: 600;
    color: var(--color-text-muted);
}

.billing-section__cost-item .billing-section__cost-amount {
    font-weight: 600;
    font-size: 12px;
    font-variant-numeric: tabular-nums;
    color: var(--color-text);
}

/* Loading cost item (optimistic UI) */
.billing-section__cost-item--loading {
    opacity: 0.7;
}

.billing-section__cost-item--loading .billing-section__cost-amount {
    color: var(--color-text-muted);
}

.billing-section__costs-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 8px 0;
    margin-top: 6px;
    border-top: 1px solid var(--color-border);
    font-size: 12px;
    color: var(--color-text-muted);
}

.billing-section__costs-total strong {
    color: var(--color-text);
    font-variant-numeric: tabular-nums;
}

.billing-section__costs-empty {
    text-align: center;
    padding: 24px;
    color: var(--color-text-muted);
    font-size: 13px;
    font-style: italic;
}

/* ============================================================================
   BILLING TOTALS - Compact Design
   ============================================================================ */

.billing-totals {
    margin-top: 12px;
    padding: 10px 14px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}

.billing-totals__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.billing-totals__breakdown {
    font-size: 12px;
    color: var(--color-text-muted);
    font-variant-numeric: tabular-nums;
}

.billing-totals__total {
    display: flex;
    align-items: center;
    gap: 8px;
}

.billing-totals__label {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--color-text-muted);
}

.billing-totals__total strong {
    font-size: 18px;
    font-weight: 700;
    color: var(--color-primary);
    font-variant-numeric: tabular-nums;
}

.billing-totals__comparison {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px dashed var(--color-border);
    font-size: 11px;
}

.billing-totals__comp-item {
    color: var(--color-text-muted);
    font-variant-numeric: tabular-nums;
}

.billing-totals__comp-item--over {
    color: var(--color-danger);
    font-weight: 600;
}

.billing-totals__comp-item--under {
    color: var(--color-success);
    font-weight: 600;
}

/* Legacy totals styles - keep for product billing */
.billing-section__totals {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 20px;
    margin-top: 12px;
    padding: 10px 16px;
    background: var(--color-surface);
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
}

.billing-section__totals-breakdown {
    display: flex;
    flex-direction: column;
    gap: 4px;
    text-align: right;
}

.billing-section__totals-line {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    font-size: 12px;
    color: var(--color-text-muted);
}

.billing-section__totals-line span:last-child {
    font-variant-numeric: tabular-nums;
    min-width: 100px;
}

.billing-section__totals-grand {
    display: flex;
    align-items: center;
    gap: 10px;
    padding-left: 16px;
    border-left: 2px solid var(--color-primary);
}

.billing-section__totals-grand span {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--color-text-muted);
    font-weight: 600;
}

.billing-section__totals-grand strong {
    font-size: 18px;
    color: var(--color-primary);
    font-variant-numeric: tabular-nums;
}

/* ============================================================================
   BUDGET TAB - Base Container
   ============================================================================ */

.task-page__budget {
    padding: 12px 16px;
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    min-width: 0;
    overflow: hidden;
}

.budget {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    min-width: 0;
    overflow: auto;
}

/* Layout wrapper - shrinks to content width so all children align */
.budget__layout {
    display: inline-flex;
    flex-direction: column;
    align-items: stretch; /* All children stretch to match width */
    align-self: flex-start; /* Don't stretch to fill parent - shrink to content */
    min-width: 580px; /* Match table min-width to ensure consistent layout */
    max-width: 100%;
}

/* Loading State */
.budget__loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 60px 24px;
    min-height: 300px;
}

.budget__loading-spinner {
    font-size: 32px;
    color: var(--color-primary, #3b82f6);
}

.budget__loading-text {
    font-size: 14px;
    color: var(--color-text-muted, #6b7280);
    margin: 0;
}

/* Locked Banner */
.budget__locked-banner {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    background: var(--color-warning-bg, #fef3c7);
    border: 1px solid var(--color-warning-border, #fcd34d);
    border-radius: var(--radius-md);
    margin-bottom: 16px;
    font-size: 13px;
    color: var(--color-warning-text, #92400e);
}

.budget__locked-banner i {
    font-size: 14px;
}

/* Review Banner (for preparers viewing budget under review) */
.budget__review-banner {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    background: var(--color-info-bg, #e0f2fe);
    border: 1px solid var(--color-info-border, #7dd3fc);
    border-radius: var(--radius-md);
    margin-bottom: 16px;
    font-size: 13px;
    color: var(--color-info-text, #0369a1);
}

.budget__review-banner i {
    font-size: 14px;
}

.budget__unlock-btn {
    margin-left: auto;
    padding: 5px 12px;
    font-size: 11px;
    font-weight: 500;
    color: var(--color-warning-text, #92400e);
    background: var(--color-card-bg, #ffffff);
    border: 1px solid var(--color-warning-border, #fcd34d);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.budget__unlock-btn:hover {
    background: var(--color-warning-bg, #fef3c7);
}

.budget__unlock-btn i {
    margin-right: 4px;
}

/* Billing Group Banner - Shows linked tasks */
.budget__billing-group-banner {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-radius: var(--radius-md);
    margin-bottom: 16px;
    font-size: 13px;
}

.budget__billing-group-banner i {
    font-size: 14px;
    flex-shrink: 0;
}

/* Linked task (this task is billed with another) */
.budget__billing-group-banner--linked {
    background: var(--color-info-bg, #eff6ff);
    border: 1px solid var(--color-info-border, #93c5fd);
    color: var(--color-info-text, #1e40af);
}

/* Primary task (has linked tasks billed with it) */
.budget__billing-group-banner--primary {
    background: var(--color-success-bg, #f0fdf4);
    border: 1px solid var(--color-success-border, #86efac);
    color: var(--color-success-text, #166534);
}

/* Budget from another task */
.budget__billing-group-banner--source {
    background: var(--color-info-bg, #eff6ff);
    border: 1px solid var(--color-info-border, #93c5fd);
    color: var(--color-info-text, #1e40af);
}

.budget__billing-link {
    color: inherit;
    font-weight: 500;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.budget__billing-link:hover {
    text-decoration-thickness: 2px;
}

/* Budget Status Banner (when not locked but has state) */
.budget__status-banner {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 16px;
    background: var(--color-card-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: 16px;
}

/* Budget State Badges */
.budget__state-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    border-radius: var(--radius-sm);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.budget__state-badge i {
    font-size: 10px;
}

.budget__state-badge--prepared {
    background: var(--color-primary-bg, #eff6ff);
    color: var(--color-primary, #2563eb);
    border: 1px solid var(--color-primary-border, #93c5fd);
}

.budget__state-badge--pending-review {
    background: var(--color-teal-bg, #f0fdfa);
    color: var(--color-teal, #0d9488);
    border: 1px solid var(--color-teal-border, #5eead4);
}

.budget__state-badge--reviewed {
    background: var(--color-info-bg, #eff6ff);
    color: var(--color-info, #0369a1);
    border: 1px solid var(--color-info-border, #7dd3fc);
}

.budget__state-badge--signed-off {
    background: var(--color-success-bg, #f0fdf4);
    color: var(--color-success, #16a34a);
    border: 1px solid var(--color-success-border, #86efac);
}

.budget__state-badge--rejected {
    background: var(--color-danger-bg, #fef2f2);
    color: var(--color-danger, #dc2626);
    border: 1px solid var(--color-danger-border, #fecaca);
}

/* Rejection Banner */
.budget__rejection-banner {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px 16px;
    background: var(--color-danger-bg, #fef2f2);
    border: 1px solid var(--color-danger-border, #fecaca);
    border-left: 4px solid var(--color-danger, #dc2626);
    border-radius: var(--radius-md);
    margin-bottom: 16px;
}

.budget__rejection-banner-icon {
    color: var(--color-danger, #dc2626);
    font-size: 18px;
    margin-top: 2px;
}

.budget__rejection-banner-content {
    flex: 1;
}

.budget__rejection-banner-title {
    font-weight: 600;
    color: var(--color-danger, #dc2626);
    margin: 0 0 4px 0;
    font-size: 13px;
}

.budget__rejection-banner-notes {
    color: var(--color-text, #1f2937);
    font-size: 12px;
    margin: 0;
    white-space: pre-wrap;
}

.budget__rejection-banner-meta {
    color: var(--color-text-muted, #6b7280);
    font-size: 11px;
    margin-top: 8px;
}

/* Budget Workflow Actions */
.budget__workflow-actions {
    display: flex;
    gap: 8px;
    margin-left: auto;
}

.budget__workflow-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    font-size: 12px;
    font-weight: 500;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all var(--transition-fast);
    border: 1px solid transparent;
}

.budget__workflow-btn i {
    font-size: 11px;
}

.budget__workflow-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.budget__workflow-btn--review {
    background: var(--color-teal-bg, #f0fdfa);
    color: var(--color-teal, #0d9488);
    border-color: var(--color-teal-border, #5eead4);
}

.budget__workflow-btn--review:hover:not(:disabled) {
    background: var(--color-teal, #0d9488);
    color: var(--color-white, #ffffff);
}

.budget__workflow-btn--accept {
    background: var(--color-info-bg, #eff6ff);
    color: var(--color-info, #0369a1);
    border-color: var(--color-info-border, #7dd3fc);
}

.budget__workflow-btn--accept:hover:not(:disabled) {
    background: var(--color-info, #0369a1);
    color: var(--color-white, #ffffff);
}

.budget__workflow-btn--sign-off {
    background: var(--color-success-bg, #f0fdf4);
    color: var(--color-success, #16a34a);
    border-color: var(--color-success-border, #86efac);
}

.budget__workflow-btn--sign-off:hover:not(:disabled) {
    background: var(--color-success, #16a34a);
    color: var(--color-white, #ffffff);
}

.budget__workflow-btn--unlock {
    background: var(--color-warning-bg, #fef3c7);
    color: var(--color-warning-text, #92400e);
    border-color: var(--color-warning-border, #fcd34d);
}

.budget__workflow-btn--unlock:hover:not(:disabled) {
    background: var(--color-warning, #f59e0b);
    color: var(--color-white, #ffffff);
}

.budget__workflow-btn--submit {
    background: var(--color-primary-bg, #eff6ff);
    color: var(--color-primary, #2563eb);
    border-color: var(--color-primary-border, #93c5fd);
}

.budget__workflow-btn--submit:hover:not(:disabled) {
    background: var(--color-primary, #2563eb);
    color: var(--color-white, #ffffff);
}

.budget__workflow-btn--reject {
    background: var(--color-danger-bg, #fef2f2);
    color: var(--color-danger, #dc2626);
    border-color: var(--color-danger-border, #fecaca);
}

.budget__workflow-btn--reject:hover:not(:disabled) {
    background: var(--color-danger, #dc2626);
    color: var(--color-white, #ffffff);
}

.budget__workflow-btn--send-back {
    background: var(--color-amber-bg, #fffbeb);
    color: var(--color-amber, #d97706);
    border-color: var(--color-amber-border, #fcd34d);
}

.budget__workflow-btn--send-back:hover:not(:disabled) {
    background: var(--color-amber, #d97706);
    color: var(--color-white, #ffffff);
}

.budget__workflow-btn--resubmit {
    background: var(--color-primary-bg, #eff6ff);
    color: var(--color-primary, #2563eb);
    border-color: var(--color-primary-border, #93c5fd);
}

.budget__workflow-btn--resubmit:hover:not(:disabled) {
    background: var(--color-primary, #2563eb);
    color: var(--color-white, #ffffff);
}

/* Budget Header - Compact Title */
.budget__header-title {
    display: flex;
    align-items: center;
    gap: 12px;
}

.budget__title {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text, #1f2937);
    margin: 0;
}

/* Budget Content Area */
.budget__content {
    margin-top: 12px;
    display: flex;
    flex-direction: column;
    align-items: stretch; /* Children stretch to fill width */
    width: 100%; /* Fill layout width */
    min-width: 0;
}

/* ============================================================================
   BUDGET CREATION SCREEN
   ============================================================================ */

.budget__creation {
    padding: 24px;
}

.budget__creation-header {
    text-align: center;
    margin-bottom: 32px;
}

.budget__creation-header h3 {
    font-size: 20px;
    font-weight: 600;
    color: var(--color-text, #1f2937);
    margin: 0 0 8px 0;
}

.budget__creation-header p {
    font-size: 13px;
    color: var(--color-text-muted, #64748b);
    margin: 0;
}

.budget__creation-section {
    margin-bottom: 24px;
}

.budget__creation-label {
    display: block;
    font-size: 12px;
    font-weight: 600;
    color: var(--color-text, #374151);
    margin-bottom: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.budget__type-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}

.budget__type-cards--compact {
    gap: 12px;
}

.budget__type-card {
    display: flex;
    flex-direction: column;
    padding: 20px;
    background: var(--color-surface, #f8fafc);
    border: 2px solid var(--color-border, #e2e8f0);
    border-radius: 12px;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.budget__type-card:hover {
    border-color: var(--color-primary, #3b82f6);
    background: var(--color-card-bg, #ffffff);
    box-shadow: 0 4px 12px rgba(var(--color-primary-rgb, 59, 130, 246), 0.1);
}

.budget__type-card--current {
    border-color: var(--color-success, #10b981);
    background: var(--color-success-bg, #ecfdf5);
}

.budget__type-card--current::after {
    content: 'Current';
    position: absolute;
    top: 8px;
    right: 8px;
    font-size: 10px;
    font-weight: 600;
    color: var(--color-success, #10b981);
    text-transform: uppercase;
}

.budget__type-card {
    position: relative;
}

.budget__type-card-icon {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-primary-light, #dbeafe);
    color: var(--color-primary, #3b82f6);
    border-radius: 10px;
    margin-bottom: 16px;
}

.budget__type-card-icon i {
    font-size: 20px;
}

.budget__type-card-content h4 {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text, #1f2937);
    margin: 0 0 8px 0;
}

.budget__type-card-content p {
    font-size: 12px;
    color: var(--color-text-muted, #64748b);
    margin: 0;
    line-height: 1.5;
}

.budget__creation-divider {
    display: flex;
    align-items: center;
    margin: 32px 0;
}

.budget__creation-divider::before,
.budget__creation-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--color-border, #e2e8f0);
}

.budget__creation-divider span {
    padding: 0 16px;
    font-size: 12px;
    color: var(--color-text-muted, #94a3b8);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.budget__creation-options {
    display: flex;
    gap: 16px;
    justify-content: center;
}

.budget__creation-option {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 20px 32px;
    background: var(--color-card-bg, #ffffff);
    border: 1px solid var(--color-border, #e2e8f0);
    border-radius: var(--radius-lg);
    cursor: pointer;
    transition: all var(--transition-fast);
    min-width: 180px;
}

.budget__creation-option:hover:not(:disabled) {
    border-color: var(--color-primary, #3b82f6);
    background: var(--color-surface, #f8fafc);
}

.budget__creation-option:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.budget__creation-option i {
    font-size: 24px;
    color: var(--color-primary, #3b82f6);
}

.budget__creation-option span {
    font-size: 13px;
    font-weight: 600;
    color: var(--color-text, #1f2937);
}

.budget__creation-option small {
    font-size: 11px;
    color: var(--color-text-muted, #94a3b8);
}

/* ============================================================================
   BUDGET HEADER (for existing budgets)
   ============================================================================ */

.budget__header {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
    flex-shrink: 0;
    width: 100%;
}

.budget__header-actions {
    display: flex;
    gap: 8px;
    flex-shrink: 0;
}

.budget__type-badge {
    display: inline-block;
    padding: 3px 10px;
    font-size: 10px;
    font-weight: 600;
    color: var(--color-primary, #3b82f6);
    background: var(--color-primary-light, #dbeafe);
    border-radius: 12px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    margin-left: 12px;
}

.budget__change-type-btn {
    padding: 6px 12px;
    font-size: 11px;
    font-weight: 500;
    color: var(--color-text, #374151);
    background: var(--color-surface, #f1f5f9);
    border: 1px solid var(--color-border, #e2e8f0);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all var(--transition-fast);
    display: flex;
    align-items: center;
    gap: 6px;
}

.budget__change-type-btn:hover {
    background: var(--color-surface-hover, #e2e8f0);
    border-color: var(--color-primary, #3b82f6);
    color: var(--color-primary, #3b82f6);
}

.budget__change-type-btn i {
    font-size: 10px;
}

/* Change type modal */
.budget__change-type-modal {
    padding: 8px 0;
}

.budget__change-type-warning {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    background: var(--color-warning-bg, #fef3c7);
    border-radius: var(--radius-md);
    font-size: 12px;
    color: var(--color-warning-text, #92400e);
    margin-bottom: 20px;
}

.budget__change-type-warning i {
    font-size: 16px;
    color: var(--color-warning, #f59e0b);
}

.budget__change-type-info {
    font-size: 13px;
    color: var(--color-text-muted, #64748b);
    margin-bottom: 16px;
}

/* Budget conversion modal */
.budget__conversion-modal {
    padding: 8px 0;
}

.budget__conversion-question {
    font-size: 14px;
    color: var(--color-text, #1f2937);
    margin-bottom: 20px;
}

.budget__conversion-question strong {
    color: var(--color-primary, #3b82f6);
}

.budget__conversion-options {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 16px;
}

.budget__conversion-option {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 16px;
    background: var(--color-surface, #f8fafc);
    border: 2px solid var(--color-border, #e2e8f0);
    border-radius: 10px;
    cursor: pointer;
    transition: all var(--transition-fast);
    text-align: left;
}

.budget__conversion-option:hover {
    border-color: var(--color-primary, #3b82f6);
    background: var(--color-card-bg, #ffffff);
}

.budget__conversion-option--convert:hover {
    border-color: var(--color-primary, #3b82f6);
}

.budget__conversion-option--reset:hover {
    border-color: var(--color-warning, #f59e0b);
}

.budget__conversion-option-icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    flex-shrink: 0;
}

.budget__conversion-option--convert .budget__conversion-option-icon {
    background: var(--color-primary-light, #dbeafe);
    color: var(--color-primary, #3b82f6);
}

.budget__conversion-option--reset .budget__conversion-option-icon {
    background: var(--color-warning-bg, #fef3c7);
    color: var(--color-warning, #f59e0b);
}

.budget__conversion-option-icon i {
    font-size: 16px;
}

.budget__conversion-option-content h4 {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text, #1f2937);
    margin: 0 0 6px 0;
}

.budget__conversion-option-content p {
    font-size: 12px;
    color: var(--color-text-muted, #64748b);
    margin: 0;
    line-height: 1.5;
}

.budget__conversion-warning {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    color: var(--color-text-muted, #64748b);
    margin: 0;
}

.budget__conversion-warning i {
    color: var(--color-info, #0ea5e9);
}

/* ============================================================================
   BUDGET TAB - Section title
   ============================================================================ */

.budget__section-title {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--color-text-muted, #6b7280);
}

/* ============================================================================
   BUDGET TYPE SELECTOR (Tabs)
   ============================================================================ */

.budget__type-selector {
    display: flex;
    gap: 4px;
    padding: 4px;
    background: var(--color-surface, #f8fafc);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border, #e2e8f0);
}

.budget__type-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    font-size: 12px;
    font-weight: 500;
    color: var(--color-text-muted, #64748b);
    background: transparent;
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-fast);
    white-space: nowrap;
}

.budget__type-btn:hover {
    color: var(--color-text, #1f2937);
    background: var(--color-surface-hover, #f1f5f9);
}

.budget__type-btn--active {
    color: var(--color-primary, #3b82f6);
    background: var(--color-card-bg, #ffffff);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

.budget__type-btn--active:hover {
    background: var(--color-card-bg, #ffffff);
}

.budget__type-btn i {
    font-size: 11px;
    opacity: 0.7;
}

.budget__type-btn--active i {
    opacity: 1;
}

/* ============================================================================
   DETAILED BUDGET (Matrix format)
   ============================================================================ */

.budget__detailed {
    display: flex;
    flex-direction: column;
    align-items: stretch; /* Children stretch to fill width */
    width: 100%; /* Fill content width */
    min-width: 0;
}

.budget__people-header {
    display: flex;
    justify-content: flex-end; /* Align to right with Total column */
    margin-bottom: 8px;
    flex-shrink: 0;
    width: 100%;
}

.budget__add-person-btn {
    padding: 4px 10px;
    background: var(--color-primary, #3b82f6);
    color: var(--color-on-primary);
    border: none;
    border-radius: var(--radius-sm);
    font-size: 11px;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    transition: background var(--transition-fast);
}

.budget__add-person-btn:hover { background: var(--color-primary-hover, #2563eb); }
.budget__add-person-btn i { font-size: 10px; }

/* Matrix table - determines the layout width, other sections follow */
.budget__matrix-wrap {
    width: fit-content; /* Shrink to table content - this determines the layout width */
    max-width: 100%; /* Don't overflow the page */
    overflow-x: auto;
    overflow-y: visible; /* Allow sticky headers to work with parent scroll */
    margin-bottom: 12px;
    border-radius: var(--radius-md, 6px);
    box-shadow: var(--shadow-subtle, 0 1px 2px rgba(0, 0, 0, 0.05));
    position: relative;
}

/* Scroll buttons container */
.budget__matrix-scroll-controls {
    position: sticky;
    top: 0;
    left: 0;
    right: 0;
    display: flex;
    justify-content: flex-end;
    gap: 2px;
    padding: 4px;
    z-index: 15;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition-fast);
    height: 0;
    overflow: visible;
}

.budget__matrix-wrap--scrollable .budget__matrix-scroll-controls {
    opacity: 1;
    pointer-events: auto;
}

.budget__matrix-scroll-btn {
    width: 24px;
    height: 24px;
    border: 1px solid var(--color-border, #e5e7eb);
    background: var(--color-card-bg, #ffffff);
    color: var(--color-text-muted, #6b7280);
    border-radius: var(--radius-sm, 4px);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    transition: all var(--transition-fast);
    box-shadow: var(--shadow-subtle);
}

.budget__matrix-scroll-btn:hover {
    background: var(--color-surface, #f8fafc);
    color: var(--color-primary, #3b82f6);
    border-color: var(--color-primary, #3b82f6);
}

.budget__matrix-scroll-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

.budget__matrix-scroll-btn:disabled:hover {
    background: var(--color-card-bg, #ffffff);
    color: var(--color-text-muted, #6b7280);
    border-color: var(--color-border, #e5e7eb);
}

.budget__matrix {
    width: auto; /* Size to content - determines the layout width */
    min-width: 580px; /* Minimum width to fit button and look good */
    table-layout: auto;
    border-collapse: collapse;
    font-size: 11px;
    border: 1px solid var(--color-border, #e5e7eb);
    background: var(--color-card-bg, #ffffff);
    border-radius: var(--radius-md, 6px);
    overflow: hidden;
}

.budget__matrix th,
.budget__matrix td {
    padding: 4px 6px;
    text-align: left;
    border: 1px solid var(--color-border, #e5e7eb);
}

/* Role header row */
.budget__matrix-header-roles th {
    background: var(--color-primary-bg, #dbeafe);
    color: var(--color-primary-hover, #1e40af);
    font-size: 11px;
    text-transform: uppercase;
    font-weight: 700;
    text-align: center;
    letter-spacing: 0.3px;
    padding: 6px 8px;
}

/* Sticky headers - always stick within the matrix wrap scroll container */
.budget__matrix .budget__matrix-header-roles th,
.budget__matrix .budget__matrix-header-names th {
    position: sticky;
    z-index: 5;
    background: var(--color-primary-bg, #dbeafe);
}

.budget__matrix .budget__matrix-header-roles th {
    top: 0;
}

.budget__matrix .budget__matrix-header-names th {
    top: 29px; /* Height of role row */
    box-shadow: 0 1px 0 var(--color-border, #e5e7eb);
    background: var(--color-surface, #f8fafc);
}

/* Role header cells that are draggable need extra padding for drag handle */
.budget__matrix-header-roles th.budget__matrix-col--draggable {
    padding-left: 18px;
}

.budget__matrix-role--total {
    background: var(--color-surface, #f8fafc);
    color: var(--color-text, #1f2937);
}

/* Names header row */
.budget__matrix-header-names th {
    background: var(--color-surface, #f8fafc);
    font-weight: 600;
    font-size: 12px;
    color: var(--color-text, #1f2937);
    vertical-align: bottom;
    padding: 8px 10px;
}

/* Default readable column widths */
.budget__matrix .budget__matrix-th--task { width: 280px; min-width: 200px; }
.budget__matrix .budget__matrix-th--date { width: 100px; min-width: 85px; text-align: center; }
.budget__matrix .budget__matrix-th--person { width: 120px; min-width: 70px; text-align: center; }
.budget__matrix .budget__matrix-th--stretch { display: none; }
.budget__matrix .budget__matrix-th--total { width: 80px; min-width: 70px; text-align: center; font-weight: 700; }
.budget__matrix-th--total-header { width: 80px; min-width: 70px; background: var(--color-surface, #f9fafb); }

/* Compact mode for many columns (6+) or narrow screens */
.budget__matrix--compact .budget__matrix-th--task { width: 180px; min-width: 140px; }
.budget__matrix--compact .budget__matrix-th--date { width: 80px; min-width: 65px; }
.budget__matrix--compact .budget__matrix-th--person { width: 85px; min-width: 55px; padding: 4px 4px; }
.budget__matrix--compact .budget__matrix-total { min-width: 60px; width: 60px; }
.budget__matrix--compact .budget__task-desc-input { width: 160px; }
.budget__matrix--compact .budget__matrix-hours { width: 55px; }
.budget__matrix--compact .budget__hours-input { font-size: 10px; }
.budget__matrix--compact .budget__matrix-total-cell { min-width: 60px; padding-right: 8px; }
.budget__matrix--compact .budget__person-header span { font-size: 11px; }
.budget__matrix--compact .budget__person-header small { font-size: 10px; }
.budget__matrix--compact .budget__person-rate { font-size: 10px; }
.budget__matrix--compact .budget__role-btn { padding: 2px 4px; font-size: 10px; }
.budget__matrix--compact .budget__matrix-header-roles th { padding: 4px 4px; font-size: 10px; }

/* Auto-compact on narrow viewports */
@media (max-width: 1400px) {
    .budget__matrix:not(.budget__matrix--compact) .budget__matrix-th--task { width: 220px; min-width: 160px; }
    .budget__matrix:not(.budget__matrix--compact) .budget__matrix-th--person { width: 100px; min-width: 60px; }
}

@media (max-width: 1200px) {
    .budget__matrix .budget__matrix-th--task { width: 180px; min-width: 140px; }
    .budget__matrix .budget__matrix-th--date { width: 80px; min-width: 65px; }
    .budget__matrix .budget__matrix-th--person { width: 85px; min-width: 55px; padding: 4px 4px; }
    .budget__matrix .budget__task-desc-input { width: 160px; }
    .budget__matrix .budget__matrix-hours { width: 55px; }
}

/* Stretch column (fills remaining width) - hidden for responsive layout */
.budget__matrix-td--stretch {
    display: none;
}

/* Row total cell */
.budget__matrix .budget__matrix-total {
    text-align: right;
    padding-right: 12px;
    font-weight: 600;
    color: var(--color-text, #1f2937);
    background: var(--color-surface, #f9fafb);
    font-variant-numeric: tabular-nums;
    min-width: 80px;
    width: 80px;
}

.budget__person-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    position: relative;
}

.budget__person-header span { font-weight: 600; color: var(--color-text, #1f2937); font-size: 12px; }
.budget__person-header small { font-size: 11px; color: var(--color-text, #1f2937); font-weight: 500; line-height: 1.2; }

/* Clickable role button in header */
.budget__role-btn {
    background: transparent;
    border: none;
    color: inherit;
    font: inherit;
    text-transform: inherit;
    letter-spacing: inherit;
    cursor: pointer;
    padding: 4px 6px;
    border-radius: 4px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    transition: background var(--transition-fast);
}

.budget__role-btn:hover {
    background: var(--color-primary-light, rgba(37, 99, 235, 0.2));
}

.budget__role-btn i {
    font-size: 9px;
    opacity: 0;
    transition: opacity var(--transition-fast);
}

.budget__role-btn:hover i {
    opacity: 1;
}

/* Column drag handle */
.budget__col-drag-handle {
    position: absolute;
    left: 4px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 10px;
    color: var(--color-text-muted, #9ca3af);
    opacity: 0;
    cursor: grab;
    transition: opacity var(--transition-fast), color var(--transition-fast);
    z-index: 1;
}

.budget__matrix-col--draggable {
    position: relative;
    cursor: grab;
    transition: background var(--transition-fast), box-shadow var(--transition-fast);
}

.budget__matrix-col--draggable:hover .budget__col-drag-handle {
    opacity: 1;
}

.budget__matrix-col--draggable:hover {
    background: var(--color-surface-hover, rgba(0, 0, 0, 0.02));
}

/* Dragging state */
.budget__matrix-col--dragging {
    opacity: 0.5;
    background: var(--color-primary-bg, #eff6ff);
    cursor: grabbing;
}

/* Drop indicators */
.budget__matrix-col--drop-before {
    box-shadow: inset 3px 0 0 var(--color-primary, #3b82f6);
}

.budget__matrix-col--drop-after {
    box-shadow: inset -3px 0 0 var(--color-primary, #3b82f6);
}

/* Cell highlighting during drag */
.budget__matrix-cell--highlight {
    background: var(--color-primary-bg, rgba(59, 130, 246, 0.08));
}

/* Clickable person button in header */
.budget__person-btn {
    background: transparent;
    border: none;
    color: inherit;
    font: inherit;
    cursor: pointer;
    padding: 4px 6px;
    border-radius: 4px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    transition: background var(--transition-fast);
}

.budget__person-btn:hover {
    background: var(--color-surface-hover, #e2e8f0);
}

.budget__person-btn span { font-weight: 600; color: var(--color-text, #1f2937); font-size: 12px; }
.budget__person-btn small { font-size: 11px; color: var(--color-text, #1f2937); font-weight: 500; line-height: 1.2; }

.budget__person-btn i {
    font-size: 8px;
    color: var(--color-text-secondary, #374151);
    opacity: 0;
    transition: opacity var(--transition-fast);
    margin-top: 3px;
}

.budget__person-btn:hover i {
    opacity: 1;
}

.budget__person-rate {
    color: var(--color-text, #1f2937);
    font-weight: 600;
    font-size: 11px;
    font-variant-numeric: tabular-nums;
    margin-top: 2px;
}

.budget__person-remove {
    position: absolute;
    top: -3px;
    right: -3px;
    padding: 1px;
    background: var(--color-card-bg, #ffffff);
    border: 1px solid var(--color-danger, #dc2626);
    border-radius: 50%;
    color: var(--color-danger, #dc2626);
    cursor: pointer;
    width: 14px;
    height: 14px;
    font-size: 7px;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity var(--transition-fast);
}

.budget__matrix-th--person:hover .budget__person-remove { opacity: 1; }

/* Section headers */
.budget__matrix-section-header td {
    background: var(--color-surface-hover, #f1f5f9);
    font-weight: 700;
    color: var(--color-text, #1f2937);
    padding: 4px 6px;
    font-size: 11px;
    border-left: 3px solid var(--color-primary, #3b82f6);
}

.budget__section-name-input {
    background: transparent;
    border: none;
    font-weight: 700;
    color: var(--color-text, #1f2937);
    font-size: 11px;
    width: 160px;
    padding: 0;
}

.budget__section-name-input:focus { outline: none; background: var(--color-bg, #ffffff); border-radius: 3px; padding: 1px 3px; }

.budget__section-remove {
    padding: 1px 4px;
    background: transparent;
    border: none;
    color: var(--color-danger, #dc2626);
    cursor: pointer;
    font-size: 10px;
    opacity: 0.4;
    float: right;
}

.budget__section-remove:hover { opacity: 1; }

/* Task rows */
.budget__matrix-row:hover { background: var(--color-surface-hover, #f8fafc); }

.budget__matrix-task {
    width: 280px;
    min-width: 200px;
    padding-left: 12px;
    position: relative;
    white-space: nowrap;
}

.budget__task-prefix {
    display: inline;
    vertical-align: middle;
    color: var(--color-text-muted, #9ca3af);
    margin-right: 3px;
    font-size: 11px;
    flex-shrink: 0;
}

.budget__task-desc-input,
.budget__task-date-input,
.budget__hours-input {
    padding: 2px 4px;
    border: 1px solid transparent;
    border-radius: 3px;
    font-size: 11px;
    font-family: inherit;
    background: transparent;
    transition: all var(--transition-fast);
}

.budget__task-desc-input:hover,
.budget__task-date-input:hover,
.budget__hours-input:hover {
    border-color: var(--color-border, #d1d5db);
    background: var(--color-input-bg, #ffffff);
}

.budget__task-desc-input:focus,
.budget__task-date-input:focus,
.budget__hours-input:focus {
    outline: none;
    border-color: var(--color-primary, #3b82f6);
    background: var(--color-input-bg, #ffffff);
}

.budget__task-desc-input {
    width: 220px;
    display: inline-block;
    vertical-align: middle;
}

/* Custom date input wrapper */
.budget__date-input-wrap {
    position: relative;
    display: inline-flex;
    align-items: center;
    width: 100%;
}

.budget__task-date-input {
    width: 100%;
    text-align: center;
    font-size: 11px;
    padding-right: 22px;
}

.budget__task-date-input::placeholder {
    color: var(--color-text-muted, #9ca3af);
    opacity: 0.6;
}

/* Hidden native date picker */
.budget__date-native {
    position: absolute;
    right: 2px;
    top: 50%;
    transform: translateY(-50%);
    width: 18px;
    height: 18px;
    opacity: 0;
    cursor: pointer;
    z-index: 2;
}

/* Calendar icon trigger */
.budget__date-calendar-btn {
    position: absolute;
    right: 2px;
    top: 50%;
    transform: translateY(-50%);
    width: 18px;
    height: 18px;
    background: transparent;
    border: none;
    color: var(--color-text-muted, #9ca3af);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition-fast), color var(--transition-fast);
    z-index: 1;
}

.budget__date-input-wrap:hover .budget__date-calendar-btn,
.budget__date-input-wrap:focus-within .budget__date-calendar-btn {
    opacity: 1;
    pointer-events: auto;
}

.budget__date-calendar-btn:hover {
    color: var(--color-primary, #3b82f6);
}
.budget__hours-input {
    width: 100%;
    text-align: center;
    /* Remove spinner arrows */
    -moz-appearance: textfield;
}
.budget__hours-input::-webkit-outer-spin-button,
.budget__hours-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.budget__matrix .budget__matrix-hours {
    text-align: center;
    width: 80px;
    font-variant-numeric: tabular-nums;
}
.budget__matrix .budget__matrix-date { text-align: center; width: 100px; }

.budget__task-remove {
    position: absolute;
    right: 4px;
    top: 50%;
    transform: translateY(-50%);
    padding: 2px 4px;
    background: transparent;
    border: none;
    color: var(--color-text-muted, #9ca3af);
    cursor: pointer;
    opacity: 0;
    transition: opacity var(--transition-fast);
    font-size: 10px;
}

.budget__matrix-row:hover .budget__task-remove { opacity: 1; }
.budget__task-remove:hover { color: var(--color-danger, #dc2626); background: var(--color-danger-bg, rgba(220, 38, 38, 0.1)); border-radius: 3px; }

/* Add buttons */
.budget__matrix-row--add-section td,
.budget__matrix-row--add-task td {
    background: transparent;
    border: none;
    padding: 3px 6px;
}

.budget__add-section-btn,
.budget__add-task-btn {
    padding: 2px 8px;
    background: transparent;
    border: 1px dashed var(--color-border, #d1d5db);
    border-radius: 3px;
    color: var(--color-text-muted, #9ca3af);
    font-size: 10px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 3px;
    transition: all var(--transition-fast);
}

.budget__add-section-btn:hover,
.budget__add-task-btn:hover {
    border-color: var(--color-primary, #3b82f6);
    color: var(--color-primary, #3b82f6);
}

.budget__add-section-btn i,
.budget__add-task-btn i { font-size: 9px; }

/* Matrix totals row */
.budget__matrix-totals td {
    background: var(--color-surface, #f8fafc);
    font-weight: 600;
    font-size: 11px;
}

/* Hours row - subtle top border */
.budget__matrix .budget__matrix-totals--hours td {
    border-top: 2px solid var(--color-border, #e5e7eb);
    color: var(--color-text-secondary, #64748b);
}

/* Spacer row - creates visual gap */
.budget__matrix .budget__matrix-totals--spacer td {
    height: 8px;
    padding: 0;
    background: var(--color-card-bg, #ffffff);
    border: none;
}

/* Amount row - prominent styling */
.budget__matrix .budget__matrix-totals--amount td {
    border-top: 1px solid var(--color-border, #e5e7eb);
    color: var(--color-text, #1f2937);
    font-weight: 700;
}

.budget__matrix .budget__matrix-total-cell {
    text-align: right;
    padding-right: 12px;
    font-variant-numeric: tabular-nums;
    min-width: 80px;
}


.budget__matrix .budget__matrix-total-cell--grand {
    background: var(--color-surface, #f8fafc);
    color: var(--color-text, #1f2937);
    font-weight: 600;
    text-align: right;
    padding-right: 12px;
    border-left: 1px solid var(--color-border, #e2e8f0);
    min-width: 80px;
    width: 80px;
}

/* Time subtotal row */
.budget__matrix .budget__matrix-totals--subtotal td {
    background: var(--color-surface, #f8fafc);
    color: var(--color-text, #1f2937);
    border-top: 1px solid var(--color-border, #e5e7eb);
}

.budget__matrix .budget__matrix-totals--subtotal td strong {
    color: var(--color-text, #1f2937);
}

.budget__matrix .budget__matrix-totals--subtotal .budget__matrix-total-cell--grand {
    background: var(--color-surface, #f8fafc);
    text-align: right;
    padding-right: 12px;
}

.budget__matrix .budget__matrix-totals--subtotal .budget__matrix-total-cell--grand strong {
    color: var(--color-text, #1f2937);
}

/* Empty state */
.budget__empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    padding: 24px;
    color: var(--color-text-muted, #6b7280);
    text-align: center;
}

.budget__empty i { font-size: 24px; opacity: 0.3; }
.budget__empty p { margin: 0; font-size: 12px; }

/* ============================================================================
   SIMPLE BUDGET (Line items)
   ============================================================================ */

.budget__simple { }

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

.budget__add-line-btn {
    padding: 3px 8px;
    background: var(--color-primary, #3b82f6);
    color: var(--color-bg, #ffffff);
    border: none;
    border-radius: var(--radius-sm);
    font-size: 10px;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 3px;
}

.budget__add-line-btn:hover { background: var(--color-primary-hover, #2563eb); }
.budget__add-line-btn i { font-size: 9px; }

.budget__simple-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 11px;
    margin-bottom: 10px;
}

.budget__simple-table th,
.budget__simple-table td {
    padding: 4px 6px;
    text-align: left;
    border-bottom: 1px solid var(--color-border, #e5e7eb);
}

.budget__simple-table th {
    background: var(--color-surface, #f1f5f9);
    font-weight: 700;
    font-size: 9px;
    text-transform: uppercase;
    color: var(--color-text-muted, #64748b);
    letter-spacing: 0.3px;
    padding: 5px 6px;
}

/* Align numeric columns in simple table - hours/rate centered, amounts right */
.budget__simple-table th:nth-child(2),
.budget__simple-table th:nth-child(3),
.budget__simple-table td:nth-child(2),
.budget__simple-table td:nth-child(3) {
    text-align: center;
}

.budget__simple-table th:nth-child(4),
.budget__simple-table td:nth-child(4) {
    text-align: right;
}

.budget__simple-table tbody tr:hover { background: var(--color-surface-hover, #f8fafc); }

.budget__simple-table tfoot td {
    border-top: 2px solid var(--color-text-muted, #94a3b8);
    background: var(--color-surface-hover, #e2e8f0);
    font-size: 11px;
    font-weight: 700;
    padding: 5px 6px;
}

.budget__simple-table tfoot td:nth-child(4) {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.budget__line-person,
.budget__line-hours,
.budget__line-rate,
.budget__line-desc,
.budget__line-custom-name {
    padding: 3px 6px;
    border: 1px solid var(--color-border, #d1d5db);
    border-radius: 3px;
    font-size: 11px;
    font-family: inherit;
    background: var(--color-input-bg, #ffffff);
}

.budget__line-person:focus,
.budget__line-hours:focus,
.budget__line-rate:focus,
.budget__line-desc:focus,
.budget__line-custom-name:focus {
    outline: none;
    border-color: var(--color-primary, #3b82f6);
}

.budget__line-person { width: 130px; }
.budget__line-hours { width: 50px; text-align: center; font-variant-numeric: tabular-nums; }
.budget__line-rate { width: 65px; text-align: center; font-variant-numeric: tabular-nums; }
.budget__line-desc { width: 100%; min-width: 80px; }
.budget__line-custom-name { width: 100px; margin-top: 3px; font-size: 10px; }
.budget__line-amount { font-weight: 700; white-space: nowrap; font-size: 11px; text-align: right; font-variant-numeric: tabular-nums; }

.budget__line-remove {
    padding: 2px;
    background: transparent;
    border: none;
    color: var(--color-text-muted, #9ca3af);
    cursor: pointer;
    font-size: 10px;
    opacity: 0.5;
    transition: opacity var(--transition-fast);
}

.budget__simple-table tbody tr:hover .budget__line-remove { opacity: 1; }
.budget__line-remove:hover { color: var(--color-danger, #dc2626); }

.budget__empty-small {
    text-align: center;
    padding: 16px;
    color: var(--color-text-muted, #9ca3af);
    font-size: 11px;
}

/* ============================================================================
   BASIC QUOTE
   ============================================================================ */

.budget__basic { }

.budget__basic-section { margin-bottom: 16px; }

.budget__basic-label {
    display: block;
    font-size: 11px;
    font-weight: 700;
    color: var(--color-text-muted, #64748b);
    margin-bottom: 3px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.budget__basic-hint {
    font-size: 11px;
    color: var(--color-text-muted, #9ca3af);
    margin: 0 0 6px 0;
}

.budget__basic-textarea {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid var(--color-border, #d1d5db);
    border-radius: var(--radius-sm);
    font-size: 12px;
    font-family: inherit;
    resize: vertical;
    min-height: 100px;
    line-height: 1.5;
}

.budget__basic-textarea:focus { outline: none; border-color: var(--color-primary, #3b82f6); }

.budget__basic-description-readonly {
    padding: 10px 12px;
    background: var(--color-surface, #f8fafc);
    border-radius: var(--radius-sm);
    font-size: 12px;
    line-height: 1.6;
    white-space: pre-wrap;
    border: 1px solid var(--color-border, #e2e8f0);
}

.budget__basic-total-section { margin-bottom: 10px; }

.budget__basic-amount-input {
    display: flex;
    align-items: center;
    gap: 4px;
}

.budget__basic-amount-input span { font-size: 14px; font-weight: 600; color: var(--color-text-muted, #64748b); }

.budget__basic-amount-input input {
    width: 120px;
    padding: 8px 10px;
    border: 2px solid var(--color-border, #d1d5db);
    border-radius: var(--radius-sm);
    font-size: 16px;
    font-weight: 700;
    text-align: right;
    font-family: inherit;
}

.budget__basic-amount-input input:focus { outline: none; border-color: var(--color-primary, #3b82f6); }

.budget__basic-amount-readonly {
    font-size: 18px;
    font-weight: 700;
    color: var(--color-primary, #3b82f6);
    font-variant-numeric: tabular-nums;
    text-align: right;
}

/* ============================================================================
   GRAND TOTAL
   ============================================================================ */

.budget__grand-total {
    padding: 8px 0;
    border-top: 2px solid var(--color-text, #1f2937);
    margin-top: 4px;
    width: 100%;
}

.budget__total-row {
    display: flex;
    justify-content: flex-end;
    align-items: baseline;
    gap: 16px;
}

.budget__total-label {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--color-text, #1f2937);
    display: flex;
    align-items: center;
    gap: 8px;
}

.budget__total-amount {
    font-size: 20px;
    font-weight: 700;
    min-width: 140px;
    text-align: right;
    font-variant-numeric: tabular-nums;
    color: var(--color-text, #1f2937);
}

.budget__total-amount--override {
    color: var(--color-warning-dark, #b45309);
}

.budget__calculated-note {
    text-align: right;
    font-size: 10px;
    color: var(--color-text-muted, #6b7280);
    margin-top: 2px;
}

.budget__override-badge {
    background: var(--color-warning-bg, #fef3c7);
    color: var(--color-warning-dark, #b45309);
    padding: 2px 6px;
    border-radius: 3px;
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    font-weight: 600;
}

/* Budget Summary Section */
.budget__summary-section {
    padding: 8px 0;
}

.budget__summary-row {
    display: flex;
    justify-content: flex-end;
    align-items: baseline;
    gap: 16px;
    padding: 4px 0;
}

.budget__summary-row--total {
    padding-bottom: 8px;
}

.budget__summary-label {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    color: var(--color-text-secondary, #64748b);
    display: flex;
    align-items: center;
    gap: 6px;
}

.budget__summary-row--total .budget__summary-label {
    font-size: 12px;
    font-weight: 700;
    color: var(--color-text, #1f2937);
}

.budget__summary-amount {
    font-size: 13px;
    font-weight: 600;
    min-width: 140px;
    text-align: right;
    font-variant-numeric: tabular-nums;
    color: var(--color-text-secondary, #64748b);
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

.budget__summary-amount--total {
    font-size: 20px;
    font-weight: 700;
    color: var(--color-text, #1f2937);
}

.budget__summary-amount--override {
    color: var(--color-warning-dark, #b45309);
}

.budget__summary-note {
    font-size: 10px;
    font-weight: 400;
    color: var(--color-text-muted, #9ca3af);
    margin-top: 1px;
}

.budget__summary-hint {
    color: var(--color-text-muted, #9ca3af);
    font-size: 10px;
    cursor: help;
}

.budget__summary-hint:hover {
    color: var(--color-primary, #3b82f6);
}

.budget__summary-divider {
    height: 1px;
    background: var(--color-border, #e5e7eb);
    margin: 8px 0;
}

/* Safety Margin Colors */
.budget__margin--positive {
    color: var(--color-success, #22c55e);
}

.budget__margin--negative {
    color: var(--color-danger, #ef4444);
}

/* ============================================================================
   BUDGET ACTIONS
   ============================================================================ */

.budget__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}

.budget__save-btn {
    padding: 8px 16px;
    background: var(--color-primary, #3b82f6);
    color: var(--color-on-primary);
    border: none;
    border-radius: var(--radius-sm);
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.budget__save-btn:hover { background: var(--color-primary-hover, #2563eb); }
.budget__save-btn:disabled { opacity: 0.5; cursor: not-allowed; }

.budget__lock-btn,
.budget__export-btn {
    padding: 8px 12px;
    background: var(--color-surface, #f1f5f9);
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-sm);
    font-size: 11px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: var(--color-text, #374151);
}

.budget__lock-btn:hover,
.budget__export-btn:hover {
    background: var(--color-surface-hover, #e2e8f0);
}

/* Template actions */
.budget__template-actions {
    display: flex;
    gap: 8px;
    margin-bottom: 12px;
}

.budget__template-btn {
    padding: 6px 10px;
    background: var(--color-surface, #f1f5f9);
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-sm);
    font-size: 11px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: var(--color-text, #374151);
    transition: all var(--transition-fast);
}

.budget__template-btn:hover:not(:disabled) {
    background: var(--color-surface-hover, #e2e8f0);
    border-color: var(--color-primary, #3b82f6);
    color: var(--color-primary, #3b82f6);
}

.budget__template-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.budget__template-btn i { font-size: 10px; }

/* ============================================================================
   BUDGET FOOTER
   ============================================================================ */

.budget__footer {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 8px;
    padding-top: 12px;
    margin-top: 12px;
    width: 100%;
}

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

.budget__override-label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--color-text-muted, #64748b);
    cursor: pointer;
}

.budget__override-label input[type="checkbox"] {
    width: 14px;
    height: 14px;
    cursor: pointer;
}

.budget__override-input {
    display: flex;
    align-items: center;
    gap: 4px;
}

.budget__override-input span {
    font-size: 12px;
    color: var(--color-text-muted, #64748b);
}

.budget__override-input input {
    width: 100px;
    padding: 4px 8px;
    font-size: 12px;
    border: 1px solid var(--color-border, #d1d5db);
    border-radius: var(--radius-sm);
    text-align: right;
}

.budget__override-input input:focus {
    outline: none;
    border-color: var(--color-primary, #3b82f6);
}

/* ============================================================================
   BUDGET COMPARISON (Prior Year)
   ============================================================================ */

.budget__comparison {
    margin-top: 12px;
    padding-top: 8px;
    width: 100%;
}

/* Collapsible toggle header */
.budget__comparison-toggle {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 0;
    cursor: pointer;
    user-select: none;
}

.budget__comparison-toggle:hover {
    color: var(--color-primary, #3b82f6);
}

.budget__comparison-toggle i {
    font-size: 10px;
    color: var(--color-text-muted, #64748b);
    transition: transform 0.2s ease;
    width: 12px;
}

.budget__comparison:not(.budget__comparison--collapsed) .budget__comparison-toggle i {
    transform: rotate(90deg);
}

.budget__comparison-toggle-title {
    font-size: 11px;
    font-weight: 600;
    color: var(--color-text-secondary, #475569);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.budget__comparison-toggle-summary {
    flex: 1;
    text-align: right;
    font-size: 11px;
    color: var(--color-text-muted, #64748b);
    font-variant-numeric: tabular-nums;
}

.budget__comparison-toggle-summary span {
    margin-left: 8px;
    font-weight: 600;
}

/* Content area - hidden when collapsed */
.budget__comparison-content {
    padding: 8px 0;
}

.budget__comparison--collapsed .budget__comparison-content {
    display: none;
}

.budget__comparison-controls {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 10px;
}

/* Legacy header - kept for backwards compatibility */
.budget__comparison-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
}

.budget__escalation {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--color-text-muted, #64748b);
}

.budget__escalation label {
    font-weight: 500;
}

.budget__escalation input {
    width: 50px;
    padding: 3px 6px;
    font-size: 11px;
    text-align: center;
    border: 1px solid var(--color-border, #d1d5db);
    border-radius: 3px;
}

.budget__escalation input:focus {
    outline: none;
    border-color: var(--color-primary, #3b82f6);
}

.budget__escalation-refresh {
    padding: 4px 6px;
    background: transparent;
    border: 1px solid var(--color-border, #d1d5db);
    border-radius: 3px;
    cursor: pointer;
    color: var(--color-text-muted, #64748b);
    transition: all var(--transition-fast);
}

.budget__escalation-refresh:hover {
    background: var(--color-surface-hover, #e2e8f0);
    color: var(--color-primary, #3b82f6);
    border-color: var(--color-primary, #3b82f6);
}

.budget__escalation-refresh i {
    font-size: 10px;
}

.budget__comparison-empty {
    text-align: center;
    padding: 16px;
    color: var(--color-text-muted, #94a3b8);
}

.budget__comparison-empty small {
    font-size: 11px;
    font-style: italic;
}

.budget__comparison-table {
    width: auto;
    min-width: 100%;
    border-collapse: collapse;
    font-size: 11px;
}

.budget__comparison-table th,
.budget__comparison-table td {
    padding: 6px 8px;
    text-align: left;
    border-bottom: 1px solid var(--color-border, #e2e8f0);
}

.budget__comparison-table th {
    font-weight: 600;
    color: var(--color-text-muted, #64748b);
    background: var(--color-surface, #f1f5f9);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.budget__comparison-table td {
    color: var(--color-text, #1f2937);
}

.budget__comparison-table td:not(:first-child) {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

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

.budget__comparison-table tfoot td {
    font-weight: 600;
    background: var(--color-surface, #f1f5f9);
    border-top: 2px solid var(--color-border, #d1d5db);
}

.budget__comparison-variance--positive,
.budget__comparison-variance--under {
    color: var(--color-success, #16a34a);
}

.budget__comparison-variance--negative,
.budget__comparison-variance--over {
    color: var(--color-danger, #dc2626);
}

/* Manual Prior Amount */
.budget__comparison-manual {
    padding: 12px 0;
}

.budget__comparison-manual-info {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin: 0 0 16px 0;
    padding: 10px 12px;
    background: var(--color-info-bg, rgba(59, 130, 246, 0.1));
    border-radius: var(--radius-sm);
    font-size: 0.85rem;
    color: var(--color-text-muted, #6b7280);
    line-height: 1.4;
}

.budget__comparison-manual-info i {
    color: var(--color-info, #3b82f6);
    margin-top: 2px;
    flex-shrink: 0;
}

.budget__comparison-manual-input {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

.budget__comparison-manual-input label {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--color-text, #1f2937);
    white-space: nowrap;
}

.budget__comparison-manual-field {
    display: flex;
    align-items: center;
    gap: 4px;
}

.budget__comparison-manual-prefix {
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--color-text-muted, #6b7280);
    padding: 0 4px;
}

.budget__comparison-manual-amount {
    width: 140px;
    padding: 8px 12px;
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-sm);
    font-size: 0.9rem;
    background: var(--color-input-bg, #ffffff);
    color: var(--color-text, #1f2937);
    transition: border-color 0.15s ease;
}

.budget__comparison-manual-amount:focus {
    outline: none;
    border-color: var(--color-primary, #3b82f6);
}

.budget__comparison-manual-amount:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.budget__comparison-manual-save,
.budget__comparison-manual-clear {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: none;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all 0.15s ease;
}

.budget__comparison-manual-save {
    background: var(--color-success, #10b981);
    color: white;
}

.budget__comparison-manual-save:hover:not(:disabled) {
    background: var(--color-success-hover, #059669);
}

.budget__comparison-manual-clear {
    background: var(--color-danger-light, rgba(220, 38, 38, 0.1));
    color: var(--color-danger, #dc2626);
}

.budget__comparison-manual-clear:hover:not(:disabled) {
    background: var(--color-danger, #dc2626);
    color: white;
}

.budget__comparison-manual-save:disabled,
.budget__comparison-manual-clear:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.budget__comparison-table--manual {
    margin-top: 8px;
}

/* ============================================================================
   BUDGET TEMPLATE MODALS
   ============================================================================ */

.budget__template-modal-overlay,
.budget__import-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
}

.budget__template-modal,
.budget__import-modal {
    background: var(--color-card-bg, #ffffff);
    border-radius: var(--radius-lg);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.2);
    width: 90%;
    max-width: 480px;
    max-height: 90vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.budget__template-modal-header,
.budget__import-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--color-border, #e5e7eb);
}

.budget__template-modal-header h3,
.budget__import-modal-header h3 {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--color-text, #1f2937);
}

.budget__template-modal-close,
.budget__import-modal-close {
    background: none;
    border: none;
    font-size: 1.5rem;
    cursor: pointer;
    color: var(--color-text-muted, #6b7280);
    line-height: 1;
    padding: 4px;
}

.budget__template-modal-close:hover,
.budget__import-modal-close:hover {
    color: var(--color-text, #1f2937);
}

.budget__template-modal-body,
.budget__import-modal-body {
    padding: 20px;
    overflow-y: auto;
}

.budget__template-modal-warning,
.budget__import-modal-warning {
    background: var(--color-warning-bg);
    color: var(--color-warning-text);
    padding: 12px;
    border-radius: var(--radius-md);
    margin-bottom: 16px;
    font-size: 0.875rem;
    display: flex;
    align-items: center;
    gap: 8px;
}

.budget__import-modal-info {
    background: var(--color-primary-light, #eff6ff);
    color: var(--color-primary, #3b82f6);
    padding: 12px;
    border-radius: var(--radius-md);
    margin-bottom: 12px;
    font-size: 0.875rem;
    display: flex;
    align-items: flex-start;
    gap: 8px;
}

.budget__template-modal-label,
.budget__import-modal-label {
    display: block;
    font-weight: 500;
    color: var(--color-text, #1f2937);
    margin-bottom: 6px;
    font-size: 0.875rem;
}

.budget__template-modal-select,
.budget__template-modal-input,
.budget__template-modal-textarea,
.budget__import-modal-input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-md);
    font-size: 0.875rem;
    margin-bottom: 16px;
    background: var(--color-input-bg, #ffffff);
    color: var(--color-text, #1f2937);
}

.budget__template-modal-select:focus,
.budget__template-modal-input:focus,
.budget__template-modal-textarea:focus,
.budget__import-modal-input:focus {
    outline: none;
    border-color: var(--color-primary, #3b82f6);
    box-shadow: 0 0 0 3px var(--color-primary-light, rgba(59, 130, 246, 0.1));
}

.budget__template-modal-textarea {
    min-height: 80px;
    resize: vertical;
}

.budget__template-modal-description {
    color: var(--color-text-muted, #6b7280);
    font-size: 0.875rem;
    font-style: italic;
    min-height: 20px;
}

.budget__import-modal-input-group {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 16px;
}

.budget__import-modal-input-group .budget__import-modal-input {
    margin-bottom: 0;
    width: 100px;
}

.budget__import-modal-suffix {
    color: var(--color-text-muted, #6b7280);
    font-weight: 500;
}

.budget__import-modal-preview {
    margin-top: 16px;
    min-height: 60px;
}

.budget__import-modal-preview-content {
    background: var(--color-surface, #f9fafb);
    border-radius: var(--radius-md);
    padding: 12px;
}

.budget__import-modal-preview-content p {
    margin: 0 0 8px 0;
    font-size: 0.875rem;
}

.budget__import-modal-preview-content p:last-child {
    margin-bottom: 0;
}

.budget__import-modal-preview-total {
    padding-top: 8px;
    border-top: 1px solid var(--color-border, #e5e7eb);
    font-weight: 600;
}

.budget__import-modal-loading,
.budget__import-modal-error {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.875rem;
}

.budget__import-modal-error {
    color: var(--color-danger);
}

.budget__template-modal-footer,
.budget__import-modal-footer {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    padding: 16px 20px;
    border-top: 1px solid var(--color-border, #e5e7eb);
    background: var(--color-surface, #f9fafb);
}

.budget__template-modal-btn,
.budget__import-modal-btn {
    padding: 10px 16px;
    border-radius: var(--radius-md);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    border: 1px solid var(--color-border, #e5e7eb);
    background: var(--color-card-bg, #ffffff);
    color: var(--color-text, #1f2937);
    transition: all var(--transition-fast);
}

.budget__template-modal-btn:hover,
.budget__import-modal-btn:hover {
    background: var(--color-surface-hover, #f3f4f6);
}

.budget__template-modal-btn:disabled,
.budget__import-modal-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.budget__template-modal-btn--apply,
.budget__template-modal-btn--save,
.budget__import-modal-btn--import {
    background: var(--color-primary, #3b82f6);
    color: var(--color-on-primary);
    border-color: var(--color-primary, #3b82f6);
}

.budget__template-modal-btn--apply:hover,
.budget__template-modal-btn--save:hover,
.budget__import-modal-btn--import:hover {
    background: var(--color-primary-hover, #2563eb);
}

.budget__import-modal-btn--preview {
    background: var(--color-card-bg, #ffffff);
    margin-right: auto;
}

/* Wide variant for template modal with tabs */
.budget__template-modal--wide {
    max-width: 560px;
}

/* Template modal tabs */
.budget__template-modal-tabs {
    display: flex;
    gap: 4px;
    margin-bottom: 16px;
    border-bottom: 1px solid var(--color-border, #e5e7eb);
    padding-bottom: 0;
}

.budget__template-modal-tab {
    padding: 10px 16px;
    border: none;
    background: none;
    color: var(--color-text-muted, #6b7280);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 6px;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: all var(--transition-fast);
}

.budget__template-modal-tab:hover {
    color: var(--color-text, #1f2937);
}

.budget__template-modal-tab--active {
    color: var(--color-primary, #3b82f6);
    border-bottom-color: var(--color-primary, #3b82f6);
}

.budget__template-modal-tab i {
    font-size: 0.875rem;
}

/* Tab content */
.budget__template-modal-tab-content {
    animation: fadeIn 0.15s ease;
}

.budget__template-modal-tab-content--hidden {
    display: none;
}

/* Escalation input group */
.budget__template-modal-escalation {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--color-border, #e5e7eb);
}

.budget__template-modal-escalation-input {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-bottom: 4px;
}

.budget__template-modal-escalation-input .budget__template-modal-input {
    width: 80px;
    margin-bottom: 0;
    text-align: right;
}

.budget__template-modal-percent {
    color: var(--color-text-muted, #6b7280);
    font-weight: 500;
}

.budget__template-modal-hint {
    color: var(--color-text-muted, #6b7280);
    font-size: 0.75rem;
    display: block;
}

/* ============================================================================
   BUDGET ROLE MODAL
   ============================================================================ */

.budget__role-modal {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.budget__role-modal-section {
    margin-bottom: 12px;
}

.budget__role-modal-label {
    display: block;
    font-weight: 500;
    color: var(--color-text, #1f2937);
    margin-bottom: 6px;
    font-size: 0.875rem;
}

.budget__role-modal-select,
.budget__role-modal-input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-md);
    font-size: 0.875rem;
    background: var(--color-input-bg, #ffffff);
    color: var(--color-text, #1f2937);
}

.budget__role-modal-select:focus,
.budget__role-modal-input:focus {
    outline: none;
    border-color: var(--color-primary, #3b82f6);
    box-shadow: 0 0 0 3px var(--color-primary-light, rgba(59, 130, 246, 0.1));
}

.budget__role-modal-hint {
    margin-top: 6px;
    font-size: 0.75rem;
    color: var(--color-text-muted, #6b7280);
    font-style: italic;
}

.budget__role-modal-rate {
    padding: 10px 12px;
    background: var(--color-surface, #f8fafc);
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-md);
    font-size: 0.875rem;
    color: var(--color-text-muted, #6b7280);
}

.budget__role-modal-rate--active {
    color: var(--color-success, #16a34a);
    font-weight: 600;
}

/* Unassigned person in column header */
.budget__person-unassigned {
    color: var(--color-text-muted, #6b7280);
    font-style: italic;
    font-size: 0.8rem;
}

/* ============================================================================
   COSTS SECTION
   ============================================================================ */

.budget__costs-section {
    padding: 8px 0;
    margin-bottom: 8px;
    width: 100%;
}

.budget__costs-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 6px;
}

.budget__add-cost-btn {
    padding: 2px 8px;
    background: transparent;
    border: 1px dashed var(--color-border, #d1d5db);
    border-radius: 3px;
    color: var(--color-text-muted, #9ca3af);
    font-size: 10px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 3px;
}

.budget__add-cost-btn:hover {
    border-color: var(--color-primary, #3b82f6);
    color: var(--color-primary, #3b82f6);
}

.budget__add-cost-btn i { font-size: 9px; }

.budget__costs-list {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 6px;
}

.budget__cost-row {
    display: grid;
    grid-template-columns: 200px 20px 1fr 120px;
    align-items: center;
    gap: 6px;
}

/* Locked state - no remove button column */
.budget__cost-row--locked {
    grid-template-columns: 200px 1fr 120px;
}

.budget__cost-desc {
    flex: 1;
    font-size: 11px;
    color: var(--color-text, #1f2937);
}

.budget__cost-amount {
    font-weight: 600;
    font-size: 11px;
    min-width: 120px;
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.budget__cost-type-wrap {
    min-width: 0;
    overflow: hidden;
}

.budget__cost-type-select {
    width: 100%;
    padding: 4px 8px;
    border: 1px solid var(--color-border, #d1d5db);
    border-radius: 3px;
    font-size: 11px;
    font-family: inherit;
    background: var(--color-input-bg, #ffffff);
    color: var(--color-text, #1f2937);
    cursor: pointer;
}

.budget__cost-type-select:focus {
    outline: none;
    border-color: var(--color-primary, #3b82f6);
}

.budget__cost-type-label {
    min-width: 200px;
    font-size: 11px;
    font-weight: 500;
    color: var(--color-text-muted, #64748b);
}

.budget__cost-desc-wrap {
    min-width: 0;
    overflow: hidden;
}

.budget__cost-desc-input {
    width: 100%;
    padding: 3px 6px;
    border: 1px solid var(--color-border, #d1d5db);
    border-radius: 3px;
    font-size: 11px;
    font-family: inherit;
    background: var(--color-input-bg, #ffffff);
    color: var(--color-text, #1f2937);
}

.budget__cost-desc-input:focus {
    outline: none;
    border-color: var(--color-primary, #3b82f6);
}

.budget__cost-amount-wrap {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 3px;
}

.budget__cost-amount-wrap span {
    color: var(--color-text-muted, #9ca3af);
    font-size: 11px;
}

.budget__cost-amount-input {
    width: 80px;
    padding: 3px 6px;
    border: 1px solid var(--color-border, #d1d5db);
    border-radius: 3px;
    font-size: 11px;
    text-align: right;
    font-family: inherit;
    background: var(--color-input-bg, #ffffff);
    color: var(--color-text, #1f2937);
    font-variant-numeric: tabular-nums;
    -moz-appearance: textfield;
}

.budget__cost-amount-input::-webkit-outer-spin-button,
.budget__cost-amount-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.budget__cost-amount-input:focus {
    outline: none;
    border-color: var(--color-primary, #3b82f6);
}

.budget__cost-remove {
    padding: 2px;
    background: transparent;
    border: none;
    color: var(--color-text-muted, #9ca3af);
    cursor: pointer;
    font-size: 10px;
    opacity: 0.5;
    transition: opacity var(--transition-fast), color var(--transition-fast);
    justify-self: center;
}

.budget__cost-row:hover .budget__cost-remove { opacity: 1; }
.budget__cost-remove:hover {
    color: var(--color-danger, #dc2626);
    opacity: 1;
}

.budget__empty-costs {
    color: var(--color-text-muted, #9ca3af);
    font-size: 10px;
    padding: 6px 0;
    text-align: center;
}

.budget__subtotal {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 12px;
    padding-top: 6px;
    border-top: 1px solid var(--color-border, #e5e7eb);
    font-weight: 600;
    font-size: 11px;
}

.budget__subtotal--locked {
    /* Same as default - no grid differences needed */
}

.budget__subtotal span:first-child {
    text-align: right;
    white-space: nowrap;
}

.budget__subtotal span:last-child {
    text-align: right;
    font-variant-numeric: tabular-nums;
    font-weight: 700;
    white-space: nowrap;
}

/* ============================================================================
   OVERTIME DISPLAY
   ============================================================================ */

.budget__hours-wrap {
    display: flex;
    align-items: center;
    gap: 4px;
    position: relative;
}

/* Subtle overtime indicator - small dot instead of badge */
.budget__overtime-indicator {
    position: absolute;
    right: 2px;
    top: 2px;
    width: 6px;
    height: 6px;
    background: var(--color-primary, #3b82f6);
    border-radius: 50%;
    cursor: help;
    opacity: 0.8;
}

.budget__overtime-indicator:hover {
    opacity: 1;
    transform: scale(1.2);
}

/* Overtime cost row in costs section - subtle styling */
.budget__overtime-cost-row {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 6px;
    background: var(--color-surface, #f8fafc);
    border-left: 2px solid var(--color-primary, #3b82f6);
    border-radius: 0 3px 3px 0;
    font-size: 11px;
}

.budget__overtime-cost-label {
    flex: 1;
    color: var(--color-text-secondary, #64748b);
    font-weight: 500;
}

.budget__overtime-cost-amount {
    color: var(--color-text, #1f2937);
    font-weight: 600;
}

/* Overtime row in matrix totals - modern subtle styling */
.budget__matrix .budget__matrix-totals--overtime td {
    background: var(--color-surface, #f8fafc);
    border-top: 1px dashed var(--color-border, #e5e7eb);
}

.budget__matrix .budget__matrix-totals--overtime td strong {
    color: var(--color-text, #1f2937);
}

.budget__matrix .budget__matrix-totals--overtime small {
    font-weight: 400;
    color: var(--color-text-muted, #6b7280);
    margin-left: 4px;
}

/* Per-person overtime cells - subtle primary color */
.budget__matrix .budget__overtime-cell {
    color: var(--color-text-secondary, #64748b);
    font-size: 11px;
    text-align: right;
    padding-right: 12px;
}

.budget__overtime-cell span {
    cursor: help;
}

/* ============================================================================
   BILLING TYPE SELECTOR
   ============================================================================ */

.billing-type-selector {
    text-align: center;
    padding: 48px 24px;
}

.billing-type-selector__icon {
    width: 72px;
    height: 72px;
    margin: 0 auto 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-primary-bg);
    border-radius: 50%;
    font-size: 28px;
    color: var(--color-primary);
}

.billing-type-selector__title {
    font-size: 18px;
    font-weight: 600;
    color: var(--color-text);
    margin: 0 0 8px 0;
}

.billing-type-selector__desc {
    font-size: 14px;
    color: var(--color-text-muted);
    margin: 0 0 32px 0;
}

.billing-type-selector__options {
    display: flex;
    gap: 20px;
    justify-content: center;
    flex-wrap: wrap;
}

.billing-type-selector__option {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 24px 28px;
    background: var(--color-card-bg);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-lg);
    cursor: pointer;
    transition: all var(--transition-fast);
    text-align: left;
    min-width: 260px;
    max-width: 320px;
}

.billing-type-selector__option:hover {
    border-color: var(--color-primary);
    background: var(--color-primary-bg);
}

.billing-type-selector__option:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.billing-type-selector__option-icon {
    width: 48px;
    height: 48px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-surface);
    border-radius: 50%;
    font-size: 20px;
    color: var(--color-primary);
}

.billing-type-selector__option:hover .billing-type-selector__option-icon {
    background: var(--color-primary);
    color: var(--color-card-bg);
}

.billing-type-selector__option-content {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.billing-type-selector__option-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--color-text);
}

.billing-type-selector__option-desc {
    font-size: 13px;
    color: var(--color-text-muted);
    line-height: 1.4;
}

/* ============================================================================
   BILLING TYPE INDICATOR (shown in billing view header)
   ============================================================================ */

.billing-section__type-indicator {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: var(--color-primary-bg);
    color: var(--color-primary);
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
    margin-bottom: 20px;
}

.billing-section__type-indicator i {
    font-size: 14px;
}

/* ============================================================================
   PRODUCT BILLING PANEL
   ============================================================================ */

.product-billing-panel {
    margin-bottom: 24px;
}

.product-billing-panel--loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 48px;
    color: var(--color-text-muted);
}

.product-billing-panel__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}

.product-billing-panel__title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 15px;
    font-weight: 600;
    color: var(--color-text);
    margin: 0;
}

.product-billing-panel__title i {
    color: var(--color-primary);
}

.product-billing-panel__readonly-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    background: var(--color-surface);
    color: var(--color-text-muted);
    border-radius: 12px;
    font-size: 11px;
    font-weight: 500;
}

.product-billing-panel__empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 48px 24px;
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    text-align: center;
}

.product-billing-panel__empty i {
    font-size: 24px;
    color: var(--color-text-muted);
}

.product-billing-panel__empty p {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 14px;
}

.product-billing-panel__empty small {
    color: var(--color-text-muted);
    font-size: 12px;
}

/* Product List */
.product-billing-panel__list {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.product-billing-panel__item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 14px 16px;
    background: var(--color-card-bg);
    border-bottom: 1px solid var(--color-border);
    transition: background var(--transition-fast);
}

.product-billing-panel__item:last-child {
    border-bottom: none;
}

.product-billing-panel__item--selected {
    background: var(--color-primary-bg);
}

/* Custom Checkbox */
.product-billing-panel__checkbox {
    position: relative;
    display: flex;
    align-items: center;
    cursor: pointer;
}

.product-billing-panel__checkbox-input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
}

.product-billing-panel__checkmark {
    width: 20px;
    height: 20px;
    background: var(--color-card-bg);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition-fast);
}

.product-billing-panel__checkbox-input:checked + .product-billing-panel__checkmark {
    background: var(--color-primary);
    border-color: var(--color-primary);
}

.product-billing-panel__checkbox-input:checked + .product-billing-panel__checkmark::after {
    content: '\f00c';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    font-size: 11px;
    color: var(--color-card-bg);
}

.product-billing-panel__checkbox-input:disabled + .product-billing-panel__checkmark {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Product Info */
.product-billing-panel__info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

.product-billing-panel__name-row {
    display: flex;
    align-items: center;
    gap: 10px;
}

.product-billing-panel__code {
    font-size: 10px;
    font-weight: 600;
    color: var(--color-text-muted);
    background: var(--color-surface);
    padding: 2px 6px;
    border-radius: 3px;
    text-transform: uppercase;
}

.product-billing-panel__name {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text);
}

.product-billing-panel__description {
    font-size: 12px;
    color: var(--color-text-muted);
}

/* Quantity */
.product-billing-panel__quantity {
    width: 70px;
    text-align: center;
}

.product-billing-panel__qty-input {
    width: 56px;
    padding: 6px 8px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    text-align: center;
    font-size: 13px;
    font-weight: 500;
}

.product-billing-panel__qty-input:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px var(--color-primary-bg);
}

.product-billing-panel__qty-display {
    font-size: 13px;
    color: var(--color-text-muted);
}

/* Price */
.product-billing-panel__price {
    min-width: 100px;
    text-align: right;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
}

.product-billing-panel__unit-price {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text);
    font-variant-numeric: tabular-nums;
}

.product-billing-panel__line-total {
    font-size: 11px;
    color: var(--color-text-muted);
    font-variant-numeric: tabular-nums;
}

/* Totals */
.product-billing-panel__totals {
    margin-top: 16px;
    padding: 16px;
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
}

.product-billing-panel__totals-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 14px;
}

.product-billing-panel__totals-row span {
    color: var(--color-text-muted);
}

.product-billing-panel__totals-row strong {
    font-size: 18px;
    color: var(--color-primary);
    font-variant-numeric: tabular-nums;
}

/* ============================================================================
   PRODUCT BILLING - TIME COST COMPARISON
   ============================================================================ */

.product-billing-panel__comparison {
    margin-top: 20px;
    padding: 16px;
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
}

.product-billing-panel__comparison-header {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 600;
    color: var(--color-text-muted);
    margin-bottom: 16px;
}

.product-billing-panel__comparison-header i {
    color: var(--color-primary);
}

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

.product-billing-panel__comparison-stat {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.product-billing-panel__comparison-label {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--color-text-muted);
}

.product-billing-panel__comparison-value {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text);
    font-variant-numeric: tabular-nums;
}

.product-billing-panel__comparison-value small {
    font-size: 12px;
    font-weight: 500;
    color: inherit;
    opacity: 0.8;
}

.product-billing-panel__comparison-stat--highlight {
    padding: 8px 12px;
    border-radius: var(--radius-sm);
}

.product-billing-panel__comparison-stat--profit {
    background: rgba(22, 163, 74, 0.1);
}

.product-billing-panel__comparison-stat--profit .product-billing-panel__comparison-value {
    color: var(--color-success);
}

.product-billing-panel__comparison-stat--loss {
    background: rgba(220, 38, 38, 0.1);
}

.product-billing-panel__comparison-stat--loss .product-billing-panel__comparison-value {
    color: var(--color-danger);
}

/* Staff Breakdown */
.product-billing-panel__staff-breakdown {
    margin-top: 16px;
}

.product-billing-panel__staff-breakdown summary {
    font-size: 12px;
    font-weight: 500;
    color: var(--color-primary);
    cursor: pointer;
    padding: 8px 0;
}

.product-billing-panel__staff-breakdown summary:hover {
    text-decoration: underline;
}

.product-billing-panel__staff-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 12px;
    margin-top: 8px;
}

.product-billing-panel__staff-table th,
.product-billing-panel__staff-table td {
    padding: 8px 12px;
    text-align: left;
    border-bottom: 1px solid var(--color-border);
}

.product-billing-panel__staff-table th {
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    font-size: 10px;
    letter-spacing: 0.5px;
}

.product-billing-panel__staff-table th:nth-child(n+2),
.product-billing-panel__staff-table td:nth-child(n+2) {
    text-align: right;
}

/* Prior Year Comparison */
.product-billing-panel__comparison-stat--prior {
    background: rgba(99, 102, 241, 0.08);
    padding: 8px 12px;
    border-radius: var(--radius-sm);
}

.product-billing-panel__comparison-stat--prior .product-billing-panel__comparison-label {
    color: var(--color-primary);
}

.product-billing-panel__comparison-stat--prior .product-billing-panel__comparison-value {
    color: var(--color-primary);
}

/* Time Warning */
.product-billing-panel__time-warning {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-top: 16px;
    padding: 12px 14px;
    background: rgba(245, 158, 11, 0.08);
    border: 1px solid rgba(245, 158, 11, 0.2);
    border-radius: var(--radius-md);
    font-size: 12px;
    color: var(--color-text-secondary);
    line-height: 1.5;
}

.product-billing-panel__time-warning i {
    color: var(--color-warning);
    font-size: 14px;
    flex-shrink: 0;
    margin-top: 1px;
}

.product-billing-panel__time-warning strong {
    color: var(--color-text);
}

/* ============================================================================
   RESPONSIVE STYLES FOR PRODUCT BILLING
   ============================================================================ */

@media (max-width: 768px) {
    .billing-type-selector__options {
        flex-direction: column;
        align-items: center;
    }

    .billing-type-selector__option {
        width: 100%;
        max-width: 100%;
    }

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

    .product-billing-panel__item {
        flex-wrap: wrap;
    }

    .product-billing-panel__quantity {
        width: auto;
    }

    .product-billing-panel__price {
        min-width: auto;
    }
}

/* ============================================================================
   VARIANCE ANALYSIS
   ============================================================================ */

.variance-analysis {
    margin-top: 16px;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    background: var(--color-bg);
    overflow: hidden;
}

.variance-analysis__header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    background: var(--color-card-bg);
    cursor: pointer;
    user-select: none;
    transition: background var(--transition-fast);
}

.variance-analysis__header:hover {
    background: var(--color-hover);
}

.variance-analysis__toggle-icon {
    font-size: 10px;
    color: var(--color-text-muted);
    transition: transform var(--transition-fast);
}

.variance-analysis--collapsed .variance-analysis__toggle-icon {
    transform: rotate(-90deg);
}

.variance-analysis--collapsed .variance-analysis__content {
    display: none;
}

.variance-analysis__title {
    font-size: 12px;
    font-weight: 600;
    color: var(--color-text);
}

.variance-analysis__alert {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    color: var(--color-warning);
    font-weight: 500;
}

.variance-analysis__alert i {
    font-size: 10px;
}

.variance-analysis__content {
    padding: 12px 14px;
    border-top: 1px solid var(--color-border);
}

.variance-analysis__grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 12px;
    align-items: stretch;
}

.variance-analysis__grid--2col {
    grid-template-columns: 1fr 1fr;
}

.variance-analysis__grid--4col {
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 10px;
}

.variance-analysis__column {
    display: grid;
    grid-template-rows: auto 1fr auto auto;
    gap: 6px;
    min-width: 0;
}

.variance-analysis__column--empty {
    opacity: 0.6;
}

.variance-analysis__column-header {
    font-size: 11px;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding-bottom: 4px;
    border-bottom: 1px solid var(--color-border);
}

.variance-analysis__items {
    display: flex;
    flex-direction: column;
    gap: 3px;
    max-height: 120px;
    overflow-y: auto;
    font-size: 11px;
    align-self: start;
}

.variance-analysis__item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    padding: 2px 0;
}

.variance-analysis__item-name {
    color: var(--color-text);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.variance-analysis__item-amount {
    color: var(--color-text-muted);
    font-variant-numeric: tabular-nums;
    flex-shrink: 0;
}

.variance-analysis__item-role {
    color: var(--color-text-muted);
    font-size: 10px;
    font-style: italic;
}

.variance-analysis__item-hours {
    color: var(--color-text-muted);
    font-size: 11px;
    font-variant-numeric: tabular-nums;
    flex-shrink: 0;
}


.variance-analysis__empty {
    color: var(--color-text-muted);
    font-style: italic;
    padding: 4px 0;
}

.variance-analysis__total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    align-self: end;
    padding-top: 6px;
    border-top: 1px solid var(--color-border);
    font-size: 11px;
}

.variance-analysis__total span {
    color: var(--color-text-muted);
}

.variance-analysis__total strong {
    color: var(--color-text);
    font-variant-numeric: tabular-nums;
}

.variance-analysis__variance-row {
    min-height: 24px;
}

.variance-analysis__variance {
    display: inline-flex;
    align-items: center;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 500;
}

.variance-analysis__variance--over {
    background: rgba(34, 197, 94, 0.1);
    color: var(--color-success);
}

.variance-analysis__variance--under {
    background: rgba(59, 130, 246, 0.1);
    color: var(--color-primary);
}

.variance-analysis__variance--over-threshold {
    background: rgba(220, 38, 38, 0.15);
    color: var(--color-danger);
}

.variance-analysis__variance--under-threshold {
    background: rgba(220, 38, 38, 0.15);
    color: var(--color-danger);
}

/* Explanation Section */
.variance-analysis__explanation {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--color-border);
}

.variance-analysis__explanation--required .variance-analysis__explanation-label {
    color: var(--color-warning);
}

.variance-analysis__explanation-label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 500;
    color: var(--color-text-muted);
    margin-bottom: 6px;
}

.variance-analysis__explanation-label i {
    font-size: 12px;
}

.variance-analysis__required {
    color: var(--color-warning);
    font-weight: 400;
}

.variance-analysis__optional {
    font-weight: 400;
    opacity: 0.7;
}

.variance-analysis__textarea {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    font-size: 12px;
    font-family: inherit;
    background: var(--color-input-bg);
    color: var(--color-text);
    resize: vertical;
    min-height: 40px;
}

.variance-analysis__textarea:focus {
    outline: none;
    border-color: var(--color-primary);
}

.variance-analysis__explanation--required .variance-analysis__textarea {
    border-color: var(--color-warning);
}

.variance-analysis__explanation-text {
    font-size: 12px;
    color: var(--color-text);
    padding: 6px 0;
}

.variance-analysis__explanation-text em {
    color: var(--color-text-muted);
}

/* Responsive */
@media (max-width: 900px) {
    .variance-analysis__grid--4col {
        grid-template-columns: 1fr 1fr;
        gap: 12px;
    }
}

@media (max-width: 640px) {
    .variance-analysis__grid,
    .variance-analysis__grid--2col,
    .variance-analysis__grid--4col {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .variance-analysis__column {
        border-bottom: 1px solid var(--color-border);
        padding-bottom: 12px;
    }

    .variance-analysis__column:last-child {
        border-bottom: none;
        padding-bottom: 0;
    }
}

/* =============================================================================
   EASTER EGG - Falling Man Animation
   ============================================================================= */

.billing-easter-egg {
    position: fixed;
    right: calc((100vw - 900px) / 4 + 50px);
    top: -100px;
    z-index: 1000;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.billing-easter-egg--falling {
    opacity: 1;
    animation: fallingMan 2s cubic-bezier(0.55, 0, 1, 0.45) forwards;
}

.billing-easter-egg--fade {
    opacity: 0;
}

/* Stick figure man */
.billing-easter-egg__man {
    position: relative;
    width: 40px;
    height: 80px;
    animation: flailing 0.15s ease-in-out infinite;
}

.billing-easter-egg--splat .billing-easter-egg__man {
    animation: none;
    transform: scaleY(0.3) scaleX(1.5);
    transform-origin: bottom center;
}

.billing-easter-egg__head {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 16px;
    height: 16px;
    background: var(--color-text-muted);
    border-radius: 50%;
}

.billing-easter-egg__body {
    position: absolute;
    top: 16px;
    left: 50%;
    transform: translateX(-50%);
    width: 4px;
    height: 30px;
    background: var(--color-text-muted);
    border-radius: 2px;
}

.billing-easter-egg__arm {
    position: absolute;
    top: 20px;
    width: 20px;
    height: 4px;
    background: var(--color-text-muted);
    border-radius: 2px;
    transform-origin: center;
}

.billing-easter-egg__arm--left {
    left: -2px;
    animation: armFlailLeft 0.15s ease-in-out infinite;
}

.billing-easter-egg__arm--right {
    right: -2px;
    animation: armFlailRight 0.15s ease-in-out infinite;
}

.billing-easter-egg--splat .billing-easter-egg__arm--left,
.billing-easter-egg--splat .billing-easter-egg__arm--right {
    animation: none;
    top: 35px;
    transform: rotate(0deg);
}

.billing-easter-egg__leg {
    position: absolute;
    top: 44px;
    width: 4px;
    height: 24px;
    background: var(--color-text-muted);
    border-radius: 2px;
    transform-origin: top center;
}

.billing-easter-egg__leg--left {
    left: 12px;
    animation: legFlailLeft 0.15s ease-in-out infinite;
}

.billing-easter-egg__leg--right {
    right: 12px;
    animation: legFlailRight 0.15s ease-in-out infinite;
}

.billing-easter-egg--splat .billing-easter-egg__leg--left,
.billing-easter-egg--splat .billing-easter-egg__leg--right {
    animation: none;
    transform: rotate(0deg) scaleY(0.5);
    top: 40px;
}

/* Splat effect */
.billing-easter-egg__splat {
    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%) scale(0);
    width: 60px;
    height: 20px;
    background: var(--color-text-muted);
    border-radius: 50%;
    opacity: 0.4;
    transition: transform 0.2s ease-out, opacity 0.2s ease-out;
}

.billing-easter-egg--splat .billing-easter-egg__splat {
    transform: translateX(-50%) scale(1);
    opacity: 0.3;
}

/* Animations */
@keyframes fallingMan {
    0% {
        top: -100px;
    }
    100% {
        top: calc(100vh - 120px);
    }
}

@keyframes flailing {
    0%, 100% {
        transform: rotate(-5deg);
    }
    50% {
        transform: rotate(5deg);
    }
}

@keyframes armFlailLeft {
    0%, 100% {
        transform: rotate(-45deg);
    }
    50% {
        transform: rotate(-80deg);
    }
}

@keyframes armFlailRight {
    0%, 100% {
        transform: rotate(45deg);
    }
    50% {
        transform: rotate(80deg);
    }
}

@keyframes legFlailLeft {
    0%, 100% {
        transform: rotate(-20deg);
    }
    50% {
        transform: rotate(10deg);
    }
}

@keyframes legFlailRight {
    0%, 100% {
        transform: rotate(20deg);
    }
    50% {
        transform: rotate(-10deg);
    }
}

/* Hide on smaller screens where there's no margin space */
@media (max-width: 1100px) {
    .billing-easter-egg {
        display: none;
    }
}

/* ============================================================================
   BUDGET SUBMIT MODAL
   ============================================================================ */

.budget-submit-modal {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.budget-submit-modal__info {
    text-align: center;
}

.budget-submit-modal__info p {
    margin: 0;
    color: var(--color-text-secondary, #64748b);
    font-size: 13px;
}

.budget-submit-modal__task {
    display: flex;
    flex-direction: column;
    gap: 2px;
    margin-top: 8px;
    padding: 12px;
    background: var(--color-surface, #f8fafc);
    border-radius: var(--radius-md, 6px);
}

.budget-submit-modal__task strong {
    color: var(--color-text, #1f2937);
    font-size: 14px;
}

.budget-submit-modal__task small {
    color: var(--color-text-muted, #9ca3af);
    font-size: 12px;
}

.budget-submit-modal__field {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.budget-submit-modal__label {
    font-size: 12px;
    font-weight: 600;
    color: var(--color-text-secondary, #64748b);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.budget-submit-modal__reviewers {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.budget-submit-modal__reviewer {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-md, 6px);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.budget-submit-modal__reviewer:hover {
    background: var(--color-surface, #f8fafc);
    border-color: var(--color-primary, #3b82f6);
}

.budget-submit-modal__reviewer--selected {
    background: var(--color-primary-bg, #eff6ff);
    border-color: var(--color-primary, #3b82f6);
}

.budget-submit-modal__reviewer input {
    margin: 0;
}

.budget-submit-modal__reviewer-name {
    font-weight: 500;
    color: var(--color-text, #1f2937);
    flex: 1;
}

.budget-submit-modal__reviewer-email {
    color: var(--color-text-muted, #9ca3af);
    font-size: 12px;
}

.budget-submit-modal__single-reviewer {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--color-surface, #f8fafc);
    border-radius: var(--radius-md, 6px);
}

.budget-submit-modal__single-reviewer i {
    color: var(--color-primary, #3b82f6);
}

.budget-submit-modal__single-reviewer span {
    font-weight: 500;
    color: var(--color-text, #1f2937);
}

.budget-submit-modal__single-reviewer small {
    color: var(--color-text-muted, #9ca3af);
    font-size: 12px;
    margin-left: auto;
}

.budget-submit-modal__note {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 10px 12px;
    background: var(--color-primary-bg, #eff6ff);
    border-radius: var(--radius-md, 6px);
    font-size: 12px;
    color: var(--color-primary, #2563eb);
}

.budget-submit-modal__note i {
    margin-top: 2px;
}

/* ============================================================================
   BUDGET WORKFLOW MODALS (New)
   ============================================================================ */

.budget-workflow-modal {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.budget-workflow-modal__info {
    text-align: center;
}

.budget-workflow-modal__task {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 12px;
    background: var(--color-surface, #f8fafc);
    border-radius: var(--radius-md, 6px);
    text-align: center;
}

.budget-workflow-modal__task strong {
    color: var(--color-text, #1f2937);
    font-size: 14px;
}

.budget-workflow-modal__task small {
    color: var(--color-text-muted, #9ca3af);
    font-size: 12px;
}

.budget-workflow-modal__field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.budget-workflow-modal__label {
    font-size: 12px;
    font-weight: 600;
    color: var(--color-text-secondary, #64748b);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.budget-workflow-modal__required {
    color: var(--color-danger, #dc2626);
}

.budget-workflow-modal__select {
    padding: 10px 12px;
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-md, 6px);
    background: var(--color-card-bg, #ffffff);
    color: var(--color-text, #1f2937);
    font-size: 14px;
    cursor: pointer;
}

.budget-workflow-modal__select:focus {
    outline: none;
    border-color: var(--color-primary, #3b82f6);
    box-shadow: 0 0 0 2px var(--color-primary-bg, #eff6ff);
}

.budget-workflow-modal__textarea {
    padding: 10px 12px;
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: var(--radius-md, 6px);
    background: var(--color-card-bg, #ffffff);
    color: var(--color-text, #1f2937);
    font-size: 13px;
    font-family: inherit;
    resize: vertical;
    min-height: 60px;
}

.budget-workflow-modal__textarea:focus {
    outline: none;
    border-color: var(--color-primary, #3b82f6);
    box-shadow: 0 0 0 2px var(--color-primary-bg, #eff6ff);
}

.budget-workflow-modal__textarea::placeholder {
    color: var(--color-text-muted, #9ca3af);
}

.budget-workflow-modal__message {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px;
    border-radius: var(--radius-md, 6px);
    font-size: 13px;
}

.budget-workflow-modal__message i {
    font-size: 16px;
}

.budget-workflow-modal__message--success {
    background: var(--color-success-bg, #dcfce7);
    color: var(--color-success-text, #166534);
}

.budget-workflow-modal__message--danger {
    background: var(--color-danger-bg, #fee2e2);
    color: var(--color-danger-text, #991b1b);
}

.budget-workflow-modal__message--warning {
    background: var(--color-warning-bg, #fef3c7);
    color: var(--color-warning-text, #92400e);
}

.budget-workflow-modal__message--info {
    background: var(--color-info-bg, #e0f2fe);
    color: var(--color-info-text, #0369a1);
}

.budget-workflow-modal__note {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 10px 12px;
    background: var(--color-primary-bg, #eff6ff);
    border-radius: var(--radius-md, 6px);
    font-size: 12px;
    color: var(--color-primary, #2563eb);
}

.budget-workflow-modal__note i {
    margin-top: 2px;
}
