
@font-face{
  font-family:'LocalInter';
  src:url('../fonts/Inter-Regular.woff2') format('woff2');
  font-weight:400;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:'LocalInter';
  src:url('../fonts/Inter-SemiBold.woff2') format('woff2');
  font-weight:600;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:'LocalInter';
  src:url('../fonts/Inter-Bold.woff2') format('woff2');
  font-weight:800;
  font-style:normal;
  font-display:swap;
}

*{box-sizing:border-box}
html{background:#0d0d0f}
body{
  margin:0;
  background:
    radial-gradient(circle at top left, rgba(204,39,113,.13), transparent 320px),
    linear-gradient(180deg,#111114 0%,#0d0d0f 45%,#0b0b0c 100%);
  color:#ededee;
  font-family:'LocalInter', Arial, sans-serif;
  font-size:14px;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.site{
  width:100%;
  max-width:1680px;
  margin:0 auto;
  padding:0 18px 32px;
}

.header{
  min-height:74px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  border-bottom:1px solid #26262a;
  margin-bottom:22px;
}
.logo{
  font-size:31px;
  line-height:1;
  font-weight:800;
  letter-spacing:-.04em;
  color:#f4f4f5;
  white-space:nowrap;
}
.logo span{
  color:#ff3d8d;
}
.nav{
  display:flex;
  align-items:center;
  gap:18px;
  color:#b7b7bc;
  font-weight:600;
  font-size:13px;
}
.nav a:hover{color:#fff}

.page-head{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:end;
  gap:20px;
  margin:10px 0 18px;
}
h1{
  margin:0 0 8px;
  font-size:30px;
  letter-spacing:-.03em;
  line-height:1.15;
}
.lead{
  max-width:880px;
  margin:0;
  color:#b7b7bc;
  line-height:1.55;
}
.search-box{
  width:280px;
  height:40px;
  background:#161619;
  border:1px solid #2b2b30;
  color:#eee;
  padding:0 13px;
  outline:none;
  border-radius:3px;
}

.banner-row{
  display:grid;
  grid-template-columns:repeat(3,300px);
  justify-content:center;
  gap:18px;
  margin:22px 0 26px;
}
.banner{
  width:300px;
  height:250px;
  background:
    linear-gradient(135deg,#18181b,#111113);
  border:1px solid #303038;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#686873;
  font-weight:700;
  letter-spacing:.02em;
  overflow:hidden;
}

.section-title{
  margin:26px 0 14px;
  font-size:18px;
  font-weight:800;
  letter-spacing:-.02em;
}
.video-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:15px;
}
.card{
  background:#151518;
  border:1px solid #25252a;
  overflow:hidden;
  border-radius:3px;
}
.card:hover{
  border-color:#565660;
  background:#18181c;
}
.thumb-link{
  position:relative;
  display:block;
  background:#080809;
}
.thumb{
  width:100%;
  aspect-ratio:16/9;
  object-fit:cover;
}
.duration{
  position:absolute;
  right:6px;
  bottom:6px;
  background:rgba(0,0,0,.78);
  color:#fff;
  font-size:11px;
  font-weight:700;
  padding:3px 5px;
}
.card-body{
  padding:9px 9px 10px;
}
.card-title{
  font-size:14px;
  font-weight:700;
  line-height:1.35;
  margin:0 0 7px;
  color:#f1f1f2;
}
.meta{
  font-size:12px;
  color:#85858c;
  margin-bottom:8px;
}
.card-tags{
  display:flex;
  flex-wrap:wrap;
  gap:5px;
}
.card-tags a{
  font-size:11px;
  color:#bbbcc2;
  background:#222227;
  border:1px solid #2e2e35;
  padding:3px 6px;
}

.tags-cloud{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:8px 0 24px;
}
.tags-cloud a{
  background:#17171a;
  border:1px solid #2e2e34;
  color:#c7c7cc;
  padding:7px 10px;
  font-size:13px;
  font-weight:600;
}
.tags-cloud a:hover{
  border-color:#ff3d8d;
  color:#fff;
}

.text-block{
  margin:28px 0;
  padding:18px 20px;
  background:#141416;
  border:1px solid #28282d;
  color:#bdbdc3;
  line-height:1.62;
}
.text-block h2{
  margin:0 0 8px;
  font-size:20px;
  color:#f0f0f2;
}

.pagination{
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:7px;
  margin:30px 0 24px;
}
.pagination a,
.pagination span{
  min-width:34px;
  height:34px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#17171a;
  border:1px solid #303036;
  color:#c7c7cc;
  font-weight:700;
  font-size:13px;
}
.pagination .active{
  background:#ff3d8d;
  border-color:#ff3d8d;
  color:#fff;
}

.embed-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 318px;
  gap:22px;
  align-items:start;
}
.player-box{
  max-width:1040px;
}
.player{
  width:100%;
  aspect-ratio:16/9;
  background:#000;
  border:1px solid #28282d;
}
.player iframe{
  width:100%;
  height:100%;
  border:0;
}
.side-banners{
  display:grid;
  gap:14px;
  justify-content:center;
}
.below-player{
  margin-top:22px;
}
.footer{
  border-top:1px solid #26262a;
  margin-top:34px;
  padding-top:18px;
  color:#777780;
  display:flex;
  justify-content:space-between;
  gap:18px;
  font-size:12px;
}
.footer-links{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}

@media(max-width:1220px){
  .video-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .embed-layout{grid-template-columns:1fr}
  .side-banners{
    grid-template-columns:repeat(3,300px);
  }
}
@media(max-width:960px){
  .video-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .banner-row,.side-banners{
    grid-template-columns:repeat(2,300px);
  }
  .page-head{grid-template-columns:1fr}
  .search-box{width:100%}
}
@media(max-width:680px){
  .site{padding:0 10px 26px}
  .header{
    align-items:flex-start;
    flex-direction:column;
    gap:12px;
    padding:16px 0;
  }
  .logo{font-size:27px}
  .nav{
    width:100%;
    overflow:auto;
    gap:14px;
    padding-bottom:2px;
  }
  h1{font-size:24px}
  .video-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
  }
  .card-body{padding:8px}
  .card-title{font-size:13px}
  .banner-row,.side-banners{
    grid-template-columns:300px;
    justify-content:center;
  }
  .text-block{padding:14px}
  .footer{flex-direction:column}
}
