*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:        #0d0d0d;
  --bg2:       #151515;
  --bg3:       #1e1e1e;
  --border:    rgba(255,255,255,0.08);
  --border2:   rgba(255,255,255,0.14);
  --text:      #f0ede8;
  --text2:     #888;
  --text3:     #555;
  --accent:    #c0392b;
  --accent2:   #e74c3c;
  --accent-bg: rgba(192,57,43,0.12);
  --green:     #27ae60;
  --green-bg:  rgba(39,174,96,0.12);
  --amber:     #e67e22;
  --amber-bg:  rgba(230,126,34,0.12);
  --blue:      #2980b9;
  --blue-bg:   rgba(41,128,185,0.12);
  --radius:    6px;
  --radius-lg: 10px;
}

html { font-size: 15px; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Inter', system-ui, sans-serif;
  min-height: 100vh;
  line-height: 1.6;
}

a { color: var(--accent2); text-decoration: none; }
a:hover { text-decoration: underline; }

/* Nav */
.nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 24px; height: 52px;
  border-bottom: 1px solid var(--border);
  background: var(--bg); position: sticky; top: 0; z-index: 100;
}
.nav-logo {
  display: flex; align-items: center; gap: 10px;
  font-size: 15px; font-weight: 600; letter-spacing: -0.01em;
  color: var(--text); text-decoration: none;
}
.logo-icon {
  width: 28px; height: 28px; border-radius: 6px;
  background: var(--accent); display: flex; align-items: center;
  justify-content: center; font-size: 13px; color: #fff;
}
.nav-links { display: flex; align-items: center; gap: 4px; }
.nav-link {
  font-size: 13px; color: var(--text2); text-decoration: none;
  padding: 5px 10px; border-radius: var(--radius);
  transition: color 0.15s, background 0.15s;
}
.nav-link:hover { color: var(--text); background: var(--bg3); text-decoration: none; }
.nav-link.active { color: var(--text); }
.nav-btn {
  font-size: 13px; padding: 6px 14px; border-radius: var(--radius);
  border: 1px solid var(--border2); background: transparent;
  color: var(--text); cursor: pointer; transition: background 0.15s; text-decoration: none;
}
.nav-btn:hover { background: var(--bg3); text-decoration: none; }
.nav-btn.primary { background: var(--accent); border-color: var(--accent); color: #fff; }
.nav-btn.primary:hover { background: var(--accent2); }

/* Layout */
.container { max-width: 800px; margin: 0 auto; padding: 32px 20px; }
.container-wide { max-width: 1000px; margin: 0 auto; padding: 32px 20px; }
.page-header { margin-bottom: 28px; }
.page-header h1 { font-size: 22px; font-weight: 600; letter-spacing: -0.02em; }
.page-header p { font-size: 13px; color: var(--text2); margin-top: 4px; }

/* Cards */
.card {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 18px 20px; margin-bottom: 16px;
}
.card-title {
  font-size: 13px; font-weight: 600; color: var(--text2);
  text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 14px;
}

/* Forms */
.field { margin-bottom: 14px; }
.field label { display: block; font-size: 12px; color: var(--text2); margin-bottom: 5px; }
.field input, .field select, .field textarea {
  width: 100%; background: var(--bg3); border: 1px solid var(--border2);
  border-radius: var(--radius); padding: 8px 11px;
  font-size: 13px; color: var(--text); font-family: inherit;
  transition: border-color 0.15s;
}
.field input:focus, .field select:focus { outline: none; border-color: var(--accent); }
.field input::placeholder { color: var(--text3); }
.field .hint { font-size: 11px; color: var(--text3); margin-top: 4px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-radius: var(--radius);
  border: 1px solid var(--border2); background: transparent;
  color: var(--text); font-size: 13px; font-family: inherit;
  cursor: pointer; transition: background 0.15s, border-color 0.15s; text-decoration: none;
}
.btn:hover { background: var(--bg3); text-decoration: none; }
.btn-primary { background: var(--accent); border-color: var(--accent); color: #fff; }
.btn-primary:hover { background: var(--accent2); border-color: var(--accent2); }
.btn-green { background: var(--green); border-color: var(--green); color: #fff; }
.btn-green:hover { filter: brightness(1.1); }
.btn-amber { background: var(--amber); border-color: var(--amber); color: #fff; }
.btn-amber:hover { filter: brightness(1.1); }
.btn-sm { padding: 5px 10px; font-size: 12px; }
.btn-full { width: 100%; justify-content: center; }
.btn-danger { border-color: var(--accent); color: var(--accent2); }
.btn-danger:hover { background: var(--accent-bg); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* Badges */
.badge {
  display: inline-flex; align-items: center;
  font-size: 11px; padding: 2px 7px; border-radius: 20px; font-weight: 500;
}
.badge-movie    { background: var(--blue-bg);  color: #5dade2; }
.badge-series   { background: var(--green-bg); color: #58d68d; }
.badge-pending  { background: var(--amber-bg); color: var(--amber); }
.badge-approved { background: var(--green-bg); color: var(--green); }

/* Slots — TV guide */
.slot {
  display: grid; grid-template-columns: 70px 56px 1fr auto;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden;
  transition: border-color 0.15s; margin-bottom: 8px;
}
.slot:hover { border-color: var(--border2); }
.slot.skipped { opacity: 0.4; }
.slot.mismatch { opacity: 0.65; }
.slot-time {
  padding: 14px 12px; font-size: 13px; font-weight: 600; color: var(--text2);
  border-right: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  background: var(--bg3); font-variant-numeric: tabular-nums;
}
.slot-poster { width: 56px; height: 84px; object-fit: cover; display: block; border-right: 1px solid var(--border); }
.slot-poster-placeholder {
  width: 56px; height: 84px; background: var(--bg3);
  border-right: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center; color: var(--text3); font-size: 20px;
}
.slot-info { padding: 12px 14px; display: flex; flex-direction: column; justify-content: center; min-width: 0; }
.slot-title { font-size: 14px; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 3px; }
.slot-meta { font-size: 12px; color: var(--text2); margin-bottom: 6px; }
.slot-tags { display: flex; flex-wrap: wrap; gap: 4px; align-items: center; }
.genre-tag { font-size: 11px; padding: 2px 7px; border-radius: 20px; background: var(--bg3); color: var(--text3); border: 1px solid var(--border); }
.mismatch-reasons { font-size: 11px; color: var(--amber); margin-top: 5px; }
.slot-actions { padding: 12px 14px; display: flex; flex-direction: column; align-items: flex-end; justify-content: space-between; gap: 8px; flex-shrink: 0; }
.slot-rating { font-size: 12px; color: var(--text2); display: flex; align-items: center; gap: 3px; white-space: nowrap; }
.star { color: #e6b800; font-size: 11px; }

/* Toggle */
.toggle { position: relative; width: 34px; height: 18px; flex-shrink: 0; }
.toggle input { opacity: 0; width: 0; height: 0; position: absolute; }
.toggle-track { position: absolute; inset: 0; background: var(--bg3); border: 1px solid var(--border2); border-radius: 20px; cursor: pointer; transition: background 0.2s, border-color 0.2s; }
.toggle input:checked + .toggle-track { background: var(--accent); border-color: var(--accent); }
.toggle-thumb { position: absolute; top: 2px; left: 2px; width: 12px; height: 12px; background: var(--text2); border-radius: 50%; transition: transform 0.2s, background 0.2s; pointer-events: none; }
.toggle input:checked ~ .toggle-thumb { transform: translateX(16px); background: #fff; }

/* Countdown */
.countdown-banner {
  display: flex; align-items: center; gap: 10px;
  background: var(--accent-bg); border: 1px solid rgba(192,57,43,0.25);
  border-radius: var(--radius-lg); padding: 12px 16px; margin-bottom: 24px;
  font-size: 13px; color: var(--text);
}
.pulse { width: 8px; height: 8px; border-radius: 50%; background: var(--accent2); flex-shrink: 0; animation: pulse 1.5s infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.3} }

/* Chips */
.chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
.chip { font-size: 12px; padding: 5px 11px; border-radius: 20px; border: 1px solid var(--border2); color: var(--text2); cursor: pointer; transition: background 0.15s, color 0.15s, border-color 0.15s; user-select: none; }
.chip:hover { color: var(--text); }
.chip.active { background: var(--accent-bg); border-color: var(--accent); color: var(--accent2); }

/* Admin slots */
.admin-slot {
  display: grid; grid-template-columns: 70px 56px 1fr 110px 160px;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden; margin-bottom: 8px; align-items: center;
}
.admin-slot-time { padding: 12px; font-size: 13px; font-weight: 600; color: var(--text2); border-right: 1px solid var(--border); text-align: center; background: var(--bg3); align-self: stretch; display: flex; align-items: center; justify-content: center; }
.admin-slot-info { padding: 10px 14px; }
.admin-slot-info .title { font-size: 13px; font-weight: 600; }
.admin-slot-info .sub   { font-size: 11px; color: var(--text2); margin-top: 2px; }
.admin-slot-status { padding: 10px 8px; }
.admin-slot-actions { padding: 8px 10px; display: flex; gap: 5px; align-items: center; justify-content: flex-end; flex-wrap: wrap; }

/* Section label */
.section-label { font-size: 11px; font-weight: 600; color: var(--text3); text-transform: uppercase; letter-spacing: 0.07em; margin: 24px 0 10px; }

/* Alerts */
.alert { padding: 10px 14px; border-radius: var(--radius); font-size: 13px; margin-bottom: 14px; }
.alert-success { background: var(--green-bg); color: #58d68d; border: 1px solid rgba(39,174,96,0.2); }
.alert-error   { background: var(--accent-bg); color: var(--accent2); border: 1px solid rgba(192,57,43,0.2); }
.alert-info    { background: var(--blue-bg); color: #5dade2; border: 1px solid rgba(41,128,185,0.2); }
.alert-amber   { background: var(--amber-bg); color: var(--amber); border: 1px solid rgba(230,126,34,0.2); }

/* Auth */
.auth-wrap { max-width: 360px; margin: 60px auto; }
.auth-logo { text-align: center; margin-bottom: 28px; }
.auth-logo-icon { width: 48px; height: 48px; border-radius: 10px; background: var(--accent); display: inline-flex; align-items: center; justify-content: center; font-size: 22px; margin-bottom: 10px; }
.auth-logo h1 { font-size: 20px; font-weight: 700; letter-spacing: -0.02em; }
.auth-logo p  { font-size: 13px; color: var(--text2); margin-top: 3px; }
.auth-tabs { display: flex; border-bottom: 1px solid var(--border); margin-bottom: 20px; }
.auth-tab { flex: 1; text-align: center; padding: 10px; font-size: 13px; color: var(--text2); cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -1px; transition: color 0.15s; }
.auth-tab.active { color: var(--text); border-bottom-color: var(--accent); }

/* Profile tabs */
.profile-tabs { display: flex; border-bottom: 1px solid var(--border); margin-bottom: 24px; }
.profile-tab { padding: 10px 16px; font-size: 13px; color: var(--text2); cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -1px; transition: color 0.15s; }
.profile-tab.active { color: var(--text); border-bottom-color: var(--accent); }
.profile-panel { display: none; }
.profile-panel.active { display: block; }

/* Stats */
.stat-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 24px; }
.stat { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 14px 16px; }
.stat-label { font-size: 11px; color: var(--text3); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 4px; }
.stat-value { font-size: 22px; font-weight: 600; }

/* Empty */
.empty { text-align: center; padding: 48px 20px; color: var(--text3); font-size: 13px; }
.empty .empty-icon { font-size: 32px; margin-bottom: 10px; }

/* Search dropdown */
.search-result-item { padding: 8px 11px; font-size: 13px; cursor: pointer; border-bottom: 1px solid var(--border); color: var(--text); background: var(--bg2); }
.search-result-item:hover { background: var(--bg3); }
#search-results { border: 1px solid var(--border2); border-top: none; border-radius: 0 0 var(--radius) var(--radius); max-height: 220px; overflow-y: auto; position: absolute; width: 100%; z-index: 50; }

/* Connection test status */
.test-status { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; margin-top: 6px; padding: 5px 10px; border-radius: var(--radius); }
.test-status.ok      { background: var(--green-bg); color: #58d68d; }
.test-status.fail    { background: var(--accent-bg); color: var(--accent2); }
.test-status.testing { background: var(--bg3); color: var(--text2); }

/* Misc */
.debrid-note { font-size: 12px; color: var(--text3); margin-top: 6px; padding: 8px 10px; background: var(--bg3); border-radius: var(--radius); }
.delete-zone { border: 1px solid rgba(192,57,43,0.25); border-radius: var(--radius-lg); padding: 16px 18px; margin-top: 16px; }
.delete-zone h3 { font-size: 13px; font-weight: 600; color: var(--accent2); margin-bottom: 8px; }
.admin-badge { font-size: 10px; padding: 2px 6px; border-radius: 4px; background: var(--accent-bg); color: var(--accent2); border: 1px solid rgba(192,57,43,0.3); margin-left: 6px; vertical-align: middle; }
.toolbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; flex-wrap: wrap; gap: 10px; }
.toolbar-right { display: flex; gap: 8px; flex-wrap: wrap; }

@media (max-width: 600px) {
  .slot { grid-template-columns: 58px 48px 1fr auto; }
  .slot-poster, .slot-poster-placeholder { width: 48px; height: 72px; }
  .admin-slot { grid-template-columns: 58px 1fr 100px; }
  .admin-slot img { display: none; }
  .field-row { grid-template-columns: 1fr; }
  .nav-links { display: none; }
  .stat-row { grid-template-columns: repeat(2, 1fr); }
  .toolbar { flex-direction: column; align-items: flex-start; }
}
