﻿/* ==================== CSS 2024 ==================== */
/* Современные переменные и флагшипы CSS */
@import url('header.css');
@import url('footer.css');
@import url('home.css');
@import url('catalog.css');
@import url('product.css');
@import url('search.css');
@import url('order.css');
@import url('contacts.css');
@import url('about-company.css');
@import url('info.css');
@import url('prices.css');
@import url('delivery.css');
@import url('blog.css');
@import url('blog-article.css');
@import url('components.css');

:root {
  /* === ТИПОГРАФИКА === */
  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 1.875rem;
  --text-4xl: 2.25rem;

  /* === ОТСТУПЫ === */
  --space-3xs: 0.25rem;
  --space-2xs: 0.5rem;
  --space-xs: 0.75rem;
  --space-sm: 1rem;
  --space-md: 1.5rem;
  --space-lg: 2rem;
  --space-xl: 3rem;
  --space-2xl: 4rem;

  /* === КОНТЕЙНЕРЫ === */
  --container-xs: min(100% - var(--space-sm), 20rem);
  --container-sm: min(100% - var(--space-md), 40rem);
  --container-md: min(100% - var(--space-lg), 48rem);
  --container-lg: min(100% - var(--space-xl), 64rem);
  --container-xl: min(100% - var(--space-xl), 80rem);
  --container-2xl: min(100% - var(--space-2xl), 90rem);
  --container-fluid: min(100% - var(--space-md), 100rem);

  /* === ЦВЕТА === */
  --color-primary: oklch(65.651% 0.0649 127.504);
  --color-primary-dark: oklch(54.884% 0.01264 89.793);
  --color-secondary: oklch(70% 0.15 75);
  --color-surface: oklch(98.9% 0.00163 148.716);
  --color-surface-dark: oklch(15% 0.02 145);
  --color-text: oklch(20% 0.02 145);
  --color-text-muted: oklch(40% 0.02 145);
  --color-text-light: oklch(60% 0.02 145);
  --color-background: oklch(98% 0.001 145);
  --color-border: oklch(90% 0.01 145);
  --color-error: oklch(50% 0.2 25);
  --color-success: oklch(55% 0.15 145);
  --color-warning: oklch(70% 0.15 75);
  --color-gray-200: oklch(92% 0.01 145);
  --color-gray-300: oklch(85% 0.01 145);
  --color-gray-500: oklch(60% 0.01 145);
  --color-gray-600: oklch(40% 0.02 145);
  --color-gray-700: oklch(30% 0.02 145);
  --color-gray-800: oklch(25% 0.02 145);
  --color-gray-900: oklch(15% 0.02 145);

  /* === ЭФФЕКТЫ === */
  --shadow-sm: 0 2px 8px oklch(0% 0 0 / 0.05);
  --shadow-md: 0 4px 16px oklch(0% 0 0 / 0.08);
  --shadow-lg: 0 8px 32px oklch(0% 0 0 / 0.12);

  /* === АНИМАЦИИ === */
  --transition-fast: 150ms ease;
  --transition-base: 300ms ease;
  --transition-slow: 500ms ease;

  /* === УТИЛИТЫ === */
  --icon-size-lg: 2rem;
  --tap-target-min: 44px;
}

/* ==================== СБРОС 2024 ==================== */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: var(--space-lg);
}

/* ==================== ОСНОВНЫЕ СТИЛИ ==================== */
body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-size: var(--text-base);
  line-height: 1.7;
  color: var(--color-text);
  background-color: var(--color-surface);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* ==================== КОНТЕЙНЕРЫ 2024 ==================== */
.container {
  width: var(--container-fluid);
  margin-inline: auto;
  padding-inline: var(--space-2xs);
}

.container-narrow {
  width: var(--container-xl);
  margin-inline: auto;
  padding-inline: var(--space-2xs);
}

.container-wide {
  width: 100%;
  max-width: 100rem;
  margin-inline: auto;
  padding-inline: var(--space-2xs);
}

/* ==================== ТИПОГРАФИКА 2024 ==================== */
h1 {
  font-size: var(--text-4xl);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--color-primary);
  margin-block-end: var(--space-md);
}

h2 {
  font-size: var(--text-3xl);
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-text);
  margin-block-end: var(--space-md);
}

h3 {
  font-size: var(--text-2xl);
  font-weight: 600;
  line-height: 1.3;
  color: var(--color-text);
  margin-block-end: var(--space-sm);
}

h1,
h2,
h3,
h4,
h5,
h6 {
  text-wrap: balance;
}

p {
  margin-block-end: var(--space-sm);
  max-width: 65ch;
  text-wrap: pretty;
}

/* ==================== АДАПТИВНОСТЬ 2024 ==================== */
@media (width < 768px) {
  .container {
    padding-inline: 0;
  }

  h1 {
    font-size: var(--text-3xl);
  }
}

/* ==================== УТИЛИТЫ ==================== */
.text-center {
  text-align: center;
}

.text-balance {
  text-wrap: balance;
}

.text-pretty {
  text-wrap: pretty;
}

.text-white {
  color: white;
}
.fs-20{font-size: 24px;}

.gap-sm {
  gap: var(--space-sm);
}

.gap-md {
  gap: var(--space-md);
}

.gap-lg {
  gap: var(--space-lg);
}

.mt-sm {
  margin-top: var(--space-sm);
}

.mt-md {
  margin-top: var(--space-md);
}

.mt-lg {
  margin-top: var(--space-lg);
}

.mb-sm {
  margin-bottom: var(--space-sm);
}

.mb-md {
  margin-bottom: var(--space-md);
}

.mb-lg {
  margin-bottom: var(--space-lg);
}

.my-sm {
  margin-bottom: var(--space-sm);
}

.my-md {
  margin-bottom: var(--space-md);
}

.my-lg {
  margin-bottom: var(--space-lg);
}


/* ==================== PRINT STYLES ==================== */
@media print {
  .container {
    width: 100%;
    max-width: none;
  }

  .no-print {
    display: none;
  }
}