/* ---------- Theme tokens ---------- */
:root {
  --max: 1100px;
  --gap: 14px;

  --bg: #fafafa;
  --card-bg: #fff;
  --text: #141414;
  --muted: #666;
  --border: #eaeaea;
  --brand: #3b82f6; /* biru */
  --brand-weak: #dbeafe;

  --shadow: 0 6px 18px rgba(0,0,0,0.06);
}

@media (prefers-color-scheme: dark) {
  :root {
    --bg: #0b0b0c;
    --card-bg: #121214;
    --text: #f4f4f5;
    --muted: #a1a1aa;
    --border: #262626;
    --brand: #60a5fa;
    --brand-weak: #1e293b;
    --shadow: 0 8px 24px rgba(0,0,0,0.35);
  }
}

/* Dark mode override via data-theme attribute */
html[data-theme="light"] {
  --bg:#fafafa; --card-bg:#fff; --text:#141414; --muted:#666; --border:#eaeaea; --brand:#3b82f6; --brand-weak:#dbeafe; --shadow:0 6px 18px rgba(0,0,0,.06);
}
html[data-theme="dark"] {
  --bg:#0b0b0c; --card-bg:#121214; --text:#f4f4f5; --muted:#a1a1aa; --border:#262626; --brand:#60a5fa; --brand-weak:#1e293b; --shadow:0 8px 24px rgba(0,0,0,.35);
}

/* ---------- Base ---------- */
* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  margin: 0; color: var(--text); background: var(--bg);
}
a { color: inherit; text-decoration: none; }
hr { border: 0; height: 1px; background: var(--border); }

.container { max-width: var(--max); margin: 0 auto; padding: 12px var(--gap); }

/* ---------- Header / Top bar ---------- */
header.container {
  display: flex; gap: var(--gap); align-items: center; justify-content: space-between;
  border-bottom: 1px solid var(--border);
}
.brand {
  display: flex; align-items: center; gap: 10px; font-weight: 700; letter-spacing: .2px;
}
.brand-badge {
  display:inline-flex; align-items:center; justify-content:center;
  width:28px; height:28px; border-radius:8px; background:var(--brand-weak); color:var(--brand);
  font-weight:700;
}
.filters { display:flex; gap: var(--gap); align-items:center; flex-wrap: wrap; }
input[type="search"], select {
  padding: 8px 10px; border:1px solid var(--border); border-radius:8px;
  background: var(--card-bg); color: var(--text);
}
.theme-toggle {
  border: 1px solid var(--border); background: var(--card-bg); color: var(--text);
  border-radius: 8px; padding: 8px 10px; cursor: pointer;
}

/* ---------- Grid & Cards ---------- */
.grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: var(--gap); }
.card {
  display:block; border:1px solid var(--border); border-radius: 12px; overflow:hidden;
  background: var(--card-bg); box-shadow: var(--shadow); transition: transform .2s ease, box-shadow .2s ease, border-color .2s;
}
.card:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(0,0,0,0.12); border-color: transparent; }

.thumb { position:relative; width:100%; background: #111; }
.thumb .dummy { width: 100%; padding-top: 56.25%; }     /* 4:3 = 3/4 = 75% */
.thumb.vertical .dummy { padding-top: 56.25%; }          /* Shorts pun ikut 4:3 di grid */


.thumb img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; display: block;
}


/* Skeleton (loading) */
.skel { background: linear-gradient(90deg,#222 25%,#333 37%,#222 63%); background-size: 400% 100%;
  animation: shimmer 1.2s ease-in-out infinite; }
@keyframes shimmer { 0% { background-position: 100% 0; } 100% { background-position: -100% 0; } }

/* Meta */
.meta { padding: 12px; }
.muted { color: var(--muted); }

/* Badges */
.badges { display:flex; gap:8px; flex-wrap: wrap; margin-top:8px; }
.badge {
  border:1px solid var(--border); color: var(--muted); background: transparent;
  padding: 2px 8px; border-radius: 999px; font-size: 12px; line-height: 1.8;
}
.badge.brand { border-color: var(--brand); color: var(--brand); background: transparent; }

/* ---------- Player Page ---------- */
.backbar { border-bottom:1px solid var(--border); }
.player-wrap { background:#000; border-radius:12px; overflow:hidden; }
video, iframe { width:100%; background:#000; border:0; }
.player-meta { display:flex; align-items:center; justify-content:space-between; gap:10px; margin:8px 0 16px; }
.kpis { display:flex; gap:10px; color:var(--muted); }

/* ---------- Footer ---------- */
footer.container { color:var(--muted); }

/* ---------- Utility ---------- */
.row { display:flex; gap: var(--gap); flex-wrap: wrap; align-items: center; }
.pill { padding: 4px 10px; border-radius:999px; background:var(--brand-weak); color:var(--brand); font-weight:600; font-size:12px; }