/* ═══════════════════════════════════════════════════════════════
   CLOSE THE MONTH — Full-screen guided review wizard
   ═══════════════════════════════════════════════════════════════ */

.close-month-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9000;
    background: var(--bg-primary);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.close-month-overlay.show {
    display: block;
}

.close-month-wizard {
    max-width: 720px;
    margin: 0 auto;
    padding: var(--space-md) var(--space-lg);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.close-month-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-sm) 0 var(--space-md);
}

.close-month-progress {
    display: flex;
    align-items: center;
    gap: 0;
    flex: 1;
    max-width: 280px;
}

.close-month-step-dot {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--text-caption);
    font-weight: var(--font-bold);
    background: var(--bg-secondary);
    color: var(--text-tertiary);
    transition: all 0.3s ease;
    flex-shrink: 0;
}

.close-month-step-dot.active {
    background: var(--primary);
    color: white;
}

.close-month-step-dot.current {
    box-shadow: 0 0 0 3px rgba(0, 113, 227, 0.25);
}

.close-month-step-line {
    flex: 1;
    height: 2px;
    background: var(--bg-secondary);
    min-width: 16px;
}

/* Steps */
.close-month-step {
    display: none;
    flex: 1;
}

.close-month-step.active {
    display: flex;
    flex-direction: column;
}

.close-month-step-header {
    text-align: center;
    margin-bottom: var(--space-lg);
}

.close-month-title {
    font-size: var(--text-title);
    font-weight: var(--font-bold);
    margin: 0 0 var(--space-xs);
}

.close-month-subtitle {
    font-size: var(--text-body);
    color: var(--text-secondary);
    margin: 0;
}

.close-month-content {
    flex: 1;
    overflow-y: auto;
}

/* Navigation */
.close-month-nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-md) 0;
    border-top: 1px solid var(--border-light);
    margin-top: var(--space-md);
    gap: var(--space-sm);
}

.close-month-step-label {
    font-size: var(--text-caption);
    color: var(--text-tertiary);
}

/* Step 2: Variance */
.close-month-adherence {
    text-align: center;
    margin: var(--space-md) 0;
}

.close-month-adherence-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    padding: var(--space-sm) var(--space-lg);
    border-radius: var(--radius-full, 999px);
    font-size: var(--text-heading);
    font-weight: var(--font-bold);
}

.close-month-adherence-badge.excellent {
    background: rgba(52, 199, 89, 0.12);
    color: var(--success);
}
.close-month-adherence-badge.good {
    background: rgba(52, 199, 89, 0.08);
    color: #2da44e;
}
.close-month-adherence-badge.fair {
    background: rgba(255, 149, 0, 0.10);
    color: var(--warning);
}
.close-month-adherence-badge.poor {
    background: rgba(255, 59, 48, 0.10);
    color: var(--danger);
}

.close-month-adherence-icon {
    font-size: 1.5em;
}

.close-month-adherence-label {
    font-size: var(--text-body);
    font-weight: var(--font-medium);
    opacity: 0.7;
}

.close-month-cat-row {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-xs) var(--space-sm);
    border-radius: var(--radius-md);
    margin-bottom: 2px;
}

.close-month-cat-row.over {
    background: rgba(255, 59, 48, 0.06);
}
.close-month-cat-row.under {
    background: rgba(52, 199, 89, 0.06);
}

.close-month-cat-icon {
    font-size: 1.2em;
}

.close-month-cat-name {
    flex: 1;
    font-size: var(--text-body);
}

.close-month-cat-var {
    font-weight: var(--font-semibold);
    font-size: var(--text-body);
}

.close-month-cat-row.over .close-month-cat-var { color: var(--danger); }
.close-month-cat-row.under .close-month-cat-var { color: var(--success); }
.close-month-cat-row.on-budget .close-month-cat-var { color: var(--text-secondary); }

.close-month-trend-section {
    margin-top: var(--space-lg);
}

/* Step 3: Reflect */
.close-month-reflect-prompts {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.close-month-prompt label {
    display: block;
    font-weight: var(--font-semibold);
    font-size: var(--text-body);
    margin-bottom: var(--space-xs);
    color: var(--text-primary);
}

.close-month-textarea {
    width: 100%;
    padding: var(--space-sm) var(--space-md);
    border: 1px solid var(--border-medium);
    border-radius: var(--radius-md);
    font-family: inherit;
    font-size: var(--text-body);
    background: var(--bg-primary);
    color: var(--text-primary);
    resize: vertical;
    box-sizing: border-box;
    transition: border-color var(--duration) ease;
}

.close-month-textarea:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(0, 113, 227, 0.15);
}

/* Step 4: Intentions */
.close-month-intention-prompt {
    margin-bottom: var(--space-lg);
}

.close-month-intention-prompt label {
    display: block;
    font-weight: var(--font-semibold);
    font-size: var(--text-body);
    margin-bottom: var(--space-xs);
}

/* Celebration */
.close-month-celebration {
    text-align: center;
    padding: var(--space-xl) 0;
}

.close-month-celebration-icon {
    font-size: 4rem;
    margin-bottom: var(--space-sm);
}

.close-month-celebration-text {
    font-size: var(--text-title);
    font-weight: var(--font-bold);
    color: var(--success);
}

.celebrate-animate .close-month-celebration-icon {
    animation: celebrateBounce 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

@keyframes celebrateBounce {
    0% { transform: scale(0); }
    50% { transform: scale(1.3); }
    100% { transform: scale(1); }
}

/* Confetti */
.close-month-confetti {
    position: fixed;
    top: -10px;
    border-radius: 2px;
    animation: confettiFall linear forwards;
    pointer-events: none;
    z-index: 9999;
}

@keyframes confettiFall {
    0% { transform: translateY(0) rotate(0deg); opacity: 1; }
    100% { transform: translateY(100vh) rotate(720deg); opacity: 0; }
}


/* ── Dashboard Adherence Prompt ──
   Width matches .health-check-container (same max-width + padding).
   ────────────────────────────────────────────────────────────── */

.dashboard-adherence-container {
    max-width: var(--container-max);
    margin: 0 auto var(--space-md);
    padding: 0 var(--container-padding);
    box-sizing: border-box;
}

.dashboard-adherence-prompt,
.dashboard-adherence-reviewed {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
    padding: var(--space-md) var(--space-lg);
    border-radius: var(--radius-lg);
    font-size: var(--text-body);
    animation: slideDown 0.3s ease;
}

.dashboard-adherence-prompt-content,
.dashboard-adherence-reviewed-content {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    flex: 1;
    min-width: 0;
}

.dashboard-adherence-icon {
    flex-shrink: 0;
}

.dashboard-adherence-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.dashboard-adherence-title {
    font-weight: var(--font-semibold);
    color: var(--text-primary);
}

.dashboard-adherence-detail {
    font-size: var(--text-caption);
    color: var(--text-secondary);
}

/* ── Needs-review state (glass card) ── */
.dashboard-adherence-prompt {
    background: var(--glass-bg);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--glass-border);
    box-shadow: var(--glass-shadow);
}

/* ── Reviewed state (success) ── */
.dashboard-adherence-reviewed {
    background: rgba(52, 199, 89, 0.08);
    border: 1px solid rgba(52, 199, 89, 0.15);
}

[data-theme="dark"] .dashboard-adherence-reviewed {
    background: rgba(52, 199, 89, 0.12);
    border-color: rgba(52, 199, 89, 0.2);
}

.dashboard-adherence-reviewed .dashboard-adherence-title {
    color: var(--success);
}

.dashboard-adherence-score {
    font-size: var(--text-caption);
    color: var(--success);
    font-weight: var(--font-medium);
}

/* ── Dismiss button (X) ── */
.dashboard-adherence-dismiss {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: transparent;
    border-radius: var(--radius-full);
    color: var(--text-tertiary, var(--text-secondary));
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease;
}

.dashboard-adherence-dismiss:hover {
    background: rgba(0, 0, 0, 0.06);
    color: var(--text-primary);
}

[data-theme="dark"] .dashboard-adherence-dismiss:hover {
    background: rgba(255, 255, 255, 0.1);
}

.dashboard-adherence-prompt .btn {
    flex-shrink: 0;
    white-space: nowrap;
}

/* ── Responsive: mobile ── */
@media (max-width: 480px) {
    .dashboard-adherence-prompt,
    .dashboard-adherence-reviewed {
        padding: var(--space-sm) var(--space-md);
        gap: var(--space-sm);
    }

    .dashboard-adherence-prompt {
        flex-direction: column;
        align-items: stretch;
    }

    .dashboard-adherence-prompt .btn {
        align-self: flex-end;
    }

    .dashboard-adherence-detail {
        display: none;
    }
}


@media (prefers-reduced-motion: reduce) {
    .close-month-confetti,
    .celebrate-animate .close-month-celebration-icon {
        animation: none !important;
    }
}


