@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Playfair+Display:wght@400;700&display=swap');

:root {
  /* Warm coffee palette */
  --cream: #faf6f1;
  --coffee: #5d4037;
  --dark-roast: #3e2723;
  --latte: #d7ccc8;
  --mocha: #8d6e63;
  --white: #ffffff;

  /* Functional color variables */
  --bg-primary: var(--cream);
  --bg-card: var(--white);
  --text-primary: var(--dark-roast);
  --text-secondary: var(--mocha);
  --text-price: var(--coffee);
  --border-color: var(--latte);

  /* Button colors */
  --btn-primary-bg: var(--coffee);
  --btn-primary-text: var(--white);
  --btn-secondary-bg: var(--latte);
  --btn-secondary-text: var(--dark-roast);

  /* State colors */
  --success: #4caf50;
  --error: #e53935;
  --warning: #ff9800;

  /* Radius variables */
  --radius-card: 20px;
  --radius-button: 16px;
  --radius-input: 12px;
  --radius-badge: 20px;

  /* Shadow variables */
  --shadow-sm: 0 4px 16px rgba(93, 64, 55, 0.08);
  --shadow-md: 0 8px 24px rgba(93, 64, 55, 0.12);
  --shadow-lg: 0 12px 32px rgba(93, 64, 55, 0.16);

  /* Typography variables */
  --font-heading: 'Playfair Display', serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

  /* Spacing */
  --container-max: 400px;
  --section-gap: 16px;
  --card-padding: 20px;
}

/* Base styles */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body {
  background-color: var(--tg-theme-bg-color, var(--bg-primary));
  color: var(--tg-theme-text-color, var(--text-primary));
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-height: 100vh;
}

/* Headings */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.2;
}

/* Reduced motion for accessibility */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
