/* Tablets: 768px and below */
@media (max-width: 768px) {
  .app-header {
    padding: var(--spacing-lg) var(--spacing-lg);
  }
  
  .header-logo {
    width: 100%;
    margin-bottom: var(--spacing-md);
  }
  
  .header-nav {
    justify-content: flex-start;
  }
  
  .app-body {
    grid-template-columns: 1fr;
  }
  
  .form-row.two-col {
    grid-template-columns: 1fr;
  }
  
  .metrics-grid {
    grid-template-columns: 1fr;
  }
}

/* Mobile: 640px and below */
@media (max-width: 640px) {
  :root {
    --spacing-2xl: 16px;
    --spacing-3xl: 20px;
  }
  
  .app-container {
    padding: var(--spacing-lg) var(--spacing-md);
  }
  
  h1 {
    font-size: var(--font-size-2xl);
  }
  
  h2 {
    font-size: var(--font-size-xl);
  }
  
  .app-header {
    flex-direction: column;
    align-items: flex-start;
  }
  
  .logo-text h1 {
    font-size: 1.3rem;
  }
  
  .header-nav {
    flex-wrap: wrap;
  }
  
  .nav-item {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-xs);
  }
  
  .panel {
    padding: var(--spacing-lg);
  }
  
  .form-row {
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
  }
  
  .toggle-group {
    flex-direction: column;
  }
  
  .toggle-btn {
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-xs);
  }
  
  .toggle-btn:first-child {
    border-radius: var(--radius-md);
  }
  
  .toggle-btn:last-child {
    border-radius: var(--radius-md);
  }
  
  .btn {
    padding: var(--spacing-md) var(--spacing-lg);
    font-size: var(--font-size-base);
  }
  
  .chart-card {
    padding: var(--spacing-lg);
  }
  
  .chart-header {
    flex-direction: column;
    gap: var(--spacing-sm);
  }
  
  .chart-badge {
    align-self: flex-start;
  }
  
  .chart-tabs {
    flex-wrap: wrap;
  }
  
  .chart-legend {
    flex-direction: column;
    gap: var(--spacing-md);
  }
  
  .metrics-grid {
    grid-template-columns: 1fr;
    gap: var(--spacing-sm);
  }
  
  .metric-card {
    padding: var(--spacing-md);
  }
  
  .metric-value {
    font-size: 1.5rem;
  }
  
  .donut-wrapper {
    flex-direction: column;
    gap: var(--spacing-lg);
  }
  
  .donut-container {
    width: 120px;
    height: 120px;
  }
  
  .info-row {
    flex-direction: column;
    gap: var(--spacing-xs);
  }
  
  .subsidy-band {
    height: 10px;
  }
}

/* Very small devices: 480px and below */
@media (max-width: 480px) {
  .app-container {
    padding: var(--spacing-md);
  }
  
  .panel {
    padding: var(--spacing-md);
    border-radius: var(--radius-lg);
  }
  
  .panel-title {
    font-size: 0.65rem;
  }
  
  .form-label {
    font-size: 0.7rem;
  }
  
  .form-input,
  .form-select {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
  }
  
  .chart-container {
    max-height: 200px;
  }
  
  .chart-title {
    font-size: var(--font-size-base);
  }
  
  .chart-subtitle {
    font-size: var(--font-size-xs);
  }
  
  .metric-value {
    font-size: 1.3rem;
  }
  
  .legend-item {
    font-size: var(--font-size-xs);
  }
}

/* Print styles */
@media print {
  .app-header,
  .option-group,
  .btn {
    display: none;
  }
  
  .panel,
  .chart-card,
  .metric-card {
    box-shadow: none;
    border: 1px solid #ccc;
  }
  
  body {
    background: white;
  }
}
