/* ========================================
   RESPONSIVE ДИЗАЙН
   Mobile-first подход
   ======================================== */

/* ========================================
   TABLET (768px и выше)
   ======================================== */

@media (max-width: 1024px) {
  :root {
    --font-size-4xl: 2rem;       /* 32px вместо 40px */
    --font-size-5xl: 2.5rem;     /* 40px вместо 48px */
  }
  
  .container {
    padding: 0 var(--space-lg);
  }
  
  .hero {
    min-height: 60vh;
    padding: var(--space-3xl) 0;
  }
  
  .hero-title {
    font-size: var(--font-size-4xl);
  }
  
  .hero-subtitle {
    font-size: var(--font-size-lg);
  }
  
  .grid-3 {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .grid-4 {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .section {
    padding: var(--space-3xl) 0;
  }
}

/* ========================================
   MOBILE (767px и ниже)
   ======================================== */

@media (max-width: 767px) {
  :root {
    --font-size-3xl: 1.5rem;     /* 24px */
    --font-size-4xl: 1.75rem;    /* 28px */
    --font-size-5xl: 2rem;       /* 32px */
    --space-3xl: 3rem;           /* 48px вместо 64px */
    --space-4xl: 4rem;           /* 64px вместо 96px */
  }
  
  body {
    font-size: var(--font-size-sm);
  }
  
  .container {
    padding: 0 var(--space-md);
  }
  
  h1 {
    font-size: var(--font-size-4xl);
  }
  
  h2 {
    font-size: var(--font-size-3xl);
  }
  
  h3 {
    font-size: var(--font-size-xl);
  }
  
  /* Hero секция */
  .hero {
    min-height: 50vh;
    padding: var(--space-2xl) 0;
  }
  
  .hero-title {
    font-size: var(--font-size-3xl);
  }
  
  .hero-subtitle {
    font-size: var(--font-size-base);
  }
  
  /* Grid система */
  .grid-2,
  .grid-3,
  .grid-4 {
    grid-template-columns: 1fr;
  }
  
  /* Навигация */
  .nav {
    position: fixed;
    top: var(--header-height);
    left: -100%;
    width: 80%;
    height: calc(100vh - var(--header-height));
    background: var(--background);
    flex-direction: column;
    align-items: flex-start;
    padding: var(--space-xl);
    box-shadow: var(--shadow-xl);
    transition: left var(--transition-base);
    z-index: 999;
  }
  
  .nav.active {
    left: 0;
  }
  
  .hamburger {
    display: flex;
  }
  
  /* Кнопки */
  .btn {
    width: 100%;
    text-align: center;
  }
  
  .btn-large {
    padding: 14px 24px;
    font-size: var(--font-size-base);
  }
  
  /* Карточки */
  .card {
    padding: var(--space-lg);
  }
  
  .silo-card {
    padding: var(--space-lg);
  }
  
  .article-content {
    padding: var(--space-lg);
  }
  
  /* Интерактивные элементы */
  .interactive-quiz {
    padding: var(--space-lg);
  }
  
  .calculator-widget {
    padding: var(--space-lg);
  }
  
  .infographic-container {
    padding: var(--space-lg);
  }
  
  /* Партнёрский блок */
  .partner-block {
    padding: var(--space-lg);
  }
  
  .partner-block h3 {
    font-size: var(--font-size-xl);
  }
  
  .partner-block a {
    font-size: var(--font-size-lg);
  }
  
  /* Таблицы */
  table {
    font-size: var(--font-size-sm);
  }
  
  th, td {
    padding: var(--space-sm) var(--space-md);
  }
  
  /* Overflow для таблиц */
  .table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  
  /* Секции */
  .section {
    padding: var(--space-2xl) 0;
  }
  
  .section-small {
    padding: var(--space-xl) 0;
  }
}

/* ========================================
   ОЧЕНЬ МАЛЕНЬКИЕ ЭКРАНЫ (480px и ниже)
   ======================================== */

@media (max-width: 480px) {
  :root {
    --font-size-4xl: 1.5rem;     /* 24px */
    --font-size-5xl: 1.75rem;    /* 28px */
  }
  
  .container {
    padding: 0 var(--space-sm);
  }
  
  .hero-title {
    font-size: var(--font-size-4xl);
  }
  
  .card {
    padding: var(--space-md);
  }
  
  .interactive-quiz {
    padding: var(--space-md);
  }
  
  .calculator-widget {
    padding: var(--space-md);
  }
  
  .quiz-option {
    padding: var(--space-md);
    font-size: var(--font-size-sm);
  }
  
  .calculator-input {
    padding: var(--space-sm) var(--space-md);
    font-size: var(--font-size-sm);
  }
}

/* ========================================
   БОЛЬШИЕ ЭКРАНЫ (1440px и выше)
   ======================================== */

@media (min-width: 1440px) {
  :root {
    --max-width: 1400px;
  }
  
  .hero-title {
    font-size: 3.5rem;
  }
}

/* ========================================
   PRINT СТИЛИ
   ======================================== */

@media print {
  * {
    background: transparent !important;
    color: black !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }
  
  a,
  a:visited {
    text-decoration: underline;
  }
  
  a[href]::after {
    content: " (" attr(href) ")";
  }
  
  abbr[title]::after {
    content: " (" attr(title) ")";
  }
  
  thead {
    display: table-header-group;
  }
  
  tr,
  img {
    page-break-inside: avoid;
  }
  
  p,
  h2,
  h3 {
    orphans: 3;
    widows: 3;
  }
  
  h2,
  h3 {
    page-break-after: avoid;
  }
  
  .nav,
  .hamburger,
  .partner-block {
    display: none;
  }
}

/* ========================================
   УТИЛИТЫ ДЛЯ АДАПТИВНОСТИ
   ======================================== */

/* Скрыть на мобильных */
@media (max-width: 767px) {
  .hide-mobile {
    display: none !important;
  }
}

/* Скрыть на десктопе */
@media (min-width: 768px) {
  .hide-desktop {
    display: none !important;
  }
}

/* Показать только на мобильных */
.show-mobile {
  display: none !important;
}

@media (max-width: 767px) {
  .show-mobile {
    display: block !important;
  }
}

/* ========================================
   ACCESSIBILITY - Улучшения для доступности
   ======================================== */

/* Фокус для клавиатурной навигации */
@media (prefers-reduced-motion: no-preference) {
  a:focus,
  button:focus,
  input:focus,
  textarea:focus,
  select:focus {
    outline: 2px solid var(--primary-color);
    outline-offset: 2px;
  }
}

/* Уменьшенная анимация для пользователей с чувствительностью */
@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;
  }
}

/* Высокая контрастность */
@media (prefers-contrast: high) {
  :root {
    --text-primary: #000000;
    --background: #ffffff;
    --border: #000000;
  }
}

/* Тёмная тема (опционально) */
@media (prefers-color-scheme: dark) {
  :root {
    --background: #1a1a1a;
    --surface: #2d2d2d;
    --surface-hover: #3d3d3d;
    --text-primary: #f8f9fa;
    --text-secondary: #adb5bd;
    --text-muted: #6c757d;
    --border: #404040;
    --border-light: #353535;
  }
  
  .hero {
    background: linear-gradient(135deg, #2d2d2d 0%, #1a1a1a 100%);
  }
  
  img {
    opacity: 0.9;
  }
}
