/* ════════════════════════════════════════════════════════════════════════════
   ADMIN.CSS - Admin Panel Styles
   RealSEOLife.com - Redirect Manager
   ════════════════════════════════════════════════════════════════════════════ */

/* ── Dark theme token override (admin pages only) ────────────────────────── */
/* The global :root uses cream/ink editorial tokens. Admin pages are dark,    */
/* so we remap all shared vars here. Everything in admin inherits these.      */
body.page--admin {
  --color-bg:             #111111;
  --color-surface:        #1a1a1a;
  --color-surface-2:      #222222;
  --color-border:         #2e2e2e;
  --color-border-subtle:  #242424;
  --color-text-primary:   #e4e0d8;
  --color-text-secondary: #b8b4ac;
  --color-text-muted:     #888480;
  --color-available:      #4ade80;
  --color-accent-blue:    #7ab8e8;
  --color-premium-gold:   #c9a84c;
  --color-gold-muted:     #9e7e35;
}

/* ── Admin Header ─────────────────────────────────────────────────────────── */
.admin-header {
  margin-bottom: var(--space-10);
}

.admin-header__eyebrow {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-accent-violet);
  margin-bottom: var(--space-2);
}

.admin-header__title {
  font-size: var(--text-4xl);
  font-weight: var(--weight-extrabold);
  color: var(--color-text-primary);
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-3);
}

.admin-header__desc {
  font-size: var(--text-base);
  color: var(--color-text-secondary);
  max-width: 600px;
}

/* ── Admin Panel (card container) ─────────────────────────────────────────── */
.admin-panel {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6) var(--space-6);
  margin-bottom: var(--space-8);
}

.admin-panel__heading {
  font-size: var(--text-lg);
  font-weight: var(--weight-bold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.admin-panel__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-5);
  margin-top: calc(var(--space-3) * -1);
}

.admin-empty {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  padding: var(--space-6) 0;
  text-align: center;
}

/* ── Badge (count pill) ───────────────────────────────────────────────────── */
.admin-badge {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  background: rgba(70, 167, 255, 0.15);
  color: var(--color-accent-blue);
  padding: 2px 8px;
  border-radius: 999px;
}

.admin-badge--red {
  background: rgba(220, 53, 69, 0.15);
  color: #E35D6A;
}

/* ── Chip (inline status) ─────────────────────────────────────────────────── */
.admin-chip {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  padding: 2px 8px;
  border-radius: var(--radius-md);
  display: inline-block;
}

.admin-chip--green {
  background: rgba(62, 207, 142, 0.12);
  color: var(--color-available);
}

.admin-chip--amber {
  background: rgba(214, 178, 94, 0.12);
  color: var(--color-premium-gold);
}

.admin-chip--red {
  background: rgba(220, 53, 69, 0.12);
  color: #E35D6A;
}

.admin-chip--muted {
  background: rgba(255, 255, 255, 0.05);
  color: var(--color-text-muted);
}

/* ── Add Redirect Form ────────────────────────────────────────────────────── */
.admin-form__row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: flex-end;
}

.admin-form__field {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.admin-form__field--wide {
  flex: 1 1 200px;
}

.admin-form__field--action {
  flex: 0 0 auto;
}

.admin-form__field label {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
}

.admin-form__field input,
.admin-form__field select {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text-primary);
  outline: none;
  transition: border-color 0.2s;
}

.admin-form__field input:focus,
.admin-form__field select:focus {
  border-color: var(--color-accent-blue);
  box-shadow: 0 0 0 2px rgba(70, 167, 255, 0.12);
}

/* ── Table ─────────────────────────────────────────────────────────────────── */
.admin-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.admin-table thead th {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-text-muted);
  text-align: left;
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--color-border);
}

.admin-table tbody td {
  padding: var(--space-3) var(--space-3);
  border-bottom: 1px solid var(--color-border-subtle);
  vertical-align: middle;
}

.admin-table tbody tr:hover {
  background: rgba(255, 255, 255, 0.02);
}

.admin-table__mono {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-primary);
  word-break: break-all;
}

.admin-table__url {
  max-width: 340px;
}

.admin-table__referrer {
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-table__muted {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}

.admin-table__actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  white-space: nowrap;
}

/* ── Inline form (for delete/dismiss buttons) ─────────────────────────────── */
.admin-inline-form {
  display: inline;
}

/* ── Delete / Dismiss buttons ─────────────────────────────────────────────── */
.admin-btn-delete,
.admin-btn-dismiss {
  background: none;
  border: 1px solid var(--color-border);
  color: var(--color-text-muted);
  width: 28px;
  height: 28px;
  font-size: var(--text-lg);
  line-height: 1;
  border-radius: var(--radius-md);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s;
}

.admin-btn-delete:hover {
  border-color: #DC3545;
  color: #E35D6A;
  background: rgba(220, 53, 69, 0.08);
}

.admin-btn-dismiss:hover {
  border-color: var(--color-premium-gold);
  color: var(--color-premium-gold);
  background: rgba(214, 178, 94, 0.08);
}

/* ── Extra small ghost button variant ─────────────────────────────────────── */
.btn--xs {
  font-size: var(--text-xs);
  padding: 2px 10px;
}

/* ── Danger button variant ────────────────────────────────────────────────── */
.btn--danger {
  background: #c0392b;
  color: #fff;
  border-color: #c0392b;
}
.btn--danger:hover {
  background: #a93226;
  border-color: #a93226;
}

/* ── 404 error bulk-action toolbar ───────────────────────────────────────── */
.admin-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.admin-toolbar__inline {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.admin-toolbar__label {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  white-space: nowrap;
}

.admin-toolbar__num-input {
  width: 4.5rem;
  padding: 4px 8px;
  font-size: var(--text-sm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-text-primary);
  text-align: center;
}

/* ── Responsive (legacy admin-header) ────────────────────────────────────── */
@media (max-width: 768px) {
  .admin-header__title {
    font-size: var(--text-3xl);
  }

  .admin-panel {
    padding: var(--space-4);
  }

  .admin-form__row {
    flex-direction: column;
  }

  .admin-form__field--wide {
    flex: 1 1 100%;
  }
}


/* ════════════════════════════════════════════════════════════════════════════
   ADMIN BACKEND - Navigation, Login, Dashboard, Layout
   ════════════════════════════════════════════════════════════════════════════ */


/* ── Admin layout shell ───────────────────────────────────────────────────── */
.admin-main {
  min-height: calc(100vh - 56px);
  background: var(--color-bg);
}

.admin-container {
  max-width: 1000px;
  margin: 0 auto;
  padding: var(--space-8) var(--space-6) var(--space-16);
}


/* ── Admin top navigation bar ─────────────────────────────────────────────── */
.admin-nav {
  background: #0a0a0a;
  border-bottom: 1px solid var(--color-border);
  position: sticky;
  top: 0;
  z-index: 200;
  height: 52px;
}

.admin-nav__inner {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 var(--space-6);
  display: flex;
  align-items: center;
  gap: var(--space-2);
  height: 52px;
}

.admin-nav__brand {
  display: flex;
  flex-direction: column;
  line-height: 1.15;
  text-decoration: none;
  margin-right: var(--space-4);
  flex-shrink: 0;
}

.admin-nav__brand-site {
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  color: var(--color-text-primary);
  letter-spacing: var(--tracking-tight);
}

.admin-nav__brand-label {
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--color-premium-gold);
}

.admin-nav__links {
  display: flex;
  align-items: stretch;
  gap: 0;
  flex: 1;
  height: 52px;
  overflow-x: auto;
  scrollbar-width: none;
}
.admin-nav__links::-webkit-scrollbar { display: none; }

.admin-nav__link {
  display: flex;
  align-items: center;
  padding: 0 var(--space-4);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  transition: color 0.15s, border-color 0.15s;
}

.admin-nav__link:hover { color: #ffffff; }

.admin-nav__link--active {
  color: var(--color-premium-gold);
  border-bottom-color: var(--color-premium-gold);
}

.admin-nav__actions {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  margin-left: auto;
  flex-shrink: 0;
}

.admin-nav__site-link,
.admin-nav__logout {
  font-size: var(--text-xs);
  font-family: 'DM Mono', monospace;
  letter-spacing: 0.5px;
  color: var(--color-text-muted);
  text-decoration: none;
  white-space: nowrap;
  transition: color 0.15s;
}

.admin-nav__site-link:hover,
.admin-nav__logout:hover { color: var(--color-text-primary); }

.admin-nav__logout:hover { color: #E35D6A; }

/* ── Push bar (below nav, all admin pages) ───────────────────────────────── */
.admin-push-bar {
  background: #0a0a0a;
  border-bottom: 1px solid var(--color-border);
  position: sticky;
  top: 52px;
  z-index: 190;
}

.admin-push-bar__inner {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 var(--space-6);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  height: 44px;
}

.admin-push-bar__form {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-left: auto;
}

.admin-push-bar__input {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text-primary);
  font-size: var(--text-xs);
  padding: 4px 10px;
  width: 220px;
  outline: none;
  transition: border-color 0.15s;
}

.admin-push-bar__input::placeholder { color: var(--color-text-muted); }
.admin-push-bar__input:focus { border-color: var(--color-border-subtle); }

.admin-push-bar__btn {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text-secondary);
  cursor: pointer;
  font-size: var(--text-xs);
  font-family: 'DM Mono', monospace;
  letter-spacing: 0.3px;
  padding: 4px 12px;
  white-space: nowrap;
  transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.admin-push-bar__btn:hover {
  background: var(--color-surface-2);
  border-color: var(--color-premium-gold);
  color: var(--color-premium-gold);
}

.admin-push-bar__badge {
  font-size: var(--text-xs);
  font-family: 'DM Mono', monospace;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  white-space: nowrap;
  flex-shrink: 0;
}

.admin-push-bar__badge--success {
  background: rgba(62, 207, 142, 0.12);
  color: var(--color-available);
}

.admin-push-bar__badge--muted {
  background: rgba(255, 255, 255, 0.04);
  color: var(--color-text-muted);
}

.admin-push-bar__badge--error {
  background: rgba(220, 53, 69, 0.1);
  color: #E35D6A;
}

.admin-push-bar__details {
  font-size: var(--text-xs);
  flex-shrink: 0;
}

.admin-push-bar__summary {
  color: var(--color-text-muted);
  cursor: pointer;
  font-family: 'DM Mono', monospace;
  font-size: var(--text-xs);
  letter-spacing: 0.3px;
  user-select: none;
}

.admin-push-bar__summary:hover { color: var(--color-text-primary); }

.admin-push-bar__output {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-top: none;
  color: var(--color-text-muted);
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  line-height: 1.6;
  max-height: 160px;
  overflow: auto;
  padding: var(--space-3) var(--space-6);
  white-space: pre-wrap;
  word-break: break-word;
  margin: 0;
}

@media (max-width: 700px) {
  .admin-push-bar__input { width: 140px; }
  .admin-push-bar__inner { gap: var(--space-2); }
}

@media (max-width: 480px) {
  .admin-push-bar__input { display: none; }
}


/* ── Admin page header ────────────────────────────────────────────────────── */
.admin-page-header {
  margin-bottom: var(--space-8);
}

.admin-page-title {
  font-size: var(--text-3xl);
  font-weight: var(--weight-extrabold);
  color: var(--color-text-primary);
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-2);
}

.admin-page-desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}


/* ── Dashboard stat cards ─────────────────────────────────────────────────── */
.admin-stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}

.admin-stat-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
  text-decoration: none;
  display: block;
  transition: border-color 0.15s, box-shadow 0.15s;
}

a.admin-stat-card:hover {
  border-color: rgba(201, 168, 76, 0.4);
  box-shadow: 0 2px 12px rgba(201, 168, 76, 0.08);
}

.admin-stat-card--alert {
  border-color: rgba(220, 53, 69, 0.25);
}

.admin-stat-card__label {
  font-family: 'DM Mono', monospace;
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-text-muted);
  margin-bottom: var(--space-2);
}

.admin-stat-card__num {
  font-size: var(--text-4xl);
  font-weight: var(--weight-extrabold);
  color: var(--color-text-primary);
  line-height: 1;
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-3);
}

.admin-stat-card__num--red { color: #E35D6A; }

.admin-stat-card__link {
  font-size: var(--text-xs);
  color: var(--color-accent-blue);
  display: block;
}


/* ── Panel footer link ────────────────────────────────────────────────────── */
.admin-panel__footer {
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
}

.admin-panel__footer-link {
  font-size: var(--text-sm);
  color: var(--color-accent-blue);
  text-decoration: none;
}

.admin-panel__footer-link:hover { text-decoration: underline; }


/* ── Quick action buttons ─────────────────────────────────────────────────── */
.admin-quick-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}

.admin-quick-btn {
  display: grid;
  grid-template-columns: 2rem 1fr;
  grid-template-rows: auto auto;
  column-gap: var(--space-3);
  align-items: center;
  padding: var(--space-4) var(--space-5);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  text-decoration: none;
  transition: border-color 0.15s;
}

.admin-quick-btn:hover { border-color: rgba(201, 168, 76, 0.4); }

.admin-quick-btn__icon {
  grid-row: 1 / 3;
  font-size: var(--text-xl);
  color: var(--color-premium-gold);
  display: flex;
  align-items: center;
  justify-content: center;
}

.admin-quick-btn__label {
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--color-text-primary);
}

.admin-quick-btn__desc {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}


/* ── Login page ───────────────────────────────────────────────────────────── */
.admin-login-wrap {
  flex: 1;
  min-height: calc(100vh - var(--header-height));
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(var(--space-8), 10vh, var(--space-16)) var(--space-6);
  background: var(--color-bg);
}

.admin-login-card {
  width: 100%;
  max-width: 400px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-8) var(--space-8);
}

.admin-login-brand {
  text-align: center;
  margin-bottom: var(--space-8);
}

.admin-login-brand__site {
  font-size: var(--text-lg);
  font-weight: var(--weight-extrabold);
  color: var(--color-text-primary);
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-1);
}

.admin-login-brand__label {
  font-family: 'DM Mono', monospace;
  font-size: var(--text-xs);
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--color-premium-gold);
}

.admin-login-error {
  background: rgba(220, 53, 69, 0.1);
  border: 1px solid rgba(220, 53, 69, 0.3);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  color: #E35D6A;
  margin-bottom: var(--space-5);
}

.admin-login-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.admin-login-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.admin-login-label {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-text-muted);
  display: block;
  margin-bottom: var(--space-2);
}

.admin-login-input {
  width: 100%;
  font-family: 'DM Mono', monospace;
  font-size: var(--text-sm);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text-primary);
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.admin-login-input:focus {
  border-color: var(--color-premium-gold);
  box-shadow: 0 0 0 2px rgba(201, 168, 76, 0.12);
}

.admin-login-btn {
  width: 100%;
  background: var(--color-premium-gold);
  color: #0d0d0d;
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  padding: var(--space-3) var(--space-5);
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: opacity 0.15s;
}

.admin-login-btn:hover { opacity: 0.88; }


/* ── Column visibility helpers ────────────────────────────────────────────── */
@media (max-width: 480px) {
  .admin-hide-mobile { display: none; }
}

@media (max-width: 768px) {
  .admin-hide-tablet { display: none; }
}


/* ── Responsive layout ────────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .admin-stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .admin-container {
    padding: var(--space-5) var(--space-4) var(--space-10);
  }

  .admin-page-title {
    font-size: var(--text-2xl);
  }

  .admin-nav__inner {
    padding: 0 var(--space-4);
  }

  .admin-nav__brand-site {
    font-size: var(--text-xs);
  }

  .admin-quick-actions {
    grid-template-columns: 1fr;
  }

  .admin-panel {
    padding: var(--space-4);
  }

  .admin-form__row {
    flex-direction: column;
  }

  .admin-form__field--wide {
    flex: 1 1 100%;
  }

  .admin-editor-grid {
    grid-template-columns: 1fr;
  }
}

/* â”€â”€ Admin alerts and editor forms â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.admin-alert {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  margin-bottom: var(--space-5);
  font-size: var(--text-sm);
}

.admin-alert--success {
  background: rgba(62, 207, 142, 0.12);
  border-color: rgba(62, 207, 142, 0.28);
  color: var(--color-available);
}

.admin-alert--error {
  background: rgba(220, 53, 69, 0.1);
  border-color: rgba(220, 53, 69, 0.28);
  color: #E35D6A;
}

.admin-alert--info {
  background: rgba(70, 167, 255, 0.08);
  border-color: rgba(70, 167, 255, 0.22);
  color: #8fc8ff;
}

.admin-alert--muted {
  background: rgba(255, 255, 255, 0.04);
  border-color: var(--color-border);
  color: var(--color-text-muted);
}

/* ── Git push form ────────────────────────────────────────────────────────── */
.admin-push-form {
  margin-top: var(--space-4);
}

.admin-push-form__row {
  display: flex;
  gap: var(--space-3);
  align-items: center;
}

.admin-push-form__input {
  flex: 1;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text-primary);
  font-size: var(--text-sm);
  padding: var(--space-2) var(--space-3);
  outline: none;
  min-width: 0;
}

.admin-push-form__input:focus {
  border-color: var(--color-premium-gold);
}

/* ── Git output code block ────────────────────────────────────────────────── */
.admin-code-block {
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text-muted);
  font-family: var(--font-mono, monospace);
  font-size: var(--text-xs);
  line-height: 1.7;
  margin-bottom: var(--space-4);
  overflow-x: auto;
  padding: var(--space-3) var(--space-4);
  white-space: pre-wrap;
  word-break: break-word;
}

@media (max-width: 600px) {
  .admin-push-form__row {
    flex-direction: column;
    align-items: stretch;
  }
}

.admin-form-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.admin-form-field--full {
  grid-column: 1 / -1;
}

.admin-form-label {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-text-muted);
}

.admin-form-input,
.admin-form-textarea {
  width: 100%;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text-primary);
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.admin-form-textarea {
  min-height: 8rem;
  resize: vertical;
}

.admin-form-input:focus,
.admin-form-textarea:focus {
  border-color: var(--color-premium-gold);
  box-shadow: 0 0 0 2px rgba(201, 168, 76, 0.12);
}

.admin-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-2);
}

.admin-checkbox {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-text-primary);
  font-size: var(--text-sm);
}

.admin-checkbox input {
  accent-color: var(--color-premium-gold);
}

.admin-content-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}

.admin-content-filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.admin-filter-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--color-border);
  text-decoration: none;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  font-family: 'DM Mono', monospace;
  letter-spacing: 0.4px;
  transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.admin-filter-pill:hover {
  color: var(--color-text-primary);
  border-color: rgba(201, 168, 76, 0.4);
}

.admin-filter-pill--active {
  color: #0d0d0d;
  background: var(--color-premium-gold);
  border-color: var(--color-premium-gold);
}

.admin-content-toolbar__meta,
.admin-content-title {
  color: var(--color-text-primary);
}

.admin-editor-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.admin-editor-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
}

.admin-richtext {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.admin-richtext__modes {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  align-self: flex-start;
  padding: 3px;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.02);
}

.admin-richtext__mode-btn {
  border: 0;
  background: transparent;
  color: var(--color-text-muted);
  font-family: 'DM Mono', monospace;
  font-size: var(--text-xs);
  padding: 6px 12px;
  border-radius: 999px;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}

.admin-richtext__mode-btn.is-active {
  background: var(--color-premium-gold);
  color: #0d0d0d;
}

.admin-richtext__visual {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.admin-richtext__hint {
  margin: 0;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

.admin-richtext__editor {
  min-height: 18rem;
  padding: var(--space-4);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text-primary);
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: 1.7;
  outline: none;
  white-space: normal;
}

.admin-richtext__editor:focus {
  border-color: var(--color-premium-gold);
  box-shadow: 0 0 0 2px rgba(201, 168, 76, 0.12);
}

.admin-richtext__editor p {
  color: var(--color-text-primary);
  margin: 0 0 1em;
}

.admin-richtext__editor p:last-child {
  margin-bottom: 0;
}

.admin-richtext__html {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.admin-richtext__html-input {
  font-family: 'DM Mono', monospace;
  font-size: var(--text-sm);
}

.admin-richtext__source[hidden],
.admin-richtext__visual[hidden],
.admin-richtext__html[hidden] {
  display: none;
}

/* ── Content block sub-sections (article editor) ─────────────────────────── */
.admin-content-block {
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  margin-bottom: var(--space-4);
}

.admin-content-block__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-border-subtle);
}

.admin-content-block__label {
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
}

.admin-add-block {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border-subtle);
  margin-top: var(--space-2);
}

.admin-add-block__select {
  max-width: 12rem;
}

.admin-image-upload {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.admin-image-upload__preview {
  max-width: 24rem;
}

.admin-image-upload__img {
  display: block;
  max-width: 100%;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border-subtle);
}

.admin-image-upload__controls {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.admin-image-upload__status {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}

/* ── Tag Picker ───────────────────────────────────────────────────────────── */
.admin-tag-picker {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.admin-tag-picker__chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  min-height: 1.5rem;
}

.admin-tag-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 3px 10px 3px 12px;
  background: rgba(201, 168, 76, 0.1);
  border: 1px solid rgba(201, 168, 76, 0.3);
  border-radius: 999px;
  font-size: var(--text-xs);
  color: var(--color-premium-gold);
  white-space: nowrap;
}

.admin-tag-chip__remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  padding: 0;
  background: none;
  border: none;
  color: var(--color-premium-gold);
  opacity: 0.6;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  border-radius: 50%;
}

.admin-tag-chip__remove:hover {
  opacity: 1;
  background: rgba(201, 168, 76, 0.15);
}

.admin-tag-picker__input-row {
  display: flex;
  gap: var(--space-2);
}

.admin-tag-picker__input-row .admin-form-input {
  flex: 1;
}

@media (max-width: 480px) {
  .admin-stats-grid {
    grid-template-columns: 1fr 1fr;
  }

  .admin-stat-card__num {
    font-size: var(--text-3xl);
  }

  .admin-nav__actions .admin-nav__site-link {
    display: none;
  }

  .admin-login-card {
    padding: var(--space-6) var(--space-5);
  }

  .admin-login-wrap {
    padding: var(--space-6) var(--space-4);
  }
}
