/* Базовые стили — как в Qt приложении */
:root {
  --bg: #ffffff;
  --text: #111827;
  --header-blue: #0012cd;
  --btn-bg: #E5E7EB;
  --btn-hover: #D1D5DB;
  --btn-pressed: #9CA3AF;
  --btn-checked: #4B5563;
  --btn-checked-hover: #374151;
  --border: #dcdce0;
  --card-bg: #ffffff;
  --history-bg: #ffffff;
  /* Мобильный drawer: отступ сверху до области main-body (шапка сайта + полоса режимов), px */
  --drawer-top-offset: 112px;
}

* {
  box-sizing: border-box;
}

html {
  height: 100%;
}

body {
  margin: 0;
  height: 100%;
  min-height: 100vh;
  overflow: hidden;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  display: flex;
  flex-direction: column;
}

/* Убираем мерцание при восстановлении состояния из URL */
body.app-booting .calc-page {
  display: none !important;
}

body.app-booting .calc-page.active {
  display: none !important;
}

/* Шапка сайта — как на макете КосмосМет */
.site-header {
  position: relative;
  z-index: 1001;
  flex-shrink: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  padding: 10px 40px;
  background: #ffffff;
  border-bottom: 1px solid var(--border);
}

.site-logo {
  font-size: 40px;
  font-weight: 700;
  color: var(--header-blue);
  text-decoration: none;
  letter-spacing: -0.02em;
}

.site-logo:hover {
  color: #001870;
}

.site-header-menu {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.site-nav-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  border: none;
  background: transparent;
  border-radius: 8px;
  cursor: pointer;
}

.site-nav-toggle:hover {
  background: #f3f4f6;
}

.site-nav-toggle:focus-visible {
  outline: 2px solid var(--header-blue);
  outline-offset: 2px;
}

.site-nav-toggle__icon {
  display: block;
  width: 28px;
  height: 28px;
}

.site-nav {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 36px;
  justify-content: flex-end;
}

.site-nav__link {
  font-size: 15px;
  font-weight: 400;
  color: #000000;
  text-decoration: none;
  white-space: nowrap;
}

.site-nav__link:hover {
  color: var(--header-blue);
}

.site-nav__link--accent {
  color: var(--header-blue);
}

@media (max-width: 650px) {
  .site-header {
    padding: 10px 16px;
    gap: 12px;
  }

  .site-logo {
    font-size: clamp(1.5rem, 6vw, 2.5rem);
  }

  .site-nav-toggle {
    display: inline-flex;
  }

  .site-nav {
    display: none;
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: min(260px, calc(100vw - 32px));
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0;
    padding: 8px 0;
    background: #ffffff;
    border: 1px solid var(--border);
    border-radius: 10px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.12);
    z-index: 1002;
  }

  .site-header-menu.is-open .site-nav {
    display: flex;
  }

  .site-nav__link {
    white-space: normal;
    padding: 12px 18px;
    border-bottom: 1px solid var(--border);
  }

  .site-nav__link:last-child {
    border-bottom: none;
  }
}

.app {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

/* Левая панель — как в Qt: материал/марка сверху, прокат с категориями.
   Grid + minmax(0,1fr): иначе flex-цепочка часто даёт «бесконечную» высоту и nav не скроллится. */
.sidebar {
  width: auto;
  min-width: 0;
  min-height: 0;
  background: #ffffff;
  border-right: 1px solid var(--border);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  align-content: stretch;
  overflow: hidden;
}

.sidebar-top {
  flex-shrink: 0;
  padding: 10px 10px 12px;
  border-bottom: 1px solid var(--border);
}

.sidebar-select-row {
  display: flex;
  gap: 8px;
  align-items: flex-end;
}

.sidebar-field {
  flex: 1;
  min-width: 0;
  margin-bottom: 0;
}

.sidebar-field label {
  display: block;
  font-size: 11px;
  margin-bottom: 4px;
  font-weight: 500;
  color: #374151;
}

.sidebar-field select {
  width: 100%;
  padding: 8px 6px;
  font-size: 12px;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: #fff;
}

.sidebar-nav {
  grid-row: 2;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding: 6px 10px 12px;
  -webkit-overflow-scrolling: touch;
}

.sidebar-category {
  margin-bottom: 4px;
}

.sidebar-category-title {
  font-size: 13px;
  font-weight: 700;
  font-style: italic;
  text-align: center;
  padding: 14px 6px 8px;
  margin: 0;
  color: var(--text);
}

.sidebar-category:first-child .sidebar-category-title {
  padding-top: 8px;
}

.type-btn {
  display: block;
  width: 100%;
  padding: 10px 8px;
  margin-bottom: 3px;
  border: none;
  background: #e9ebed;
  color: var(--text);
  font-size: 12px;
  text-align: center;
  border-radius: 0;
  cursor: pointer;
}

.type-btn:hover {
  background: #dde0e4;
}

.type-btn.active {
  background: var(--btn-checked);
  color: #fff;
}

.type-btn.active:hover {
  background: var(--btn-checked-hover);
}

/* Скрытые для выбранного материала типы (как в Qt: tip_metala_2) */
.type-btn.type-btn--hidden {
  display: none !important;
}

.sidebar-category.sidebar-category--hidden {
  display: none;
}

/* Центральная область: сетка — сайдбар | (toolbar + main-body) */
.main {
  grid-column: 1;
  min-height: 0;
  display: grid;
  grid-template-columns: 300px 1fr;
  grid-template-rows: auto 1fr;
  overflow: hidden;
  background: #ffffff;
}

.main > .sidebar {
  grid-column: 1;
  grid-row: 1 / -1;
  min-height: 0;
  align-self: stretch;
}

.main > .toolbar {
  grid-column: 2;
  grid-row: 1;
}

/* Колонка main: калькулятор, реклама, текстовый блок; прокрутка при длинном контенте */
.main-body {
  grid-column: 2;
  grid-row: 2;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

/* Одна строка grid — content и history-panel одной высоты */
.main-workspace {
  display: grid;
  grid-template-rows: minmax(0, 1fr);
  align-items: stretch;
  border-bottom: 1px solid var(--border);
  font-size: 16px;
  line-height: 1.45;
}

/* Крупнее шрифт только внутри workspace (не сайдбар) */
.main-workspace .mode-btn {
  font-size: 16px;
}

.main-workspace .calc-title {
  font-size: 22px;
}

.main-workspace .form-group label {
  font-size: 15px;
}

.main-workspace .form-group select,
.main-workspace .form-group input {
  font-size: 16px;
}

.main-workspace .calc-btn {
  font-size: 16px;
}

.main-workspace .result-label {
  font-size: 14px;
}

.main-workspace .result-value {
  font-size: 20px;
}

.main-workspace .dim-overlay {
  font-size: 14px;
}

.main-workspace .history-title {
  font-size: 15px;
}

.main-workspace .history-item {
  font-size: 14px;
}

.main-workspace .history-stats {
  font-size: 14px;
}

.main-workspace .history-item-delete {
  font-size: 18px;
  width: 24px;
  height: 24px;
}

.main-workspace .dim-labels {
  font-size: 14px;
}

.main-workspace .calc-page p {
  font-size: 1em;
}

/* Верхние кнопки режимов */
.toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  background: var(--card-bg);
  border-bottom: 1px solid var(--border);
}

.toolbar-modes {
  display: flex;
  gap: 8px;
  flex: 1;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.toolbar-menu-btn {
  display: none;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  border: none;
  background: var(--btn-bg);
  color: var(--text);
  border-radius: 8px;
  cursor: pointer;
}

.toolbar-menu-btn:hover {
  background: var(--btn-hover);
}

.toolbar-menu-btn__chev {
  display: block;
  transition: transform 0.2s ease;
}

body.sidebar-open .toolbar-menu-btn__chev {
  transform: rotate(180deg);
}

/* Затемнение внутри main-body (на десктопе не используется) */
.sidebar-backdrop {
  display: none;
}

.mode-btn {
  padding: 8px 16px;
  border: none;
  background: var(--btn-bg);
  color: var(--text);
  font-size: 14px;
  border-radius: 6px;
  cursor: pointer;
}

.mode-btn:hover {
  background: var(--btn-hover);
}

.mode-btn.active {
  background: var(--btn-checked);
  color: #fff;
}

.mode-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

/* Контент калькулятора — первая колонка сетки */
.content {
  grid-column: 1;
  grid-row: 1;
  min-width: 0;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 20px;
  background: #ffffff;
}

.calc-page {
  display: none;
  max-width: 900px;
}

.calc-page.active {
  display: block;
}

.calc-title {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 20px;
  text-align: center;
}

.calc-form {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
}

.calc-form-left {
  flex: 0 0 360px;
}

.calc-form-right {
  flex: 1;
  min-width: 260px;
}

.calc-picture {
  width: 100%;
  max-width: 360px;
  height: 340px;
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 36px;
  box-sizing: border-box;
}

.calc-picture img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.scheme-container {
  position: relative;
}

/* Для оверлеев размеров на разных схемах (лист стальной / профнастил) */
.scheme-container .profn-overlays {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}
.scheme-container .profn-dim {
  position: absolute;
  font-size: 12px;
  font-weight: 700;
  color: #111827;
  line-height: 1.25;
  white-space: nowrap;
  letter-spacing: -0.02em;
}
/* Лист стальной: подписи a/b на схеме крупнее */
#list-overlays .profn-dim {
  font-size: 16px;
}

/* Труба стальная: подписи D/t на схеме крупнее */
#truba-overlays .profn-dim {
  font-size: 16px;
}

/* Отводы: подписи размеров на схеме крупнее */
#otvod-overlays .profn-dim {
  font-size: 16px;
}

/* Тройники: подписи размеров на схеме крупнее */
#troynik-overlays .profn-dim {
  font-size: 16px;
}

#flanci-overlays .profn-dim {
  font-size: 16px;
}

/* Болты: d (диаметр резьбы), l (длина) на схеме */
#bolt-overlays .profn-dim {
  font-size: 16px;
}

/* Гайки: S, m на схеме — те же стили, что у болтов */
#gaika-overlays .profn-dim {
  font-size: 16px;
}

/* Шайбы: d1, d2, S на схеме — как у болтов */
#shayba-overlays .profn-dim {
  font-size: 16px;
}

/* Гвозди: d, l на схеме — как у болтов */
#gvozd-overlays .profn-dim {
  font-size: 16px;
}

/* Винты: d, l на схеме — как у болтов */
#samorez-overlays .profn-dim {
  font-size: 16px;
}

#vint-overlays .profn-dim {
  font-size: 16px;
}

.dim-overlay {
  position: absolute;
  font-size: 12px;
  font-weight: 600;
  color: #111827;
  padding: 2px 6px;
  min-width: 24px;
  text-align: center;
  pointer-events: none;
} 

/* Равнополочный: S сверху, A слева и справа снизу */
.scheme-container .dim-s { top: 6%; left: 34%; transform: translateX(-50%); }
.scheme-container .dim-a { top: 47%; left: 11%; }
.scheme-container .dim-b { top: 88%; right: 40%; left: auto; }

/* Неравнополочный — те же классы, B показываем вместо второго A */
.scheme-container.unequal .dim-s {
  top: 8%;
  left: 37%;
  right: auto;
  transform: translate(-50%, -50%);
}
.scheme-container.unequal .dim-a { top: 48%; left: 17%; }
.scheme-container.unequal .dim-b {
  top: auto;
  bottom: 5%;
  left: 56%;
  right: auto;
  transform: translateX(-50%);
}

/* Двутавр: h, b, s, t */
.scheme-container .dim-h { top: 43%; left: 13%; }
.scheme-container .dim-bf { bottom: 6%; left: 55%; transform: translateX(-50%); }
.scheme-container .dim-sw { top: 40%; left: 47%; transform: translate(-50%, -50%); }
.scheme-container .dim-tf { top: 67%; right: 19%; left: auto; }

/* Швеллер: h, b, s, t (примерные позиции для shv_ukl/shv_par) */
.scheme-container .dim-shv-h { top: 43%; left: 24%; }
.scheme-container .dim-shv-b { bottom: 6%; left: 57%; transform: translateX(-50%); }
.scheme-container .dim-shv-s { top: 47%; left: 38%; transform: translate(-50%, -50%); }
.scheme-container .dim-shv-t { top: 64%; right: 33%; left: auto; }

/* Рельс: H, b (головка), B_big (подошва) — стартовые позиции */
.scheme-container .dim-rels-h { top: 47%; left: 14%; }
.scheme-container .dim-rels-b { top: 6%; left: 55%; transform: translateX(-50%); }
.scheme-container .dim-rels-bbig { bottom: 6%; left: 56%; transform: translateX(-50%); }

/* Арматура: выводим диаметр на схеме */
.scheme-container .dim-arm-d { top: 48%; left: 9%; transform: translateX(-50%); }

/* Круг: диаметр на схеме */
.scheme-container .dim-krug-d { bottom: 3%; left: 51%; transform: translate(-50%, -50%); }
/* Правый край у центра схемы: при наборе цифр блок растёт влево */
.scheme-container .dim-shestigran-d {
  bottom: 42%;
  right: 85%;
  left: auto;
  transform: translateY(-50%);
  text-align: right;
  display: inline-block;
  width: max-content;
  max-width: 100%;
  box-sizing: border-box;
}
/* Правый край у линии размера закреплён: при наборе цифр блок растёт влево (не left + width!) */
.scheme-container .dim-kvadrat-a {
  top: 47%;
  right: 86%;
  left: auto;
  text-align: right;
  display: inline-block;
  width: max-content;
  max-width: 100%;
  box-sizing: border-box;
}

/* Лента: a и L на схеме; t только в форме */
.scheme-container .dim-lenta-a {
  bottom: 51%;
  right: 86%;
  text-align: center;
  transform: translateY(-50%);
}
.scheme-container .dim-lenta-L {
  bottom: 19%;
  left: 60%;
  transform: translate(-50%, -50%);
  text-align: center;
}

/* Профнастил: SVG + подписи размеров поверх схемы */
.scheme-container--profn {
  min-height: 280px;
}
.scheme-container--profn img {
  display: block;
  max-height: 260px;
  margin: 0 auto;
  position: relative;
  z-index: 0;
}
.scheme-container--profn .profn-overlays {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}
.scheme-container--profn .profn-dim {
  position: absolute;
  font-size: 12px;
  font-weight: 700;
  color: #111827;
  line-height: 1.25;
  white-space: nowrap;
  letter-spacing: -0.02em;
}
.form-hint {
  font-size: 12px;
  color: #6b7280;
  margin: 0 0 10px 0;
  line-height: 1.4;
}

.form-group {
  margin-bottom: 16px;
}

/* Тройники: D/D1 и T/T1 по 2 в ряд (как в программе) */
.troynik-dims-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 16px;
}
.troynik-dims-grid .form-group {
  margin-bottom: 0;
}

.form-group label {
  display: block;
  font-size: 13px;
  margin-bottom: 6px;
  font-weight: 500;
}

.form-group select,
.form-group input {
  width: 100%;
  padding: 10px 12px;
  font-size: 14px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: #fff;
}

.calc-btn {
  padding: 10px 24px;
  background: var(--btn-checked);
  color: #fff;
  border: none;
  font-size: 14px;
  border-radius: 6px;
  cursor: pointer;
  margin-top: 8px;
}

.calc-btn:hover {
  background: var(--btn-checked-hover);
}

.result-box {
  margin-top: 16px;
  padding: 12px 16px;
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 6px;
}

.result-label {
  font-size: 12px;
  color: #6B7280;
  margin-bottom: 4px;
}

.result-value {
  font-size: 16px;
  font-weight: 500;
  color: var(--text);
}

/* Нули до первого успешного расчёта */
.result-value--empty {
  color: #9ca3af;
}

/* Панель истории — вторая колонка сетки, та же высота строки, что и расчёт */
.history-panel {
  grid-column: 2;
  grid-row: 1;
  min-width: 0;
  min-height: 0;
  box-sizing: border-box;
  background: #ffffff;
  border-left: 1px solid var(--border);
  padding: 16px 12px 20px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

@media (max-width: 1100px) {
  .main-workspace {
    display: block;
  }

  .content {
    grid-column: unset;
    grid-row: unset;
  }

  .history-panel {
    grid-column: unset;
    grid-row: unset;
    border-left: none;
    border-top: 1px solid var(--border);
    /* Без высоты строки grid flex:1 у списка даёт 0px — задаём явную область прокрутки */
    overflow: visible;
  }

  .history-panel .history-list {
    flex: 0 1 auto;
    min-height: 160px;
    max-height: min(45vh, 420px);
    overflow-y: auto;
  }

  .main-article-aside {
    display: none;
  }
}

/* Под main-workspace: место под рекламу (полная ширина колонки main) */
.main-footer {
  flex-shrink: 0;
  height: 250px;
  margin: 50px;
  background: #e5e7eb;
}

/* Статья + рекламная колонка 250px справа на всю высоту блока */
.main-article-with-aside {
  display: flex;
  align-items: stretch;
  width: 100%;
  border-top: 1px solid var(--border);
}

.main-article-aside {
  flex: 0 0 250px;
  width: 250px;
  min-width: 250px;
  box-sizing: border-box;
  background: #e5e7eb;
  border-left: 1px solid var(--border);
  margin: 50px;
}

.main-article {
  flex: 1;
  min-width: 0;
  margin: 0;
  padding: 50px;
  font-size: 15px;
}

.main-article__title {
  margin: 0 0 18px;
  font-size: 1.35rem;
  font-weight: 700;
  color: #000000;
}

.main-article__subtitle {
  margin: 28px 0 14px;
  font-size: 1.05rem;
  font-weight: 700;
  color: #000000;
}

.main-article__lead {
  margin: 20px 0 8px;
  font-weight: 600;
}

.main-article p {
  margin: 0 0 14px;
}

.main-article__list {
  margin: 0 0 18px;
  padding-left: 22px;
}

.main-article__list li {
  margin-bottom: 6px;
}

.main-article__categories {
  display: grid;
  grid-template-columns: 200px 200px;
  margin: 8px 0 8px;
}

@media (max-width: 800px) and (min-width: 651px) {
  .site-nav {
    gap: 20px;
  }
}

@media (max-width: 768px) {
  .app {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    overflow: hidden;
  }

  .main {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
    position: relative;
  }

  .main > .sidebar {
    display: none;
  }

  .main-body {
    position: relative;
    grid-column: auto;
    grid-row: auto;
    width: 100%;
    flex: 1;
    min-height: 0;
  }

  .sidebar-backdrop {
    position: fixed;
    top: var(--drawer-top-offset);
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 999;
    display: block;
    background: rgba(0, 0, 0, 0.35);
    opacity: 0;
    pointer-events: none;
    visibility: hidden;
    transition: opacity 0.2s ease, visibility 0s linear 0.2s;
  }

  body.sidebar-open .sidebar-backdrop {
    opacity: 1;
    pointer-events: auto;
    visibility: visible;
    transition: opacity 0.2s ease, visibility 0s linear 0s;
  }

  .main-body > .sidebar {
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    overflow: hidden;
    min-height: 0;
    position: fixed;
    top: var(--drawer-top-offset);
    left: 0;
    bottom: 0;
    width: min(300px, 88vw);
    max-width: 300px;
    z-index: 1000;
    transform: translateX(-100%);
    transition: transform 0.2s ease;
    box-shadow: none;
    border-right: 1px solid var(--border);
  }

  .main-body > .sidebar .sidebar-nav {
    grid-row: 2;
    min-height: 0;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
  }

  body.sidebar-open .main-body > .sidebar {
    transform: translateX(0);
    box-shadow: 4px 0 24px rgba(0, 0, 0, 0.12);
  }

  .main-workspace {
    position: relative;
    z-index: 1;
  }

  .toolbar-menu-btn {
    display: inline-flex;
  }

  .main-article-with-aside {
    flex-direction: column;
  }

  .main-article-aside {
    flex: 0 0 auto;
    width: 100%;
    min-width: 0;
    min-height: 250px;
    border-left: none;
    border-top: 1px solid var(--border);
  }

  .site-logo {
    font-size: 22px;
  }
}

@media (max-width: 640px) {
  .main-article__categories {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}

.main-article__group {
  margin-bottom: 18px;
}

.main-article__group:last-child {
  margin-bottom: 0;
}

.main-article__cat {
  font-weight: 700;
  margin-bottom: 6px;
  color: #000000;
}

.main-article__links {
  margin: 0;
  line-height: 1.5;
}

.main-article__links a {
  display: block;
  color: var(--header-blue);
  text-decoration: none;
}

.main-article__links a:last-child {
  margin-bottom: 0;
}

.main-article__links a:hover {
  text-decoration: underline;
}

.history-title {
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 12px;
  flex-shrink: 0;
}

.history-list {
  list-style: none;
  padding: 0;
  margin: 0;
  flex: 1 1 0;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.history-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px;
  margin-bottom: 6px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 12px;
}

.history-item-text {
  flex: 1 1 auto;
  min-width: 0;
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.history-item-delete {
  width: 22px;
  height: 22px;
  padding: 0;
  border: none;
  background: #c0392b;
  color: #fff;
  font-size: 16px;
  line-height: 1;
  border-radius: 4px;
  cursor: pointer;
  flex-shrink: 0;
  margin-left: 8px;
}

.history-item-delete:hover {
  background: #e74c3c;
}

.history-stats {
  margin-top: 12px;
  padding: 10px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 12px;
  flex-shrink: 0;
}

/* Материал */
.material-row {
  display: flex;
  gap: 12px;
  margin-bottom: 16px;
}

.material-row .form-group {
  flex: 1;
  margin-bottom: 0;
}

.dim-labels {
  display: flex;
  gap: 8px;
  margin: 8px 0;
  font-size: 12px;
  color: #6B7280;
}

.dim-label {
  padding: 4px 8px;
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 4px;
}

@media (max-width: 375px) {
  .calc-form-left {
    flex: 360px;
  }
}