/*
Theme Name: МотоДрайв Екатеринбург
Theme URI: https://motodrive-ekb.ru
Description: BMW-style тема для мотосалона — фулскрин слайдер, bento-сетка, мега-меню, мобильная drill-down навигация.
Version: 3.0.0
Text Domain: motodrive
*/

/* =================================================================
   СОДЕРЖАНИЕ
   -----------------------------------------------------------------
   01. Design tokens (CSS-переменные)
   02. Reset + base + типографика
   03. Layout primitives (container, section)
   04. Header + desktop nav + mega menu
   05. Burger + mobile menu (drill-down)
   06. Buttons + badges
   07. Section header (eyebrow + title + link)
   08. Hero slider
   09. Bento grid (tiles w2/w3/w4/w6)
   10. Categories strip
   11. Featured story
   12. Advantages strip
   13. Promo slider (CPT hero_slide — legacy fallback)
   14. Product card (shop + archive)
   15. Shop layout + filters
   16. Breadcrumbs + pagination
   17. News card / promotions
   18. CTA form (callback)
   19. Footer
   20. Scroll reveal + utility
   21. WooCommerce tweaks
   22. Media queries
   ================================================================= */


/* =================================================================
   01. DESIGN TOKENS
   ================================================================= */
:root{
  /* Палитра */
  --yellow:#FEC110;
  --yellow-hot:#FFD60A;
  --yellow-deep:#E5A500;
  --ink:#0A0A0A;
  --ink-2:#141414;
  --ink-3:#1A1A1A;
  --line-dark:#2A2A2A;
  --line:#EDEDED;
  --paper:#F7F7F5;
  --white:#FFFFFF;
  --muted:#8A8A8A;
  --text-dim:#4A4A4A;
  --red:#E63946;
  --green:#2ECC71;
  --success:#1EDC6B;
  --secondary:#FF3D00;

  /* Совместимость с legacy-переменными из старого style.css
     (чтобы не ломать инлайн-стили, которые могли остаться в PHP) */
  --primary:var(--yellow);
  --primary-dark:var(--yellow-deep);
  --bg-body:var(--white);
  --bg-light:var(--paper);
  --bg-dark:var(--ink);
  --text-primary:var(--ink);
  --text-secondary:var(--text-dim);
  --text-light:var(--white);
  --text-muted:var(--muted);
  --border-color:var(--line);
  --border-light:var(--line);

  /* Шрифты */
  --font-display:'Oswald','OswaldFallback','Impact',sans-serif;
  --font-body:'Inter','Helvetica Neue','Arial',sans-serif;
  --font-mono:'JetBrains Mono','Menlo','Consolas',monospace;

  /* Geometry */
  --container:1600px;
  --gutter:32px;
  --header-h:64px;

  /* Тени */
  --shadow-sm:0 1px 2px rgba(10,10,10,.05);
  --shadow-md:0 6px 20px -8px rgba(10,10,10,.12);
  --shadow-lg:0 20px 40px -16px rgba(10,10,10,.18);
  --shadow-glow:0 0 0 1px var(--yellow), 0 6px 24px -4px rgba(254,193,16,.35);

  /* Easings */
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  /* Radii — минимальные, BMW-like */
  --r-xs:0;
  --r-sm:2px;
  --r-md:4px;
}

/* Fallback-шрифт под Oswald с коррекцией метрик,
   чтобы layout не прыгал пока загружается Oswald */
@font-face{
  font-family:'OswaldFallback';
  src:local('Arial Narrow'),local('Impact'),local('sans-serif');
  size-adjust:88%;
  ascent-override:95%;
  descent-override:22%;
}

/* =================================================================
   02. RESET + BASE + ТИПОГРАФИКА
   ================================================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

body{
  font-family:var(--font-body);
  font-size:15px;
  line-height:1.6;
  color:var(--ink);
  background:var(--white);
  overflow-x:hidden;
  padding-top:var(--header-h);  /* отступ на высоту fixed-хедера — ОДИН РАЗ для всего сайта */
}
/* Если виден admin-bar WP — он автоматически добавляет отступ через html{margin-top},
   наш fixed-хедер нужно сдвинуть вниз чтобы admin-bar был виден над ним */
.admin-bar .header{top:32px}
@media screen and (max-width:782px){
  .admin-bar .header{top:46px}
}

img{max-width:100%;height:auto;display:block}
svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none;transition:color .2s var(--ease)}
button,input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}
button{cursor:pointer;border:none;background:none}
ul,ol{list-style:none}

h1,h2,h3,h4,h5,h6{
  font-family:var(--font-display);
  font-weight:500;
  line-height:1;
  letter-spacing:-.005em;
  text-transform:uppercase;
}

p{margin:0}

/* Блокируем скролл body когда открыто мобильное меню */
body.mmenu-open{overflow:hidden}


/* =================================================================
   03. LAYOUT PRIMITIVES
   ================================================================= */
.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--gutter);
}

.section{padding:80px 0;position:relative}
.sec{padding:120px 0;position:relative}
.sec--sm{padding:48px 0}
.sec--dark{background:var(--ink);color:var(--white)}
.sec--light{background:var(--paper)}

.section--light{background:var(--paper)}


/* =================================================================
   04. HEADER + DESKTOP NAV + MEGA MENU
   ================================================================= */
.header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:var(--white);
  border-bottom:1px solid var(--line);
  transition:transform .35s var(--ease);
}
.header.is-hidden{transform:translateY(-100%)}

.header__row{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--gutter);
  height:var(--header-h);
}
.header__left{display:flex;align-items:center;gap:48px}
.header__right{display:flex;align-items:center;gap:16px}

/* Logo */
.logo{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-weight:600;font-size:20px;letter-spacing:.02em;
  color:var(--ink);
}
.logo__mark{
  width:32px;height:32px;
  background:var(--ink);color:var(--yellow);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:700;font-size:16px;
}
.logo__text em,.logo em{color:var(--yellow-deep);font-style:normal}

/* Поддержка кастомного логотипа WordPress — убираем inline width/height */
.custom-logo{max-height:48px;width:auto}

/* Desktop navigation */
.nav-main{display:flex;gap:2px}
.nav-main__item{position:static}
.nav-main__link{
  padding:0 16px;height:var(--header-h);
  display:flex;align-items:center;gap:6px;
  font-size:13px;font-weight:500;letter-spacing:.02em;
  color:var(--ink);position:relative;
  transition:color .2s var(--ease);
  cursor:pointer;
  white-space:nowrap;
}
.nav-main__link svg{width:10px;height:10px;transition:transform .25s var(--ease);opacity:.6;fill:none;stroke:currentColor;stroke-width:2}
.nav-main__item:hover .nav-main__link svg{transform:rotate(180deg)}
.nav-main__link::after{
  content:'';position:absolute;bottom:0;left:16px;right:16px;
  height:2px;background:var(--yellow);
  transform:scaleX(0);transform-origin:left;
  transition:transform .3s var(--ease);
}
.nav-main__link:hover::after,.nav-main__item:hover .nav-main__link::after{transform:scaleX(1)}
.nav-main__link--sale{color:var(--red)}

/* Search, phone, icons в шапке */
.header__phone{
  font-family:var(--font-display);font-weight:500;font-size:16px;letter-spacing:.01em;
  color:var(--ink);
}
.header__phone:hover{color:var(--yellow-deep)}

.header__icon{
  width:40px;height:40px;
  display:flex;align-items:center;justify-content:center;
  position:relative;
  color:var(--ink);
  transition:background .2s var(--ease);
}
.header__icon:hover{background:var(--paper)}
.header__icon svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.7}
.header__icon-count,.header__cart-count{
  position:absolute;top:4px;right:2px;
  min-width:18px;height:18px;padding:0 5px;
  background:var(--yellow);color:var(--ink);
  font-family:var(--font-mono);font-size:10px;font-weight:700;
  border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  line-height:1;
}

/* === MEGA MENU === */
.mega{
  position:absolute;top:var(--header-h);left:0;right:0;z-index:50;
  background:var(--white);
  border-top:1px solid var(--line);
  box-shadow:0 30px 60px -10px rgba(0,0,0,.12);
  opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:opacity .3s var(--ease),transform .3s var(--ease),visibility .3s;
  pointer-events:none;
}
.nav-main__item:hover .mega{
  opacity:1;visibility:visible;transform:none;pointer-events:auto;
}
.mega__inner{
  max-width:var(--container);margin:0 auto;padding:36px var(--gutter);
  display:grid;grid-template-columns:repeat(5,1fr);gap:16px;
}
.mega__item{
  display:flex;flex-direction:column;gap:10px;
  padding:16px;background:var(--paper);
  color:var(--ink);
  transition:background .25s var(--ease),transform .25s var(--ease),color .25s var(--ease);
}
.mega__item:hover{background:var(--ink);color:var(--white);transform:translateY(-4px)}
.mega__item-img,.mega-menu__image{
  height:100px;display:flex;align-items:center;justify-content:center;
  background:var(--white);transition:background .25s var(--ease);
}
.mega__item:hover .mega__item-img,.mega__item:hover .mega-menu__image{background:var(--yellow)}
.mega__item-img img,.mega-menu__image img{max-width:80%;max-height:80px;object-fit:contain}
.mega__item-img svg,.mega-menu__image svg{
  width:40px;height:40px;
  color:var(--muted);fill:none;stroke:currentColor;stroke-width:1.5;
  transition:color .25s var(--ease);
}
.mega__item:hover .mega__item-img svg,.mega__item:hover .mega-menu__image svg{color:var(--ink)}
.mega__item-title,.mega-menu__title{
  font-family:var(--font-display);font-weight:500;font-size:15px;letter-spacing:.03em;text-transform:uppercase;
}
.mega__item-count,.mega-menu__count{
  font-family:var(--font-mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;
  color:var(--muted);
}
.mega__item:hover .mega__item-count,.mega__item:hover .mega-menu__count{color:var(--yellow)}


/* =================================================================
   05. BURGER + MOBILE MENU (drill-down, BMW-style)
   ================================================================= */
.burger{
  display:none;
  width:40px;height:40px;
  flex-direction:column;align-items:center;justify-content:center;gap:5px;
  padding:0;
  transition:background .2s var(--ease);
}
.burger:hover{background:var(--paper)}
.burger span{
  display:block;width:20px;height:2px;background:var(--ink);
  transition:transform .3s var(--ease),opacity .2s var(--ease);
  transform-origin:center;
}
.burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mmenu{
  position:fixed;inset:0;z-index:200;
  pointer-events:none;visibility:hidden;
  transition:visibility 0s .4s;
}
.mmenu.is-open{pointer-events:auto;visibility:visible;transition:visibility 0s}

.mmenu__backdrop{
  position:absolute;inset:0;background:rgba(0,0,0,.4);
  opacity:0;transition:opacity .35s var(--ease);
}
.mmenu.is-open .mmenu__backdrop{opacity:1}

.mmenu__panel{
  position:absolute;top:0;right:0;bottom:0;
  width:100%;max-width:420px;
  background:var(--white);color:var(--ink);
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform .4s var(--ease);
  box-shadow:-20px 0 40px rgba(0,0,0,.1);
}
.mmenu.is-open .mmenu__panel{transform:none}

.mmenu__head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:12px 16px;
  border-bottom:1px solid var(--line);
  height:var(--header-h);flex-shrink:0;
}
.mmenu__back{
  display:flex;align-items:center;gap:6px;padding:8px 12px;margin-left:-12px;
  font-family:var(--font-display);font-size:13px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink);
  opacity:0;visibility:hidden;transform:translateX(-8px);
  transition:opacity .25s,transform .25s,visibility .25s;
}
.mmenu.is-deep .mmenu__back{opacity:1;visibility:visible;transform:none}
.mmenu__back svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}

.mmenu__title{
  flex:1;text-align:center;
  font-family:var(--font-display);font-size:15px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;
}
.mmenu.is-deep .mmenu__title{text-align:left;padding-left:4px}

.mmenu__close{
  width:40px;height:40px;display:flex;align-items:center;justify-content:center;
  color:var(--ink);transition:background .2s var(--ease);
}
.mmenu__close:hover{background:var(--paper)}
.mmenu__close svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2}

.mmenu__body{flex:1;overflow:hidden;position:relative}
.mmenu__slides{
  position:relative;
  width:100%;height:100%;
}

.mmenu__slide{
  position:absolute;
  top:0;left:0;right:0;bottom:0;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  flex-direction:column;
  transform:translateX(100%);
  transition:transform .35s var(--ease);
  background:var(--white);
  display:flex;
  visibility:hidden;
}
/* LEVEL 0 — root slide, изначально на месте */
.mmenu__slide[data-level="0"]{
  transform:translateX(0);
  visibility:visible;
}
/* Когда открыт drill-down — LEVEL 0 уезжает влево */
.mmenu.is-deep .mmenu__slide[data-level="0"]{
  transform:translateX(-100%);
}
/* Активный LEVEL 1 — въезжает справа */
.mmenu__slide[data-level="1"].is-active{
  transform:translateX(0);
  visibility:visible;
}

.mmenu__list{list-style:none;padding:0;margin:0}
.mmenu__list li{border-bottom:1px solid var(--line)}

.mmenu__link{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  width:100%;padding:20px 24px;
  font-family:var(--font-display);font-size:17px;font-weight:500;letter-spacing:.02em;text-transform:uppercase;
  color:var(--ink);background:none;border:none;text-align:left;cursor:pointer;
  transition:background .2s var(--ease),color .2s var(--ease),padding-left .25s var(--ease);
}
.mmenu__link:hover,.mmenu__link:active{background:var(--paper);padding-left:28px}
.mmenu__link--sale{color:var(--red)}
.mmenu__link--all{
  color:var(--yellow-deep);font-size:14px;letter-spacing:.1em;
  background:var(--paper);
}
.mmenu__link--all svg{
  width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;
  transition:transform .25s var(--ease);
}
.mmenu__link--all:hover svg{transform:translateX(4px)}

.mmenu__chev{
  width:16px;height:16px;color:var(--muted);
  stroke:currentColor;fill:none;stroke-width:2;
  transition:transform .25s var(--ease),color .2s var(--ease);
}
.mmenu__link:hover .mmenu__chev{color:var(--yellow-deep);transform:translateX(4px)}

.mmenu__count{
  font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:.05em;
  color:var(--muted);text-transform:none;
}

.mmenu__contact{
  margin-top:auto;padding:24px;
  background:var(--ink);color:var(--white);
}
.mmenu__contact-label{
  font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--yellow);margin-bottom:10px;
}
.mmenu__phone{
  display:block;
  font-family:var(--font-display);font-size:28px;font-weight:500;letter-spacing:.02em;
  color:var(--white);margin-bottom:6px;
}
.mmenu__phone:hover{color:var(--yellow)}
.mmenu__hours{
  font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.5);
}


/* =================================================================
   06. BUTTONS + BADGES
   ================================================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 28px;
  font-family:var(--font-display);font-weight:500;font-size:13px;
  letter-spacing:.15em;text-transform:uppercase;
  border:none;cursor:pointer;
  transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease),filter .2s var(--ease);
  position:relative;
}
.btn svg{
  width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;
  transition:transform .3s var(--ease);
}
.btn:hover svg{transform:translateX(6px)}

.btn--primary,.btn--yellow{background:var(--yellow);color:var(--ink)}
.btn--primary:hover,.btn--yellow:hover{background:var(--yellow-hot)}

.btn--secondary,.btn--ghost{
  background:transparent;color:var(--ink);
  border:1px solid var(--ink);
}
.btn--secondary:hover,.btn--ghost:hover{background:var(--ink);color:var(--white)}

.btn--outline{
  background:transparent;color:var(--white);
  border:1px solid rgba(255,255,255,.4);
}
.btn--outline:hover{background:var(--white);color:var(--ink);border-color:var(--white)}

.btn--dark-solid{background:var(--ink);color:var(--white)}
.btn--dark-solid:hover{background:var(--ink-3)}

.btn--red{background:var(--red);color:var(--white)}
.btn--red:hover{filter:brightness(1.08)}

.btn--lg{padding:18px 36px;font-size:14px}
.btn--sm{padding:10px 18px;font-size:12px}

/* Badges */
.badge{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-mono);font-weight:700;font-size:11px;letter-spacing:.08em;
  padding:5px 10px;text-transform:uppercase;
  background:var(--yellow);color:var(--ink);
}
.badge--hit{background:var(--yellow);color:var(--ink)}
.badge--new{background:var(--green);color:var(--white)}
.badge--sale{background:var(--red);color:var(--white)}
.badge--stock{background:transparent;color:var(--green);padding:0;font-size:11px}
.badge--stock::before{content:'●';margin-right:6px;filter:drop-shadow(0 0 4px var(--green))}
.badge--nostock{background:transparent;color:var(--muted);padding:0;font-size:11px}
.badge--nostock::before{content:'○';margin-right:6px}


/* =================================================================
   07. SECTION HEADER (eyebrow + title + link)
   ================================================================= */
.sec-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:32px;margin-bottom:56px;
}
.sec-head--center{justify-content:center;text-align:center;flex-direction:column;align-items:center}

.sec-eyebrow{
  font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.25em;
  text-transform:uppercase;color:var(--yellow-deep);
  margin-bottom:12px;
  display:inline-flex;align-items:center;gap:12px;
}
.sec-eyebrow::before{content:'';width:32px;height:1px;background:var(--yellow)}
.sec-head--center .sec-eyebrow{justify-content:center}
.sec--dark .sec-eyebrow{color:var(--yellow)}

.sec-title{
  font-size:clamp(40px,5.5vw,72px);
  font-weight:500;line-height:1.02;
}
.sec-title em{color:var(--yellow-deep);font-style:normal;font-weight:600}
.sec--dark .sec-title em{color:var(--yellow)}

/* Совместимость со старыми названиями */
.section-subtitle{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.25em;
  text-transform:uppercase;color:var(--yellow-deep);
  margin-bottom:12px;
}
.section-subtitle::before{content:'';width:32px;height:1px;background:var(--yellow)}
.section-title{font-family:var(--font-display);font-size:clamp(40px,5.5vw,72px);font-weight:500;line-height:1.02;text-transform:uppercase}
.section-title span{color:var(--yellow-deep)}
.section-header{margin-bottom:56px}

.sec-link{
  font-family:var(--font-display);font-size:13px;font-weight:500;letter-spacing:.15em;
  text-transform:uppercase;
  display:inline-flex;align-items:center;gap:10px;
  border-bottom:1px solid currentColor;padding-bottom:2px;
  transition:gap .25s var(--ease),color .25s var(--ease);
}
.sec-link:hover{gap:16px;color:var(--yellow-deep)}
.sec-link svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}


/* =================================================================
   08. HERO SLIDER (фулскрин, категория-свитч, BMW-like)
   ================================================================= */
.hero{
  position:relative;
  height:calc(100vh - var(--header-h));
  min-height:640px;
  background:var(--ink);overflow:hidden;
}
/* WP admin-bar добавляет 32px сверху — hero должен это компенсировать */
.admin-bar .hero{
  height:calc(100vh - var(--header-h) - 32px);
}
@media screen and (max-width:782px){
  .admin-bar .hero{
    height:calc(100vh - var(--header-h) - 46px);
  }
}

.hero__cats{
  position:absolute;top:28px;left:0;right:0;z-index:10;
  display:flex;justify-content:center;gap:0;
  padding:0 var(--gutter);
}
.hero__cat{
  padding:10px 22px;
  font-family:var(--font-display);font-weight:500;font-size:13px;letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(255,255,255,.55);
  background:none;border:none;cursor:pointer;
  position:relative;
  transition:color .25s var(--ease);
}
.hero__cat::after{
  content:'';position:absolute;bottom:0;left:22px;right:22px;
  height:2px;background:var(--yellow);
  opacity:0;transform:scaleX(0);transform-origin:center;
  transition:all .35s var(--ease);
}
.hero__cat:hover{color:var(--white)}
.hero__cat.is-active{color:var(--yellow)}
.hero__cat.is-active::after{opacity:1;transform:scaleX(1)}

.hero__slides{position:absolute;inset:0}
.hero__slide{
  position:absolute;inset:0;
  display:flex;align-items:center;
  opacity:0;visibility:hidden;
  transition:opacity .8s var(--ease),visibility .8s;
}
.hero__slide.is-active{opacity:1;visibility:visible}

.hero__img{position:absolute;inset:0;overflow:hidden}
.hero__img::before{
  content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg, rgba(10,10,10,0.5) 0%, rgba(10,10,10,0) 40%, rgba(10,10,10,.5) 100%);
}
.hero__img img{
  width:100%;height:100%;object-fit:cover;
  transform:scale(1.05);transition:transform 6s ease-out;
}
.hero__slide.is-active .hero__img img{transform:scale(1)}

.hero__content{
  position:relative;z-index:2;
  max-width:var(--container);width:100%;margin:0 auto;padding:0 var(--gutter);
  color:var(--white);
}
.hero__meta{
  display:flex;align-items:center;gap:14px;
  font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.2em;
  color:var(--yellow);text-transform:uppercase;
  margin-bottom:20px;
  opacity:0;transform:translateY(12px);
  transition:opacity .7s .3s var(--ease),transform .7s .3s var(--ease);
}
.hero__slide.is-active .hero__meta{opacity:1;transform:none}
.hero__meta::before{content:'';width:32px;height:1px;background:var(--yellow)}

.hero__title{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(56px,9vw,132px);line-height:.95;letter-spacing:-.01em;
  text-transform:uppercase;color:#fff;
  margin-bottom:20px;padding-bottom:8px;
  text-shadow:0 2px 24px rgba(0,0,0,.5), 0 1px 2px rgba(0,0,0,.35);
  opacity:0;transform:translateY(24px);
  transition:opacity .8s .45s var(--ease),transform .9s .45s var(--ease);
}
.hero__slide.is-active .hero__title{opacity:1;transform:none}
.hero__title em{color:var(--yellow);font-style:normal;font-weight:600;text-shadow:0 2px 24px rgba(0,0,0,.7), 0 1px 3px rgba(0,0,0,.55)}

.hero__tagline{
  font-size:18px;max-width:540px;color:rgba(255,255,255,.92);
  margin-bottom:40px;
  text-shadow:0 1px 12px rgba(0,0,0,.55), 0 1px 2px rgba(0,0,0,.4);
  opacity:0;transform:translateY(16px);
  transition:opacity .8s .65s var(--ease),transform .8s .65s var(--ease);
}
.hero__slide.is-active .hero__tagline{opacity:1;transform:none}

.hero__ctas{
  display:flex;gap:16px;flex-wrap:wrap;
  opacity:0;transform:translateY(16px);
  transition:opacity .8s .8s var(--ease),transform .8s .8s var(--ease);
}
.hero__slide.is-active .hero__ctas{opacity:1;transform:none}

.hero__bottom{
  position:absolute;bottom:32px;left:0;right:0;z-index:10;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--gutter);
}
.hero__counter{
  font-family:var(--font-mono);font-size:13px;color:rgba(255,255,255,.6);letter-spacing:.1em;
}
.hero__counter b{color:var(--white);font-weight:500}

.hero__nav{display:flex;gap:10px}
.hero__arrow{
  width:52px;height:52px;
  border:1px solid rgba(255,255,255,.3);
  display:flex;align-items:center;justify-content:center;
  color:var(--white);
  background:rgba(10,10,10,.2);backdrop-filter:blur(8px);
  transition:all .25s var(--ease);
}
.hero__arrow:hover{background:var(--yellow);color:var(--ink);border-color:var(--yellow)}
.hero__arrow svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2}

.hero__progress{
  position:absolute;bottom:0;left:0;right:0;z-index:10;
  height:2px;background:rgba(255,255,255,.1);
}
.hero__progress-fill{
  height:100%;background:var(--yellow);width:0;
  transition:width .1s linear;
}


/* =================================================================
   09. BENTO GRID (tile system: w2/w3/w4/w6)
   ================================================================= */
.bento{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  grid-auto-rows:440px;
  gap:12px;
}
/* Ширины — сумма span в ряду всегда = 6 */
.tile--w2{grid-column:span 2}
.tile--w3{grid-column:span 3}
.tile--w4{grid-column:span 4}
.tile--w6{grid-column:span 6}

.tile{
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:28px;
  color:var(--white);
  background:var(--ink);
  cursor:pointer;
  isolation:isolate;
}
.tile__bg{
  position:absolute;inset:0;z-index:-2;
  background-size:cover;background-position:center;
  transition:transform .9s var(--ease-out);
}
.tile:hover .tile__bg{transform:scale(1.06)}
.tile__overlay{
  position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(10,10,10,.15) 0%,rgba(10,10,10,.3) 50%,rgba(10,10,10,.85) 100%);
  transition:background .4s var(--ease);
}
.tile:hover .tile__overlay{
  background:linear-gradient(180deg,rgba(10,10,10,.2) 0%,rgba(10,10,10,.45) 50%,rgba(10,10,10,.9) 100%);
}

.tile__tag{
  position:absolute;top:24px;left:24px;
  font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.2em;
  color:var(--yellow);text-transform:uppercase;
  padding:6px 10px;
  border:1px solid rgba(254,193,16,.4);
  background:rgba(10,10,10,.3);backdrop-filter:blur(8px);
}

.tile__title{
  font-family:var(--font-display);font-weight:500;font-size:36px;line-height:1.02;letter-spacing:-.01em;
  text-transform:uppercase;margin-bottom:8px;padding-bottom:4px;
  overflow-wrap:break-word;hyphens:auto;
}
.tile--w4 .tile__title{font-size:56px}
.tile--w3 .tile__title{font-size:42px}
.tile--w2 .tile__title{font-size:28px}

.tile__desc{
  font-size:14px;color:rgba(255,255,255,.75);max-width:420px;margin-bottom:16px;
  opacity:0;transform:translateY(8px);
  transition:opacity .35s var(--ease),transform .35s var(--ease);
}
.tile:hover .tile__desc{opacity:1;transform:none}

.tile__arrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-size:12px;font-weight:500;letter-spacing:.15em;text-transform:uppercase;
  color:var(--yellow);
  transition:gap .3s var(--ease);
}
.tile:hover .tile__arrow{gap:16px}
.tile__arrow svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}

.tile--light{background:var(--paper);color:var(--ink)}
.tile--light .tile__overlay{display:none}
.tile--light .tile__desc{color:var(--text-dim);opacity:1;transform:none}
.tile--light .tile__tag{color:var(--yellow-deep);border-color:var(--yellow);background:rgba(254,193,16,.1)}
.tile--light .tile__arrow{color:var(--yellow-deep)}

.tile__price{
  font-family:var(--font-mono);font-weight:700;font-size:22px;letter-spacing:-.02em;
  margin-bottom:4px;
}
.tile__price-from{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  color:rgba(255,255,255,.6);letter-spacing:.15em;text-transform:uppercase;margin-right:6px;
}
.tile--light .tile__price{color:var(--ink)}
.tile--light .tile__price-from{color:var(--muted)}

.tile__specs{
  display:flex;gap:20px;flex-wrap:wrap;
  font-family:var(--font-mono);font-size:11px;color:rgba(255,255,255,.65);
  letter-spacing:.05em;text-transform:uppercase;
  margin-bottom:14px;
}
.tile__spec b{color:var(--yellow);font-weight:500;margin-right:4px}
.tile--light .tile__spec{color:var(--muted)}
.tile--light .tile__spec b{color:var(--yellow-deep)}


/* =================================================================
   10-NEW. STORIES BENTO — "Выбери свой путь" (CPT story_card)
   ================================================================= */
.stories{
  background:var(--ink);
  padding:40px 0 40px;
  color:var(--white);
}
.stories .sec-head{margin-bottom:48px}
.stories .sec-title{color:var(--white)}

.stories__grid{
  display:grid;
  grid-template-columns:repeat(6, 1fr);
  gap:16px;
  width:100%;
  box-sizing:border-box;
}
.stories__grid > *{
  min-width:0;
}

/* Размеры плиток с aspect-ratio */
.story--small {grid-column:span 2; aspect-ratio:3/4}
.story--medium{grid-column:span 3; aspect-ratio:4/3}
.story--large {grid-column:span 4; aspect-ratio:16/10}
.story--hero  {grid-column:span 6; aspect-ratio:21/9}

/* Карточка */
.story{
  position:relative;
  display:block;
  overflow:hidden;
  background:#1a1a1a;
  color:inherit;text-decoration:none;
  transition:transform .4s var(--ease-out);
  min-height:280px;
}
.story:hover{transform:translateY(-4px)}

.story__bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transition:transform .8s var(--ease-out),filter .4s;
  filter:brightness(.92);
}
.story:hover .story__bg{transform:scale(1.06);filter:brightness(1)}

.story__plate{
  position:absolute;left:24px;right:24px;bottom:24px;z-index:2;
  background:rgba(255,255,255,.96);
  padding:22px 24px 24px;
  color:var(--ink);
  max-width:420px;
}
.story--small .story__plate{left:16px;right:16px;bottom:16px;padding:16px 18px 18px}
.story--hero  .story__plate{max-width:520px}

.story__title{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(20px,2.4vw,32px);line-height:1.05;
  margin:0 0 6px;
  text-transform:uppercase;
  letter-spacing:-.005em;
}
.story__subtitle{
  font-size:14px;line-height:1.4;color:var(--muted);
  margin:0;
}
.story__line{
  display:block;height:2px;width:40%;
  background:var(--yellow);
  margin-top:16px;
  transition:width .5s var(--ease-out);
}
.story:hover .story__line{width:100%}

/* Адаптив: на мобилке все карточки в одну колонку */
@media (max-width: 900px){
  .stories{padding:60px 0}
  .stories__grid{
    grid-template-columns:1fr;
    grid-auto-rows:auto;  /* на мобилке высота автоматически по контенту */
    gap:12px;
  }
  .story--small, .story--medium, .story--large, .story--hero{
    grid-column:1 / -1;
    grid-row:span 1;
    aspect-ratio:16/10;
    min-height:220px;
  }
  .story__plate{left:16px;right:16px;bottom:16px;padding:14px 18px 16px;max-width:100%}
  .story__title{font-size:18px}
  .story__subtitle{font-size:13px}
}
@media (max-width: 480px){
  .stories{padding:48px 0}
  .story--small, .story--medium, .story--large, .story--hero{
    aspect-ratio:4/3;
    min-height:200px;
  }
}

/* MOBILE FIX для stories-grid */
@media (max-width: 900px){
  .stories{padding:60px 0 !important}
  .stories__grid{
    grid-template-columns:1fr !important;
    gap:12px !important;
  }
  .stories__grid .story,
  .story--small, .story--medium, .story--large, .story--hero{
    grid-column:1 / -1 !important;
    aspect-ratio:4/3 !important;
    min-height:240px !important;
    max-width:100% !important;
  }
  .story__plate{
    left:16px !important;right:16px !important;bottom:16px !important;
    padding:14px 18px 16px !important;
    max-width:calc(100% - 32px) !important;
  }
  .story__title{font-size:18px !important}
  .story__subtitle{font-size:13px !important}
}

/* =================================================================
   11. FEATURED STORY — горизонтальный нарратив
   ================================================================= */
.featured-story{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  background:var(--ink);color:var(--white);
  overflow:hidden;min-height:560px;
}
.featured-story__visual{background-size:cover;background-position:center;min-height:500px}
.featured-story__content{
  padding:72px 56px;
  display:flex;flex-direction:column;justify-content:center;
}
.featured-story__category{
  font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.25em;text-transform:uppercase;
  color:var(--yellow);margin-bottom:20px;
}
.featured-story__title{
  font-family:var(--font-display);font-size:54px;line-height:1.05;font-weight:500;
  text-transform:uppercase;margin-bottom:20px;
}
.featured-story__title em{color:var(--yellow);font-style:normal;font-weight:600}
.featured-story__text{
  color:rgba(255,255,255,.75);
  margin-bottom:32px;max-width:520px;font-size:15px;line-height:1.7;
}
.featured-story__btn{align-self:flex-start}


/* =================================================================
   12. ADVANTAGES STRIP (6 преимуществ в линию)
   ================================================================= */
.advs{display:grid;grid-template-columns:repeat(6,1fr);gap:0}
.adv{
  padding:48px 24px;text-align:center;
  border-right:1px solid var(--line);
  transition:background .3s var(--ease);
}
.adv:last-child{border-right:none}
.adv:hover{background:var(--paper)}
.adv__icon{
  width:56px;height:56px;margin:0 auto 16px;
  display:flex;align-items:center;justify-content:center;
  color:var(--yellow-deep);
}
.adv__icon svg{width:36px;height:36px;stroke:currentColor;fill:none;stroke-width:1.5}
.adv__title{
  font-family:var(--font-display);font-size:14px;font-weight:500;letter-spacing:.08em;
  text-transform:uppercase;margin-bottom:6px;color:var(--ink);
}
.adv__text{font-size:12px;color:var(--muted);line-height:1.5}

/* Совместимость со старыми advantage-card */
.advantages__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:0}
.advantage-card{
  padding:48px 24px;text-align:center;
  border-right:1px solid var(--line);
  transition:background .3s var(--ease);
}
.advantage-card:last-child{border-right:none}
.advantage-card:hover{background:var(--paper);transform:none;box-shadow:none}
.advantage-card__icon{
  width:56px;height:56px;margin:0 auto 16px;
  display:flex;align-items:center;justify-content:center;
  background:none;border-radius:0;box-shadow:none;
  color:var(--yellow-deep);
}
.advantage-card__icon svg{width:36px;height:36px;stroke:currentColor;fill:none;stroke-width:1.5}
.advantage-card__title{
  font-family:var(--font-display);font-size:14px;font-weight:500;letter-spacing:.08em;
  text-transform:uppercase;margin-bottom:6px;color:var(--ink);
}
.advantage-card__text{font-size:12px;color:var(--muted);line-height:1.5}


/* =================================================================
   13. PROMO SLIDER (legacy CPT hero_slide — если используется)
   ================================================================= */
.promo-slider{
  background:var(--ink);color:var(--white);position:relative;overflow:hidden;
}
.promo-slider__viewport{overflow:hidden;width:100%}
.promo-slider__wrapper{display:flex;width:100%;transition:transform .5s var(--ease)}
.promo-slider__slide{
  flex:0 0 100%;position:relative;width:100%;
  aspect-ratio:16/7;
  background-position:center;background-repeat:no-repeat;background-size:cover;
  overflow:hidden;
}
.promo-slider__slide::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(10,10,10,.8) 0%,rgba(10,10,10,.3) 60%,transparent 100%);
}
.promo-slider__inner{
  position:absolute;inset:0;z-index:2;
  display:flex;align-items:center;
  padding:clamp(24px,5vw,64px);
  max-width:var(--container);margin:0 auto;
}
.promo-slider__content{max-width:600px}
.promo-slider__badge{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--yellow);background:none;padding:0;margin-bottom:16px;
}
.promo-slider__badge::before{content:'';width:32px;height:1px;background:var(--yellow)}
.promo-slider__title{
  font-family:var(--font-display);font-size:clamp(40px,6vw,72px);line-height:1;font-weight:500;
  text-transform:uppercase;margin-bottom:20px;color:var(--white);
}
.promo-slider__title span{color:var(--yellow);font-weight:600}
.promo-slider__text{font-size:16px;color:rgba(255,255,255,.75);margin-bottom:24px;max-width:480px}
.promo-slider__price{display:flex;align-items:baseline;gap:14px;margin-bottom:28px}
.promo-slider__price-new{
  font-family:var(--font-mono);font-weight:700;font-size:40px;color:var(--yellow);letter-spacing:-.02em;
}
.promo-slider__price-old{
  font-family:var(--font-mono);font-size:16px;color:rgba(255,255,255,.4);text-decoration:line-through;
}
.promo-slider__image{display:none}

.promo-slider__nav{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:3;
  display:flex;gap:8px;
}
.promo-slider__dot{
  width:32px;height:2px;background:rgba(255,255,255,.3);
  border:none;cursor:pointer;padding:0;
  transition:background .2s var(--ease);
}
.promo-slider__dot.active,.promo-slider__dot:hover{background:var(--yellow)}

.promo-slider__arrows{
  position:absolute;top:50%;left:0;right:0;transform:translateY(-50%);z-index:3;
  display:flex;justify-content:space-between;
  padding:0 var(--gutter);
  pointer-events:none;
}
.promo-slider__arrow{
  width:48px;height:48px;
  border:1px solid rgba(255,255,255,.3);
  background:rgba(10,10,10,.3);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;pointer-events:auto;
  transition:all .25s var(--ease);
}
.promo-slider__arrow:hover{background:var(--yellow);border-color:var(--yellow)}
.promo-slider__arrow svg{width:18px;height:18px;stroke:var(--white);fill:none;stroke-width:2}
.promo-slider__arrow:hover svg{stroke:var(--ink)}


/* =================================================================
   14. PRODUCT CARD (для архива/каталога)
   ================================================================= */
.products__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

.product-card{
  position:relative;
  background:var(--white);
  border:1px solid var(--line);
  display:flex;flex-direction:column;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);
  overflow:hidden;
}
.product-card:hover{
  transform:translateY(-4px);
  border-color:transparent;
  box-shadow:var(--shadow-lg);
}
/* Жёлтая полоса-акцент снизу при ховере */
.product-card::after{
  content:'';position:absolute;left:0;right:0;bottom:0;height:3px;
  background:var(--yellow);
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.product-card:hover::after{transform:scaleX(1)}

.product-card__image{
  position:relative;padding-bottom:66.6%;
  background:var(--paper);overflow:hidden;display:block;
}
.product-card__image-inner{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  padding:20px;
}
.product-card__image-inner img,
.product-card__image-inner .wp-post-image,
.product-card__image img{
  max-width:100%;max-height:100%;width:auto;height:auto;
  object-fit:contain;
  transition:transform .5s var(--ease-out);
}
.product-card:hover .product-card__image img,
.product-card:hover .product-card__image-inner img{transform:scale(1.06)}

/* ===== Галерея (scrub / swipe) ===== */
.product-card__slides{
  position:absolute;inset:0;
  overflow:hidden;
}
.product-card__slide{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  opacity:0;
  transition:opacity .25s var(--ease);
  pointer-events:none;
}
.product-card__slide.is-active{opacity:1;pointer-events:auto}
.product-card__slide img,
.product-card__slide .product-card__slide-img{
  max-width:100%;max-height:100%;width:auto;height:auto;
  object-fit:contain;
  transition:transform .5s var(--ease-out);
}
.product-card:hover .product-card__slide.is-active img{transform:scale(1.04)}

/* Индикаторы-полоски снизу картинки */
.product-card__dots{
  position:absolute;left:12px;right:12px;bottom:10px;z-index:3;
  display:flex;gap:4px;
  opacity:0;
  transition:opacity .25s var(--ease);
  pointer-events:none;
}
.product-card:hover .product-card__dots,
.product-card.is-scrubbing .product-card__dots{opacity:1}
.product-card__dot{
  flex:1;height:2px;
  background:rgba(10,10,10,.2);
  transition:background .2s var(--ease);
}
.product-card__dot.is-active{background:var(--yellow)}

/* Скрываем точки если всего один слайд (на всякий, если data-gallery забыли) */
.product-card__dots:has(> :only-child){display:none}

/* Подсказка "зонирования" на hover — маленькие вертикальные полоски сверху картинки,
   визуально показывающие сколько фоток есть */
.product-card__slides::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:0;
  background:transparent;
  pointer-events:none;
}

/* Badges на карточке */
.product-card__badges{
  position:absolute;top:12px;left:12px;z-index:2;
  display:flex;flex-direction:column;gap:6px;align-items:flex-start;
}
.product-card__badge{
  font-family:var(--font-mono);font-weight:700;font-size:10px;letter-spacing:.1em;
  padding:5px 10px;text-transform:uppercase;
  background:var(--yellow);color:var(--ink);
}
.product-card__badge--sale{background:var(--red);color:var(--white)}
.product-card__badge--new{background:var(--green);color:var(--white)}
.product-card__badge--hit{background:var(--yellow);color:var(--ink)}

.product-card__content{
  padding:18px 20px 20px;
  display:flex;flex-direction:column;gap:10px;
  flex:1;border-top:1px solid var(--line);
}

.product-card__rating{
  display:flex;align-items:center;gap:4px;
  font-family:var(--font-mono);font-size:12px;font-weight:700;color:var(--ink);
}
.product-card__rating .star{color:#ddd;font-size:14px}
.product-card__rating .star.filled{color:var(--yellow);filter:drop-shadow(0 0 2px var(--yellow-hot))}
.product-card__reviews{margin-left:6px;color:var(--muted);font-weight:500}

.product-card__stock{
  font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.05em;
  text-transform:uppercase;
}
.product-card__stock.in-stock{color:var(--green)}
.product-card__stock.in-stock::before{content:'●';margin-right:6px;filter:drop-shadow(0 0 4px var(--green))}
.product-card__stock.out-of-stock{color:var(--muted)}
.product-card__stock.out-of-stock::before{content:'○';margin-right:6px}

.product-card__title{
  font-family:var(--font-display);font-weight:500;font-size:18px;line-height:1.1;letter-spacing:-.005em;
  text-transform:uppercase;color:var(--ink);
  min-height:auto;
}
.product-card__title a{color:inherit}
.product-card__title a:hover{color:var(--yellow-deep)}

.product-card__specs{
  display:grid;grid-template-columns:1fr 1fr;gap:4px 12px;
  font-family:var(--font-mono);font-size:11px;color:var(--muted);
  padding-top:8px;margin-top:2px;
  border-top:1px dashed var(--line);
}
.product-card__spec{display:flex;align-items:baseline;gap:4px;padding:2px 0}
.product-card__spec-label{color:var(--muted);white-space:nowrap}
.product-card__spec-dots{flex:1;border-bottom:1px dotted var(--line);margin:0 4px;min-width:6px}
.product-card__spec-value{color:var(--ink);font-weight:700;white-space:nowrap}

.product-card__price{
  display:flex;align-items:baseline;gap:10px;
  margin-top:auto;padding-top:6px;
}
.product-card__price-current{
  font-family:var(--font-mono);font-weight:700;font-size:20px;color:var(--ink);letter-spacing:-.02em;
}
.product-card__price-old{
  font-family:var(--font-mono);font-size:13px;color:var(--muted);text-decoration:line-through;
}

.product-card__btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;padding:12px 16px;
  font-family:var(--font-display);font-weight:500;font-size:13px;letter-spacing:.15em;
  text-transform:uppercase;
  background:var(--ink);color:var(--yellow);
  border:none;cursor:pointer;
  transition:background .25s var(--ease),color .25s var(--ease);
}
.product-card__btn:hover{background:var(--yellow);color:var(--ink)}
.product-card__btn--disabled{background:var(--paper);color:var(--muted);cursor:not-allowed;pointer-events:none}
.product-card__btn--disabled:hover{background:var(--paper);color:var(--muted)}

/* Скрываем категорию по умолчанию — оставляем для совместимости */
.product-card__category{display:none}


/* =================================================================
   15. SHOP LAYOUT + FILTERS
   ================================================================= */
.shop-layout{
  display:grid;grid-template-columns:280px 1fr;gap:40px;
  margin-bottom:60px;
}
.shop-sidebar{position:sticky;top:calc(var(--header-h) + 20px);height:fit-content;align-self:start}
.shop-content{min-width:0}

/* Sidebar — заголовок */
.sidebar__title{
  font-family:var(--font-display);font-size:18px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;
  margin-bottom:16px;padding-bottom:14px;
  border-bottom:2px solid var(--ink);
}

/* Filter Box */
.filter-box{
  background:var(--white);
  border:1px solid var(--line);border-top:none;
  overflow:hidden;
}
.filter-box:first-of-type{border-top:1px solid var(--line)}

.filter-box__header{
  width:100%;
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 18px;
  font-family:var(--font-display);font-weight:500;font-size:13px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink);background:var(--white);border:none;cursor:pointer;
  transition:background .2s var(--ease);
}
.filter-box__header:hover{background:var(--paper)}
.filter-box__header svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .25s var(--ease)}
.filter-box.open .filter-box__header svg{transform:rotate(180deg)}

.filter-box__content{
  display:none;
  padding:4px 18px 18px;background:var(--paper);
  border-top:1px solid var(--line);
}
.filter-box.open .filter-box__content{display:block}

/* Filter search input */
.filter-search{margin-bottom:10px}
.filter-search__input{
  width:100%;padding:9px 12px;
  background:var(--white);
  border:1px solid var(--line);
  font-family:var(--font-body);font-size:13px;
  color:var(--ink);
  transition:border-color .2s var(--ease);
}
.filter-search__input:focus{outline:none;border-color:var(--yellow)}
.filter-search__input::placeholder{color:var(--muted)}

/* Filter list */
.filter-list{max-height:280px;overflow-y:auto}
.filter-list::-webkit-scrollbar{width:4px}
.filter-list::-webkit-scrollbar-track{background:var(--line)}
.filter-list::-webkit-scrollbar-thumb{background:var(--muted)}
.filter-list::-webkit-scrollbar-thumb:hover{background:var(--yellow)}

/* Checkbox / radio */
.filter-checkbox{
  display:flex;align-items:center;gap:12px;
  padding:9px 0;cursor:pointer;
  font-size:13px;color:var(--text-dim);
  border-bottom:1px solid var(--line);
  transition:padding-left .2s var(--ease),color .2s var(--ease);
}
.filter-checkbox:last-child{border-bottom:none}
.filter-checkbox:hover{color:var(--ink);padding-left:4px}
.filter-checkbox.hidden{display:none}
.filter-checkbox input{display:none}

.filter-checkbox__mark{
  width:20px;height:20px;flex-shrink:0;
  background:var(--white);
  border:1px solid #C8C8C8;
  display:flex;align-items:center;justify-content:center;
  transition:all .15s var(--ease);
}
.filter-checkbox__mark::after{
  content:'';width:8px;height:8px;background:var(--ink);
  opacity:0;transform:scale(0);
  transition:all .15s var(--ease);
}
.filter-checkbox input:checked + .filter-checkbox__mark{
  background:var(--yellow);border-color:var(--yellow);
  box-shadow:0 0 0 2px rgba(254,193,16,.25);
}
.filter-checkbox input:checked + .filter-checkbox__mark::after{opacity:1;transform:scale(1)}

.filter-checkbox__label{flex:1}

/* Кнопки фильтров */
.filter-buttons{display:flex;gap:8px;margin-top:20px}
.filter-buttons .btn{flex:1;padding:12px 14px;font-size:12px}


/* =================================================================
   16. BREADCRUMBS + PAGINATION
   ================================================================= */
.breadcrumbs{
  background:var(--paper);
  padding:14px 0;
  border-bottom:1px solid var(--line);
  font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);
}
.breadcrumbs a{color:var(--muted);transition:color .2s var(--ease)}
.breadcrumbs a:hover{color:var(--yellow-deep)}
.breadcrumbs .container > div,
.breadcrumbs > .container > div{
  display:flex !important;flex-wrap:wrap;gap:10px;align-items:center;
}

/* Pagination */
.pagination{display:flex;justify-content:center;margin:40px 0 20px}
.pagination ul,.page-numbers{
  display:flex;gap:4px;list-style:none;padding:0;margin:0;
}
.pagination a,.pagination span,
.page-numbers a,.page-numbers span{
  display:flex;align-items:center;justify-content:center;
  min-width:40px;height:40px;padding:0 10px;
  font-family:var(--font-mono);font-size:13px;font-weight:500;
  color:var(--ink);background:var(--white);
  border:1px solid var(--line);
  transition:all .2s var(--ease);
}
.pagination a:hover,.page-numbers a:hover{
  background:var(--ink);color:var(--yellow);border-color:var(--ink);
}
.pagination .current,.page-numbers.current{
  background:var(--yellow);color:var(--ink);border-color:var(--yellow);font-weight:700;
}


/* =================================================================
   17. NEWS CARD / PROMOTIONS
   ================================================================= */
.news__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.news-card{
  background:var(--white);
  border:1px solid var(--line);
  overflow:hidden;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);
}
.news-card:hover{
  transform:translateY(-4px);
  border-color:transparent;box-shadow:var(--shadow-lg);
}
.news-card__image{
  position:relative;display:block;
  padding-bottom:60%;
  background:var(--paper);overflow:hidden;
}
.news-card__image img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;
  transition:transform .5s var(--ease-out);
}
.news-card:hover .news-card__image img{transform:scale(1.06)}
.news-card__placeholder{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  color:var(--line);
}
.news-card__placeholder svg{width:60px;height:60px}
.news-card__tag{
  position:absolute;top:16px;left:16px;
  font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;
  padding:6px 10px;
  background:var(--yellow);color:var(--ink);
}
.news-card__content{padding:24px}
.news-card__date{
  font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);margin-bottom:10px;
}
.news-card__title{
  font-family:var(--font-display);font-size:20px;font-weight:500;line-height:1.1;
  text-transform:uppercase;margin-bottom:12px;
}
.news-card__title a{color:var(--ink)}
.news-card__title a:hover{color:var(--yellow-deep)}
.news-card__excerpt{
  font-size:14px;color:var(--text-dim);line-height:1.6;margin-bottom:16px;
}
.news-card__link{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-size:12px;font-weight:500;letter-spacing:.15em;text-transform:uppercase;
  color:var(--yellow-deep);
  transition:gap .25s var(--ease);
}
.news-card__link:hover{gap:14px}
.news-card__link svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}


/* =================================================================
   18. CTA FORM (callback)
   ================================================================= */
.cta-section{
  background:var(--ink);color:var(--white);position:relative;overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 20% 50%,rgba(254,193,16,.12) 0%,transparent 50%);
}
.cta-section__inner{
  max-width:720px;margin:0 auto;text-align:center;
  position:relative;z-index:2;
}
.cta-section__title{
  font-family:var(--font-display);font-size:clamp(36px,5vw,56px);font-weight:500;line-height:1.02;
  text-transform:uppercase;margin-bottom:16px;
}
.cta-section__title span{color:var(--yellow)}
.cta-section__text{
  font-size:17px;color:rgba(255,255,255,.7);margin-bottom:36px;
}
.cta-form{
  display:flex;gap:12px;justify-content:center;flex-wrap:wrap;
}
.cta-form__input{
  flex:1;min-width:220px;max-width:280px;
  padding:14px 20px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.2);
  color:var(--white);font-size:15px;
  transition:border-color .2s var(--ease),background .2s var(--ease);
}
.cta-form__input::placeholder{color:rgba(255,255,255,.5)}
.cta-form__input:focus{outline:none;border-color:var(--yellow);background:rgba(255,255,255,.12)}


/* =================================================================
   19. FOOTER
   ================================================================= */
.footer{
  background:var(--ink);color:var(--white);
  padding:72px 0 28px;
}
.footer__grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1.2fr;
  gap:48px;padding-bottom:56px;
  border-bottom:1px solid var(--line-dark);
}
.footer__column{min-width:0}
.footer__column--contacts{text-align:left}
.footer__column-title{
  font-family:var(--font-display);font-size:13px;font-weight:500;letter-spacing:.15em;text-transform:uppercase;
  color:var(--yellow);margin-bottom:20px;
}
.footer__links{list-style:none;padding:0;margin:0}
.footer__links li{margin-bottom:10px}
.footer__links a{
  color:rgba(255,255,255,.55);font-size:13px;
  transition:color .2s var(--ease);
}
.footer__links a:hover{color:var(--yellow)}

.footer__phone{
  display:block;
  font-family:var(--font-display);font-size:26px;font-weight:500;letter-spacing:.02em;
  color:var(--white);margin-bottom:4px;white-space:nowrap;
}
.footer__phone:hover{color:var(--yellow)}
.footer__email{
  display:block;color:var(--yellow);font-size:13px;margin-bottom:14px;
}
.footer__email:hover{text-decoration:underline}
.footer__address,.footer__hours{
  font-size:13px;color:rgba(255,255,255,.55);margin-bottom:6px;line-height:1.6;
}

.footer__social{display:flex;gap:8px;margin-top:16px}
.footer__social-link{
  width:36px;height:36px;
  background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s var(--ease);
}
.footer__social-link:hover{background:var(--yellow)}
.footer__social-link svg{width:16px;height:16px;fill:var(--white)}
.footer__social-link:hover svg{fill:var(--ink)}

.footer__bottom{
  padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
  font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.45);
}
.footer__copy{color:inherit}
.footer__legal{display:flex;gap:24px}
.footer__legal a{color:inherit;transition:color .2s var(--ease)}
.footer__legal a:hover{color:var(--yellow)}
.footer__payments{display:flex;gap:8px}
.footer__payment{
  padding:6px 10px;
  background:rgba(255,255,255,.06);
  font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.5);
}


/* =================================================================
   20. SCROLL REVEAL + UTILITY
   ================================================================= */
.reveal{
  opacity:0;transform:translateY(40px);
  transition:opacity .9s var(--ease-out),transform .9s var(--ease-out);
}
.reveal.is-in{opacity:1;transform:none}


/* =================================================================
   21. WOOCOMMERCE TWEAKS
   ================================================================= */
/* Скрываем нативные элементы Woo, которые не вписываются в дизайн */
.woocommerce-result-count,
.woocommerce-ordering{display:none}

/* "No products found" на архиве */
.no-products{
  text-align:center;padding:80px 24px;
  background:var(--paper);
  margin-bottom:40px;
}
.no-products__icon{margin-bottom:24px;display:flex;justify-content:center;color:var(--muted)}
.no-products__icon svg{width:80px;height:80px;stroke:currentColor;fill:none;stroke-width:1.5;opacity:.5}
.no-products__title{
  font-family:var(--font-display);font-size:28px;font-weight:500;line-height:1.02;
  text-transform:uppercase;margin-bottom:14px;
}
.no-products__text{
  font-size:15px;color:var(--text-dim);max-width:500px;margin:0 auto 16px;line-height:1.6;
}
.no-products__hint{
  display:inline-block;margin-bottom:24px;
  font-family:var(--font-mono);font-size:12px;letter-spacing:.05em;
  background:rgba(254,193,16,.15);color:var(--yellow-deep);
  padding:10px 20px;
}
.no-products__actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.no-products__popular{margin-top:56px}
.no-products__popular-title{
  font-family:var(--font-display);font-size:24px;font-weight:500;text-align:center;text-transform:uppercase;
  margin-bottom:28px;
}

/* Catalog subcategories grid (на архив-странице) */
.catalog-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  margin-bottom:40px;
}
.catalog-card{
  display:flex;align-items:center;gap:16px;
  background:var(--white);
  border:1px solid var(--line);
  overflow:hidden;
  min-height:80px;
  transition:transform .25s var(--ease),border-color .25s var(--ease),box-shadow .25s var(--ease);
}
.catalog-card:hover{
  transform:translateY(-2px);
  border-color:var(--yellow);
  box-shadow:var(--shadow-md);
}
.catalog-card__image{
  width:100px;height:80px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:var(--paper);
}
.catalog-card__image img{
  max-width:80%;max-height:80%;width:auto;height:auto;object-fit:contain;
  transition:transform .3s var(--ease);
}
.catalog-card:hover .catalog-card__image img{transform:scale(1.08)}
.catalog-card__placeholder{color:var(--line)}
.catalog-card__placeholder svg{width:32px;height:32px}
.catalog-card__content{flex:1;padding:10px 16px 10px 0}
.catalog-card__title{
  font-family:var(--font-display);font-size:14px;font-weight:500;letter-spacing:.02em;
  text-transform:uppercase;color:var(--ink);margin-bottom:2px;
}
.catalog-card:hover .catalog-card__title{color:var(--yellow-deep)}
.catalog-card__count{
  font-family:var(--font-mono);font-size:11px;letter-spacing:.05em;
  color:var(--muted);text-transform:uppercase;
}

/* Woo standard classes */
.woocommerce .onsale{display:none}
.woocommerce .products .product{padding:0}
.woocommerce a.added_to_cart{display:none}


/* =================================================================
   22. MEDIA QUERIES
   ================================================================= */

/* Большие ноутбуки: ужимаем контейнер, меньший padding в nav */
@media(max-width:1400px){
  :root{--container:1280px;--gutter:28px}
  .products__grid{grid-template-columns:repeat(4,1fr)}
}

/* Средний ноутбук: прячем телефон чтобы меню влезло */
@media(max-width:1200px){
  .header__phone{display:none}
  .nav-main__link{padding:0 12px;font-size:12px}
  .sec-title,.section-title{font-size:clamp(36px,5vw,56px)}
  .tile--w4 .tile__title{font-size:44px}
  .tile--w3 .tile__title{font-size:34px}
  .story__title{font-size:42px}
  .cat-card{height:420px}
  .products__grid{grid-template-columns:repeat(3,1fr)}
}

/* Планшет: скрываем desktop-nav, показываем бургер */
@media(max-width:900px){
  .nav-main{display:none}
  .burger{display:flex}

  .sec{padding:80px 0}
  .section{padding:60px 0}

  /* Bento на 6 колонках, но w4 в полную */
  .bento{grid-template-columns:repeat(6,1fr);grid-auto-rows:360px}
  .tile--w4{grid-column:span 6}
  .tile--w3{grid-column:span 3}
  .tile--w2{grid-column:span 3}
  .tile--w6{grid-column:span 6}

  .cats-strip{grid-template-columns:repeat(2,1fr)}
  .cat-card{height:360px}

  .advs,.advantages__grid{grid-template-columns:repeat(3,1fr)}
  .adv,.advantage-card{border-bottom:1px solid var(--line)}
  .adv:nth-child(3n),.advantage-card:nth-child(3n){border-right:none}

  .story{grid-template-columns:1fr}
  .story__visual{min-height:360px}
  .story__content{padding:40px 32px}

  .news__grid{grid-template-columns:repeat(2,1fr)}
  .products__grid{grid-template-columns:repeat(2,1fr)}

  .shop-layout{grid-template-columns:1fr;gap:24px}
  .shop-sidebar{position:static;order:-1}

  .catalog-grid{grid-template-columns:repeat(2,1fr)}

  .footer__grid{grid-template-columns:repeat(2,1fr);gap:32px}

  .hero__title{font-size:clamp(48px,9vw,84px)}
}

/* Мобильный телефон */
@media(max-width:640px){
  :root{--gutter:20px}

  .mmenu__panel{max-width:100%}

  .hero{height:auto;min-height:560px;padding:100px 0 80px}
  .hero__cats{
    overflow-x:auto;justify-content:flex-start;padding:0 20px;top:16px;
    scrollbar-width:none;
  }
  .hero__cats::-webkit-scrollbar{display:none}
  .hero__cat{white-space:nowrap;padding:8px 14px;font-size:11px}
  .hero__title{font-size:44px;line-height:.95}
  .hero__tagline{font-size:15px}
  .hero__bottom{padding:0 20px;bottom:20px}
  .hero__arrow{width:44px;height:44px}
  .hero__arrow svg{width:16px;height:16px}

  .bento{grid-template-columns:1fr;grid-auto-rows:300px;gap:8px}
  .tile--w2,.tile--w3,.tile--w4,.tile--w6{grid-column:span 1}
  .tile{padding:20px}
  .tile__title,.tile--w4 .tile__title,.tile--w3 .tile__title,.tile--w2 .tile__title{font-size:28px}

  .cats-strip{grid-template-columns:1fr}

  .advs,.advantages__grid{grid-template-columns:repeat(2,1fr)}
  .adv:nth-child(even),.advantage-card:nth-child(even){border-right:none}
  .adv:nth-child(3n),.advantage-card:nth-child(3n){border-right:1px solid var(--line)}
  .adv:nth-last-child(-n+2),.advantage-card:nth-last-child(-n+2){border-bottom:none}

  .news__grid{grid-template-columns:1fr}
  .products__grid{grid-template-columns:1fr;gap:16px}

  .catalog-grid{grid-template-columns:1fr}

  .sec-head{flex-direction:column;align-items:flex-start;gap:16px;margin-bottom:32px}
  .sec-title,.section-title{font-size:clamp(32px,8vw,42px)}
  .story__title{font-size:32px}
  .story__content{padding:32px 20px}

  .footer{padding:56px 0 24px}
  .footer__grid{grid-template-columns:1fr;gap:28px}
  .footer__bottom{flex-direction:column;text-align:center;gap:14px}
  .footer__legal{flex-direction:column;gap:8px}

  .cta-form{flex-direction:column}
  .cta-form__input{max-width:100%}

  .btn{padding:12px 22px;font-size:12px}
  .btn--lg{padding:16px 30px;font-size:13px}
}

/* Фикс для очень узких экранов */
@media(max-width:380px){
  .header__row{padding:0 12px}
  .header__left{gap:0}
  .header__icon{width:36px;height:36px}
  .logo__text{font-size:16px}
  .logo__mark{width:28px;height:28px;font-size:14px}
  .hero__title{font-size:36px}
}

/* =================================================================
   23. SINGLE PRODUCT PAGE (переписано под новый дизайн)
   ================================================================= */
.product-page{
  padding:40px 0 80px;
  background:var(--white);
}

.product-single{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  margin-bottom:80px;
}

/* ===== Галерея ===== */
.product-single__gallery{
  position:relative;
}
/* WooCommerce photoswipe выводит свою разметку — применяем базовые стили */
.product-single__gallery .woocommerce-product-gallery{
  width:100%;
  position:relative;
}
.product-single__gallery .woocommerce-product-gallery__image{
  background:var(--paper);
  border:1px solid var(--line);
  overflow:hidden;
  cursor:zoom-in;
}
.product-single__gallery .woocommerce-product-gallery__image img{
  width:100%;height:auto;display:block;
  transition:transform .5s var(--ease-out);
}
.product-single__gallery .woocommerce-product-gallery__image:hover img{
  transform:scale(1.02);
}
/* Миниатюры под главным фото */
.product-single__gallery .flex-control-thumbs{
  display:grid;grid-template-columns:repeat(5, 1fr);gap:8px;
  margin:8px 0 0;padding:0;list-style:none;
}
.product-single__gallery .flex-control-thumbs li{cursor:pointer}
.product-single__gallery .flex-control-thumbs img{
  width:100%;height:auto;display:block;
  border:2px solid transparent;
  opacity:.6;
  transition:opacity .25s var(--ease),border-color .25s var(--ease);
}
.product-single__gallery .flex-control-thumbs img:hover,
.product-single__gallery .flex-control-thumbs img.flex-active{
  opacity:1;
  border-color:var(--yellow);
}
/* Кнопка-лупа сверху справа от главного фото */
.product-single__gallery .woocommerce-product-gallery__trigger{
  position:absolute;top:12px;right:12px;z-index:5;
  width:44px;height:44px;
  background:rgba(255,255,255,.95);
  border:none;
  display:flex;align-items:center;justify-content:center;
  font-size:0;
  cursor:pointer;
  transition:background .2s var(--ease);
}
.product-single__gallery .woocommerce-product-gallery__trigger:hover{background:var(--yellow)}
.product-single__gallery .woocommerce-product-gallery__trigger::before{
  content:'';
  width:18px;height:18px;
  background:no-repeat center/contain url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230A0A0A' stroke-width='2'><circle cx='11' cy='11' r='8'/><line x1='21' y1='21' x2='16.65' y2='16.65'/><line x1='8' y1='11' x2='14' y2='11'/><line x1='11' y1='8' x2='11' y2='14'/></svg>");
}

/* ===== Инфо-блок справа ===== */
.product-single__info{
  display:flex;flex-direction:column;gap:20px;
}
.product-single__category{
  display:inline-block;
  font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted);
}
.product-single__category a{color:var(--yellow-deep);text-decoration:none}
.product-single__category a:hover{color:var(--yellow)}

.product-single__title{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(28px,4vw,48px);line-height:1.05;letter-spacing:-.01em;
  text-transform:uppercase;
  margin:0;color:var(--ink);
}

.product-single__meta{
  display:flex;flex-wrap:wrap;gap:18px;align-items:center;
  padding-bottom:20px;border-bottom:1px solid var(--line);
}
.product-single__sku{
  font-family:var(--font-mono);font-size:12px;color:var(--muted);
  letter-spacing:.05em;
}
.product-single__sku b{color:var(--ink);font-weight:500}
.product-single__stock{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:12px;font-weight:500;
  text-transform:uppercase;letter-spacing:.1em;
}
.product-single__stock-dot{
  width:8px;height:8px;border-radius:50%;display:inline-block;
}
.product-single__stock.in-stock{color:var(--green)}
.product-single__stock.in-stock .product-single__stock-dot{background:var(--green);box-shadow:0 0 8px rgba(30,220,107,.5)}
.product-single__stock.out-of-stock{color:var(--muted)}
.product-single__stock.out-of-stock .product-single__stock-dot{background:var(--muted)}

.product-single__price{
  display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;
}
.product-single__price-current{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(28px,3.5vw,42px);
  color:var(--ink);line-height:1;
}
.product-single__price-old{
  font-family:var(--font-mono);font-size:16px;
  color:var(--muted);text-decoration:line-through;
}
.product-single__price-badge{
  font-family:var(--font-mono);font-weight:700;font-size:12px;
  padding:6px 10px;
  background:var(--red);color:var(--white);
  letter-spacing:.05em;
}

.product-single__highlights{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(160px, 1fr));
  gap:1px;background:var(--line);
  border:1px solid var(--line);
}
/* Если характеристика всего одна — растягиваем её на всю ширину */
.product-single__highlights .product-single__highlight:only-child{
  grid-column:1 / -1;
}
.product-single__highlight{
  display:flex;flex-direction:column;gap:4px;
  padding:14px 16px;background:var(--paper);
}
.product-single__highlight-label{
  font-family:var(--font-mono);font-size:10px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.1em;
}
.product-single__highlight-value{
  font-family:var(--font-display);font-size:18px;font-weight:500;
  color:var(--ink);
}

/* Actions (qty + кнопка) */
.product-single__actions{margin-top:4px}
.product-single__cart{display:flex;gap:12px;align-items:stretch;flex-wrap:wrap}
.product-single__qty{
  display:flex;align-items:stretch;
  border:1px solid var(--line);
  background:var(--white);
}
.product-single__qty-btn{
  width:44px;
  background:transparent;border:none;
  font-size:18px;font-weight:500;
  cursor:pointer;color:var(--ink);
  transition:background .2s var(--ease);
}
.product-single__qty-btn:hover{background:var(--paper)}
.product-single__qty-input{
  width:52px;text-align:center;
  border:none;border-left:1px solid var(--line);border-right:1px solid var(--line);
  font-family:var(--font-mono);font-size:15px;font-weight:500;
  background:transparent;color:var(--ink);
  -moz-appearance:textfield;
}
.product-single__qty-input::-webkit-outer-spin-button,
.product-single__qty-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.product-single__btn{
  flex:1;min-width:200px;
  padding:14px 28px;
  font-size:13px;
}

/* Features — 3 преимущества иконками */
.product-single__features{
  display:grid;grid-template-columns:repeat(3, 1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
  margin-top:8px;
}
.product-single__feature{
  display:flex;align-items:center;gap:14px;
  padding:16px;background:var(--white);
}
.product-single__feature svg{
  flex-shrink:0;width:28px;height:28px;
  color:var(--yellow-deep);
}
.product-single__feature-title{
  font-family:var(--font-display);font-size:14px;font-weight:500;
  color:var(--ink);text-transform:uppercase;letter-spacing:.02em;
  margin-bottom:2px;
}
.product-single__feature-text{
  font-size:12px;color:var(--muted);line-height:1.4;
}

.product-single__help{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding:16px 18px;background:var(--paper);
  font-size:14px;color:var(--muted);
}
.product-single__phone{
  font-family:var(--font-display);font-weight:600;font-size:17px;
  color:var(--ink);text-decoration:none;letter-spacing:.01em;
}
.product-single__phone:hover{color:var(--yellow-deep)}

/* ===== ТАБЫ ===== */
.product-tabs{
  margin:40px 0 80px;
  border-top:1px solid var(--line);
}
.product-tabs__nav{
  display:flex;gap:0;
  border-bottom:1px solid var(--line);
  overflow-x:auto;
  scrollbar-width:none;
}
.product-tabs__nav::-webkit-scrollbar{display:none}
.product-tabs__btn{
  font-family:var(--font-display);font-size:14px;font-weight:500;
  padding:20px 24px;
  background:transparent;border:none;border-bottom:2px solid transparent;
  color:var(--muted);cursor:pointer;
  text-transform:uppercase;letter-spacing:.1em;
  white-space:nowrap;
  transition:color .25s var(--ease),border-color .25s var(--ease);
}
.product-tabs__btn:hover{color:var(--ink)}
.product-tabs__btn.is-active{
  color:var(--ink);
  border-bottom-color:var(--yellow);
}
.product-tabs__content{padding:32px 0}
.product-tabs__panel{display:none;line-height:1.7;font-size:16px;color:var(--ink)}
.product-tabs__panel.is-active{display:block}
.product-tabs__text p{margin:0 0 14px}
.product-tabs__text h2,
.product-tabs__text h3{margin:24px 0 12px;font-family:var(--font-display)}

.product-tabs__specs{
  width:100%;border-collapse:collapse;
  font-size:15px;
}
.product-tabs__specs tr{border-bottom:1px solid var(--line)}
.product-tabs__specs tr:first-child{border-top:1px solid var(--line)}
.product-tabs__specs th,
.product-tabs__specs td{
  padding:14px 20px;vertical-align:top;text-align:left;
}
.product-tabs__specs th{
  font-weight:500;color:var(--muted);
  font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;
  width:40%;
}
.product-tabs__specs td{color:var(--ink);font-weight:500}

/* ===== ПОХОЖИЕ ТОВАРЫ ===== */
.related-products{
  margin-top:80px;padding-top:60px;
  border-top:1px solid var(--line);
}
.related-products .sec-head{margin-bottom:32px}
.related-products .products__grid{
  display:grid;grid-template-columns:repeat(4, 1fr);gap:24px;
}

/* ===== Адаптив для страницы товара ===== */
@media (max-width: 900px){
  .product-page{padding:20px 0 40px}
  .product-single{
    grid-template-columns:1fr;
    gap:32px;
    margin-bottom:40px;
  }
  .product-single__highlights{grid-template-columns:repeat(2, 1fr)}
  .product-single__features{grid-template-columns:1fr}
  .related-products .products__grid{grid-template-columns:repeat(2, 1fr);gap:16px}
  .product-tabs__btn{padding:14px 18px;font-size:12px}
  .product-tabs__content{padding:20px 0}
}
@media (max-width: 500px){
  .product-single__highlights{grid-template-columns:1fr}
  .product-single__title{font-size:26px}
  .product-single__price-current{font-size:28px}
  /* qty + кнопка — в одну строку, qty компактный, кнопка растянута */
  .product-single__cart{
    flex-direction:row;
    gap:10px;
    align-items:stretch;
  }
  .product-single__qty{flex:0 0 auto}
  .product-single__qty-btn{width:40px}
  .product-single__qty-input{width:44px;font-size:14px}
  .product-single__btn{
    flex:1 1 auto;
    min-width:0;
    padding:14px 16px;
    font-size:12px;
  }
}

/* =================================================================
   24. КНОПКА КОРЗИНЫ + МОДАЛКА ЗАЯВКИ
   ================================================================= */

/* Подсказка под кнопкой "Связаться с менеджером" в корзине */
.cart-contact-hint{
  font-size:13px;color:var(--muted);line-height:1.5;
  margin:14px 0 0;text-align:center;
}

/* ===== Модалка ===== */
.order-modal{
  position:fixed;inset:0;z-index:9999;
  display:none;
  align-items:center;justify-content:center;
  padding:20px;
}
.order-modal.is-open{display:flex}
.order-modal__backdrop{
  position:absolute;inset:0;
  background:rgba(10,10,10,.7);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  animation:fadeIn .25s var(--ease);
}
.order-modal__panel{
  position:relative;z-index:1;
  width:100%;max-width:480px;
  background:var(--white);
  padding:40px 36px 32px;
  box-shadow:0 20px 80px rgba(0,0,0,.25);
  animation:modalIn .35s var(--ease-out);
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes modalIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

.order-modal__close{
  position:absolute;top:14px;right:14px;
  width:36px;height:36px;
  background:transparent;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);
  transition:color .2s var(--ease),background .2s var(--ease);
}
.order-modal__close:hover{color:var(--ink);background:var(--paper)}
.order-modal__close svg{width:18px;height:18px}

.order-modal__head{margin-bottom:24px}
.order-modal__title{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(24px,3vw,32px);line-height:1.1;
  text-transform:uppercase;letter-spacing:-.005em;
  margin:8px 0 10px;color:var(--ink);
}
.order-modal__title em{color:var(--yellow);font-style:normal;font-weight:600}
.order-modal__text{
  font-size:14px;line-height:1.5;color:var(--muted);margin:0;
}

.order-modal__form{display:flex;flex-direction:column;gap:14px}
.order-modal__field{display:flex;flex-direction:column;gap:6px}
.order-modal__field label{
  font-family:var(--font-mono);font-size:11px;
  text-transform:uppercase;letter-spacing:.1em;color:var(--muted);
}
.order-modal__field input{
  padding:14px 16px;
  background:var(--paper);
  border:1px solid var(--line);
  font-family:var(--font-body);font-size:15px;
  color:var(--ink);
  transition:border-color .2s var(--ease),background .2s var(--ease);
}
.order-modal__field input:focus{
  outline:none;
  border-color:var(--yellow);
  background:var(--white);
}

.order-modal__message{
  margin-top:4px;min-height:20px;
  font-size:14px;text-align:center;
}
.order-modal__message.is-success{color:var(--green)}
.order-modal__message.is-error{color:var(--red)}

.order-modal__policy{
  font-size:11px;color:var(--muted);line-height:1.5;
  text-align:center;margin:8px 0 0;
}
.order-modal__policy a{color:var(--muted);text-decoration:underline}
.order-modal__policy a:hover{color:var(--ink)}

@media (max-width: 500px){
  .order-modal__panel{padding:32px 24px 24px}
  .order-modal__title{font-size:22px}
}

/* Блокируем скролл body когда модалка открыта */
body.is-modal-open{overflow:hidden}

/* Прячем стандартную кнопку чекаута в корзине — у нас своя "Связаться с менеджером" */
.wc-proceed-to-checkout .checkout-button,
a.checkout-button,
a.button.checkout-button{
  display:none !important;
}

/* =================================================================
   25. SHOP TOOLBAR — количество + сортировка над списком товаров
   ================================================================= */
.shop-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  gap:20px;flex-wrap:wrap;
  padding:16px 20px;margin-bottom:24px;
  background:var(--paper);
  border:1px solid var(--line);
}
.shop-toolbar__count{
  font-family:var(--font-mono);font-size:13px;color:var(--muted);
  letter-spacing:.02em;
}
.shop-toolbar__count b{color:var(--ink);font-weight:600}
.shop-toolbar__sort{
  display:flex;align-items:center;gap:10px;
}
.shop-toolbar__sort label{
  font-family:var(--font-mono);font-size:11px;
  text-transform:uppercase;letter-spacing:.1em;color:var(--muted);
}
.shop-toolbar__select{
  padding:8px 32px 8px 12px;
  background:var(--white) no-repeat right 10px center/10px url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236B6B6B' stroke-width='2'><polyline points='6 9 12 15 18 9'/></svg>");
  border:1px solid var(--line);
  font-family:var(--font-body);font-size:14px;color:var(--ink);
  cursor:pointer;
  -webkit-appearance:none;-moz-appearance:none;appearance:none;
  transition:border-color .2s var(--ease);
}
.shop-toolbar__select:hover,.shop-toolbar__select:focus{
  outline:none;
  border-color:var(--yellow);
}
@media (max-width: 600px){
  .shop-toolbar{padding:12px 16px;gap:12px}
  .shop-toolbar__sort{width:100%;justify-content:space-between}
  .shop-toolbar__select{flex:1;min-width:0}
}

/* =================================================================
   26. BRANDS STRIP — карусель логотипов на главной
   ================================================================= */
.brands-strip{
  padding:48px 0;
  background:var(--white);
  overflow:hidden;
}
.brands-strip .sec-head{margin-bottom:40px}

.brands-strip__scroller{
  overflow:hidden;
  mask-image:linear-gradient(to right, transparent, black 10%, black 90%, transparent);
  -webkit-mask-image:linear-gradient(to right, transparent, black 10%, black 90%, transparent);
}
.brands-strip__track{
  display:flex;
  gap:48px;
  align-items:center;
  animation:brandsScroll 40s linear infinite;
  width:max-content;
}
.brands-strip__track:hover{animation-play-state:paused}

@keyframes brandsScroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

.brand-logo{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  flex-shrink:0;
  width:140px;
  padding:20px;
  text-decoration:none;color:inherit;
  transition:transform .3s var(--ease-out);
}
.brand-logo:hover{transform:translateY(-4px)}
.brand-logo img{
  max-width:100%;max-height:60px;
  width:auto;height:auto;
  object-fit:contain;
  filter:grayscale(1);
  opacity:.6;
  transition:filter .3s var(--ease),opacity .3s var(--ease);
}
.brand-logo:hover img{filter:grayscale(0);opacity:1}
.brand-logo__name{
  font-family:var(--font-mono);font-size:10px;
  text-transform:uppercase;letter-spacing:.15em;
  color:var(--muted);
  opacity:0;transform:translateY(-4px);
  transition:opacity .3s,transform .3s;
}
.brand-logo:hover .brand-logo__name{opacity:1;transform:none}

@media (max-width: 700px){
  .brands-strip{padding:48px 0}
  .brand-logo{width:110px;padding:14px}
  .brand-logo img{max-height:44px}
  .brands-strip__track{gap:24px;animation-duration:30s}
}


/* =================================================================
   27. BRAND PAGE — страница отдельного бренда
   ================================================================= */
.brand-page{background:var(--white)}

/* ШАПКА БРЕНДА */
.brand-hero{
  position:relative;
  padding:80px 0;
  background:var(--ink);
  color:var(--white);
  overflow:hidden;
}
.brand-hero.has-banner{padding:120px 0 80px}
.brand-hero__bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:.25;
}
.brand-hero__overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(10,10,10,.7) 0%, var(--ink) 100%);
}
.brand-hero__inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns:280px 1fr;gap:48px;align-items:center;
}
.brand-hero__logo{
  background:rgba(255,255,255,.96);
  padding:32px;
  display:flex;align-items:center;justify-content:center;
  aspect-ratio:16/10;
}
.brand-hero__logo img{max-width:100%;max-height:120px;width:auto;height:auto}

.brand-hero__info{color:var(--white)}
.brand-hero__eyebrow{
  font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.2em;
  color:var(--brand-accent, var(--yellow));
  text-transform:uppercase;margin-bottom:12px;
}
.brand-hero__title{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(36px,5vw,64px);line-height:1;letter-spacing:-.01em;
  text-transform:uppercase;
  margin:0 0 20px;
}
.brand-hero__description{
  font-size:16px;line-height:1.6;color:rgba(255,255,255,.8);
  max-width:640px;margin-bottom:20px;
}
.brand-hero__description p:last-child{margin-bottom:0}
.brand-hero__meta{
  display:inline-block;
  font-family:var(--font-mono);font-size:12px;
  padding:8px 16px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.15);
  color:var(--brand-accent, var(--yellow));
  letter-spacing:.1em;text-transform:uppercase;
}

/* Товары бренда */
.brand-products{padding:80px 0}
.brand-products .sec-head{margin-bottom:40px}
.brand-products .products__grid{
  display:grid;grid-template-columns:repeat(4, 1fr);gap:24px;
}
.brand-products .pagination{margin-top:48px}

.no-products{
  text-align:center;padding:80px 0;
}
.no-products p{font-size:18px;color:var(--muted);margin-bottom:20px}

/* Адаптив страницы бренда */
@media (max-width: 900px){
  .brand-hero{padding:60px 0}
  .brand-hero.has-banner{padding:80px 0 60px}
  .brand-hero__inner{grid-template-columns:1fr;gap:24px;text-align:center}
  .brand-hero__logo{max-width:240px;margin:0 auto}
  .brand-hero__description{margin-left:auto;margin-right:auto}
  .brand-products{padding:48px 0}
  .brand-products .products__grid{grid-template-columns:repeat(2, 1fr);gap:16px}
}
@media (max-width: 500px){
  .brand-hero__title{font-size:32px}
  .brand-hero__logo{padding:20px;max-width:200px}
}

.stories + .sec,
.stories + section{
  padding-top:40px;
}

/* =================================================================
   28. СКОРО В ПРОДАЖЕ — плашки
   ================================================================= */

/* Бейдж на карточке товара */
.product-card__badge.badge--coming-soon{
  background:var(--yellow);
  color:var(--ink);
  font-weight:700;
  letter-spacing:.05em;
}

/* Статус на странице товара */
.product-single__stock.coming-soon{
  color:var(--yellow-deep, #B8860B);
}
.product-single__stock.coming-soon .product-single__stock-dot{
  background:var(--yellow);
  box-shadow:0 0 8px rgba(254,193,16,.5);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{opacity:1}
  50%{opacity:.5}
}

/* Плашка у категории в меню/фильтрах */
.coming-soon-label{
  display:inline-block;
  font-family:var(--font-mono);
  font-size:9px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:2px 6px;
  margin-left:6px;
  background:var(--yellow);
  color:var(--ink);
  vertical-align:middle;
  line-height:1.3;
}

/* Вариант для мега-меню — меньше и поярче */
.mega .coming-soon-label,
.nav-main__item .coming-soon-label{
  font-size:8px;padding:2px 5px;margin-left:5px;
}

/* Плашка в мобильном меню — чуть крупнее чем в мега-меню */
.mmenu__link .coming-soon-label{
  font-size:9px;
  padding:3px 7px;
  margin-left:8px;
}