/* =======================
CSS (ARTICLE PACK)
======================= */
:root{
  /* === ОСНОВНЫЕ ЦВЕТА ТЕКСТА/ФОНА === */
  --a-bg:#fff;          /* фон статьи */
  --a-text:#111;        /* основной цвет текста */
  --a-muted:#555;       /* вторичный текст (мета, подписи) */
  --a-line:#e5e5e5;     /* цвет линий/разделителей */
  --a-card:#f6f6f6;     /* фон “карточек”/блоков */
  --a-link:#0b57d0;     /* цвет ссылок */
  --a-link-hover:#0b57d0; /* цвет ссылки при наведении (если нужно менять) */

  --a-radius:12px;

  /* === РАЗМЕРЫ ТЕКСТА (менять здесь) ===
     --a-fs  : базовый размер шрифта статьи (все p/li и т.п. наследуют его)
     --a-h1  : размер H1
     --a-h2  : размер H2
     --a-h3  : размер H3
     --a-lh  : базовый line-height (межстрочный интервал) */
  --a-fs: clamp(16px, 1.2vw, 18px);     /* <-- общий размер текста статьи */
  --a-h1: clamp(28px, 3.2vw, 40px);     /* <-- размер H1 */
  --a-h2: clamp(22px, 2.2vw, 28px);     /* <-- размер H2 */
  --a-h3: clamp(18px, 1.6vw, 22px);     /* <-- размер H3 */
  --a-lh: 1.65;                         /* <-- общий межстрочный интервал */

  /* === ОТСТУПЫ (менять здесь) === */
  --a-s1: 8px;
  --a-s2: 12px;
  --a-s3: 16px;
  --a-s4: 22px;
  --a-s5: 30px;
}

article{
  color: var(--a-text);       /* <-- основной цвет текста */
  background: var(--a-bg);

  /* === ОБЩИЙ ТЕКСТ: размер/межстрочный/шрифт (менять здесь) ===
     var(--a-fs)  влияет на весь текст, который наследует font-size
     var(--a-lh)  влияет на всю типографику по умолчанию */
  font: 400 var(--a-fs)/var(--a-lh) system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* === ССЫЛКИ === */
article a{
  color: var(--a-link);       /* <-- цвет ссылки */
  text-underline-offset: 3px;
}
article a:hover{
  color: var(--a-link-hover); /* <-- цвет ссылки при наведении */
  text-decoration-thickness: 2px;
}

/* === ЗАГОЛОВКИ (размер берётся из переменных выше) === */
article h1{
  font-size: var(--a-h1);     /* <-- размер H1 */
  line-height: 1.15;          /* <-- межстрочный для H1 (если нужно) */
  margin: 0 0 var(--a-s2);
  letter-spacing: -0.01em;
}
article .infoArticle {
  font-size: 14px;            /* <-- размер текста мета-строки */
  color: var(--a-muted);
  margin: 0;
}
.banner {
    width: 100%;
    height: 300px;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
}
.banner img {
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: 0;
    top: 0;
    left: 0;
    object-fit: cover;
    filter: brightness(0.4);
}
.bannerTitle {
    position: relative;
    margin: 0;
    padding: 0;
    text-align: center;
    color: #fff;
    font-size: 7rem;
    font-weight: 700;
    z-index: 1;
}
article .meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;

  /* === РАЗМЕР МЕТА-ТЕКСТА (менять тут) === */
  font-size: 14px;            /* <-- размер текста мета-строки */
  color: var(--a-muted);
  list-style-type: none;
}

/* === ЛИД (крупнее базового текста) === */
article .lead{
  margin: var(--a-s2) 0 0;

  /* <-- размер лида (менять тут) */
  font-size: clamp(17px, 1.3vw, 20px);
}

section{ margin: 0 0 var(--a-s2); }
article section {
  padding: 0;
}

h2{
  font-size: var(--a-h2);     /* <-- размер H2 */
  line-height: 1.2;           /* <-- межстрочный для H2 */
  margin: var(--a-s2) 0 var(--a-s2);
  letter-spacing: -0.01em;
}

h3{
  font-size: var(--a-h3);     /* <-- размер H3 */
  line-height: 1.25;          /* <-- межстрочный для H3 */
  margin: var(--a-s4) 0 var(--a-s1);
}

/* Абзацы (наследуют общий --a-fs) */
section p{ margin: 0 0 var(--a-s2); }

/* Списки (наследуют общий --a-fs) */
section ul,
section ol{
  margin: 0 0 var(--a-s2);
  padding-left: 22px;
}
section li{ margin: 6px 0; }
section li > ul,
section li > ol{
  margin-top: 6px;
  margin-bottom: 0;
}

/* === BLOCKQUOTE (как на вашем примере) === */
blockquote{
  position: relative;
  margin: var(--a-s3) 0;
  padding: 18px 38px 18px 46px;
  background: #f3f3f3;             /* <-- фон цитаты */
  border-radius: var(--a-radius);
  border-left: 6px solid #7b7b7b;  /* <-- border-left цитаты (левая линия) */
  overflow: hidden;
}

/* большие кавычки по углам */
blockquote::before,
blockquote::after{
  position: absolute;
  color: #cfcfcf;                  /* <-- цвет кавычек */
  font-size: 44px;                 /* <-- размер кавычек */
  line-height: 1;
  font-weight: 700;
  pointer-events: none;
}

blockquote::before{
  content: "“";                    /* <-- символ левой кавычки */
  left: 14px;
  top: 10px;
}

blockquote::after{
  content: "”";                    /* <-- символ правой кавычки */
  right: 14px;
  bottom: 6px;
}

blockquote > *{
  margin: 0;
  font-style: italic;

  /* === РАЗМЕР/ЦВЕТ ТЕКСТА В ЦИТАТЕ (менять тут) === */
  color: #2a2a2a;                  /* <-- цвет текста цитаты */
  /* font-size: 1em; */            /* <-- если хотите отдельно управлять размером цитаты */
}

/* Изображения */
article figure{
  margin: var(--a-s3) 0;
  display: block;
}
article figure img{
  display: block;
  width: 100%;
  height: auto;
  border-radius: var(--a-radius);
  border: 1px solid var(--a-line);
}
article figure.align-left {
  float: left;
  margin-right: var(--a-s3); /* Отступ справа, чтобы текст не прилипал */
  max-width: 50%;            /* Ограничение ширины, чтобы оставить место тексту */
}

article figure.align-right {
  float: right;
  margin-left: var(--a-s3);  /* Отступ слева, чтобы текст не прилипал */
  max-width: 50%;            /* Ограничение ширины */
}

/* Сброс обтекания для родительского контейнера (Clearfix) */
section:has(figure.align-right,figure.align-left)::after {
  content: "";
  display: table;
  clear: both;
}

/* === ПОДПИСЬ К ИЗОБРАЖЕНИЮ (размер текста) === */
section figure figcaption{
  margin-top: 8px;
  color: var(--a-muted);
  font-size: 14px;                /* <-- размер подписи */
}

/* === КЛАССЫ ВЫРАВНИВАНИЯ ИЗОБРАЖЕНИЙ === */
.img-left{
  float: left;
  width: min(420px, 40%);
  margin: 6px 16px 12px 0;
}
.img-right{
  float: right;
  width: min(420px, 40%);
  margin: 6px 0 12px 16px;
}
.img-center{
  float: none;
  width: 100%;
  margin: var(--a-s3) 0;
}
@media (max-width: 640px){
  .a-img-left,
  .a-img-right{
    float: none;
    width: 100%;
    margin: var(--a-s3) 0;
  }

  /* === МЕЛЬЧЕ ТЕКСТ В ТАБЛИЦЕ НА МОБИЛКЕ (если нужно) === */
  /* Можно раскомментировать при желании:
  .a-table thead th,
  .a-table tbody th,
  .a-table tbody td { font-size: 14px; }
  */
}

/* Clearfix для секций после float */
section::after{
  content: "";
  display: block;
  clear: both;
}

/* === TABLE (скролл по X, полоса скрыта) === */
.a-table-wrap{
  margin: var(--a-s3) 0;
  border: 1px solid #d8d8d8;
  border-radius: var(--a-radius);
  background: #fff;
  box-shadow: 0 6px 18px rgba(0,0,0,.08);
}
.a-scroll-x{
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none; /* Firefox: скрыть полосу */
}
.a-scroll-x::-webkit-scrollbar{
  width: 0;
  height: 0;
}

section table{
  width: 100%;
  min-width: 900px;               /* <-- ширина таблицы (чем больше, тем чаще будет скролл) */
  border-collapse: separate;
  border-spacing: 0;
  background: #fff;
}

/* header */
section table thead th{
  background: #f1f1f1;
  color: #222;
  font-weight: 700;

  /* === РАЗМЕР ТЕКСТА В ШАПКЕ ТАБЛИЦЫ (менять тут) === */
  font-size: 16px;                /* <-- размер заголовков таблицы */

  padding: 12px 14px;
  border-bottom: 1px solid #d8d8d8;
  border-right: 1px solid #d8d8d8;
  text-align: left;
  white-space: nowrap;
}
section table thead th:last-child{ border-right: 0; }

/* body cells */
section table tbody th,
section table tbody td{
  padding: 12px 14px;
  border-bottom: 1px solid #e2e2e2;
  border-right: 1px solid #e2e2e2;
  vertical-align: top;
  text-align: left;

  /* === РАЗМЕР ТЕКСТА В ТЕЛЕ ТАБЛИЦЫ (менять тут) === */
  font-size: 16px;                /* <-- размер текста в ячейках */
}
section table tbody th{
  font-weight: 500;
  color: #111;
  background: #fff;
  white-space: nowrap;
}
section table tbody td:last-child{ border-right: 0; }

/* zebra */
section table tbody tr:nth-child(odd) th,
section table tbody tr:nth-child(odd) td{
  background: #f6fbff;
}

/* hover подсветка строки */
section table tbody tr:hover th,
section table tbody tr:hover td{
  background: #eef6ff;
}

/* скругления */
section table thead tr:first-child th:first-child{ border-top-left-radius: var(--a-radius); }
section table thead tr:first-child th:last-child{ border-top-right-radius: var(--a-radius); }
section table tbody tr:last-child th:first-child{ border-bottom-left-radius: var(--a-radius); }
section table tbody tr:last-child td:last-child{ border-bottom-right-radius: var(--a-radius); }

/* faq */
section[itemtype="https://schema.org/FAQPage"] {
  border-top: 1px solid var(--a-line);
  padding-top: var(--a-s4);
}

.faq-item{
  border: 1px solid var(--a-line);
  border-radius: var(--a-radius);
  background: var(--a-bg);
  margin: 10px 0;
  overflow: hidden;
}

.faq-question{
  width: 100%;
  text-align: left;
  border: 0;
  background: transparent;
  padding: 12px 14px;
  cursor: pointer;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;

  /* === РАЗМЕР ТЕКСТА В ВОПРОСЕ faq (менять тут) === */
  font-size: 16px;                /* <-- размер вопроса */
  font: inherit;
  font-weight: 700;
}

.faq-question:focus-visible{
  outline: 2px solid var(--a-link);
  outline-offset: 2px;
}

.faq-icon{
  width: 18px;
  height: 18px;
  position: relative;
  flex: 0 0 18px;
}
.faq-icon::before,
.faq-icon::after{
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 14px;
  height: 2px;
  background: var(--a-muted);
  transform: translate(-50%, -50%);
  transition: transform .2s ease;
}
.faq-icon::after{ transform: translate(-50%, -50%) rotate(90deg); }
.faq-item[open] .faq-icon::after{ transform: translate(-50%, -50%) rotate(0deg); }

.faq-answer-wrapper{ padding: 0 14px; }

.faq-answer-content {
  padding: 0 0 14px;
  color: var(--a-text);
  display: flex;
  flex-direction: column;
  gap: 10px;

  /* === РАЗМЕР ТЕКСТА В ОТВЕТЕ faq (менять тут) === */
  font-size: 16px;                /* <-- размер ответа */
}

.faq-answer-content > * {
  margin: 0 !important;
}

/* Обязательно для корректного замера высоты в JS */
.faq-answer-wrapper {
  overflow: hidden;
  display: block; /* Важно: не grid и не flex */
}

/* Убираем стандартную иконку */
summary::-webkit-details-marker { display: none; }
summary { list-style: none; outline: none; }


/* Motion preference */
@media (prefers-reduced-motion: reduce){
  .faq-icon::before,
  .faq-icon::after{
    transition: none;
  }
}