* { box-sizing: border-box; }
body { margin:0; font-family: 'Segoe UI', Arial, sans-serif; background:#0f1729; color:#e6eaf2; }

.brand {
  display:flex;
  align-items:center;
  gap:14px;
}

.brand-vertical {
  flex-direction:column;
  gap:10px;
}

.brand-logo {
  display:block;
  width:100%;
  height:auto;
}

.brand-logo-lg {
  width:min(260px, 72vw);
}

.brand-logo-sm {
  width:154px;
}

.brand-section {
  color:#cbd5e1;
  font-size:18px;
  font-weight:700;
  letter-spacing:.03em;
}

/* ===== Login ===== */
.login-body {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  background: radial-gradient(circle at top, #1e3a8a, #0f1729 70%);
}
.login-box {
  background:#1a2340; padding:40px 36px; border-radius:14px; width:340px;
  box-shadow:0 12px 40px rgba(0,0,0,.5); text-align:center;
}
.logo { font-size:42px; font-weight:bold; letter-spacing:2px; }
.logo span { color:#3b82f6; }
.subtitle { color:#94a3b8; margin:0 0 24px; }
.login-box input {
  width:100%; padding:12px 14px; margin:6px 0; border-radius:8px; border:1px solid #334155;
  background:#0f1729; color:#fff; font-size:15px;
}
.login-box button {
  width:100%; margin-top:12px; padding:12px; background:#3b82f6; color:#fff;
  border:none; border-radius:8px; font-size:16px; font-weight:bold; cursor:pointer;
}
.login-box button:hover { background:#2563eb; }
.hint { margin-top:18px; font-size:12px; color:#64748b; }

.msg { margin-top:10px; min-height:18px; font-size:14px; color:#f87171; }
.msg.ok { color:#4ade80; }
.msg.error { color:#f87171; }

/* ===== Admin ===== */
.admin-body { background:#0f1729; }
.topbar {
  background:#1a2340; padding:14px 24px; display:flex; justify-content:space-between; align-items:center;
  border-bottom:1px solid #1e293b;
  gap:16px;
}
.logo-small { font-size:22px; font-weight:bold; }
.logo-small span { color:#3b82f6; }

.container { max-width:1100px; margin:24px auto; padding:0 16px; }
.card { background:#1a2340; padding:22px; border-radius:12px; margin-bottom:20px; }
.card h2 { margin-top:0; font-size:18px; color:#cbd5e1; }

.row { display:flex; gap:10px; flex-wrap:wrap; align-items:flex-end; }
.row input, .row button, .row select, .row textarea { padding:10px 14px; border-radius:8px; border:1px solid #334155;
  background:#0f1729; color:#fff; font-size:14px; }
.row label { display:flex; flex-direction:column; font-size:12px; color:#94a3b8; gap:4px; }
.row label input, .row label select { margin-top:0; }
.row input[type=text], .row input[type=password] { flex:1; min-width:160px; }
.row button { background:#3b82f6; border:none; cursor:pointer; font-weight:bold; }
.row button:hover { background:#2563eb; }
.row textarea { flex:1 1 260px; min-height:92px; resize:vertical; }

.btn-ghost { background:transparent !important; color:#cbd5e1 !important; border:1px solid #334155 !important; cursor:pointer; padding:8px 14px; border-radius:8px; }
.btn-danger { background:#dc2626 !important; }

.stack { display:flex; flex-direction:column; gap:12px; }
.stack label { display:flex; flex-direction:column; gap:6px; color:#94a3b8; font-size:12px; }
.stack input, .stack select, .stack textarea {
  width:100%; padding:10px 12px; border-radius:8px; border:1px solid #334155;
  background:#0f1729; color:#fff; font-size:14px;
}
.stack textarea { min-height:110px; resize:vertical; }

.stats-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(170px, 1fr)); gap:12px; margin-top:12px; }
.stat-card { background:#0f1729; border:1px solid #1e293b; border-radius:12px; padding:16px; }
.stat-card strong { display:block; font-size:28px; color:#fff; }
.stat-card span { display:block; margin-top:6px; color:#94a3b8; font-size:12px; }

.badge { display:inline-block; padding:4px 8px; border-radius:999px; font-size:12px; font-weight:600; }
.badge.success { background:#14532d; color:#dcfce7; }
.badge.warn { background:#78350f; color:#fde68a; }
.badge.danger { background:#7f1d1d; color:#fecaca; }
.badge.info { background:#1e3a8a; color:#dbeafe; }

.actions-inline { display:flex; gap:6px; flex-wrap:wrap; }

.overlay {
  display:none; position:fixed; inset:0; background:rgba(0,0,0,.6);
  z-index:1000; align-items:center; justify-content:center; padding:16px;
}
.modal-card {
  background:#1a2340; color:#fff; padding:24px; border-radius:12px; width:100%;
  max-width:560px; box-shadow:0 10px 40px rgba(0,0,0,.5);
}

.media-schedule {
  display:flex; flex-direction:column; gap:6px; padding-top:6px; border-top:1px solid #1e293b;
}
.media-schedule-grid {
  display:grid; grid-template-columns:repeat(2, minmax(108px, 1fr)); gap:6px;
}
.weekday-row { display:flex; flex-wrap:wrap; gap:4px; }
.weekday-chip {
  display:inline-flex; align-items:center; gap:4px; padding:2px 7px;
  border:1px solid #334155; border-radius:999px; font-size:11px; line-height:1.1;
  color:#cbd5e1; background:#0f1729;
}
.weekday-chip input { margin:0; }
.media-status { font-size:11px; line-height:1.2; color:#94a3b8; }
.media-status.ok { color:#4ade80; }

.table-wrap { overflow:auto; }

@media (max-width: 768px) {
  .topbar {
    padding:12px 16px;
    flex-wrap:wrap;
  }
  .brand-logo-sm {
    width:128px;
  }
  .brand-section {
    font-size:15px;
  }
  .media-schedule-grid { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns:repeat(2, minmax(0, 1fr)); }
}

table { width:100%; border-collapse:collapse; margin-top:10px; }
th, td { padding:10px; text-align:left; border-bottom:1px solid #1e293b; font-size:14px; }
th { color:#94a3b8; font-weight:600; }
td button { margin-right:6px; padding:6px 12px; border-radius:6px; border:none; cursor:pointer;
  background:#3b82f6; color:#fff; font-size:12px; }

.media-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:18px; margin-top:14px; }
.media-item { background:#0f1729; border:1px solid #1e293b; border-radius:10px; overflow:hidden; display:flex; flex-direction:column; cursor:grab; transition:transform .15s, box-shadow .15s, opacity .15s; }
.media-item:active { cursor:grabbing; }
.media-item.dragging { opacity:.35; transform:scale(.97); }
.media-item.drag-over { box-shadow:0 0 0 2px #38bdf8; transform:translateY(-2px); }
.media-item img, .media-item video { width:100%; height:140px; object-fit:cover; background:#000; pointer-events:none; }
.media-item .meta { padding:14px; display:flex; flex-direction:column; gap:10px; font-size:12px; }
.media-primary-grid { display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:10px; align-items:end; }
.media-item .meta input[type=number],
.media-item .meta input[type=date],
.media-item .meta input[type=time],
.media-item .meta select {
  width:100%; min-width:0; padding:7px 8px; background:#1a2340; color:#fff; border:1px solid #334155; border-radius:6px;
}
.media-primary-grid > label,
.media-primary-grid > .media-note {
  display:flex; flex-direction:column; align-items:stretch; gap:6px; color:#94a3b8;
}
.media-primary-grid > .media-note strong {
  display:flex; align-items:center; min-height:37px; padding:7px 8px; background:#1a2340; color:#cbd5e1; border:1px solid #334155; border-radius:6px; font-size:12px; font-weight:600;
}
.media-item .meta > label,
.media-schedule-grid label {
  display:flex; flex-direction:column; align-items:stretch; gap:6px; color:#94a3b8;
}
.media-schedule-grid label {
  gap:3px;
  font-size:11px;
}
.media-schedule-grid input {
  padding:5px 7px;
}
.media-item .meta .check-label {
  flex-direction:row; align-items:center; gap:8px;
}
.media-item .meta .check-label input[type=checkbox] {
  width:auto; margin:0;
}
.media-item .meta button { margin-top:2px; padding:8px 10px; border-radius:8px; border:none; cursor:pointer; color:#fff; font-size:12px; align-self:flex-start; }
.media-schedule .actions-inline { gap:4px; }
.media-schedule .btn-ghost {
  margin-top:0;
  padding:6px 8px;
  font-size:11px;
}

@media (max-width: 1100px) {
  .media-grid { grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); }
}
