/* ============================================================
   CFU — Адаптивный слой (генерируется gen_responsive.py)
   Подключается ПОСЛЕ shared.css и стиля страницы.
   Десктоп не меняется; правила включаются на планшете/телефоне.
   ============================================================ */

/* Десктоп НЕ трогаем: ширина как в оригинале (во всю страницу).
   Адаптив включается только медиа-запросами ниже. */

/* На узких экранах убираем фикс десктоп-ширины (legacy: body{min-width:1280px}
   из @media(max-width:800px)). Без этого мобильный макет не сворачивается. */
@media (max-width: 1279px) {
  body { min-width: 0 !important; width: auto !important; overflow-x: hidden; }
}

/* Бургер по умолчанию скрыт (десктоп). */
.cfu-nav-cb, .cfu-nav-burger { display: none; }

/* Картинки и фреймы не вылезают за экран. */
img, svg, iframe, video { max-width: 100%; }

/* ---------- ПЛАНШЕТ: ≤1024px ---------- */
@media (max-width: 1024px) {
  .footer-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .home-hero-stats { grid-template-columns: repeat(2, 1fr) !important; }
  .quick-strip-home { grid-template-columns: repeat(2, 1fr) !important; }
  .sb-stats { grid-template-columns: repeat(2, 1fr) !important; }
  .events-list { grid-template-columns: repeat(2, 1fr) !important; }
  .struct-grid-home { grid-template-columns: repeat(2, 1fr) !important; }
  .num-band-row { grid-template-columns: repeat(2, 1fr) !important; }
  .prorector-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .bodies-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .dept-hero-stats { grid-template-columns: repeat(2, 1fr) !important; }
  .quick-strip { grid-template-columns: repeat(2, 1fr) !important; }
  .fac-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .news-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .aud-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .prog-tabs { grid-template-columns: repeat(2, 1fr) !important; }
  .priem-side-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .resource-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .subkafs { grid-template-columns: repeat(2, 1fr) !important; }
  .staff-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .partner-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .audience-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .learn-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .trainer-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .m-prog-quickstats { grid-template-columns: repeat(2, 1fr) !important; }
  .contact-blocks-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .reception-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .feedback-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .socials-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .pc-stats { grid-template-columns: repeat(2, 1fr) !important; }
  .grad-hero-stats { grid-template-columns: repeat(2, 1fr) !important; }
  .grad-docs-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .eb-stats { grid-template-columns: repeat(2, 1fr) !important; }
  .benefits-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .grad-polls-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .alumni-socs-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .clubs-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .sport-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .status-strip { grid-template-columns: repeat(2, 1fr) !important; }
  .step-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .topic-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .prog-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .srv-grid-small { grid-template-columns: repeat(2, 1fr) !important; }
  .info-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .staff-hero-quickfacts { grid-template-columns: repeat(2, 1fr) !important; }
  .pub-stats { grid-template-columns: repeat(2, 1fr) !important; }
  .sci-blocks-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .ttc-band-stats { grid-template-columns: repeat(2, 1fr) !important; }
  .ttc-services-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .m-pub-stats { grid-template-columns: repeat(2, 1fr) !important; }
  .partner-logos { grid-template-columns: repeat(2, 1fr) !important; }
  .sci-news-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .services-top-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .support-grid { grid-template-columns: repeat(2, 1fr) !important; }
}

/* ---------- ТЕЛЕФОН/УЗКИЙ ПЛАНШЕТ: ≤760px ---------- */
@media (max-width: 760px) {
  /* боковые отступы чуть меньше */
  .section { padding-left: 20px; padding-right: 20px; }
  .home-hero { padding-left: 20px !important; padding-right: 20px !important; }
  .home-hero-title { font-size: 34px !important; }

  /* все «контентные» многоколоночные сетки — в одну колонку */
  .pres-pair { grid-template-columns: 1fr !important; }
  .footer-grid { grid-template-columns: 1fr !important; }
  .home-hero-stats { grid-template-columns: 1fr !important; }
  .quick-strip-home { grid-template-columns: 1fr !important; }
  .adm-grid { grid-template-columns: 1fr !important; }
  .about-grid { grid-template-columns: 1fr !important; }
  .sb-stats { grid-template-columns: 1fr !important; }
  .news-events-grid { grid-template-columns: 1fr !important; }
  .events-list { grid-template-columns: 1fr !important; }
  .struct-grid-home { grid-template-columns: 1fr !important; }
  .partners-band { grid-template-columns: 1fr !important; }
  .pb-stats { grid-template-columns: 1fr !important; }
  .m-stat-strip-4 { grid-template-columns: 1fr !important; }
  .m-sci-stats { grid-template-columns: 1fr !important; }
  .num-band-row { grid-template-columns: 1fr !important; }
  .mission-grid { grid-template-columns: 1fr !important; }
  .rector-card { grid-template-columns: 1fr !important; }
  .prorector-grid { grid-template-columns: 1fr !important; }
  .awards-grid { grid-template-columns: 1fr !important; }
  .strat-partners-grid { grid-template-columns: 1fr !important; }
  .about-cta-band { grid-template-columns: 1fr !important; }
  .bodies-grid { grid-template-columns: 1fr !important; }
  .dept-hero { grid-template-columns: 1fr !important; }
  .dept-hero-stats { grid-template-columns: 1fr !important; }
  .quick-strip { grid-template-columns: 1fr !important; }
  .fac-grid { grid-template-columns: 1fr !important; }
  .prog-row { grid-template-columns: 1fr !important; }
  .news-grid { grid-template-columns: 1fr !important; }
  .aud-grid { grid-template-columns: 1fr !important; }
  .prog-hero { grid-template-columns: 1fr !important; }
  .prog-tabs { grid-template-columns: 1fr !important; }
  .vstuplenie-grid { grid-template-columns: 1fr !important; }
  .priem-side-grid { grid-template-columns: 1fr !important; }
  .disc-row { grid-template-columns: 1fr !important; }
  .resource-grid { grid-template-columns: 1fr !important; }
  .dept-card-header { grid-template-columns: 1fr !important; }
  .subkafs { grid-template-columns: 1fr !important; }
  .staff-grid { grid-template-columns: 1fr !important; }
  .partner-grid { grid-template-columns: 1fr !important; }
  .dpo-hero { grid-template-columns: 1fr !important; }
  .dpo-hero-meta { grid-template-columns: 1fr !important; }
  .dpo-about { grid-template-columns: 1fr !important; }
  .about-highlights { grid-template-columns: 1fr !important; }
  .audience-grid { grid-template-columns: 1fr !important; }
  .learn-grid { grid-template-columns: 1fr !important; }
  .mod-item summary { grid-template-columns: 1fr !important; }
  .trainer-grid { grid-template-columns: 1fr !important; }
  .cert-strip { grid-template-columns: 1fr !important; }
  .review-grid { grid-template-columns: 1fr !important; }
  .m-prog-quickstats { grid-template-columns: 1fr !important; }
  .contacts-hero { grid-template-columns: 1fr !important; }
  .contact-blocks-grid { grid-template-columns: 1fr !important; }
  .reception-grid { grid-template-columns: 1fr !important; }
  .feedback-grid { grid-template-columns: 1fr !important; }
  .addresses-grid { grid-template-columns: 1fr !important; }
  .socials-grid { grid-template-columns: 1fr !important; }
  .level-grid { grid-template-columns: 1fr !important; }
  .prog-cards { grid-template-columns: 1fr !important; }
  .pc-stats { grid-template-columns: 1fr !important; }
  .dpo-cat-grid { grid-template-columns: 1fr !important; }
  .dpo-cards { grid-template-columns: 1fr !important; }
  .dpo-cta-band { grid-template-columns: 1fr !important; }
  .dcb-aside { grid-template-columns: 1fr !important; }
  .grad-hero { grid-template-columns: 1fr !important; }
  .grad-hero-stats { grid-template-columns: 1fr !important; }
  .grad-docs-grid { grid-template-columns: 1fr !important; }
  .success-grid { grid-template-columns: 1fr !important; }
  .eb-stats { grid-template-columns: 1fr !important; }
  .benefits-grid { grid-template-columns: 1fr !important; }
  .grad-polls-grid { grid-template-columns: 1fr !important; }
  .alumni-socs-grid { grid-template-columns: 1fr !important; }
  .grad-cta-band { grid-template-columns: 1fr !important; }
  .home-hero-grid { grid-template-columns: 1fr !important; }
  .news-feed-grid { grid-template-columns: 1fr !important; }
  .clubs-grid { grid-template-columns: 1fr !important; }
  .dorms-grid { grid-template-columns: 1fr !important; }
  .dorms-stats { grid-template-columns: 1fr !important; }
  .sport-grid { grid-template-columns: 1fr !important; }
  .culture-grid { grid-template-columns: 1fr !important; }
  .life-cta-band { grid-template-columns: 1fr !important; }
  .lcb-socials { grid-template-columns: 1fr !important; }
  .status-strip { grid-template-columns: 1fr !important; }
  .step-grid { grid-template-columns: 1fr !important; }
  .topic-grid { grid-template-columns: 1fr !important; }
  .prog-grid { grid-template-columns: 1fr !important; }
  .rab-hero { grid-template-columns: 1fr !important; }
  .srv-grid { grid-template-columns: 1fr !important; }
  .srv-grid-small { grid-template-columns: 1fr !important; }
  .info-grid { grid-template-columns: 1fr !important; }
  .sveden-layout { grid-template-columns: 1fr !important; }
  .m-status-strip { grid-template-columns: 1fr !important; }
  .staff-hero { grid-template-columns: 1fr !important; }
  .staff-hero-quickfacts { grid-template-columns: 1fr !important; }
  .staff-grid-2 { grid-template-columns: 1fr !important; }
  .pub-stats { grid-template-columns: 1fr !important; }
  .disc-grid { grid-template-columns: 1fr !important; }
  .sci-hero { grid-template-columns: 1fr !important; }
  .sci-hero-stats { grid-template-columns: 1fr !important; }
  .sci-blocks-grid { grid-template-columns: 1fr !important; }
  .ttc-band-stats { grid-template-columns: 1fr !important; }
  .ttc-services-grid { grid-template-columns: 1fr !important; }
  .mip-grid { grid-template-columns: 1fr !important; }
  .contact-card { grid-template-columns: 1fr !important; }
  .m-pub-stats { grid-template-columns: 1fr !important; }
  .m-ttc-stats { grid-template-columns: 1fr !important; }
  .partner-logos { grid-template-columns: 1fr !important; }
  .sci-news-grid { grid-template-columns: 1fr !important; }
  .m-srv-grid { grid-template-columns: 1fr !important; }
  .stu-hero { grid-template-columns: 1fr !important; }
  .services-top-grid { grid-template-columns: 1fr !important; }
  .finance-grid { grid-template-columns: 1fr !important; }
  .support-grid { grid-template-columns: 1fr !important; }
  .polls-grid { grid-template-columns: 1fr !important; }
}

/* ---------- МОБИЛЬНОЕ МЕНЮ: ≤960px ---------- */
@media (max-width: 960px) {
  .main-header { flex-wrap: wrap; row-gap: 10px; }
  .brand { margin-right: auto; }
  .header-actions { order: 2; }

  .cfu-nav-burger {
    display: inline-flex; flex-direction: column; justify-content: center;
    gap: 5px; width: 46px; height: 40px; padding: 8px; box-sizing: border-box;
    cursor: pointer; order: 3; background: transparent; border: 0;
  }
  .cfu-nav-burger span {
    display: block; height: 3px; width: 100%;
    background: var(--c-red, #DA291C); border-radius: 2px;
    transition: transform .2s ease, opacity .2s ease;
  }

  .main-nav {
    order: 4; width: 100%; display: none;
    flex-direction: column; gap: 0;
    border-top: 1px solid var(--c-line, #D9DBE0);
  }
  #cfu-nav-toggle:checked ~ .main-nav { display: flex; }
  .main-nav a {
    padding: 13px 4px; font-size: 16px;
    border-bottom: 1px solid var(--c-line, #ECEDEF);
  }

  /* верхний бар аудиторий — переносим вместо обрезки */
  .top-bar { flex-wrap: wrap; row-gap: 4px; }
  .top-bar-links { flex-wrap: wrap; gap: 10px 16px; }
}

/* ---------- МАЛЕНЬКИЙ ТЕЛЕФОН: ≤480px ---------- */
@media (max-width: 480px) {
  .top-bar, .main-header, .section, .home-hero { padding-left: 16px; padding-right: 16px; }
  .brand-name { font-size: 14px; line-height: 1.15; }
  .brand-sub  { font-size: 11px; }
  .main-header .icon-btn { display: none; }   /* прячем иконку поиска, бургер остаётся */
  .home-hero { padding-top: 40px; padding-bottom: 36px; }
  .home-hero-title { font-size: 26px !important; }
}

/* ===== A11Y: тёмный текст на золоте (контраст AA 6.6:1, как у btn-primary) ===== */
/* responsive.css грузится последним → перекрывает белый текст из shared.css/страничных CSS */
.chip-active,
.chips .chip-active,
.edu-filters .chip.is-active,
.cont-filters .chip.is-active { color: #1a1a1a; }
.dpoc-btn { color: #1a1a1a; }

/* ===== Версия для слабовидящих (ГОСТ Р 52872-2019): панель + режимы ===== */
.access-link { cursor: pointer; }
.access-link[aria-pressed="true"] { font-weight: 700; text-decoration: underline; }

/* Панель видна только в BVI-режиме; вне .site → монохром и zoom её не трогают */
#cfu-bvi-panel { display: none; }
html.bvi #cfu-bvi-panel { display: block; }

/* Цветовые схемы (две краски на каждую) */
html.bvi { --bvi-bg: #ffffff; --bvi-fg: #000000; }                       /* дефолт = «чёрным по белому» */
html.bvi[data-bvi-scheme="wb"] { --bvi-bg: #ffffff; --bvi-fg: #000000; }
html.bvi[data-bvi-scheme="bw"] { --bvi-bg: #000000; --bvi-fg: #ffffff; }
html.bvi[data-bvi-scheme="bc"] { --bvi-bg: #9DD1FF; --bvi-fg: #0A2A43; }

/* Сама панель */
#cfu-bvi-panel { position: sticky; top: 0; z-index: 1000; background: var(--bvi-bg);
  color: var(--bvi-fg); border-bottom: 3px solid var(--bvi-fg); font-family: var(--font-body); }
.bvi-inner { max-width: 1400px; margin: 0 auto; padding: 8px 16px;
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px 22px; }
.bvi-group { display: flex; align-items: center; gap: 6px; }
.bvi-label { font-size: 14px; font-weight: 600; color: var(--bvi-fg); margin-right: 2px; }
.bvi-btn { min-width: 40px; min-height: 40px; padding: 6px 12px; border: 2px solid var(--bvi-fg);
  background: var(--bvi-bg); color: var(--bvi-fg); font-family: inherit; line-height: 1; cursor: pointer;
  border-radius: 4px; display: inline-flex; align-items: center; justify-content: center; }
.bvi-btn.is-active { background: var(--bvi-fg); color: var(--bvi-bg); font-weight: 700; }
.bvi-btn:focus-visible { outline: none; box-shadow: 0 0 0 2px var(--bvi-bg), 0 0 0 5px var(--bvi-fg); }
/* превью цветосхем — кнопки всегда показывают свою краску */
.bvi-sw { font-weight: 700; font-size: 16px; }
.bvi-sw-wb { background: #ffffff !important; color: #000000 !important; border-color: #000000 !important; }
.bvi-sw-bw { background: #000000 !important; color: #ffffff !important; border-color: #000000 !important; }
.bvi-sw-bc { background: #9DD1FF !important; color: #0A2A43 !important; border-color: #0A2A43 !important; }
.bvi-sw.is-active { box-shadow: 0 0 0 2px var(--bvi-bg), 0 0 0 5px var(--bvi-fg); }
.bvi-exit { margin-left: auto; min-height: 40px; padding: 8px 16px; border: 2px solid var(--bvi-fg);
  background: var(--bvi-fg); color: var(--bvi-bg); font-family: inherit; font-weight: 700; font-size: 15px;
  cursor: pointer; border-radius: 4px; }
.bvi-exit:focus-visible { outline: none; box-shadow: 0 0 0 2px var(--bvi-bg), 0 0 0 5px var(--bvi-fg); }

/* Монохром контента по выбранной схеме (панель — вне .site, не затрагивается) */
html.bvi body { background: var(--bvi-bg) !important; }
html.bvi .site { background: var(--bvi-bg) !important; }
html.bvi .site, html.bvi .site * {
  background-color: transparent !important; background-image: none !important;
  color: var(--bvi-fg) !important; border-color: var(--bvi-fg) !important;
  box-shadow: none !important; text-shadow: none !important; }
html.bvi .site a, html.bvi .site a *, html.bvi .site a:visited {
  color: var(--bvi-fg) !important; text-decoration: underline !important; }
/* кнопки/поля/чипы — видимая рамка, чтобы не сливались с текстом */
html.bvi .site .btn-primary, html.bvi .site .btn-blue, html.bvi .site .btn-ghost,
html.bvi .site button, html.bvi .site .chip, html.bvi .site .dpoc-btn,
html.bvi .site input, html.bvi .site select, html.bvi .site textarea {
  border: 2px solid var(--bvi-fg) !important; }
html.bvi .site .btn-primary, html.bvi .site .btn-blue { font-weight: 700 !important; }
html.bvi .site .chip-active, html.bvi .site .chips .chip-active {
  background: var(--bvi-fg) !important; color: var(--bvi-bg) !important; }
html.bvi .site .cfu-nav-burger span { background: var(--bvi-fg) !important; }
html.bvi .site .main-nav a.active::after { background: var(--bvi-fg) !important; }

/* Размер шрифта — zoom на .site (тема px-овая, % на html не масштабирует) */
html.bvi[data-bvi-font="2"] .site { zoom: 1.2; }
html.bvi[data-bvi-font="3"] .site { zoom: 1.4; }

/* Межбуквенный интервал */
html.bvi[data-bvi-kern="2"] .site { letter-spacing: 0.09em; word-spacing: 0.12em; }
html.bvi[data-bvi-kern="3"] .site { letter-spacing: 0.18em; word-spacing: 0.22em; }

/* Изображения */
html.bvi[data-bvi-img="off"] .site img,
html.bvi[data-bvi-img="off"] .site picture { display: none !important; }

/* ===== Skip-link (к содержимому) — видна при фокусе с клавиатуры ===== */
.skip-link { position: absolute; left: -9999px; top: 0; z-index: 1000; background: var(--c-burgundy, #7A1810); color: #fff; padding: 10px 16px; border-radius: 0 0 8px 0; font-weight: 600; }
.skip-link:focus { left: 0; }

/* ===== A11Y-добивка: контраст мелкого приглушённого текста + тач-таргет иконки ===== */
:root { --c-text-soft: #6B6B6B; }            /* было #7A7A7A (4.30:1) → 5.1:1 ✅ */
.main-header .icon-btn { width: 40px; height: 40px; }   /* было 36×36 — комфортнее для тача */

/* ===== Поиск по сайту (1.3.85): дропдаун в шапке + живые подсказки + страница результатов ===== */
.header-search { position: relative; }
.search-pop { position: absolute; top: calc(100% + 12px); right: 0; z-index: 1200;
  width: min(360px, 86vw); background: #fff; border: 1px solid var(--c-line);
  border-radius: 10px; box-shadow: 0 10px 30px rgba(20,30,60,.16); padding: 10px; }
.search-pop[hidden] { display: none; }
.search-form { position: relative; display: flex; gap: 8px; }
.search-input { flex: 1; min-width: 0; padding: 10px 12px; border: 1px solid var(--c-line);
  border-radius: 6px; font: inherit; font-size: 14px; }
.search-input:focus { outline: 2px solid var(--c-burgundy); outline-offset: 1px; }
.search-go { flex-shrink: 0; width: 40px; height: 40px; border: none; border-radius: 6px;
  background: var(--c-gold); color: #1a1a1a; cursor: pointer; display: inline-flex;
  align-items: center; justify-content: center; }
/* выпадающие подсказки */
.search-suggest { position: absolute; top: calc(100% + 8px); left: 0; right: 0; z-index: 5;
  list-style: none; margin: 0; padding: 4px; background: #fff; border: 1px solid var(--c-line);
  border-radius: 8px; box-shadow: 0 10px 24px rgba(20,30,60,.14); max-height: 60vh; overflow-y: auto; }
.search-suggest[hidden] { display: none; }
.search-suggest li { margin: 0; }
.search-suggest a { display: block; padding: 8px 10px; border-radius: 6px; text-decoration: none; color: var(--c-text); }
.search-suggest a:hover, .search-suggest a.is-active { background: var(--c-gold-soft); }
.search-suggest .ss-type { display: block; font-size: 11px; color: var(--c-gold-text); font-weight: 600; letter-spacing: .03em; }
.search-suggest .ss-title { display: block; font-size: 14px; line-height: 1.35; }
.search-suggest .ss-empty { padding: 10px; color: var(--c-text-soft); font-size: 13px; }

/* страница результатов /?s= */
.search-head { margin-bottom: 16px; }
.search-count { color: var(--c-text-muted); font-size: 14px; margin-top: 4px; }
.search-form-lg { position: relative; display: flex; gap: 10px; margin-top: 16px; max-width: 720px; flex-wrap: wrap; }
.search-input-lg { flex: 1; min-width: 240px; padding: 12px 14px; border: 1px solid var(--c-line); border-radius: 8px; font: inherit; font-size: 16px; }
.search-input-lg:focus { outline: 2px solid var(--c-burgundy); outline-offset: 1px; }
.search-form-lg .search-suggest { top: calc(100% + 6px); }
.search-list { margin-top: 8px; }
.search-item { padding: 18px 0; border-bottom: 1px solid var(--c-line); }
.search-item-type { font-size: 12px; color: var(--c-gold-text); text-transform: uppercase; letter-spacing: .04em; font-weight: 600; }
.search-item-title { font-family: var(--font-display); font-size: 19px; font-weight: 700; margin: 5px 0; }
.search-item-title a { color: var(--c-burgundy); }
.search-item-title a:hover { text-decoration: underline; }
.search-item-excerpt { color: var(--c-text-muted); font-size: 14px; line-height: 1.55; }
.search-item-url { font-size: 12px; color: var(--c-text-soft); margin-top: 5px; }
.search-empty { padding: 8px 0 16px; color: var(--c-text-muted); }
.search-empty-links { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 14px; }

/* мобильный: поиск остаётся доступным (отменяем старое скрытие иконки ≤480), панель шире */
@media (max-width: 480px) {
  .main-header .header-search .icon-btn { display: inline-flex !important; }
  .search-pop { width: min(340px, 92vw); }
}

/* ===== Кнопки: единая геометрия (1.3.86) ===== */
/* Цвета-роли сохранены (primary/blue = красный+белый, ghost = контур, dpoc/sb = золото+тёмный текст);
   унифицированы размер/форма/тач-таргет через ТОКЕНЫ ОТСТУПОВ --space-* (есть в :root, ранее не использовались).
   responsive.css грузится последним → чисто перекрывает разнобой defs в shared.css/page-CSS.
   Полную миграцию остальных padding'ов на токены делаем постепенно — кнопки здесь как эталон. */
.btn-primary, .btn-blue, .btn-ghost, .dpoc-btn, .sb-cta {
  padding: var(--space-3) var(--space-5);   /* 12px 24px — было вразнобой 10/18 · 12/16 · 14/22 */
  min-height: 40px;                          /* тач-таргет, как у .icon-btn (1.3.83) */
  border-radius: var(--radius-sm);           /* 6px — было 4px вперемешку */
  font-size: 14px;
  line-height: 1.2;
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  box-sizing: border-box;
}
.hero-actions .btn-primary, .hero-actions .btn-ghost { padding: var(--space-4) var(--space-5); font-size: 15px; }

/* подсказка-переход к каталогу программ при поиске по КОДУ направления */
.search-code-callout { display: inline-flex; align-items: center; gap: 8px; margin: 4px 0 18px;
  padding: 12px 18px; background: var(--c-gold-soft); border: 1px solid var(--c-gold);
  border-radius: 8px; color: #1a1a1a; font-size: 15px; text-decoration: none; }
.search-code-callout:hover { background: #efe6cf; }
.search-code-callout b { font-weight: 700; }
