/* css/admin.css — extends style.css for the dashboard */

body.admin { background: var(--ink); }

.admin-header {
  border-bottom: 1px solid var(--panel-line);
  padding: 20px 0;
}
.admin-shell { padding: 40px 0 80px; }

.login-wrap {
  min-height: 80vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.login-card {
  width: 100%;
  max-width: 380px;
  border: none;
  padding: 40px;
  background: var(--ink);
}
.login-card input {
  background: var(--ink);
  border: 1px solid #1c1c1e;
}
.login-card input:focus {
  border-color: var(--accent);
}

.admin-tabs { display: flex; gap: 2px; margin-bottom: 34px; border-bottom: 1px solid var(--panel-line); }
.admin-tabs button {
  background: none; border: none; color: var(--bone-faint);
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 14px 18px; border-bottom: 2px solid transparent;
}
.admin-tabs button.active { color: var(--bone); border-color: var(--accent); }

.admin-panel { display: none; }
.admin-panel.active { display: block; }

.data-table { width: 100%; border-collapse: collapse; }
.data-table th {
  text-align: left; font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--bone-faint); padding: 10px 12px; border-bottom: 1px solid var(--panel-line);
}
.data-table td { padding: 14px 12px; border-bottom: 1px solid var(--panel-line); font-size: 14px; vertical-align: top; }
.data-table tr:hover td { background: var(--ink-raised); }

.pill {
  display: inline-block; font-family: var(--mono); font-size: 11px; text-transform: uppercase;
  padding: 4px 10px; border-radius: 20px; border: 1px solid var(--panel-line);
}
.pill.pending { color: #e0b84a; border-color: #e0b84a; }
.pill.confirmed { color: #7fbf6a; border-color: #7fbf6a; }
.pill.declined, .pill.rejected { color: var(--accent); border-color: var(--accent); }
.pill.cancelled { color: var(--bone-faint); }
.pill.completed { color: var(--bone-dim); }
.pill.approved { color: #7fbf6a; border-color: #7fbf6a; }

.row-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.row-actions button {
  background: none; border: 1px solid var(--panel-line); color: var(--bone);
  font-family: var(--mono); font-size: 11px; text-transform: uppercase; padding: 6px 10px;
}
.row-actions button.confirm { border-color: #7fbf6a; color: #7fbf6a; }
.row-actions button.decline { border-color: var(--accent); color: var(--accent); }

.panel-toolbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; flex-wrap: wrap; gap: 12px; }
.empty-state { padding: 40px; text-align: center; color: var(--bone-faint); font-family: var(--mono); font-size: 13px; }

.add-form { border: 1px dashed var(--panel-line); padding: 24px; margin-bottom: 30px; display: none; }
.add-form.open { display: block; }
.add-form .field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

.thumb { width: 56px; height: 56px; object-fit: cover; background: var(--ink-raised); }

/* ---------- admin calendar ---------- */
.cal-month-summary {
  font-family: var(--mono); font-size: 12px; color: var(--bone-faint); margin-top: 6px;
}
.admin-cal-weekdays {
  display: grid; grid-template-columns: repeat(7, 1fr);
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--bone-faint); text-align: center; margin-bottom: 8px;
}
.admin-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
.admin-cal-day {
  aspect-ratio: 1; border: 1px solid var(--panel-line); background: var(--ink);
  border-radius: 6px;
  padding: 10px; display: flex; flex-direction: column; justify-content: space-between;
  cursor: pointer; text-align: left; color: var(--bone); font-family: var(--body);
  transition: border-color 0.15s, transform 0.1s;
}
.admin-cal-day:hover { border-color: var(--accent); transform: translateY(-1px); }
.admin-cal-day.selected { border-color: var(--accent); background: var(--accent-soft); }
.admin-cal-day.is-today { border-color: var(--accent-blue); box-shadow: inset 0 0 0 1px var(--accent-blue); }
.admin-cal-day.blank { visibility: hidden; cursor: default; }
.admin-cal-day .cal-daynum { font-family: var(--mono); font-size: 13px; color: var(--bone-dim); }
.admin-cal-day.is-today .cal-daynum { color: var(--accent-blue); }
.admin-cal-day .cal-day-revenue { font-family: var(--mono); font-size: 11px; color: #7fbf6a; }
.admin-cal-day .cal-dots { display: flex; gap: 3px; flex-wrap: wrap; }
.admin-cal-day .cal-dot { width: 6px; height: 6px; border-radius: 50%; }
.admin-cal-day .cal-dot.pending { background: #e0b84a; }
.admin-cal-day .cal-dot.confirmed { background: #7fbf6a; }
.admin-cal-day .cal-dot.completed { background: var(--bone-faint); }
.admin-cal-day .cal-dot.declined, .admin-cal-day .cal-dot.cancelled { background: var(--accent); }
.cal-legend {
  display: flex; gap: 20px; flex-wrap: wrap; margin-top: 16px;
  font-family: var(--mono); font-size: 11px; color: var(--bone-faint);
}
.cal-legend span { display: flex; align-items: center; gap: 6px; }
.cal-legend .cal-dot { width: 7px; height: 7px; border-radius: 50%; display: inline-block; }
.cal-legend .cal-dot.pending { background: #e0b84a; }
.cal-legend .cal-dot.confirmed { background: #7fbf6a; }
.cal-legend .cal-dot.completed { background: var(--bone-faint); }
.cal-legend .cal-dot.declined { background: var(--accent); }

/* ---------- message center ---------- */
.message-center {
  display: grid;
  grid-template-columns: 280px 1fr;
  border: 1px solid var(--panel-line);
  height: 560px;
}
.conversation-list { border-right: 1px solid var(--panel-line); overflow-y: auto; }
.conversation-item {
  padding: 14px 16px; border-bottom: 1px solid var(--panel-line); cursor: pointer;
}
.conversation-item:hover, .conversation-item.active { background: var(--ink-raised); }
.conversation-item .conv-name { font-size: 14px; color: var(--bone); }
.conversation-item .conv-preview { font-size: 12px; color: var(--bone-faint); margin-top: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.conversation-item .conv-unread {
  display: inline-block; background: var(--accent); color: var(--bone); border-radius: 20px;
  font-family: var(--mono); font-size: 10px; padding: 1px 7px; margin-left: 6px;
}
.thread-view { display: flex; flex-direction: column; }
.thread-header { padding: 14px 18px; border-bottom: 1px solid var(--panel-line); font-family: var(--mono); font-size: 13px; text-transform: uppercase; letter-spacing: 0.05em; }
.thread-messages { flex: 1; overflow-y: auto; padding: 18px; display: flex; flex-direction: column; gap: 10px; }
.thread-bubble { max-width: 70%; padding: 10px 14px; border-radius: 4px; font-size: 14px; line-height: 1.5; }
.thread-bubble.outbound { align-self: flex-end; background: var(--accent-soft); border: 1px solid var(--accent); }
.thread-bubble.inbound { align-self: flex-start; background: var(--panel); border: 1px solid var(--panel-line); }
.thread-bubble .bubble-time { font-family: var(--mono); font-size: 10px; color: var(--bone-faint); margin-top: 4px; }
.thread-compose { display: flex; gap: 8px; padding: 14px; border-top: 1px solid var(--panel-line); }
.thread-compose input { flex: 1; }

@media (max-width: 800px) {
  .message-center { grid-template-columns: 1fr; height: auto; }
  .conversation-list { max-height: 240px; border-right: none; border-bottom: 1px solid var(--panel-line); }
  .thread-messages { max-height: 360px; }
}

/* ---------- responsive stat grids ---------- */
@media (max-width: 900px) {
  #alltime-grid { grid-template-columns: repeat(2, 1fr) !important; }
  #revenue-grid, #kpi-grid { grid-template-columns: repeat(2, 1fr) !important; }
}

/* ---------- trend badges (revenue tiles) ---------- */
.trend-badge {
  display: inline-block;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.03em;
  margin-top: 6px;
}
.trend-badge.up { color: #7fbf6a; }
.trend-badge.down { color: #e0725a; }
.trend-badge.new { color: var(--bone-faint); }
