/* ============================================
   CMA OMBESSA - Dashboard Home Page Responsive
   Mobile-first approach for the overview page
   ============================================ */

/* ============================================
   MOBILE BASE STYLES (< 480px)
   ============================================ */

/* Page Header - Side by side buttons */
.page-header {
    gap: var(--space-3);
}

.page-header-left {
    width: 100%;
}

.page-title {
    font-size: var(--text-xl);
}

.page-subtitle {
    font-size: var(--text-xs);
    display: none; /* Hide on very small screens */
}

.page-header-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-2);
    width: 100%;
}

.page-header-actions .btn {
    width: 100%;
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-sm);
    justify-content: center;
}

/* Hide button text, show only icon on very small screens */
.page-header-actions .btn svg {
    flex-shrink: 0;
}

/* ----------------------------------------
   Stats Grid - 2x2 layout on mobile
   ---------------------------------------- */
.stats-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: var(--space-3);
}

.stat-card {
    padding: var(--space-3);
}

.stat-card-header {
    gap: var(--space-2);
}

.stat-card-label {
    font-size: var(--text-xs);
}

.stat-card-value {
    font-size: var(--text-lg);
}

.stat-card-icon {
    width: 36px;
    height: 36px;
}

.stat-card-icon svg {
    width: 18px;
    height: 18px;
}

.stat-card-trend {
    font-size: 10px;
    padding: 2px 6px;
}

/* ----------------------------------------
   Analytics + Reminders - Flip order
   ---------------------------------------- */
.dashboard-grid-2-1 {
    display: flex;
    flex-direction: column-reverse;
    gap: var(--space-4);
}

.dashboard-grid-2-1 > * {
    width: 100%;
}

/* Analytics Card compact */
.analytics-card {
    padding: var(--space-3);
}

.analytics-card-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-2);
    margin-bottom: var(--space-3);
}

.analytics-card-title {
    font-size: var(--text-base);
}

.chart-period-selector {
    width: 100%;
}

.period-btn {
    flex: 1;
    padding: var(--space-1) var(--space-2);
    font-size: var(--text-xs);
}

.chart-container {
    height: 200px;
}

/* Reminder Card compact */
.reminder-card {
    padding: var(--space-3);
}

.reminder-item {
    padding: var(--space-3);
}

.reminder-title {
    font-size: var(--text-sm);
}

.reminder-time {
    font-size: var(--text-xs);
}

.reminder-btn {
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-xs);
}

/* ----------------------------------------
   3-Column Grid - Stack on mobile
   ---------------------------------------- */
.dashboard-grid-3 {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.dashboard-grid-3 > * {
    width: 100%;
}

/* Team Card compact */
.team-card {
    padding: var(--space-3);
}

.team-member {
    padding: var(--space-2) 0;
}

.team-avatar {
    width: 36px;
    height: 36px;
    font-size: var(--text-xs);
}

.team-name {
    font-size: var(--text-sm);
}

.team-role {
    font-size: var(--text-xs);
}

.team-status {
    font-size: 10px;
    padding: 2px 8px;
}

/* Progress Card compact */
.progress-card {
    padding: var(--space-3);
}

.donut-chart-container {
    flex-direction: column;
    gap: var(--space-3);
}

.donut-chart-wrapper {
    width: 120px;
    height: 120px;
}

.donut-chart-value {
    font-size: var(--text-lg);
}

.donut-chart-label {
    font-size: var(--text-xs);
}

.donut-chart-legend {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-2);
}

.donut-legend-item {
    font-size: var(--text-xs);
}

/* Quick Actions Card compact */
.quick-actions-card {
    padding: var(--space-3);
}

.quick-action-btn {
    padding: var(--space-3);
    font-size: var(--text-sm);
    gap: var(--space-2);
}

.quick-action-icon {
    width: 32px;
    height: 32px;
}

.quick-action-icon svg {
    width: 16px;
    height: 16px;
}

/* ----------------------------------------
   Transactions Card compact
   ---------------------------------------- */
.transactions-card {
    padding: var(--space-3);
}

.transaction-item {
    padding: var(--space-3);
    gap: var(--space-2);
}

.transaction-icon {
    width: 36px;
    height: 36px;
}

.transaction-icon svg {
    width: 16px;
    height: 16px;
}

.transaction-type {
    font-size: var(--text-sm);
}

.transaction-time {
    font-size: var(--text-xs);
}

.transaction-amount {
    font-size: var(--text-sm);
    white-space: nowrap;
}

/* ----------------------------------------
   Card Headers compact
   ---------------------------------------- */
.card-header {
    margin-bottom: var(--space-3);
}

.card-title {
    font-size: var(--text-sm);
}

.card-action-btn {
    font-size: var(--text-xs);
    padding: var(--space-1) var(--space-2);
}

/* ============================================
   LARGER MOBILE (480px+)
   ============================================ */
@media (min-width: 480px) {
    .page-title {
        font-size: var(--text-2xl);
    }

    .page-subtitle {
        display: block;
    }

    .page-header-actions .btn {
        padding: var(--space-2) var(--space-4);
    }

    /* Stats cards slightly larger */
    .stat-card {
        padding: var(--space-4);
    }

    .stat-card-value {
        font-size: var(--text-xl);
    }

    .stat-card-icon {
        width: 40px;
        height: 40px;
    }

    /* Chart taller */
    .chart-container {
        height: 220px;
    }

    /* Donut chart larger */
    .donut-chart-wrapper {
        width: 140px;
        height: 140px;
    }

    .donut-chart-value {
        font-size: var(--text-xl);
    }
}

/* ============================================
   TABLET (768px+)
   ============================================ */
@media (min-width: 768px) {
    .page-header {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }

    .page-header-left {
        width: auto;
    }

    .page-header-actions {
        width: auto;
        grid-template-columns: auto auto;
    }

    .page-header-actions .btn {
        width: auto;
    }

    /* Stats grid - keep 2x2 on tablet */
    .stats-grid {
        gap: var(--space-4);
    }

    .stat-card {
        padding: var(--space-5);
    }

    .stat-card-value {
        font-size: var(--text-2xl);
    }

    .stat-card-icon {
        width: 44px;
        height: 44px;
    }

    /* Analytics + Reminders - restore row layout */
    .dashboard-grid-2-1 {
        display: grid;
        grid-template-columns: 2fr 1fr;
        flex-direction: unset;
    }

    .analytics-card {
        padding: var(--space-5);
    }

    .analytics-card-header {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }

    .chart-period-selector {
        width: auto;
    }

    .chart-container {
        height: 280px;
    }

    .reminder-card {
        padding: var(--space-5);
    }

    /* 3-column grid - 2+1 layout on tablet */
    .dashboard-grid-3 {
        display: grid;
        grid-template-columns: 1fr 1fr;
        flex-direction: unset;
    }

    .dashboard-grid-3 > *:last-child {
        grid-column: span 2;
    }

    .team-card,
    .progress-card,
    .quick-actions-card {
        padding: var(--space-5);
    }

    /* Donut chart */
    .donut-chart-wrapper {
        width: 160px;
        height: 160px;
    }

    /* Transactions */
    .transactions-card {
        padding: var(--space-5);
    }
}

/* ============================================
   DESKTOP (1024px+)
   ============================================ */
@media (min-width: 1024px) {
    /* Stats grid - 4 columns */
    .stats-grid {
        grid-template-columns: repeat(4, 1fr) !important;
    }

    .stat-card-value {
        font-size: var(--text-3xl);
    }

    /* 3-column grid - restore 3 columns */
    .dashboard-grid-3 {
        grid-template-columns: repeat(3, 1fr);
    }

    .dashboard-grid-3 > *:last-child {
        grid-column: span 1;
    }

    .chart-container {
        height: 300px;
    }

    .donut-chart-wrapper {
        width: 180px;
        height: 180px;
    }
}

/* ============================================
   LARGE DESKTOP (1200px+)
   ============================================ */
@media (min-width: 1200px) {
    .stat-card {
        padding: var(--space-6);
    }

    .analytics-card,
    .reminder-card,
    .team-card,
    .progress-card,
    .quick-actions-card,
    .transactions-card {
        padding: var(--space-6);
    }
}

/* ============================================
   LANDSCAPE MOBILE ADJUSTMENTS
   ============================================ */
@media (max-width: 767px) and (orientation: landscape) {
    .stats-grid {
        grid-template-columns: repeat(4, 1fr) !important;
        gap: var(--space-2);
    }

    .stat-card {
        padding: var(--space-2);
    }

    .stat-card-value {
        font-size: var(--text-base);
    }

    .stat-card-icon {
        width: 32px;
        height: 32px;
    }

    .chart-container {
        height: 180px;
    }

    .donut-chart-wrapper {
        width: 100px;
        height: 100px;
    }
}

/* ============================================
   ACCESSIBILITY & REDUCED MOTION
   ============================================ */
@media (prefers-reduced-motion: reduce) {
    .stat-card,
    .analytics-card,
    .reminder-card,
    .team-card,
    .progress-card,
    .quick-actions-card,
    .transactions-card {
        transition: none;
    }
}

/* ============================================
   TOUCH DEVICE OPTIMIZATIONS
   ============================================ */
@media (hover: none) and (pointer: coarse) {
    /* Ensure touch-friendly sizes */
    .quick-action-btn {
        min-height: 48px;
    }

    .card-action-btn {
        min-height: 36px;
        min-width: 60px;
    }

    .period-btn {
        min-height: 36px;
    }

    .reminder-btn {
        min-height: 40px;
    }

    /* Remove hover transforms on touch */
    .stat-card:hover,
    .quick-action-btn:hover {
        transform: none;
    }
}
