/* ============================================================
   Wint Technology — Industrial Supplies
   Главный лист стилей (build 2)
   ============================================================ */

<style>
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:Arial,sans-serif;background:#f4f5f7;color:#333}
.top-bar{background:#1b3a6b;padding:.35rem 2rem;display:flex;justify-content:space-between;font-size:11px;color:#aec6e8}
nav{background:#fff;border-bottom:1px solid #dde3ed;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 1px 4px rgba(0,0,0,0.06)}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;padding:.6rem 0}
.logo-mark{width:36px;height:36px;background:#1b3a6b;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;border-radius:4px}
.logo-text{font-size:15px;font-weight:600;color:#1b3a6b}
.logo-text small{display:block;font-size:10px;color:#888;font-weight:400;text-transform:uppercase;letter-spacing:.5px}
.nav-menu{display:flex;align-items:center}
.nav-item{position:relative}
.nav-item>a{display:block;padding:.85rem .9rem;font-size:13px;color:#555;text-decoration:none;border-bottom:2px solid transparent;white-space:nowrap;cursor:pointer}
.nav-item>a:hover,.nav-item.active>a{color:#1b3a6b;border-bottom-color:#1b3a6b}
.dropdown{display:none;position:absolute;top:100%;left:-60px;background:#fff;border:1px solid #dde3ed;width:860px;z-index:200;padding:1rem 0;grid-template-columns:1fr 1fr 1fr;box-shadow:0 8px 24px rgba(0,0,0,0.1)}
.nav-item:hover .dropdown{display:grid}
.dropdown a{display:block;padding:.35rem 1.25rem;font-size:12px;color:#555;text-decoration:none}
.dropdown a:hover{color:#1b3a6b;background:#f0f4ff}
.col-head{font-size:10px;font-weight:700;color:#1b3a6b;text-transform:uppercase;letter-spacing:.6px;padding:.6rem 1.25rem .3rem}
.nav-right{display:flex;align-items:center;gap:12px}
.nav-phone{font-size:13px;color:#1b3a6b;font-weight:600}
.btn-kp{background:#1b3a6b;color:#fff;border:none;padding:7px 16px;font-size:12px;cursor:pointer;border-radius:3px;font-family:Arial,sans-serif}
.btn-kp:hover{background:#142d57}
.hero{
  background:
    linear-gradient(to right, rgba(15,23,42,.88) 0%, rgba(15,23,42,.80) 50%, rgba(15,23,42,.56) 80%, rgba(15,23,42,.52) 100%),
    linear-gradient(to bottom, rgba(15,23,42,.42) 0%, rgba(15,23,42,.10) 34%, rgba(15,23,42,0) 58%),
    url('hero-bg.jpg') center right / cover no-repeat,
    #1b3a6b;
  padding:1.5rem 2rem 1.75rem;
  position:relative;
  min-height: 340px;
}
.hero h1{font-size:26px;font-weight:700;color:#fff;line-height:1.25;margin-bottom:.5rem;max-width:780px;text-shadow:0 2px 14px rgba(0,0,0,0.7), 0 0 4px rgba(0,0,0,0.5)}
.hero h1 span{color:#f0b429;text-shadow:0 2px 14px rgba(0,0,0,0.7), 0 0 4px rgba(0,0,0,0.5)}
.hero p{font-size:13px;color:#e8eef7;line-height:1.55;margin-bottom:.7rem;max-width:780px;text-shadow:0 2px 10px rgba(0,0,0,0.75), 0 0 3px rgba(0,0,0,0.5)}
.hero-stats-row{display:flex;gap:1.5rem;margin-bottom:1rem;flex-wrap:wrap;align-items:center}
.h-stat-inline{text-align:center}
.h-stat-inline strong{display:block;font-size:20px;font-weight:700;color:#f0b429;text-shadow:0 2px 10px rgba(0,0,0,0.7), 0 0 3px rgba(0,0,0,0.5)}
.h-stat-inline span{font-size:10px;color:#cfd9eb;text-transform:uppercase;letter-spacing:.5px;text-shadow:0 1px 6px rgba(0,0,0,0.7)}
.sep{width:1px;height:36px;background:rgba(255,255,255,0.2)}
.hero-btns{display:flex;gap:10px}
.btn-primary{background:#f0b429;color:#1b3a6b;border:none;padding:10px 22px;font-size:13px;font-weight:700;cursor:pointer;border-radius:3px;font-family:Arial,sans-serif}
.btn-outline{background:transparent;color:#fff;border:1px solid rgba(255,255,255,0.4);padding:10px 22px;font-size:13px;cursor:pointer;border-radius:3px;font-family:Arial,sans-serif}
.breadcrumb{background:#eef1f7;border-bottom:1px solid #dde3ed;padding:.45rem 2rem;font-size:12px;color:#888}
.breadcrumb span{color:#1b3a6b}
.cat-wrap{display:flex;min-height:500px}
.sidebar{width:220px;min-width:220px;max-width:220px;background:#fff;border-right:1px solid #dde3ed;padding:.75rem 0;overflow-y:auto}
.s-title{font-size:10px;font-weight:700;color:#1b3a6b;text-transform:uppercase;letter-spacing:.7px;padding:.5rem 1rem .25rem}
.s-item{display:flex;justify-content:space-between;align-items:center;padding:.45rem 1rem;font-size:12px;color:#555;cursor:pointer;border-left:2px solid transparent}
.s-item:hover{background:#f0f4ff;color:#1b3a6b}
.s-item.active{color:#1b3a6b;border-left-color:#1b3a6b;background:#eef1f7;font-weight:600}
.s-count{font-size:10px;background:#eef1f7;padding:1px 5px;border-radius:10px;color:#888;flex-shrink:0}
.s-item.active .s-count{background:#dde3ed;color:#1b3a6b}
.s-divider{height:1px;background:#eee;margin:.4rem 0}
.cat-main{flex:1;min-width:0;padding:1.25rem;background:#f4f5f7}
.main-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:8px}
.main-top h2{font-size:14px;font-weight:500;color:#333}
.search-bar{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #dde3ed;border-radius:3px;padding:7px 12px;width:220px}
.search-bar input{border:none;background:transparent;font-size:12px;color:#333;outline:none;width:100%;font-family:Arial,sans-serif}
.search-bar input::placeholder{color:#aaa}
.products{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:10px}
.p-card{background:#fff;border:1px solid #dde3ed;border-radius:4px;padding:1rem;display:flex;flex-direction:column;gap:7px;cursor:pointer;transition:border-color .15s}
.p-card:hover{border-color:#1b3a6b}
.p-badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:2px;display:inline-block;width:fit-content}
.p-badge.red{background:#fff0ef;color:#cc2200}
.p-badge.blue{background:#e8f0ff;color:#1b3a6b}
.p-badge.green{background:#e8f8ee;color:#0a6e35}
.p-badge.amber{background:#fff8e1;color:#b36200}
.p-badge.purple{background:#f3eeff;color:#5b2d9e}
.p-name{font-size:12px;font-weight:600;color:#222;line-height:1.4}
.p-desc{font-size:11px;color:#777;line-height:1.5;flex:1}
.p-footer{display:flex;justify-content:space-between;align-items:center;padding-top:6px;border-top:1px solid #eee;margin-top:auto}
.p-status{font-size:10px;color:#0a7a3e}
.p-price{font-size:11px;color:#1b3a6b;font-weight:600}
.info-strip{background:#1b3a6b;padding:1.5rem 2rem;display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.info-block{display:flex;align-items:center;gap:12px}
.info-icon{width:40px;height:40px;background:rgba(255,255,255,0.15);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.info-icon i{font-size:20px;color:#f0b429}
.info-text strong{display:block;font-size:13px;color:#fff;margin-bottom:2px}
.info-text span{font-size:11px;color:#aec6e8}
.logistics-section{background:#fff;padding:2rem 2rem 2.25rem;border-top:1px solid #dde3ed}
.logistics-section .section-header{margin-bottom:1.1rem}
.section-header{text-align:center;margin-bottom:2rem}
.section-header h2{font-size:22px;font-weight:600;color:#1b3a6b;margin-bottom:.5rem}
.section-header p{font-size:14px;color:#888;max-width:600px;margin:0 auto}
.log-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;background:#f8f9fc;border-radius:8px;padding:1.15rem 1.5rem;margin-bottom:1.25rem;border:1px solid #dde3ed}
.log-stat{text-align:center}
.log-stat-n{font-size:24px;font-weight:700;color:#1b3a6b}
.log-stat-l{font-size:11px;color:#888;margin-top:3px}
.logistics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2rem}
.log-card{border:1px solid #dde3ed;border-radius:8px;padding:1.5rem;transition:all .2s}
.log-card:hover{border-color:#1b3a6b;box-shadow:0 6px 20px rgba(27,58,107,0.1);transform:translateY(-2px)}
.log-card-top{display:flex;align-items:center;gap:12px;margin-bottom:1rem}
.log-icon{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.log-icon.china{background:#fff0f0}
.log-icon.europe{background:#f0f4ff}
.log-icon.sng{background:#f0fff4}
.log-card h3{font-size:14px;font-weight:600;color:#1b3a6b;margin-bottom:2px}
.log-route{font-size:11px;color:#888}
.log-features{list-style:none;margin:0 0 1rem;padding:0}
.log-features li{font-size:12px;color:#555;padding:.28rem 0;border-bottom:1px solid #f5f5f5;display:flex;align-items:flex-start;gap:6px}
.log-features li:last-child{border-bottom:none}
.log-features li::before{content:"✓";color:#1b3a6b;font-weight:700;flex-shrink:0}
.log-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px;display:inline-block;margin:2px}
.log-badge.fast{background:#fff3e0;color:#e65100}
.log-badge.safe{background:#e8f5e9;color:#1b5e20}
.log-badge.custom{background:#e3f2fd;color:#0d47a1}
.brands-section{background:#f8f9fc;padding:2.25rem 2rem 1.25rem;border-top:1px solid #dde3ed}
.brands-section .section-header{margin-bottom:1.1rem}
.brands-grid2{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}
.brand-tile{background:#fff;border:1px solid #eee;border-radius:6px;padding:.9rem .6rem;text-align:center;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:5px}
.brand-tile:hover{border-color:#1b3a6b;transform:translateY(-2px);box-shadow:0 4px 12px rgba(27,58,107,0.1)}
.brand-icon{width:42px;height:42px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}
.brand-name{font-size:10px;font-weight:600;color:#444;line-height:1.3}
footer{background:#1b3a6b;padding:2rem;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem}
.f-logo-mark{width:32px;height:32px;background:#f0b429;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#1b3a6b;border-radius:3px;margin-bottom:.5rem}
.f-name{font-size:14px;font-weight:500;color:#fff;margin-bottom:.5rem}
.f-about{font-size:12px;color:#aec6e8;line-height:1.7}
.f-col h4{font-size:10px;font-weight:700;color:#f0b429;text-transform:uppercase;letter-spacing:.7px;margin-bottom:.75rem}
.f-col a{display:block;font-size:12px;color:#aec6e8;text-decoration:none;line-height:2;cursor:pointer}
.f-col a:hover{color:#fff}
.footer-bottom{background:#142d57;padding:.75rem 2rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
.footer-bottom p{font-size:11px;color:#7a9cc4}
.modal-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.7);z-index:1000;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:6px;padding:2rem;width:100%;max-width:460px;position:relative}
.modal h3{font-size:16px;font-weight:600;color:#1b3a6b;margin-bottom:.4rem}
.modal p{font-size:13px;color:#888;margin-bottom:1.25rem}
.modal input,.modal textarea{width:100%;background:#f8f9fc;border:1px solid #dde3ed;color:#333;font-size:13px;padding:9px 12px;border-radius:3px;margin-bottom:10px;font-family:Arial,sans-serif;outline:none}
.modal input:focus,.modal textarea:focus{border-color:#1b3a6b}
.modal textarea{height:90px;resize:none}
.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:#999;font-size:20px;cursor:pointer}

/* === БУРГЕР-КНОПКА (скрыта на десктопе) === */
.burger{display:none;flex-direction:column;justify-content:space-between;width:26px;height:20px;background:none;border:none;cursor:pointer;padding:0;margin-left:6px}
.burger span{display:block;height:2px;width:100%;background:#1b3a6b;border-radius:2px;transition:all .25s ease}
.burger.active span:nth-child(1){transform:translateY(9px) rotate(45deg)}
.burger.active span:nth-child(2){opacity:0}
.burger.active span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}

/* === ПЛАНШЕТ: 641–1023px === */
@media(max-width:1023px){
  /* Шапка */
  .top-bar{padding:.35rem 1rem;font-size:10px}
  nav{padding:0 1rem;flex-wrap:wrap}
  .burger{display:flex}
  .nav-right .nav-phone{display:none}
  .nav-menu{display:none;width:100%;flex-direction:column;align-items:stretch;background:#fff;border-top:1px solid #dde3ed;padding:.5rem 0;max-height:70vh;overflow-y:auto}
  nav.menu-open .nav-menu{display:flex}
  .nav-item{width:100%;border-bottom:1px solid #f0f3f8}
  .nav-item:last-child{border-bottom:none}
  .nav-item>a{padding:.85rem 1rem;border-bottom:none}
  .nav-item:hover .dropdown{display:none}
  .dropdown{position:static;width:100%;left:0;display:none;grid-template-columns:1fr;box-shadow:none;border:none;background:#f8f9fc;padding:.5rem 0}
  .nav-item.open .dropdown{display:grid}
  .dropdown>div{padding:.5rem 0}

  /* Hero */
  .hero{
    padding:1.25rem 1rem 1.5rem;
    min-height: auto;
    background:
      linear-gradient(to bottom, rgba(27,58,107,0.54) 0%, rgba(27,58,107,0.36) 100%),
      url('hero-bg.jpg') center center / cover no-repeat,
      #1b3a6b;
  }
  .hero h1{font-size:22px;max-width:100%;line-height:1.2}
  .hero p{font-size:12.5px;max-width:100%;line-height:1.5}
  .hero-stats-row{gap:1.2rem;margin-bottom:.85rem}
  .h-stat-inline strong{font-size:18px}

  /* Каталог */
  .breadcrumb{padding:.45rem 1rem}
  .cat-wrap{flex-direction:column}
  .sidebar{width:100%;min-width:0;max-width:none;border-right:none;border-bottom:1px solid #dde3ed;display:flex;flex-wrap:wrap;gap:6px;padding:.75rem 1rem;overflow-x:auto}
  .s-title,.s-divider{display:none}
  .s-item{padding:.4rem .75rem;border:1px solid #dde3ed;border-radius:20px;border-left:1px solid #dde3ed;font-size:11px;flex-shrink:0}
  .s-item.active{border-color:#1b3a6b;border-left-color:#1b3a6b}
  .cat-main{padding:1rem}
  .main-top{flex-direction:column;align-items:stretch}
  .search-bar{width:100%}
  .products{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}

  /* Информационная полоса */
  .info-strip{grid-template-columns:1fr 1fr;padding:1.25rem 1rem;gap:1rem}

  /* Логистика */
  .logistics-section{padding:2.5rem 1rem}
  .section-header h2{font-size:20px}
  .log-stats{grid-template-columns:repeat(2,1fr);padding:1.25rem}
  .logistics-grid{grid-template-columns:1fr 1fr;gap:1rem}

  /* Бренды */
  .brands-section{padding:2rem 1rem}
  .brands-grid2{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}

  /* О компании */
  .about-hero{padding:3rem 1rem}
  .about-hero-title{font-size:28px}
  .about-hero p{font-size:14px}
  .about-numbers{grid-template-columns:repeat(2,1fr)}
  .about-num{padding:1.5rem}
  .about-num:nth-child(2){border-right:none}
  .about-num:nth-child(1),.about-num:nth-child(2){border-bottom:1px solid #dde3ed}
  .about-num strong{font-size:28px}
  .about-body{grid-template-columns:1fr}
  .about-left{padding:2rem 1rem;border-right:none;border-bottom:1px solid #dde3ed}
  .about-right{padding:2rem 1rem}
  .about-left h2{font-size:20px}
  .about-values{grid-template-columns:1fr 1fr}
  .about-portfolio{padding:2.5rem 1rem}
  .portfolio-grid{grid-template-columns:1fr 1fr;gap:.85rem}
  .about-cta{padding:2.5rem 1rem}
  .about-cta h2{font-size:20px}

  /* Футер */
  footer{grid-template-columns:1fr 1fr;padding:1.5rem 1rem;gap:1.25rem}
  .footer-bottom{padding:.75rem 1rem;flex-direction:column;align-items:flex-start;gap:4px;text-align:left}

  /* Siemens-секция */

  /* Yokogawa-секция */

  /* Schneider-секция */

  /* ABB-секция */

  /* Rockwell-секция */

  /* Honeywell-секция */

  /* Mitsubishi/Omron/Phoenix Contact — общие правила */

  /* Универсальный шаблон .brand-section (Emerson/E+H/WAGO/P+F) */
  .brand-section{padding:2.5rem 1rem}
  .brand-section .brand-header h2{font-size:20px}
  .brand-section .brand-grid{grid-template-columns:1fr;gap:.85rem}
  .brand-section .brand-cta{flex-direction:column;text-align:center;padding:1.5rem;gap:1.25rem}
  .brand-section .brand-cta-btns{justify-content:center;flex-wrap:wrap}
}

/* === СМАРТФОН: ≤640px === */
@media(max-width:640px){
  /* Скрыть top-bar */
  .top-bar{display:none}

  /* Шапка */
  nav{padding:0 .85rem}
  .logo-text{font-size:13px}
  .logo-text small{font-size:9px}
  .nav-right{gap:6px}
  .btn-kp{padding:6px 10px;font-size:11px}

  /* Hero */
  .hero{
    padding:1rem 1rem 1.25rem;
    background:
      linear-gradient(to bottom, rgba(27,58,107,0.70) 0%, rgba(27,58,107,0.48) 100%),
      url('hero-bg.jpg') center center / cover no-repeat,
      #1b3a6b;
  }
  .hero h1{font-size:19px;line-height:1.2;margin-bottom:.4rem}
  .hero p{font-size:11.5px;line-height:1.5;margin-bottom:.55rem}
  .hero-stats-row{gap:.85rem;margin-bottom:.75rem;justify-content:space-between}
  .h-stat-inline strong{font-size:16px}
  .h-stat-inline span{font-size:9px}
  .sep{height:28px}
  .hero-btns{flex-direction:column;gap:8px}
  .hero-btns button{width:100%}

  /* Breadcrumb */
  .breadcrumb{font-size:11px;padding:.45rem .85rem}

  /* Каталог: одна колонка карточек */
  .products{grid-template-columns:1fr 1fr;gap:8px}
  .p-card{padding:.85rem}
  .p-name{font-size:11px}
  .p-desc{font-size:10px}

  /* Инфо-полоса: одна колонка */
  .info-strip{grid-template-columns:1fr;padding:1.25rem .85rem}
  .info-icon{width:36px;height:36px}
  .info-icon i{font-size:18px}
  .info-text strong{font-size:12px}
  .info-text span{font-size:10px}

  /* Логистика */
  .logistics-section{padding:2rem .85rem}
  .section-header h2{font-size:18px}
  .section-header p{font-size:12px}
  .log-stats{grid-template-columns:repeat(2,1fr);padding:1rem;gap:.5rem}
  .log-stat-n{font-size:20px}
  .log-stat-l{font-size:10px}
  .logistics-grid{grid-template-columns:1fr;gap:.85rem}
  .log-card{padding:1.25rem}

  /* Бренды */
  .brands-section{padding:1.75rem .85rem}
  .brands-grid2{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:6px}
  .brand-tile{padding:.7rem .4rem}
  .brand-icon{width:36px;height:36px;font-size:10px}
  .brand-name{font-size:9px}

  /* О компании */
  .about-hero{padding:2.25rem .85rem}
  .about-hero-title{font-size:22px}
  .about-hero p{font-size:13px;line-height:1.65}
  .about-numbers{grid-template-columns:1fr 1fr}
  .about-num{padding:1.1rem .5rem}
  .about-num strong{font-size:22px}
  .about-num span{font-size:10px}
  .about-left,.about-right{padding:1.75rem .85rem}
  .about-left h2{font-size:18px}
  .about-left p{font-size:12px;line-height:1.75}
  .about-values{grid-template-columns:1fr;gap:.5rem}
  .clients-title{font-size:14px}
  .client-icon{width:34px;height:34px;font-size:16px}
  .client-item-text strong{font-size:11px}
  .client-item-text span{font-size:10px}
  .client-tile{padding:.6rem .6rem;gap:8px}
  .client-tile .client-icon{width:30px;height:30px;font-size:15px}
  .client-tile strong{font-size:11px}
  .about-portfolio{padding:2rem .85rem}
  .portfolio-title{font-size:18px}
  .portfolio-sub{font-size:12px;margin-bottom:1.5rem}
  .portfolio-grid{grid-template-columns:1fr;gap:.75rem}
  .portfolio-card{padding:1.1rem}
  .p-card-icon{font-size:24px;margin-bottom:.5rem}
  .about-cta{padding:2rem .85rem}
  .about-cta h2{font-size:18px}
  .about-cta p{font-size:13px}
  .about-cta-btns{flex-direction:column;width:100%}
  .about-cta-btns button{width:100%}

  /* Футер */
  footer{grid-template-columns:1fr;padding:1.5rem .85rem;gap:1rem}
  .footer-bottom{padding:.75rem .85rem;font-size:10px}
  .footer-bottom p{font-size:10px}

  /* Модалка */
  .modal{padding:1.5rem 1.1rem;max-width:calc(100% - 2rem);margin:0 1rem}
  .modal h3{font-size:15px}
  .modal p{font-size:12px}

  /* Siemens-секция */
  .si-series{margin-bottom:1.5rem}

  /* Yokogawa-секция */

  /* Schneider-секция */

  /* ABB-секция */

  /* Rockwell-секция */

  /* Honeywell-секция */

  /* Mitsubishi/Omron/Phoenix Contact — общие правила на смартфон */

  /* Универсальный шаблон .brand-section на смартфон */
  .brand-section{padding:2rem .85rem}
  .brand-section .brand-header h2{font-size:18px}
  .brand-section .brand-header p{font-size:12px}
  .brand-section .brand-series{margin-bottom:1.5rem}
  .brand-section .brand-tag{font-size:10px;padding:4px 9px}
  .brand-section .brand-card-head{padding:.95rem 1rem}
  .brand-section .brand-num{width:30px;height:30px;font-size:12px}
  .brand-section .brand-card-title h3{font-size:12px}
  .brand-section .brand-card-title span{font-size:10px}
  .brand-section .brand-card-body{padding:.7rem 1rem 1rem}
  .brand-section .brand-table td{font-size:11px;padding:.4rem .35rem}
  .brand-section .brand-model{width:52%}
  .brand-section .brand-list li{font-size:11px}
  .brand-section .brand-cta{padding:1.25rem;flex-direction:column;text-align:center}
  .brand-section .brand-cta-text h3{font-size:15px}
  .brand-section .brand-cta-btns{flex-direction:column;width:100%}
  .brand-section .brand-cta-btns button{width:100%}
}

.about-section{background:#fff;padding:0;border-top:1px solid #dde3ed}
.about-hero{background:linear-gradient(135deg,rgba(27,58,107,.90) 0%,rgba(15,35,71,.95) 100%),url('hero-bg.jpg') center/cover no-repeat,#0f2347;padding:4rem 2rem;text-align:center;position:relative;overflow:hidden}
.about-hero::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(240,180,41,0.08) 0%,transparent 60%);pointer-events:none}
.about-hero-title{font-size:36px;font-weight:800;color:#fff;line-height:1.2;margin-bottom:1rem;position:relative;text-shadow:0 2px 12px rgba(0,0,0,.45)}
.about-hero-title span{color:#f0b429}
.about-hero-title::after{content:'';display:block;width:160px;height:2px;margin:1.1rem auto 0;background:linear-gradient(90deg,transparent,#4da3ff 50%,transparent);box-shadow:0 0 12px rgba(77,163,255,.85)}
.about-hero p{font-size:16px;color:#dbe6f5;max-width:700px;margin:0 auto;line-height:1.8;position:relative;text-shadow:0 1px 8px rgba(0,0,0,.45)}
.about-numbers{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid #dde3ed;border-bottom:1px solid #dde3ed}
.about-num{padding:2rem;text-align:center;border-right:1px solid #dde3ed}
.about-num:last-child{border-right:none}
.about-num strong{display:block;font-size:36px;font-weight:700;color:#1b3a6b;line-height:1}
.about-num span{font-size:12px;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-top:.4rem;display:block}
.about-body{display:grid;grid-template-columns:1fr 1fr;gap:0}
.about-left{padding:3rem 2rem;border-right:1px solid #dde3ed}
.about-right{padding:3rem 2rem;background:#f8f9fc}
.about-section-label{font-size:10px;font-weight:700;color:#f0b429;text-transform:uppercase;letter-spacing:1px;margin-bottom:.75rem}
.about-left h2{font-size:22px;font-weight:700;color:#1b3a6b;margin-bottom:1.25rem;line-height:1.4}
.about-left p{font-size:13px;color:#555;line-height:1.85;margin-bottom:1rem}
.about-values{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:1.5rem}
.about-val{background:#f0f4ff;border:1px solid #dde3ed;border-radius:6px;padding:.85rem;border-left:3px solid #1b3a6b}
.about-val strong{display:block;font-size:12px;font-weight:700;color:#1b3a6b;margin-bottom:3px}
.about-val span{font-size:11px;color:#777}
.clients-title{font-size:16px;font-weight:700;color:#1b3a6b;margin-bottom:1.25rem}
.client-item{display:flex;align-items:flex-start;gap:12px;padding:.85rem 0;border-bottom:1px solid #eee}
.client-item:last-child{border-bottom:none}
.client-icon{width:38px;height:38px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.client-icon.oil{background:#fff3e0}
.client-icon.gov{background:#fce4ec}
.client-icon.energy{background:#e8f5e9}
.client-icon.bank{background:#e3f2fd}
.client-icon.ind{background:#f3e5f5}
.client-icon.edu{background:#e0f7fa}
.client-icon.post{background:#fff8e1}
.client-icon.rail{background:#e8eaf6}
.client-item-text strong{display:block;font-size:12px;font-weight:700;color:#222;margin-bottom:2px}
.client-item-text span{font-size:11px;color:#777;line-height:1.5}
.client-icon.refine{background:#fbe9e7}
/* Компактные плитки отраслей (обзор охвата, без описаний) */
.clients-sub{font-size:12px;color:#777;margin:-0.75rem 0 1.1rem;line-height:1.4}
.client-tiles{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.client-tile{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid #dde3ed;border-left:3px solid #1b3a6b;border-radius:8px;padding:.7rem .75rem;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}
.client-tile:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(27,58,107,.1);border-left-color:#f0b429}
.client-tile .client-icon{width:34px;height:34px;font-size:16px}
.client-tile strong{font-size:12px;font-weight:700;color:#1b3a6b;line-height:1.25}
.about-portfolio{padding:3rem 2rem;border-top:1px solid #dde3ed;background:#fff}
.portfolio-title{font-size:22px;font-weight:700;color:#1b3a6b;text-align:center;margin-bottom:.5rem}
.portfolio-sub{font-size:13px;color:#888;text-align:center;margin-bottom:2rem}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.portfolio-card{border:1px solid #dde3ed;border-radius:8px;padding:1.25rem;position:relative;overflow:hidden;transition:all .2s}
.portfolio-card:hover{border-color:#1b3a6b;box-shadow:0 6px 20px rgba(27,58,107,0.1);transform:translateY(-2px)}
.portfolio-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:#1b3a6b}
.portfolio-card.gold::before{background:#f0b429}
.portfolio-card.red::before{background:#cc2200}
.portfolio-card.green::before{background:#0a7a3e}
.p-card-icon{font-size:28px;margin-bottom:.75rem}
.p-card-client{font-size:10px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.3rem}
.p-card-title{font-size:13px;font-weight:700;color:#1b3a6b;margin-bottom:.5rem}
.p-card-desc{font-size:12px;color:#666;line-height:1.6}
.p-card-tag{display:inline-block;font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px;background:#eef1f7;color:#1b3a6b;margin-top:.6rem}
.about-cta{background:linear-gradient(135deg,#1b3a6b,#0f2347);padding:3rem 2rem;text-align:center}
.about-cta h2{font-size:24px;font-weight:700;color:#fff;margin-bottom:.75rem}
.about-cta p{font-size:14px;color:#aec6e8;max-width:500px;margin:0 auto 1.5rem}
.about-cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}


/* ================================================================
   ИНТЕРАКТИВНЫЙ КАТАЛОГ БРЕНДОВ
   Двухпанельный layout: sidebar слева, контент справа
   ================================================================ */

.brands-app{background:#f4f5f7;padding:2rem 2rem 3rem;border-top:1px solid #dde3ed}
.ba-header{text-align:center;max-width:1280px;margin:0 auto 2rem}
.ba-header h2{font-size:24px;font-weight:700;color:#1b3a6b;margin-bottom:.5rem}
.ba-header p{font-size:14px;color:#888;line-height:1.6}

/* Layout: grid с фиксированной левой колонкой */
.ba-layout{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:260px 1fr;gap:1.5rem;align-items:flex-start}

/* === SIDEBAR === */
.ba-sidebar{background:#fff;border:1px solid #dde3ed;border-radius:8px;padding:1rem 0;position:sticky;top:60px;max-height:calc(100vh - 80px);overflow-y:auto;scrollbar-width:thin}
.ba-sidebar-title{font-size:10px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.7px;padding:.25rem 1.1rem .75rem;border-bottom:1px solid #eef1f7;margin-bottom:.4rem}
.ba-brand-list{display:flex;flex-direction:column;gap:1px}
.ba-brand-item{display:flex;align-items:center;gap:10px;padding:.7rem 1.1rem;font-size:13px;color:#444;cursor:pointer;border-left:3px solid transparent;transition:background .12s,color .12s;background:none;border-top:none;border-right:none;border-bottom:none;text-align:left;width:100%;font-family:Arial,sans-serif}
.ba-brand-item:hover{background:#f0f4ff;color:#1b3a6b}
.ba-brand-item.active{background:#eef1f7;color:#1b3a6b;font-weight:700;border-left-color:var(--brand-active,#1b3a6b)}
.ba-brand-dot{flex-shrink:0;width:12px;height:12px;border-radius:3px;background:var(--brand-color,#888)}
.ba-brand-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.ba-brand-name{font-weight:600;font-size:13px;line-height:1.2}
.ba-brand-sub{font-size:10px;color:#888;font-weight:400;line-height:1.2}
.ba-brand-item.active .ba-brand-sub{color:#5a7298}
.ba-brand-flag{flex-shrink:0;font-size:14px;opacity:.7}

/* === Мобильный селект (скрыт на десктопе) === */
.ba-mobile-select-wrap{display:none}
.ba-mobile-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:#fff;border:1px solid #dde3ed;border-radius:8px;padding:.85rem 1rem;font-size:13px;color:#1b3a6b;font-weight:600;cursor:pointer;font-family:Arial,sans-serif}
.ba-mobile-arrow{font-size:14px;color:#888}
.ba-mobile-list{display:none;background:#fff;border:1px solid #dde3ed;border-radius:8px;margin-top:.5rem;padding:.5rem 0;max-height:60vh;overflow-y:auto}
.ba-mobile-list.open{display:block}

/* === MAIN: правая часть === */
.ba-main{background:#fff;border:1px solid #dde3ed;border-radius:8px;min-height:400px;overflow:hidden}

/* Пустое состояние (когда бренд не выбран) */
.ba-empty{padding:4rem 2rem;text-align:center}
.ba-empty-icon{font-size:48px;margin-bottom:1rem;opacity:.4}
.ba-empty h3{font-size:18px;color:#1b3a6b;margin-bottom:.5rem}
.ba-empty p{font-size:13px;color:#888;max-width:480px;margin:0 auto;line-height:1.6}

/* === Шапка выбранного бренда === */
.ba-brand-hero{padding:1.5rem 2rem;border-bottom:1px solid #eef1f7;background:linear-gradient(135deg,var(--brand-color),var(--brand-color-dark));color:#fff}
.ba-brand-hero-row{display:flex;align-items:center;gap:1rem;margin-bottom:.4rem}
.ba-brand-hero-flag{font-size:24px}
.ba-brand-hero h3{font-size:22px;font-weight:700;color:#fff;margin:0}
.ba-brand-hero-sub{font-size:12px;color:rgba(255,255,255,0.85);text-transform:uppercase;letter-spacing:.5px}

/* === Горизонтальная лента-фильтр категорий === */
.ba-filters{padding:1rem 2rem;background:#fafbfd;border-bottom:1px solid #eef1f7;display:flex;flex-wrap:wrap;gap:8px}
.ba-filter{flex-shrink:0;padding:7px 16px;font-size:12px;font-weight:600;border:1.5px solid var(--c-border, #dde3ed);border-radius:20px;background:#fff;color:var(--c-text, #555);cursor:pointer;white-space:nowrap;font-family:'Manrope',Arial,sans-serif;transition:all .12s}
.ba-filter:hover{border-color:var(--brand-color);color:var(--brand-color-dark)}
.ba-filter.active{background:var(--brand-color);color:#fff;border-color:var(--brand-color)}
/* ТЕЛЕФОН: фильтры брендов — лента с намёком на прокрутку */
@media (max-width: 720px){
  .ba-filters{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;position:relative;-webkit-overflow-scrolling:touch}
  .ba-filters::-webkit-scrollbar{display:none}
}

/* === Контейнер карточек === */
.ba-cards{padding:1.5rem 2rem}
.ba-card{border:1px solid #dde3ed;border-radius:8px;margin-bottom:.85rem;overflow:hidden;transition:all .2s}
.ba-card:last-child{margin-bottom:0}
.ba-card:hover{border-color:var(--brand-color);box-shadow:0 4px 14px var(--brand-shadow)}
.ba-card-head{display:flex;align-items:center;gap:12px;padding:1.1rem 1.25rem;cursor:pointer;user-select:none;background:#fff;transition:background .15s;border-bottom:1px solid transparent}
.ba-card-head:hover{background:var(--brand-bg)}
.ba-card.open .ba-card-head{border-bottom-color:var(--brand-soft);background:var(--brand-bg)}
.ba-card-num{flex-shrink:0;width:34px;height:34px;border-radius:6px;background:var(--brand-bg);color:var(--brand-color);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}
.ba-card.open .ba-card-num{background:var(--brand-color);color:#fff}
.ba-card-icon{flex-shrink:0;width:34px;height:34px;border-radius:6px;background:#fff8ec;display:flex;align-items:center;justify-content:center;font-size:18px}
.ba-card-info{flex:1;min-width:0}
.ba-card-info h4{font-size:13px;font-weight:700;color:#1b3a6b;margin-bottom:2px;line-height:1.3}
.ba-card-info span{font-size:11px;color:#888}
.ba-card-count{background:#fff;border:1px solid var(--brand-soft);color:var(--brand-color);font-family:'Courier New',monospace;font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;margin-right:8px;white-space:nowrap}
.ba-card-arrow{flex-shrink:0;font-size:18px;color:#aaa;transition:transform .2s}
.ba-card.open .ba-card-arrow{transform:rotate(180deg);color:var(--brand-color)}

.ba-card-body{display:none;padding:.85rem 1.25rem 1.25rem}
.ba-card.open .ba-card-body{display:block}
.ba-group{margin-top:.85rem}
.ba-group:first-child{margin-top:.25rem}
.ba-group-name{font-size:11px;font-weight:700;color:var(--brand-color-dark);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;padding-bottom:.35rem;border-bottom:1px solid var(--brand-soft)}
.ba-table{width:100%;border-collapse:collapse;table-layout:fixed}
.ba-table td{padding:.45rem .5rem;font-size:12px;border-bottom:1px solid #f5f5f5;vertical-align:top;word-break:break-word}
.ba-table tr:last-child td{border-bottom:none}
.ba-table tr:hover td{background:#fafafa}
.ba-model{font-family:'Courier New',monospace;font-weight:700;color:var(--brand-color);width:46%;line-height:1.4}
.ba-desc{color:#555;line-height:1.5}
.ba-desc-extra{display:block;margin-top:4px;padding-top:4px;border-top:1px dashed #e8edf3;font-size:11px;color:#888;line-height:1.45;font-style:italic}
.ba-list{list-style:none;padding:0;margin:0}
.ba-list li{font-size:12px;color:#555;padding:.3rem 0 .3rem .85rem;line-height:1.5;position:relative;border-bottom:1px solid #f5f5f5}
.ba-list li:last-child{border-bottom:none}
.ba-list li::before{content:"▸";color:var(--brand-color);position:absolute;left:0;font-weight:700;font-size:10px;top:.5rem}

/* CTA внизу контента */
.ba-cta{margin:1rem 2rem 2rem;background:linear-gradient(135deg,var(--brand-color),var(--brand-color-dark));border-radius:8px;padding:1.5rem 1.75rem;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;color:#fff}
.ba-cta-text h4{font-size:16px;font-weight:600;color:#fff;margin-bottom:.3rem}
.ba-cta-text p{font-size:13px;color:rgba(255,255,255,0.85);line-height:1.5;margin:0}
.ba-cta-btns{display:flex;gap:8px;flex-shrink:0}
.ba-cta-btns button{padding:9px 18px;border-radius:4px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;font-family:Arial,sans-serif;border:none}
.ba-cta-btn-primary{background:#fff;color:var(--brand-color-dark)}
.ba-cta-btn-outline{background:transparent;color:#fff;border:1px solid rgba(255,255,255,0.5) !important}

/* === Sticky кнопка «Наверх» === */
.scroll-top{position:fixed;bottom:24px;right:24px;width:44px;height:44px;border-radius:50%;border:none;background:#1b3a6b;color:#fff;font-size:20px;cursor:pointer;box-shadow:0 4px 14px rgba(0,0,0,0.2);opacity:0;transform:translateY(8px);transition:opacity .2s,transform .2s,background .15s;z-index:500;font-family:Arial,sans-serif}
.scroll-top:hover{background:#142d57}
.scroll-top.visible{opacity:1;transform:translateY(0)}

/* === ПЛАНШЕТ: 641–1023px === */
@media(max-width:1023px){
  .brands-app{padding:2.5rem 1rem}
  .ba-layout{grid-template-columns:1fr;gap:0}

  /* Десктопный сайдбар скрывается, появляется мобильный селект */
  .ba-sidebar{display:none}
  .ba-mobile-select-wrap{display:block;margin-bottom:1rem}

  .ba-brand-hero{padding:1.25rem 1.25rem}
  .ba-brand-hero h3{font-size:18px}
  .ba-filters{padding:.85rem 1.25rem}
  .ba-cards{padding:1.25rem 1.25rem}
  .ba-cta{margin:1rem 1.25rem 1.25rem;flex-direction:column;text-align:center;padding:1.25rem}
  .ba-cta-btns{justify-content:center;flex-wrap:wrap}
}

/* === СМАРТФОН: ≤640px === */
@media(max-width:640px){
  .brands-app{padding:2rem .85rem}
  .ba-header h2{font-size:18px}
  .ba-header p{font-size:12px}
  .ba-brand-hero{padding:1rem .85rem}
  .ba-brand-hero h3{font-size:16px}
  .ba-brand-hero-flag{font-size:20px}
  .ba-brand-hero-sub{font-size:10px}
  .ba-filters{padding:.7rem .85rem;gap:5px}
  .ba-filter{font-size:11px;padding:5px 11px}
  .ba-cards{padding:1rem .85rem}
  .ba-card-head{padding:.95rem 1rem}
  .ba-card-num,.ba-card-icon{width:30px;height:30px;font-size:12px}
  .ba-card-icon{font-size:15px}
  .ba-card-info h4{font-size:12px}
  .ba-card-info span{font-size:10px}
  .ba-card-count{font-size:9px;padding:2px 6px}
  .ba-card-body{padding:.7rem 1rem 1rem}
  .ba-table td{font-size:11px;padding:.4rem .35rem}
  .ba-model{width:50%}
  .ba-desc-extra{font-size:10px;margin-top:3px;padding-top:3px}
  .ba-list li{font-size:11px}
  .ba-cta{padding:1rem;margin:1rem .85rem 1rem}
  .ba-cta-text h4{font-size:14px}
  .ba-cta-text p{font-size:12px}
  .ba-cta-btns{flex-direction:column;width:100%}
  .ba-cta-btns button{width:100%}

  .ba-empty{padding:3rem 1rem}
  .ba-empty-icon{font-size:40px}

  /* Sticky кнопка меньше на телефоне */
  .scroll-top{width:40px;height:40px;font-size:18px;bottom:16px;right:16px}
}

/* ============================================================
   МАГАЗИН: поиск + категории + сетка товаров
   ============================================================ */

.shop {
  max-width: 1400px;
  margin: 0 auto;
  padding: 1.5rem 1.5rem 2rem;
  scroll-margin-top: 70px;
}
.shop-fuzzy-hint{
  background:#fff8e1;
  border:1px solid #f0d68a;
  border-left:3px solid #f0b429;
  border-radius:6px;
  padding:.6rem .85rem;
  margin:0 0 1rem;
  font-size:13px;
  color:#7a5c00;
}

/* Длинный поиск */
.shop-search-wrap {
  margin-bottom: 1.25rem;
}
.shop-search-box {
  display: flex;
  align-items: center;
  background: #fff;
  border: 2px solid #e4e7eb;
  border-radius: 12px;
  padding: 0 1rem;
  height: 56px;
  transition: border-color .15s, box-shadow .15s;
}
.shop-search-box:focus-within {
  border-color: #1b3a6b;
  box-shadow: 0 0 0 4px rgba(27,58,107,0.08);
}
.shop-search-icon {
  color: #9aa5b1;
  font-size: 22px;
  margin-right: 12px;
}
.shop-search-box input {
  flex: 1;
  border: none;
  outline: none;
  background: transparent;
  font-size: 16px;
  color: #1b3a6b;
  height: 100%;
}
.shop-search-box input::placeholder {
  color: #9aa5b1;
}
.shop-search-clear {
  width: 32px;
  height: 32px;
  border: none;
  background: #f3f5f7;
  border-radius: 50%;
  color: #6b7785;
  font-size: 14px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s;
}
.shop-search-clear:hover {
  background: #e4e7eb;
  color: #1b3a6b;
}

/* Категории-плитки */
.shop-cats-wrap {
  margin-bottom: 1.5rem;
  position: relative;
}
.shop-cats-wrap::-webkit-scrollbar { display: none; }
/* ДЕСКТОП/ПЛАНШЕТ: автоматическая сетка — ВСЕ категории видны сразу, без прокрутки */
/* ДЕСКТОП: ровно 2 ряда по 11 категорий (всего 22) */
.shop-cats {
  display: grid;
  grid-template-columns: repeat(11, 1fr);
  gap: 0.5rem;
}
/* Скрытие категорий когда активен поиск — чтобы результаты были видны сразу */
.shop-categories.hidden-during-search,
#shopCategories.hidden-during-search {
  display: none !important;
}
.shop-cat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.45rem;
  padding: 0.8rem 0.5rem;
  background: #fff;
  border: 2px solid #e4e7eb;
  border-radius: 12px;
  cursor: pointer;
  transition: all .2s;
  text-align: center;
}
.shop-cat:hover {
  border-color: #1b3a6b;
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(27,58,107,0.08);
}
.shop-cat.active {
  border-color: #1b3a6b;
  background: #1b3a6b;
}
.shop-cat.active .shop-cat-name { color: #fff; }
.shop-cat-icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
}
.shop-cat-name {
  font-size: 12px;
  font-weight: 600;
  color: #1b3a6b;
  line-height: 1.3;
}

/* ДЕСКТОП ≥1101px: компактные плитки под сетку 11×2, равная высота, читаемый шрифт */
@media (min-width: 1101px) {
  .shop-cats { grid-template-columns: repeat(11, 1fr); gap: 0.5rem; }
  .shop-cat {
    padding: 0.7rem 0.3rem;
    min-height: 110px;
    justify-content: center;
    gap: 0.45rem;
  }
  .shop-cat-icon { width: 40px; height: 40px; font-size: 19px; }
  .shop-cat-name { font-size: 11.5px; line-height: 1.22; }
}

/* Заголовок секции + счётчик */
.shop-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 1rem;
  gap: 1rem;
  flex-wrap: wrap;
}
.shop-header h2 {
  font-size: 22px;
  font-weight: 700;
  color: #1b3a6b;
  margin: 0;
}
.shop-counter {
  font-size: 14px;
  color: #6b7785;
  font-weight: 500;
}

/* Сетка товаров */
.shop-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin-bottom: 2rem;
}

.shop-card {
  background: #fff;
  border: 1px solid #e4e7eb;
  border-radius: 12px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: all .2s;
}
.shop-card:hover {
  border-color: #cbd2d9;
  box-shadow: 0 8px 24px rgba(27,58,107,0.1);
  transform: translateY(-2px);
}
.shop-card-img {
  aspect-ratio: 4 / 3;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  border-bottom: 1px solid #f3f5f7;
}
.shop-card-icon {
  font-size: 56px;
  opacity: 0.85;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.1));
}
.shop-card-brand {
  position: absolute;
  top: 8px;
  left: 8px;
  background: rgba(255,255,255,0.95);
  border: 1px solid #e4e7eb;
  border-radius: 6px;
  padding: 3px 8px;
  font-size: 10px;
  font-weight: 700;
  color: #1b3a6b;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.shop-card-body {
  padding: 0.9rem;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 0.4rem;
}
.shop-card-model {
  font-size: 11px;
  color: #9aa5b1;
  font-family: 'SF Mono', Menlo, Monaco, monospace;
  letter-spacing: 0.2px;
}
.shop-card-name {
  font-size: 14px;
  font-weight: 600;
  color: #1b3a6b;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.shop-card-desc {
  font-size: 12px;
  color: #6b7785;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  flex: 1;
}
.shop-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-top: 0.5rem;
  padding-top: 0.6rem;
  border-top: 1px solid #f3f5f7;
}
.shop-card-price {
  font-size: 13px;
  font-weight: 700;
  color: #f0b429;
}
.shop-card-btn {
  background: #1b3a6b;
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 6px 12px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s;
  white-space: nowrap;
}
.shop-card-btn:hover { background: #0f2447; }

/* Пагинация */
.shop-pager {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  margin-top: 1rem;
}
.shop-pages {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  flex-wrap: wrap;
  justify-content: center;
}
.shop-page-btn {
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  background: #fff;
  border: 1px solid #e4e7eb;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 600;
  color: #1b3a6b;
  cursor: pointer;
  transition: all .15s;
}
.shop-page-btn:hover:not(:disabled):not(.active) {
  background: #f3f5f7;
  border-color: #cbd2d9;
}
.shop-page-btn.active {
  background: #1b3a6b;
  border-color: #1b3a6b;
  color: #fff;
}
.shop-page-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
.shop-page-dots {
  padding: 0 6px;
  color: #9aa5b1;
}

.shop-loadmore {
  background: #fff;
  border: 2px solid #1b3a6b;
  color: #1b3a6b;
  border-radius: 10px;
  padding: 12px 28px;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: all .15s;
}
.shop-loadmore:hover {
  background: #1b3a6b;
  color: #fff;
}

/* Пустое состояние */
.shop-empty {
  text-align: center;
  padding: 3rem 1rem;
  background: #f7f9fa;
  border-radius: 12px;
  margin-bottom: 2rem;
}
.shop-empty-icon { font-size: 48px; margin-bottom: 1rem; }
.shop-empty h3 {
  font-size: 18px;
  color: #1b3a6b;
  margin: 0 0 0.5rem;
}
.shop-empty p {
  color: #6b7785;
  font-size: 14px;
  max-width: 480px;
  margin: 0 auto 1.25rem;
  line-height: 1.5;
}

/* ===== Адаптив: планшет ===== */
@media (max-width: 1100px) {
  .shop-grid { grid-template-columns: repeat(3, 1fr); }
  .shop-cats { grid-template-columns: repeat(auto-fill, minmax(118px, 1fr)); }
}

/* ===== Адаптив: мобильный ===== */
@media (max-width: 767px) {
  .shop { padding: 1rem 0.75rem 1.5rem; }
  .shop-search-box { height: 50px; padding: 0 0.75rem; }
  .shop-search-box input { font-size: 15px; }
  .shop-cats { gap: 0.5rem; }
  .shop-cat { min-width: 90px; padding: 0.7rem 0.4rem; }
  .shop-cat-icon { width: 38px; height: 38px; font-size: 18px; }
  .shop-cat-name { font-size: 11px; }
  .shop-header h2 { font-size: 18px; }
  .shop-grid { grid-template-columns: repeat(2, 1fr); gap: 0.6rem; }
  .shop-card-img { aspect-ratio: 1 / 1; }
  .shop-card-icon { font-size: 44px; }
  .shop-card-body { padding: 0.7rem; gap: 0.3rem; }
  .shop-card-name { font-size: 13px; }
  .shop-card-desc { font-size: 11px; -webkit-line-clamp: 2; }
  .shop-card-brand { font-size: 9px; padding: 2px 6px; }
  .shop-card-model { font-size: 10px; }
  .shop-card-price { font-size: 12px; }
  .shop-card-btn { font-size: 10px; padding: 5px 8px; }
  .shop-page-btn { min-width: 32px; height: 32px; font-size: 13px; padding: 0 8px; }
}

/* Очень узкий экран */
@media (max-width: 380px) {
  .shop-card-img { aspect-ratio: 1 / 1; }
  .shop-card-icon { font-size: 38px; }
}

/* ============================================================
   КАРУСЕЛЬ БРЕНДОВ (две ленты в противоположных направлениях)
   ============================================================ */

.brands-marquee {
  position: relative;
  overflow: hidden;
  padding: 0.85rem 0 0.4rem;
  /* Затемнение по краям — fade-эффект */
  mask-image: linear-gradient(to right, transparent 0%, #000 8%, #000 92%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 8%, #000 92%, transparent 100%);
}

.brands-marquee-track {
  display: flex;
  gap: 0.75rem;
  width: max-content;
  animation: brandsScroll 60s linear infinite;
  margin-bottom: 0.75rem;
  will-change: transform;
}
.brands-marquee-track.reverse {
  animation: brandsScrollReverse 50s linear infinite;
  margin-bottom: 0;
}

@keyframes brandsScroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
@keyframes brandsScrollReverse {
  0%   { transform: translateX(-50%); }
  100% { transform: translateX(0); }
}

/* Карточка бренда — компактный вордмарк */
.brand-logo {
  flex: 0 0 auto;
  background: #fff;
  border: 1px solid #e4e7eb;
  border-radius: 10px;
  padding: 0.7rem 1.1rem;
  min-width: 130px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  transition: all .25s;
  text-align: center;
}
.brand-logo:hover {
  border-color: #1b3a6b;
  transform: translateY(-2px);
  box-shadow: 0 8px 18px rgba(27,58,107,0.1);
}
.brand-logo-accent {
  width: 24px;
  height: 3px;
  border-radius: 2px;
  flex-shrink: 0;
}
.brand-logo-name {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.3px;
  font-family: 'Helvetica Neue', 'Inter', system-ui, sans-serif;
  white-space: nowrap;
  line-height: 1;
}

/* Адаптив: мобильный */
@media (max-width: 767px) {
  .brands-marquee { padding: 0.8rem 0; }
  .brands-marquee-track { gap: 0.5rem; margin-bottom: 0.5rem; }
  .brand-logo {
    min-width: 100px;
    padding: 0.55rem 0.8rem;
    gap: 0.3rem;
    border-radius: 8px;
  }
  .brand-logo-name { font-size: 12px; }
  .brand-logo-accent { width: 20px; height: 2.5px; }
  /* Чуть быстрее на мобильном чтобы не казалось медленным */
  .brands-marquee-track { animation-duration: 45s; }
  .brands-marquee-track.reverse { animation-duration: 38s; }
}

/* Если у пользователя включён prefers-reduced-motion — выключаем анимацию */
@media (prefers-reduced-motion: reduce) {
  .brands-marquee-track {
    animation: none;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
  }
}

/* Старая сетка .brands-grid2 — больше не используется, но оставим стили на случай если что-то ссылается */
.brands-grid2 { display: none; }

/* ============================================================
   ФОТО В КАРТОЧКАХ ТОВАРОВ (поверх градиента-заглушки)
   ============================================================ */

.shop-card-img.has-photo .shop-card-icon {
  display: none; /* при наличии фото — скрываем эмодзи */
}
.shop-card-img.has-photo.img-error .shop-card-icon {
  display: flex; /* если фото не загрузилось — иконка снова видна */
}
.shop-card-photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 12px;
  background: #fff;
  display: block;
}
.shop-card-img {
  position: relative; /* нужно для absolute-позиционирования фото */
}
.shop-card-img.has-photo {
  background: #fff !important; /* перебиваем градиент когда есть фото */
}

/* ============================================================
   МОДАЛКА «Запросить КП» (полная версия)
   ============================================================ */

.modal-kp {
  max-width: 540px;
  width: 92%;
  padding: 1.75rem;
  border-radius: 16px;
  max-height: 92vh;
  overflow-y: auto;
}

.modal-head h3 {
  font-size: 20px;
  color: #1b3a6b;
  margin: 0 0 6px;
}
.modal-head p {
  color: #6b7785;
  font-size: 14px;
  margin: 0 0 1.25rem;
}

.modal-form {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.85rem;
}
.form-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.form-label {
  font-size: 12px;
  color: #6b7785;
  font-weight: 600;
}
.form-label .req { color: #ff4d4f; }

.modal-form input,
.modal-form textarea {
  font-family: inherit;
  font-size: 14px;
  color: #1b3a6b;
  padding: 10px 12px;
  border: 1.5px solid #e4e7eb;
  border-radius: 8px;
  outline: none;
  background: #fff;
  transition: border-color .15s, box-shadow .15s;
  width: 100%;
}
.modal-form input:focus,
.modal-form textarea:focus {
  border-color: #1b3a6b;
  box-shadow: 0 0 0 3px rgba(27,58,107,0.08);
}
.modal-form textarea {
  min-height: 90px;
  max-height: 200px;
  resize: vertical;
}

.form-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.6rem;
  margin-top: 0.5rem;
}
.btn-send {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 14px;
  border: none;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  cursor: pointer;
  transition: transform .12s, box-shadow .15s, filter .15s;
}
.btn-send:hover { transform: translateY(-1px); filter: brightness(1.05); }
.btn-send:active { transform: translateY(0); }
.btn-send svg { flex-shrink: 0; }
.btn-wa { background: #25d366; box-shadow: 0 4px 12px rgba(37,211,102,.25); }
.btn-em { background: #1b3a6b; box-shadow: 0 4px 12px rgba(27,58,107,.25); }

.form-note {
  font-size: 13px;
  padding: 10px 12px;
  border-radius: 8px;
  line-height: 1.4;
}
.form-note.ok { background: #d4f4dd; color: #0f5c2a; border: 1px solid #a8e8ba; }
.form-note.err { background: #ffe0e0; color: #a01818; border: 1px solid #ffb3b3; }

.modal-divider {
  text-align: center;
  margin: 1.5rem 0 1rem;
  position: relative;
}
.modal-divider::before {
  content: '';
  position: absolute;
  inset: 50% 0 0 0;
  border-top: 1px solid #e4e7eb;
}
.modal-divider span {
  background: #fff;
  padding: 0 12px;
  color: #9aa5b1;
  font-size: 12px;
  position: relative;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.modal-contacts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.6rem;
}
.mc-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1.5px solid #e4e7eb;
  border-radius: 10px;
  text-decoration: none;
  transition: all .15s;
}
.mc-item:hover {
  border-color: #1b3a6b;
  background: #f7f9fa;
}
.mc-icon { font-size: 22px; flex-shrink: 0; }
.mc-text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.mc-label { font-size: 11px; color: #9aa5b1; text-transform: uppercase; letter-spacing: 0.3px; }
.mc-value {
  font-size: 13px;
  font-weight: 600;
  color: #1b3a6b;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Мобильный адаптив */
@media (max-width: 580px) {
  .modal-kp { padding: 1.25rem; width: 95%; }
  .modal-head h3 { font-size: 18px; }
  .form-row, .form-actions, .modal-contacts {
    grid-template-columns: 1fr;
  }
  .btn-send { padding: 14px; font-size: 15px; }
}

/* ============================================================
   КОРЗИНА ДЛЯ КП
   ============================================================ */

/* Кнопка корзины в шапке */
.btn-cart {
  position: relative;
  width: 42px;
  height: 42px;
  border-radius: 10px;
  border: 1.5px solid #e4e7eb;
  background: #fff;
  color: #1b3a6b;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all .15s;
  flex-shrink: 0;
}
.btn-cart:hover { border-color: #1b3a6b; background: #f7f9fa; }
.btn-cart svg { display: block; }
.cart-badge {
  position: absolute;
  top: -6px;
  right: -6px;
  min-width: 20px;
  height: 20px;
  padding: 0 5px;
  background: #f0b429;
  color: #1b3a6b;
  font-size: 11px;
  font-weight: 800;
  border-radius: 10px;
  display: none;
  align-items: center;
  justify-content: center;
  line-height: 1;
  border: 2px solid #fff;
  box-sizing: content-box;
}
.cart-badge.visible { display: flex; }

/* Степпер количества (− N +) на карточке и в корзине */
.qty-stepper {
  display: inline-flex;
  align-items: center;
  border: 1.5px solid #1b3a6b;
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
}
.qty-btn {
  width: 28px;
  height: 28px;
  border: none;
  background: #fff;
  color: #1b3a6b;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  transition: background .12s;
}
.qty-btn:hover { background: #f0b429; color: #1b3a6b; }
.qty-input {
  width: 40px;
  height: 28px;
  border: none;
  border-left: 1px solid #e4e7eb;
  border-right: 1px solid #e4e7eb;
  text-align: center;
  font-size: 13px;
  font-weight: 700;
  color: #1b3a6b;
  background: #fff;
  outline: none;
  -moz-appearance: textfield;
}
.qty-input::-webkit-outer-spin-button,
.qty-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* Кнопка "В корзину" — теперь это shop-card-btn.cart-add */
.shop-card-btn.cart-add {
  background: #1b3a6b;
  color: #fff;
  padding: 6px 14px;
  border-radius: 8px;
  font-size: 11px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  transition: background .12s;
  white-space: nowrap;
}
.shop-card-btn.cart-add:hover { background: #0f2447; }

/* Модалка корзины */
.modal-cart {
  max-width: 720px;
  width: 95%;
  padding: 1.5rem;
  border-radius: 16px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
}

.cart-empty {
  text-align: center;
  padding: 2.5rem 1rem;
}
.cart-empty-icon {
  font-size: 56px;
  margin-bottom: 0.75rem;
  opacity: 0.6;
}
.cart-empty h4 {
  font-size: 18px;
  color: #1b3a6b;
  margin: 0 0 0.4rem;
}
.cart-empty p {
  color: #6b7785;
  font-size: 14px;
  margin: 0 0 1rem;
}

.cart-body {
  flex: 1;
  overflow-y: auto;
  margin: 0.5rem 0;
  padding-right: 4px;
}
.cart-body::-webkit-scrollbar { width: 6px; }
.cart-body::-webkit-scrollbar-thumb { background: #cbd2d9; border-radius: 3px; }

.cart-row {
  display: grid;
  grid-template-columns: 64px 1fr auto 32px;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 0;
  border-bottom: 1px solid #f3f5f7;
}
.cart-row:last-child { border-bottom: none; }

.cart-row-img {
  width: 64px;
  height: 64px;
  border-radius: 8px;
  overflow: hidden;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.cart-row-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 4px;
  background: #fff;
}
.cart-row-icon {
  font-size: 28px;
  display: flex;
}

.cart-row-info { min-width: 0; }
.cart-row-model {
  font-size: 10px;
  color: #9aa5b1;
  font-family: 'SF Mono', Menlo, Monaco, monospace;
  margin-bottom: 2px;
}
.cart-row-name {
  font-size: 13px;
  font-weight: 600;
  color: #1b3a6b;
  line-height: 1.3;
  margin-bottom: 2px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.cart-row-brand {
  font-size: 11px;
  color: #6b7785;
}

.cart-row-qty .qty-stepper { border-color: #cbd2d9; }
.cart-row-qty .qty-input { width: 44px; }

.cart-row-remove {
  width: 32px;
  height: 32px;
  border: none;
  background: transparent;
  color: #cbd2d9;
  font-size: 16px;
  cursor: pointer;
  border-radius: 50%;
  transition: all .12s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cart-row-remove:hover {
  background: #ffe0e0;
  color: #d44;
}

.cart-footer {
  display: flex;
  gap: 0.6rem;
  padding-top: 1rem;
  border-top: 1px solid #e4e7eb;
}
.btn-cart-clear {
  flex: 0 0 auto;
  background: #fff;
  color: #6b7785;
  border: 1.5px solid #e4e7eb;
  border-radius: 10px;
  padding: 11px 16px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s;
}
.btn-cart-clear:hover {
  border-color: #d44;
  color: #d44;
  background: #fff5f5;
}
.btn-cart-send {
  flex: 1;
  background: #f0b429;
  color: #1b3a6b;
  border: none;
  border-radius: 10px;
  padding: 12px 20px;
  font-size: 14px;
  font-weight: 800;
  cursor: pointer;
  transition: all .15s;
  box-shadow: 0 4px 12px rgba(240,180,41,0.3);
}
.btn-cart-send:hover {
  background: #d99c1a;
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(240,180,41,0.4);
}

/* Мобильный адаптив корзины */
@media (max-width: 580px) {
  .modal-cart { padding: 1rem; }
  .cart-row {
    grid-template-columns: 56px 1fr 32px;
    grid-template-rows: auto auto;
    gap: 0.5rem;
  }
  .cart-row-img { width: 56px; height: 56px; }
  .cart-row-info { grid-column: 2; }
  .cart-row-qty {
    grid-column: 2;
    grid-row: 2;
    justify-self: start;
  }
  .cart-row-remove {
    grid-column: 3;
    grid-row: 1 / 3;
    align-self: center;
  }
  .cart-row-name { -webkit-line-clamp: 2; }
  .cart-footer { flex-direction: column-reverse; }
  .btn-cart-clear { width: 100%; }

  /* В шапке кнопка корзины компактнее */
  .btn-cart { width: 36px; height: 36px; }
  .btn-cart svg { width: 18px; height: 18px; }
}

/* ============================================================
   КЛИКАБЕЛЬНАЯ КАРТОЧКА ТОВАРА (hover-эффект)
   ============================================================ */
.shop-card {
  cursor: pointer;
}
.shop-card:hover {
  border-color: #1b3a6b;
  box-shadow: 0 10px 28px rgba(27,58,107,0.14);
}
.shop-card:active {
  transform: translateY(0);
}
/* Степпер и кнопка "В корзину" не должны давать ощущение клика по карточке */
.shop-card-cart-zone {
  z-index: 2;
  position: relative;
}

/* ============================================================
   МОДАЛКА ДЕТАЛЬНОГО ПРОСМОТРА ТОВАРА
   ============================================================ */
.modal-product {
  max-width: 880px;
  width: 95%;
  padding: 1.75rem;
  border-radius: 16px;
  max-height: 90vh;
  overflow-y: auto;
}

.pm-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 1.75rem;
  align-items: start;
}

.pm-img {
  aspect-ratio: 1 / 1;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
.pm-img.has-photo { background: #fff !important; }
.pm-img.has-photo .pm-icon { display: none; }
.pm-img.has-photo.img-error .pm-icon { display: flex; }
.pm-photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 20px;
  background: #fff;
}
.pm-icon {
  font-size: 96px;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,0.1));
}

.pm-info { display: flex; flex-direction: column; gap: 0.6rem; }

.pm-brand-row {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}
.pm-brand {
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.4px;
}

.pm-name {
  font-size: 22px;
  font-weight: 700;
  color: #1b3a6b;
  margin: 0;
  line-height: 1.25;
}

.pm-model {
  font-size: 13px;
  color: #6b7785;
  font-family: 'SF Mono', Menlo, Monaco, monospace;
}
.pm-model b {
  color: #1b3a6b;
  font-weight: 700;
}

.pm-desc {
  font-size: 14px;
  color: #4a5663;
  line-height: 1.55;
  margin: 0.25rem 0;
}

.pm-price-row {
  display: flex;
  align-items: baseline;
  gap: 8px;
  padding: 12px 16px;
  background: linear-gradient(135deg, #fff8e1 0%, #fff4cc 100%);
  border-radius: 10px;
  border: 1px solid #f0b42940;
}
.pm-price-label { font-size: 13px; color: #6b7785; font-weight: 600; }
.pm-price {
  font-size: 22px;
  font-weight: 800;
  color: #1b3a6b;
}

.pm-actions {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-top: 0.5rem;
}

.pm-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 13px 18px;
  border: none;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: all .15s;
  width: 100%;
}
.pm-btn-kp {
  background: #f0b429;
  color: #1b3a6b;
  box-shadow: 0 4px 12px rgba(240,180,41,0.3);
}
.pm-btn-kp:hover {
  background: #d99c1a;
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(240,180,41,0.4);
}
.pm-btn-cart {
  background: #fff;
  color: #1b3a6b;
  border: 2px solid #1b3a6b;
}
.pm-btn-cart:hover {
  background: #1b3a6b;
  color: #fff;
}

.pm-cart-row { display: flex; }
.pm-in-cart {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: #d4f4dd;
  border: 1.5px solid #a8e8ba;
  border-radius: 10px;
  width: 100%;
  flex-wrap: wrap;
}
.pm-in-cart-label {
  font-size: 13px;
  font-weight: 600;
  color: #0f5c2a;
}
.pm-cart-link {
  margin-left: auto;
  background: transparent;
  border: none;
  color: #1b3a6b;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 6px;
  transition: background .12s;
}
.pm-cart-link:hover { background: #fff; }

.pm-hint {
  font-size: 12px;
  color: #6b7785;
  line-height: 1.5;
  padding: 10px 12px;
  background: #f3f5f7;
  border-radius: 8px;
  margin-top: 0.25rem;
}

/* Адаптив модалки товара */
@media (max-width: 720px) {
  .modal-product { padding: 1.25rem; width: 96%; }
  .pm-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  .pm-img {
    aspect-ratio: 4 / 3;
    max-height: 280px;
  }
  .pm-icon { font-size: 72px; }
  .pm-name { font-size: 19px; }
  .pm-price { font-size: 19px; }
  .pm-in-cart { padding: 10px 12px; gap: 8px; }
  .pm-cart-link { width: 100%; margin-left: 0; text-align: center; margin-top: 4px; }
}
@media (max-width: 380px) {
  .modal-product { padding: 1rem; }
  .pm-img { aspect-ratio: 1 / 1; max-height: 220px; }
  .pm-icon { font-size: 56px; }
}

/* ============================================================
   HERO — текст: основной + подзаголовок
   ============================================================ */
.hero p {
  max-width: 780px;
}
.hero-sub {
  font-size: 12px !important;
  color: #e8eef7 !important;
  line-height: 1.5 !important;
  margin-top: -0.2rem !important;
  margin-bottom: 0.85rem !important;
  max-width: 780px;
  border-left: 2px solid #f0b429;
  padding-left: 10px;
  text-shadow: 0 2px 10px rgba(0,0,0,0.75), 0 0 3px rgba(0,0,0,0.5);
}
@media (max-width: 760px) {
  .hero-sub {
    font-size: 12px !important;
    padding-left: 10px;
  }
}

/* ============================================================
   КОМПАКТНАЯ ТЕНДЕРНАЯ СЕКЦИЯ (после магазина)
   ============================================================ */
.tender-section {
  background: linear-gradient(135deg, #fafbfc 0%, #eef2f7 100%);
  padding: 2rem 2rem;
  border-top: 1px solid #e4e7eb;
  border-bottom: 1px solid #e4e7eb;
}
.tender-compact {
  max-width: 1100px;
  margin: 0 auto;
  background: #fff;
  border: 1px solid #e4e7eb;
  border-left: 4px solid #f0b429;
  border-radius: 12px;
  padding: 1.25rem 1.5rem;
  display: flex;
  align-items: center;
  gap: 1.5rem;
}
.tender-compact-text { flex: 1; min-width: 0; }
.tender-compact-text h3 {
  font-size: 16px;
  color: #1b3a6b;
  margin: 0 0 0.35rem;
  font-weight: 700;
}
.tender-compact-text p {
  font-size: 13px;
  color: #6b7785;
  margin: 0;
  line-height: 1.5;
}
.tender-compact .btn-primary {
  background: #1b3a6b;
  color: #fff;
  padding: 11px 18px;
  border-radius: 9px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  font-size: 13px;
  transition: all .15s;
  flex-shrink: 0;
}
.tender-compact .btn-primary:hover {
  background: #0f2447;
  transform: translateY(-1px);
}

@media (max-width: 760px) {
  .tender-section { padding: 1.5rem 1rem; }
  .tender-compact {
    flex-direction: column;
    align-items: stretch;
    text-align: center;
    padding: 1.25rem;
    gap: 1rem;
  }
  .tender-compact .btn-primary { width: 100%; }
}


/* ============================================================
   ОПТИМИЗАЦИЯ ПОД ФЛАГМАНЫ ANDROID
   (Samsung Galaxy S25 Ultra: 412×891, S24 Ultra: 412×883,
    iPhone 16 Pro Max: 430×932, Pixel 10 Pro XL: 412×892)
   ============================================================ */

/* Safe-area-insets для камеры и системных кнопок Android */
@supports (padding: max(0px)) {
  body {
    padding-top: env(safe-area-inset-top);
    padding-left: env(safe-area-inset-left);
    padding-right: env(safe-area-inset-right);
  }
  .scroll-top {
    bottom: max(20px, env(safe-area-inset-bottom)) !important;
  }
  .modal-overlay {
    padding-top: env(safe-area-inset-top);
    padding-bottom: env(safe-area-inset-bottom);
  }
  /* Корзина и КП-модалки — не залазят под системные жесты */
  .modal {
    margin-bottom: env(safe-area-inset-bottom);
  }
}

/* Брейкпойнт для широких мобильных флагманов (400-540px)
   Делаем виджеты крупнее и комфортнее, используя доступную ширину */
@media (min-width: 400px) and (max-width: 540px) {
  /* Hero — крупнее на флагманах */
  .hero {
    padding: 1.5rem 1.25rem 1.75rem;
  }
  .hero h1 {
    font-size: 24px;
    line-height: 1.22;
  }
  .hero p {
    font-size: 13.5px;
    line-height: 1.55;
  }
  .hero-sub {
    font-size: 12.5px !important;
    line-height: 1.55 !important;
  }
  .h-stat-inline strong {
    font-size: 19px;
  }
  .h-stat-inline span {
    font-size: 10px;
  }
  .hero-btns {
    gap: 12px;
  }
  .btn-primary, .btn-outline {
    padding: 11px 18px;
    font-size: 13.5px;
  }

  /* Магазин — 2 колонки с большим gap, карточки крупнее */
  .shop-grid {
    grid-template-columns: 1fr 1fr;
    gap: 14px;
  }
  .shop-card-img {
    height: 130px;
  }
  .shop-card-icon {
    font-size: 42px;
  }
  .shop-card-body {
    padding: 12px;
  }
  .shop-card-name {
    font-size: 13px;
    line-height: 1.35;
  }
  .shop-card-desc {
    font-size: 11.5px;
    line-height: 1.45;
    -webkit-line-clamp: 3;
  }
  .shop-card-price {
    font-size: 13px;
  }
  .shop-card-btn {
    padding: 7px 13px;
    font-size: 11.5px;
  }

  /* Категории магазина — крупнее иконки */
  .shop-cat {
    padding: 10px 12px;
  }
  .shop-cat-icon {
    width: 26px;
    height: 26px;
    font-size: 14px;
  }
  .shop-cat-name {
    font-size: 12.5px;
  }

  /* Поиск — крупнее на широких мобильниках */
  .shop-search-box input {
    font-size: 15px;
    padding: 14px 14px 14px 44px;
  }
  .shop-search-icon {
    font-size: 20px;
    left: 14px;
  }

  /* Категории-плитки внизу — 3 колонки вместо 2 */
  .brands-tiles {
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
  }
  .brand-tile {
    padding: 10px 6px;
  }
  .brand-tile-ab {
    font-size: 13px;
  }
  .brand-tile-name {
    font-size: 10.5px;
  }

  /* Каталог брендов — карточки чуть просторнее */
  .bs-card {
    padding: 14px;
  }
  .bs-card h4 {
    font-size: 14px;
  }

  /* Шапка — иконки в шапке больше */
  .btn-cart {
    width: 38px;
    height: 38px;
  }
  .btn-cart svg {
    width: 19px;
    height: 19px;
  }
  .cart-badge {
    font-size: 11px;
    min-width: 19px;
    height: 19px;
  }

  /* Модалка КП — крупнее поля */
  .modal-kp {
    padding: 1.4rem;
  }
  .modal-form input,
  .modal-form textarea {
    font-size: 15px;
    padding: 11px 13px;
  }
  .btn-send {
    padding: 13px 14px;
    font-size: 14.5px;
  }

  /* Корзина — крупнее фото и текст */
  .cart-row-img {
    width: 60px;
    height: 60px;
  }
  .cart-row-name {
    font-size: 13.5px;
  }
  .qty-input {
    width: 48px;
    height: 30px;
    font-size: 14px;
  }
  .qty-btn {
    width: 30px;
    height: 30px;
    font-size: 17px;
  }

  /* Детальная карточка товара — шире инфо */
  .pm-name {
    font-size: 19px;
  }
  .pm-desc {
    font-size: 14px;
  }
  .pm-price {
    font-size: 20px;
  }
  .pm-btn {
    padding: 14px 16px;
    font-size: 14.5px;
  }
}

/* Очень тонкая настройка под S25 Ultra (412×891) */
@media (width: 412px) and (height: 891px),
       (width: 412px) and (min-height: 880px) and (max-height: 900px) {
  /* На этом конкретном размере чуть подвинем категории-плитки */
  .brands-tiles {
    gap: 7px;
  }
  /* Hero — оптимальная высота под экран */
  .hero {
    min-height: 320px;
  }
}

/* Большие мобильные в landscape (Galaxy S25 Ultra повёрнутый: 891×412) */
@media (orientation: landscape) and (max-height: 500px) {
  .hero {
    padding: 1rem 1.5rem;
    min-height: auto;
  }
  .hero h1 {
    font-size: 22px;
    margin-bottom: 0.4rem;
  }
  .hero p {
    font-size: 12.5px;
    margin-bottom: 0.5rem;
  }
  .hero-sub {
    font-size: 11.5px !important;
    margin-bottom: 0.6rem !important;
  }
  .hero-stats-row {
    margin-bottom: 0.7rem;
  }
  /* Модалки — не на весь экран в landscape */
  .modal {
    max-height: 85vh;
    overflow-y: auto;
  }
  .pm-grid {
    grid-template-columns: 1fr 1.5fr;
    gap: 1rem;
  }
  .pm-img {
    aspect-ratio: 1 / 1;
    max-height: 180px;
  }
}

/* Поддержка high-DPI экранов (Samsung AMOLED) — резкие SVG-иконки */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  /* Tabler icons — уже SVG, для них настройка не нужна */
  /* Но плитки брендов — SVG в data:URL, рендер на высоких DPI ок */
  .shop-card-photo {
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
  }
}

/* Samsung Internet специфика — Samsung любит автоматически менять цвета (Dark Mode) */
@media (prefers-color-scheme: dark) {
  /* НЕ переключаемся в dark mode — наш брендинг светлый.
     Принудительно держим светлую тему. */
  html, body {
    background: #fff;
    color: #1b3a6b;
  }
}

/* Тач-цель >= 44px (Apple HIG) — улучшаем UX на тач-устройствах */
@media (hover: none) and (pointer: coarse) {
  .shop-card-btn,
  .nav-item a,
  .shop-cat,
  .brand-tile,
  .qty-btn,
  .cart-row-remove,
  .modal-close {
    min-height: 36px;
  }
  .btn-primary, .btn-outline, .btn-kp, .pm-btn, .btn-send, .btn-cart-send {
    min-height: 44px;
  }
  /* На тач-устройствах убираем hover-эффекты, чтобы не «залипали» после тапа */
  .shop-card:hover {
    transform: none;
  }
}

/* ===========================================================================
   ============= ЕДИНАЯ СИСТЕМА АДАПТИВНОСТИ (финальная) =====================
   Перекрывает старые правила и обеспечивает полную поддержку всех устройств.
   ===========================================================================

   БРЕЙКПОЙНТЫ:
   - XS:  < 380px         iPhone SE, старые мобильные
   - SM:  380-479px       Стандартные мобильные (iPhone 14, S24)
   - MD:  480-599px       Большие мобильные (S25 Ultra, iPhone Pro Max)
   - LG:  600-767px       Планшет портрет (iPad Mini)
   - XL:  768-1023px      Планшет landscape, маленький ноутбук
   - 2XL: 1024-1439px     Стандартный ноутбук, обычный монитор
   - 3XL: 1440px+         Большой монитор (4K, ультраширокие)
   =========================================================================== */

/* ─────────────────────────────────────────────────────────────────────────
   XS — Очень маленькие мобильные (< 380px) — iPhone SE, старые Android
   ───────────────────────────────────────────────────────────────────────── */
@media (max-width: 379px) {
  /* Шапка ультра-компактная */
  .top-bar { padding: 4px 8px; font-size: 10px; }
  .top-bar > span:nth-child(2) { display: none; }
  nav { padding: 8px 8px; }
  .nav-logo strong { font-size: 14px; }
  .nav-logo small { display: none; }
  .nav-phone { display: none; }
  .btn-cart { width: 34px; height: 34px; }
  .btn-cart svg { width: 16px; height: 16px; }
  .btn-kp { font-size: 11px; padding: 6px 10px; }

  /* Hero — самое узкое */
  .hero { padding: 1rem 0.85rem 1.25rem; }
  .hero h1 { font-size: 18px; line-height: 1.18; }
  .hero p { font-size: 11px; line-height: 1.5; }
  .hero-sub { font-size: 10.5px !important; padding-left: 8px !important; }
  .h-stat-inline strong { font-size: 14px; }
  .h-stat-inline span { font-size: 8.5px; }
  .hero-btns { flex-direction: column; gap: 8px; width: 100%; }
  .hero-btns button { width: 100%; }

  /* Магазин — 1 колонка */
  .shop-grid { grid-template-columns: 1fr !important; gap: 12px; }
  .shop-search-box input { font-size: 13px; padding: 11px 11px 11px 38px; }
  .shop-cat { padding: 6px 8px; font-size: 11px; }
  .shop-cat-icon { width: 22px; height: 22px; font-size: 12px; }
  .shop-cat-name { font-size: 11px; }
  .shop-card-img { height: 140px; }
  .shop-card-icon { font-size: 48px; }
  .shop-card-name { font-size: 13.5px; }
  .shop-card-desc { font-size: 11.5px; -webkit-line-clamp: 2; }

  /* Категории-плитки */
  .brands-tiles { grid-template-columns: repeat(2, 1fr) !important; gap: 6px; }

  /* Модалки */
  .modal { padding: 1rem !important; max-width: 96% !important; }
  .modal-kp .form-row { grid-template-columns: 1fr !important; }
  .modal-kp input, .modal-kp textarea { font-size: 14px; }
  .form-actions { flex-direction: column; }
  .btn-send { width: 100%; }
}

/* ─────────────────────────────────────────────────────────────────────────
   SM — Стандартные мобильные (380-479px) — iPhone 13/14/15, S22-S24
   ───────────────────────────────────────────────────────────────────────── */
@media (min-width: 380px) and (max-width: 479px) {
  .top-bar { font-size: 10.5px; }
  .nav-phone { display: none; }

  /* Hero */
  .hero { padding: 1.15rem 1rem 1.4rem; }
  .hero h1 { font-size: 20px; line-height: 1.2; }
  .hero p { font-size: 12px; line-height: 1.5; }
  .hero-sub { font-size: 11.5px !important; }
  .h-stat-inline strong { font-size: 16px; }

  /* Магазин — 2 колонки стандартные */
  .shop-grid { grid-template-columns: 1fr 1fr !important; gap: 12px; }
  .shop-card-img { height: 120px; }
  .shop-card-icon { font-size: 38px; }
  .shop-card-name { font-size: 12.5px; }
  .shop-card-desc { font-size: 11px; -webkit-line-clamp: 2; }

  .brands-tiles { grid-template-columns: repeat(2, 1fr) !important; gap: 7px; }
}

/* ─────────────────────────────────────────────────────────────────────────
   MD — Большие мобильные (480-599px) — S25 Ultra (412), iPhone Pro Max (430)
   Примечание: S25 Ultra (412px) попадает в SM-диапазон тоже, но 480+ это
   реальные крупные мобильные где можно делать просторнее.
   ───────────────────────────────────────────────────────────────────────── */
@media (min-width: 480px) and (max-width: 599px) {
  /* Шапка чуть просторнее */
  .top-bar { font-size: 11px; padding: 4px 12px; }
  .nav-phone { display: inline; font-size: 12px; }

  /* Hero ещё крупнее */
  .hero { padding: 1.5rem 1.25rem 1.75rem; }
  .hero h1 { font-size: 26px; line-height: 1.22; max-width: 100%; }
  .hero p { font-size: 14px; line-height: 1.55; }
  .hero-sub { font-size: 13px !important; line-height: 1.55 !important; }
  .h-stat-inline strong { font-size: 20px; }

  /* Магазин */
  .shop-grid { grid-template-columns: 1fr 1fr !important; gap: 14px; }
  .shop-card-img { height: 140px; }
  .shop-card-icon { font-size: 44px; }
  .shop-card-name { font-size: 13.5px; }
  .shop-card-desc { font-size: 12px; -webkit-line-clamp: 3; }

  /* Плитки 3 в ряд */
  .brands-tiles { grid-template-columns: repeat(3, 1fr) !important; gap: 8px; }
}

/* ─────────────────────────────────────────────────────────────────────────
   LG — Планшет портрет (600-767px) — iPad Mini, Galaxy Tab portrait
   ───────────────────────────────────────────────────────────────────────── */
@media (min-width: 600px) and (max-width: 767px) {
  /* Шапка нормальная */
  .top-bar { font-size: 11px; padding: 4px 16px; }
  .nav-phone { display: inline; font-size: 13px; }
  nav { padding: 10px 16px; }
  .nav-logo strong { font-size: 16px; }
  .btn-kp { font-size: 12px; padding: 8px 14px; }

  /* Hero просторный */
  .hero { padding: 2rem 2rem 2.25rem; min-height: 320px; }
  .hero h1 { font-size: 30px; max-width: 600px; }
  .hero p { font-size: 14.5px; max-width: 600px; }
  .hero-sub { font-size: 13.5px !important; max-width: 600px; }
  .h-stat-inline strong { font-size: 22px; }

  /* Магазин — 3 колонки на планшете! */
  .shop-grid { grid-template-columns: repeat(3, 1fr) !important; gap: 14px; }
  .shop-card-img { height: 130px; }
  .shop-card-icon { font-size: 42px; }
  .shop-card-name { font-size: 13px; }
  .shop-card-desc { font-size: 11.5px; -webkit-line-clamp: 2; }

  /* Категории магазина — горизонтальный скролл удобнее */
  .shop-cats {
    overflow-x: auto;
    flex-wrap: nowrap !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
  }
  .shop-cat { flex-shrink: 0; }

  /* Плитки 4 в ряд */
  .brands-tiles { grid-template-columns: repeat(4, 1fr) !important; gap: 9px; }

  /* Модалки шире */
  .modal-product { max-width: 90% !important; }
  .pm-grid { grid-template-columns: 1fr !important; }
  .modal-cart { max-width: 90% !important; }

  /* Каталог брендов — sidebar нормальный */
  .bs-sidebar { width: 180px !important; }
}

/* ─────────────────────────────────────────────────────────────────────────
   XL — Планшет landscape, маленький ноутбук (768-1023px) — iPad, Surface
   ───────────────────────────────────────────────────────────────────────── */
@media (min-width: 768px) and (max-width: 1023px) {
  /* Шапка с полной навигацией */
  nav { padding: 10px 20px; }
  .nav-logo strong { font-size: 17px; }
  .nav-items { display: flex; }
  .nav-item a { font-size: 13px; padding: 8px 10px; }
  .nav-phone { display: inline; font-size: 13.5px; }
  .burger { display: none; }

  /* Hero ноутбучный */
  .hero { padding: 2.25rem 2.5rem 2.5rem; min-height: 360px; }
  .hero h1 { font-size: 32px; max-width: 700px; }
  .hero p { font-size: 14.5px; max-width: 700px; }
  .hero-sub { font-size: 13.5px !important; max-width: 700px; }
  .h-stat-inline strong { font-size: 22px; }

  /* Магазин — 4 колонки! */
  .shop-grid { grid-template-columns: repeat(4, 1fr) !important; gap: 16px; }
  .shop-card-img { height: 140px; }
  .shop-card-icon { font-size: 42px; }
  .shop-card-name { font-size: 13px; }
  .shop-card-desc { font-size: 11.5px; -webkit-line-clamp: 2; }

  /* Плитки 6 в ряд */
  .brands-tiles { grid-template-columns: repeat(6, 1fr) !important; gap: 10px; }

  /* Каталог брендов */
  .bs-sidebar { width: 200px !important; }

  /* Модалки шире */
  .modal-product { max-width: 720px !important; }
  .pm-grid { grid-template-columns: 1fr 1.2fr !important; gap: 1.5rem !important; }
  .modal-cart { max-width: 700px !important; }
}

/* ─────────────────────────────────────────────────────────────────────────
   2XL — Стандартный ноутбук, монитор (1024-1439px) — большинство ПК
   ───────────────────────────────────────────────────────────────────────── */
@media (min-width: 1024px) and (max-width: 1439px) {
  /* Полная навигация */
  nav { padding: 12px 24px; }
  .nav-logo strong { font-size: 18px; }
  .nav-items { display: flex; gap: 4px; }
  .nav-item a { font-size: 13.5px; padding: 8px 12px; }
  .nav-phone { display: inline; font-size: 14px; font-weight: 700; }
  .burger { display: none; }

  /* Hero — премиум */
  .hero { padding: 2.5rem 3rem 3rem; min-height: 380px; }
  .hero h1 { font-size: 36px; line-height: 1.2; max-width: 800px; }
  .hero p { font-size: 15px; line-height: 1.6; max-width: 750px; }
  .hero-sub { font-size: 13.5px !important; line-height: 1.6 !important; max-width: 750px; }
  .h-stat-inline strong { font-size: 24px; }

  /* Магазин — 4 колонки, крупнее */
  .shop-grid { grid-template-columns: repeat(4, 1fr) !important; gap: 18px; }
  .shop-card-img { height: 160px; }
  .shop-card-icon { font-size: 48px; }
  .shop-card-name { font-size: 14px; }
  .shop-card-desc { font-size: 12px; -webkit-line-clamp: 3; }

  /* Плитки 8 в ряд */
  .brands-tiles { grid-template-columns: repeat(8, 1fr) !important; gap: 12px; }

  /* Каталог брендов с широким sidebar */
  .bs-sidebar { width: 240px !important; }

  /* Модалки полноразмерные */
  .modal-product { max-width: 880px !important; }
  .modal-cart { max-width: 720px !important; }
  .modal-kp { max-width: 540px !important; }
}

/* ─────────────────────────────────────────────────────────────────────────
   3XL — Большие мониторы (1440px+) — 4K, ультраширокие, профи
   ───────────────────────────────────────────────────────────────────────── */
@media (min-width: 1440px) {
  /* Ограничиваем максимальную ширину контента */
  nav, .hero, .shop, .tender-section, .logistics-section, .brands-app, footer,
  .brands-section {
    max-width: 1400px;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .top-bar > span:first-child {
    max-width: 1400px;
    margin: 0 auto;
  }

  /* Шапка крупная */
  nav { padding: 14px 32px; }
  .nav-logo strong { font-size: 20px; }
  .nav-logo small { font-size: 9.5px; }
  .nav-item a { font-size: 14px; padding: 10px 14px; }
  .nav-phone { font-size: 15px; }
  .btn-kp { font-size: 13.5px; padding: 10px 18px; }

  /* Hero премиум-уровня */
  .hero { padding: 3rem 4rem 3.5rem; min-height: 420px; }
  .hero h1 { font-size: 42px; line-height: 1.2; max-width: 850px; }
  .hero p { font-size: 16px; line-height: 1.65; max-width: 800px; }
  .hero-sub { font-size: 14.5px !important; max-width: 800px; }
  .h-stat-inline strong { font-size: 28px; }
  .h-stat-inline span { font-size: 11px; }

  /* Магазин — 5 колонок на широких мониторах */
  .shop-grid { grid-template-columns: repeat(5, 1fr) !important; gap: 20px; }
  .shop-card-img { height: 170px; }
  .shop-card-icon { font-size: 54px; }
  .shop-card-name { font-size: 14px; }
  .shop-card-desc { font-size: 12.5px; -webkit-line-clamp: 3; }

  /* Плитки 10 в ряд (вместо 8) */
  .brands-tiles { grid-template-columns: repeat(10, 1fr) !important; gap: 14px; }

  /* Каталог брендов — широкий sidebar */
  .bs-sidebar { width: 260px !important; }

  /* Магазин: больше товаров на странице */
  /* Управляется в JS через perPage */
}

/* ─────────────────────────────────────────────────────────────────────────
   4XL — Очень большие мониторы (1920px+) — 4K телевизоры, профи мониторы
   ───────────────────────────────────────────────────────────────────────── */
@media (min-width: 1920px) {
  nav, .hero, .shop, .tender-section, .logistics-section, .brands-app, footer,
  .brands-section {
    max-width: 1600px;
  }

  .hero h1 { font-size: 46px; }
  .hero p { font-size: 17px; }

  /* Магазин — 6 колонок! Для 4K экранов */
  .shop-grid { grid-template-columns: repeat(6, 1fr) !important; }

  /* Плитки 12 в ряд */
  .brands-tiles { grid-template-columns: repeat(12, 1fr) !important; }
}

/* ─────────────────────────────────────────────────────────────────────────
   ВСПОМОГАТЕЛЬНЫЕ ПРАВИЛА (универсальные, применяются на всех устройствах)
   ───────────────────────────────────────────────────────────────────────── */

/* Бургер-меню на мобильных */
@media (max-width: 767px) {
  .burger { display: flex !important; }
  .nav-items { display: none; }
  nav.menu-open .nav-items {
    display: flex !important;
    flex-direction: column;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: #fff;
    box-shadow: 0 8px 20px rgba(0,0,0,0.08);
    padding: 12px 16px;
    z-index: 999;
    border-top: 1px solid #e4e7eb;
  }
  nav.menu-open .nav-items .nav-item {
    width: 100%;
    border-bottom: 1px solid #f3f5f7;
  }
  nav.menu-open .nav-items .nav-item a {
    display: block;
    padding: 12px 4px;
    font-size: 14px;
  }
}

/* Большие экраны — не растягиваем картинку Hero без меры */
@media (min-width: 1600px) {
  .hero {
    background-size: 1800px auto, cover, cover !important;
    background-position: center top, center, center !important;
  }
}

/* Универсальные печатные стили — для распечатки прайс-листа */
@media print {
  nav, .hero, .scroll-top, .modal-overlay, .brands-section,
  .tender-section, .logistics-section, footer,
  .btn-cart, .btn-kp, .shop-card-btn, .shop-cats {
    display: none !important;
  }
  body { color: #000; background: #fff; }
  .shop-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 8px;
  }
  .shop-card {
    page-break-inside: avoid;
    border: 1px solid #ccc;
  }
  .shop-card-img { display: none; }
  .shop-card-name { color: #000; font-size: 11px; }
  .shop-card-desc { color: #444; font-size: 10px; }
}

/* Touch-устройства — крупнее тач-цели */
@media (hover: none) and (pointer: coarse) {
  .nav-item a,
  .shop-cat,
  .brand-tile {
    min-height: 40px;
    display: flex;
    align-items: center;
  }
}

/* Поддержка ландшафтной ориентации мобильных */
@media (max-height: 500px) and (orientation: landscape) and (max-width: 1023px) {
  .hero { min-height: auto; padding: 1rem 1.5rem 1.25rem; }
  .hero h1 { font-size: 22px; }
  .hero p { font-size: 12.5px; }
  .hero-sub { font-size: 11.5px !important; }
  .h-stat-inline strong { font-size: 17px; }

  /* Модалки не на весь экран */
  .modal { max-height: 90vh; overflow-y: auto; }
  .pm-grid { grid-template-columns: 1fr 1.5fr !important; gap: 1rem !important; }
  .pm-img { aspect-ratio: 4 / 3 !important; max-height: 200px; }
}

/* === Бейдж "🔥 ХИТ" на карточке товара (build v9) === */
.shop-card { position: relative; }
.shop-card.is-hit {
  border: 2px solid #dc2626;
  box-shadow: 0 0 0 1px rgba(220,38,38,0.1);
}
.shop-hit-badge {
  position: absolute;
  top: 8px; left: 8px;
  background: #dc2626;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 4px;
  z-index: 10;
  letter-spacing: 0.5px;
  box-shadow: 0 2px 4px rgba(220,38,38,0.3);
}
@media (max-width: 480px) {
  .shop-hit-badge { font-size: 10px; padding: 3px 8px; top: 6px; left: 6px; }
}

/* === Бейдж "В наличии" на карточке товара (build v10) === */
.shop-card.is-stock {
  border-color: #16a34a;
}
.shop-stock-badge {
  position: absolute;
  top: 8px; right: 8px;
  background: #16a34a;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 4px 8px;
  border-radius: 4px;
  z-index: 10;
  letter-spacing: 0.3px;
  box-shadow: 0 2px 4px rgba(22,163,74,0.3);
}
/* Если есть и ХИТ и В НАЛИЧИИ — ХИТ слева, В НАЛИЧИИ справа (уже разнесены) */
.shop-card.is-hit.is-stock {
  border-color: #dc2626;  /* ХИТ важнее */
}
@media (max-width: 480px) {
  .shop-stock-badge { font-size: 9px; padding: 3px 6px; top: 6px; right: 6px; }
}

/* === ФИКС: бренд-бейдж не должен накладываться на бейдж ХИТ/НАЛИЧИИ (build v14) === */
/* Если карточка — хит, опускаем бренд-бейдж ниже, под бейдж ХИТ */
.shop-card.is-hit .shop-card-brand {
  top: 40px;
}
/* Если есть оба (хит + наличие) или просто наличие — бренд тоже опускаем */
.shop-card.is-stock .shop-card-brand {
  top: 40px;
}
@media (max-width: 480px) {
  .shop-card.is-hit .shop-card-brand,
  .shop-card.is-stock .shop-card-brand {
    top: 36px;
  }
}

/* === ФИКС: запрет горизонтальной прокрутки всей страницы на мобильном (build v14) === */
/* Лента категорий .shop-cats-wrap продолжает листаться свайпом внутри себя, */
/* но вся страница больше не ездит вбок. */
/* ВАЖНО: overflow-x:hidden ломает position:sticky на шапке, поэтому используем clip. */
/* clip обрезает переполнение БЕЗ создания scroll-контейнера → sticky работает. */
html, body {
  overflow-x: clip;          /* совр. браузеры: не ломает sticky */
  max-width: 100%;
}
@supports not (overflow-x: clip) {
  /* старые браузеры — fallback (sticky может работать хуже, но переполнение защищено) */
  html, body { overflow-x: hidden; }
}
/* Гарантия, что секции не выходят за ширину экрана */
.hero, .shop, .brands-section, .about-section, footer, section {
  max-width: 100%;
}

/* ============================================================ */
/* НОВЫЕ ФУНКЦИИ (build v15): WhatsApp-кнопка, Найдём под заказ, Поделиться */
/* ============================================================ */

/* --- ИДЕЯ 1: Плавающая кнопка WhatsApp --- */
.wa-float{
  position:fixed; right:20px; bottom:20px; z-index:9000;
  width:60px; height:60px; border-radius:50%;
  background:#25D366; color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 16px rgba(37,211,102,.45);
  cursor:pointer; text-decoration:none;
  transition:transform .2s, box-shadow .2s;
}
.wa-float:hover{ transform:scale(1.08); box-shadow:0 6px 22px rgba(37,211,102,.6); }
.wa-float svg{ position:relative; z-index:2; }
/* Пульсирующее кольцо */
.wa-float-pulse{
  position:absolute; inset:0; border-radius:50%;
  background:#25D366; opacity:.6; z-index:1;
  animation:waPulse 2.2s ease-out infinite;
}
@keyframes waPulse{
  0%{ transform:scale(1); opacity:.6; }
  70%{ transform:scale(1.7); opacity:0; }
  100%{ transform:scale(1.7); opacity:0; }
}
@media (max-width:480px){
  .wa-float{ width:54px; height:54px; right:16px; bottom:16px; }
  .wa-float svg{ width:28px; height:28px; }
}

/* --- ИДЕЯ 2/3: Кнопка «Найдём под заказ» в hero --- */
.btn-find{
  background:#fff; color:#1b3a6b; border:none;
  padding:10px 22px; font-size:13px; font-weight:700;
  cursor:pointer; border-radius:3px; font-family:Arial,sans-serif;
  transition:background .2s, transform .1s;
}
.btn-find:hover{ background:#f0f3f8; transform:translateY(-1px); }

/* --- Модалка «Найдём под заказ» --- */
.modal-find{ max-width:560px; }
.find-head{ text-align:center; margin-bottom:1.25rem; }
.find-emoji{ font-size:38px; display:block; margin-bottom:.5rem; }
.find-title{
  font-size:22px; color:#1b3a6b; font-weight:700;
  margin:0 0 .5rem; font-family:Arial,sans-serif;
}
.find-sub{
  font-size:13px; color:#6b7785; line-height:1.55; margin:0;
}
.find-sub b{ color:#1b3a6b; }
.form-label-hint{ color:#8a93a0; font-weight:400; font-size:12px; }
.find-file-hint{
  font-size:12px; color:#6b7785; line-height:1.45;
  background:#f4f7fc; border:1px dashed #cdd8e8; border-radius:6px;
  padding:.55rem .7rem; margin:0 0 .9rem;
}
@media (max-width:480px){
  .find-title{ font-size:18px; }
  .find-sub{ font-size:12px; }
  .form-actions{ grid-template-columns:1fr; }
}

/* --- ИДЕЯ 4: Кнопка «Поделиться в WhatsApp» в карточке товара --- */
.pm-btn-share{
  background:#25D366; color:#fff;
}
.pm-btn-share:hover{ background:#1da851; }

/* ============================================================ */
/* КАТЕГОРИИ: адаптивное поведение (build v18) */
/* Десктоп = сетка (всё видно). Телефон = лента с намёком на прокрутку. */
/* ============================================================ */

/* ПЛАНШЕТ: сетка плотнее */
@media (max-width: 1023px) {
  .shop-cats {
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: 0.6rem;
  }
}

/* ТЕЛЕФОН: горизонтальная лента со СТРЕЛКОЙ-НАМЁКОМ и градиентом */
@media (max-width: 720px) {
  .shop-cats-wrap {
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
    /* место справа под градиент-намёк */
    padding-right: 4px;
  }
  .shop-cats {
    display: flex;            /* лента в один ряд */
    grid-template-columns: none;
    gap: 0.6rem;
    width: max-content;       /* шире экрана → прокрутка */
    padding-right: 44px;      /* чтобы последняя плитка не пряталась под стрелкой */
  }
  .shop-cat {
    flex: 0 0 auto;
    min-width: 110px;
    max-width: 130px;
  }
  /* Градиент-затухание справа = визуальный намёк "есть ещё" */
  .shop-cats-wrap::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 48px;
    background: linear-gradient(to right, rgba(244,245,247,0) 0%, #f4f5f7 80%);
    pointer-events: none;
    z-index: 2;
  }
  /* Пульсирующая стрелка-намёк "листай вправо" */
  .shop-cats-hint {
    position: absolute;
    top: 50%;
    right: 6px;
    transform: translateY(-50%);
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #1b3a6b;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    z-index: 3;
    pointer-events: none;
    box-shadow: 0 2px 8px rgba(27,58,107,.3);
    animation: catHintPulse 1.6s ease-in-out infinite;
  }
  /* Прячем намёк, когда долистали до конца (класс ставит JS) */
  .shop-cats-wrap.scrolled-end .shop-cats-hint,
  .shop-cats-wrap.scrolled-end::after {
    opacity: 0;
    transition: opacity .3s;
  }
}
@keyframes catHintPulse {
  0%, 100% { transform: translateY(-50%) translateX(0); }
  50% { transform: translateY(-50%) translateX(4px); }
}
/* На десктопе стрелка-намёк не нужна — прячем */
@media (min-width: 721px) {
  .shop-cats-hint { display: none; }
}

/* На широких экранах: логотип + поиск + кнопки в первой строке, меню во второй */
@media (min-width: 901px) {
  nav { flex-wrap: wrap; row-gap: 6px; }
  .logo { order: 1; }
  .nav-search { order: 2; flex: 1 1 auto; max-width: 520px; margin: 0 1.5rem; }
  .nav-right { order: 3; }
  .nav-menu { order: 4; flex: 1 1 100%; border-top: 1px solid #eef1f7; padding-top: 6px; margin-top: 2px; }
}

/* ============================================================ */
/* ПОИСК В ШАПКЕ (как Amazon/Kaspi/Sulpak) — build v19 */
/* nav уже sticky, поэтому поиск виден всегда при прокрутке. */
/* ============================================================ */
.nav-search {
  flex: 1;
  display: flex;
  align-items: center;
  max-width: 460px;
  margin: 0 1.5rem;
  background: #f4f5f7;
  border: 1.5px solid #dde3ed;
  border-radius: 8px;
  overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
}
.nav-search:focus-within {
  border-color: #1b3a6b;
  box-shadow: 0 0 0 3px rgba(27,58,107,.08);
  background: #fff;
}
.nav-search input {
  flex: 1;
  border: none;
  background: transparent;
  padding: 9px 14px;
  font-size: 13px;
  color: #333;
  outline: none;
  font-family: Arial, sans-serif;
  min-width: 0;
}
.nav-search input::placeholder { color: #9aa5b1; }
.nav-search-btn {
  border: none;
  background: #f0b429;
  color: #1b3a6b;
  padding: 0 16px;
  align-self: stretch;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background .2s;
}
.nav-search-btn:hover { background: #e0a420; }

/* ПЛАНШЕТ: поиск чуть уже, меню может скрываться */
@media (max-width: 1100px) {
  .nav-search { max-width: 320px; margin: 0 1rem; }
}

/* ТЕЛЕФОН: поиск переносится на отдельную строку под логотипом, на всю ширину */
@media (max-width: 900px) {
  nav { flex-wrap: wrap; row-gap: 8px; padding: 8px 1rem; }
  .nav-search {
    order: 3;
    flex: 1 1 100%;
    max-width: 100%;
    margin: 0;
  }
  /* логотип и кнопки остаются в первой строке, поиск — во второй */
  .logo { order: 1; }
  .nav-right { order: 2; }
  .nav-menu { order: 4; }
}

/* ============================================================ */
/* РЕДИЗАЙН UI 2026 (build v20) — новая палитра + Manrope        */
/* Палитра: navy #0F172A, blue #2563EB, accent #06B6D4,         */
/* bg #F8FAFC, text #475569 + green #16A34A, amber #F59E0B      */
/* ============================================================ */
:root {
  --c-navy: #0F172A;
  --c-blue: #2563EB;
  --c-blue-dark: #1D4ED8;
  --c-accent: #06B6D4;
  --c-bg: #F8FAFC;
  --c-text: #475569;
  --c-text-dark: #1E293B;
  --c-border: #E2E8F0;
  --c-green: #16A34A;
  --c-amber: #F59E0B;
}

/* Шрифт Manrope на весь сайт */
body {
  font-family: 'Manrope', Arial, sans-serif !important;
  background: var(--c-bg) !important;
  color: var(--c-text) !important;
}

/* --- ШАПКА --- */
.top-bar {
  background: var(--c-navy) !important;
  color: #94A3B8 !important;
}
nav {
  background: #fff !important;
  border-bottom: 1px solid var(--c-border) !important;
  box-shadow: 0 1px 3px rgba(15,23,42,.04) !important;
}
.logo-text { color: var(--c-navy) !important; font-weight: 800 !important; }
.logo-mark {
  background: var(--c-navy) !important;
  color: #fff !important;
  border-radius: 8px !important;
  font-weight: 800 !important;
}
.nav-menu a { color: var(--c-text) !important; font-weight: 500 !important; }
.nav-menu a:hover, .nav-item.active > a { color: var(--c-blue) !important; }
.nav-phone { color: var(--c-navy) !important; font-weight: 700 !important; }

/* Поиск в шапке */
.nav-search {
  background: var(--c-bg) !important;
  border: 1.5px solid var(--c-border) !important;
  border-radius: 10px !important;
}
.nav-search:focus-within {
  border-color: var(--c-blue) !important;
  box-shadow: 0 0 0 3px rgba(37,99,235,.1) !important;
}
.nav-search-btn {
  background: var(--c-blue) !important;
  color: #fff !important;
}
.nav-search-btn:hover { background: var(--c-blue-dark) !important; }

/* --- КНОПКИ --- */
.btn-kp, .btn-primary {
  background: var(--c-blue) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 10px !important;
  font-weight: 700 !important;
  box-shadow: 0 1px 2px rgba(37,99,235,.2) !important;
  transition: all .2s !important;
}
.btn-kp:hover, .btn-primary:hover {
  background: var(--c-blue-dark) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 12px rgba(37,99,235,.3) !important;
}
.btn-find {
  background: transparent !important;
  color: #fff !important;
  border: 1.5px solid rgba(255,255,255,.55) !important;
  border-radius: 10px !important;
  font-weight: 700 !important;
}
.btn-find:hover { background: rgba(255,255,255,.12) !important; }
.btn-outline {
  border: 1.5px solid var(--c-accent) !important;
  color: var(--c-accent) !important;
  border-radius: 10px !important;
  font-weight: 700 !important;
  background: transparent !important;
}
.btn-outline:hover { background: rgba(6,182,212,.08) !important; }
.wt-auth-header-btn {
  background: #fff !important;
  border: 1.5px solid var(--c-border) !important;
  color: var(--c-text-dark) !important;
  border-radius: 10px !important;
  font-weight: 600 !important;
}
.wt-auth-header-btn:hover { border-color: var(--c-blue) !important; color: var(--c-blue) !important; background: #fff !important; }

/* --- HERO --- */
.hero h1 { color: #fff !important; font-weight: 800 !important; letter-spacing: -.02em !important; }
.hero h1 span { color: var(--c-accent) !important; }
.hero p { color: #CBD5E1 !important; }
.hero-sub { border-left: 3px solid var(--c-accent) !important; color: #94A3B8 !important; }
.h-stat-inline strong { color: var(--c-accent) !important; font-weight: 800 !important; }
.h-stat-inline span { color: #94A3B8 !important; }

/* плашка "цены ориентировочные" */
.hero-note, .price-note {
  background: #EFF6FF !important;
  border-left: 4px solid var(--c-blue) !important;
}

/* --- КАТЕГОРИИ --- */
.shop-cat {
  border: 1px solid var(--c-border) !important;
  border-radius: 14px !important;
  background: #fff !important;
  transition: all .2s !important;
}
.shop-cat:hover {
  border-color: var(--c-blue) !important;
  box-shadow: 0 4px 16px rgba(37,99,235,.1) !important;
  transform: translateY(-2px) !important;
}
.shop-cat.active {
  background: var(--c-navy) !important;
  border-color: var(--c-navy) !important;
}
.shop-cat.active .shop-cat-name { color: #fff !important; }
.shop-cat-name { color: var(--c-text-dark) !important; font-weight: 600 !important; }

/* --- КАРТОЧКИ ТОВАРОВ --- */
.shop-card {
  border: 1px solid var(--c-border) !important;
  border-radius: 14px !important;
  background: #fff !important;
  transition: all .2s !important;
  overflow: hidden !important;
}
.shop-card:hover {
  border-color: var(--c-blue) !important;
  box-shadow: 0 8px 24px rgba(15,23,42,.1) !important;
  transform: translateY(-3px) !important;
}
.shop-card.is-hit { border-color: var(--c-border) !important; }
.shop-card-name, .pm-title { color: var(--c-text-dark) !important; font-weight: 700 !important; }
.shop-card-desc { color: var(--c-text) !important; }
.shop-card-price { color: var(--c-navy) !important; font-weight: 800 !important; }
.shop-card-model { color: #94A3B8 !important; }

/* Бейджи */
.shop-hit-badge {
  background: var(--c-amber) !important;
  color: #fff !important;
  border-radius: 8px !important;
  font-weight: 700 !important;
}
.shop-stock-badge {
  background: var(--c-green) !important;
  color: #fff !important;
  border-radius: 8px !important;
  font-weight: 700 !important;
}
.shop-card-brand {
  background: #fff !important;
  border: 1px solid var(--c-border) !important;
  color: var(--c-text-dark) !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
}

/* Кнопка "В корзину" */
.shop-card-btn {
  background: var(--c-blue) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 8px !important;
  font-weight: 700 !important;
  transition: all .2s !important;
}
.shop-card-btn:hover { background: var(--c-blue-dark) !important; }

/* Заголовок каталога */
.shop-header h2, .shop h2 { color: var(--c-text-dark) !important; font-weight: 800 !important; }
.shop-counter { color: #94A3B8 !important; }

/* --- ССЫЛКИ И АКЦЕНТЫ --- */
.btn-cart { color: var(--c-navy) !important; }
.cart-badge { background: var(--c-amber) !important; color: #fff !important; }

/* ============================================================ */
/* ФОТО ТОВАРОВ + СТИЛЬНАЯ ЗАГЛУШКА (build v21)                  */
/* Фото ищется по артикулу. Нет фото → аккуратный плейсхолдер.  */
/* ============================================================ */
.shop-card-img {
  position: relative;
  aspect-ratio: 4 / 3;
  background: #F1F5F9 !important;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.shop-card-photo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  position: relative;
  z-index: 2;
  background: #fff;
}
/* Заглушка видна только когда фото НЕ загрузилось (.img-error на родителе) */
.shop-card-placeholder {
  position: absolute;
  inset: 0;
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: linear-gradient(135deg, #F8FAFC 0%, #EEF2F7 100%);
}
.shop-card-img.img-error .shop-card-placeholder { display: flex; }
.shop-card-placeholder i {
  font-size: 40px;
  opacity: .35;
}
.shop-card-ph-brand {
  font-size: 12px;
  font-weight: 700;
  color: #94A3B8;
  letter-spacing: .04em;
  text-transform: uppercase;
}
/* Старую эмодзи-иконку прячем (если где-то осталась) */
.shop-card-icon { display: none !important; }

/* Бейдж бренда поверх фото — только когда фото есть */
.shop-card-img:not(.img-error) .shop-card-brand { z-index: 3; }
.shop-card-img.img-error .shop-card-brand { display: none; }

/* Фото в модалке товара */
.pm-photo {
  width: 100%;
  max-height: 320px;
  object-fit: contain;
  background: #fff;
  border-radius: 12px;
}
.pm-img.img-error, .pm-photo-wrap.img-error {
  min-height: 200px;
  background: linear-gradient(135deg, #F8FAFC, #EEF2F7);
  border-radius: 12px;
}

/* ============================================================ */
/* ФИКС ВЫПАДАЮЩЕГО МЕНЮ КАТАЛОГ (build v24)                     */
/* Меню больше не вылезает за левый край, адаптивная ширина.    */
/* ============================================================ */
@media (min-width: 901px) {
  .dropdown {
    left: 0 !important;
    width: min(960px, calc(100vw - 48px)) !important;
    grid-template-columns: 1fr 1fr 1fr 1fr !important;
    border-radius: 12px !important;
    border: 1px solid var(--c-border) !important;
    box-shadow: 0 12px 32px rgba(15,23,42,.12) !important;
    margin-top: 4px !important;
    padding: 1rem 0 !important;
  }
  .dropdown a {
    padding: .3rem 1rem !important;
    line-height: 1.3 !important;
  }
  .dropdown .col-head {
    padding: .5rem 1rem .25rem !important;
  }
  .col-head {
    color: var(--c-blue) !important;
    font-weight: 700 !important;
  }
  .dropdown a:hover {
    color: var(--c-blue) !important;
    background: #EFF6FF !important;
  }
}

/* Заглушка в модалке товара (build v28 - fix) */
.pm-img { position: relative; }
.pm-img .shop-card-placeholder { border-radius: 12px; }
.pm-img.img-error .shop-card-placeholder { display: flex; }
.pm-img:not(.img-error) .shop-card-placeholder { display: none; }

/* ============================================================ */
/* ТАБЛИЦА ТЕХ. ХАРАКТЕРИСТИК в карточке товара (build v32)      */
/* Строгая таблица для закупщиков — никакого сплошного текста.   */
/* ============================================================ */
.pm-specs {
  margin: 1rem 0;
  border: 1px solid var(--c-border, #E2E8F0);
  border-radius: 10px;
  overflow: hidden;
}
.pm-specs-title {
  background: var(--c-navy, #0F172A);
  color: #fff;
  font-weight: 700;
  font-size: 13px;
  padding: 8px 14px;
  letter-spacing: .02em;
}
.pm-specs-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.pm-specs-table tr:nth-child(even) {
  background: #F8FAFC;
}
.pm-specs-table td {
  padding: 8px 14px;
  border-bottom: 1px solid #EEF2F7;
  vertical-align: top;
}
.pm-specs-table tr:last-child td {
  border-bottom: none;
}
.pm-spec-key {
  color: #64748B;
  font-weight: 500;
  width: 45%;
}
.pm-spec-val {
  color: var(--c-text-dark, #1E293B);
  font-weight: 600;
}

/* ============================================================ */
/* МЕГА-МЕНЮ «КАТАЛОГ» — выравнивание под «Каталог брендов»     */
/* (build v36): убрана пустая 4-я колонка, иконки разделов,     */
/* промо-блок с CTA, hover-микроанимации, плавное появление.    */
/* ============================================================ */
@media (min-width: 901px) {
  .dropdown.catalog-mega {
    grid-template-columns: 1fr 1fr 1fr 1.15fr !important;
    width: min(1040px, calc(100vw - 48px)) !important;
    column-gap: 0 !important;
    padding: 1.1rem 0 !important;
    overflow: hidden !important;
    animation: cmIn .18s ease both;
  }
  .catalog-mega > div { animation: cmCol .28s ease both; }
  .catalog-mega > div:nth-child(2) { animation-delay: .04s; }
  .catalog-mega > div:nth-child(3) { animation-delay: .08s; }
  .catalog-mega > div:nth-child(4) { animation-delay: .12s; }

  /* Заголовки разделов с иконкой */
  .catalog-mega .col-head {
    display: flex; align-items: center; gap: .5rem;
    font-size: 11px !important; letter-spacing: .6px;
    padding: .55rem 1.15rem .35rem !important;
  }
  .catalog-mega .col-head + .cat-link { margin-top: .1rem; }
  .catalog-mega .cat-link + .col-head { margin-top: .55rem; }
  .catalog-mega .ch-ic {
    flex: 0 0 auto;
    display: inline-flex; align-items: center; justify-content: center;
    width: 24px; height: 24px; border-radius: 7px;
    background: #EFF4FF; color: var(--c-blue);
  }
  .catalog-mega .ch-ic svg { width: 14px; height: 14px; }

  /* Ссылки категорий */
  .catalog-mega a.cat-link {
    position: relative;
    margin: 0 .55rem; border-radius: 8px;
    padding: .34rem .85rem !important;
    color: var(--c-text-dark) !important; font-weight: 500;
    transition: background .14s ease, color .14s ease, transform .14s ease;
  }
  .catalog-mega a.cat-link:hover {
    background: #EFF4FF !important; color: var(--c-blue) !important;
    transform: translateX(3px);
  }
  .catalog-mega a.cat-link::after {
    content: "→"; position: absolute; right: .8rem; top: 50%;
    transform: translate(-4px, -50%); opacity: 0; font-weight: 700;
    transition: opacity .14s ease, transform .14s ease;
  }
  .catalog-mega a.cat-link:hover::after {
    opacity: 1; transform: translate(0, -50%);
  }

  /* Промо-блок (бывшая пустая колонка) */
  .catalog-mega .cm-promo {
    align-self: stretch;
    margin: -1.1rem 0;
    padding: 1.4rem 1.35rem;
    display: flex; flex-direction: column;
    color: #fff; position: relative; overflow: hidden;
    border-radius: 0 12px 12px 0;
    background: linear-gradient(150deg, var(--c-navy) 0%, #15294A 45%, var(--c-blue) 135%);
  }
  .catalog-mega .cm-promo::before {
    content: ""; position: absolute; right: -45px; top: -45px;
    width: 170px; height: 170px; border-radius: 50%;
    background: radial-gradient(circle, rgba(6,182,212,.30), transparent 70%);
  }
  .catalog-mega .cm-eyebrow {
    font-size: 10px; font-weight: 700; letter-spacing: 1.4px;
    text-transform: uppercase; color: var(--c-accent);
  }
  .catalog-mega .cm-title {
    font-size: 17px; font-weight: 800; line-height: 1.25;
    margin: .55rem 0 .4rem; color: #fff;
  }
  .catalog-mega .cm-sub {
    font-size: 12px; line-height: 1.5; color: #C7D2E4; margin-bottom: 1.1rem;
  }
  .catalog-mega a.cm-btn {
    display: inline-flex; align-items: center; justify-content: center;
    margin: 0 !important; padding: .68rem .9rem !important;
    background: var(--c-blue); color: #fff !important;
    font-weight: 700; font-size: 12.5px; line-height: 1.2;
    border-radius: 9px; text-align: center;
    transition: background .14s ease, color .14s ease;
  }
  .catalog-mega a.cm-btn:hover {
    background: #fff !important; color: var(--c-navy) !important; transform: none;
  }
  .catalog-mega a.cm-btn::after { content: none; }
  .catalog-mega .cm-divider {
    height: 1px; background: rgba(255,255,255,.14); margin: 1.05rem 0 .8rem;
  }
  .catalog-mega .cm-hint { font-size: 11.5px; color: #A9B7CE; }
  .catalog-mega a.cm-link {
    display: inline-block; margin: .25rem 0 0 !important; padding: 0 !important;
    background: transparent !important; color: var(--c-accent) !important;
    font-weight: 700; font-size: 12.5px; transform: none !important;
  }
  .catalog-mega a.cm-link:hover { color: #fff !important; background: transparent !important; }
  .catalog-mega a.cm-link::after { content: none; }
}
@keyframes cmIn  { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: none; } }
@keyframes cmCol { from { opacity: 0; transform: translateY(8px);  } to { opacity: 1; transform: none; } }

/* Мобайл/планшет: промо-блок в обычном потоке, без отрицательных полей */
@media (max-width: 900px) {
  .catalog-mega .cm-promo { margin: .4rem 0 0; border-radius: 10px; padding: 1.1rem; }
  .catalog-mega .col-head { display: flex; align-items: center; gap: .5rem; }
}

/* ============================================================ */
/* ФИКС МОБИЛЬНОЙ ВЁРСТКИ (build v37)                            */
/* Мобильные медиазапросы в этом файле стоят ВЫШE базовых правил */
/* и перебивались ими (равная специфичность → побеждает позднее).*/
/* Из-за этого .about-body / .about-numbers / .portfolio-grid    */
/* оставались многоколоночными на телефоне, и контент уезжал     */
/* за правый край (срезался из-за overflow-x:clip). Переопределяем */
/* в конце файла, чтобы мобильная сетка победила.                */
/* ============================================================ */
@media (max-width: 1023px){
  .about-body{ grid-template-columns: minmax(0,1fr) !important; }
  .about-numbers{ grid-template-columns: repeat(2, minmax(0,1fr)) !important; }
  .about-values{ grid-template-columns: repeat(2, minmax(0,1fr)) !important; }
  .client-tiles{ grid-template-columns: repeat(2, minmax(0,1fr)) !important; }
  .portfolio-grid{ grid-template-columns: repeat(2, minmax(0,1fr)) !important; }
}
@media (max-width: 640px){
  .about-values{ grid-template-columns: minmax(0,1fr) !important; }
  .portfolio-grid{ grid-template-columns: minmax(0,1fr) !important; }
}
/* длинные слова в плитках клиентов не должны вылезать за край плитки */
.client-tile strong{ overflow-wrap:anywhere; word-break:break-word; }

/* ============================================================ */
/* СЕКЦИЯ «СЕРВИСЫ» — оптовый закуп из Китая для B2B (build v38) */
/* Тёмная стилистика WT: navy фон, бирюзово-синие акценты.       */
/* ============================================================ */
.services-section{
  position:relative; overflow:hidden; color:#fff;
  padding:4rem 2rem;
  background:linear-gradient(160deg,#0b1524 0%, var(--c-navy) 45%, #0e2138 100%);
}
.services-section::before{
  content:""; position:absolute; top:-90px; right:-70px;
  width:420px; height:420px; border-radius:50%;
  background:radial-gradient(circle, rgba(6,182,212,.16), transparent 70%);
  pointer-events:none;
}
.svc-inner{
  position:relative; z-index:1; max-width:1180px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1.12fr; gap:2.5rem; align-items:start;
}
.svc-left{ position:relative; }
.svc-title{ font-size:34px; font-weight:800; letter-spacing:-.5px; margin:0 0 1.5rem; }

.svc-feature{
  position:relative; z-index:1;
  display:flex; gap:14px; margin-bottom:1rem;
  padding:1.1rem 1.2rem; border-radius:12px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.09); border-left:3px solid var(--c-accent);
  transition:background .15s ease, border-color .15s ease;
}
.svc-feature:hover{ background:rgba(6,182,212,.06); border-left-color:var(--c-blue); }
.svc-feat-ic{
  flex:0 0 auto; width:40px; height:40px; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(6,182,212,.12); color:var(--c-accent);
}
.svc-feat-ic svg{ width:21px; height:21px; }
.svc-feature h3{ font-size:15px; font-weight:700; color:#fff; margin:0 0 .35rem; }
.svc-feature ul{ margin:0; padding-left:1.05rem; display:flex; flex-direction:column; gap:.25rem; }
.svc-feature li, .svc-feature p{ font-size:12.5px; line-height:1.55; color:#A7B4C7; margin:0; }

.svc-knot{ position:absolute; left:-34px; bottom:-40px; width:300px; height:300px; opacity:.7; pointer-events:none; z-index:0; }

.svc-card{
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.1); border-radius:16px; padding:1.5rem;
}
.svc-card-title{ font-size:20px; font-weight:800; margin:0 0 1rem; }
.svc-switch{
  display:flex; gap:4px; margin-bottom:.9rem; padding:4px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08); border-radius:12px;
}
.svc-seg{
  flex:1; border:none; background:none; cursor:pointer;
  font-family:inherit; font-size:13.5px; font-weight:700; color:#C7D2E4;
  padding:.6rem; border-radius:9px; transition:all .15s ease;
}
.svc-seg.is-active{ background:#fff; color:var(--c-navy); box-shadow:0 2px 8px rgba(0,0,0,.28); }
.svc-note{ display:flex; align-items:center; gap:8px; font-size:12.5px; color:#A7B4C7; margin-bottom:1rem; }
.svc-badge{ font-size:10px; font-weight:800; letter-spacing:.4px; text-transform:uppercase; padding:3px 8px; border-radius:6px; white-space:nowrap; }
.svc-badge.green{ background:rgba(22,163,74,.18); color:#4ade80; }
.svc-badge.cyan{ background:transparent; border:1px solid rgba(6,182,212,.5); color:var(--c-accent); }

.svc-list{ display:flex; flex-direction:column; gap:.5rem; margin-bottom:1.1rem; }
.svc-item{
  display:block; padding:.85rem 1rem; border-radius:11px;
  background:rgba(255,255,255,.025); border:1px solid rgba(255,255,255,.08);
  transition:background .15s ease, border-color .15s ease;
}
.svc-item-head{ display:flex; align-items:center; gap:10px; }
.svc-item-name{ flex:1; font-size:14px; font-weight:700; color:#fff; line-height:1.3; }
.svc-item-desc{ font-size:12px; line-height:1.5; color:#9FAEC2; margin:.45rem 0 0; }
.svc-item ul{ margin:.45rem 0 0; padding-left:1.05rem; display:flex; flex-direction:column; gap:.2rem; }
.svc-item li{ font-size:12px; line-height:1.45; color:#9FAEC2; }

.svc-item.is-toggle{ cursor:pointer; }
.svc-toggle{ position:relative; flex:0 0 auto; width:40px; height:22px; }
.svc-toggle input{ position:absolute; inset:0; width:100%; height:100%; margin:0; opacity:0; cursor:pointer; }
.svc-knob{ position:absolute; inset:0; border-radius:999px; background:rgba(255,255,255,.18); transition:background .15s ease; }
.svc-knob::after{ content:""; position:absolute; top:2px; left:2px; width:18px; height:18px; border-radius:50%; background:#fff; transition:transform .18s ease; }
.svc-toggle input:checked ~ .svc-knob{ background:var(--c-accent); }
.svc-toggle input:checked ~ .svc-knob::after{ transform:translateX(18px); }
.svc-item.is-toggle.is-on{ border-color:rgba(6,182,212,.45); background:rgba(6,182,212,.07); }

.svc-cta{
  display:block; width:100%; border:none; cursor:pointer;
  font-family:inherit; font-size:14px; font-weight:700; color:#fff;
  padding:.95rem; border-radius:11px; background:var(--c-blue); transition:background .15s ease;
}
.svc-cta:hover{ background:var(--c-blue-dark); }

.services-section[data-mode="bundle"] .svc-list-single{ display:none; }
.services-section[data-mode="single"] .svc-list-bundle{ display:none; }

@media (max-width:900px){
  .services-section{ padding:2.5rem 1rem; }
  .svc-inner{ grid-template-columns:1fr; gap:1.5rem; }
  .svc-title{ font-size:26px; margin-bottom:1rem; }
  .svc-knot{ display:none; }
  .svc-card{ padding:1.15rem; }
}

/* ============================================================ */
/* СЕКЦИЯ FAQ — частые вопросы + форма заявки (build v39)        */
/* Тёмная стилистика WT, бирюзовый акцент.                       */
/* ============================================================ */
.faq-section{
  position:relative; overflow:hidden; color:#fff; padding:4rem 2rem;
  background:linear-gradient(180deg,#0b1524 0%, #0c1a2e 100%);
}
.faq-section::before{
  content:""; position:absolute; left:-80px; bottom:-90px;
  width:420px; height:420px; border-radius:50%;
  background:radial-gradient(circle, rgba(6,182,212,.14), transparent 70%);
  pointer-events:none;
}
.faq-inner{
  position:relative; z-index:1; max-width:1180px; margin:0 auto;
  display:grid; grid-template-columns:1.4fr .9fr; gap:2.5rem; align-items:start;
}
.faq-title{ font-size:34px; font-weight:800; letter-spacing:-.5px; margin:0 0 1.5rem; }

.faq-item{
  border:1px solid rgba(255,255,255,.1); border-radius:12px;
  background:rgba(255,255,255,.035); margin-bottom:.75rem;
  transition:border-color .15s ease, background .15s ease;
}
.faq-item.open{ border-color:rgba(6,182,212,.4); background:rgba(6,182,212,.05); }
.faq-q{
  width:100%; display:flex; align-items:center; justify-content:space-between; gap:14px;
  background:none; border:none; cursor:pointer; text-align:left;
  font-family:inherit; font-size:15px; font-weight:700; color:#fff;
  padding:1.1rem 1.2rem; line-height:1.35;
}
.faq-chev{ flex:0 0 auto; width:20px; height:20px; color:#9FAEC2; transition:transform .25s ease, color .15s ease; }
.faq-item.open .faq-chev{ transform:rotate(180deg); color:var(--c-accent); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.faq-item.open .faq-a{ max-height:420px; }
.faq-a-inner{ padding:0 1.2rem 1.15rem; }
.faq-a-inner p{ font-size:13px; line-height:1.7; color:#AEBACD; margin:0; }
.faq-tag{ display:inline-block; margin-top:.7rem; font-size:11px; font-weight:600; color:var(--c-accent); }

.faq-cta{
  border:1px solid rgba(6,182,212,.35); border-radius:16px; padding:1.6rem 1.5rem;
  background:linear-gradient(160deg, rgba(6,182,212,.07), rgba(255,255,255,.03));
}
.faq-cta h3{ font-size:24px; font-weight:800; margin:0 0 .5rem; }
.faq-cta>p{ font-size:13px; color:#AEBACD; margin:0 0 1.1rem; line-height:1.5; }
.faq-tags{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:1.2rem; }
.faq-tags span{
  font-size:11.5px; font-weight:600; color:#C7D2E4;
  border:1px solid rgba(255,255,255,.16); border-radius:999px; padding:5px 11px; white-space:nowrap;
}
.faq-input{
  width:100%; box-sizing:border-box; margin-bottom:.7rem;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.14); border-radius:10px;
  padding:.85rem 1rem; font-family:inherit; font-size:14px; color:#fff; outline:none;
  transition:border-color .15s ease, background .15s ease;
}
.faq-input::placeholder{ color:#7E8CA1; }
.faq-input:focus{ border-color:var(--c-accent); background:rgba(6,182,212,.06); }
.faq-hint{ font-size:11.5px; color:#8C99AD; margin:-.2rem 0 1rem; }
.faq-submit{
  width:100%; border:none; cursor:pointer; font-family:inherit; font-size:14.5px; font-weight:800;
  color:var(--c-navy); background:var(--c-accent); padding:.95rem; border-radius:11px;
  transition:filter .15s ease;
}
.faq-submit:hover{ filter:brightness(1.08); }
.faq-note{ font-size:11px; color:#8C99AD; margin-top:.8rem; line-height:1.5; }

@media (max-width:900px){
  .faq-section{ padding:2.5rem 1rem; }
  .faq-inner{ grid-template-columns:1fr; gap:1.5rem; }
  .faq-title{ font-size:26px; margin-bottom:1rem; }
  .faq-q{ font-size:14px; padding:1rem; }
}

/* ============================================================ */
/* МЕГА-МЕНЮ «ЛОГИСТИКА» и «ОБОРУДОВАНИЕ» — 3 колонки (build v41) */
/* Базовый .dropdown форсит 4 колонки; для этих меню — ровно 3,  */
/* чтобы не оставалось пустого столбца.                          */
/* ============================================================ */
@media (min-width: 901px){
  .dropdown.mega-3{
    grid-template-columns: repeat(3, 1fr) !important;
    width: min(900px, calc(100vw - 48px)) !important;
  }
}

/* ============================================================ */
/* МОБИЛЬНАЯ НИЖНЯЯ ПАНЕЛЬ (tab bar) — только телефон (build v42) */
/* ============================================================ */
.mtabs{ display:none; }
@media (max-width: 768px){
  .mtabs{
    display:flex; position:fixed; left:0; right:0; bottom:0; z-index:8000;
    background:#fff; border-top:1px solid var(--c-border, #E2E8F0);
    box-shadow:0 -2px 12px rgba(15,23,42,.08);
    padding-bottom:env(safe-area-inset-bottom, 0px);
  }
  .mtab{
    flex:1; display:flex; flex-direction:column; align-items:center; gap:3px;
    padding:8px 4px 7px; text-decoration:none;
    color:#64748B; font-size:11px; font-weight:600; line-height:1;
    -webkit-tap-highlight-color:transparent;
  }
  .mtab svg{ width:23px; height:23px; }
  .mtab.is-active{ color:var(--c-blue, #2563EB); }
  .mtab-ic{ position:relative; display:inline-flex; }
  .mtab-badge{
    position:absolute; top:-6px; right:-9px;
    min-width:16px; height:16px; padding:0 4px; box-sizing:border-box;
    background:#EF4444; color:#fff; font-size:10px; font-weight:700; line-height:16px;
    border-radius:999px; text-align:center; display:none;
  }
  .mtab-badge.visible{ display:block; }

  /* контент не должен прятаться под панелью */
  body{ padding-bottom:62px; }
  /* поднять плавающие кнопки над панелью */
  .wa-float{ bottom:78px; }
  .scroll-top{ bottom:78px; }
}
@media (max-width: 480px){
  /* перебиваем прежние правила bottom:16px для плавающих кнопок */
  .wa-float{ bottom:76px; }
  .scroll-top{ bottom:76px; }
}

/* ============================================================ */
/* Меню «Каталог брендов»: тот же стиль, что у «Каталога»,      */
/* но уже и со сдвигом влево — оно правее в навигации (build v47)*/
/* ============================================================ */
@media (min-width: 901px){
  .dropdown.brands-mega{
    width: min(900px, calc(100vw - 360px)) !important;
    left: -150px !important;
  }
}
