/* Picrota Video Manager - Modern 2025 Styles (admin + frontend) */
:root{
  --bg:#071019; --panel:#0f1418; --muted:#9fb0bd; --accent1:#5ee7df; --accent2:#4facfe;
  --danger:#ff6b6b; --glass:rgba(255,255,255,0.02); --radius:12px; --shadow:0 12px 36px rgba(2,6,23,0.6);
  font-family: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial;
}

/* Admin wrapper */
.pvm-admin-wrap { background:linear-gradient(180deg,var(--bg),#041018); padding:22px; color:#e9f6ff; min-height:80vh; }

/* Header */
.pvm-header { display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:14px; flex-wrap:wrap; }
.pvm-title h1 { margin:0; font-size:22px; }
.pvm-sub { margin:4px 0 0 0; color:var(--muted); font-size:13px; }
.pvm-actions-top { display:flex; gap:10px; align-items:center; }
#pvm-search { padding:8px 10px; border-radius:8px; border:1px solid var(--glass); background:rgba(255,255,255,0.01); color:#dff6ff; outline:none; min-width:220px; }

/* Banner */
.pvm-banner { margin-bottom:12px; padding:12px; border-radius:10px; box-shadow:var(--shadow); }
.pvm-banner-warning { background:linear-gradient(90deg,#2b1a12,#2d2120); color:#ffdede; border-left:4px solid #ff9f9f; }

/* Panel layout */
.pvm-panel { display:flex; gap:18px; margin-bottom:18px; align-items:flex-start; flex-wrap:wrap; }
.pvm-panel-left { flex:1 1 520px; min-width:300px; }
.pvm-panel-right { width:360px; min-width:260px; }

/* Upload area */
.pvm-upload-area { display:block; border-radius:var(--radius); padding:16px; background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01)); border:1px solid var(--glass); cursor:pointer; box-shadow:var(--shadow); transition:transform .18s ease, box-shadow .18s ease; }
.pvm-upload-area:hover { transform:translateY(-6px); }
.pvm-upload-inner { display:flex; gap:14px; align-items:center; color:var(--muted); }
.pvm-upload-note { font-size:12px; color:var(--muted); margin-top:6px; }
.pvm-drag-over { outline: 3px dashed rgba(95,211,200,0.12); transform: scale(1.01); }

/* Progress grid */
.pvm-progress-grid { display:flex; flex-direction:column; gap:12px; margin-top:12px; max-height:280px; overflow:auto; }
.pvm-upload-item { display:flex; gap:12px; align-items:center; padding:10px; border-radius:10px; background:linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.007)); border:1px solid var(--glass); }
.pvm-upload-left { flex:1; }
.pvm-upload-name { font-weight:700; color:#e9fbff; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.pvm-upload-size { color:var(--muted); font-size:12px; margin-top:4px; }
.pvm-upload-bar { width:260px; height:10px; background:rgba(255,255,255,0.02); border-radius:999px; overflow:hidden; border:1px solid rgba(255,255,255,0.01); }
.pvm-upload-fill { height:100%; width:0%; background: linear-gradient(90deg, var(--accent1), var(--accent2)); transition: width 160ms linear; }
.pvm-upload-pct { min-width:44px; text-align:right; font-weight:700; color:var(--muted); }

/* Play order area */
.pvm-play-order { background: linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.007)); padding:12px; border-radius:10px; border:1px solid var(--glass); box-shadow:var(--shadow); min-height:120px; }
.pvm-playable { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.pvm-play-thumb { width:86px; height:60px; border-radius:8px; overflow:hidden; position:relative; border:1px solid rgba(255,255,255,0.02); }
.pvm-play-thumb video { width:100%; height:100%; object-fit:cover; display:block; }
.pvm-play-badge { position:absolute; right:6px; top:6px; background:rgba(0,0,0,0.45); color:#fff; padding:4px 6px; border-radius:6px; font-size:12px; cursor:grab; }

/* Uploaded video grid */
.pvm-video-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap:14px; margin-top:12px; }
.pvm-video-card { background:linear-gradient(180deg, rgba(255,255,255,0.015), rgba(255,255,255,0.01)); border-radius:12px; padding:12px; border:1px solid var(--glass); box-shadow:var(--shadow); display:flex; flex-direction:column; gap:10px; transition: transform .18s ease; }
.pvm-video-card:hover { transform: translateY(-6px); }
.pvm-card-media { height:120px; overflow:hidden; border-radius:8px; position:relative; background:#000; }
.pvm-card-video { width:100%; height:100%; object-fit:cover; display:block; }
.pvm-active-tag { position:absolute; left:8px; top:8px; background:linear-gradient(90deg,var(--accent1),var(--accent2)); color:#012; padding:6px 8px; border-radius:6px; font-weight:800; font-size:12px; }

/* card body */
.pvm-card-body { display:flex; flex-direction:column; gap:8px; }
.pvm-card-title { font-size:13px; font-weight:800; color:#e9fbff; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.pvm-card-meta { color:var(--muted); font-size:12px; }
.pvm-card-actions { display:flex; gap:8px; margin-top:auto; }
.pvm-btn { flex:1; padding:8px 10px; border-radius:8px; background:linear-gradient(180deg,#121617,#0a0b0c); border:1px solid rgba(255,255,255,0.03); color:#fff; font-weight:700; cursor:pointer; transition:transform .12s ease; }
.pvm-btn:hover { transform:translateY(-4px); box-shadow: 0 10px 30px rgba(3,10,20,0.6); }
.pvm-btn-danger { background:linear-gradient(180deg,#4b1313,#2b0b0b); border-color: rgba(255,80,80,0.12); }

/* small ui */
.pvm-small-btn { padding:8px 12px; border-radius:8px; background:linear-gradient(90deg,var(--accent1),var(--accent2)); color:#012; font-weight:800; border:none; cursor:pointer; }
.pvm-panel-title { margin:0 0 10px 0; color:#dff6ff; }

/* empty */
.pvm-empty { color:var(--muted); padding:12px; border-radius:8px; background:rgba(255,255,255,0.01); }

/* toast */
.pvm-toast { position:fixed; right:18px; bottom:-80px; background:#041018; color:#bfefff; padding:10px 14px; border-radius:8px; box-shadow:0 8px 24px rgba(0,0,0,0.6); opacity:0; transform:translateY(8px); transition:all 260ms ease; z-index:9999; }
.pvm-toast-show { opacity:1; bottom:18px; transform:translateY(0); }

/* Frontend hero styles */
.pvm-hero-video-container { position:relative; width:100%; height:65vh; min-height:320px; overflow:hidden; background:#000; }
.pvm-hero-video { position:absolute !important; top:50% !important; left:50% !important; transform:translate(-50%,-50%) !important; width:100% !important; height:100% !important; object-fit:cover !important; opacity:0; transition:opacity 780ms ease-in-out; z-index:1; }
.pvm-hero-video.show { opacity:1; z-index:2; }

/* responsive tweaks */
@media (max-width:1000px) {
  .pvm-video-grid { grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); }
  .pvm-hero-video-container { height:50vh; }
}
@media (max-width:560px) {
  .pvm-video-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
  .pvm-hero-video-container { height:40vh; min-height:200px; }
}