/* Legacy pluso: hide any leftover UI */
.title-block__socials-wrap,
.title-block__socials,
.pluso,
.pluso-more { display: none !important; visibility: hidden !important; }

.pluso-more{visibility: hidden;}

/* Global safety guard: prevent horizontal document scroll in case of component overflow */
html, body { max-width: 100%; overflow-x: hidden; }

/* Hide gallery duplicates before Slick init */
.photo-slider:not(.slick-initialized) .photo-block-img{display:none}
.photo-slider:not(.slick-initialized) .photo-block-img:first-child{display:block}

/* Video gallery below main photos: single-row scroller with arrows */
.product-item__video-wrap{ margin-top:16px; position:relative; overflow:visible; /* arrow horizontal offset, tuned to 1024x600 look */ --vstrip-arrow-ox: 30%; /* content padding var to keep arrows aligned */ --vstrip-pad-x: 0px; padding-left: var(--vstrip-pad-x); padding-right: var(--vstrip-pad-x); }
.product-item__video-wrap .video-slider{ position:relative; }

/* Video gallery with horizontal scroll - show 3 videos at a time */
.product-item__video-wrap .video-slider{
  display:flex !important;
  gap:12px !important;
  overflow-x:auto !important;
  overflow-y:visible !important; /* allow titles above items */
  padding-top: 2px !important;  /* minimal space for outside titles */
  margin-top: 16px !important;
  width: 100% !important;
  scroll-behavior: smooth !important;
}
.product-item__video-wrap .video-slider::-webkit-scrollbar{ 
  width:0; 
  height:0; 
}
.product-item__video-wrap .video-slider{ 
  scrollbar-width:none; 
  -ms-overflow-style:none; 
}

/* Titles row above thumbnails */
.product-item__video-wrap .product-item__video-titles{
  display:none !important; /* показываем только активный заголовок */
}
.product-item__video-wrap .product-item__video-title-active{
  display:none !important; /* отдельная активная строка не нужна, заголовки у карточек */
}
/* Всегда показываем активный заголовок; строку всех заголовков при желании можно скрыть отдельным классом */
.product-item__video-wrap .product-item__video-title-item{
  flex: 0 0 calc((100% - 24px)/3); min-height:1em; font-size:16px; line-height:1.25; color:#3C3E44;
  font-family:'Magistral-Bold', 'Magistral', Arial, sans-serif; font-weight:700; padding:0 8px; box-sizing:border-box; /* боковые отступы, чтобы текст не доходил до скруглений */
}
@media (max-width:1024px){
  .product-item__video-wrap .product-item__video-title-item{ flex-basis:calc((100% - 12px)/2); }
}
@media (max-width:640px){
  .product-item__video-wrap .product-item__video-title-item{ flex-basis:100%; }
}

/* Video gallery items - responsive width with 16:9 aspect ratio */
.product-item__video-wrap .video-slider .video-item{
  flex: 0 0 calc((100% - 24px) / 3) !important; /* 3 videos with gaps */
  width: calc((100% - 24px) / 3) !important;
}
.product-item__video-wrap .video-slider .video-item .photo-block-img{
  height: 0 !important;
  padding-top: 56.25% !important; /* Custom compact ratio */
  position: relative !important;
  margin: 0 !important;
}
/* Важно: ширина превью внутри ячейки должна занимать всю ячейку */
.product-item__video-wrap .video-slider .video-item .photo-block-img{ width:100% !important; }
@media (max-width: 1024px){
  .product-item__video-wrap .video-slider .video-item{ 
    flex: 0 0 calc((100% - 12px) / 2) !important; /* 2 videos with gaps */
    width: calc((100% - 12px) / 2) !important;
  }
  .product-item__video-wrap .video-slider .video-item .photo-block-img{ 
    height: 0 !important;
    padding-top: 28% !important; /* Custom compact ratio */
  }
}
/* Force override for small screens with higher specificity */
@media (max-width: 1024px) and (max-height: 768px){
  .product-item__video-wrap .video-slider .video-item .photo-block-img{ 
    padding-top: 28% !important; /* Smaller ratio for low resolution screens */
    height: 0 !important;
  }
}
@media (max-width: 800px){
  .product-item__video-wrap .video-slider .video-item .photo-block-img{ 
    padding-top: 28% !important; /* Even smaller for very small screens */
    height: 0 !important;
  }
}
@media (max-width: 640px){
  .product-item__video-wrap .video-slider .video-item{ 
    flex: 0 0 100% !important; /* 1 video full width */
    width: 100% !important;
  }
  .product-item__video-wrap .video-slider .video-item .photo-block-img{ 
    height: 0 !important;
    padding-top: 56.25% !important; /* Very compact for mobile */
  }
}

/* Additional override with even higher specificity */
@media screen and (max-width: 1024px) and (max-height: 768px){
  .product-item__video-wrap .video-slider .video-item .photo-block-img{ 
    padding-top: 56.25% !important;
    height: 0 !important;
  }
}
@media screen and (max-width: 800px){
  .product-item__video-wrap .video-slider .video-item .photo-block-img{ 
    padding-top: 56.25% !important;
    height: 0 !important;
  }
}

/* Override Slick styles for video gallery */
.product-item__video-wrap .video-slider.slick-initialized{
  display:grid !important;
  grid-template-columns:repeat(auto-fit, minmax(200px, 1fr)) !important;
  gap:12px !important;
}
.product-item__video-wrap .video-slider.slick-initialized .slick-list,
.product-item__video-wrap .video-slider.slick-initialized .slick-track{
  display:contents !important;
}
.product-item__video-wrap .video-slider.slick-initialized .slick-slide{
  width:auto !important;
  float:none !important;
}

/* Native horizontal scroller styles (class added by JS) - only when more than 3 videos */
.product-item__video-wrap .video-slider.vstrip-ready{
  display:flex !important; gap:12px !important; overflow-x:auto !important; overflow-y:hidden !important; /* no smooth to avoid delay */
  align-items:flex-start !important; /* keep 16:9 padding boxes, do not stretch */
}
.product-item__video-wrap .video-slider.vstrip-ready::-webkit-scrollbar{ width:0; height:0; }
.product-item__video-wrap .video-slider.vstrip-ready{ scrollbar-width:none; -ms-overflow-style:none; }
/* Cards width for 3/2/1 per view */
.product-item__video-wrap .video-slider.vstrip-ready .photo-block-img{ flex:0 0 calc((100% - 24px)/3); }
.product-item__video-wrap .video-slider.vstrip-ready .photo-block-img{ align-self:flex-start; }
@media (max-width: 1024px){
  .product-item__video-wrap .video-slider.vstrip-ready .photo-block-img{ flex-basis:calc((100% - 12px)/2); }
}
@media (max-width: 640px){
  .product-item__video-wrap .video-slider.vstrip-ready .photo-block-img{ flex-basis:100%; }
}
.product-item__video-wrap .video-slider .photo-block-img{
  position:relative; width:calc((100% - 24px) / 3); height:0; padding-top:56.25% !important; min-height: 0 !important;
  background-size:cover; background-position:center; border-radius:8px; overflow:hidden;
  cursor:pointer;
}
/* Floating title just above each visible thumbnail */
/* Outside title above each visible thumbnail */
.product-item__video-wrap .video-slider .video-item .thumb-title-out{
  margin: 2px 0 6px; padding: 0 6px; 
  font-family:'Magistral-Bold','Magistral',Arial,sans-serif; font-size:15px; line-height:1.15; font-weight:700; color:#3C3E44;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; text-align:left;
  visibility:hidden;
}
@media (max-width: 1440px){
  .product-item__video-wrap .video-slider .video-item .thumb-title-out{ font-size:18px; }
}
@media (max-width: 1200px){
  .product-item__video-wrap .video-slider .video-item .thumb-title-out{ font-size:18px; }
}
@media (max-width: 1024px){
  .product-item__video-wrap .video-slider .video-item .thumb-title-out{ font-size:18px; margin:2px 0 4px; }
}
@media (max-width: 800px){
  .product-item__video-wrap .video-slider .video-item .thumb-title-out{ font-size:20px; }
}
@media (max-width: 640px){
  .product-item__video-wrap .video-slider .video-item .thumb-title-out{ font-size:20px; }
}
/* Title over video thumbnail */
.product-item__video-wrap .video-slider .photo-block-img .video-thumb-title{
  position:absolute; left:0; right:0; bottom:0; padding:6px 8px; font-size:13px; line-height:1.2;
  color:#fff; background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.55) 55%, rgba(0,0,0,0.75) 100%);
  text-shadow: 0 1px 2px rgba(0,0,0,0.5); z-index:2; pointer-events:none;
}
/* Responsive ratio overrides must be placed AFTER the base rule to win by order */
@media (max-width: 1024px) and (max-height: 768px){
  .product-item__video-wrap .video-slider .photo-block-img{ padding-top:28% !important; height:0 !important; }
}
@media (max-width: 800px){
  .product-item__video-wrap .video-slider .photo-block-img{ padding-top:28% !important; height:0 !important; }
}
@media (max-width: 640px){
  .product-item__video-wrap .video-slider .photo-block-img{ padding-top:56.25% !important; height:0 !important; width:100% !important; flex:0 0 100% !important; }
}
.product-item__video-wrap .video-slider .photo-block-img > img{
  position:absolute; left:0; top:0; width:100%; height:100%; object-fit:cover; display:block;
}
.product-item__video-wrap .product-item__video-icon{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  pointer-events:none;
}

/* Spacing between slides when Slick is active */
.product-item__video-wrap .video-slider.slick-initialized .slick-list{ margin:0 -6px; }
.product-item__video-wrap .video-slider.slick-initialized .slick-slide{ padding:0 6px; }

/* Slick arrow styling to match main photo gallery */
/* Slick arrow styling (if Slick is active) */
.product-item__video-wrap .slick-arrow{
  position:absolute; display:block; border:none; outline:none; width:50px; height:50px; z-index:10;
  top:45%; cursor:pointer; transition:.4s; border-radius:50%;
}
.product-item__video-wrap .slick-arrow:before{ display:none; }
.product-item__video-wrap .slick-prev{
  left:5px;
  background: url('../../assets/css/static/pic/arrow-left-white.png') center no-repeat #51b858;
}
.product-item__video-wrap .slick-next{
  right:5px;
  background: url('../../assets/css/static/pic/arrow-right-white.png') center no-repeat #51b858;
}
.product-item__video-wrap .slick-arrow.slick-disabled{ background-color: rgba(0,0,0,.5); }

/* Arrows for video gallery navigation - compact with shadow and overlap */
.product-item__video-wrap .gallery-arrow{
  position:absolute; display:block; border:none; outline:none; width:35px; height:35px; z-index:10;
  top: calc(50% + var(--vstrip-caption-h, 0px)/2); transform:translateY(-50%); cursor:pointer; transition:.4s; border-radius:50%;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.product-item__video-wrap .gallery-arrow:before{ display:none; }
.product-item__video-wrap .gallery-prev{
  left: var(--vstrip-pad-x); /* align with content edge */
  transform: translate(calc(-1 * var(--vstrip-arrow-ox)), -50%);
  background: url('../../assets/css/static/pic/arrow-left-white.png') center no-repeat #51b858;
}
.product-item__video-wrap .gallery-next{
  right: var(--vstrip-pad-x); /* align with content edge */
  transform: translate(var(--vstrip-arrow-ox), -50%);
  background: url('../../assets/css/static/pic/arrow-right-white.png') center no-repeat #51b858;
}
.product-item__video-wrap .gallery-arrow[disabled]{ 
  background-color: rgba(0,0,0,.5); 
  box-shadow: 0 1px 4px rgba(0,0,0,0.1);
}

@media (max-width: 640px){
  .product-item__video-wrap .gallery-arrow{ width:32px; height:32px; }
}

/* Responsive fine-tuning of horizontal offset to keep visual protrusion consistent */
@media (max-width: 1280px){
  .product-item__video-wrap{ --vstrip-arrow-ox: 24%; }
}
@media (max-width: 1024px){
  .product-item__video-wrap{ --vstrip-arrow-ox: 18%; }
}
@media (max-width: 768px){
  .product-item__video-wrap{ --vstrip-arrow-ox: 16%; }
}
@media (max-width: 640px){
  .product-item__video-wrap{ --vstrip-arrow-ox: 14%; }
}

/* Catalog list: always show equipment in two columns on all resolutions */
/* Increase horizontal spacing between characteristic columns and keep two cols */
.product-item__equipment{ 
  justify-content: flex-start !important;
  column-gap: 20px !important; /* doubled gutter */
  row-gap: 6px !important; 
}
.product-item__equipment-item{ width: calc(50% - 10px) !important; }

/* Keep price row on one line and slightly tune value size per breakpoint */
.product-item__price-box{ white-space: nowrap; }
@media (max-width: 1440px){
  .product-item__price{ font-size: 20px !important; }
}
@media (max-width: 1280px){
  .product-item__price{ font-size: 18px !important; }
}
@media (max-width: 1024px){
  .product-item__price{ font-size: 17px !important; }
}

/* Similar offers: don't clip hover ring/shadows around cards */
.similar-block{ overflow: visible !important; padding-bottom: 10px; }
.similar-slider, .similar-slider .slick-list, .similar-slider .slick-track{ overflow: visible !important; }

/* Prevent ribbon from shifting outside photo area in carousels */
.similar-block .product-item__img-wrap{ position: relative !important; }
.similar-block .product-item__img-wrap img{ display:block; width:100%; height:auto; }

/* Ensure ribbons inside similar cards appear above slider controls */
.similar-block .arrival-ribbon{ z-index: 20 !important; }

/* Hide outgoing slide title instantly when slick is animating */
.similar-slider .slick-slide[aria-hidden="true"] .product-item__title{ visibility: hidden; }

/* Unify side paddings with characteristics block on small screens */
@media (max-width: 1024px){
  /* Video gallery wrapper */
  .product-item__video-wrap{ --vstrip-pad-x: 15px; }

  /* Photo block: give padding to wrapper only, sliders have no side padding */
  .item__photo-wrap{ padding-left:15px !important; padding-right:15px !important; }
  .photo-slider{ padding-left:0 !important; padding-right:0 !important; }
  .photo-nav-slider{ padding-left:0 !important; padding-right:0 !important; }
}

/* ===============
   Header unification
   Make index (home) header look the same as inner pages by normalizing paddings
   and logo/social icon sizes. Do NOT hide the overlay header.
   =============== */
/* Overlay top header (logo + socials) */
.section .header .index-header__wrap{ padding: 10px 15px !important; }
.index-header__logo img{ max-height: 42px; height: auto; width: auto; }
.index-header__social-icon svg{ width: 25px !important; height: 25px !important; }
.index-header__social-wrap .index-header__social-item{ padding: 5px !important; }

/* Floating quick contacts */
.floating-contacts{
  position:fixed;
  top:50%;
  right:22px;
  transform:translateY(-50%);
  z-index:70;
  display:flex;
  flex-direction:column;
  gap:12px;
  pointer-events:none;
}
.floating-contacts__dropdown{
  position:relative;
  margin:0;
  pointer-events:auto;
}
.floating-contacts__dropdown summary{
  list-style:none;
}
.floating-contacts__dropdown summary::-webkit-details-marker{
  display:none;
}
.floating-contacts__action{
  position:relative;
  width:58px;
  height:58px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  border-radius:18px;
  border:1px solid rgba(81,184,88,.55);
  background:linear-gradient(180deg, rgba(20,24,31,.94) 0%, rgba(9,12,17,.96) 100%);
  box-shadow:0 20px 40px rgba(0,0,0,.24);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  cursor:pointer;
  pointer-events:auto;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease, background-color .25s ease;
}
.floating-contacts__action:focus,
.floating-contacts__action:hover{
  transform:translateX(-4px);
  border-color:#51b858;
  box-shadow:0 22px 46px rgba(0,0,0,.3);
}
.floating-contacts__action:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(81,184,88,.22), 0 22px 46px rgba(0,0,0,.3);
}
.floating-contacts__icon{
  display:flex;
  align-items:center;
  justify-content:center;
  width:24px;
  height:24px;
}
.floating-contacts__icon svg{
  width:22px;
  height:22px;
  fill:#fff;
  transition:fill .25s ease, transform .25s ease;
}
.floating-contacts__action:focus .floating-contacts__icon svg,
.floating-contacts__action:hover .floating-contacts__icon svg{
  fill:#51b858;
  transform:scale(1.04);
}
.floating-contacts__hint{
  position:absolute;
  right:calc(100% + 12px);
  top:50%;
  transform:translateY(-50%) translateX(8px);
  white-space:nowrap;
  padding:10px 14px;
  border-radius:14px;
  background:rgba(12,16,21,.92);
  border:1px solid rgba(81,184,88,.3);
  color:#fff;
  font-family:'Magistral-Bold', 'Magistral', Arial, sans-serif;
  font-size:14px;
  line-height:1;
  letter-spacing:.04em;
  text-transform:uppercase;
  opacity:0;
  visibility:hidden;
  transition:opacity .2s ease, transform .2s ease, visibility .2s ease;
  pointer-events:none;
}
.floating-contacts__hint::after{
  content:'';
  position:absolute;
  top:50%;
  right:-6px;
  width:12px;
  height:12px;
  transform:translateY(-50%) rotate(45deg);
  background:rgba(12,16,21,.92);
  border-top:1px solid rgba(81,184,88,.3);
  border-right:1px solid rgba(81,184,88,.3);
}
.floating-contacts__action:focus .floating-contacts__hint,
.floating-contacts__action:hover .floating-contacts__hint,
.floating-contacts__dropdown[open] .floating-contacts__hint{
  opacity:1;
  visibility:visible;
  transform:translateY(-50%) translateX(0);
}
.floating-contacts__action--instagram{
  border-color:rgba(214,97,137,.55);
}
.floating-contacts__action--instagram:focus,
.floating-contacts__action--instagram:hover{
  border-color:#d66189;
}
.floating-contacts__action--fb{
  border-color:rgba(86,122,214,.55);
}
.floating-contacts__action--fb:focus,
.floating-contacts__action--fb:hover{
  border-color:#567ad6;
}
.floating-contacts__action--youtube{
  border-color:rgba(255,91,91,.55);
}
.floating-contacts__action--youtube:focus,
.floating-contacts__action--youtube:hover{
  border-color:#ff5b5b;
}
.floating-contacts__action--messenger{
  border-color:rgba(76,173,255,.55);
}
.floating-contacts__action--messenger:focus,
.floating-contacts__action--messenger:hover{
  border-color:#4cadff;
}
.floating-contacts__menu{
  position:absolute;
  right:calc(100% + 12px);
  top:50%;
  transform:translateY(-50%);
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px;
  border-radius:18px;
  background:rgba(12,16,21,.94);
  border:1px solid rgba(81,184,88,.22);
  box-shadow:0 18px 40px rgba(0,0,0,.28);
}
.floating-contacts__menu-link{
  width:44px;
  height:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:14px;
  text-decoration:none;
  background:rgba(255,255,255,.04);
  transition:transform .2s ease, background-color .2s ease;
}
.floating-contacts__menu-link svg{
  width:20px;
  height:20px;
  fill:#fff;
  transition:fill .2s ease;
}
.floating-contacts__menu-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  width:20px;
  height:20px;
}
.floating-contacts__menu-icon svg{
  width:20px;
  height:20px;
  fill:#fff;
  transition:fill .2s ease, transform .2s ease;
}
.floating-contacts__menu-tooltip{
  position:absolute;
  top:calc(100% + 8px);
  left:50%;
  transform:translateX(-50%) translateY(-4px);
  white-space:nowrap;
  padding:8px 10px;
  border-radius:10px;
  background:rgba(12,16,21,.95);
  border:1px solid rgba(81,184,88,.2);
  color:#fff;
  font-family:'Magistral-Bold', 'Magistral', Arial, sans-serif;
  font-size:12px;
  line-height:1;
  letter-spacing:.04em;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .2s ease, transform .2s ease, visibility .2s ease;
}
.floating-contacts__menu-link:hover,
.floating-contacts__menu-link:focus{
  transform:translateY(-2px);
  background:rgba(255,255,255,.08);
}
.floating-contacts__menu-link:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(81,184,88,.18);
}
.floating-contacts__menu-link:hover .floating-contacts__menu-tooltip,
.floating-contacts__menu-link:focus .floating-contacts__menu-tooltip{
  opacity:1;
  visibility:visible;
  transform:translateX(-50%) translateY(0);
}
.floating-contacts__menu-link--instagram:hover svg,
.floating-contacts__menu-link--instagram:focus svg,
.floating-contacts__menu-link--instagram:hover .floating-contacts__menu-icon svg,
.floating-contacts__menu-link--instagram:focus .floating-contacts__menu-icon svg{
  fill:#d66189;
}
.floating-contacts__menu-link--fb:hover svg,
.floating-contacts__menu-link--fb:focus svg,
.floating-contacts__menu-link--fb:hover .floating-contacts__menu-icon svg,
.floating-contacts__menu-link--fb:focus .floating-contacts__menu-icon svg{
  fill:#567ad6;
}
.floating-contacts__menu-link--youtube:hover svg,
.floating-contacts__menu-link--youtube:focus svg,
.floating-contacts__menu-link--youtube:hover .floating-contacts__menu-icon svg,
.floating-contacts__menu-link--youtube:focus .floating-contacts__menu-icon svg{
  fill:#ff5b5b;
}
.floating-contacts__menu-link--wa:hover .floating-contacts__menu-icon svg,
.floating-contacts__menu-link--wa:focus .floating-contacts__menu-icon svg{
  fill:#48c857;
  transform:scale(1.06);
}
.floating-contacts__menu-link--tg:hover .floating-contacts__menu-icon svg,
.floating-contacts__menu-link--tg:focus .floating-contacts__menu-icon svg{
  fill:#4cadff;
  transform:scale(1.06);
}
.floating-contacts__menu-link--viber:hover .floating-contacts__menu-icon svg,
.floating-contacts__menu-link--viber:focus .floating-contacts__menu-icon svg{
  fill:#8f5cff;
  transform:scale(1.06);
}
@media (max-width: 1024px){
  .floating-contacts{
    top:auto;
    bottom:18px;
    right:18px;
    transform:none;
  }
  .floating-contacts__hint{
    display:none;
  }
  .floating-contacts__menu{
    top:auto;
    bottom:calc(100% + 10px);
    right:0;
    transform:none;
    flex-direction:column;
  }
  .floating-contacts__menu--messengers{
    flex-direction:column;
  }
  .floating-contacts__menu-tooltip{
    display:none;
  }
}
@media (max-width: 767px){
  .floating-contacts{
    right:14px;
    bottom:14px;
    gap:10px;
  }
  .floating-contacts__action{
    width:54px;
    height:54px;
    border-radius:16px;
  }
  .floating-contacts__menu{
    padding:8px;
    gap:8px;
  }
  .floating-contacts__menu-link{
    width:40px;
    height:40px;
    border-radius:12px;
  }
}

/* Moving header bar with menu – keep compact like inner pages */
.header-menu__wrap.move{ padding-top: 10px !important; padding-bottom: 10px !important; }
.header-menu__wrap{
  /* ≈2x darker than before for consistent readability */
  background: rgba(0,0,0,0.85) !important;
  -webkit-backdrop-filter: saturate(120%) blur(8px);
  backdrop-filter: saturate(120%) blur(8px);
}
.index-header__logo--move img{ max-height: 42px; height: auto; width: auto; }
@media (min-width: 1441px){
  .header-menu__wrap.move{ padding-top: 12px !important; padding-bottom: 12px !important; }
}
