/*
Theme Name: ДЮСШ №1 Курск — Государственный стандарт
Description: Профессиональная тема для образовательного учреждения с учетом ГОСТ и современных веб-стандартов.
Version: 4.0.0
Text Domain: dyussh1-kursk-gov
*/

/* --- 1. Базовые переменные и глобальные стили --- */
:root {
  /* Цветовая палитра (вдохновлено госсайтами и IT-сферой) */
  --primary-blue: #0d47a1; /* Глубокий синий, как на сайтах госорганов */
  --accent-blue: #1976d2;  /* Яркий синий для акцентов */
  --accent-teal: #0d47a1;  /* "Айтишный" цвет для рамок и акцентов */
  --light-gray-bg: #f5f7fa; /* Фоновый цвет для секций */
  --text-dark: #0d47a1;      /* Основной цвет текста */
  --text-light: #495057;     /* Второстепенный текст */
  --border-color: #dee2e6;   /* Цвет рамок */
  --white: #ffffff;
  --black: #000000;

  /* Типографика */
  --font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-size-base: 16px;
  --line-height-base: 1.7;

  /* Макет */
  --max-width: 1320px;
  --container-padding: 1.5rem;
  --radius: 8px;
  --shadow: 0 4px 12px rgba(0, 0, 0, 0.07);
  --transition: 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

/* Сброс стилей и базовые настройки */
*, *::before, *::after { box-sizing: border-box; }
html { font-size: var(--font-size-base); scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-family);
  background: var(--white);
  color: var(--text-dark);
  line-height: var(--line-height-base);
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
.site-wrapper {
  flex: 1 0 auto;
  width: 100%;
  border-top: 5px solid var(--accent-teal); /* Верхняя рамка */
  border-bottom: 5px solid var(--accent-teal); /* Нижняя рамка */
}
.container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--container-padding);
}
a { color: var(--accent-blue); text-decoration: none; transition: color var(--transition); }
a:hover { text-decoration: underline; color: var(--primary-blue); }
img { max-width: 100%; height: auto; display: block; }
h1, h2, h3, h4, h5, h6 { margin: 0 0 1rem; line-height: 1.3; }

/* Скрытие элементов для скринридеров */
.screen-reader-text {
    border: 0; clip: rect(1px, 1px, 1px, 1px);
    -webkit-clip-path: inset(50%); clip-path: inset(50%);
    height: 1px; width: 1px; margin: -1px;
    overflow: hidden; padding: 0; position: absolute;
}

/* --- 2. Версия для слабовидящих (VI Panel) --- */
.vi-panel {
  display: none; background: #2d3748; color: #fff; padding: 1rem 0;
}
.vi-panel.active { display: block; }
.vi-panel .container { display: flex; justify-content: space-between; align-items: center; }
.vi-panel-inner { display: flex; flex-wrap: wrap; gap: 1.5rem; }
.vi-group { display: flex; align-items: center; gap: 0.5rem; font-size: 0.9rem; }
.vi-panel button {
  background: #4a5568; color: #fff; border: 1px solid #718096;
  padding: 0.4rem 0.8rem; cursor: pointer; border-radius: 4px; transition: background-color var(--transition);
}
.vi-panel button:hover { background: #718096; }
#vi-close-panel { font-size: 1.5rem; background: none; border: none; line-height: 1; padding: 0 .5rem; }

/* VI-режимы */
body.vi-mode-fontsize-large { font-size: 18px; }
body.vi-mode-fontsize-xlarge { font-size: 20px; }
body.vi-mode-dark { background: #1a1a1a; color: #f0f0f0; }
body.vi-mode-dark .site-header,
body.vi-mode-dark .site-footer,
body.vi-mode-dark .news-card { background-color: #2b2b2b; border-color: #444; }
body.vi-mode-dark h1, body.vi-mode-dark h2, body.vi-mode-dark h3 { color: #fff; }
body.vi-mode-dark a { color: #87c3ff; }

/* --- 3. Шапка сайта (Header) --- */
.site-header {
  background: var(--white); position: sticky; top: 0; z-index: 1000;
  box-shadow: 0 2px 4px rgba(0,0,0,0.05); width: 100%;
}
.top-bar {
  background: var(--light-gray-bg); padding: 0.5rem 0;
  border-bottom: 1px solid var(--border-color); font-size: 0.875rem;
}
.top-bar .container { display: flex; justify-content: space-between; align-items: center; }
.vi-toggle-button {
  background: none; border: none; cursor: pointer; display: inline-flex;
  align-items: center; gap: 0.5rem; font-family: inherit; font-size: inherit; color: var(--text-light);
}
.vi-toggle-button:hover { color: var(--text-dark); }
.header-main .container {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 1rem; padding-bottom: 1rem; gap: 1.5rem;
}
.site-branding { display: flex; align-items: center; gap: 1rem; }
.brand-text .site-title { font-size: 1.25rem; font-weight: 700; margin: 0; }
.brand-text .site-title a { color: var(--text-dark); text-decoration: none; }
.brand-text .site-description { font-size: 0.9rem; margin: 0; color: var(--text-light); }
.header-contacts { display: flex; flex-direction: column; align-items: flex-end; font-size: 0.9rem; }
.header-contacts .contact-phone { font-weight: 700; font-size: 1rem; color: var(--text-dark); }

/* --- 4. Навигация (кроссплатформенная) --- */
.main-navigation { background: var(--primary-blue); }
.main-navigation .container { position: relative; }
.main-menu { list-style: none; margin: 0; padding: 0; display: flex; }
.main-menu > li > a {
  display: block; padding: 1rem 1.5rem; color: var(--white);
  font-weight: 500; text-decoration: none; transition: background-color var(--transition);
  position: relative;
}
.main-menu > li:hover > a, .main-menu > li.current-menu-item > a { background-color: var(--accent-blue); }
.main-menu .sub-menu {
  display: none; position: absolute; top: 100%; left: 0;
  background: var(--white); min-width: 240px; box-shadow: var(--shadow);
  border-radius: 0 0 var(--radius) var(--radius); padding: 0.5rem 0; z-index: 1010;
}
.main-menu > li:hover > .sub-menu, .main-menu > li:hover > .mega-menu { display: block; }
.main-menu .sub-menu li { list-style: none; }
.main-menu .sub-menu a {
  padding: 0.75rem 1.5rem; display: block; white-space: nowrap;
  color: var(--text-dark);
}
.main-menu .sub-menu a:hover { background-color: var(--light-gray-bg); text-decoration: none; }
/* Мега-меню */
.main-menu .mega-menu {
  display: none; position: absolute; top: 100%; left: 0; width: 100%;
  background: var(--white); box-shadow: var(--shadow); padding: 2rem;
}
.mega-menu-grid { display: grid; grid-template-columns: repeat(var(--columns, 4), 1fr); gap: 2rem; }
.mega-menu-title { font-size: 1rem; font-weight: 700; color: var(--text-dark); border-bottom: 2px solid var(--accent-teal); padding-bottom: 0.5rem; margin-bottom: 1rem; }
.mega-menu-column ul { list-style: none; margin: 0; padding: 0; }
.mega-menu-column li a {
  display: block; padding: 0.5rem 0; color: var(--text-light);
}
.mega-menu-column li a:hover { color: var(--primary-blue); text-decoration: none; }
/* Кнопка мобильного меню */
.menu-toggle { display: none; background: none; border: none; cursor: pointer; padding: 0; color: var(--primary-blue); }
.menu-toggle .icon-close { display: none; }

/* --- 5. Основной контент (Homepage) --- */
.site-content { padding: 3rem 0; }
.section-title { text-align: center; font-size: 2.25rem; margin-bottom: 3rem; font-weight: 700; }
.hero-section {
    text-align: center; background: var(--light-gray-bg);
    padding: 4rem var(--container-padding); border-radius: var(--radius); margin-bottom: 3rem;
}
.hero-title { font-size: 2.5rem; font-weight: 900; }
.hero-description { font-size: 1.1rem; color: var(--text-light); max-width: 700px; margin: 1rem auto 2rem; }
.hero-stats { display: flex; justify-content: center; gap: 2rem; flex-wrap: wrap; }
.stat-item { text-align: center; }
.stat-number { font-size: 2.5rem; font-weight: 900; color: var(--primary-blue); }
.stat-label { font-size: 1rem; color: var(--text-light); }
.posts-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 2rem;
}
.news-card {
  background: var(--white); border-radius: var(--radius); overflow: hidden;
  box-shadow: var(--shadow); transition: all var(--transition); display: flex; flex-direction: column;
}
.news-card:hover { transform: translateY(-5px); box-shadow: 0 10px 20px rgba(0,0,0,0.1); }
.news-card-image-link img { width: 100%; height: 200px; object-fit: cover; }
.news-card-content { padding: 1.5rem; display: flex; flex-direction: column; flex-grow: 1; }
.news-card-meta { font-size: 0.875rem; color: var(--text-light); margin-bottom: 0.5rem; }
.news-card-title { font-size: 1.25rem; margin: 0 0 1rem 0; line-height: 1.4; }
.news-card-title a { color: var(--text-dark); text-decoration: none; }
.news-card-excerpt { margin-bottom: 1rem; flex-grow: 1; }
.read-more { font-weight: 700; text-decoration: none; }
.section-actions { text-align: center; margin-top: 3rem; }
.button-primary {
    display: inline-block; padding: 0.75rem 2rem; background: var(--primary-blue);
    color: var(--white); border-radius: var(--radius); font-weight: 500;
    text-decoration: none; transition: background-color var(--transition);
}
.button-primary:hover { background: var(--accent-blue); text-decoration: none; }

/* --- 6. Подвал (Footer) --- */
.site-footer {
  background: var(--text-dark); color: rgba(255, 255, 255, 0.7);
  padding: 3rem 0 0; margin-top: auto;
}
.footer-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 2rem; margin-bottom: 2rem;
}
.footer-widget-area { min-width: 0; }
.footer-widget h4 { color: var(--white); font-size: 1.1rem; }
.footer-widget ul { list-style: none; padding: 0; margin: 0; }
.footer-widget ul li a { color: rgba(255, 255, 255, 0.8); padding: 0.25rem 0; display: inline-block; }
.footer-widget ul li a:hover { color: var(--white); text-decoration: none; }
.footer-bottom { text-align: center; padding: 1.5rem 0; border-top: 1px solid #444; font-size: 0.9rem; }
.footer-bottom p { margin: 0; }

/* --- 7. Адаптивность --- */
@media (max-width: 1024px) {
  .header-contacts { display: none; } /* Скрываем контакты, чтобы влезло меню */
  .menu-toggle { display: block; }
  .main-navigation {
    position: absolute; top: 100%; right: 0; left: 0;
    background: var(--white);
    transform-origin: top;
    transform: scaleY(0);
    transition: transform var(--transition);
    box-shadow: var(--shadow);
    max-height: calc(100vh - 80px); /* Высота шапки */
    overflow-y: auto;
  }
  body.menu-open .main-navigation { transform: scaleY(1); }
  body.menu-open .menu-toggle .icon-menu { display: none; }
  body.menu-open .menu-toggle .icon-close { display: block; }

  .main-menu { flex-direction: column; }
  .main-menu > li > a { color: var(--text-dark); padding: 1rem 1.5rem; border-bottom: 1px solid var(--border-color); }
  .main-menu .sub-menu, .main-menu .mega-menu {
    display: block; position: static; box-shadow: none; padding: 0;
    border-radius: 0; background-color: var(--light-gray-bg);
    display: none; /* Скрываем по умолчанию */
  }
  .main-menu .sub-menu a { padding-left: 3rem; }
  .main-menu > li:hover > .sub-menu, .main-menu > li:hover > .mega-menu { display: none; } /* Отключаем ховер */
  .main-menu .menu-item-has-children > a { display: flex; justify-content: space-between; align-items: center; }
  .main-menu .menu-item-has-children > a::after {
      content: '▼'; display: inline-block; font-size: 0.7rem; margin-left: 1rem;
  }
  .main-menu .mega-menu-grid { grid-template-columns: 1fr; }
  .mega-menu { padding: 1rem 1.5rem !important; }

  .hero-title { font-size: 2rem; }
  .footer-grid { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  :root { --container-padding: 1rem; }
  .header-main .container { flex-wrap: wrap; }
  .site-branding { flex-grow: 1; }
  .hero-stats { gap: 1rem; }
  .stat-item { flex-basis: 45%; }
}