/* Страница «Формулы» */
/*
  В style.css для калькулятора задано body { height: 100%; overflow: hidden; } —
  иначе здесь страница не прокручивается. Для документа с формулами возвращаем
  обычную прокрутку окна.
*/
body.formulas-page {
  height: auto;
  min-height: 100vh;
  overflow-x: hidden;
  overflow-y: auto;
}

.formulas-page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: #ffffff;
}

.formulas-main {
  flex: 0 1 auto;
  max-width: 920px;
  margin: 0 auto;
  padding: 24px 16px 56px;
  width: 100%;
  box-sizing: border-box;
}

.formulas-main h1 {
  font-size: 1.75rem;
  font-weight: 700;
  margin: 0 0 1.25rem;
  color: var(--text, #111827);
}

.formulas-main h2 {
  font-size: 1.35rem;
  font-weight: 700;
  margin: 2rem 0 0.75rem;
  color: #111827;
}

.formulas-main h3 {
  font-size: 1.1rem;
  font-weight: 600;
  margin: 1.25rem 0 0.5rem;
}

.formulas-prose {
  font-size: 15px;
  line-height: 1.55;
  color: #111827;
}

.formulas-prose p {
  margin: 0 0 0.75rem;
}

.formulas-prose .formula {
  margin: 0.75rem 0;
  padding-left: 1rem;
  font-family: ui-monospace, "Cascadia Mono", Consolas, monospace;
  font-size: 0.95rem;
}

.formulas-prose dl {
  margin: 0.5rem 0 1rem;
}

.formulas-prose dt {
  font-weight: 600;
  margin-top: 0.35rem;
}

.formulas-prose dd {
  margin: 0.15rem 0 0 1rem;
}

.formulas-calc {
  display: grid;
  grid-template-columns: minmax(120px, 200px) minmax(180px, 1fr) minmax(200px, 1fr);
  gap: 20px;
  align-items: start;
  padding: 18px;
  border-radius: 10px;
  margin: 1.25rem 0;
}

.formulas-calc__scheme {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 120px;
}

/* Как в калькуляторе: контейнер для подписей размеров поверх SVG */
.formulas-calc__scheme.scheme-container {
  position: relative;
  min-height: 160px;
}

.formulas-calc__scheme img {
  position: relative;
  z-index: 0;
  max-width: 100%;
  max-height: 160px;
  object-fit: contain;
}

.formulas-page .formulas-scheme-dim,
.formulas-page .scheme-container .profn-dim.formulas-scheme-dim {
  position: absolute;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: -0.02em;
  color: #111827;
  white-space: nowrap;
  pointer-events: none;
  z-index: 1;
  padding: 0;
  min-width: 0;
}

/* Круг: D под окружностью */
.formulas-page .formulas-scheme-dim--krug-d {
  bottom: -7%;
  left: 50%;
  transform: translate(-50%, 0);
  text-align: center;
}

/* Квадрат: a слева у линии размера */
.formulas-page .formulas-scheme-dim--kv-a {
  top: 52%;
  right: 93%;
  left: auto;
  transform: translateY(-50%);
  text-align: right;
  width: max-content;
  max-width: 42%;
}

/* Шестигранник: d слева */
.formulas-page .formulas-scheme-dim--sh-d {
  top: 51%;
  right: 91%;
  left: auto;
  transform: translateY(-50%);
  text-align: right;
  width: max-content;
  max-width: 44%;
}

/* Лента: ширина b (поперёк), длина L (вдоль) */
.formulas-page .formulas-scheme-dim--lenta-a {
  bottom: 50%;
  right: 98%;
  left: auto;
  transform: translateY(-50%);
  text-align: center;
}

.formulas-page .formulas-scheme-dim--lenta-L {
  bottom: 1%;
  left: 63%;
  transform: translate(-50%, -50%);
  text-align: center;
}

/* Лист: длина a внизу, ширина b слева */
.formulas-page .formulas-scheme-dim--list-a {
  bottom: -8%;
  left: 62%;
  transform: translate(-50%, 0);
  text-align: center;
}

.formulas-page .formulas-scheme-dim--list-b {
  top: 38%;
  right: 89%;
  left: auto;
  transform: translateY(-50%);
  text-align: right;
  display: inline-block;
  width: max-content;
  max-width: 38%;
  box-sizing: border-box;
}

/* Круглая труба: D у наружного контура, t у стенки */
.formulas-page .formulas-scheme-dim--truba-D {
  top: 0%;
  left: 96%;
  transform: translate(-50%, 0);
  text-align: center;
}

.formulas-page .formulas-scheme-dim--truba-t {
  bottom: 49%;
  left: 6%;
  transform: translate(-50%, 0);
  text-align: center;
}

@media (max-width: 768px) {
  .formulas-page .formulas-scheme-dim--kv-a {
    right: 76%;
    max-width: 48%;
  }

  .formulas-page .formulas-scheme-dim--sh-d {
    right: 72%;
    max-width: 50%;
  }

  .formulas-page .formulas-scheme-dim--truba-D {
    left: 80%;
    top: 10%;
  }

  .formulas-page .formulas-scheme-dim--truba-t {
    left: 8%;
    bottom: 44%;
  }
}

.formulas-calc__inputs .formulas-field {
  margin-bottom: 12px;
}

.formulas-calc__inputs label {
  display: block;
  font-size: 13px;
  font-weight: 500;
  margin-bottom: 4px;
  color: #374151;
}

.formulas-calc__inputs input,
.formulas-calc__inputs select {
  width: 100%;
  max-width: 220px;
  padding: 8px 10px;
  font-size: 15px;
  border: 1px solid var(--border, #dcdce0);
  border-radius: 6px;
  box-sizing: border-box;
}

.formulas-calc__btn {
  margin-top: 8px;
  padding: 10px 20px;
  font-size: 15px;
  border: none;
  border-radius: 6px;
  background: var(--btn-checked, #4b5563);
  color: #fff;
  cursor: pointer;
}

.formulas-calc__btn:hover {
  background: var(--btn-checked-hover, #374151);
}

.formulas-calc__result {
  font-size: 14px;
  line-height: 1.5;
  color: #111827;
  font-family: ui-monospace, "Cascadia Mono", Consolas, monospace;
  white-space: pre-wrap;
  word-break: break-word;
}

.formulas-calc__result--empty {
  color: #6b7280;
}

.formulas-note {
  font-size: 13px;
  color: #6b7280;
  margin-top: 0.5rem;
}

@media (max-width: 768px) {
  .formulas-calc {
    grid-template-columns: 1fr;
  }

  .formulas-calc__inputs input,
  .formulas-calc__inputs select {
    max-width: none;
  }
}
