/* ==========================================
   8-Point Grid System
   Spacing, touch targets, and layout
   ========================================== */

:root {
  /* ===== 8-POINT GRID SCALE ===== */
  --spacing-0: 0;
  --spacing-1: 0.25rem;   /* 4px */
  --spacing-2: 0.5rem;    /* 8px */
  --spacing-3: 0.75rem;   /* 12px */
  --spacing-4: 1rem;      /* 16px - minimum for mobile */
  --spacing-5: 1.25rem;   /* 20px */
  --spacing-6: 1.5rem;    /* 24px */
  --spacing-8: 2rem;      /* 32px */
  --spacing-10: 2.5rem;   /* 40px */
  --spacing-12: 3rem;     /* 48px */
  --spacing-16: 4rem;     /* 64px */
  --spacing-20: 5rem;     /* 80px */
  --spacing-24: 6rem;     /* 96px */

  /* ===== TOUCH TARGET ===== */
  --touch-target-minimum: 44px;  /* iOS HIG */
  --touch-target-comfortable: 48px;
  --touch-target-large: 56px;

  /* ===== BORDER RADIUS ===== */
  --radius-none: 0;
  --radius-sm: 0.25rem;   /* 4px */
  --radius-base: 0.375rem; /* 6px */
  --radius-md: 0.5rem;    /* 8px */
  --radius-lg: 0.75rem;   /* 12px */
  --radius-xl: 1rem;      /* 16px */
  --radius-2xl: 1.5rem;   /* 24px */
  --radius-full: 9999px;  /* fully rounded */

  /* ===== SHADOWS ===== */
  --shadow-none: none;
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-base: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);

  /* ===== TRANSITIONS ===== */
  --transition-fast: 150ms ease;
  --transition-base: 200ms ease;
  --transition-slow: 300ms ease;
}

/* ===== MARGIN UTILITIES ===== */
/* Use these instead of m-1, m-2 which are too small on mobile */
.m-0 { margin: var(--spacing-0); }
.m-2 { margin: var(--spacing-2); }
.m-3 { margin: var(--spacing-3); }
.m-4 { margin: var(--spacing-4); }
.m-6 { margin: var(--spacing-6); }
.m-8 { margin: var(--spacing-8); }
.m-12 { margin: var(--spacing-12); }

.mx-auto { margin-left: auto; margin-right: auto; }
.my-auto { margin-top: auto; margin-bottom: auto; }

.mx-0 { margin-left: var(--spacing-0); margin-right: var(--spacing-0); }
.mx-2 { margin-left: var(--spacing-2); margin-right: var(--spacing-2); }
.mx-3 { margin-left: var(--spacing-3); margin-right: var(--spacing-3); }
.mx-4 { margin-left: var(--spacing-4); margin-right: var(--spacing-4); }
.mx-6 { margin-left: var(--spacing-6); margin-right: var(--spacing-6); }

.my-0 { margin-top: var(--spacing-0); margin-bottom: var(--spacing-0); }
.my-2 { margin-top: var(--spacing-2); margin-bottom: var(--spacing-2); }
.my-3 { margin-top: var(--spacing-3); margin-bottom: var(--spacing-3); }
.my-4 { margin-top: var(--spacing-4); margin-bottom: var(--spacing-4); }
.my-6 { margin-top: var(--spacing-6); margin-bottom: var(--spacing-6); }

.mt-0 { margin-top: var(--spacing-0); }
.mt-2 { margin-top: var(--spacing-2); }
.mt-3 { margin-top: var(--spacing-3); }
.mt-4 { margin-top: var(--spacing-4); }
.mt-6 { margin-top: var(--spacing-6); }
.mt-8 { margin-top: var(--spacing-8); }

.mb-0 { margin-bottom: var(--spacing-0); }
.mb-2 { margin-bottom: var(--spacing-2); }
.mb-3 { margin-bottom: var(--spacing-3); }
.mb-4 { margin-bottom: var(--spacing-4); }
.mb-6 { margin-bottom: var(--spacing-6); }
.mb-8 { margin-bottom: var(--spacing-8); }

/* ===== PADDING UTILITIES ===== */
/* CRITICAL: Minimum p-4 (16px) on mobile for touch targets */
.p-0 { padding: var(--spacing-0); }
.p-2 { padding: var(--spacing-2); }
.p-3 { padding: var(--spacing-3); }
.p-4 { padding: var(--spacing-4); }
.p-6 { padding: var(--spacing-6); }
.p-8 { padding: var(--spacing-8); }
.p-12 { padding: var(--spacing-12); }

.px-0 { padding-left: var(--spacing-0); padding-right: var(--spacing-0); }
.px-2 { padding-left: var(--spacing-2); padding-right: var(--spacing-2); }
.px-3 { padding-left: var(--spacing-3); padding-right: var(--spacing-3); }
.px-4 { padding-left: var(--spacing-4); padding-right: var(--spacing-4); }
.px-6 { padding-left: var(--spacing-6); padding-right: var(--spacing-6); }

.py-0 { padding-top: var(--spacing-0); padding-bottom: var(--spacing-0); }
.py-2 { padding-top: var(--spacing-2); padding-bottom: var(--spacing-2); }
.py-3 { padding-top: var(--spacing-3); padding-bottom: var(--spacing-3); }
.py-4 { padding-top: var(--spacing-4); padding-bottom: var(--spacing-4); }
.py-6 { padding-top: var(--spacing-6); padding-bottom: var(--spacing-6); }

.pt-0 { padding-top: var(--spacing-0); }
.pt-2 { padding-top: var(--spacing-2); }
.pt-4 { padding-top: var(--spacing-4); }
.pt-6 { padding-top: var(--spacing-6); }

.pb-0 { padding-bottom: var(--spacing-0); }
.pb-2 { padding-bottom: var(--spacing-2); }
.pb-4 { padding-bottom: var(--spacing-4); }
.pb-6 { padding-bottom: var(--spacing-6); }

/* ===== BORDER RADIUS UTILITIES ===== */
.rounded-none { border-radius: var(--radius-none); }
.rounded-sm { border-radius: var(--radius-sm); }
.rounded { border-radius: var(--radius-base); }
.rounded-md { border-radius: var(--radius-md); }
.rounded-lg { border-radius: var(--radius-lg); }
.rounded-xl { border-radius: var(--radius-xl); }
.rounded-2xl { border-radius: var(--radius-2xl); }
.rounded-full { border-radius: var(--radius-full); }

/* ===== SHADOW UTILITIES ===== */
.shadow-none { box-shadow: var(--shadow-none); }
.shadow-sm { box-shadow: var(--shadow-sm); }
.shadow { box-shadow: var(--shadow-base); }
.shadow-md { box-shadow: var(--shadow-md); }
.shadow-lg { box-shadow: var(--shadow-lg); }
.shadow-xl { box-shadow: var(--shadow-xl); }
.shadow-2xl { box-shadow: var(--shadow-2xl); }

/* ===== TOUCH TARGET SIZES ===== */
/* Minimum 44x44px buttons/links on mobile */
.touch-target {
  min-width: var(--touch-target-minimum);
  min-height: var(--touch-target-minimum);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.touch-target-comfortable {
  min-width: var(--touch-target-comfortable);
  min-height: var(--touch-target-comfortable);
}

.touch-target-large {
  min-width: var(--touch-target-large);
  min-height: var(--touch-target-large);
}

/* ===== TRANSITION UTILITIES ===== */
.transition-fast {
  transition: all var(--transition-fast);
}

.transition {
  transition: all var(--transition-base);
}

.transition-slow {
  transition: all var(--transition-slow);
}

/* ===== RESPONSIVE PADDING ON MOBILE ===== */
/* Reduce padding on very small screens, increase on larger */
@media (max-width: 360px) {
  /* Extra small devices get slightly less padding */
  .p-4 { padding: 0.875rem; }
  .px-4 { padding-left: 0.875rem; padding-right: 0.875rem; }
  .py-4 { padding-top: 0.875rem; padding-bottom: 0.875rem; }
}

/* ===== TABLET (≥768px) ===== */
@media (min-width: 768px) {
  /* Increase spacing on tablet */
  .md\:p-6 { padding: var(--spacing-6); }
  .md\:px-8 { padding-left: var(--spacing-8); padding-right: var(--spacing-8); }
  .md\:m-8 { margin: var(--spacing-8); }
}

/* ===== DESKTOP (≥1024px) ===== */
@media (min-width: 1024px) {
  /* Increase spacing on desktop */
  .lg\:p-8 { padding: var(--spacing-8); }
  .lg\:px-12 { padding-left: var(--spacing-12); padding-right: var(--spacing-12); }
}

/* ===== SAFE AREA INSETS ===== */
/* For notched devices (iPhone X and later) */
.safe-area-inset-top {
  padding-top: max(1rem, env(safe-area-inset-top));
}

.safe-area-inset-bottom {
  padding-bottom: max(1rem, env(safe-area-inset-bottom));
}

.safe-area-inset-left {
  padding-left: max(1rem, env(safe-area-inset-left));
}

.safe-area-inset-right {
  padding-right: max(1rem, env(safe-area-inset-right));
}
