/* Roboto Condensed — самохостинг вместо Google Fonts.
   Вариативный шрифт (wght 100–900), один файл на subset покрывает 400 и 700.
   Зачем локально: убираем 2 внешних домена (googleapis/gstatic) и цепочку
   "скачай CSS → узнай URL → скачай шрифт"; preload в base.html стартует шрифт
   сразу. unicode-range оставляет загрузку только нужного subset'а.
   Подключать ПЕРВЫМ среди стилей (до app.css), чтобы @font-face объявился рано. */

@font-face {
  font-family: 'Roboto Condensed';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('../inc/fonts/roboto-condensed/roboto-condensed-cyrillic.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto Condensed';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('../inc/fonts/roboto-condensed/roboto-condensed-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA,
    U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193,
    U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Метрически подогнанный fallback: пока Roboto Condensed грузится, текст
   рисуется этим семейством, занимая РОВНО столько же места → нет "прыжка"
   при подмене. Якорь — Arial: есть и на Windows, и на macOS с идентичными
   метриками (Arial Narrow ненадёжен между ОС). Значения size-adjust/override
   посчитаны из реального файла шрифта (a–z avg + hhea) относительно Arial. */
@font-face {
  font-family: 'Roboto Condensed Fallback';
  src: local('Arial');
  size-adjust: 99.94%;
  ascent-override: 92.82%;
  descent-override: 24.43%;
  line-gap-override: 0%;
}
