/* =========================================
   1) THEME TOKENS
   ========================================= */
:root {
  color-scheme: dark light;

  /* Dark (default) */
  --bg: #000000;
  --card: #0f1012;
  --text: #eaeaea;
  --muted: #a3a3a3;
  --accent: #22c55e;       /* hijau aksen */
  --accent-2: #0ea5e9;     /* biru sekunder */
  --border: #1f1f1f;
  --badge-bg: #111111;
  --badge-fg: #e5e7eb;
  --nav: var(--card);

  --shadow-sm: 0 1px 2px rgba(0,0,0,.35);
  --shadow-card: 0 10px 28px rgba(0,0,0,.45);
  --shadow-card-hover: 0 14px 44px rgba(0,0,0,.55);
}

html[data-theme="light"] {
  --bg: #f6f8fb;
  --card: #ffffff;
  --text: #111827;
  --muted: #6b7280;
  --accent: #2563eb;
  --accent-2: #16a34a;
  --border: #e5e7eb;
  --badge-bg: #eef2ff;
  --badge-fg: #3730a3;

  /* Header gradient (light) */
  --nav: linear-gradient(39deg, rgb(224, 5, 5) 6%, rgba(219,198,171,1) 50%, rgb(0,119,0) 88%);
}

/* =========================================
   2) BASE & LAYOUT
   ========================================= */
* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: ui-sans-serif, system-ui, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  line-height: 1.5;
}
.container {
  max-width: 1440px;
  margin: 0 auto;
  padding: 8px;
}

/* =========================================
   3) NAVBAR
   ========================================= */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: var(--nav);
  border-bottom: 1px solid var(--border);
  backdrop-filter: saturate(1.2) blur(6px);
}
.nav-inner {
  display: flex; gap: 12px; align-items: center; justify-content: space-between;
}
.brand { display: flex; align-items: center; gap: 10px; font-weight: 700; }
.brand-link { color: var(--text); text-decoration: none; display: inline-flex; gap: 10px; align-items: center; }
.logo { height: 36px; width: auto; display: block; border-radius: 2px; }
@media (max-width: 480px){ .logo { height: 30px; } }

.menu { display: flex; gap: 3px; align-items: center; }
.menu a {
  padding: 3px; border-radius: 6px; text-decoration: none;
  color: var(--text); border: 1px solid transparent; transition: background .2s ease, border-color .2s ease;
}
.menu a.active, .menu a:hover { border-color: var(--border); background: linear-gradient(180deg, transparent, rgba(0,0,0,.04)); }
html[data-theme="dark"] .menu a:hover { background: linear-gradient(180deg, transparent, rgba(255,255,255,.04)); }

/* Theme toggle button */
.theme-toggle, #themeToggle {
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text);
  border-radius: 12px;
  padding: 8px 10px;
  cursor: pointer;
  transition: transform .12s ease, box-shadow .12s ease, background-color .12s ease, border-color .12s ease;
  outline: none; user-select: none;
}
.theme-toggle:hover, #themeToggle:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(0,0,0,.12);
  background: rgba(127,127,127,.08);
}
.theme-toggle:active, #themeToggle:active { transform: translateY(0); box-shadow: inset 0 2px 8px rgba(0,0,0,.16); }

/* =========================================
   4) GRID & CARDS
   ========================================= */
.grid { display: grid; gap: 20px; }
@media (min-width:1024px){ .grid { grid-template-columns: repeat(3,1fr); } }
@media (min-width:640px) and (max-width:1023.98px){ .grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width:639.98px){ .grid { grid-template-columns: 1fr; } }

.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-card-hover);
  border-color: rgba(37,99,235,.25);
}
.card-body { padding: 6px; }
.card-title { font-weight: 200; margin: 0 0 4px; }
.card-sub { color: var(--muted); font-size: .92rem; margin: 0; }

/* Badges */
.badge {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 4px 10px; border-radius: 999px;
  font-weight: 600; font-size: 11px; line-height: 1;
  background: var(--badge-bg); color: var(--badge-fg);
}
.badge.small { padding: .15rem .5rem; font-size: .8rem; white-space: nowrap; }

/* Status “live” optional effect (add class .live in PHP when st=1) */
.badge.status.live::after{
  content:''; margin-left:.5ch; width:.45rem; height:.45rem; border-radius:50%;
  display:inline-block; background:#22c55e; box-shadow:0 0 0 .25rem rgba(34,197,94,.15);
  animation: ping 1.2s infinite;
}
@keyframes ping{ 0%{transform:scale(.9);opacity:.9} 80%{transform:scale(1.6);opacity:0} 100%{opacity:0} }

/* Video container */
.video-wrap {
  background:#000; aspect-ratio:16/9; display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden; border-radius: 12px;
}
.video-wrap video, .video-wrap .plyr { width:100%; height:100%; }

/* =========================================
   5) FORMS, BUTTONS & TABLES
   ========================================= */
.form { display:grid; gap:12px; max-width:720px; }
.form-row { display:grid; gap:10px; }
.form-row.two { grid-template-columns: 1fr 1fr; }

input[type="text"], input[type="url"], input[type="number"], input[type="password"], select {
  width:100%; padding:10px 12px; border-radius:12px; border:1px solid var(--border);
  background:var(--card); color:var(--text);
}

.btn {
  background: var(--accent); color:#fff; border:none; padding:10px 14px; border-radius:12px; cursor:pointer; font-weight:600;
  transition: transform .12s ease, box-shadow .12s ease, background .2s ease;
}
.btn:hover { transform: translateY(-1px); box-shadow: 0 10px 22px rgba(0,0,0,.16); }
.btn:active { transform: translateY(0); box-shadow: none; }
.btn.secondary { background: var(--accent-2); color:#fff; }
.btn-outline {
  border:1px solid var(--border); background:transparent; color:var(--text);
  padding:10px 14px; border-radius:12px;
}
.btn-outline:hover {
  background: rgba(127,127,127,.08);
  border-color: rgba(127,127,127,.35);
}
.btn-warning { background:#f59e0b; color:#111827; }
.btn-danger { background:#ef4444; color:#fff; }

.table { width:100%; border-collapse:collapse; margin-top:16px; }
.table th, .table td { border-bottom:1px solid var(--border); padding:10px; text-align:center; }
.table td.actions { white-space:nowrap; gap:8px; align-items:center; }

/* =========================================
   6) FOOTER
   ========================================= */
.footer {
  opacity:.85; font-size:.9rem; border-top:1px solid var(--border);
  margin-top:24px; padding-top:16px;
}

/* =========================================
   7) MAP LAYOUT & LEAFLET
   ========================================= */
.map-shell { width:100%; height: calc(100vh - 170px); min-height:60vh; }
.leaflet-container {
  width:100%; height:100%;
  border:1px solid var(--border); border-radius:16px; overflow:hidden;
}
.leaflet-top.leaflet-right { z-index:700; }
@media (max-width:640px){ .map-shell { height: calc(100vh - 140px); } }

.map-layout { display:grid; grid-template-columns:2fr 1fr; gap:16px; min-height: calc(100vh - 160px); }
.map-pane { width:100%; height:100%; }
.side-pane {
  background:var(--card); border:1px solid var(--border); border-radius:16px;
  padding:12px; display:flex; flex-direction:column; gap:10px; min-height:240px;
}
.side-header { display:flex; align-items:center; justify-content:space-between; gap:8px; }
.side-header h3 { margin:0; }
.side-header button{
  border:1px solid var(--border); background:transparent; color:var(--text);
  border-radius:8px; padding:6px 10px; cursor:pointer;
}
.side-meta { color:var(--muted); font-size:.9rem; }
@media (max-width:900px){ .map-layout { grid-template-columns:1fr; } .side-pane { order:2; } }

/* =========================================
   8) FILTER TOOLBAR (Dusun)
   ========================================= */
.filter-bar { margin:1px 0 9px; display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.filter-label { font-weight:600; color:var(--text); font-size:15px; }
.filter-reset.btn-outline { font-size:13px; padding:6px 10px; border-radius:8px; }

.select-wrap { position:relative; display:inline-block; line-height:0; }
.select {
  appearance:none; padding:8px 36px 8px 12px; border:1px solid var(--border);
  border-radius:10px; background:var(--card); color:var(--text); box-shadow: var(--shadow-sm); line-height:1.4;
}
.select-arrow {
  position:absolute; right:10px; top:50%; transform:translateY(-50%);
  width:12px; height:8px; pointer-events:none; color:var(--muted);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='currentColor' d='M1.41 0L6 4.58 10.59 0 12 1.41 6 7.41 0 1.41z'/></svg>");
  background-repeat:no-repeat; background-size:100% 100%;
}
@media (max-width:420px){ .select{ padding:8px 32px 8px 10px; } .select-arrow{ right:8px; } }

/* =========================================
   9) LEAFLET POPUP (Camera)
   ========================================= */
.leaflet-popup-content-wrapper, .leaflet-popup-tip { background:transparent; box-shadow:none; border:none; }
.leaflet-popup-content { margin:0 !important; }
.cam-popup {
  background:var(--card); border:1px solid var(--border); border-radius:12px; overflow:hidden;
}
.cam-popup .cam-header{
  display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:8px;
  padding:10px 12px; margin:0; background:var(--card); color:var(--text); border-bottom:1px solid var(--border);
}
.cam-popup .cam-title{ font-weight:700; line-height:1.2; text-align:center; justify-self:center; color:var(--text); }
.cam-popup .cam-body{ background:var(--card); padding:0 12px 12px; }
.cam-popup .video-wrap{ margin:0; background:#000; aspect-ratio:16/9; display:block; border-radius:12px; }

/* Tooltip untuk marker title */
.cctv-tip { background: var(--card); color: var(--text); border: 1px solid var(--border); }

/* =========================================
   10) PLAYER (Spinner, Plyr, Auto-hide)
   ========================================= */
.video-loading {
  position:absolute; inset:0; display:none; align-items:center; justify-content:center;
  z-index:5; pointer-events:none; background: rgba(0,0,0,.25);
}
html[data-theme="light"] .video-loading { background: rgba(255,255,255,.35); }
.video-loading .spinner{
  width:40px; height:40px; border-radius:50%;
  border:3px solid rgba(255,255,255,.35); border-top-color: var(--accent, #3b82f6);
  animation: spin .8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
@media (max-width:480px){ .video-loading .spinner{ width:30px; height:30px; } }
.video-wrap.spinner-on > .video-loading { display:flex; }

/* Plyr */
.plyr__spinner { display:block; opacity:1; pointer-events:none; }
.plyr__spinner svg { width:3rem; height:3rem; }

/* Auto-hide controls ketika playing (disinkronkan via JS) */
.plyr__controls, .player-toolbar, .toolbar, .controls {
  transition: transform .24s ease, opacity .24s ease; will-change: transform, opacity;
}
.player-card.is-playing .plyr__controls,
.player-card.is-playing .player-toolbar,
.player-card.is-playing .toolbar,
.player-card.is-playing .controls,
.card.is-playing .plyr__controls,
.card.is-playing .player-toolbar,
.card.is-playing .toolbar,
.card.is-playing .controls { transform: translateY(110%); opacity:0; pointer-events:none; }
.player-card.is-playing.show-controls .plyr__controls,
.player-card.is-playing.show-controls .player-toolbar,
.player-card.is-playing.show-controls .toolbar,
.player-card.is-playing.show-controls .controls,
.card.is-playing.show-controls .plyr__controls,
.card.is-playing.show-controls .player-toolbar,
.card.is-playing.show-controls .toolbar,
.card.is-playing.show-controls .controls { transform: translateY(0); opacity:1; pointer-events:auto; }
@media (hover:hover) and (pointer:fine){
  .player-card.is-playing:hover .plyr__controls,
  .player-card.is-playing:hover .player-toolbar,
  .player-card.is-playing:hover .toolbar,
  .player-card.is-playing:hover .controls,
  .card.is-playing:hover .plyr__controls,
  .card.is-playing:hover .player-toolbar,
  .card.is-playing:hover .toolbar,
  .card.is-playing:hover .controls { transform: translateY(0); opacity:1; pointer-events:auto; }
}

/* =========================================
   11) MSE / IFRAME CARDS
   ========================================= */

/* Iframe card (opsional) */
.player-card--iframe .iframe-wrap{ position:relative; }
.player-card--iframe.spinner-on .iframe-wrap::after{
  content:''; position:absolute; inset:0; background:rgba(0,0,0,.35); z-index:2;
}

/* =========================================
   12) UTILITIES
   ========================================= */
section[id]{ scroll-margin-top: 80px; }

.actions-inline{ margin:8px 0; }
.inline-form{ display:inline-block; margin-left:8px; }
.order-input{
  width: 48px; padding:6px 8px; text-align:center; border-radius:8px;
  border:1px solid var(--border); background:var(--card); color:var(--text);
}

/* Skeleton loader (gunakan class="skeleton" pada thumb saat loading) */
.skeleton{
  position:relative;
  background: linear-gradient(90deg,#1b1d20 25%,#23262a 37%,#1b1d20 63%);
  background-size: 400% 100%;
  animation: shimmer 1.2s infinite;
  border-radius: 12px;
}
html[data-theme="light"] .skeleton{
  background: linear-gradient(90deg,#eee 25%,#f6f6f6 37%,#eee 63%);
}
@keyframes shimmer{ 0%{background-position:100% 0} 100%{background-position:-100% 0} }

/* Focus accessibility */
:where(a,button,input,select,.select,.btn):focus-visible{
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: 10px;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  * { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition: none !important; }
}
