/* ====================================================================
   ОБЩАЯ ШАПКА КАЛЬКУЛЯТОРОВ
   Подключается на всех расчётных программах calc.pro-z.ru
   --------------------------------------------------------------------
   Подключение в HTML калькулятора:
     <link rel="stylesheet" href="/shared/calc-header.css">
     <script defer src="/shared/calc-header.js"
             data-title="Лента на естественном основании"
             data-subtitle="СП 22.13330"></script>
   Скрипт сам вставит <header class="calc-header"> в начало <body>,
   а в <body> добавит класс calc-has-header — чтобы контент сместился.
   ==================================================================== */

:root {
  --ch-bg: #1a2f6b;
  --ch-bg-2: #233a82;
  --ch-fg: #ffffff;
  --ch-muted: #b9c6ed;
  --ch-accent: #ffd24a;
  --ch-height: 56px;
  --ch-shadow: 0 2px 12px rgba(20, 40, 90, .15);
}

body.calc-has-header {
  padding-top: var(--ch-height);
}

/* При любых автопрокрутках (открытие <select>, scrollIntoView, autofocus, anchor-линки)
   браузер оставляет место под нашу фиксированную шапку. */
body.calc-has-header { scroll-padding-top: var(--ch-height); }

/* КРИТИЧНО: Radix UI / Headless UI / shadcn при открытии любого
   попапа (Select, Combobox, Dialog) включают «scroll lock» на body:
   ставят атрибут data-scroll-locked и применяют стили
     overflow: hidden !important;
     position: relative !important;
     padding-top: 0 !important;   <-- убивает наш отступ под фикс-шапку
     padding-left/right: 0 !important;
     margin-right: 15px !important;  <-- компенсация скроллбара, дёргает
     контент на 15px вправо
   Из-за padding-top:0 внутренняя «sticky»-панель калькулятора (с табами
   и кнопками Открыть/Сохранить) теряет якорь top:0 и уезжает наверх
   под нашу синюю шапку — визуально это и выглядит как «исчезла».
   Полностью нейтрализуем эти правила. */
body.calc-has-header[data-scroll-locked] {
  overflow: visible !important;
  position: static !important;
  padding-top: var(--ch-height) !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-right: 0 !important;
  margin-left: 0 !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

/* На всякий случай — pointer-events: none, который popup кладёт на body
   через inline-style (старые версии Radix). */
body.calc-has-header[style*="pointer-events: none"] {
  pointer-events: auto !important;
}

/* aria-hidden="true" на корне React-приложения — Chrome иногда
   применяет визуальное скрытие. Возвращаем видимость, чтобы
   контент калькулятора не «моргал». */
body.calc-has-header > #root[aria-hidden="true"],
body.calc-has-header [data-radix-scroll-area-viewport][aria-hidden="true"] {
  visibility: visible !important;
  opacity: 1 !important;
}

.calc-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--ch-height);
  background: linear-gradient(90deg, var(--ch-bg) 0%, var(--ch-bg-2) 100%);
  color: var(--ch-fg);
  display: flex;
  align-items: center;
  padding: 0 16px;
  gap: 12px;
  z-index: 9999;
  box-shadow: var(--ch-shadow);
  font: 500 15px/1.2 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
}

/* Кнопка «Назад в кабинет» */
.calc-header__back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 36px;
  padding: 0 14px 0 10px;
  border-radius: 18px;
  background: rgba(255, 255, 255, .12);
  color: var(--ch-fg);
  text-decoration: none;
  font-weight: 500;
  font-size: 14px;
  transition: background .15s ease, transform .15s ease;
  white-space: nowrap;
}
.calc-header__back:hover { background: rgba(255, 255, 255, .22); }
.calc-header__back:active { transform: scale(.97); }
.calc-header__back svg { width: 18px; height: 18px; flex: 0 0 18px; }

/* Заголовок калькулятора (название + подзаголовок) */
.calc-header__title {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  line-height: 1.15;
  padding: 0 8px;
}
.calc-header__title b {
  font-weight: 600;
  font-size: 15px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}
.calc-header__title span {
  font-size: 12px;
  color: var(--ch-muted);
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

/* Логотип-метка справа (необязательно, по умолчанию скрыта на мобиле) */
.calc-header__brand {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  font-size: 14px;
  color: var(--ch-fg);
  text-decoration: none;
  opacity: .92;
  white-space: nowrap;
}
.calc-header__brand:hover { opacity: 1; }
.calc-header__brand img {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: #fff;
  display: block;
  flex: 0 0 36px;
  object-fit: cover;
  box-shadow: 0 0 0 2px rgba(255,255,255,.35);
}
.calc-header__brand-text {
  letter-spacing: .5px;
}

/* ----- Мобильная адаптация ----- */
@media (max-width: 640px) {
  :root { --ch-height: 52px; }
  .calc-header { padding: 0 10px; gap: 8px; }
  .calc-header__back { padding: 0 12px 0 8px; height: 34px; font-size: 13px; }
  .calc-header__back .calc-header__back-text { display: none; } /* оставляем только стрелку на узких экранах */
  .calc-header__back svg { margin: 0 2px; }
  .calc-header__title b { font-size: 14px; }
  .calc-header__title span { font-size: 11px; }
  /* На мобильных оставляем только логотип — без подписи. */
  .calc-header__brand-text { display: none; }
  .calc-header__brand img { width: 32px; height: 32px; flex-basis: 32px; }
}

/* Совсем узкие — прячем подзаголовок, чтобы заголовок не обрезался */
@media (max-width: 380px) {
  .calc-header__title span { display: none; }
}
