/* ============================================
   DIRxHUB — Redesign v3
   ============================================ */

:root {
  --bg: #07070a;
  --bg2: #0c0c12;
  --card: #0f0f17;
  --hover: rgba(255,255,255,.03);
  --border: rgba(255,255,255,.06);
  --border-hover: rgba(229,9,20,.25);
  --text: #eee;
  --dim: #666;
  --muted: #888;
  --accent: #e50914;
  --accent2: #b00710;
  --glow: rgba(229,9,20,.2);
  --radius: 12px;
  --radius-sm: 8px;
  --ease: .22s cubic-bezier(.4,0,.2,1);
}

*{margin:0;padding:0;box-sizing:border-box}

body{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}

/* Фон */
body::before{
  content:'';
  position:fixed;inset:0;
  background:
    radial-gradient(ellipse 70% 45% at 25% 0%,rgba(229,9,20,.06) 0,transparent 60%),
    radial-gradient(ellipse 50% 35% at 75% 100%,rgba(120,20,180,.04) 0,transparent 60%),
    radial-gradient(ellipse 40% 30% at 50% 50%,rgba(229,9,20,.02) 0,transparent 50%);
  pointer-events:none;z-index:0;
}

body::after{
  content:'';
  position:fixed;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.008) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.008) 1px,transparent 1px);
  background-size:48px 48px;
  pointer-events:none;z-index:0;
}

/* ============================================
   Header
   ============================================ */
.header{
  position:sticky;top:0;z-index:100;
  background:rgba(7,7,10,.82);
  -webkit-backdrop-filter:blur(14px) saturate(1.4);
  backdrop-filter:blur(14px) saturate(1.4);
  border-bottom:1px solid rgba(255,255,255,.04);
}

.header-inner{
  display:flex;align-items:center;gap:16px;
  padding:10px 16px;
  max-width:1400px;margin:0 auto;
}

.logo{
  text-decoration:none;
  font-size:20px;font-weight:900;
  color:#fff;white-space:nowrap;
  letter-spacing:-.3px;
  position:relative;
}

.logo span{color:var(--accent)}

.logo::after{
  content:'';
  position:absolute;bottom:-2px;left:0;
  width:100%;height:2px;
  background:var(--accent);
  transform:scaleX(0);transform-origin:left;
  transition:transform var(--ease);
  border-radius:1px;
}

.logo:hover::after{transform:scaleX(1)}

.search-wrap{
  flex:1;display:flex;
  max-width:440px;margin-left:auto;
}

.search-wrap input{
  flex:1;
  padding:9px 14px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-right:0;
  border-radius:var(--radius-sm) 0 0 var(--radius-sm);
  color:var(--text);
  font-size:13px;
  outline:none;
  transition:all var(--ease);
}

.search-wrap input:focus{
  border-color:var(--accent);
  background:rgba(229,9,20,.03);
  box-shadow:inset 0 0 0 1px rgba(229,9,20,.06);
}

.search-wrap input::placeholder{color:var(--dim);font-size:13px}

.search-wrap button{
  padding:9px 14px;
  background:var(--accent);
  border:none;
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  color:#fff;
  cursor:pointer;
  display:flex;align-items:center;
  transition:background var(--ease),transform var(--ease);
}

.search-wrap button:hover{
  background:var(--accent2);
  transform:scale(1.02);
}

.search-wrap button:active{transform:scale(.97)}

/* ============================================
   Category pills
   ============================================ */
.cats{
  display:flex;gap:6px;
  padding:6px 16px 12px;
  overflow-x:auto;
  scrollbar-width:none;
  max-width:1400px;margin:0 auto;
  -webkit-overflow-scrolling:touch;
}

.cats::-webkit-scrollbar{display:none}

.cat{
  flex-shrink:0;
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 14px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius:20px;
  color:#888;
  font-size:12px;font-weight:500;
  cursor:pointer;
  transition:all var(--ease);
  white-space:nowrap;
  letter-spacing:.2px;
}

.cat:hover{
  border-color:rgba(229,9,20,.2);
  background:rgba(229,9,20,.06);
  color:var(--text);
}

.cat.active{
  background:var(--accent);
  border-color:var(--accent);
  color:#fff;
  font-weight:600;
  box-shadow:0 0 14px var(--glow);
}

.ci{font-size:13px;line-height:1}

/* ============================================
   Main content
   ============================================ */
.main{
  position:relative;z-index:1;
  max-width:1400px;margin:0 auto;
  padding:18px 16px 40px;
}

.section-head{margin-bottom:14px}

.section-head h2{
  font-size:14px;font-weight:700;
  text-transform:uppercase;letter-spacing:1.2px;
  color:#999;
  padding-left:12px;
  border-left:3px solid var(--accent);
}

/* ============================================
   Video grid
   ============================================ */
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:10px;
}

.video-card{
  background:var(--card);
  border-radius:var(--radius);
  overflow:hidden;
  cursor:pointer;
  transition:all var(--ease);
  border:1px solid rgba(255,255,255,.03);
  position:relative;
}

.video-card::after{
  content:'';
  position:absolute;inset:0;
  border-radius:var(--radius);
  pointer-events:none;
  transition:opacity var(--ease);
  opacity:0;
  box-shadow:inset 0 0 0 1px var(--accent);
}

.video-card:hover{
  transform:translateY(-4px);
  box-shadow:0 8px 24px rgba(0,0,0,.3);
}

.video-card:hover::after{opacity:1}

.thumb{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  background:#000;
  overflow:hidden;
}

.thumb img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .35s ease;
}

.video-card:hover .thumb img{transform:scale(1.06)}

.thumb .dur{
  position:absolute;bottom:6px;right:6px;
  background:rgba(0,0,0,.82);
  padding:2px 7px;border-radius:4px;
  font-size:11px;font-weight:600;
  color:#fff;backdrop-filter:blur(4px);
  z-index:2;
}

.thumb .play-btn{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%) scale(.8);
  width:40px;height:40px;
  background:var(--accent);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  opacity:0;
  transition:all var(--ease);
  box-shadow:0 0 18px var(--glow);
  z-index:3;
}

.video-card:hover .play-btn{opacity:1;transform:translate(-50%,-50%) scale(1)}

.play-btn::after{content:'▶';color:#fff;font-size:15px;margin-left:2px}

.info{padding:10px 12px 11px}

.info h3{
  font-size:12px;font-weight:600;
  line-height:1.35;
  display:-webkit-box;
  -webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;color:var(--text);margin-bottom:3px;
}

.info .src{
  font-size:10px;color:var(--dim);
  text-transform:uppercase;letter-spacing:1px;
}


/* ============================================
   Player v2
   ============================================ */
.player{
  position:fixed;inset:0;z-index:200;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.92);
  animation:pfade .12s ease;
}
@keyframes pfade{from{opacity:0}to{opacity:1}}

.player-stage{
  position:relative;
  width:100%;max-width:960px;
  height:100%;max-height:100vh;
  display:flex;flex-direction:column;
  padding:48px 16px 20px;
  animation:pup .2s ease;
}
@keyframes pup{from{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}

/* Close button */
.plyr-close{
  position:absolute;top:8px;left:16px;
  z-index:10;
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.06);
  border-radius:50%;
  color:#fff;
  cursor:pointer;
  transition:all .2s ease;
}
.plyr-close:hover{
  background:rgba(229,9,20,.15);
  border-color:rgba(229,9,20,.25);
  color:var(--accent);
}

/* Badge */
.plyr-badge{
  position:absolute;top:12px;right:16px;
  z-index:10;
  padding:4px 12px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.04);
  border-radius:20px;
  font-size:9px;font-weight:600;
  text-transform:uppercase;letter-spacing:1px;
  color:rgba(255,255,255,.3);
}

/* Video */
.plyr-video-wrap{
  flex:1;
  display:flex;align-items:center;justify-content:center;
  padding:4px 0;
}
.plyr-video{
  position:relative;width:100%;
  max-height:calc(100vh - 180px);
  aspect-ratio:16/9;
  background:#000;
  border-radius:12px;
  overflow:hidden;
  box-shadow:0 2px 24px rgba(0,0,0,.5);
}
.plyr-video iframe{
  position:absolute;top:0;left:0;
  width:100%;height:100%;
}

/* Footer */
.plyr-footer{
  padding:8px 0 4px;
}
.plyr-info{
  display:flex;align-items:center;gap:6px;
  margin-bottom:4px;
}
.plyr-source{
  display:inline-flex;align-items:center;gap:4px;
  font-size:11px;color:rgba(255,255,255,.25);
}
.plyr-link{
  display:inline-flex;align-items:center;
  background:none;border:none;
  color:rgba(255,255,255,.2);
  cursor:pointer;padding:2px;
  transition:color .2s ease;
}
.plyr-link:hover{color:var(--accent)}
.plyr-title{
  font-size:15px;font-weight:700;
  line-height:1.3;color:#fff;
  margin-bottom:2px;
  display:-webkit-box;
  -webkit-line-clamp:1;-webkit-box-orient:vertical;
  overflow:hidden;
}
.plyr-hint{
  font-size:9px;
  color:rgba(255,255,255,.35);
  user-select:none;
  margin-top:2px;
}


/* Hidden */


/* Load More */
.load-more{
  display:none;align-items:center;justify-content:center;gap:6px;
  width:100%;max-width:300px;margin:24px auto 0;
  padding:10px 0;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);
  border-radius:10px;
  color:#999;font-size:13px;font-weight:500;
  cursor:pointer;
  transition:all .2s ease;
}
.load-more:hover{
  background:rgba(229,9,20,.08);
  border-color:rgba(229,9,20,.2);
  color:#eee;
}
.load-more svg{transition:transform .2s ease}
.load-more:hover svg{transform:translateY(2px)}
.load-more.loading-more{pointer-events:none;opacity:.5}

@media(min-width:640px){
  .load-more{max-width:400px;padding:12px 0;font-size:14px}
}

.hidden{display:none!important}

@media(min-width:640px){
  .player-stage{padding:52px 24px 24px}
  .plyr-close{top:10px;left:24px}
  .plyr-badge{top:14px;right:24px}
  .plyr-title{font-size:17px}
}

@media(min-width:1024px){
  .player-stage{padding:56px 32px 28px;max-width:1000px}
  .plyr-close{top:12px;left:32px}
  .plyr-badge{top:16px;right:32px}
  .plyr-title{font-size:18px}
}/* ============================================
   Tablets
   ============================================ */

/* Hidden */
.hidden{display:none!important}

@media(min-width:640px){
  .header-inner{padding:12px 24px}
  .cats{padding:8px 24px 12px;gap:7px}
  .cat{font-size:13px;padding:7px 16px}
  .main{padding:22px 24px 50px}
  .grid{gap:14px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}
  .info h3{font-size:13px}
}

/* ============================================
   Desktop
   ============================================ */
@media(min-width:1024px){
  .header-inner{padding:14px 32px}
  .cats{padding:10px 32px 14px;gap:8px}
  .main{padding:26px 32px 60px}
  .grid{gap:16px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
  .section-head{margin-bottom:18px}
  .cat{font-size:13px;padding:8px 18px}
}

/* ============================================
   Scrollbar
   ============================================ */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.05);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.1)}
