/* =========================================================
   Page: Хоккейное видео
   Separate video archive with sticky league tabs + lazy loading
   ========================================================= */

.sp-video-page{
  display:grid;
  gap:clamp(22px,3vw,36px);
  min-width:0;
  padding-bottom:clamp(34px,5vw,64px);
}

.sp-video-page__breadcrumbs{
  margin-bottom:-6px;
}

.sp-video-hero{
  position:relative;
  overflow:hidden;
  display:grid;
  gap:14px;
  padding:clamp(26px,4.8vw,52px);
  border:1px solid var(--sp-card-border);
  border-radius:var(--sp-radius-lg);
  background:
    radial-gradient(circle at 12% 8%, var(--sp-accent-alpha-18), transparent 32%),
    radial-gradient(circle at 85% 0%, rgba(255,255,255,.09), transparent 28%),
    var(--sp-gradient-card);
  box-shadow:var(--sp-shadow-soft);
}

.sp-video-hero::after{
  content:"";
  position:absolute;
  inset:auto -120px -160px auto;
  width:360px;
  height:360px;
  border-radius:50%;
  background:var(--sp-accent-alpha-12);
  filter:blur(8px);
  pointer-events:none;
}

.sp-video-hero > *{
  position:relative;
  z-index:1;
}

.sp-video-hero h1{
  max-width:900px;
  margin:0;
  font-family:var(--sp-font-display);
  font-size:var(--sp-fs-page-title);
  line-height:1.02;
  letter-spacing:-.05em;
}

.sp-video-hero p{
  max-width:760px;
  margin:0;
  color:var(--sp-muted);
  font-size:var(--sp-fs-body);
  line-height:1.65;
}

.spvk-archive{
  display:grid;
  gap:18px;
  min-width:0;
}

.spvk-archive__tabs-wrap{
  position:sticky;
  top:calc(var(--sp-header-height) + 0px);
  z-index:35;
  margin:-4px 0 2px;
  padding:10px 0;
  background:linear-gradient(180deg, var(--sp-bg) 0%, color-mix(in srgb, var(--sp-bg) 82%, transparent) 100%);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
}

.spvk-archive__tabs{
  margin-bottom:0;
  padding:2px 0 4px;
  overflow-x:auto;
  overflow-y:hidden;
  flex-wrap:nowrap;
  scrollbar-width:none;
  -ms-overflow-style:none;
}

.spvk-archive__tabs::-webkit-scrollbar{
  display:none;
}

.spvk-archive__tab{
  flex:0 0 auto;
}

.spvk-archive__panels,
.spvk-archive__panel{
  min-width:0;
}

.spvk-archive__panel[hidden]{
  display:none !important;
}

.spvk-archive__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  align-items:stretch;
  min-width:0;
}

@media (max-width:1024px){
  .spvk-archive__grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media (max-width:767px){
  .spvk-archive__grid{
    grid-template-columns:1fr;
  }
}

.spvk-archive__empty,
.spvk-video--notice,
.sp-video-page__notice{
  padding:18px;
  border:1px solid var(--sp-card-border);
  border-radius:var(--sp-radius-lg);
  background:var(--sp-gradient-card);
  color:var(--sp-muted);
  box-shadow:var(--sp-shadow-soft);
}

.spvk-archive__more{
  display:grid;
  justify-items:center;
  gap:10px;
  margin-top:22px;
}

.spvk-archive__sentinel{
  width:100%;
  height:1px;
}

.spvk-archive__more-button{
  min-width:190px;
}

.spvk-archive__fallback{
  color:var(--sp-muted);
  font-size:var(--sp-fs-xs);
  text-decoration:none;
}

.spvk-archive__fallback:hover{
  color:var(--sp-accent);
}

.spvk-archive__status{
  min-height:18px;
  margin:0;
  color:var(--sp-muted);
  font-size:var(--sp-fs-xs);
  text-align:center;
}

.sp-video-seo-text{
  display:grid;
  gap:12px;
  max-width:920px;
  padding-top:8px;
  color:var(--sp-muted);
  line-height:1.7;
}

.sp-video-seo-text h2{
  margin:0;
  color:var(--sp-text);
  font-family:var(--sp-font-display);
  font-size:clamp(24px,3vw,34px);
  line-height:1.08;
  letter-spacing:-.035em;
}

.sp-video-seo-text p{
  margin:0;
}


/* Shaiba Pro VK Video — общие стили блока, карточек, модального окна и плеера для главной и /video/. */

.spvk-video{
  min-width:0;
  max-width:100%;
}

.spvk-video__head{
  align-items:end;
}

.spvk-video__lead{
  max-width:680px;
  margin:10px 0 0;
  color:var(--sp-muted);
}

.spvk-video-tabs{
  margin-bottom:18px;
}

.spvk-video-panels,
.spvk-video-panel,
.spvk-video-scroll,
.spvk-video-grid{
  min-width:0;
  max-width:100%;
}

.spvk-video-panel[hidden]{
  display:none !important;
}

.spvk-video-scroll{
  overflow-x:auto;
  overflow-y:hidden;
  width:100%;
  max-width:100%;
  padding:0 0 12px;
  overscroll-behavior-x:contain;
  scrollbar-width:thin;
  scrollbar-color:var(--sp-accent-alpha-42) var(--sp-white-04);
}

.spvk-video-scroll::-webkit-scrollbar{
  height:10px;
}

.spvk-video-scroll::-webkit-scrollbar-track{
  border-radius:var(--sp-radius-pill);
  background:var(--sp-white-04);
}

.spvk-video-scroll::-webkit-scrollbar-thumb{
  border:2px solid transparent;
  border-radius:var(--sp-radius-pill);
  background:var(--sp-accent-alpha-42);
  background-clip:content-box;
}

.spvk-video-scroll::-webkit-scrollbar-thumb:hover{
  background:var(--sp-accent-alpha-75);
  background-clip:content-box;
}

.spvk-video-grid{
  display:grid;
  width:max-content;
  min-width:100%;
  max-width:none;
  grid-auto-flow:column;
  grid-auto-columns:calc((100vw - 96px - 42px) / 4);
  grid-template-columns:none;
  gap:14px;
}

.spvk-video-card{
  min-width:0;
}

.spvk-video-card__button{
  overflow:hidden;
  display:grid;
  width:100%;
  height:100%;
  min-height:100%;
  padding:0;
  border:1px solid var(--sp-card-border);
  border-radius:var(--sp-radius-md);
  background:var(--sp-gradient-card);
  color:var(--sp-text);
  text-align:left;
  box-shadow:var(--sp-shadow-soft);
  cursor:pointer;
  transition:
    transform var(--sp-transition-fast),
    border-color var(--sp-transition-fast),
    background var(--sp-transition-fast),
    box-shadow var(--sp-transition-fast);
}

.spvk-video-card__button:hover,
.spvk-video-card__button:focus-visible{
  transform:translateY(-2px);
  border-color:var(--sp-card-border-hover);
  background:var(--sp-gradient-card-hover);
  outline:none;
}

.spvk-video-card__media{
  position:relative;
  overflow:hidden;
  display:block;
  width:100%;
  aspect-ratio:16/9;
  background:var(--sp-black-45);
}

.spvk-video-card__media img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.01);
  transition:
    transform .35s ease,
    filter .35s ease;
}

.spvk-video-card__button:hover .spvk-video-card__media img,
.spvk-video-card__button:focus-visible .spvk-video-card__media img{
  transform:scale(1.055);
  filter:saturate(1.08) contrast(1.04);
}

.spvk-video-card__shade{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 20%, rgba(0,0,0,.34) 62%, rgba(0,0,0,.72));
}

.spvk-video-card__play{
  position:absolute;
  left:50%;
  top:50%;
  display:grid;
  width:62px;
  height:62px;
  place-items:center;
  border:1px solid var(--sp-card-border);
  border-radius:50%;
  background:
    radial-gradient(circle at 30% 22%, var(--sp-white-28), transparent 35%),
    linear-gradient(135deg, var(--sp-accent-alpha-75), var(--sp-accent-alpha-20));
  box-shadow:0 16px 44px var(--sp-black-45), inset 0 1px 0 var(--sp-white-28);
  transform:translate(-50%, -50%);
  transition:transform var(--sp-transition-fast), background var(--sp-transition-fast);
}

.spvk-video-card__play svg{
  display:block;
  width:34px;
  height:34px;
  fill:var(--sp-white);
  filter:drop-shadow(0 3px 8px var(--sp-black-45));
}

.spvk-video-card__button:hover .spvk-video-card__play,
.spvk-video-card__button:focus-visible .spvk-video-card__play{
  transform:translate(-50%, -50%) scale(1.07);
}

.spvk-video-card__duration{
  position:absolute;
  right:12px;
  bottom:12px;
  padding:5px 8px;
  border:1px solid var(--sp-card-border);
  border-radius:var(--sp-radius-pill);
  background:var(--sp-black-62);
  color:var(--sp-white);
  font-size:12px;
  font-weight:var(--sp-fw-bold);
  line-height:1;
  backdrop-filter:blur(10px);
}

.spvk-video-card__body{
  display:grid;
  gap:8px;
  padding:14px 15px 16px;
}

.spvk-video-card__meta{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  color:var(--sp-accent);
  font-size:var(--sp-fs-xs);
  font-weight:var(--sp-fw-bold);
  line-height:1;
  text-transform:uppercase;
  letter-spacing:.04em;
}

.spvk-video-card__meta span:not(:last-child)::after{
  content:"·";
  margin-left:6px;
  color:var(--sp-muted);
}

.spvk-video-card__title{
  overflow:hidden;
  display:-webkit-box;
  min-height:3.15em;
  color:var(--sp-text);
  font-size:clamp(17px, 2vw, 20px);
  font-weight:var(--sp-fw-medium);
  line-height:1.05;
  letter-spacing:-.035em;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
}

.spvk-video-card__date{
  color:var(--sp-muted);
  font-size:var(--sp-fs-xs);
  line-height:1.15;
}

.spvk-video--notice{
  padding:18px;
  border:1px dashed var(--sp-card-border);
  border-radius:var(--sp-radius-md);
  color:var(--sp-text-soft);
}

.spvk-modal{
  position:fixed;
  inset:0;
  z-index:100000;
  display:grid;
  place-items:center;
  padding:clamp(14px, 3vw, 34px);
}

.spvk-modal[hidden]{
  display:none;
}

.spvk-modal__backdrop{
  position:absolute;
  inset:0;
  background:rgba(2,6,14,.84);
  backdrop-filter:blur(16px);
}

.spvk-modal__dialog{
  position:relative;
  overflow:hidden;
  display:grid;
  grid-template-rows:auto auto auto;
  width:min(1120px, 100%);
  border:1px solid var(--sp-card-border);
  border-radius:var(--sp-radius-lg);
  background:var(--sp-bg-2);
  box-shadow:var(--sp-shadow);
}

.spvk-modal__top{
  display:flex;
  gap:16px;
  align-items:flex-start;
  justify-content:space-between;
  padding:18px 20px;
  border-bottom:1px solid var(--sp-card-border);
  background:var(--sp-gradient-surface);
}

.spvk-modal__text{
  min-width:0;
}

.spvk-modal__league{
  display:block;
  margin-bottom:6px;
  color:var(--sp-accent);
  font-size:var(--sp-fs-xs);
  font-weight:var(--sp-fw-bold);
  line-height:1;
  text-transform:uppercase;
  letter-spacing:.06em;
}

.spvk-modal__title{
  margin:0;
  padding:14px 18px 18px;
  border-top:1px solid var(--sp-card-border);
  background:var(--sp-bg);
  color:var(--sp-text);
  font-size:clamp(17px,2vw,24px);
  line-height:1.22;
  letter-spacing:-.03em;
}

.spvk-modal__meta{
  margin-top:8px;
  color:var(--sp-muted);
  font-size:var(--sp-fs-sm);
}

.spvk-modal__close{
  display:grid;
  flex:0 0 42px;
  width:42px;
  height:42px;
  place-items:center;
  border:1px solid var(--sp-card-border);
  border-radius:50%;
  background:var(--sp-white-04);
  color:var(--sp-text);
  font:inherit;
  font-size:30px;
  line-height:1;
  cursor:pointer;
  transition:
    transform var(--sp-transition-fast),
    border-color var(--sp-transition-fast),
    background var(--sp-transition-fast),
    color var(--sp-transition-fast);
}

.spvk-modal__close:hover,
.spvk-modal__close:focus-visible{
  transform:translateY(-1px);
  border-color:var(--sp-card-border-hover);
  background:var(--sp-accent-alpha-08);
  color:var(--sp-accent);
  outline:none;
}

.spvk-modal__player{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  background:var(--sp-black);
}

.spvk-modal__player iframe{
  position:absolute;
  inset:0;
  display:block;
  width:100%;
  height:100%;
  border:0;
}

body.spvk-modal-open{
  overflow:hidden;
}

@media (min-width:1440px){
  .spvk-video-grid{
    grid-auto-columns:minmax(300px, calc((100vw - 156px - 42px) / 4));
  }
}

@media (max-width:1200px){
  .spvk-video-grid{
    grid-auto-columns:calc((100vw - 72px - 28px) / 3);
  }
}

@media (max-width:900px){
  .spvk-video-grid{
    grid-auto-columns:calc((100vw - 56px - 14px) / 2);
  }
}

@media (max-width:767px){
  .spvk-video__head{
    align-items:flex-start;
  }

  .spvk-video-tabs{
    overflow-x:auto;
    flex-wrap:nowrap;
    margin-bottom:14px;
    padding-bottom:2px;
    scrollbar-width:none;
    -ms-overflow-style:none;
  }

  .spvk-video-tabs::-webkit-scrollbar{
    display:none;
  }

  .spvk-video-tab{
    flex:0 0 auto;
  }

  .spvk-video-scroll{
    padding-bottom:4px;
    scrollbar-width:none;
    -ms-overflow-style:none;
  }

  .spvk-video-scroll::-webkit-scrollbar{
    display:none;
  }

  .spvk-video-grid{
    grid-auto-columns:82vw;
    gap:12px;
  }

  .spvk-video-card__button{
    border-radius:var(--sp-radius-mobile);
  }

  .spvk-video-card__play{
    width:56px;
    height:56px;
  }

  .spvk-modal{
    padding:10px;
  }

  .spvk-modal__dialog{
    border-radius:var(--sp-radius-mobile);
  }

  .spvk-modal__top{
    padding:14px;
  }

  .spvk-modal__title{
    padding:12px 14px 15px;
    font-size:17px;
  }

  .spvk-modal__close{
    flex-basis:38px;
    width:38px;
    height:38px;
    font-size:28px;
  }
}

@media (hover:none), (pointer:coarse){
  .spvk-video-card__button:hover,
  .spvk-video-card__button:focus-visible,
  .spvk-modal__close:hover,
  .spvk-modal__close:focus-visible{
    transform:none;
  }
}