/* ── TechCraft Video Player v2 ── */
.tcvp-wrapper*,.tcvp-wrapper*::before,.tcvp-wrapper*::after{box-sizing:border-box;margin:0;padding:0}

.tcvp-wrapper{
  --primary:var(--tcvp-primary,#7c3aed);
  --accent:var(--tcvp-accent,#a855f7);
  --bg:#13111a;--bg2:#1e1b2e;--sf:#252238;
  --bd:rgba(255,255,255,.08);--tx:#f1f0f5;--td:#9590a8;
  --r:12px;--ctrl-h:42px;
  font-family:'Segoe UI',system-ui,sans-serif;
  background:var(--bg);border-radius:var(--r);overflow:hidden;
  position:relative;width:100%;max-width:860px;
  margin:0 auto 28px;
  box-shadow:0 8px 40px rgba(0,0,0,.55),0 0 0 1px var(--bd);
  color:var(--tx);
}

/* ── Stage ── */
.tcvp-stage{position:relative;width:100%;aspect-ratio:16/9;background:#000;cursor:pointer;user-select:none}
.tcvp-video{width:100%;height:100%;display:block;object-fit:contain}

.tcvp-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.35);transition:opacity .2s}
.tcvp-wrapper.tcvp-playing .tcvp-overlay{opacity:0;pointer-events:none}

.tcvp-big-play{width:68px;height:68px;border-radius:50%;background:var(--primary);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 24px rgba(124,58,237,.6);transition:transform .15s,box-shadow .15s}
.tcvp-big-play:hover{transform:scale(1.1);box-shadow:0 6px 32px rgba(124,58,237,.8)}
.tcvp-big-play svg{width:32px;height:32px;margin-left:4px}

.tcvp-duration-badge{position:absolute;bottom:10px;right:12px;background:rgba(0,0,0,.75);color:#fff;font-size:12px;font-weight:700;padding:2px 7px;border-radius:4px;letter-spacing:.3px;transition:opacity .2s}
.tcvp-wrapper.tcvp-playing .tcvp-duration-badge{opacity:0}

.tcvp-spinner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}
.tcvp-spinner-ring{width:40px;height:40px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--primary);border-radius:50%;animation:tcvp-spin .8s linear infinite}
@keyframes tcvp-spin{to{transform:rotate(360deg)}}

/* ── Controls ── */
.tcvp-controls{background:linear-gradient(180deg,#0d0b14,var(--bg));padding:0 14px 10px}

.tcvp-progress-wrap{position:relative;height:18px;display:flex;align-items:center;cursor:pointer;margin:0 -2px}
.tcvp-progress-bg{position:absolute;left:0;right:0;height:4px;background:rgba(255,255,255,.12);border-radius:2px;transition:height .15s}
.tcvp-progress-wrap:hover .tcvp-progress-bg{height:6px}
.tcvp-progress-buffer{position:absolute;left:0;top:0;height:100%;background:rgba(255,255,255,.2);border-radius:2px;width:0}
.tcvp-progress-fill{position:absolute;left:0;top:0;height:100%;background:var(--primary);border-radius:2px;width:0;transition:width .05s}
.tcvp-progress-thumb{position:absolute;width:14px;height:14px;background:var(--accent);border-radius:50%;top:50%;transform:translateY(-50%);margin-left:-7px;box-shadow:0 0 6px rgba(168,85,247,.8);left:0;opacity:0;transition:opacity .15s;pointer-events:none}
.tcvp-progress-wrap:hover .tcvp-progress-thumb{opacity:1}
.tcvp-progress-range{position:absolute;inset:0;width:100%;opacity:0;cursor:pointer;height:18px;margin:0}

.tcvp-controls-row{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-top:6px;height:var(--ctrl-h)}
.tcvp-controls-left,.tcvp-controls-right{display:flex;align-items:center;gap:2px}

/* Buttons */
.tcvp-btn{background:none;border:none;color:var(--tx);cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;line-height:1;gap:4px;font-size:13px;font-weight:600}
.tcvp-btn:hover{background:rgba(255,255,255,.08);color:#fff}
.tcvp-btn svg{width:20px;height:20px;display:block;flex-shrink:0}

/* Volume */
.tcvp-volume-wrap{display:flex;align-items:center;gap:4px}
.tcvp-volume-slider-wrap{position:relative;width:64px;height:4px;background:rgba(255,255,255,.15);border-radius:2px}
.tcvp-volume-fill{position:absolute;left:0;top:0;height:100%;background:var(--primary);border-radius:2px;width:100%;pointer-events:none}
.tcvp-volume-range{position:absolute;inset:0;width:100%;opacity:0;cursor:pointer;margin:0;height:18px;top:-7px}

.tcvp-time{font-size:12px;color:var(--td);white-space:nowrap;letter-spacing:.3px;padding:0 4px}

/* ── Like / Dislike group ── */
.tcvp-vote-group{display:flex;align-items:center;background:rgba(255,255,255,.06);border-radius:20px;overflow:hidden;border:1px solid var(--bd)}
.tcvp-vote-group .tcvp-btn{padding:6px 10px;border-radius:0;border:none}
.tcvp-vote-group .tcvp-btn svg{width:18px;height:18px}
.tcvp-vote-group .tcvp-btn:first-child{border-radius:20px 0 0 20px;padding-left:12px}
.tcvp-vote-group .tcvp-btn:last-child{border-radius:0 20px 20px 0;padding-right:12px}
.tcvp-vote-group .tcvp-btn:hover{background:rgba(255,255,255,.1)}

.tcvp-like-btn.active svg{fill:var(--accent);filter:drop-shadow(0 0 4px rgba(168,85,247,.6))}
.tcvp-like-btn.active{color:var(--accent)}
.tcvp-dislike-btn.active svg{fill:#f87171;filter:drop-shadow(0 0 4px rgba(248,113,113,.5))}
.tcvp-dislike-btn.active{color:#f87171}

/* Pulse animation on vote */
@keyframes tcvp-vote-pop{0%{transform:scale(1)}40%{transform:scale(1.3)}100%{transform:scale(1)}}
.tcvp-btn.vote-pop svg{animation:tcvp-vote-pop .3s ease}

.tcvp-vote-divider{width:1px;height:20px;background:rgba(255,255,255,.12);flex-shrink:0}

/* Speed */
.tcvp-speed-wrap{position:relative}
.tcvp-speed-btn{background:rgba(255,255,255,.08);border:none;color:var(--tx);cursor:pointer;padding:4px 8px;border-radius:6px;font-size:13px;font-weight:600;transition:background .15s}
.tcvp-speed-btn:hover{background:rgba(255,255,255,.15)}
.tcvp-speed-menu{position:absolute;bottom:calc(100% + 8px);right:0;background:var(--bg2);border:1px solid var(--bd);border-radius:8px;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.5);min-width:78px;z-index:100}
.tcvp-speed-menu button{display:block;width:100%;background:none;border:none;color:var(--td);padding:8px 14px;font-size:13px;cursor:pointer;text-align:center;transition:background .1s,color .1s}
.tcvp-speed-menu button:hover,.tcvp-speed-menu button.active{background:rgba(124,58,237,.25);color:var(--accent)}

.tcvp-quality-badge{font-size:11px;font-weight:700;letter-spacing:.5px;color:var(--accent);border:1px solid var(--accent);border-radius:4px;padding:2px 6px}

/* ── Like ratio bar ── */
.tcvp-ratio-bar-wrap{height:3px;background:rgba(255,255,255,.08);margin:8px 0 0;border-radius:0 0 4px 4px;overflow:hidden}
.tcvp-ratio-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:2px;transition:width .6s ease}

/* ── Meta row ── */
.tcvp-meta-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;padding:10px 14px 14px;border-top:1px solid var(--bd)}
.tcvp-meta-left,.tcvp-meta-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

.tcvp-tags{display:flex;gap:6px;flex-wrap:wrap}
.tcvp-tag{display:inline-block;background:rgba(124,58,237,.2);border:1px solid rgba(124,58,237,.4);color:var(--accent);font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;letter-spacing:.2px}

.tcvp-view-count{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--td)}

/* View count bump animation */
@keyframes tcvp-bump{0%{transform:scale(1)}50%{transform:scale(1.15);color:#fff}100%{transform:scale(1)}}
.tcvp-views-num.bumping{animation:tcvp-bump .4s ease}

/* Share */
.tcvp-share-wrap{position:relative}
.tcvp-share-toggle{display:flex;align-items:center;gap:5px;background:var(--sf);border:1px solid var(--bd);color:var(--tx);font-size:12px;font-weight:600;padding:5px 12px;border-radius:20px;cursor:pointer;transition:background .15s,border-color .15s}
.tcvp-share-toggle:hover{background:rgba(124,58,237,.2);border-color:var(--primary)}
.tcvp-share-menu{position:absolute;bottom:calc(100% + 8px);right:0;background:var(--bg2);border:1px solid var(--bd);border-radius:10px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.6);min-width:140px;z-index:200}
.tcvp-share-menu button,.tcvp-share-menu a{display:flex;align-items:center;gap:8px;width:100%;background:none;border:none;border-bottom:1px solid var(--bd);color:var(--td);padding:9px 14px;font-size:13px;text-decoration:none;cursor:pointer;transition:background .1s,color .1s}
.tcvp-share-menu button:last-child,.tcvp-share-menu a:last-child{border-bottom:none}
.tcvp-share-menu button:hover,.tcvp-share-menu a:hover{background:rgba(124,58,237,.2);color:#fff}

/* ── Fullscreen ── */
.tcvp-wrapper:fullscreen,.tcvp-wrapper:-webkit-full-screen{max-width:100vw;border-radius:0}
.tcvp-wrapper:fullscreen .tcvp-stage,.tcvp-wrapper:-webkit-full-screen .tcvp-stage{aspect-ratio:auto;height:calc(100vh - 120px)}

/* ── Mobile ── */
@media(max-width:540px){
  .tcvp-volume-slider-wrap{display:none}
  .tcvp-time{font-size:11px}
  .tcvp-big-play{width:54px;height:54px}
  .tcvp-big-play svg{width:26px;height:26px}
  .tcvp-vote-group .tcvp-btn span{display:none}
}
