/* ========== NORMETRA — shared styles (Montserrat + navy + yellow) ========== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
:root{
  --navy:#212d45;
  --navy-2:#2a3654;
  --navy-3:#384364;
  --yellow:#ffc03d;
  --yellow-dark:#f8b526;
  --yellow-soft:#fff4d9;
  --bg:#ffffff;
  --bg-soft:#F2F5F7;
  --bg-soft-2:#F5F5F5;
  --text:#4b4f58;
  --heading:#212d45;
  --gray:#6b7280;
  --gray-2:#9aa0a6;
  --line:#E1E1E1;
  --line-2:#eaeaea;
  --line-dk:rgba(255,255,255,.10);
  --font-head:'Montserrat',sans-serif;
  --font-body:'Open Sans',sans-serif;
}
html{scroll-behavior:smooth;}
body{font-family:var(--font-body);color:var(--text);background:var(--bg);line-height:1.7;font-weight:400;font-size:16px;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img,svg{display:block;max-width:100%;}
.container{max-width:1280px;margin:0 auto;padding:0 32px;}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--font-head);font-weight:700;font-size:0.88rem;letter-spacing:0.04em;text-transform:uppercase;padding:16px 32px;border:2px solid transparent;border-radius:4px;cursor:pointer;transition:.22s;}
.btn svg{width:18px;height:18px;}
.btn-sm{padding:11px 20px;font-size:.78rem;}
.btn-yellow{background:var(--yellow);color:var(--navy);}
.btn-yellow:hover{background:var(--yellow-dark);transform:translateY(-2px);box-shadow:0 10px 22px rgba(255,192,61,.35);}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.55);}
.btn-outline:hover{background:var(--yellow);color:var(--navy);border-color:var(--yellow);}
.btn-outline-dark{background:transparent;color:var(--navy);border-color:var(--navy);}
.btn-outline-dark:hover{background:var(--navy);color:#fff;}
.section-title{font-family:var(--font-head);font-weight:700;font-size:clamp(2rem,3.6vw,2.9rem);line-height:1.22;letter-spacing:-0.01em;color:var(--heading);}
.section-title .accent{color:var(--yellow-dark);}
.section-pad{padding:clamp(70px,8vw,110px) 0;}
.icon{width:24px;height:24px;display:inline-block;}
.eyebrow{display:inline-flex;align-items:center;gap:14px;font-family:var(--font-head);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.22em;color:var(--yellow-dark);margin-bottom:18px;}
.eyebrow::before{content:"";width:42px;height:2px;background:var(--yellow-dark);display:inline-block;}

/* ─── TOP BAR ─── */
.topbar{background:var(--navy);color:#cdd2dc;font-size:0.86rem;}
.topbar .container{display:flex;justify-content:space-between;align-items:center;padding:12px 32px;}
.topbar-info{display:flex;gap:30px;flex-wrap:wrap;align-items:center;}
.topbar-info span{display:flex;align-items:center;gap:8px;}
.topbar-info span b{color:#fff;font-weight:600;}
.topbar-info .icon{width:16px;height:16px;color:var(--yellow);}
.topbar-social{display:flex;gap:20px;}
.topbar-social a{color:#cdd2dc;transition:.18s;font-weight:500;}
.topbar-social a:hover{color:var(--yellow);}

/* ─── HEADER ─── */
header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:100;}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:20px;flex-wrap:nowrap;}
.logo{display:flex;align-items:center;gap:13px;}
.logo-mark{width:48px;height:48px;flex-shrink:0;}
.logo-text .lt-main{font-family:var(--font-head);font-weight:800;font-size:1.5rem;letter-spacing:-0.01em;line-height:1;color:var(--navy);}
.logo-text .lt-main span{color:#4a6fb5;}
.logo-text .lt-sub{font-family:var(--font-head);font-weight:600;font-size:0.7rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--gray);margin-top:5px;}
header nav,nav.main-nav{display:flex;gap:0;flex-shrink:1;min-width:0;}
header nav a,nav.main-nav a{font-family:var(--font-head);font-weight:600;font-size:0.88rem;letter-spacing:0.01em;padding:10px 12px;color:var(--navy);transition:.18s;white-space:nowrap;}
header nav a:hover,header nav a.active,nav.main-nav a:hover,nav.main-nav a.active{color:var(--yellow-dark);}
.logo{flex-shrink:0;}
.header-cta{flex-shrink:0;}
.header-cta{display:flex;align-items:center;gap:20px;}
.header-phone-wrap{text-align:right;}
.header-phone{font-family:var(--font-head);font-weight:700;font-size:1.15rem;color:var(--navy);white-space:nowrap;line-height:1;}
.header-phone-note{font-family:var(--font-head);font-size:0.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gray);margin-top:4px;font-weight:600;}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:8px;}
.burger span{width:28px;height:3px;background:var(--navy);}

/* ─── HERO (home page) ─── */
.hero{position:relative;background:var(--navy);color:#fff;overflow:hidden;}
.hero::before{content:"";position:absolute;inset:0;z-index:0;background:linear-gradient(105deg,rgba(33,45,69,.94) 0%,rgba(33,45,69,.78) 45%,rgba(33,45,69,.5) 100%),url('/wp-content/uploads/normetra-catalog/_unsplash_hero.jpg') center/cover;}
.hero-stripe{position:absolute;top:0;left:0;right:0;height:6px;background:repeating-linear-gradient(45deg,var(--yellow) 0 26px,var(--navy) 26px 52px);z-index:3;}
.hero-inner{position:relative;z-index:2;padding:clamp(80px,11vw,150px) 0 clamp(150px,16vw,220px);max-width:740px;}
.hero h1{font-family:var(--font-head);font-weight:800;font-size:clamp(2.4rem,5vw,4rem);line-height:1.12;letter-spacing:-0.015em;margin-bottom:24px;}
.hero h1 em{color:var(--yellow);font-style:normal;}
.hero-lead{font-size:1.1rem;color:#d4d8e1;margin-bottom:36px;max-width:560px;line-height:1.7;}
.hero-magnets{display:flex;gap:18px;flex-wrap:wrap;}
.magnet{flex:1;min-width:262px;background:rgba(42,54,84,.78);backdrop-filter:blur(2px);border:1px solid var(--line-dk);padding:26px;border-radius:6px;transition:.22s;}
.magnet:hover{border-color:var(--yellow);transform:translateY(-3px);}
.magnet-title{font-family:var(--font-head);font-weight:700;font-size:1.12rem;margin-bottom:9px;display:flex;align-items:center;gap:11px;color:#fff;}
.magnet-title .icon{width:26px;height:26px;color:var(--yellow);flex-shrink:0;}
.magnet-desc{font-size:0.92rem;color:#b5bccc;margin-bottom:18px;}
.magnet .btn{width:100%;padding:13px 18px;font-size:0.82rem;}

/* ─── PAGE BANNER (внутренние страницы) ─── */
.page-banner{position:relative;background:var(--navy);color:#fff;padding:60px 0 56px;overflow:hidden;}
.page-banner::before{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(33,45,69,.95) 0%,rgba(33,45,69,.78) 60%,rgba(33,45,69,.55) 100%),url('/wp-content/uploads/normetra-catalog/_unsplash_banner.jpg') center/cover;opacity:.95;}
.page-banner-stripe{position:absolute;top:0;left:0;right:0;height:6px;background:repeating-linear-gradient(45deg,var(--yellow) 0 26px,var(--navy) 26px 52px);z-index:3;}
.page-banner-inner{position:relative;z-index:2;}
.page-banner h1{font-family:var(--font-head);font-weight:800;font-size:clamp(1.9rem,3.6vw,3rem);line-height:1.15;letter-spacing:-0.015em;}
.page-banner h1 em{color:var(--yellow);font-style:normal;}
.page-banner-lead{margin-top:14px;color:#cfd3de;max-width:680px;font-size:1.02rem;}

/* ─── BREADCRUMBS ─── */
.breadcrumbs{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-family:var(--font-head);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:#cfd3de;margin-bottom:18px;}
.breadcrumbs a{color:#cfd3de;transition:.18s;}
.breadcrumbs a:hover{color:var(--yellow);}
.breadcrumbs .sep{color:var(--yellow);}
.breadcrumbs .current{color:#fff;}

/* ─── STATS ─── */
.stats{position:relative;z-index:5;margin-top:-100px;padding-bottom:clamp(40px,5vw,72px);}
.stats-card{display:grid;grid-template-columns:0.95fr 1.05fr;background:#fff;box-shadow:0 30px 60px -10px rgba(33,45,69,.22);border-radius:6px;overflow:hidden;}
.stats-left{background:var(--yellow);color:var(--navy);padding:52px 50px;display:flex;flex-direction:column;}
.stats-eyebrow{font-family:var(--font-head);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.22em;margin-bottom:22px;color:rgba(33,45,69,.78);}
.stats-heading{font-family:var(--font-head);font-weight:700;font-size:1.95rem;line-height:1.2;margin-bottom:20px;color:var(--navy);letter-spacing:-0.01em;}
.stats-lead{font-size:.98rem;color:rgba(33,45,69,.82);margin-bottom:34px;max-width:430px;line-height:1.65;}
.stats-btn{background:var(--navy);color:#fff;padding:15px 30px;margin-top:auto;align-self:flex-start;border-color:var(--navy);}
.stats-btn:hover{background:#15203b;border-color:#15203b;box-shadow:0 10px 22px rgba(33,45,69,.3);}
.stats-right{display:grid;grid-template-columns:1fr 1fr;}
.stats-right .stat{padding:44px 40px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff;}
.stats-right .stat:nth-child(2n){border-right:none;}
.stats-right .stat:nth-child(n+3){border-bottom:none;}
.stats-right .stat-num{font-family:var(--font-head);font-weight:700;font-size:2.4rem;color:var(--navy);line-height:1;letter-spacing:-0.01em;}
.stats-right .stat-label{font-size:.93rem;color:var(--gray);margin-top:14px;font-weight:400;line-height:1.55;}

/* ─── SECTION HEAD ─── */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:50px;gap:32px;flex-wrap:wrap;}
.sec-head-text{max-width:780px;}

/* ─── ADVANTAGES ─── */
.adv{background:var(--navy);color:#fff;overflow:hidden;}
.adv .section-title{color:#fff;}
.adv .section-title .accent{color:var(--yellow);}
.adv-head{margin-bottom:46px;}
.adv-board{display:grid;grid-template-columns:1fr 1.55fr;gap:32px;align-items:stretch;}
.adv-tabs{display:flex;flex-direction:column;gap:6px;}
.adv-tab{display:flex;gap:18px;align-items:center;text-align:left;background:transparent;border:none;border-left:2px solid var(--line-dk);padding:18px 22px;color:#b5bccc;cursor:pointer;transition:.22s;font-family:var(--font-head);width:100%;border-radius:0 4px 4px 0;}
.adv-tab .at-num{font-weight:700;font-size:.95rem;color:var(--gray-2);letter-spacing:.04em;transition:.22s;flex-shrink:0;width:28px;}
.adv-tab .at-title{font-weight:600;font-size:1rem;letter-spacing:0;color:#dee2eb;transition:.22s;}
.adv-tab:hover{border-left-color:rgba(255,192,61,.6);background:rgba(255,255,255,.03);}
.adv-tab:hover .at-title{color:#fff;}
.adv-tab.active{border-left-color:var(--yellow);background:var(--navy-2);}
.adv-tab.active .at-num{color:var(--yellow);}
.adv-tab.active .at-title{color:#fff;}
.adv-feature{position:relative;background:var(--navy-2);border:1px solid var(--line-dk);overflow:hidden;display:grid;grid-template-columns:1fr 0.78fr;min-height:360px;border-radius:6px;}
.adv-feature-text-side{padding:48px 44px 28px;display:flex;flex-direction:column;min-width:0;}
.adv-feature-photo{position:relative;background:#0e1424;overflow:hidden;}
.adv-feature-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .55s ease;}
.adv-feature-photo img.active{opacity:1;}
.adv-feature-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(42,54,84,.95) 0%,rgba(42,54,84,.3) 25%,rgba(42,54,84,0) 60%);pointer-events:none;}
.adv-progress{position:absolute;top:0;left:0;height:3px;background:var(--yellow);width:0;z-index:3;}
.adv-progress.run{animation:advProg var(--adv-int,4800ms) linear forwards;}
@keyframes advProg{from{width:0;}to{width:100%;}}
.adv-feature:hover .adv-progress.run{animation-play-state:paused;}
.adv-feature-icon{width:68px;height:68px;background:rgba(255,192,61,.15);display:flex;align-items:center;justify-content:center;margin-bottom:24px;flex-shrink:0;border-radius:6px;}
.adv-feature-icon .icon{width:34px;height:34px;color:var(--yellow);}
.adv-feature-title{font-family:var(--font-head);font-weight:700;font-size:1.7rem;margin-bottom:14px;line-height:1.2;color:#fff;letter-spacing:-0.01em;}
.adv-feature-text{font-size:1rem;color:#b5bccc;line-height:1.7;}
.adv-fade{animation:advFade .5s ease;}
@keyframes advFade{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}
.adv-controls{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:26px;border-top:1px solid var(--line-dk);}
.adv-counter{font-family:var(--font-head);font-size:.95rem;color:var(--gray-2);letter-spacing:.05em;display:flex;align-items:baseline;gap:6px;}
.adv-counter b{color:#fff;font-size:1.7rem;font-weight:700;}
.adv-nav{display:flex;gap:10px;}
.adv-arrow{width:48px;height:48px;border:1.5px solid rgba(255,255,255,.2);background:transparent;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.18s;border-radius:4px;}
.adv-arrow:hover{background:var(--yellow);border-color:var(--yellow);color:var(--navy);}
.adv-arrow .icon{width:18px;height:18px;}

/* ─── GALLERY ─── */
.gallery{background:var(--bg-soft);}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:24px;}
.gal-tile{position:relative;overflow:hidden;background:var(--navy);display:block;border-radius:6px;}
.gal-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:opacity .55s ease,transform .55s ease;}
.gal-tile:hover img{transform:scale(1.06);}
.gal-tile img.fading{opacity:0;}
.gal-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(33,45,69,0) 55%,rgba(33,45,69,.55) 100%);pointer-events:none;}
.gal-tile--tall{grid-row:span 2;}
.gal-tile--wide{grid-column:span 2;}

/* ─── SERVICES CARDS ─── */
.services{background:var(--bg-soft);}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;grid-auto-rows:1fr;}
.svc-card{background:#fff;border:1px solid var(--line);transition:.22s;cursor:pointer;display:flex;flex-direction:column;height:100%;border-radius:6px;overflow:hidden;}
.svc-card:hover{transform:translateY(-6px);box-shadow:0 18px 38px rgba(33,45,69,.13);border-color:transparent;}
.svc-img{width:100%;overflow:hidden;position:relative;aspect-ratio:4/3;background:var(--bg-soft);}
.svc-img img{width:100%;height:100%;object-fit:cover;transition:.5s;}
.svc-card:hover .svc-img img{transform:scale(1.07);}
.svc-ico-badge{position:absolute;left:0;top:0;width:60px;height:60px;background:var(--yellow);color:var(--navy);display:flex;align-items:center;justify-content:center;z-index:2;}
.svc-ico-badge .icon{width:30px;height:30px;}
.svc-body{padding:28px 28px 26px;display:flex;flex-direction:column;flex:1;}
.svc-card h3{font-family:var(--font-head);font-weight:700;font-size:1.3rem;margin-bottom:12px;color:var(--heading);letter-spacing:-0.005em;}
.svc-card p{font-size:0.94rem;color:var(--text);margin-bottom:20px;flex:1;line-height:1.7;}
.svc-link{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-head);font-weight:700;font-size:0.85rem;letter-spacing:.05em;text-transform:uppercase;color:var(--navy);transition:.18s;}
.svc-link .icon{width:17px;height:17px;color:var(--yellow-dark);transition:.18s;}
.svc-card:hover .svc-link{color:var(--yellow-dark);}
.svc-card:hover .svc-link .icon{transform:translateX(4px);color:var(--navy);}

/* ─── CATALOG (hero на главной) ─── */
.catalog{background:var(--navy);color:#fff;}
.catalog .section-title{color:#fff;}
.catalog .section-title .accent{color:var(--yellow);}
.cat-btn{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.4);}
.cat-btn:hover{background:var(--yellow);border-color:var(--yellow);color:var(--navy);}
.catalog-grid{display:grid;grid-template-columns:1.25fr 1fr 1fr;grid-template-rows:296px 296px;gap:22px;}
.cat-item{position:relative;overflow:hidden;background:var(--navy-2);display:block;min-height:296px;border:1px solid rgba(255,255,255,.06);transition:border-color .2s;border-radius:6px;}
.cat-item:hover{border-color:rgba(255,192,61,.6);}
.cat-item--hero{grid-column:1/2;grid-row:1/3;}
.cat-item--wide{grid-column:2/4;grid-row:1/2;}
.cat-item--hero .cb-title{font-size:1.65rem;}
.cat-item img{width:100%;height:100%;object-fit:cover;opacity:.6;transition:.45s;}
.cat-item:hover img{opacity:.42;transform:scale(1.06);}
.cat-body{position:absolute;left:0;right:0;bottom:0;padding:26px;color:#fff;}
.cat-body .cb-title{font-family:var(--font-head);font-weight:700;font-size:1.25rem;line-height:1.2;letter-spacing:-0.005em;}
.cat-body .cb-note{font-size:0.88rem;color:var(--yellow);margin-top:6px;font-weight:600;}
.cat-corner{position:absolute;right:22px;top:22px;width:42px;height:42px;border:1.6px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;transition:.2s;border-radius:4px;}
.cat-corner .icon{width:20px;height:20px;color:#fff;}
.cat-item:hover .cat-corner{background:var(--yellow);border-color:var(--yellow);}
.cat-item:hover .cat-corner .icon{color:var(--navy);}

/* ─── CATALOG PAGE (фильтры + сетка карточек) ─── */
.catalog-section{background:var(--bg-soft);}
.cat-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:38px;}
.cat-filter{font-family:var(--font-head);font-weight:700;font-size:.85rem;letter-spacing:.04em;text-transform:uppercase;padding:12px 22px;background:#fff;border:1.5px solid var(--line);color:var(--navy);cursor:pointer;border-radius:4px;transition:.18s;display:inline-flex;align-items:center;gap:9px;}
.cat-filter:hover{border-color:var(--yellow);color:var(--yellow-dark);}
.cat-filter.active{background:var(--yellow);border-color:var(--yellow);color:var(--navy);}
.cat-filter .count{font-size:.72rem;background:var(--bg-soft);color:var(--gray);padding:2px 8px;border-radius:10px;font-weight:600;}
.cat-filter.active .count{background:var(--navy);color:#fff;}
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.product-card{background:#fff;border:1px solid var(--line);border-radius:6px;overflow:hidden;display:flex;flex-direction:column;transition:.22s;}
.product-card:hover{transform:translateY(-6px);box-shadow:0 22px 44px rgba(33,45,69,.13);border-color:transparent;}
.product-card-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--bg-soft);}
.product-card-img img{width:100%;height:100%;object-fit:cover;transition:.5s;}
.product-card:hover .product-card-img img{transform:scale(1.06);}
.product-card-tag{position:absolute;left:14px;top:14px;background:var(--navy);color:#fff;font-family:var(--font-head);font-weight:700;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;padding:6px 12px;border-radius:3px;z-index:2;}
.product-card-tag.tag-yellow{background:var(--yellow);color:var(--navy);}
.product-card-body{padding:24px 26px 26px;display:flex;flex-direction:column;flex:1;gap:14px;}
.product-card-cat{font-family:var(--font-head);font-weight:700;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--yellow-dark);}
.product-card h3{font-family:var(--font-head);font-weight:700;font-size:1.22rem;line-height:1.25;letter-spacing:-0.005em;color:var(--heading);min-height:60px;}
.product-card-meta{display:flex;flex-direction:column;gap:6px;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.product-card-meta div{display:flex;justify-content:space-between;gap:10px;align-items:baseline;font-size:.86rem;flex-wrap:wrap;}
.product-card-meta div span:first-child{color:var(--gray);min-width:0;}
.product-card-meta div b{color:var(--navy);font-family:var(--font-head);font-weight:700;text-align:right;min-width:0;}
.product-card-price{display:flex;justify-content:space-between;align-items:center;margin-top:auto;gap:14px;}
.product-card-price .pcp-num{font-family:var(--font-head);font-weight:700;color:var(--yellow-dark);font-size:1.3rem;line-height:1;}
.product-card-price .pcp-suffix{font-size:.78rem;color:var(--gray);display:block;font-weight:500;margin-top:4px;}
.product-card-link{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-head);font-weight:700;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--navy);padding:10px 14px;border:1.5px solid var(--navy);border-radius:4px;transition:.18s;}
.product-card-link svg{width:14px;height:14px;}
.product-card-link:hover{background:var(--navy);color:#fff;}
.product-card.hidden{display:none;}

/* ─── PRODUCT DETAIL (карточка товара/услуги) ─── */
.prod-detail{padding:60px 0 clamp(60px,7vw,100px);background:#fff;}
.prod-detail-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:50px;align-items:start;}
.prod-gallery{position:sticky;top:96px;}
.prod-gallery-main{aspect-ratio:4/3;background:var(--bg-soft);border-radius:6px;overflow:hidden;position:relative;}
.prod-gallery-main img{width:100%;height:100%;object-fit:cover;}
.prod-gallery-tag{position:absolute;left:16px;top:16px;background:var(--yellow);color:var(--navy);font-family:var(--font-head);font-weight:700;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;padding:7px 14px;border-radius:3px;}
.prod-gallery-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:14px;}
.prod-gallery-thumb{aspect-ratio:1/1;background:var(--bg-soft);border-radius:4px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:.18s;}
.prod-gallery-thumb img{width:100%;height:100%;object-fit:cover;}
.prod-gallery-thumb.active{border-color:var(--yellow);}
.prod-cat-label{font-family:var(--font-head);font-weight:700;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--yellow-dark);margin-bottom:14px;}
.prod-title{font-family:var(--font-head);font-weight:800;font-size:clamp(1.7rem,3vw,2.4rem);line-height:1.15;color:var(--heading);letter-spacing:-0.015em;margin-bottom:18px;}
.prod-summary{font-size:1rem;color:var(--text);line-height:1.75;margin-bottom:28px;}
.prod-key-points{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:32px;}
.prod-key{display:flex;align-items:flex-start;gap:12px;padding:14px;background:var(--bg-soft);border-radius:4px;border-left:3px solid var(--yellow);}
.prod-key .icon{width:22px;height:22px;color:var(--yellow-dark);flex-shrink:0;margin-top:2px;}
.prod-key span{font-size:.92rem;line-height:1.5;}
.prod-key b{font-family:var(--font-head);font-weight:700;color:var(--navy);display:block;margin-bottom:2px;font-size:.95rem;}
.prod-price-box{background:var(--bg-soft);border:1px solid var(--line);padding:26px 28px;border-radius:6px;margin-bottom:28px;}
.prod-price-row{display:flex;justify-content:space-between;align-items:baseline;padding:12px 0;border-bottom:1px dashed var(--line);}
.prod-price-row:last-child{border-bottom:none;padding-bottom:0;}
.prod-price-row:first-child{padding-top:0;}
.prod-price-label{font-family:var(--font-head);font-weight:600;color:var(--navy);font-size:.96rem;}
.prod-price-val{font-family:var(--font-head);font-weight:700;font-size:1.2rem;color:var(--yellow-dark);}
.prod-price-val small{font-family:var(--font-body);font-size:.78rem;color:var(--gray);font-weight:500;margin-left:4px;}
.prod-actions{display:flex;flex-wrap:wrap;gap:12px;}
.prod-actions .btn{flex:1;min-width:200px;}

/* ─── PRODUCT TABS ─── */
.prod-tabs-section{background:var(--bg-soft);padding:clamp(60px,7vw,90px) 0;}
.prod-tabs{display:flex;flex-wrap:wrap;gap:0;border-bottom:1.5px solid var(--line);margin-bottom:40px;}
.prod-tab{font-family:var(--font-head);font-weight:700;font-size:.88rem;letter-spacing:.04em;text-transform:uppercase;padding:18px 26px;background:transparent;border:none;cursor:pointer;color:var(--gray);position:relative;transition:.18s;}
.prod-tab:hover{color:var(--navy);}
.prod-tab.active{color:var(--navy);}
.prod-tab.active::after{content:"";position:absolute;left:0;right:0;bottom:-1.5px;height:3px;background:var(--yellow);}
.prod-panel{display:none;}
.prod-panel.active{display:block;}
.prod-text-block{background:#fff;padding:38px 40px;border-radius:6px;border:1px solid var(--line);}
.prod-text-block h3{font-family:var(--font-head);font-weight:700;font-size:1.25rem;color:var(--heading);margin-bottom:14px;letter-spacing:-0.005em;}
.prod-text-block h3:not(:first-child){margin-top:28px;}
.prod-text-block p{margin-bottom:14px;line-height:1.78;}
.prod-text-block p:last-child{margin-bottom:0;}
.prod-text-block ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:10px;}
.prod-text-block ul li{padding-left:30px;position:relative;line-height:1.65;}
.prod-text-block ul li::before{content:"";position:absolute;left:0;top:8px;width:14px;height:14px;background:var(--yellow);border-radius:50%;box-shadow:0 0 0 4px rgba(255,192,61,.15);}

/* ─── SPECS TABLE ─── */
.specs-table{width:100%;background:#fff;border-radius:6px;overflow:hidden;border:1px solid var(--line);border-collapse:separate;border-spacing:0;}
.specs-table th,.specs-table td{padding:18px 24px;text-align:left;border-bottom:1px solid var(--line);font-size:.94rem;}
.specs-table tr:last-child th,.specs-table tr:last-child td{border-bottom:none;}
.specs-table th{font-family:var(--font-head);font-weight:700;color:var(--navy);background:var(--bg-soft);width:46%;letter-spacing:.01em;}
.specs-table td{color:var(--text);}
.specs-table td b{color:var(--navy);font-weight:700;}

/* ─── RELATED ─── */
.related{background:#fff;padding:clamp(60px,7vw,100px) 0;}

/* ─── DIAGNOSIS ─── */
.diagnosis{background:#fff;}
.diag-grid{display:grid;grid-template-columns:repeat(3,1fr);border-left:1px solid var(--line);border-top:1px solid var(--line);border-radius:6px;overflow:hidden;}
.diag-card{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:36px 34px;transition:.2s;background:#fff;}
.diag-card:hover{background:var(--bg-soft);}
.dc-symptom{font-family:var(--font-head);font-weight:700;font-size:1.25rem;margin-bottom:12px;color:var(--heading);letter-spacing:-0.005em;}
.dc-text{font-size:0.94rem;color:var(--text);margin-bottom:24px;min-height:78px;line-height:1.7;}
.dc-foot{display:flex;justify-content:space-between;align-items:center;padding-top:20px;border-top:1px solid var(--line);}
.dc-price{font-family:var(--font-head);font-weight:700;font-size:1.35rem;color:var(--yellow-dark);}
.dc-term{font-family:var(--font-head);font-weight:600;font-size:0.85rem;color:var(--gray);text-transform:uppercase;letter-spacing:.06em;}

/* ─── PROCESS ─── */
.process{background:var(--bg-soft);}
.process-track{position:relative;margin-top:54px;}
.process-line{position:absolute;top:39px;left:8%;right:8%;height:3px;background:var(--line);z-index:0;}
.process-line-fill{position:absolute;top:39px;left:8%;height:3px;background:var(--yellow);z-index:1;width:0;transition:width .5s ease;}
.process-grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(5,1fr);gap:20px;}
.proc-step{text-align:center;cursor:pointer;}
.proc-node{width:80px;height:80px;margin:0 auto 24px;background:#fff;border:3px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;transition:.3s;}
.proc-node .icon{width:34px;height:34px;color:var(--gray-2);transition:.3s;}
.proc-node .pn-num{position:absolute;top:-8px;right:-8px;width:30px;height:30px;background:var(--navy);color:#fff;font-family:var(--font-head);font-weight:700;font-size:0.9rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:.3s;}
.proc-step h4{font-family:var(--font-head);font-weight:700;font-size:1.1rem;margin-bottom:9px;transition:.3s;color:var(--heading);letter-spacing:-0.005em;}
.proc-step p{font-size:0.92rem;color:var(--gray);padding:0 8px;line-height:1.65;}
.proc-step.active .proc-node,.proc-step:hover .proc-node{border-color:var(--yellow);background:var(--yellow);transform:scale(1.08);}
.proc-step.active .proc-node .icon,.proc-step:hover .proc-node .icon{color:var(--navy);}
.proc-step.active .proc-node .pn-num,.proc-step:hover .proc-node .pn-num{background:#fff;color:var(--navy);}
.proc-step.active h4,.proc-step:hover h4{color:var(--yellow-dark);}

/* ─── FAQ ─── */
.faq{background:#fff;}
.faq-inner{display:grid;grid-template-columns:.82fr 1.18fr;gap:60px;align-items:start;}
.faq-list{display:flex;flex-direction:column;}
.faq-q{border-bottom:1px solid var(--line);}
.faq-q:first-child{border-top:1px solid var(--line);}
.faq-q button{width:100%;text-align:left;padding:26px 4px;background:none;border:none;cursor:pointer;font-family:var(--font-head);font-weight:700;font-size:1.05rem;display:flex;justify-content:space-between;align-items:center;gap:20px;color:var(--heading);letter-spacing:-0.005em;}
.faq-ico{width:34px;height:34px;flex-shrink:0;border:1.6px solid var(--line);display:flex;align-items:center;justify-content:center;transition:.25s;border-radius:4px;}
.faq-ico .icon{width:16px;height:16px;color:var(--navy);transition:.25s;}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.faq-a p{padding:0 4px 26px;font-size:0.96rem;color:var(--text);max-width:90%;line-height:1.7;}
.faq-q.open .faq-ico{background:var(--yellow);border-color:var(--yellow);}
.faq-q.open .faq-ico .icon{color:var(--navy);transform:rotate(45deg);}
.faq-q.open .faq-a{max-height:400px;}

/* ─── CTA ─── */
.cta{position:relative;background:var(--navy);color:#fff;overflow:hidden;}
.cta-bg-grid{position:absolute;inset:0;background:linear-gradient(105deg,rgba(33,45,69,.94) 0%,rgba(33,45,69,.82) 50%,rgba(33,45,69,.68) 100%),url('https://images.unsplash.com/photo-1531834685032-c34bf0d84c77?w=1600&q=80') center/cover;}
.cta-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.cta-text .section-title{color:#fff;}
.cta-text .section-title .accent{color:var(--yellow);}
.cta-text p{color:#d4d8e1;margin-top:18px;max-width:430px;line-height:1.7;}
.cta-contacts{margin-top:30px;display:flex;flex-direction:column;gap:14px;}
.cta-contacts .cc-row{display:flex;align-items:center;gap:13px;font-size:1rem;}
.cta-contacts .cc-row .icon{width:22px;height:22px;color:var(--yellow);flex-shrink:0;}
.cta-contacts .cc-row b{font-family:var(--font-head);font-weight:700;font-size:1.25rem;}
.cta-form{background:#fff;padding:42px 40px;border-radius:6px;}
.cta-form h3{font-family:var(--font-head);font-weight:700;font-size:1.55rem;color:var(--heading);margin-bottom:8px;letter-spacing:-0.01em;}
.cta-form .cf-sub{font-size:0.92rem;color:var(--gray);margin-bottom:24px;}
.cta-form input,.cta-form select{width:100%;padding:14px 16px;border:1px solid var(--line);font-family:var(--font-body);font-size:0.96rem;margin-bottom:14px;background:var(--bg-soft);color:var(--text);border-radius:4px;transition:.18s;}
.cta-form input:focus,.cta-form select:focus{outline:none;border-color:var(--yellow);background:#fff;}
.cta-form .cf-note{font-size:0.78rem;color:var(--gray);margin-top:8px;}
.cta-form .cf-note a{color:var(--yellow-dark);}

/* ─── FOOTER ─── */
footer{background:#1a2338;color:#9aa0b0;padding-top:68px;}
.footer-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.2fr;gap:44px;padding-bottom:50px;border-bottom:1px solid var(--line-dk);}
.footer-brand .logo-text .lt-main{color:#fff;}
.footer-brand p{margin-top:18px;font-size:0.9rem;line-height:1.72;}
.footer-col h4{font-family:var(--font-head);font-weight:700;font-size:0.95rem;letter-spacing:.06em;text-transform:uppercase;color:#fff;margin-bottom:20px;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:11px;}
.footer-col a{font-size:0.9rem;transition:.18s;}
.footer-col a:hover{color:var(--yellow);}
.footer-col .fc-line{font-size:0.9rem;margin-bottom:9px;display:flex;gap:10px;align-items:flex-start;}
.footer-col .fc-line .icon{width:18px;height:18px;color:var(--yellow);flex-shrink:0;margin-top:2px;}
.footer-col .fc-line b{color:#fff;font-family:var(--font-head);font-weight:700;font-size:1.1rem;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:22px 0;font-size:0.84rem;flex-wrap:wrap;gap:10px;}

/* ─── RESPONSIVE ─── */
@media(max-width:1279px){.container{max-width:1140px;}}
@media(max-width:1024px){
  .container{padding:0 26px;}
  .hero-inner{max-width:100%;}
  .adv-board{grid-template-columns:1fr;}
  .adv-tabs{flex-direction:row;flex-wrap:wrap;gap:6px;}
  .adv-tab{flex:1 1 30%;border-left:none;border-top:2px solid var(--line-dk);padding:14px 14px;border-radius:0;}
  .adv-tab.active{border-left:none;border-top-color:var(--yellow);}
  .adv-feature{grid-template-columns:1fr;min-height:auto;}
  .adv-feature-text-side{padding:36px 28px 20px;}
  .adv-feature-photo{min-height:240px;order:-1;}
  .adv-feature-photo::after{background:linear-gradient(180deg,rgba(42,54,84,0) 40%,rgba(42,54,84,.85) 100%);}
  .adv-feature-title{font-size:1.4rem;}
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .gal-grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:170px;}
  .catalog-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(3,260px);}
  .cat-item--hero{grid-column:1/3;grid-row:1/2;}
  .cat-item--wide{grid-column:1/3;grid-row:2/3;}
  .diag-grid{grid-template-columns:repeat(2,1fr);}
  .process-grid{grid-template-columns:repeat(2,1fr);gap:40px;}
  .process-line,.process-line-fill{display:none;}
  .faq-inner,.cta-inner{grid-template-columns:1fr;gap:44px;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .product-grid{grid-template-columns:repeat(2,1fr);}
  .prod-detail-grid{grid-template-columns:1fr;gap:36px;}
  .prod-gallery{position:static;}
}
@media(max-width:768px){
  /* Мобильное меню: nav становится оверлеем, открывается бургером */
  header nav,nav.main-nav{position:fixed;top:0;right:-100%;width:80%;max-width:340px;height:100vh;background:#fff;flex-direction:column;gap:0;padding:90px 0 24px;box-shadow:-10px 0 40px rgba(33,45,69,.18);z-index:99;transition:right .3s ease;overflow-y:auto;}
  header nav a,nav.main-nav a{padding:18px 28px;border-bottom:1px solid var(--line);font-size:1rem;width:100%;}
  body.nav-open header nav,body.nav-open nav.main-nav{right:0;}
  body.nav-open::before{content:"";position:fixed;inset:0;background:rgba(33,45,69,.45);z-index:98;}
  body.nav-open{overflow:hidden;}
  .header-phone-wrap{display:none;}
  .burger{display:flex;position:relative;z-index:101;}
  .burger.is-active span:nth-child(1){transform:translateY(8px) rotate(45deg);}
  .burger.is-active span:nth-child(2){opacity:0;}
  .burger.is-active span:nth-child(3){transform:translateY(-8px) rotate(-45deg);}
  .burger span{transition:.25s;}
  .topbar-info{gap:16px;}
  .topbar-social{display:none;}
  .stats{margin-top:-60px;}
  .stats-card{grid-template-columns:1fr;}
  .stats-left{padding:42px 36px;}
  .stats-heading{font-size:1.55rem;}
  .stats-right .stat{padding:34px 30px;}
  .stats-right .stat-num{font-size:2rem;}
  .adv-tab .at-title{font-size:.82rem;}
  .adv-tab{padding:12px 10px;}
  .services-grid{grid-template-columns:1fr;}
  .svc-img{aspect-ratio:16/9;}
  .gal-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px;grid-auto-flow:dense;}
  .gal-tile--wide{grid-column:span 1;}
  .gal-tile--tall{grid-row:span 1;}
  .diag-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .sec-head,.adv-head{flex-direction:column;align-items:flex-start;}
  .product-grid{grid-template-columns:1fr;}
  .prod-key-points{grid-template-columns:1fr;}
  .prod-actions .btn{min-width:100%;}
  .prod-text-block{padding:28px 24px;}
  .specs-table th,.specs-table td{padding:14px 16px;font-size:.88rem;}

  /* fix: cta-two-column-mobile-broken */
  
    /* Фикс CTA: на 768 и ниже принудительно 1 колонка (перебиваем .cta-inner 1.05fr .95fr из 1024 QA) */
    .cta-inner{grid-template-columns:1fr;gap:28px;}
    .cta-text,.cta-contacts,.cta-form{width:100%;min-width:0;}
  
    /* iOS zoom prevention: поля CTA-формы должны быть >=16px при фокусе */
    .cta-form input,.cta-form select,.cta-form textarea{font-size:max(16px,.95rem);}
  
    /* Длинные опции селекта не должны обрезаться визуально */
    .cta-form select{max-width:100%;width:100%;}

  /* fix: process-768-no-connector-line */
    /* Фикс #process-768-no-connector-line: соединительная линия для шагов на планшете (2-кол + 5-й full-width) */
    .process-grid{position:relative;row-gap:32px;}
    .proc-step{position:relative;}
    .proc-step::before{content:'';position:absolute;left:50%;top:-22px;width:2px;height:22px;background:var(--line);transform:translateX(-50%);z-index:0;}
    .proc-step:nth-child(1)::before,.proc-step:nth-child(2)::before{display:none;}
    .proc-node{position:relative;z-index:1;}

  /* fix: catalog-768-inherits-1024-layout */
    /* Каталог на планшете: убираем унаследованную из @1024 жёсткую сетку 2x3 по 260px.
       Переходим на 1 колонку с auto-высотой; hero/wide сбрасываем до обычной ячейки. */
    .catalog-grid{grid-template-columns:1fr;grid-template-rows:auto;grid-auto-rows:auto;}
    .cat-item,.cat-item--hero,.cat-item--wide{grid-column:auto;grid-row:auto;min-height:220px;}
    .cat-item--hero{min-height:280px;}

  /* fix: warehouse-map-height-tablet */
    .wh-map{height:260px;}
}
@media(max-width:768px){
  /* Скрываем «Заказать звонок» в header на мобиле (есть в overlay-меню) */
  .header-cta>.btn{display:none;}
  /* Уменьшаем хедер */
  .header-inner{padding:14px 0;}
  .logo-mark{width:40px;height:40px;}
  .logo-text .lt-main{font-size:1.25rem;}
  .logo-text .lt-sub{font-size:.62rem;}
  /* Топбар одной строкой */
  .topbar .container{flex-wrap:wrap;padding:8px 18px;}
  .topbar-info{flex-wrap:wrap;gap:14px;font-size:.78rem;}
  /* Баннер компактнее */
  .page-banner{padding:36px 0 40px;}
  .page-banner h1{font-size:1.6rem;}
  .page-banner-lead{font-size:.94rem;}
  .breadcrumbs{font-size:.7rem;letter-spacing:.08em;}
  /* Hero компактнее */
  .hero-inner{padding:60px 0 80px;}
  .hero h1{font-size:2rem;}
  .hero-lead{font-size:1rem;}
  /* Секции — меньше отступы */
  .section-pad{padding:50px 0;}
  .sec-head{margin-bottom:30px;}
  .section-title{font-size:1.6rem;}
  /* Карточки товара/услуги — внутренние блоки */
  .prod-detail{padding:30px 0 50px;}
  .prod-detail-grid{gap:24px;}
  .prod-title{font-size:1.5rem;}
  .prod-price-box{padding:20px 22px;}
  .prod-price-val{font-size:1.05rem;}
  .prod-tabs-section{padding:40px 0;}
  /* Связанные/related — 1 кол */
  .services-grid,.product-grid{grid-template-columns:1fr;gap:18px;}
  /* CTA-форма компактнее */
  .cta-form{padding:28px 22px;}
  .cta-form h3{font-size:1.3rem;}
  /* Фильтры каталога */
  .cat-filters{gap:6px;}
  .cat-filter{padding:10px 14px;font-size:.78rem;}
  /* Stats overlap на хиро меньше */
  .stats{margin-top:-40px;}
  .stats-card{grid-template-columns:1fr;}
  .stats-left{padding:32px 24px;}
  /* Footer */
  .footer-grid{gap:28px;}
  /* Защита от горизонтального overflow (iOS Safari: нужно и html, и body) */
  html,body{overflow-x:hidden;max-width:100%;}
  .hero{overflow:hidden;}
}
@media(max-width:480px){
  .container{padding:0 18px;}
  .topbar .container{padding:10px 18px;}
  .topbar-info span:nth-child(n+3){display:none;}
  .hero-magnets{flex-direction:column;}
  .magnet{min-width:100%;}
  .stats{margin-top:-30px;}
  .stats-left{padding:32px 24px;}
  .stats-right{grid-template-columns:1fr;}
  .stats-right .stat{border-right:none;border-bottom:1px solid var(--line);padding:28px 24px;}
  .stats-right .stat:last-child{border-bottom:none;}
  .catalog-grid{grid-template-columns:1fr;grid-template-rows:auto;}
  .cat-item,.cat-item--hero,.cat-item--wide{grid-column:auto;grid-row:auto;height:260px;min-height:260px;}
  .process-grid{grid-template-columns:1fr;gap:32px;}
  .footer-grid{grid-template-columns:1fr;gap:32px;}
  .prod-tabs{flex-direction:column;border-bottom:none;gap:6px;}
  .prod-tab{background:#fff;border:1px solid var(--line);border-radius:4px;text-align:left;padding:14px 18px;}
  .prod-tab.active{background:var(--yellow);border-color:var(--yellow);color:var(--navy);}
  .prod-tab.active::after{display:none;}

  /* fix: cta-contacts-row-wrap-icon-detached */
    /* Фикс #cta-contacts-row-wrap-icon-detached: при переносе длинного email/адреса иконка не должна "висеть" по центру — прижимаем её к верху и даём тексту занять остаток ширины */
    .cta-contacts .cc-row{align-items:flex-start;flex-wrap:nowrap;}
    .cta-contacts .cc-row .icon{margin-top:3px;}
    .cta-contacts .cc-row>*:not(.icon){flex:1 1 auto;min-width:0;word-break:break-word;overflow-wrap:anywhere;}
}

/* footer-bottom links (Phase 5) */
.footer-bottom a{text-decoration:underline;text-underline-offset:3px;transition:.18s;}
.footer-bottom a:hover{color:var(--yellow);}

/* ═══════════════════════════════════════════════════════════════
   NORMETRA — стили для новых блоков (geo, warehouse, trust, etc.)
   Добавлено для WP-темы (Carbon Fields)
   ═══════════════════════════════════════════════════════════════ */

/* ─── GEOGRAPHY ─── */
.geo{background:var(--bg-soft);}
.geo-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.geo-card{background:#fff;border:1px solid var(--line);border-radius:6px;padding:32px;display:flex;flex-direction:column;}
.geo-card-head{display:flex;gap:18px;align-items:flex-start;margin-bottom:22px;}
.geo-ico{width:56px;height:56px;background:var(--yellow-soft);color:var(--yellow-dark);display:flex;align-items:center;justify-content:center;border-radius:6px;flex-shrink:0;}
.geo-ico .icon{width:28px;height:28px;}
.geo-card h3{font-family:var(--font-head);font-weight:700;font-size:1.2rem;color:var(--heading);margin-bottom:6px;letter-spacing:-0.005em;}
.geo-card-head p{font-size:0.92rem;color:var(--gray);line-height:1.55;}
.geo-list{list-style:none;display:flex;flex-direction:column;gap:14px;margin:0;padding:0;}
.geo-list li{display:flex;align-items:center;gap:14px;font-size:1rem;color:var(--text);padding:14px 18px;background:var(--bg-soft);border-radius:4px;border-left:3px solid var(--yellow);}
.geo-list li b{color:var(--heading);font-weight:700;}
.geo-region{background:var(--navy);color:#fff;padding:28px;border-radius:4px;margin-top:auto;}
.geo-region-title{font-family:var(--font-head);font-weight:700;font-size:1.2rem;margin-bottom:8px;letter-spacing:-0.005em;}
.geo-region-note{font-size:0.95rem;color:#d4d8e1;line-height:1.6;}
.geo-delivery{margin-top:24px;background:#fff;border:1px solid var(--line);border-left:4px solid var(--yellow);border-radius:6px;padding:22px 28px;display:flex;gap:20px;align-items:center;}
.geo-delivery-ico{width:52px;height:52px;background:var(--yellow-soft);color:var(--yellow-dark);display:flex;align-items:center;justify-content:center;border-radius:6px;flex-shrink:0;}
.geo-delivery-ico .icon{width:26px;height:26px;}
.geo-delivery-title{font-family:var(--font-head);font-weight:700;font-size:1.15rem;color:var(--heading);margin-bottom:4px;}
.geo-delivery-note{font-size:0.92rem;color:var(--gray);}

/* ─── WAREHOUSE ─── */
.warehouse{background:#fff;}
.wh-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:32px;align-items:stretch;margin-bottom:32px;}
.wh-photo{position:relative;border-radius:6px;overflow:hidden;aspect-ratio:4/3;background:var(--bg-soft);}
.wh-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.wh-info{display:flex;flex-direction:column;gap:14px;}
.wh-row{display:flex;gap:16px;align-items:flex-start;padding:18px 20px;background:var(--bg-soft);border-radius:6px;}
.wh-row-ico{width:44px;height:44px;background:#fff;color:var(--yellow-dark);display:flex;align-items:center;justify-content:center;border-radius:4px;flex-shrink:0;}
.wh-row-ico .icon{width:22px;height:22px;}
.wh-row-label{font-family:var(--font-head);font-weight:700;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gray);margin-bottom:6px;}
.wh-row-val{font-size:0.96rem;color:var(--text);line-height:1.55;}
.wh-cta{align-self:flex-start;margin-top:6px;}
.wh-map{border-radius:6px;overflow:hidden;border:1px solid var(--line);height:380px;background:var(--bg-soft);}
.wh-map iframe{width:100%;height:100%;border:0;display:block;}

/* ─── TRUST ─── */
.trust{background:var(--bg-soft);}
.trust-logos{margin-bottom:50px;}
.trust-logos-title{font-family:var(--font-head);font-weight:600;font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gray);text-align:center;margin-bottom:24px;}
.trust-logos-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:1020px;margin:0 auto;}
.tl-card{aspect-ratio:5/3;background:#fff;border:1px solid var(--line);border-radius:4px;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:700;font-size:1.05rem;letter-spacing:.06em;color:var(--heading);transition:.18s;padding:14px;overflow:hidden;}
.tl-card:hover{border-color:var(--yellow);color:var(--text);}
.tl-card--logo{padding:0;}
.tl-card--logo img{max-width:80%;max-height:62%;width:auto;height:auto;object-fit:contain;display:block;margin:auto;}
.trust-quotes{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.tq-card{background:#fff;border:1px solid var(--line);border-radius:6px;padding:32px;position:relative;}
.tq-card::before{content:"\201C";position:absolute;top:14px;right:24px;font-family:Georgia,serif;font-size:5rem;color:var(--yellow);line-height:1;opacity:.35;}
.tq-text{font-size:1rem;color:var(--text);line-height:1.7;margin-bottom:20px;font-style:italic;position:relative;}
.tq-author{display:flex;flex-direction:column;gap:4px;border-left:3px solid var(--yellow);padding-left:14px;}
.tq-author b{font-family:var(--font-head);font-weight:700;color:var(--heading);}
.tq-author span{font-size:0.86rem;color:var(--gray);}

/* ─── Adaptive ─── */
@media(max-width:1024px){
  .geo-grid{grid-template-columns:1fr;}
  .wh-grid{grid-template-columns:1fr;}
  .wh-photo{aspect-ratio:16/9;}
  .wh-map{height:320px;}
  .trust-logos-grid{grid-template-columns:repeat(4,1fr);max-width:600px;}
  .trust-quotes{grid-template-columns:1fr;}
  .adv .services-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:768px){
  .header-cta .btn,.header-cta>.btn{display:none;}
  .logo-text .lt-main{font-size:1.2rem;}
  .logo-text .lt-sub{font-size:.62rem;}
  .topbar .container{flex-wrap:wrap;gap:8px;padding:8px 18px;}
  .topbar-info{flex-wrap:wrap;gap:12px;font-size:.78rem;}
  .topbar-social{display:none;}
  .trust-logos-grid{grid-template-columns:repeat(2,1fr);max-width:420px;}
  .geo-delivery{flex-direction:column;text-align:center;align-items:center;}
  .adv .services-grid{grid-template-columns:1fr;}
}
@media(max-width:480px){
  .geo-card{padding:24px 22px;}
  .geo-region{padding:22px;}
  .trust-logos-grid{grid-template-columns:repeat(2,1fr);max-width:none;}
  /* Фикс reviews-mobile: уменьшаем декоративную кавычку и резервируем место сверху, чтобы не налезала на текст */
  .tq-card{padding:36px 22px 24px;}
  .tq-card::before{font-size:3rem;top:6px;right:14px;opacity:.25;}
  .tq-text{padding-top:6px;}
  .wh-row{padding:14px 16px;gap:12px;}
}

/* ═══════════════════════════════════════════════════════════════
   QA-FIXES — апрель 2026 (адаптив по аудиту)
   ═══════════════════════════════════════════════════════════════ */

/* Защита от двойной вложенности контейнеров (фикс #3) */
.container .container{padding:0;}

/* .wh-note — общий стиль (фикс #9 и #33) */
.wh-note{display:block;margin-top:6px;font-size:.82rem;color:var(--gray);font-weight:400;}

/* Калькулятор: iOS zoom prevention при focus (фикс #12 + ios-select-zoom-480) */
.fwc-form-input,.fwc-form-select,.fwc-form-textarea,.cta-form select,.cta-form input,.cta-form textarea,.calculator select,.calculator input,.calculator textarea{font-size:16px;}

/* footer-bottom ссылки underline (фикс #54: cf-note) */
.cta-form .cf-note a{text-decoration:underline;text-underline-offset:2px;}

/* CTA-форма: чекбокс согласия (legal consent) */
.cta-form .cf-consent{display:flex;align-items:flex-start;gap:10px;margin:4px 0 14px;cursor:pointer;user-select:none;}
.cta-form .cf-consent input[type="checkbox"]{width:18px;height:18px;min-width:18px;margin:2px 0 0;padding:0;accent-color:var(--yellow);cursor:pointer;flex:0 0 auto;}
.cta-form .cf-consent .cf-consent-text{font-size:0.82rem;line-height:1.45;color:var(--gray);}
.cta-form .cf-consent a{color:var(--yellow-dark);text-decoration:underline;text-underline-offset:2px;}
.cta-form .cf-consent input[type="checkbox"]:focus-visible{outline:2px solid var(--yellow);outline-offset:2px;}

/* CTA select ellipsis (фикс #45) */
.cta-form select{text-overflow:ellipsis;overflow:hidden;}

/* CTA contacts: длинный email — wrap (фикс #57) */
.cta-contacts .cc-row{word-break:break-word;flex-wrap:wrap;}

/* prod-cat-label — wrap длинных subcategory (фикс #76) */
.prod-cat-label{max-width:100%;word-break:keep-all;}

/* Tabular nums у stats (фикс #49) */
.stats-right .stat-num{font-variant-numeric:tabular-nums;}

/* svc-card описание — clamp 3 строки (фикс #68) */
.svc-card p{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}

/* prod-gallery — отключаем sticky (фикс #58) */
.prod-gallery{position:static;}

/* ─── 1100px (header пограничный — порог бургера) ─── */
@media(max-width:1100px){
  header nav a,nav.main-nav a{padding:10px 10px;font-size:.84rem;}
}

/* ─── 1024px QA fixes ─── */
@media(max-width:1024px){
  /* Фикс #1: показываем бургер с 1024px, скрываем CTA + сжимаем nav */
  .burger{display:flex;}
  .header-cta>.btn{display:none;}
  header nav,nav.main-nav{position:fixed;top:0;right:-100%;width:80%;max-width:340px;height:100vh;background:#fff;flex-direction:column;gap:0;padding:90px 0 24px;box-shadow:-10px 0 40px rgba(33,45,69,.18);z-index:99;transition:right .3s ease;overflow-y:auto;}
  header nav a,nav.main-nav a{padding:18px 28px;border-bottom:1px solid var(--line);font-size:1rem;width:100%;}
  body.nav-open header nav,body.nav-open nav.main-nav{right:0;}
  body.nav-open::before{content:"";position:fixed;inset:0;background:rgba(33,45,69,.45);z-index:98;}
  body.nav-open{overflow:hidden;}
  .burger.is-active span:nth-child(1){transform:translateY(8px) rotate(45deg);}
  .burger.is-active span:nth-child(2){opacity:0;}
  .burger.is-active span:nth-child(3){transform:translateY(-8px) rotate(-45deg);}
  .burger span{transition:.25s;}

  /* Фикс #4: gallery — на планшете 1024 выравниваем все плитки в одинаковые ячейки (без L-дыр и сирот) */
  .gal-grid{grid-auto-flow:dense;grid-auto-rows:180px;}
  .gal-tile--wide{grid-column:span 1;}
  .gal-tile--tall{grid-row:span 1;}

  /* Фикс #5: advantages — выровнять табы */
  .adv-tab{min-height:64px;align-items:center;}
  .adv-tab .at-title{font-size:.9rem;}

  /* Фикс #6: trust logos — крупнее */
  .trust-logos-grid{grid-template-columns:repeat(2,1fr);max-width:520px;}

  /* Фикс #15: CTA inner — уменьшить gap, перераспределить */
  .cta-inner{gap:36px;grid-template-columns:1.05fr .95fr;}

  /* Фикс #19/75: prod-gallery-main — уменьшить */
  .prod-gallery-main{max-width:560px;margin-inline:auto;}

  /* Фикс #23/67: stats card в 1 кол; process — 2 кол (5-й шаг через .proc-step:nth-child(5) ниже растягивается на всю ширину и центрируется) */
  .stats-card{grid-template-columns:1fr;}
  .process-grid{grid-template-columns:repeat(2,1fr);}

  /* Фикс #27/61: prod-tabs компактнее на 1024 */
  .prod-tabs{gap:4px;}
  .prod-tab{padding:14px 18px;font-size:.82rem;letter-spacing:.02em;}

  /* Фикс #34: process на главной — 3 кол + сирота по центру */
  .proc-step:nth-child(5){grid-column:1/-1;text-align:center;}

  /* Фикс #35: stats heading адаптируется */
  .stats-heading{font-size:1.65rem;}
  .stats-left{padding:36px 32px;}

  /* Фикс #37: footer 3-кол + brand на всю ширину */
  .footer-grid{grid-template-columns:1.5fr 1fr 1fr;}
  .footer-brand{grid-column:1/-1;margin-bottom:8px;}

  /* Фикс #52: cat-filters padding compact */
  .cat-filter{padding:11px 18px;}

  /* Фикс #60: prod-gallery-thumbs 5 кол + max-width */
  .prod-gallery-thumbs{grid-template-columns:repeat(5,1fr);max-width:560px;margin-inline:auto;}
}

/* ─── 768px QA fixes ─── */
@media(max-width:768px){
  /* Фикс #7: footer-brand на всю ширину */
  .footer-brand{grid-column:1/-1;}

  /* Фикс #8: hero magnets в column */
  .hero-magnets{flex-direction:column;}
  .magnet{min-width:100%;flex-basis:100%;}

  /* Фикс #9: warehouse CTA на всю ширину */
  .wh-cta{width:100%;justify-content:center;align-self:stretch;}

  /* Фикс #16/63: product card h3 без min-height */
  .product-card h3{min-height:0;}

  /* Фикс #20/28: prod-tabs column-режим уже с 768 */
  .prod-tabs{flex-direction:column;border-bottom:none;gap:6px;}
  .prod-tab{background:#fff;border:1px solid var(--line);border-radius:4px;text-align:left;padding:14px 18px;}
  .prod-tab.active{background:var(--yellow);border-color:var(--yellow);color:var(--navy);}
  .prod-tab.active::after{display:none;}

  /* Фикс #24: stats-right в 1 кол на 768, убрать right border */
  .stats-right{grid-template-columns:1fr;}
  .stats-right .stat{padding:22px 26px;gap:6px;}
  .stats-right .stat:nth-child(2n){border-right:none;border-bottom:1px solid var(--line);}
  .stats-right .stat:last-child{border-bottom:none;}

  /* Фикс #38: stats-right числа компактнее */
  .stats-right .stat-num{font-size:1.6rem;letter-spacing:-0.02em;font-variant-numeric:tabular-nums;}
  .stats-right .stat-label{font-size:.84rem;}

  /* Фикс #39: cta section-title — крупнее */
  .cta .section-title{font-size:1.8rem;line-height:1.2;}

  /* Фикс #40: geo иконка/блоки центрируются */
  .geo-region-title{font-size:1.05rem;}
  .geo-delivery>div{text-align:center;}

  /* Фикс #41: 6 кнопок advantage компактно */
  .adv-tab .at-num{display:none;}
  .adv-tab{flex:1 1 45%;}

  /* Фикс #62: prod-price-row column на 768 */
  .prod-price-row{flex-direction:column;align-items:flex-start;gap:4px;padding:10px 0;}
  .prod-price-val{font-size:1rem;}

  /* Фикс #69: page-banner h1 и lead на 768 */
  .page-banner h1{font-size:1.8rem;}
  .page-banner-lead{font-size:.9rem;max-width:560px;}
}

/* ─── 480px QA fixes ─── */
@media(max-width:480px){
  /* Фикс #2: cat-filters — 2 кол grid */
  .cat-filters{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;}
  .cat-filter{justify-content:space-between;padding:14px 12px;font-size:.76rem;letter-spacing:.02em;min-height:44px;}

  /* Фикс #10: gallery — 1 кол + сброс tall/wide; высота из ширины (4:3), без жёсткой обрезки портретов */
  .gal-grid{grid-template-columns:1fr;grid-auto-rows:auto;}
  .gal-tile{aspect-ratio:4/3;height:auto;}
  .gal-tile--tall,.gal-tile--wide{grid-row:span 1;grid-column:span 1;}

  /* Фикс #13: hero-тайл заголовок не давит */
  .cat-item--hero .cb-title{font-size:1.4rem;}

  /* Фикс #17: product-card-price wrap */
  .product-card-price{flex-wrap:wrap;gap:12px;}
  .product-card-price>div:first-child{min-width:0;flex:1 1 100%;}
  /* Фикс #480-touch: .product-card-link — touch-таргет ≥44px на мобайле */
  .product-card-link{align-self:flex-end;padding:12px 18px;font-size:.82rem;min-height:44px;}

  /* Фикс #21: prod-price-row column на 480 */
  .prod-price-row{flex-direction:column;align-items:flex-start;gap:4px;}
  .prod-price-val{font-size:1rem;}
  .prod-price-val small{display:block;margin-left:0;}

  /* Фикс #22: specs-table стек + группировка строк (issue specs-table-row-grouping-480) */
  .specs-table tr{display:block;border-bottom:1px solid var(--line);padding-bottom:6px;margin-bottom:6px;}
  .specs-table tr:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none;}
  .specs-table th,.specs-table td{display:block;width:100%;padding:10px 14px;border-bottom:none;}
  .specs-table th{background:var(--bg-soft);font-size:.82rem;}
  .specs-table td{border-top:none;}

  /* Фикс #25: faq button компактнее */
  .faq-q button{font-size:.95rem;padding:20px 6px;gap:12px;}
  .faq-ico{width:34px;height:34px;}
  .faq-a p{padding:0 6px 22px;max-width:100%;}

  /* Фикс #26: stats heading + CTA на ширину */
  .stats-heading{font-size:1.35rem;}
  .stats-lead{font-size:.9rem;margin-bottom:24px;}
  /* Фикс #stats-btn-width-check-480: явный сброс align-self:flex-start (унаследован с L114),
     чтобы кнопка гарантированно растягивалась на всю ширину flex-родителя .stats-left,
     а не "залипала" слева в одноколоночной mobile-раскладке. */
  .stats-btn{width:100%;text-align:center;justify-content:center;align-self:stretch;}

  /* Фикс #29/74: thumbs auto-fit */
  .prod-gallery-thumbs{grid-template-columns:repeat(auto-fit,minmax(72px,1fr));}

  /* Фикс #30: page-banner h1 крупнее с переносом */
  .page-banner h1{font-size:1.4rem;line-height:1.2;word-break:break-word;hyphens:auto;}
  .page-banner-lead{font-size:.88rem;line-height:1.55;}

  /* Фикс #42: footer-bottom column */
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:14px;text-align:left;}
  .footer-brand p{font-size:.84rem;}

  /* Фикс #43 (исправлен): process — горизонтальная раскладка через grid.
     Реальная разметка: <proc-node> + <h4> + <p> — три плоских сиблинга.
     При flex-direction:row они становились 3 колонками и шаги ломались (h4/p сжимались до min-content). */
  .proc-step{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;column-gap:18px;row-gap:4px;text-align:left;align-items:start;}
  .proc-node{margin:0;flex-shrink:0;grid-column:1;grid-row:1 / span 2;align-self:start;}
  .proc-step h4{grid-column:2;grid-row:1;align-self:center;margin-bottom:4px;min-width:0;}
  .proc-step p{grid-column:2;grid-row:2;padding:0;min-width:0;}

  /* Фикс #44 (исправлен): advantages mobile <480 — полная раскладка с фото сверху, табы вертикально */
  .adv-board{grid-template-columns:1fr;gap:18px;}
  .adv-tabs{display:flex;flex-direction:column;gap:4px;width:100%;}
  .adv-tab{flex:0 0 auto;width:100%;min-height:52px;padding:14px 16px;border-top:none;border-left:2px solid var(--line-dk);border-radius:0 4px 4px 0;background:rgba(255,255,255,.02);}
  .adv-tab .at-num{display:inline-block;width:24px;font-size:.8rem;}
  .adv-tab .at-title{font-size:.88rem;color:#dee2eb;}
  .adv-tab.active{border-top:none;border-left-color:var(--yellow);background:var(--navy-2);}
  .adv-tab.active .at-title{color:#fff;}
  .adv-feature{display:flex;flex-direction:column;grid-template-columns:none;min-height:auto;border-radius:6px;overflow:hidden;}
  .adv-feature-photo{order:-1;position:relative;width:100%;min-height:0;height:auto;aspect-ratio:16/10;background:#0e1424;}
  .adv-feature-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
  .adv-feature-text-side{order:1;padding:28px 22px 22px;display:flex;flex-direction:column;gap:10px;}
  .adv-feature-icon{width:54px;height:54px;margin-bottom:12px;}
  .adv-feature-icon .icon{width:28px;height:28px;}
  .adv-feature-title{font-size:1.25rem;margin-bottom:8px;}
  .adv-feature-text{font-size:.92rem;line-height:1.6;}
  /* Фикс прогресс-бара: в колоночной раскладке .adv-progress (top:0) лежал тонкой полосой над фото.
     Переносим его вниз карточки — становится явным индикатором прогресса слайда под текстом. */
  .adv-progress{top:auto;bottom:0;left:0;right:0;width:0;height:3px;}
  .adv-controls{padding-top:16px;margin-top:14px;gap:12px;flex-wrap:wrap;}
  .adv-counter{font-size:.85rem;gap:4px;}
  .adv-counter b{font-size:1.25rem;}
  .adv-nav{gap:8px;margin-left:auto;}
  .adv-arrow{width:40px;height:40px;}
  .adv-arrow .icon{width:16px;height:16px;}

  /* Фикс #46: warehouse map ниже + CTA на ширину */
  /* Fix warehouse-map-touch-hijack-480: touch-action:pan-y чтобы вертикальный скролл страницы не перехватывался картой при касании на мобилке */
  .wh-map{height:260px;touch-action:pan-y;-ms-touch-action:pan-y;}
  .wh-cta{width:100%;justify-content:center;align-self:stretch;}

  /* Фикс #47: diagnosis card компакт */
  .diag-card{padding:28px 24px;}
  .dc-text{min-height:auto;}
  .dc-foot{flex-wrap:wrap;gap:8px;}

  /* Фикс #48: stats num на мобилке */
  .stats-right .stat-num{font-size:1.8rem;}

  /* Фикс #55: product-card-body компактнее */
  .product-card-body{padding:20px 18px 22px;gap:12px;}

  /* Фикс #56: catalog page-banner */
  /* (фикс #30 покрывает) */

  /* Фикс #64: prod-gallery-tag крупнее */
  .prod-gallery-tag{font-size:.7rem;padding:5px 10px;}

  /* Фикс #65: prod-actions кнопки */
  .prod-actions .btn{padding:14px 22px;font-size:.82rem;min-width:100%;flex:1 1 100%;word-break:break-word;}

  /* Фикс #66: prod-key компакт */
  .prod-key{padding:12px;}
  .prod-key span{font-size:.86rem;}

  /* Фикс #70 (пересобран): process на мобиле — компактный node, линия точно по центру круга, padding обнулён */
  .process-grid{position:relative;padding:0;}
  .proc-node{width:56px;height:56px;margin:0;border-width:2px;position:relative;z-index:1;background:#fff;}
  .proc-node .icon{width:24px;height:24px;}
  .proc-node .pn-num{top:-6px;right:-6px;width:22px;height:22px;font-size:.72rem;border:2px solid #fff;}
  .proc-step{column-gap:16px;align-items:center;}
  .proc-step h4{font-size:1rem;align-self:center;}
  .proc-step p{font-size:.9rem;line-height:1.55;}
  /* Линия проходит ровно по центру .proc-node (28px = радиус 56/2), от центра первого до центра последнего */
  .process-grid::before{content:'';position:absolute;left:27px;top:28px;bottom:28px;width:2px;background:var(--line);z-index:0;}

  /* Фикс #71: cta-form padding compact */
  .cta-form{padding:24px 18px;}
  .cta-form h3{font-size:1.2rem;}
  .cf-note{font-size:.74rem;line-height:1.5;}

  /* Фикс #79: prod-tab column — стыковка с панелью */
  .prod-tab.active{border-bottom-left-radius:0;border-bottom-right-radius:0;}
  .prod-panel.active .prod-text-block{border-top-left-radius:0;}

  /* Фикс #80: breadcrumbs current — без uppercase */
  .breadcrumbs .current{text-transform:none;}

  /* Фикс #81: svc-img 16/9 на мобиле */
  .svc-img{aspect-ratio:16/9;}
}

/* ─── 1440px и крупнее (косметика) ─── */
@media(min-width:1441px){
  /* Фикс #31: hero-inner уже + правее градиент */
  .hero-inner{max-width:920px;}

  /* Фикс #32: trust logos крупнее на широком экране */
  .trust-logos-grid{max-width:1020px;}
}

/* ─── AJAX-формы: inline-сообщение об отправке ─── */
.nm-form-message { padding:14px 18px; border-radius:6px; margin-top:14px; font-size:.92rem; }
.nm-form-message--success { background:#e8f5e9; color:#2e7d32; border:1px solid #66bb6a; }
.nm-form-message--error { background:#ffebee; color:#c62828; border:1px solid #ef5350; }

/* === fix: footer-broken-grid-and-spacing === */
/* ─── FIX: footer-broken-grid-and-spacing ─── */
/* 768px: переводим footer-grid в 3 колонки, чтобы оставшиеся 3 (Услуги/Каталог/Контакты)
   ровно заполняли ряд после .footer-brand{grid-column:1/-1}. Без этого был 1fr 1fr и сирота. */
@media (max-width:768px){
  .footer-grid{grid-template-columns:repeat(3,1fr);gap:28px 24px;}
  .footer-col .fc-line{overflow-wrap:anywhere;word-break:break-word;}
  .footer-col .fc-line a{text-decoration:underline;text-underline-offset:3px;}
  .footer-col .fc-line a:hover{color:var(--yellow);}
  .footer-col .fc-line .icon{width:16px;height:16px;}
}
/* 480px: меньше воздуха в футере + 1 кол + читаемый текст в одну колонку */
@media (max-width:480px){
  footer{padding-top:40px;}
  .footer-grid{grid-template-columns:1fr;gap:24px;padding-bottom:28px;}
  .footer-brand{margin-bottom:8px;}
  .footer-col h4{margin-bottom:12px;}
  .footer-col .fc-line{font-size:.88rem;margin-bottom:8px;overflow-wrap:anywhere;word-break:break-word;}
  .footer-col .fc-line a{text-decoration:underline;text-underline-offset:3px;}
  .footer-col .fc-line b{font-size:1rem;}
  .footer-bottom{padding:16px 0;font-size:.78rem;}

  /* fix: proc-step-before-not-reset-480 */
    /* fix: proc-step-before-not-reset-480 — сбрасываем короткую вертикальную линию-коннектор, унаследованную из @768 (там она нужна для 2-кол сетки). В 480 раскладка одно-колоночная, линия становится лишним декором над каждым шагом. */
    .proc-step::before{display:none !important;}
}

/* === fix: advantages-tabs-tablet-mobile-text-wrap === */
/* ─── Фикс advantages-tabs-tablet-mobile-text-wrap ─── */
/* 768: выровнять кнопки таб-вертикали и ужать padding фото-карточки */
@media(max-width:768px){
  .adv-tab{min-height:56px;display:flex;align-items:center;justify-content:center;text-align:center;}
  .adv-tab .at-title{font-size:.8rem;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;hyphens:auto;word-break:break-word;}
  .adv-feature-text-side{padding:26px 20px 18px;}
  .adv-feature-photo{min-height:200px;}
  .adv-feature-title{font-size:1.25rem;}
}
/* 480: вертикальный список табов — длинные тайтлы переносим аккуратно, освобождаем место под at-num.
   Объединено с базовым правилом из L855 (border-left/border-radius/background сохранены каскадом),
   гарантируем touch-friendly высоту 52px и вертикальное центрирование, чтобы избежать "дрожания"
   между двумя авторами правил .adv-tab на 480. */
@media(max-width:480px){
  .adv-tab{display:flex;align-items:center;text-align:left;min-height:52px;padding:14px 14px;gap:10px;}
  .adv-tab .at-num{flex-shrink:0;width:auto;min-width:22px;align-self:center;}
  .adv-tab .at-title{font-size:.86rem;line-height:1.3;display:block;-webkit-line-clamp:unset;overflow:visible;word-break:break-word;hyphens:auto;flex:1 1 auto;min-width:0;}
}

/* === fix: trust-logos-mobile-tablet-scaling === */
/* ─── Фикс trust-logos-mobile-tablet-scaling ─── */
@media(max-width:768px){
  /* Снимаем жёсткий max-width:420px и позволяем сетке масштабироваться,
     auto-fit предотвращает orphan-ряд при 5-8 логотипах */
  .trust-logos-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));max-width:620px;gap:14px;}
  /* Логотипная карточка крупнее, шрифт текстового бейджа уменьшен — не переполняется */
  .tl-card{font-size:.78rem;letter-spacing:.04em;padding:10px;aspect-ratio:5/3;}
  .tl-card--logo img{max-width:86%;max-height:74%;}
  /* tq-card padding компактнее на планшете */
  .tq-card{padding:24px 22px;}
}
@media(max-width:480px){
  /* На самой узкой ширине — одна колонка с разумным размером карточки,
     либо 2 колонки если ширина позволяет (auto-fit min 140px) */
  /* Фикс orphan-ряда: жёстко 2 колонки, чтобы 4 логотипа давали 2×2, а 5 — 2+2+1 без одиночки в широком ряду */
  .trust-logos-grid{grid-template-columns:repeat(2,1fr);gap:10px;max-width:none;}
  .tl-card{aspect-ratio:2/1;font-size:.72rem;letter-spacing:.03em;padding:8px;}
  .tl-card--logo img{max-width:88%;max-height:78%;}
  /* tq-author читаемее: уменьшаем border-left, увеличиваем шрифт подписи и имени */
  .tq-author{border-left-width:2px;padding-left:12px;gap:2px;}
  .tq-author b{font-size:.95rem;line-height:1.3;}
  .tq-author span{font-size:.8rem;line-height:1.4;}
}

/* === fix: container-small-screen-icons-not-scaled === */
/* ═══════════════════════════════════════════════════════════════
   QA-FIX #container-small-screen-icons-not-scaled
   На устройствах 360–375px (iPhone SE/Mini) при .container padding 18px
   полезная ширина ~324–339px. Крупные иконки (.proc-node 80px,
   .adv-feature-icon 54px, .adv-arrow 42px) занимают слишком большую
   долю ширины — уменьшаем их пропорционально, не трогая 390+.
   ═══════════════════════════════════════════════════════════════ */
@media(max-width:380px){
  .container{padding:0 14px;}
  .topbar .container{padding:10px 14px;}

  /* fix #topbar-info-wrap-360: на 360px даже 2 инфо-пункта могут переноситься
     flex-wrap'ом во вторую строку и раздувать топбар до 60–70px.
     Оставляем только первый пункт (часы работы), запрещаем перенос
     и обрезаем переполнение, чтобы высота топбара оставалась стабильной. */
  .topbar-info{flex-wrap:nowrap;min-width:0;overflow:hidden;}
  .topbar-info span:nth-child(n+2){display:none;}
  .topbar-info span:first-child{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

  /* process — уменьшаем кружок шага */
  .proc-node{width:64px;height:64px;border-width:2px;}
  .proc-node .icon{width:28px;height:28px;}
  .proc-node .pn-num{width:26px;height:26px;font-size:.78rem;top:-6px;right:-6px;}
  .process-grid::before{left:32px;}

  /* advantages — иконка и стрелки чуть меньше */
  .adv-feature-icon{width:46px;height:46px;margin-bottom:10px;}
  .adv-feature-icon .icon{width:24px;height:24px;}
  .adv-arrow{width:38px;height:38px;}
  .adv-arrow .icon{width:16px;height:16px;}

  /* services / geo / warehouse — крупные бейджи */
  .svc-ico-badge{width:50px;height:50px;}
  .svc-ico-badge .icon{width:26px;height:26px;}
  .geo-ico{width:48px;height:48px;}
  .geo-ico .icon{width:24px;height:24px;}
  .geo-delivery-ico{width:46px;height:46px;}
  .geo-delivery-ico .icon{width:22px;height:22px;}
  .wh-row-ico{width:38px;height:38px;}
  .wh-row-ico .icon{width:20px;height:20px;}
}

/* ═══════════════════════════════════════════════════════════════
   FINAL CASCADE OVERRIDE — критические grid-сетки на mobile
   В файле выше есть QA-фикс блок @media(max-width:1024px) (line 645+)
   который объявлен ПОЗЖЕ оригинальных mobile-правил и побеждает их по каскаду.
   Этот блок ниже всего → форсирует правильное mobile-поведение.
   !important нужен потому что специфичность та же, а двигать QA-блок рискованно.
   ═══════════════════════════════════════════════════════════════ */

/* ── tablet 768 — все основные блоки в 1 колонку ── */
@media (max-width:768px){
  .cta-inner{grid-template-columns:1fr !important;gap:32px;}
  .cta-text,.cta-contacts,.cta-form{width:100%;min-width:0;}

  /* Процесс: на планшете 5-й шаг центрируется (см. фикс #23/67), на мобиле — все 5 в столбик */
  .process-grid{grid-template-columns:repeat(2,1fr) !important;gap:32px;}
  .proc-step:nth-child(5){grid-column:1/-1;text-align:center;}
}

/* ── mobile 480 — окончательно в 1 колонку ── */
@media (max-width:480px){
  .cta-inner{gap:24px;}
  .cta-text p{max-width:none;}
  .cta-form{padding:24px 18px;}
  .cta-form input,.cta-form select,.cta-form textarea{font-size:max(16px,1rem);}
  .cf-note{font-size:.78rem;line-height:1.5;}

  /* Процесс: ВСЕ 5 шагов вертикальным списком, никаких 2-кол */
  .process-grid{grid-template-columns:1fr !important;gap:24px;}
  .proc-step:nth-child(5){grid-column:auto;text-align:left;}
  .proc-step{display:grid;grid-template-columns:64px 1fr;grid-template-rows:auto auto;column-gap:16px;row-gap:4px;text-align:left;align-items:start;}
  .proc-node{width:64px;height:64px;grid-column:1;grid-row:1 / span 2;align-self:start;}
  .proc-node .icon{width:28px;height:28px;}
  .pn-num{width:22px;height:22px;font-size:.72rem;top:-4px;right:-4px;}
  /* Фикс конфликта размеров: .proc-node здесь 64px, поэтому линию пересчитываем под радиус 32 (вместо 28 в фиксе #70) */
  .process-grid::before{left:31px;top:32px;bottom:32px;}
  .proc-step h4{grid-column:2;grid-row:1;align-self:center;margin-bottom:2px;font-size:1.05rem;min-width:0;}
  .proc-step p{grid-column:2;grid-row:2;padding:0;font-size:.92rem;line-height:1.5;min-width:0;}

  /* Чтобы галерея, услуги, каталог и преимущества тоже не оставались 2-кол */
  .services-grid{grid-template-columns:1fr !important;}
  .product-grid{grid-template-columns:1fr !important;}
  .gal-grid{grid-template-columns:1fr !important;}
  .adv-board{grid-template-columns:1fr !important;}
  .geo-cards{grid-template-columns:1fr !important;}
  .stats-card{grid-template-columns:1fr !important;}

  /* Hero h1: адаптация шрифта и переноса длинных русских слов на <=480 */
  .hero h1{font-size:1.7rem !important;line-height:1.18;word-break:break-word;hyphens:auto;-webkit-hyphens:auto;}
}

/* === Sticky messenger sidebar === */
/* ===== Sticky messenger icons (WA / TG / Max) =====
   Превращает существующий .topbar-social (header.php) в фиксированный
   вертикальный сайдбар круглых иконок справа. Иконки видны при скролле.
   CSS-only решение: текст ссылок ("Telegram"/"WhatsApp"/"Max") скрывается
   через font-size:0, глиф рисуется через ::before по селектору [href*=].
   Если в будущем понадобится семантическая разметка (aria-label, SVG),
   потребуется также правка header.php (вынести блок .topbar-social
   в отдельный <div class="nm-sticky-messengers"> с явными иконками). */

.topbar .topbar-social{
  position:fixed;
  right:20px;
  top:50%;
  transform:translateY(-50%);
  z-index:9000;
  display:flex !important;
  flex-direction:column;
  gap:12px;
  padding:0;
  background:transparent;
  pointer-events:none; /* контейнер не ловит клики между иконками */
}

.topbar .topbar-social a{
  pointer-events:auto;
  display:flex;
  align-items:center;
  justify-content:center;
  width:48px;
  height:48px;
  border-radius:50%;
  font-size:0;          /* прячем текст-метку */
  line-height:0;
  color:#fff;
  text-decoration:none;
  box-shadow:0 6px 16px rgba(0,0,0,.18);
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;
}

.topbar .topbar-social a:hover{
  transform:translateY(-2px) scale(1.05);
  box-shadow:0 10px 22px rgba(0,0,0,.25);
  color:#fff;
  filter:brightness(1.05);
}

.topbar .topbar-social a::before{
  content:"";
  width:62%;
  height:62%;
  background-repeat:no-repeat;
  background-position:center;
  background-size:contain;
}

/* WhatsApp — зелёный круг + белый логотип трубки */
.topbar .topbar-social a[href*="wa.me"],
.topbar .topbar-social a[href*="whatsapp"]{
  background:#25D366;
}
.topbar .topbar-social a[href*="wa.me"]::before,
.topbar .topbar-social a[href*="whatsapp"]::before{
  background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32' fill='%23fff'%3E%3Cpath d='M16 3C9 3 3 9 3 16c0 2.4.7 4.6 1.9 6.5L3 29l6.7-1.8c1.9 1 4 1.6 6.3 1.6 7 0 13-6 13-13S23 3 16 3zm0 23.4c-2 0-3.9-.5-5.5-1.5l-.4-.2-4 1.1 1-3.9-.3-.4C5.5 19.8 5 17.9 5 16c0-6 4.9-11 11-11s11 4.9 11 11-4.9 11.4-11 11.4zm6-8.2c-.3-.2-1.9-.9-2.2-1-.3-.1-.5-.2-.7.2-.2.3-.8 1-1 1.2-.2.2-.4.2-.7.1-.3-.2-1.4-.5-2.6-1.6-1-.9-1.6-1.9-1.8-2.3-.2-.3 0-.5.1-.7.1-.1.3-.4.5-.6.1-.2.2-.3.3-.5.1-.2 0-.4 0-.5-.1-.2-.7-1.7-1-2.3-.3-.6-.5-.5-.7-.5h-.6c-.2 0-.5.1-.8.4-.3.3-1 1-1 2.4 0 1.4 1 2.8 1.2 3 .2.2 2 3 4.9 4.2.7.3 1.2.5 1.6.6.7.2 1.3.2 1.8.1.5-.1 1.7-.7 1.9-1.4.2-.7.2-1.2.2-1.4-.1-.2-.3-.2-.5-.4z'/%3E%3C/svg%3E");
}

/* Telegram — голубой круг + белый бумажный самолёт */
.topbar .topbar-social a[href*="t.me"],
.topbar .topbar-social a[href*="telegram"]{
  background:#229ED9;
}
.topbar .topbar-social a[href*="t.me"]::before,
.topbar .topbar-social a[href*="telegram"]::before{
  background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32' fill='%23fff'%3E%3Cpath d='M28 5.2 3.5 14.4c-1.4.5-1.4 1.5-.3 1.8l6.3 2 2.5 7.5c.3.8.5 1.1 1.1 1.1.5 0 .7-.2 1-.5l3-2.9 6.2 4.6c1.1.6 1.9.3 2.2-1l4-19c.4-1.6-.6-2.4-1.5-1.8zM12.4 19.3l-1 4-2-7L23 8.3l-10.6 11z'/%3E%3C/svg%3E");
}

/* MAX (VK Max) — фирменный сине-фиолетовый градиент + белая чат-бабл «а» */
.topbar .topbar-social a[href*="max"]{
  background:linear-gradient(135deg,#2962FF 0%,#9C27B0 100%);
}
.topbar .topbar-social a[href*="max"]::before{
  background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32' fill='%23fff'%3E%3Cpath d='M16 5C9.9 5 5 9.5 5 15c0 2.6 1.1 4.9 2.9 6.7L7.2 26c-.2.7.5 1.3 1.2 1l4.3-2.4c1 .3 2.1.4 3.2.4 6.1 0 11-4.5 11-10S22.1 5 16 5zm0 14.5c-2.5 0-4.5-2-4.5-4.5s2-4.5 4.5-4.5 4.5 2 4.5 4.5-2 4.5-4.5 4.5z'/%3E%3C/svg%3E");
}

/* Tablet / small desktop — слегка меньше и ближе к краю */
@media (max-width:900px){
  .topbar .topbar-social{
    right:12px;
    gap:10px;
  }
  .topbar .topbar-social a{
    width:44px;
    height:44px;
  }
}

/* Mobile — перенос в правый нижний угол, горизонтально/вертикально по вкусу */
@media (max-width:480px){
  /* Перебиваем существующее display:none на узких экранах */
  .topbar .topbar-social{
    display:flex !important;
    right:12px;
    left:auto;
    top:auto;
    bottom:16px;
    transform:none;
    flex-direction:column;
    gap:10px;
  }
  .topbar .topbar-social a{
    width:46px;
    height:46px;
    box-shadow:0 4px 14px rgba(0,0,0,.28);
  }
}

/* Печать — sticky-иконки не нужны */
@media print{
  .topbar .topbar-social{display:none !important;}
}

/* ═══════════════════════════════════════════════════════════════
   FINAL DIAGNOSTIC FIXES (MFD-03/05/06/09/11)
   Применены после financial workflow аудита перед deploy
   ═══════════════════════════════════════════════════════════════ */

/* MFD-03: на 1024 (iPad portrait) принудительно 1 колонка cta-inner */
@media (min-width:769px) and (max-width:1024px){
  .cta-inner{grid-template-columns:1fr !important;gap:36px;}
  .cta-text,.cta-form{width:100%;}
}

/* MFD-05: устаревший блок sticky-мессенджеров удалён — заменён единым DIAG-FIX-2 ниже */

/* MFD-06: .cat-item — снять жёсткую height, оставить только min-height */
@media (max-width:480px){
  .cat-item{height:auto !important;min-height:240px !important;}
}

/* MFD-09: touch targets для CTA-формы на mobile */
@media (max-width:480px){
  .cta-form select,.cta-form input,.cta-form button{min-height:44px;}
}

/* MFD-11: specs-table — th 25% вместо 46% на desktop, max-width ограничить */
@media (min-width:769px){
  .specs-table{max-width:780px;margin-left:auto;margin-right:auto;}
  .specs-table th{width:30% !important;}
}

/* MFD-01 cleanup: убедиться что для лишнего aside (если кеш) ничего не выводится */
.nm-sticky-messengers{display:none !important;}

/* ═══════════════════════════════════════════════════════════════
   MESSENGER PICKER MODAL
   Открывается по data-action="msg-picker"
   ═══════════════════════════════════════════════════════════════ */
.nm-msg-picker[hidden]{display:none;}
.nm-msg-picker{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;}
.nm-mp-backdrop{position:absolute;inset:0;background:rgba(20,28,48,.7);backdrop-filter:blur(4px);}
.nm-mp-card{position:relative;background:#fff;border-radius:14px;padding:32px 28px 26px;max-width:420px;width:calc(100% - 32px);box-shadow:0 20px 60px rgba(0,0,0,.3);}
.nm-mp-close{position:absolute;top:10px;right:14px;background:transparent;border:0;font-size:28px;line-height:1;color:#888;cursor:pointer;padding:4px 8px;}
.nm-mp-close:hover{color:#222;}
.nm-mp-card h3{font-family:var(--font-head);font-weight:700;font-size:1.35rem;color:var(--heading);margin:0 0 8px;text-align:center;}
.nm-mp-lead{color:var(--gray);font-size:.95rem;margin:0 0 22px;text-align:center;}
.nm-mp-buttons{display:flex;flex-direction:column;gap:10px;}
.nm-mp-btn{display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:10px;text-decoration:none;font-family:var(--font-head);font-weight:600;font-size:1.05rem;transition:.18s;color:#fff;}
.nm-mp-btn svg{flex-shrink:0;}
.nm-mp-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(0,0,0,.15);}
.nm-mp-wa{background:#25D366;}
.nm-mp-tg{background:#2AABEE;}
.nm-mp-max{background:#FF6B35;}
@media (max-width:480px){
  .nm-mp-card{padding:26px 20px 22px;}
  .nm-mp-card h3{font-size:1.2rem;}
  .nm-mp-btn{font-size:1rem;padding:13px 16px;}
}

/* ═══════════════════════════════════════════════════════════════
   DIAG-FIX-2 — финальные фиксы перед клиентским показом
   (заменяют устаревший POST-AUDIT FIXES блок)
   ═══════════════════════════════════════════════════════════════ */

/* DIAG-2-CRIT-02: Sticky-мессенджеры — единый размер 44px на всех breakpoint
   (предыдущий 36px на 1024 был слишком мелким). На мобиле — фиксированы внизу-справа. */
@media (max-width:1100px) and (min-width:769px){
  .topbar .topbar-social{right:14px !important;gap:10px !important;}
  .topbar .topbar-social a{width:44px !important;height:44px !important;}
}
@media (max-width:768px){
  /* Перебиваем display:none из @768 (линия 424) — мессенджеры нужны на мобиле */
  .topbar-social,.topbar .topbar-social{display:flex !important;
    position:fixed !important;right:12px !important;bottom:16px !important;
    top:auto !important;transform:none !important;flex-direction:column !important;
    gap:10px !important;z-index:999;}
  .topbar .topbar-social a{width:44px !important;height:44px !important;}
}
/* При открытой виртуальной клавиатуре прячем чтобы не закрывали поля */
@media (max-height:520px){
  .topbar-social,.topbar .topbar-social{display:none !important;}
}

/* DIAG-2-MOBILE-01/02: Резерв пространства под sticky-мессенджеры —
   реальный селектор footer (не .footer), плюс body padding-bottom как fallback
   для страниц без catalog/services/gallery сеток */
@media (max-width:480px){
  body{padding-bottom:80px;}
  footer{padding-bottom:24px;} /* собственный inner padding достаточен, body резервит */
}

/* DIAG-2-MOBILE-03: Footer на мобиле — текст по центру (1 колонка → центр) */
@media (max-width:480px){
  .footer-grid{text-align:center;}
  .footer-col h4{text-align:center;}
  .footer-col ul{padding:0;}
  .footer-col ul li{list-style:none;}
  .footer-col .fc-line{justify-content:center;flex-wrap:wrap;}
  .footer-brand .logo{justify-content:center;}
  .footer-brand p{text-align:center;}
  .footer-bottom{align-items:center;text-align:center;}
}

/* DIAG-2-CRIT-01: Footer на 768 — orphan-ячейка устранена.
   Ранее .footer-col:last-child{grid-column:span 2} создавал пустой "огрызок" справа.
   Сейчас footer-grid задан repeat(3,1fr) на линии 961 — Услуги/Каталог/Контакты ровно
   заполняют ряд после footer-brand{grid-column:1/-1}. Дополнительной правки не требуется. */

/* DIAG-2-CRIT-03: Бургер-меню — синхронизация breakpoint.
   Ранее: бургер появлялся с 1024, а nav уже сжимался с 1100 →
   в 1025-1100 nav плотный без бургера. Сейчас: бургер с 1100. */
@media (max-width:1100px) and (min-width:1025px){
  .burger{display:flex !important;}
  .header-cta>.btn{display:none !important;}
  header nav,nav.main-nav{position:fixed !important;top:0;right:-100%;width:80%;max-width:340px;
    height:100vh;background:#fff;flex-direction:column !important;gap:0;padding:90px 0 24px;
    box-shadow:-10px 0 40px rgba(33,45,69,.18);z-index:99;transition:right .3s ease;overflow-y:auto;}
  header nav a,nav.main-nav a{padding:18px 28px !important;border-bottom:1px solid var(--line);
    font-size:1rem !important;width:100%;}
  body.nav-open header nav,body.nav-open nav.main-nav{right:0 !important;}
  body.nav-open::before{content:"";position:fixed;inset:0;background:rgba(33,45,69,.45);z-index:98;}
  body.nav-open{overflow:hidden;}
}

/* DIAG-2-MAJOR-04: catalog-grid гибкий (не ломается при 5+ категориях) */
@media (min-width:769px){
  .catalog-grid{grid-template-rows:none !important;grid-auto-rows:296px;}
}

/* ═══════════════════════════════════════════════════════════════
   FOOTER — фоновое фото с тёмно-синим overlay (читаемость текста)
   ═══════════════════════════════════════════════════════════════ */
footer{
  position:relative;
  background-image:linear-gradient(rgba(20,28,48,.70),rgba(20,28,48,.88)),url('/wp-content/uploads/normetra-catalog/footer.jpg?v=2026-06-03') !important;
  background-size:cover;
  background-position:center;
  background-attachment:scroll;
}
@media (max-width:768px){
  footer{background-attachment:scroll;}
}

/* ═══════════════════════════════════════════════════════════════
   HERO — фоновое фото клиента (стеновая опалубка + арматура + кран)
   ═══════════════════════════════════════════════════════════════ */
.hero::before{
  background-image:linear-gradient(rgba(20,28,48,.55),rgba(20,28,48,.75)),url('/wp-content/uploads/normetra-catalog/header.jpg') !important;
  background-size:cover;
  background-position:center;
}

/* ─── Слайдер склада (warehouse) ─── */
.wh-slider{position:relative;width:100%;height:100%;border-radius:6px;overflow:hidden;}
.wh-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .5s ease;}
.wh-slide.active{opacity:1;}
.wh-slider-dots{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:5;}
.wh-dot{width:10px;height:10px;border-radius:50%;border:2px solid #fff;background:rgba(255,255,255,.3);cursor:pointer;padding:0;transition:.2s;}
.wh-dot:hover{background:rgba(255,255,255,.6);}
.wh-dot.active{background:var(--yellow);border-color:var(--yellow);}

/* ═══════════════════════════════════════════════════════════════
   CALCULATOR CTA — прикольный split-блок с мини-превью
   ═══════════════════════════════════════════════════════════════ */
.calc-cta{
  background:linear-gradient(135deg,#212d45 0%,#1a2338 100%);
  position:relative;
  overflow:hidden;
}
.calc-cta::before{
  content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,180,0,.12) 0%,transparent 70%);
  pointer-events:none;
}
.calc-cta-grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;position:relative;z-index:1;
}

/* ── Левая колонка ── */
.calc-cta-text{color:#fff;}
.calc-cta-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 16px;border:1px solid rgba(245,180,0,.4);border-radius:100px;
  background:rgba(245,180,0,.08);color:var(--yellow);
  font-family:var(--font-head);font-weight:600;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;
  margin-bottom:24px;
}
.calc-cta-badge svg{color:var(--yellow);}
.calc-cta-title{
  font-family:var(--font-head);font-weight:800;font-size:2.5rem;line-height:1.12;letter-spacing:-.01em;
  margin-bottom:18px;color:#fff;
}
.calc-cta-title .accent{color:var(--yellow);}
.calc-cta-lead{
  font-size:1.05rem;line-height:1.65;color:#cdd2dc;max-width:480px;margin-bottom:26px;
}
.calc-cta-perks{list-style:none;padding:0;margin:0 0 32px;display:flex;flex-direction:column;gap:12px;}
.calc-cta-perks li{
  display:flex;align-items:flex-start;gap:12px;font-size:.96rem;color:#e3e6ee;line-height:1.45;
}
.calc-cta-perks svg{
  width:22px;height:22px;flex-shrink:0;color:var(--yellow);
  background:rgba(245,180,0,.12);border-radius:50%;padding:4px;margin-top:1px;
}
.calc-cta-btn{
  font-size:1rem;padding:18px 32px;display:inline-flex;align-items:center;gap:10px;
}
.calc-cta-note{
  margin-top:12px;font-size:.82rem;color:#8b94a8;
}

/* ── Правая колонка — мини-превью калькулятора ── */
.calc-cta-preview{position:relative;}
.ccp-card{
  background:#fff;border-radius:14px;padding:24px;
  box-shadow:0 20px 60px rgba(0,0,0,.4),0 0 0 1px rgba(245,180,0,.15);
  transform:perspective(900px) rotateY(-3deg) rotateX(2deg);
  transform-origin:center;
  transition:transform .4s ease;
}
.calc-cta-preview:hover .ccp-card{transform:perspective(900px) rotateY(-1deg) rotateX(1deg) scale(1.01);}

.ccp-tabs{display:flex;gap:4px;background:#f3f4f7;border-radius:8px;padding:4px;margin-bottom:18px;}
.ccp-tab{flex:1;text-align:center;padding:9px 6px;font-size:12px;font-weight:600;color:#5e6776;
  font-family:var(--font-head);border-radius:6px;letter-spacing:.02em;}
.ccp-tab.on{background:var(--yellow);color:var(--heading);}

.ccp-row{display:flex;justify-content:space-between;align-items:baseline;
  padding:10px 0;border-bottom:1px solid #e6e9f0;font-size:14px;}
.ccp-row span{color:#5e6776;}
.ccp-row b{color:var(--heading);font-family:var(--font-head);font-weight:700;}

.ccp-divider{height:1px;background:linear-gradient(90deg,transparent,#e6e9f0,transparent);margin:14px 0;}

.ccp-results{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.ccp-result-card{background:#f9fafc;border-radius:8px;padding:12px 14px;border:1px solid #e6e9f0;}
.ccp-result-card.accent{background:#fff8e1;border-color:#f5e4a0;}
.ccp-result-l{font-size:11px;color:#5e6776;margin-bottom:4px;font-weight:500;text-transform:uppercase;letter-spacing:.04em;}
.ccp-result-v{font-size:18px;font-weight:800;color:var(--heading);font-family:var(--font-head);line-height:1.1;}
.ccp-result-card.accent .ccp-result-v{color:#d4a000;}

.ccp-cta-mini{margin-top:16px;text-align:center;padding:12px;background:#212d45;color:#fff;
  border-radius:8px;font-family:var(--font-head);font-weight:700;font-size:.82rem;letter-spacing:.04em;
  text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:8px;}
.ccp-cta-dot{width:8px;height:8px;background:var(--yellow);border-radius:50%;
  box-shadow:0 0 0 0 var(--yellow);animation:ccp-pulse 1.8s ease-in-out infinite;}
@keyframes ccp-pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(245,180,0,.5);}
  50%{box-shadow:0 0 0 6px rgba(245,180,0,0);}
}

/* Плавающие подсказки */
.ccp-float{position:absolute;background:#fff;border-radius:10px;padding:10px 14px;
  box-shadow:0 12px 30px rgba(0,0,0,.25);display:flex;flex-direction:column;gap:2px;
  z-index:3;font-family:var(--font-head);}
.ccp-float b{font-size:1.05rem;font-weight:800;color:var(--heading);line-height:1;}
.ccp-float span{font-size:.7rem;color:#5e6776;font-weight:500;}
.ccp-float-1{top:-18px;left:-30px;border-left:3px solid var(--yellow);}
.ccp-float-2{bottom:-12px;right:-20px;border-left:3px solid #25D366;}

/* ── Адаптив calc-cta — 6 breakpoint с плавной типографикой ── */

/* Большой десктоп (>1280) */
@media (min-width:1281px){
  .calc-cta-title{font-size:2.7rem;}
  .calc-cta-grid{gap:80px;}
}

/* Десктоп 1024-1280 */
@media (max-width:1280px) and (min-width:1025px){
  .calc-cta-grid{gap:50px;}
  .calc-cta-title{font-size:2.3rem;}
  .ccp-float-1{left:-22px;top:-15px;}
  .ccp-float-2{right:-15px;bottom:-8px;}
}

/* Планшет landscape 768-1024 */
@media (max-width:1024px) and (min-width:769px){
  .calc-cta-grid{grid-template-columns:1fr 1fr;gap:36px;}
  .calc-cta-title{font-size:1.85rem;line-height:1.18;}
  .calc-cta-lead{font-size:.96rem;margin-bottom:22px;}
  .calc-cta-perks li{font-size:.88rem;gap:10px;}
  .calc-cta-perks svg{width:20px;height:20px;}
  .calc-cta-btn{font-size:.92rem;padding:14px 22px;}
  .ccp-card{padding:18px;}
  .ccp-tab{font-size:11px;padding:8px 4px;}
  .ccp-row{font-size:13px;padding:8px 0;}
  .ccp-row b{font-size:13px;}
  .ccp-result-v{font-size:16px;}
  .ccp-cta-mini{font-size:.74rem;padding:10px;}
  .ccp-float{padding:8px 10px;}
  .ccp-float b{font-size:.92rem;}
  .ccp-float span{font-size:.62rem;}
  .ccp-float-1{left:-12px;top:-8px;}
  .ccp-float-2{right:-8px;bottom:-6px;}
}

/* Планшет portrait и меньше — 1 колонка, превью наверх */
@media (max-width:768px){
  .calc-cta{padding:60px 0;}
  .calc-cta-grid{grid-template-columns:1fr;gap:40px;}
  .calc-cta-text{text-align:center;}
  .calc-cta-text .calc-cta-perks{align-items:flex-start;}
  .calc-cta-title{font-size:1.8rem;line-height:1.18;}
  .calc-cta-lead{font-size:1rem;margin:0 auto 24px;}
  .calc-cta-perks{margin:0 auto 26px;display:inline-flex;text-align:left;}
  .calc-cta-preview{order:-1;max-width:460px;margin:0 auto;width:100%;}
  .ccp-card{transform:none;}
  .calc-cta-preview:hover .ccp-card{transform:none;}
  .calc-cta-btn{padding:16px 28px;}
}

/* Малый планшет 480-600 — float ещё видны но компактнее */
@media (max-width:600px){
  .calc-cta{padding:48px 0;}
  .calc-cta-title{font-size:1.55rem;}
  .calc-cta-lead{font-size:.94rem;}
  .ccp-float{padding:7px 10px;}
  .ccp-float b{font-size:.85rem;}
  .ccp-float span{font-size:.6rem;}
  .ccp-float-1{left:8px;top:-8px;}
  .ccp-float-2{right:8px;bottom:-6px;}
}

/* Мобильный (≤480) */
@media (max-width:480px){
  .calc-cta{padding:40px 0;}
  .calc-cta-grid{gap:28px;}
  .calc-cta-title{font-size:1.35rem;line-height:1.22;}
  .calc-cta-title br{display:none;}
  .calc-cta-lead{font-size:.92rem;line-height:1.55;margin-bottom:20px;}
  .calc-cta-perks{margin-bottom:22px;gap:10px;}
  .calc-cta-perks li{font-size:.88rem;}
  .calc-cta-btn{width:100%;justify-content:center;font-size:.92rem;padding:15px 20px;}
  .calc-cta-note{font-size:.76rem;}
  .ccp-card{padding:16px;border-radius:12px;}
  .ccp-tab{font-size:10.5px;padding:7px 3px;letter-spacing:0;}
  .ccp-row{font-size:13px;padding:8px 0;}
  .ccp-row b{font-size:13px;}
  .ccp-divider{margin:10px 0;}
  .ccp-result-card{padding:10px 12px;}
  .ccp-result-l{font-size:10px;}
  .ccp-result-v{font-size:15px;}
  .ccp-cta-mini{font-size:.72rem;padding:10px;letter-spacing:.02em;}
  .ccp-float{display:none;}
  .calc-cta::before{display:none;}
}

/* Узкий мобил (≤360) */
@media (max-width:360px){
  .calc-cta-title{font-size:1.2rem;}
  .calc-cta-perks li{font-size:.82rem;}
  .ccp-result-v{font-size:14px;}
}

/* ═══════════════════════════════════════════════════════════════
   DIAG-3 ARMOR — броневой блок sticky-мессенджеров на мобиле
   Финальное слово в каскаде. Специфичность 0,0,3,0 + !important
   на каждое свойство — гарантированно перебивает всё что выше.
   ═══════════════════════════════════════════════════════════════ */

/* Базовая видимость — три иконки в столбик справа-снизу на любом мобиле/планшете */
@media (max-width:1024px){
  div.topbar div.topbar-social,
  .topbar > .topbar-social{
    display:flex !important;
    visibility:visible !important;
    opacity:1 !important;
    position:fixed !important;
    right:14px !important;
    bottom:18px !important;
    top:auto !important;
    left:auto !important;
    transform:none !important;
    flex-direction:column !important;
    gap:10px !important;
    z-index:9999 !important;
    padding:0 !important;
    margin:0 !important;
    background:transparent !important;
    pointer-events:none !important;
  }
  div.topbar div.topbar-social a,
  .topbar > .topbar-social a{
    display:flex !important;
    visibility:visible !important;
    opacity:1 !important;
    pointer-events:auto !important;
    width:48px !important;
    height:48px !important;
    border-radius:50% !important;
    box-shadow:0 6px 18px rgba(0,0,0,.22) !important;
    font-size:0 !important;
    line-height:0 !important;
    color:#fff !important;
    text-decoration:none !important;
    align-items:center !important;
    justify-content:center !important;
  }
}

/* Узкий мобил — чуть компактнее */
@media (max-width:480px){
  div.topbar div.topbar-social,
  .topbar > .topbar-social{
    right:12px !important;
    bottom:14px !important;
    gap:8px !important;
  }
  div.topbar div.topbar-social a,
  .topbar > .topbar-social a{
    width:44px !important;
    height:44px !important;
  }
}

/* При альбомной ориентации или открытой клавиатуре прячем */
@media (max-height:480px) and (max-width:1024px){
  div.topbar div.topbar-social,
  .topbar > .topbar-social{display:none !important;}
}

/* ═══════════════════════════════════════════════════════════════
   DIAG-4 — Отдельный мобильный sticky-блок мессенджеров
   <aside class="nm-sticky-msg"> в footer.php (вне .topbar родителя).
   Решает проблему: на мобиле .topbar/.topbar-social где-то перебивается
   и иконки не видны. Новый блок имеет собственный класс и каскад без
   зависимостей — гарантированно видим.
   На десктопе скрыт (там работает оригинальный .topbar .topbar-social).
   ═══════════════════════════════════════════════════════════════ */

/* По умолчанию скрыт — на десктопе видим только оригинальный topbar-social */
.nm-sticky-msg{display:none;}

/* На мобиле/планшете до 1024px — показываем НОВЫЙ блок, ПРЯЧЕМ старый */
@media (max-width:1024px){
  .nm-sticky-msg{
    display:flex !important;
    position:fixed !important;
    right:14px !important;
    bottom:16px !important;
    z-index:9999 !important;
    flex-direction:column !important;
    gap:10px !important;
    margin:0 !important;
    padding:0 !important;
    background:transparent !important;
    pointer-events:none !important;
  }
  .nm-sm-btn{
    pointer-events:auto !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    width:48px !important;
    height:48px !important;
    border-radius:50% !important;
    box-shadow:0 6px 18px rgba(0,0,0,.25) !important;
    text-decoration:none !important;
    transition:transform .18s ease, box-shadow .18s ease !important;
  }
  .nm-sm-btn:hover,.nm-sm-btn:active{
    transform:translateY(-2px) scale(1.05) !important;
    box-shadow:0 10px 24px rgba(0,0,0,.32) !important;
  }
  .nm-sm-wa{background:#25D366 !important;}
  .nm-sm-tg{background:#229ED9 !important;}
  .nm-sm-max{background:linear-gradient(135deg,#2962FF 0%,#9C27B0 100%) !important;}

  /* Прячем оригинальный topbar-social на мобиле — теперь работает nm-sticky-msg */
  div.topbar div.topbar-social,
  .topbar > .topbar-social,
  .topbar-social{display:none !important;}
}

/* Узкий мобил — чуть компактнее */
@media (max-width:480px){
  .nm-sticky-msg{right:12px !important;bottom:14px !important;gap:8px !important;}
  .nm-sm-btn{width:44px !important;height:44px !important;}
  .nm-sm-btn svg{width:20px !important;height:20px !important;}
}

/* Виртуальная клавиатура (landscape mobile) — прячем чтоб не закрывать поля */
@media (max-height:480px) and (max-width:1024px){
  .nm-sticky-msg{display:none !important;}
}

/* ═══════════════════════════════════════════════════════════════
   DIAG-5 — Финальная порция фиксов:
   1) Sticky header работает на мобиле (overflow-x:clip вместо hidden)
   2) Логотип на мобиле крупнее
   3) Footer address: иконка и текст не разваливаются
   ═══════════════════════════════════════════════════════════════ */

/* 1) Sticky header гарантированно работает на всех экранах.
   Корень проблемы: html,body{overflow-x:hidden} на L523 создавал
   scrolling-container, к которому привязывался position:sticky вместо
   viewport — особенно ломалось в мобильных Safari/Chrome. Меняем на
   overflow-clip-margin / overflow:clip — то же поведение (никакого
   горизонтального скролла), но БЕЗ создания scrolling-container. */
html,body{
  overflow-x:clip !important;
}
header{
  position:sticky !important;
  top:0 !important;
  z-index:1000 !important;
  background:#fff !important;
}

/* 2) Логотип на мобиле — крупнее (раньше 40px/1.25rem был слишком тонкий) */
@media (max-width:768px){
  .logo-mark{width:46px !important;height:46px !important;}
  .logo-text .lt-main{font-size:1.4rem !important;}
  .logo-text .lt-sub{font-size:.68rem !important;letter-spacing:.14em !important;}
  .header-inner{padding:12px 0 !important;}
}
@media (max-width:480px){
  .logo-mark{width:42px !important;height:42px !important;}
  .logo-text .lt-main{font-size:1.3rem !important;}
  .logo-text .lt-sub{font-size:.65rem !important;}
}

/* ═══════════════════════════════════════════════════════════════
   DIAG-7 — Склад фото: правильный max-height на родителе
   Раньше DIAG-6 ставил aspect-ratio:16/10 на .wh-slider, но это
   конфликтовало с .wh-photo (aspect-ratio:4/3 default / 16/9 @1024)
   — слайдер вылезал ИЗ родителя. Теперь ограничиваем именно родитель.
   ═══════════════════════════════════════════════════════════════ */
.wh-photo{
  max-width:100% !important;
  max-height:480px !important;
  overflow:hidden !important;
  position:relative !important;
}
.wh-slider{
  position:relative !important;
  width:100% !important;
  height:100% !important;
  inset:auto !important;
}
.wh-slide{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  display:block;
}
@media (max-width:1100px){
  .wh-photo{max-height:400px !important;}
}
@media (max-width:1024px){
  .wh-photo{max-height:380px !important;aspect-ratio:16/9 !important;}
}
@media (max-width:768px){
  .wh-photo{max-height:280px !important;aspect-ratio:4/3 !important;}
}
@media (max-width:480px){
  .wh-photo{max-height:240px !important;}
}

/* 3) Footer address — иконка и текст в одной строке, длинный
   адрес переносится с висячим отступом, не разваливается. */
@media (max-width:768px){
  .footer-col .fc-line{align-items:flex-start;}
  .footer-col .fc-line .icon{margin-top:4px;flex-shrink:0;}
}

/* ═══════════════════════════════════════════════════════════════
   DIAG-8 — Единый header.jpg на всех page-banner + чистый шов CTA→footer
   ═══════════════════════════════════════════════════════════════ */
.page-banner::before{
  background-image:linear-gradient(105deg,rgba(33,45,69,.85) 0%,rgba(33,45,69,.65) 60%,rgba(33,45,69,.45) 100%),url('/wp-content/uploads/normetra-catalog/header.jpg?v=2026-06-03') !important;
  background-size:cover !important;
  background-position:center !important;
  opacity:1 !important;
}

/* ═══════════════════════════════════════════════════════════════
   DIAG-9 — СВАП: фото уходит на CTA (заявка), footer = плоский navy
   Заказчик: «фотография на блок заявки, под футером — просто синий».
   Применяется на всех брейкпоинтах (desktop / tablet / mobile).
   ═══════════════════════════════════════════════════════════════ */
.cta{
  background:linear-gradient(rgba(20,28,48,.78),rgba(20,28,48,.88)),url('/wp-content/uploads/normetra-catalog/footer.jpg?v=2026-06-04') !important;
  background-size:cover !important;
  background-position:center !important;
  background-repeat:no-repeat !important;
  border-bottom:0 !important;
  box-shadow:none !important;
}
.cta-bg-grid{display:none !important;} /* декоративный grid-pattern не нужен поверх фото */

footer{
  background-image:none !important;
  background:linear-gradient(180deg,#1a2338 0%,#141c30 100%) !important;
}
@media (max-width:768px){
  .cta{background-attachment:scroll !important;}
  footer{background-attachment:scroll !important;}
}
