/* =========================================================
   РОССИЙСКОЕ ТЕПЛО — компоненты под макет Figma
   Мега-меню, каталог с фильтрами, корзина, посадочные категории,
   карточка товара. Подключается после main.css.
   ========================================================= */

/* ---------- Мега-меню «Каталог» ---------- */
.has-mega{position:static}
.mega-trigger{display:inline-flex;align-items:center;gap:7px;cursor:pointer}
.mega-trigger svg{width:14px;height:14px;transition:.25s}
.has-mega:hover .mega-trigger svg{transform:rotate(180deg)}
/* Мега-меню во всю ширину шапки, контент внутри ограничен контейнером */
.mega{position:absolute;left:0;right:0;top:100%;
  background:#fff;color:var(--text);border-top:1px solid var(--line);
  border-radius:0 0 var(--radius-lg) var(--radius-lg);
  box-shadow:0 40px 90px -30px rgba(20,23,26,.45);padding:24px 0 22px;
  opacity:0;visibility:hidden;transform:translateY(8px);transition:.22s ease;z-index:80;
  max-height:calc(100vh - 126px);overflow-y:auto}
.has-mega:hover .mega,.mega:hover{opacity:1;visibility:visible;transform:translateY(0)}
.mega__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px 44px;align-items:start;
  max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
.mega__col h5{font-family:var(--head);font-weight:900;text-transform:uppercase;font-size:.98rem;white-space:normal;
  letter-spacing:.03em;color:var(--dark);margin:0 0 11px;line-height:1.15}
.mega__col ul + h5,.mega__col h5:not(:first-child){margin-top:20px}
.mega__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:3px}
.mega__col li a{font-size:.85rem;transition:.15s;line-height:1.2;display:block;position:relative;padding:0 0 0 24px;color:var(--text)}
.mega__col li a:hover{color:var(--orange)}
/* верхний пункт — маркер «play в рамке» */
.mega__col li.top a::before{content:"";position:absolute;left:0;top:2px;width:15px;height:15px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Crect x='0.8' y='0.8' width='14.4' height='14.4' rx='3.4' fill='none' stroke='%2314171a' stroke-width='1.3'/%3E%3Cpath d='M6.2 4.7 L10.6 8 L6.2 11.3 Z' fill='%2314171a'/%3E%3C/svg%3E") no-repeat center;background-size:contain}
/* подпункт «·» */
.mega__col li.sub a{color:var(--slate);font-size:.83rem}
.mega__col li.sub a::before{content:"·";position:absolute;left:9px;top:0;color:var(--slate);font-weight:800}
/* подпункт-бренд «—» */
.mega__col li.sub2 a{color:#8a939a;font-size:.83rem}
.mega__col li.sub2 a::before{content:"—";position:absolute;left:4px;top:0;color:var(--gray);font-size:.8rem}
/* «Все товары» */
.mega-all{list-style:none;margin:14px 0 0;padding:0}
.mega-all li a{font-family:var(--head);font-weight:700;text-transform:uppercase;font-size:.82rem;letter-spacing:.03em}
.mega__col--accent{background:var(--gray-bg);border-radius:var(--radius);padding:20px;margin:-8px}
.mega__all{max-width:var(--maxw);margin:20px auto 0;padding-inline:var(--gut)}
.mega__all a{display:inline-flex;align-items:center;gap:8px;font-family:var(--head);font-weight:700;
  color:var(--orange);text-transform:uppercase;font-size:.85rem;letter-spacing:.04em}

/* ---------- Хлебные крошки (светлые) ---------- */
.crumbs--light{color:var(--slate);margin-bottom:26px;font-size:.85rem}
.crumbs--light a{color:var(--slate)}
.crumbs--light a:hover{color:var(--orange)}
.crumbs--light span{color:var(--orange)}

/* ---------- Каталог: вкладки категорий ---------- */
.cat-tabs{background:var(--dark);position:sticky;top:78px;z-index:40}
.cat-tabs .wrap{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none}
.cat-tabs .wrap::-webkit-scrollbar{display:none}
.cat-tab{color:#c8d0d6;font-family:var(--head);font-weight:600;font-size:.95rem;white-space:nowrap;
  padding:18px 22px;transition:.2s;border-bottom:3px solid transparent}
.cat-tab:hover{color:#fff}
.cat-tab.is-active{color:#fff;border-bottom-color:var(--orange)}

/* ---------- Каталог: раскладка сайдбар + сетка ---------- */
.catalog{display:grid;grid-template-columns:280px 1fr;gap:36px;align-items:start}
.catalog__bar{display:flex;gap:14px;margin-bottom:26px;align-items:center}
.search-box{flex:1;display:flex;align-items:center;background:var(--gray-bg);border:1.5px solid var(--line);
  border-radius:999px;padding:4px 6px 4px 22px;transition:.2s}
.search-box:focus-within{border-color:var(--orange);background:#fff}
.search-box input{flex:1;border:0;background:transparent;font-family:var(--body);font-size:1rem;padding:12px 0;outline:none}
.search-box button{width:46px;height:46px;border-radius:50%;border:0;background:var(--dark);color:#fff;cursor:pointer;
  display:grid;place-items:center;flex-shrink:0}
.search-box button svg{width:20px;height:20px;stroke:#fff}
.sort-select{border:1.5px solid var(--line);border-radius:999px;padding:13px 18px;font-family:var(--head);
  font-weight:600;font-size:.9rem;background:#fff;cursor:pointer;color:var(--slate)}

/* Панель фильтров */
.filters{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;position:sticky;top:150px}
.filters__head{background:var(--dark);color:#fff;padding:18px 20px;font-family:var(--head);font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;font-size:.95rem;display:flex;align-items:center;gap:10px}
.filters__head svg{width:18px;height:18px;stroke:var(--orange)}
.filter-group{border-bottom:1px solid var(--line)}
.filter-group__top{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:16px 20px;
  display:flex;justify-content:space-between;align-items:center;font-family:var(--head);font-weight:600;font-size:.95rem;color:var(--dark)}
.filter-group__top svg{width:14px;height:14px;transition:.2s;flex-shrink:0}
.filter-group.is-open .filter-group__top svg{transform:rotate(180deg)}
.filter-group__body{padding:0 20px 16px;display:none;max-height:230px;overflow:auto}
.filter-group.is-open .filter-group__body{display:block}
.filter-opt{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:.9rem;color:var(--slate);cursor:pointer}
.filter-opt input{width:17px;height:17px;accent-color:var(--orange);flex-shrink:0}
.filters__foot{padding:16px 20px;display:grid;gap:10px}

/* Карточка товара с корзиной */
.products--shop{grid-template-columns:repeat(3,1fr)}
.product-card .product-card__desc{font-size:.86rem;color:var(--slate);line-height:1.45;margin:0}
.product-card__price-row{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-top:2px}
.product-card__buy{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:auto;padding-top:14px}
.product-card__buy .btn{width:100%;padding:12px 10px;font-size:.82rem;justify-content:center;text-align:center}
.btn--cart{background:var(--orange);color:#fff;border:0}
.btn--cart:hover{background:#e63f00}
.btn--cart svg{width:17px;height:17px;stroke:#fff;fill:none}
.btn--outline{background:#fff;color:var(--dark);border:1.5px solid var(--line)}
.btn--outline:hover{border-color:var(--dark)}

/* ---------- Посадочная категория: подвиды ---------- */
.subtypes{grid-template-columns:repeat(3,1fr);gap:26px}
.subtype{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;
  background:#fff;transition:.25s}
.subtype:hover{box-shadow:var(--shadow);transform:translateY(-4px);border-color:transparent}
.subtype__img{aspect-ratio:4/3;background:var(--gray-bg);overflow:hidden}
.subtype__img img{width:100%;height:100%;object-fit:cover;transition:.5s}
.subtype:hover .subtype__img img{transform:scale(1.05)}
.subtype__body{padding:22px;display:flex;flex-direction:column;gap:10px;flex:1}
.subtype__body h3{font-size:1.12rem}
.subtype__body p{font-size:.9rem;color:var(--slate);margin:0;flex:1}
.subtype__body .btn{margin-top:6px;align-self:flex-start;padding:11px 20px;font-size:.84rem}

/* ---------- Карточка товара (single) под Figma ---------- */
.pdp{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:clamp(28px,4vw,56px);align-items:start}
.pdp__top{display:grid;grid-template-columns:minmax(280px,440px) 1fr;gap:36px;align-items:start}
.pdp__price-block{margin-top:26px;padding-top:22px;border-top:1px solid var(--line)}
.pdp__price{font-family:var(--head);font-weight:800;font-size:2.1rem;line-height:1}
.pdp__price small{font-family:var(--body);font-weight:400;font-size:.9rem;color:var(--muted);display:block;margin-top:6px}
.pdp__discount{display:inline-flex;align-items:center;gap:7px;color:var(--orange);font-family:var(--head);
  font-weight:600;font-size:.95rem;margin:14px 0;cursor:pointer}
.pdp__discount svg{width:18px;height:18px;stroke:var(--orange)}
.pdp__buy{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}
.pdp__buy .btn--cart{padding:16px 32px;font-size:1rem}
.specs--full th{width:62%}

/* Боковая форма-консультация */
.consult{background:var(--dark);color:#fff;border-radius:var(--radius-lg);padding:30px;position:sticky;top:150px}
.consult h3{color:#fff;font-size:1.3rem;line-height:1.2;margin-bottom:12px}
.consult p{color:#b9c2c8;font-size:.92rem;margin-bottom:20px}
.consult .field input{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.16);color:#fff}
.consult .field input::placeholder{color:#8b959c}
.consult .field input:focus{border-color:var(--orange);background:rgba(255,255,255,.12)}
.consult .form-note{color:#8b959c}
.consult-grid{display:grid;gap:12px}

/* ---------- Блок «Реализованные проекты» (кейсы) ---------- */
.cases{grid-template-columns:repeat(3,1fr);gap:26px}
.case{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;display:flex;flex-direction:column}
.case__img{aspect-ratio:4/3;background:var(--gray-bg);overflow:hidden}
.case__img img{width:100%;height:100%;object-fit:cover}
.case__body{padding:22px;display:flex;flex-direction:column;gap:12px}
.case__body h3{font-size:1.15rem}
.case__meta{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;font-size:.84rem}
.case__meta div{display:flex;flex-direction:column}
.case__meta b{color:var(--slate);font-weight:500;font-size:.76rem}
.case__meta span{font-family:var(--head);font-weight:600;color:var(--dark)}
.case__body p{font-size:.88rem;color:var(--slate);margin:0}

/* ---------- Логотипы-аналоги (импортозамещение) ---------- */
.analogs{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}
.analog-chip{border:1.5px solid var(--line);border-radius:999px;padding:10px 20px;font-family:var(--head);
  font-weight:600;font-size:.9rem;color:var(--slate)}

/* ---------- Адаптив ---------- */
@media(max-width:1024px){
  .mega__grid{grid-template-columns:repeat(3,1fr)}
  .catalog{grid-template-columns:1fr}
  .filters{position:static}
  .pdp{grid-template-columns:1fr}
  .consult{position:static}
  .products--shop{grid-template-columns:repeat(2,1fr)}
  .subtypes,.cases{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .pdp__top{grid-template-columns:1fr}
  .products--shop,.subtypes,.cases{grid-template-columns:1fr}
  .mega{display:none} /* на мобильных каталог раскрывается в мобильном меню */
  .case__meta{grid-template-columns:1fr 1fr}
  .cat-tabs{top:0}
}

/* Мобильное меню: раскрывающийся каталог */
.m-cat{margin-top:clamp(2px,.6vh,8px)}
.m-cat summary{font-family:var(--head);font-weight:700;font-size:clamp(.95rem,2.3vh,1.5rem);text-transform:uppercase;
  padding:clamp(6px,1.2vh,14px) 0;border-bottom:1px solid rgba(255,255,255,.1);cursor:pointer;list-style:none;display:flex;
  justify-content:space-between;align-items:center}
.m-cat summary::-webkit-details-marker{display:none}
.m-cat[open] summary{color:var(--orange)}
.m-cat__list{padding:10px 0 4px}
.m-cat__list h5{color:#8b959c;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;margin:14px 0 6px;font-family:var(--head)}
.m-cat__list a{display:block;color:#dfe5e9;font-size:1rem;padding:7px 0;border:0}

/* Верх каталога: отступ как у баннеров разделов (.page-hero) */
.section--top{padding-top:24px}

/* ===== Страницы категорий: блоки «как в каталоге» ===== */
.cat-panel{background:#1e1e1e;border-radius:var(--radius);padding:clamp(22px,3vw,38px);color:#fff}
.cat-panel+.cat-panel{margin-top:22px}
.cat-cols2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,3vw,40px)}
.cat-cols2 p{color:rgba(255,255,255,.92);line-height:1.6;margin:0 0 14px}
.cat-cols2 p:last-child{margin-bottom:0}
@media(max-width:860px){.cat-cols2{grid-template-columns:1fr}}
/* шкала температур — капсула с каталожным градиентом */
.temp-scale{margin-top:clamp(20px,3vw,30px)}
.temp-scale__labels{display:flex;justify-content:space-between;font-family:var(--head);font-weight:600;font-size:clamp(1rem,1.6vw,1.25rem);margin-bottom:10px}
.temp-scale__bar{height:20px;border-radius:999px;
  background:linear-gradient(90deg,#4792d5 0%,#82d5e6 12%,#bbe5b7 25%,#edf394 37%,#fadd3e 50%,#f27a43 62%,#ef4a38 75%,#c6272c 87%,#652629 100%)}
/* карточки особенностей */
.spec-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:1100px){.spec-cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.spec-cards{grid-template-columns:1fr}}
.spec-card{background:#1e1e1e;border-radius:var(--radius);padding:22px;color:#fff}
.spec-card h3{font-family:var(--head);font-size:.82rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.82);margin:0 0 12px}
.spec-card ul{list-style:none;margin:0;padding:0}
.spec-card li{color:rgba(255,255,255,.94);line-height:1.5;padding:4px 0 4px 16px;position:relative}
.spec-card li::before{content:"";position:absolute;left:0;top:.85em;width:7px;height:7px;border-radius:2px;background:var(--orange);transform:rotate(45deg)}
/* преимущества */
.cat-adv{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,3vw,40px)}
@media(max-width:860px){.cat-adv{grid-template-columns:1fr}}
.cat-adv h3{color:#fff;font-family:var(--head);font-size:1.1rem;margin:0 0 12px}
.cat-adv p,.cat-adv li{color:rgba(255,255,255,.85);line-height:1.6}
.cat-adv ul{list-style:none;margin:0;padding:0}
.cat-adv li{padding:6px 0 6px 18px;position:relative}
.cat-adv li::before{content:"";position:absolute;left:0;top:1em;width:8px;height:8px;border-radius:2px;background:var(--orange);transform:rotate(45deg)}
/* таблица характеристик */
.spec-table-wrap{overflow-x:auto;border-radius:var(--radius);background:#1e1e1e;padding:6px}
.spec-table{width:100%;border-collapse:collapse;color:#fff;font-size:.88rem}
.spec-table th{font-family:var(--head);font-weight:600;text-align:left;color:rgba(255,255,255,.8);
  padding:10px;border-bottom:1px solid rgba(255,255,255,.18);white-space:normal;vertical-align:bottom}
.spec-table td{padding:9px 10px;border-bottom:1px solid rgba(255,255,255,.08);white-space:nowrap}
/* мобила: горизонтальный скролл с закреплённым первым столбцом */
@media(max-width:900px){
  .spec-table-wrap{padding:6px 6px 6px 0}
  .spec-table{min-width:640px}
  .spec-table th:first-child,.spec-table td:first-child{position:sticky;left:0;z-index:2;background:#1e1e1e;
    box-shadow:6px 0 10px -4px rgba(0,0,0,.55)}
  .spec-table tbody tr:hover{background:none}
}
.spec-table tr:last-child td{border-bottom:0}
.spec-table tbody tr:hover{background:rgba(255,255,255,.05)}
.spec-table td:first-child{font-family:var(--head);font-weight:600}
/* размерная схема из каталога */
.scheme-panel{background:#1e1e1e;border-radius:var(--radius);padding:clamp(14px,2vw,26px);
  display:grid;place-items:center;margin-bottom:18px}
.scheme-panel img{max-width:780px;width:100%;height:auto}
.scheme-panel figcaption{color:rgba(255,255,255,.78);font-size:.85rem;margin-top:8px;text-align:center}
