/* Tailwind CSS - Базовые стили (СВЕТЛАЯ ТЕМА) */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

/* Reset и базовые стили */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  line-height: 1.6;
  background: #F0F2F5 !important; /* Очень светло-серый для основного фона */
  color: #1A1A1A; /* Темный текст по умолчанию */
}

/* Утилиты для отступов */
.p-2 { padding: 0.5rem; }
.p-4 { padding: 1rem; }
.p-6 { padding: 1.5rem; }
.px-4 { padding-left: 1rem; padding-right: 1rem; }
.px-6 { padding-left: 1.5rem; padding-right: 1.5rem; }
.py-2 { padding-top: 0.5rem; padding-bottom: 0.5rem; }
.py-3 { padding-top: 0.75rem; padding-bottom: 0.75rem; }
.py-4 { padding-top: 1rem; padding-bottom: 1rem; }
.py-6 { padding-top: 1.5rem; padding-bottom: 1.5rem; }

/* Утилиты для отступов */
.m-4 { margin: 1rem; }
.mb-2 { margin-bottom: 0.5rem; }
.mb-4 { margin-bottom: 1rem; }
.mb-8 { margin-bottom: 2rem; }
.mt-2 { margin-top: 0.5rem; }
.mt-4 { margin-top: 1rem; }
.mt-8 { margin-top: 2rem; }
.mr-2 { margin-right: 0.5rem; }
.mx-4 { margin-left: 1rem; margin-right: 1rem; }
.mx-auto { margin-left: auto; margin-right: auto; }

/* Утилиты для размеров */
.w-full { width: 100%; }
.max-w-md { max-width: 28rem; }
.max-w-sm { max-width: 24rem; }
.min-h-screen { min-height: 100vh; }

/* Утилиты для фона */
.bg-white { background-color: #ffffff; } /* Уже белый */
.bg-gray-100 { background-color: #f3f4f6; } /* Уже светлый */
.bg-gray-200 { background-color: #e5e7eb; } /* Уже светлый */
.bg-gray-300 { background-color: #d1d5db; } /* Уже светлый */
.bg-gray-600 { background-color: #E8ECEF; } /* Светлый серый */
.bg-gray-700 { background-color: #C4CDD4; } /* Более темный светлый серый */
.bg-gray-800 { background-color: #FFFFFF; } /* Белый */
.bg-gray-900 { background-color: #F0F2F5; } /* Очень светло-серый */
.bg-blue-500 { background-color: #3b82f6; } /* Синий */
.bg-blue-600 { background-color: #2563eb; } /* Темнее синий */
.bg-blue-700 { background-color: #1d4ed8; } /* Еще темнее синий */
.bg-green-500 { background-color: #10b981; } /* Зеленый */
.bg-green-600 { background-color: #059669; } /* Темнее зеленый */
.bg-green-700 { background-color: #047857; } /* Еще темнее зеленый */
.bg-red-500 { background-color: #ef4444; } /* Красный */
.bg-black { background-color: #F0F2F5; } /* Очень светло-серый вместо черного */

/* Утилиты для текста */
.text-black { color: #1A1A1A; } /* Темный текст */
.text-white { color: #1A1A1A; } /* Темный текст вместо белого */
.text-gray-400 { color: #667788; } /* Темный светлый серый */
.text-gray-500 { color: #4B5563; } /* Более темный серый */
.text-gray-600 { color: #374151; } /* Еще темнее серый */
.text-gray-700 { color: #1F2937; } /* Почти черный */
.text-blue-500 { color: #3b82f6; } /* Синий */
.text-green-500 { color: #10b981; } /* Зеленый */
.text-yellow-400 { color: #fbbf24; } /* Желтый */
.text-2xl { font-size: 1.5rem; line-height: 2rem; }
.text-xl { font-size: 1.25rem; line-height: 1.75rem; }
.text-lg { font-size: 1.125rem; line-height: 1.75rem; }
.text-sm { font-size: 0.875rem; line-height: 1.25rem; }

/* Утилиты для шрифтов */
.font-medium { font-weight: 500; }
.font-semibold { font-weight: 600; }
.font-bold { font-weight: 700; }

/* Утилиты для границ */
.border { border-width: 1px; }
.border-b { border-bottom-width: 1px; }
.border-gray-200 { border-color: #e5e7eb; } /* Уже светлый */
.border-gray-300 { border-color: #d1d5db; } /* Уже светлый */
.border-gray-600 { border-color: #E0E0E0; } /* Светлый серый */
.border-gray-700 { border-color: #C4CDD4; } /* Более темный светлый серый */
.border-transparent { border-color: transparent; }

/* Утилиты для скругления */
.rounded { border-radius: 0.25rem; }
.rounded-lg { border-radius: 0.5rem; }
.rounded-xl { border-radius: 0.75rem; }
.rounded-full { border-radius: 9999px; }

/* Утилиты для теней */
.shadow-lg { box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.08), 0 4px 6px -2px rgba(0, 0, 0, 0.04); } /* Более светлая тень */
.shadow-xl { box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04); } /* Более светлая тень */
.shadow-sm { box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.03); } /* Более светлая тень */

/* Утилиты для позиционирования */
.fixed { position: fixed; }
.relative { position: relative; }
.absolute { position: absolute; }
.inset-0 { top: 0; right: 0; bottom: 0; left: 0; }
.top-4 { top: 1rem; }
.right-4 { right: 1rem; }

/* Утилиты для отображения */
.flex { display: flex; }
.hidden { display: none; }
.block { display: block; }
.inline-block { display: inline-block; }

/* Утилиты для flexbox */
.items-center { align-items: center; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.space-x-2 > * + * { margin-left: 0.5rem; }
.space-x-3 > * + * { margin-left: 0.75rem; }
.space-y-3 > * + * { margin-top: 0.75rem; }
.space-y-4 > * + * { margin-top: 1rem; }

/* Утилиты для z-index */
.z-50 { z-index: 50; }

/* Утилиты для прозрачности */
.bg-opacity-50 { background-color: rgba(0, 0, 0, 0.3); } /* Слегка светлее фон */

/* Утилиты для переходов */
.transition-all { transition-property: all; }
.transition-colors { transition-property: color, background-color, border-color, text-decoration-color, fill, stroke; }
.duration-200 { transition-duration: 200ms; }
.duration-300 { transition-duration: 300ms; }

/* Утилиты для трансформации */
.transform { transform: translateX(0) translateY(0) rotate(0) skewX(0) skewY(0) scaleX(1) scaleY(1); }
.hover\:scale-105:hover { transform: scale(1.05); }
.active\:scale-95:active { transform: scale(0.95); }

/* Утилиты для hover эффектов */
.hover\:bg-blue-700:hover { background-color: #2A79CC; } /* Темнее синий */
.hover\:bg-green-700:hover { background-color: #047857; }
.hover\:bg-gray-300:hover { background-color: #DDE3E7; } /* Темнее светлый серый */
.hover\:bg-gray-600:hover { background-color: #DDE3E7; } /* Темнее светлый серый */
.hover\:text-gray-700:hover { color: #1F2937; } /* Темнее серый */
.hover\:text-gray-200:hover { color: #1A1A1A; } /* Темный */
.hover\:shadow-xl:hover { box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.15), 0 10px 10px -5px rgba(0, 0, 0, 0.08); } /* Более светлая тень */

/* Утилиты для фокуса */
.focus\:ring-2:focus { box-shadow: 0 0 0 2px rgba(51, 144, 236, 0.4); } /* Синий ринг */
.focus\:ring-blue-500:focus { box-shadow: 0 0 0 2px rgba(51, 144, 236, 0.4); } /* Синий ринг */
.focus\:border-transparent:focus { border-color: transparent; }

/* Кастомные стили */
.telegram-button {
  background-color: #3390EC; /* Telegram Blue */
  color: white;
  font-weight: 500;
  padding: 0.75rem 1.5rem;
  border-radius: 0.5rem;
  transition: all 200ms;
  transform: translateX(0) translateY(0) rotate(0) skewX(0) skewY(0) scaleX(1) scaleY(1);
}

.telegram-button:hover {
  background-color: #2A79CC; /* Темнее Telegram Blue */
  transform: scale(1.05);
}

.telegram-button:active {
  transform: scale(0.95);
}

.package-card {
  background-color: #ffffff;
  border-radius: 0.75rem;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.08), 0 4px 6px -2px rgba(0, 0, 0, 0.04); /* Более светлая тень */
  transition: all 300ms;
  border: 1px solid #E0E0E0; /* Светлая граница */
}

.package-card:hover {
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04); /* Более светлая тень */
}

.price-tag {
  background: linear-gradient(to right, #10b981, #059669); /* Зеленый градиент */
  color: white;
  font-weight: 700;
  padding: 0.5rem 1rem;
  border-radius: 9999px;
}

/* Комментируем темную тему, так как это теперь светлая тема по умолчанию */
/*
.dark .bg-white { background-color: #1f2937; }
.dark .bg-gray-100 { background-color: #111827; }
.dark .bg-gray-200 { background-color: #374151; }
.dark .bg-gray-300 { background-color: #4b5563; }
.dark .bg-gray-600 { background-color: #6b7280; }
.dark .bg-gray-700 { background-color: #9ca3af; }
.dark .bg-gray-800 { background-color: #1f2937; }
.dark .bg-gray-900 { background-color: #111827; }
.dark .border-gray-200 { border-color: #374151; }
.dark .border-gray-300 { border-color: #4b5563; }
.dark .border-gray-600 { border-color: #6b7280; }
.dark .border-gray-700 { border-color: #9ca3af; }
.dark .text-black { color: #ffffff; }
.dark .text-gray-400 { color: #9ca3af; }
.dark .text-gray-500 { color: #6b7280; }
.dark .text-gray-600 { color: #4b5563; }
.dark .text-gray-700 { color: #374151; }

.dark .package-card {
  background-color: #1f2937;
  border-color: #374151;
}
*/

/* Анимации */
@keyframes pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: .5;
  }
}

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.star-icon.spinning {
    animation: spin 1s linear infinite; /* Вращение 1 секунда, линейно, бесконечно */
    /* Отменяем или изменяем свойства pulse во время вращения */
    animation-duration: 1s; /* Убедимся, что вращение быстрее, чем пульс */
    animation-timing-function: linear;
    animation-iteration-count: infinite;
    animation-name: spin !important; /* Убедимся, что эта анимация главнее */
}

/* Адаптивность */
@media (max-width: 640px) {
  .max-w-md {
    max-width: 100%;
  }
  
  .px-4 {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

/* Стили для input */
input[type="number"] {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid #C4CDD4; /* Светлая граница */
  border-radius: 0.5rem;
  background-color: #FFFFFF; /* Белый фон */
  color: #1A1A1A; /* Темный текст */
  transition: all 200ms;
}

input[type="number"]:focus {
  outline: none;
  box-shadow: 0 0 0 2px rgba(51, 144, 236, 0.4); /* Синий ринг */
  border-color: #3390EC; /* Синяя граница */
}

/* Комментируем темную тему для input */
/*
.dark input[type="number"] {
  background-color: #374151;
  border-color: #4b5563;
  color: #ffffff;
}
*/

/* Стили для модального окна */
.modal-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.4); /* Более светлый оверлей */
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 50;
}

.modal-content {
  background-color: #FFFFFF; /* Белый фон */
  border-radius: 0.5rem;
  padding: 1.5rem;
  margin: 1rem;
  max-width: 24rem;
  width: 100%;
  color: #1A1A1A; /* Темный текст */
}

/* Комментируем темную тему для модального окна */
/*
.dark .modal-content {
  background-color: #1f2937;
}
*/

body, main {
    background: #F0F2F5 !important; /* Очень светло-серый */
    color: #1A1A1A; /* Темный текст */
  }
  
  .product-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  @media (min-width: 600px) {
    .product-grid {
      grid-template-columns: 1fr 1fr;
    }
  }
  
  .product-card {
    background: #FFFFFF; /* Белый */
    border-radius: 0.75rem;
    box-shadow: 0 10px 15px -3px rgba(0,0,0,0.08), 0 4px 6px -2px rgba(0,0,0,0.04); /* Светлее тень */
    border: 1px solid #E0E0E0; /* Светлая граница */
    cursor: pointer;
    transition: box-shadow 0.2s, transform 0.2s, border-color 0.2s;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    position: relative;
    min-height: 120px;
  }
  .product-card:hover {
    box-shadow: 0 20px 25px -5px rgba(0,0,0,0.15), 0 10px 10px -5px rgba(0,0,0,0.08); /* Светлее тень */
    border-color: #3390EC; /* Синий */
    transform: translateY(-4px) scale(1.03);
  }
  .product-card:active {
    transform: scale(0.98);
  }
  .product-card .star-icon {
    color: #fbbf24; /* Желтый */
    font-size: 1.5rem;
    margin-right: 0.5rem;
    animation: pulse 3s cubic-bezier(0.4, 0, 0.6, 1) infinite;
  }
  .product-card .price-tag {
    background: linear-gradient(to right, #10b981, #059669); /* Зеленый градиент */
    color: white;
    font-weight: 700;
    padding: 0.5rem 1rem;
    border-radius: 9999px;
    font-size: 1rem;
    margin-left: auto;
  }
  .product-card .product-title {
    font-size: 1.125rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
    display: flex;
    align-items: center;
    color: #1A1A1A; /* Темный текст */
  }
  
  /* Кастомная карточка */
  .custom-card {
    background: #FFFFFF; /* Белый */
    border-radius: 0.75rem;
    box-shadow: 0 10px 15px -3px rgba(0,0,0,0.08), 0 4px 6px -2px rgba(0,0,0,0.04); /* Светлее тень */
    border: 1px solid #E0E0E0; /* Светлая граница */
    padding: 1.5rem;
    margin-top: 1rem;
    color: #1A1A1A; /* Темный текст */
  }
  
  input[type="number"] {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid #C4CDD4; /* Светлая граница */
    border-radius: 0.5rem;
    background: #FFFFFF; /* Белый */
    color: #1A1A1A; /* Темный текст */
    transition: all 200ms;
  }
  input[type="number"]:focus {
    outline: none;
    box-shadow: 0 0 0 2px rgba(51, 144, 236, 0.4); /* Синий ринг */
    border-color: #3390EC; /* Синяя граница */
  }
  
  /* Уведомления */
  .fixed-notification {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 1000;
    padding: 1rem 1.5rem;
    border-radius: 0.5rem;
    font-weight: 500;
    background: #4CAF50; /* Зеленый (как в первом файле) */
    color: #fff;
    box-shadow: 0