:root {
  --bg: #0f1115; --panel: #181b22; --panel2: #1f242d; --line: #2a313c;
  --text: #e7ebf0; --muted: #8b95a3; --accent: #25d1c4; --accent2: #6aa8ff;
  --good: #3ecf8e; --bad: #ff6b6b; --warn: #ffb454;
}
* { box-sizing: border-box; }
body {
  margin: 0; background: var(--bg); color: var(--text);
  font: 14px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}
header { padding: 16px 24px; border-bottom: 1px solid var(--line); background: var(--panel); }
h1 { font-size: 18px; margin: 0 0 12px; }
h2 { font-size: 16px; margin: 0 0 12px; }
h3 { font-size: 13px; margin: 0 0 10px; color: var(--muted); text-transform: uppercase; letter-spacing: .04em; }
.badge { font-size: 11px; background: var(--panel2); color: var(--accent); padding: 2px 8px; border-radius: 10px; margin-left: 8px; }
nav button {
  background: none; border: none; color: var(--muted); padding: 8px 14px; cursor: pointer;
  border-radius: 8px; font-size: 14px;
}
nav button.active { background: var(--panel2); color: var(--text); }
main { padding: 24px; max-width: 1240px; margin: 0 auto; }
.tab { display: none; } .tab.active { display: block; }
.row-between { display: flex; justify-content: space-between; align-items: center; }
.muted { color: var(--muted); }
.hidden { display: none !important; }

button, .btn {
  background: var(--panel2); color: var(--text); border: 1px solid var(--line);
  padding: 8px 14px; border-radius: 8px; cursor: pointer; font-size: 13px; text-decoration: none;
  display: inline-block;
}
button:hover, .btn:hover { border-color: var(--accent); }
button.primary, .btn.primary { background: var(--accent); color: #06302c; border-color: var(--accent); font-weight: 600; }
button.ghost { background: none; }
button.danger { color: var(--bad); }
button.small { padding: 4px 8px; font-size: 12px; }

.cards { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; margin: 16px 0; }
.card { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 14px; }
.card .n { font-size: 24px; font-weight: 700; }
.card .l { color: var(--muted); font-size: 12px; }

/* KPI grid (6 per row) */
.section-label { margin: 18px 0 8px; }
.kpis { display: grid; grid-template-columns: repeat(6, 1fr); gap: 10px; margin-bottom: 8px; }
.kpi { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 12px 14px; min-height: 74px; }
.kpi .l { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .03em; }
.kpi .n { font-size: 22px; font-weight: 700; margin-top: 2px; font-variant-numeric: tabular-nums; }
.kpi .sub { font-size: 12px; margin-top: 2px; }
.kpi .who { font-size: 13px; font-weight: 600; margin-top: 2px; }
.up { color: var(--good); } .down { color: var(--bad); } .flat { color: var(--muted); }
.kpi.good-edge { border-left: 3px solid var(--good); }
.kpi.bad-edge { border-left: 3px solid var(--bad); }
.delta-up::before { content: "▲ "; color: var(--good); }
.delta-down::before { content: "▼ "; color: var(--bad); }

/* alerts */
#alerts { display: flex; flex-wrap: wrap; gap: 10px; margin: 14px 0; }
.alert { border-radius: 10px; padding: 10px 14px; font-size: 13px; border: 1px solid var(--line); background: var(--panel); cursor: pointer; }
.alert b { font-size: 16px; margin-right: 4px; }
.alert.red { border-color: var(--bad); color: var(--bad); }
.alert.amber { border-color: var(--warn); color: var(--warn); }
.alert.green { border-color: var(--good); color: var(--good); }
.alert.muted { color: var(--muted); }
.alert.open { background: var(--panel2); }

/* subtabs */
.subtabs button { padding: 5px 10px; font-size: 12px; }
.subtabs button.active { background: var(--accent); color: #06302c; border-color: var(--accent); }

td.pos, .pos { color: var(--good); } td.neg, .neg { color: var(--bad); }

/* auth pages */
.auth-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 20px; }
.auth-card { background: var(--panel); border: 1px solid var(--line); border-radius: 16px; padding: 28px; width: 380px; max-width: 92vw; }
.auth-card h1 { font-size: 20px; margin: 0 0 6px; }
.auth-card label { display: block; margin: 14px 0 4px; }
.auth-card input { width: 100%; }
.auth-err { color: var(--bad); margin-top: 12px; }

/* header user area */
.user-area { display: flex; align-items: center; gap: 10px; }
.user-area .who { font-size: 13px; }
.user-area .role { font-size: 11px; padding: 2px 8px; border-radius: 10px; background: var(--panel2); color: var(--accent); text-transform: uppercase; }
.header-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.role-admin { color: var(--accent); } .role-manager { color: var(--accent2); } .role-viewer { color: var(--muted); }

/* viewer (read-only) hides write controls — server enforces this regardless */
body.readonly #addAccountBtn, body.readonly #addModelBtn, body.readonly #refreshAllBtn,
body.readonly #importBtn, body.readonly [data-edit], body.readonly [data-del],
body.readonly [data-check], body.readonly [data-save], body.readonly #inviteBtn,
body.readonly #tabs button[data-tab="entry"], body.readonly #csvFile, body.readonly #csvText,
body.readonly #syncPhonesBtn, body.readonly #phoneBulk #bulkAccount, body.readonly #bulkAssignBtn,
body.readonly #bulkInactiveBtn, body.readonly #bulkActiveBtn, body.readonly .psel, body.readonly #selAll { display: none !important; }
body.readonly #tab-entry::before { content: "Read-only access — ask an admin or manager to enter data."; color: var(--muted); }

.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.panel { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 16px; margin-bottom: 16px; }

table { width: 100%; border-collapse: collapse; font-size: 13px; }
th, td { text-align: left; padding: 8px 10px; border-bottom: 1px solid var(--line); white-space: nowrap; }
th { color: var(--muted); font-weight: 600; position: sticky; top: 0; background: var(--panel); }
tr:hover td { background: var(--panel2); }
.num { text-align: right; font-variant-numeric: tabular-nums; }
.scroll-x { overflow-x: auto; }

.filters { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin-bottom: 14px; }
input, select, textarea {
  background: var(--panel2); color: var(--text); border: 1px solid var(--line);
  border-radius: 8px; padding: 7px 9px; font-size: 13px; font-family: inherit;
}
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--accent); }
textarea { width: 100%; resize: vertical; }
label { color: var(--muted); font-size: 12px; }

.pill { padding: 2px 8px; border-radius: 10px; font-size: 11px; font-weight: 600; }
.s-active, .s-updated, .s-working { background: rgba(62,207,142,.15); color: var(--good); }
.s-warming, .s-checking, .s-queued, .s-rate_limited { background: rgba(255,180,84,.15); color: var(--warn); }
.s-banned, .s-failed, .s-not_found { background: rgba(255,107,107,.15); color: var(--bad); }
.s-paused, .s-private, .s-needs_manual, .s-archived { background: rgba(139,149,163,.18); color: var(--muted); }
.s-in_use { background: rgba(62,207,142,.15); color: var(--good); }
.s-out_of_use { background: rgba(255,107,107,.15); color: var(--bad); }     /* red */
.s-used_posting { background: rgba(62,207,142,.15); color: var(--good); }   /* green */
.s-blank { background: rgba(255,180,84,.15); color: var(--warn); }          /* orange */
.s-missing { background: rgba(255,180,84,.15); color: var(--warn); }
.s-retired { background: rgba(139,149,163,.18); color: var(--muted); }
.s-flagged { background: rgba(255,107,107,.18); color: var(--bad); }
.s-inactive { background: rgba(139,149,163,.18); color: var(--muted); }

/* big status circles in the Profiles table */
.dot { font-size: 14px; line-height: 1; }
.dot-in_use { color: var(--good); }
.dot-out_of_use { color: var(--bad); }       /* red */
.dot-used_posting { color: var(--good); }    /* green */
.dot-blank { color: var(--warn); }           /* orange */
.dot-missing { color: var(--warn); }
.dot-inactive { color: var(--muted); }
.dot-retired { color: var(--muted); }
.dot-flagged { color: var(--bad); }

/* clickable + selected top cards (filter shortcuts) */
.kpi.clickable { cursor: pointer; transition: box-shadow .12s, transform .12s; }
.kpi.clickable:hover { box-shadow: 0 0 0 1px var(--c); }
.kpi.selected { box-shadow: 0 0 0 2px var(--c); border-color: var(--c); }

/* stage tags (CRM ↔ GeeLark): blue / yellow / green / red / grey */
.stage { padding: 2px 9px; border-radius: 10px; font-size: 11px; font-weight: 600; white-space: nowrap; }
.stage-logged_in { background: rgba(106,168,255,.16); color: var(--accent2); }   /* blue */
.stage-posted { background: rgba(255,180,84,.16); color: var(--warn); }            /* yellow */
.stage-views { background: rgba(62,207,142,.16); color: var(--good); }             /* green */
.stage-unconnected { background: rgba(255,107,107,.16); color: var(--bad); }       /* red */
.stage-no_data { background: rgba(139,149,163,.18); color: var(--muted); }         /* grey */

/* top background-sync progress bar */
.sync-bar { position: fixed; top: 0; left: 0; right: 0; z-index: 60; height: 30px;
  background: var(--panel2); border-bottom: 1px solid var(--line);
  display: flex; align-items: center; padding: 0 16px; font-size: 12px; color: var(--text); }
.sync-bar-fill { position: absolute; left: 0; bottom: 0; height: 3px; width: 0%;
  background: var(--accent); transition: width .5s ease; }
.sync-bar-label .down { color: var(--bad); }
body.syncing { padding-top: 30px; }

/* TikTok username links — inherit colour (keeps model/account coding), never purple */
a.tiktok-link, a.tiktok-link:link, a.tiktok-link:visited, a.tiktok-link:active {
  color: inherit; text-decoration: none;
}
a.tiktok-link:hover { text-decoration: underline; cursor: pointer; }

/* per-row refresh spinner */
.spinner { display: inline-block; width: 12px; height: 12px; vertical-align: middle;
  border: 2px solid var(--line); border-top-color: var(--accent); border-radius: 50%;
  animation: spin .7s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* employee tracking */
.emp-card { border: 1px solid var(--line); border-radius: 10px; padding: 10px 12px; margin-bottom: 8px; background: var(--panel2); }
.emp-timeline table.emp-tl { width: 100%; margin-top: 6px; }
/* local-time timestamp with hover tooltip (UTC + local + zone) */
.ts { cursor: help; border-bottom: 1px dotted var(--line); white-space: nowrap; }
.emp-timeline td { padding: 3px 8px; border-bottom: 1px solid var(--line); font-size: 13px; }

.toast {
  position: fixed; top: 16px; right: 16px; z-index: 50; padding: 12px 16px; border-radius: 10px;
  background: var(--panel2); border: 1px solid var(--line); max-width: 380px;
}
.toast.ok { border-color: var(--good); } .toast.err { border-color: var(--bad); }

.modal-backdrop {
  position: fixed; inset: 0; background: rgba(0,0,0,.55); display: flex; align-items: center;
  justify-content: center; z-index: 40;
}
.modal { background: var(--panel); border: 1px solid var(--line); border-radius: 14px; padding: 20px; width: 460px; max-width: 92vw; max-height: 90vh; overflow: auto; }
.modal label { display: block; color: var(--text); margin: 10px 0 4px; }
.modal input, .modal select, .modal textarea { width: 100%; }
.modal .actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 18px; }
.result { background: var(--panel2); padding: 12px; border-radius: 8px; white-space: pre-wrap; }
.entry-input { width: 110px; }
@media (max-width: 1100px) { .kpis { grid-template-columns: repeat(3,1fr); } }
@media (max-width: 900px) { .cards { grid-template-columns: repeat(2,1fr); } .grid2 { grid-template-columns: 1fr; } .kpis { grid-template-columns: repeat(2,1fr); } }
