/* ============================================================
   inner.css — ре-скин легаси-страниц CMS под новый тёмный шаблон.
   Подключается ПОСЛЕ style.css. Разметка страниц не меняется —
   только визуальный слой. Использует CSS-переменные из style.css.
   ============================================================ */

/* ---------- Контейнер внутренней страницы ---------- */
main.inner {
  position: relative;
  z-index: 1;
  padding: 48px 0 96px;
  min-height: 50vh;
}
main.inner > .container { max-width: 1200px; }

/* Базовая типографика контента */
.inner h1 {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(30px, 4vw, 52px);
  line-height: 1.05;
  letter-spacing: -.03em;
  margin: 0 0 28px;
  color: var(--fg);
}
.inner h2 {
  font-family: var(--display);
  font-weight: 700;
  font-size: clamp(24px, 3vw, 36px);
  letter-spacing: -.02em;
  margin: 32px 0 16px;
  color: var(--fg);
}
.inner h2 span a { color: var(--fg-dim); }
.inner h3 { font-family: var(--display); font-weight: 600; font-size: 20px; margin: 24px 0 12px; color: var(--fg); }
.inner p { margin: 0 0 16px; color: var(--fg); }
.inner a { color: var(--accent-2); text-decoration: none; transition: color .2s; }
.inner a:hover { color: var(--accent); }
.inner img { max-width: 100%; height: auto; }
.inner ul, .inner ol { margin: 0 0 16px 22px; }
.inner li { margin-bottom: 6px; }
.inner hr { border: none; border-top: 1px solid var(--border); margin: 28px 0; }
.inner strong, .inner b { color: var(--fg); }
.inner .copy { color: var(--fg-muted); font-size: 13px; }

/* ---------- Хлебные крошки ---------- */
.bc_wrap { width: 100%; margin-bottom: 24px; }
.bc_wrap td { padding: 0; }
ul.bredcrams {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 12px;
  text-transform: uppercase; letter-spacing: .08em;
  color: var(--fg-muted);
}
ul.bredcrams .bc_item { margin: 0; }
ul.bredcrams .bc_item a { color: var(--fg-dim); }
ul.bredcrams .bc_item a:hover { color: var(--accent); }

/* ---------- Двухколоночная таблица .main → адаптивный стэк ---------- */
table.main { display: block; width: 100% !important; border-collapse: collapse; }
table.main > tbody { display: block; width: 100%; }
table.main > tbody > tr { display: flex; flex-wrap: wrap; gap: 28px; width: 100%; }
table.main > tbody > tr > td {
  display: block;
  width: 100% !important;
  vertical-align: top;
  max-width: 100%;
  overflow-x: auto;
}
/* основная колонка против узкой правой колонки (250/235px) */
table.main > tbody > tr > td[width="660px"],
table.main > tbody > tr > td[width="750px"] { flex: 1 1 520px; }
table.main > tbody > tr > td[width="250px"],
table.main > tbody > tr > td[width="235px"] { flex: 0 1 280px; }
table.main > tbody > tr > td[colspan="2"] { flex-basis: 100%; }

/* ---------- Правая колонка: кнопки и блок новостей ---------- */
.button_one, .button_two, a.button_one, a.button_two {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 11px 18px; margin: 0 8px 10px 0;
  border-radius: 8px; font-family: var(--body); font-weight: 600;
  font-size: 13px; text-decoration: none; cursor: pointer;
  background-image: none !important;
}
.button_one, a.button_one { background: var(--accent); color: #fff !important; }
.button_one:hover { background: #b91c1c; box-shadow: var(--glow); }
.button_two, a.button_two {
  background: transparent; color: var(--fg) !important;
  border: 1px solid var(--border-bright);
}
.button_two:hover { border-color: var(--accent); color: var(--accent) !important; }

.news_block {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 20px;
  margin-top: 16px;
}
.news_block .date, .inner .date {
  font-family: var(--mono); font-size: 11px; letter-spacing: .08em;
  color: var(--accent); text-transform: uppercase; margin: 12px 0 4px;
}
.news_link, .akzii_link, .cat_link {
  font-family: var(--display); font-weight: 600;
  color: var(--fg) !important; display: inline-block; margin-bottom: 6px;
}
.news_link:hover, .akzii_link:hover, .cat_link:hover { color: var(--accent) !important; }

/* ---------- Пагинация ---------- */
.pagenav, .pager, table.pager { margin-top: 24px; }
.pagenav table, table.pager { border-collapse: separate; border-spacing: 6px; }
.pagenav td a, table.pager td a, .page_nav td a {
  display: inline-block; padding: 8px 12px;
  border: 1px solid var(--border); border-radius: 8px;
  font-family: var(--mono); font-size: 13px; color: var(--fg-dim);
}
.pagenav td a:hover, table.pager td a:hover { border-color: var(--accent); color: var(--accent); }
.pagenav td a.active, table.pager td a.active { background: var(--accent); border-color: var(--accent); color: #fff; }

/* ---------- Справочник ГОСТ ---------- */
.sprav { line-height: 1.9; color: var(--fg-dim); }
.sprav .gost {
  font-family: var(--display); font-weight: 700; font-size: 24px;
  color: var(--fg); margin-bottom: 16px;
}
.sprav .murena { color: var(--fg-muted); }

/* ---------- Каталог (price.tpl): сетка категорий ---------- */
.cat_image {
  display: inline-flex; flex-direction: column; align-items: center;
  gap: 10px; width: 200px; vertical-align: top;
  margin: 10px; padding: 20px 16px;
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: 14px; transition: all .25s; text-align: center;
}
.cat_image:hover { border-color: var(--accent); transform: translateY(-3px); background: var(--bg-3); }
.cat_image img { max-width: 150px; max-height: 110px; object-fit: contain; }

/* ---------- Каталог-категория (price_cat.tpl) ---------- */
ul#menu { list-style: none; margin: 0; padding: 0; }
ul#menu li { margin: 0 0 6px; }
ul#menu li a, ul#menu li span {
  display: block; padding: 10px 14px; border-radius: 8px;
  background: var(--bg-2); border: 1px solid var(--border);
  color: var(--fg-dim) !important; font-size: 14px; text-decoration: none;
}
ul#menu li a:hover { border-color: var(--border-bright); color: var(--fg) !important; }
ul#menu .avtive_m { background: var(--accent); border-color: var(--accent); border-radius: 8px; }
ul#menu .avtive_m .padd_left { color: #fff; display: block; padding: 10px 14px; }

.tocart_order { margin-bottom: 16px; }
.tocart_order a {
  display: inline-flex; align-items: center; padding: 11px 20px;
  background: var(--accent); color: #fff !important; border-radius: 8px;
  font-weight: 600; font-size: 14px;
}
.tocart_order a:hover { background: #b91c1c; box-shadow: var(--glow); }

/* Таблица товаров внутри категории */
.padd_left_t table { width: 100%; border-collapse: collapse; font-size: 14px; }
.top_style td, tr.top_style td {
  background: var(--bg-3); color: var(--fg);
  font-family: var(--mono); font-size: 11px; text-transform: uppercase;
  letter-spacing: .05em; padding: 12px 8px; border-bottom: 1px solid var(--border);
}
.padd_left_t td.pad_bot, td.pad_bot {
  padding: 12px 8px; border-bottom: 1px solid var(--border); color: var(--fg-dim);
}
.padd_left_t tr:hover td.pad_bot { background: rgba(255,255,255,.02); }
.padd_left_t input[type="text"] {
  width: 56px; padding: 8px; text-align: center;
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 6px; color: var(--fg);
}
.product_tocart a.button_z, a.button_z {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; background: var(--accent); border-radius: 8px;
}
a.button_z:hover { background: #b91c1c; }
a.button_z img { filter: brightness(0) invert(1); }

/* ---------- Карточка товара / поиск (item-list) ---------- */
.title2, h2.title2, .inner .title2 {
  font-family: var(--display); font-weight: 800;
  font-size: clamp(26px, 3.4vw, 42px); margin: 8px 0 24px; color: var(--fg);
}
h2.title, .inner .title { font-family: var(--display); font-weight: 700; font-size: 26px; margin: 28px 0 14px; }
.history { position: static !important; width: auto !important; left: auto !important; top: auto !important; margin-bottom: 18px; }
.history-bg, .history-bg2 { background: none; }

.item-list {
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: 14px; padding: 22px; margin-bottom: 18px;
}
.item-list table { width: 100%; }
.item-list-img { display: flex; align-items: center; justify-content: center; }
.item-list-img img { border-radius: 8px; background: #fff; padding: 6px; }
.item-list-link, a.item-list-link {
  font-family: var(--display); font-weight: 600; font-size: 18px; color: var(--fg) !important;
}
.item-list-link:hover { color: var(--accent) !important; }
.item-list-price {
  font-family: var(--display); font-weight: 800; font-size: 26px;
  color: var(--fg); line-height: 1.1;
}
.item-list-price .unit, .unit { font-family: var(--body); font-weight: 400; font-size: 12px; color: var(--fg-muted); }
/* символ рубля вместо иконочного шрифта */
.rybl { font-size: 0 !important; color: var(--accent); }
.rybl::after { content: '₽'; font-size: 18px; }
.item-list-quantity { margin: 12px 0; color: var(--fg-dim); font-size: 14px; }
.item-list-quantity input, .item-list input[type="text"] {
  width: 64px; padding: 8px; margin-left: 8px; text-align: center;
  background: var(--bg); border: 1px solid var(--border); border-radius: 6px; color: var(--fg);
}
.item-list-tocart a, a.tocart {
  display: inline-flex; align-items: center; padding: 11px 20px; margin-top: 8px;
  background: var(--accent); color: #fff !important; border-radius: 8px; font-weight: 600; font-size: 14px;
}
.item-list-tocart a:hover, a.tocart:hover { background: #b91c1c; box-shadow: var(--glow); }
.item-one-preview { list-style: none; display: flex; flex-wrap: wrap; gap: 8px; margin: 0; padding: 0; }
.item-one-preview li { margin: 0; }
.item-one-preview img { border-radius: 6px; border: 1px solid var(--border); cursor: pointer; background:#fff; }
.item-one-link { display: inline-block; margin: 6px 14px 0 0; color: var(--accent-2) !important; font-size: 13px; }
.opisanie, .opisanie-full { color: var(--fg-dim); line-height: 1.7; }
.har-list { list-style: none; margin: 0; padding: 0; }
.har-list li { padding: 10px 0; border-top: 1px solid var(--border); color: var(--fg-dim); }
.show-opisanie { color: var(--accent-2) !important; }

/* поиск */
.item-list .img-col img { border-radius: 8px; background:#fff; padding:6px; }
.price-col { text-align: right; }
.link1, .link2, .link3, .link-extra { color: var(--accent-2) !important; font-size: 13px; margin-right: 12px; }

/* разделительная линия (.line) */
.line { height: 1px; background: var(--border); margin: 16px 0; }
.line i, .line em, .line span { display: none; }

/* ---------- Галерея ---------- */
ul.gallery-list { list-style: none; display: grid; grid-template-columns: repeat(auto-fill, minmax(200px,1fr)); gap: 16px; margin: 0; padding: 0; }
.gallery-list-box { background: var(--bg-2); border: 1px solid var(--border); border-radius: 14px; padding: 16px; }
.gallery-list-box ul { list-style: none; display: flex; flex-wrap: wrap; gap: 8px; margin: 10px 0 0; padding: 0; }
.gallery-list-box img { border-radius: 6px; }

/* ---------- Формы (обратная связь, корзина) ---------- */
.inner input[type="text"],
.inner input[type="email"],
.inner input[type="tel"],
.inner input[type="password"],
.inner input[type="number"],
.inner textarea,
.inner select {
  background: var(--bg-2); border: 1px solid var(--border-bright);
  border-radius: 8px; color: var(--fg); padding: 12px 14px;
  font-family: var(--body); font-size: 15px; max-width: 100%;
}
.inner input:focus, .inner textarea:focus, .inner select:focus { outline: none; border-color: var(--accent); }
.inner input[type="submit"], .inner button[type="submit"] {
  display: inline-flex; align-items: center; padding: 13px 24px;
  background: var(--accent); color: #fff; border: none; border-radius: 8px;
  font-family: var(--body); font-weight: 600; font-size: 15px; cursor: pointer;
}
.inner input[type="submit"]:hover, .inner button[type="submit"]:hover { background: #b91c1c; box-shadow: var(--glow); }

/* общий вид прочих таблиц контента (корзина, счёт) */
.inner table:not(.main):not(.bc_wrap):not(.pager) { max-width: 100%; }
.inner table:not(.main):not(.bc_wrap) td { color: var(--fg-dim); }

/* SEO-текст на главной */
.seo-text { padding: 64px 0; border-top: 1px solid var(--border); background: var(--bg-2); }
.seo-text .container { max-width: 1000px; }
.seo-text, .seo-text p, .seo-text td { color: var(--fg-dim); line-height: 1.75; }

@media (max-width: 720px) {
  main.inner { padding: 28px 0 64px; }
  table.main > tbody > tr { gap: 18px; }
  .cat_image { width: 100%; }
}

/* мобильный hero: предотвращаем обрезание длинного заголовка */
@media (max-width: 720px) {
  .hero h1 { font-size: 34px; word-break: break-word; }
  .hero p.lead { font-size: 16px; }
  .ticker span { font-size: 24px; }
}

/* ===== Страница контактов ===== */
.contacts-page { }
.contacts-warn {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 18px 22px; margin-bottom: 36px;
  background: rgba(220,38,38,.08);
  border: 1px solid rgba(220,38,38,.35);
  border-radius: 12px;
  color: var(--fg); font-size: 14px; line-height: 1.55;
}
.contacts-warn strong { color: var(--accent); }
.contacts-page .contact-card .contact-main { margin-bottom: 6px; }

.team-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.team-card {
  padding: 26px;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 14px;
  transition: all .25s;
}
.team-card:hover { border-color: var(--accent); background: var(--bg-3); transform: translateY(-3px); }
.team-role {
  font-family: var(--mono); font-size: 11px; text-transform: uppercase;
  letter-spacing: .15em; color: var(--accent); margin-bottom: 12px;
}
.team-name {
  font-family: var(--display); font-weight: 600; font-size: 18px;
  color: var(--fg); line-height: 1.2; margin-bottom: 14px;
}
.team-phone {
  display: block; font-family: var(--display); font-weight: 700;
  font-size: 22px; color: var(--fg) !important; letter-spacing: -.01em;
}
.team-phone:hover { color: var(--accent) !important; }
.team-email { display: inline-block; margin-top: 8px; color: var(--accent-2) !important; font-size: 14px; }

.contacts-map { border: 1px solid var(--border-bright); border-radius: 16px; overflow: hidden; }
.contacts-map iframe { display: block; width: 100%; height: 460px; border: 0; }

@media (max-width: 1100px) { .team-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 720px)  { .team-grid { grid-template-columns: 1fr; } .contacts-map iframe { height: 340px; } }
