﻿:root {
  --admin-bg: #f4f7fb;
  --admin-surface: #ffffff;
  --admin-surface-2: #f8fbff;
  --admin-border: #dbe4ee;
  --admin-text: #1f2a37;
  --admin-muted: #6b7a90;
  --admin-accent: #39c7be;
  --admin-accent-2: #22b5ac;
  --admin-danger: #ef4444;
  --admin-success: #16a34a;
  --admin-warning: #f59e0b;
  --admin-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
}

html[data-theme="dark"] {
  --admin-bg: #040c1d;
  --admin-surface: #0f1c2f;
  --admin-surface-2: #12243c;
  --admin-border: #243a57;
  --admin-text: #dce7f9;
  --admin-muted: #8ea4c4;
  --admin-accent: #48d0c7;
  --admin-accent-2: #2eb8af;
  --admin-danger: #ff6b6b;
  --admin-success: #34d399;
  --admin-warning: #fbbf24;
  --admin-shadow: 0 14px 34px rgba(0, 0, 0, 0.35);
}

.admin-main {
  min-height: calc(100vh - 120px);
  background: var(--admin-bg);
  color: var(--admin-text);
  padding: 18px;
}

.admin-container {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  gap: 18px;
}

.admin-header {
  background: linear-gradient(180deg, var(--admin-surface), var(--admin-surface-2));
  border: 1px solid var(--admin-border);
  border-radius: 18px;
  padding: 18px 20px;
  box-shadow: var(--admin-shadow);
}

.header-content h1 {
  margin: 0;
  font-size: clamp(1.4rem, 2.6vw, 2.05rem);
  font-weight: 800;
  color: var(--admin-text);
}

.header-subtitle {
  margin-top: 8px;
  color: var(--admin-muted);
  font-size: 0.98rem;
}

.admin-content,
.admin-card {
  background: var(--admin-surface);
  border: 1px solid var(--admin-border);
  border-radius: 16px;
  box-shadow: var(--admin-shadow);
}

.admin-content {
  padding: 16px;
}

.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 14px;
  color: var(--admin-text);
}

.section-header h2,
.section-header h3 {
  margin: 0;
  font-size: 1.15rem;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.section-header i {
  color: var(--admin-accent);
}

.admin-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.stat-card {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--admin-surface);
  border: 1px solid var(--admin-border);
  border-radius: 14px;
  padding: 12px;
  transition: transform .2s ease, border-color .2s ease;
}

.stat-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--admin-accent) 50%, var(--admin-border));
}

.stat-card i {
  color: var(--admin-accent);
  font-size: 1.1rem;
}

.stat-number {
  display: block;
  font-weight: 800;
  font-size: 1.2rem;
  color: var(--admin-text);
}

.stat-label {
  color: var(--admin-muted);
  font-size: .86rem;
}

.admin-toolbar,
.date-filter-form,
.filters,
.status-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.admin-quick-links .admin-toolbar {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 10px;
}

.date-filter-form label,
.filters label {
  display: grid;
  gap: 6px;
  font-size: .86rem;
  color: var(--admin-muted);
  font-weight: 600;
}

.admin-main input,
.admin-main select,
.admin-main textarea {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  border: 1px solid var(--admin-border);
  border-radius: 10px;
  background: var(--admin-surface-2);
  color: var(--admin-text);
  padding: 10px 12px;
  font: inherit;
}

.admin-main a {
  color: var(--admin-accent);
  text-decoration: none;
}

.admin-main a:hover {
  text-decoration: underline;
}

.admin-main input:focus,
.admin-main select:focus,
.admin-main textarea:focus {
  outline: none;
  border-color: var(--admin-accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--admin-accent) 20%, transparent);
}

.btn,
.btn-submit,
.btn-filter,
.btn-approve,
.btn-reject,
.btn-block,
.btn-primary,
.btn-secondary,
.btn-cancel {
  border: 1px solid var(--admin-border);
  border-radius: 10px;
  padding: 9px 14px;
  background: var(--admin-surface-2);
  color: var(--admin-text);
  cursor: pointer;
  font: inherit;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.btn-submit,
.btn-primary,
.btn-approve {
  background: linear-gradient(135deg, var(--admin-accent), var(--admin-accent-2));
  color: #07272a;
  border-color: transparent;
}

html[data-theme="dark"] .btn-submit,
html[data-theme="dark"] .btn-primary,
html[data-theme="dark"] .btn-approve {
  color: #05201f;
}

.btn-reject,
.btn-danger {
  background: color-mix(in srgb, var(--admin-danger) 16%, var(--admin-surface));
  border-color: color-mix(in srgb, var(--admin-danger) 45%, var(--admin-border));
  color: var(--admin-danger);
}

.btn-block,
.btn-secondary,
.btn-cancel {
  background: color-mix(in srgb, var(--admin-warning) 14%, var(--admin-surface));
  border-color: color-mix(in srgb, var(--admin-warning) 38%, var(--admin-border));
  color: color-mix(in srgb, var(--admin-warning) 65%, var(--admin-text));
}

.btn-filter.active-filter,
.btn.active {
  background: color-mix(in srgb, var(--admin-accent) 22%, var(--admin-surface));
  border-color: var(--admin-accent);
}

.action-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.search-box {
  position: relative;
  flex: 1 1 320px;
}

.search-box input {
  padding-left: 38px;
}

.search-box i {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--admin-muted);
}

.admin-table-wrap,
.user-table-container {
  background: var(--admin-surface);
  border: 1px solid var(--admin-border);
  border-radius: 14px;
  overflow: auto;
}

.admin-table,
.user-table,
.admin-main table {
  width: 100%;
  border-collapse: collapse;
  min-width: 720px;
}

.admin-main th,
.admin-main td {
  padding: 12px 10px;
  border-bottom: 1px solid var(--admin-border);
  text-align: left;
  vertical-align: middle;
  color: var(--admin-text);
}

.admin-main thead th {
  background: color-mix(in srgb, var(--admin-surface-2) 65%, var(--admin-surface));
  font-weight: 700;
  color: var(--admin-muted);
}

.status-approved,
.status-chip--approved { color: var(--admin-success); font-weight: 700; user-select: none; -webkit-user-select: none; }
.status-rejected,
.status-chip--rejected { color: var(--admin-danger); font-weight: 700; user-select: none; -webkit-user-select: none; }
.status-blocked,
.status-chip--blocked { color: var(--admin-warning); font-weight: 700; user-select: none; -webkit-user-select: none; }
.status-expired,
.status-chip--expired { color: var(--admin-muted); font-weight: 700; user-select: none; -webkit-user-select: none; }
.status-pending,
.status-chip--pending { color: var(--admin-warning); font-weight: 700; user-select: none; -webkit-user-select: none; }
.status-published,
.status-chip--published { color: var(--admin-accent); font-weight: 700; user-select: none; -webkit-user-select: none; }
.status-completed,
.status-chip--completed { color: var(--admin-success); font-weight: 700; user-select: none; -webkit-user-select: none; }

/* Products moderation table: keep status text plain without colored highlight */
.admin-products-status-text {
  color: var(--admin-text);
  background: transparent;
  border: 0;
  padding: 0;
  border-radius: 0;
  font-weight: 600;
  user-select: none;
  -webkit-user-select: none;
}

#toastContainer {
  position: fixed;
  right: 18px;
  top: 18px;
  z-index: 1200;
}

.toast {
  margin-top: 8px;
  padding: 10px 14px;
  border-radius: 10px;
  color: #fff;
  box-shadow: var(--admin-shadow);
}

.toast-success { background: #10b981; }
.toast-error { background: #ef4444; }
.toast-info { background: #0ea5e9; }
.toast-warning { background: #f59e0b; color: #1f2937; }

.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 1300;
}

.modal-content {
  width: min(560px, 92vw);
  background: var(--admin-surface);
  border: 1px solid var(--admin-border);
  border-radius: 14px;
  padding: 16px;
}

.reason-modal-overlay {
  backdrop-filter: blur(2px);
}

.reason-modal-card {
  width: min(680px, 94vw);
  max-height: min(88vh, 860px);
  overflow: auto;
}

.reason-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 6px;
}

.reason-modal-head h3 {
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 1.06rem;
}

.reason-modal-head h3 i {
  color: var(--admin-warning);
}

.reason-modal-close {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1px solid var(--admin-border);
  background: var(--admin-surface-2);
  color: var(--admin-muted);
  cursor: pointer;
}

.reason-modal-note {
  margin: 0 0 10px;
  color: var(--admin-muted);
  font-size: .92rem;
  line-height: 1.4;
}

.reason-modal-field {
  display: grid;
  gap: 6px;
  margin-bottom: 10px;
}

.reason-modal-field label {
  color: var(--admin-muted);
  font-size: .86rem;
  font-weight: 700;
}

.reason-modal-select {
  width: 100%;
}

.reason-modal-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 4px 0 10px;
}

.reason-chip {
  border: 1px solid color-mix(in srgb, var(--admin-accent) 40%, var(--admin-border));
  background: color-mix(in srgb, var(--admin-accent) 11%, var(--admin-surface));
  color: var(--admin-text);
  border-radius: 999px;
  padding: 6px 10px;
  font-size: .82rem;
  line-height: 1.2;
  cursor: pointer;
}

.reason-chip:hover {
  border-color: var(--admin-accent);
  transform: translateY(-1px);
}

.reason-modal-textarea {
  min-height: 130px;
  resize: vertical;
}

.reason-modal-foot {
  display: flex;
  justify-content: flex-end;
  margin: -2px 0 10px;
}

.reason-modal-counter {
  color: var(--admin-muted);
  font-size: .82rem;
}

.reason-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.staff-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.staff-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 12px;
}

.staff-grid .card {
  border: 1px solid var(--admin-border);
  border-radius: 12px;
  background: var(--admin-surface-2);
  padding: 12px;
  display: flex;
  gap: 10px;
  align-items: center;
}

.staff-grid .card.staff-card {
  cursor: pointer;
  transition: transform .2s ease, border-color .2s ease;
}

.staff-grid .card.staff-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--admin-accent) 45%, var(--admin-border));
}

.staff-grid .ava {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid var(--admin-border);
}

.staff-grid .name {
  font-weight: 700;
  color: var(--admin-text);
}

.staff-grid .roles {
  margin-top: 4px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.staff-grid .tag {
  border: 1px solid var(--admin-border);
  border-radius: 999px;
  padding: 3px 8px;
  font-size: 12px;
  color: var(--admin-text);
  background: var(--admin-surface);
}

.staff-grid .muted {
  color: var(--admin-muted);
  font-size: 13px;
}

.role-row {
  display: flex;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--admin-border);
  border-radius: 10px;
  padding: 10px;
  background: var(--admin-surface-2);
}

.role-row-key {
  color: var(--admin-muted);
  font-size: 12px;
}

.staff-stats-modal {
  width: min(900px, 94vw);
}

.staff-stats-toolbar {
  display: grid;
  grid-template-columns: minmax(220px, 1.4fr) repeat(2, minmax(150px, 0.8fr)) auto auto;
  gap: 10px;
  align-items: end;
  padding: 10px;
  border: 1px solid var(--admin-border);
  border-radius: 12px;
  background: linear-gradient(180deg, var(--admin-surface), var(--admin-surface-2));
}

.staff-stats-toolbar label {
  display: grid;
  gap: 6px;
  margin: 0;
  font-size: .84rem;
  color: var(--admin-muted);
  font-weight: 600;
}

.staff-stats-toolbar input {
  height: 42px;
  padding: 9px 12px;
  border-radius: 10px;
}

.staff-stats-toolbar .btn-submit,
.staff-stats-toolbar .btn {
  height: 42px;
  min-width: 108px;
  white-space: nowrap;
}

.staff-stats-toolbar .btn {
  background: color-mix(in srgb, var(--admin-accent) 8%, var(--admin-surface-2));
  border-color: color-mix(in srgb, var(--admin-accent) 24%, var(--admin-border));
}

.staff-stats-toolbar .btn:hover,
.staff-stats-toolbar .btn-submit:hover {
  transform: translateY(-1px);
}

.staff-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}

.staff-metric-card {
  border: 1px solid var(--admin-border);
  border-radius: 12px;
  padding: 10px;
  background: var(--admin-surface-2);
  color: var(--admin-text);
  text-align: left;
  cursor: pointer;
  transition: border-color .2s ease, transform .2s ease;
}

.staff-metric-card:hover {
  border-color: color-mix(in srgb, var(--admin-accent) 55%, var(--admin-border));
  transform: translateY(-1px);
}

.staff-metric-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
}

.staff-metric-title i {
  color: var(--admin-accent);
}

.staff-metric-values {
  margin-top: 8px;
  display: grid;
  gap: 2px;
}

.staff-metric-values span:first-child {
  font-size: 1.35rem;
  font-weight: 800;
}

.staff-metric-values span:last-child {
  color: var(--admin-muted);
  font-size: .9rem;
}

.staff-stats-logs {
  display: grid;
  gap: 8px;
  max-height: 340px;
  overflow: auto;
  padding-right: 2px;
}

.staff-log-item {
  border: 1px solid var(--admin-border);
  border-radius: 10px;
  background: var(--admin-surface-2);
  padding: 10px;
}

.staff-log-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font-size: .94rem;
}

.staff-log-head span {
  color: var(--admin-muted);
  font-size: .82rem;
  white-space: nowrap;
}

.staff-log-meta {
  margin-top: 6px;
  color: var(--admin-muted);
  font-size: .86rem;
}

.staff-log-target {
  margin-top: 8px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.staff-log-target img {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid var(--admin-border);
}

.staff-log-target a {
  color: var(--admin-text);
  text-decoration: none;
  font-weight: 600;
}

.staff-log-target a:hover {
  color: var(--admin-accent);
}

.staff-log-empty {
  color: var(--admin-muted);
  border: 1px dashed var(--admin-border);
  border-radius: 10px;
  padding: 10px;
}

@media (max-width: 920px) {
  .staff-stats-toolbar {
    grid-template-columns: 1fr 1fr;
  }

  .staff-stats-toolbar label:first-child {
    grid-column: 1 / -1;
  }

  .staff-stats-toolbar .btn-submit,
  .staff-stats-toolbar .btn {
    width: 100%;
  }
}

@media (max-width: 560px) {
  .staff-stats-toolbar {
    grid-template-columns: 1fr;
  }
}

.submission-list {
  display: grid;
  gap: 14px;
}

.submission-card {
  border: 1px solid var(--admin-border);
  border-radius: 16px;
  padding: 14px;
  background: var(--admin-surface-2);
  overflow: hidden;
}

.submission-empty-state {
  padding: 16px;
  color: var(--admin-muted);
}

.submission-header {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-bottom: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--admin-border);
}

.submission-avatar {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  object-fit: cover;
  border: 1px solid var(--admin-border);
}

.submission-user {
  display: grid;
  gap: 2px;
}

.submission-user span {
  font-size: 13px;
  color: var(--admin-muted);
}

.submission-badges {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.status-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 700;
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid var(--admin-border);
  background: color-mix(in srgb, var(--admin-surface) 70%, transparent);
}

.submission-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, .8fr);
  gap: 14px;
}

.submission-main {
  min-width: 0;
}

.submission-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.submission-box {
  border: 1px solid var(--admin-border);
  border-radius: 12px;
  background: var(--admin-surface);
  padding: 11px;
  margin-top: 10px;
}

.submission-box h4 {
  margin: 0 0 9px;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--admin-text);
}

.submission-box h4 i {
  color: var(--admin-accent);
}

.submission-box p {
  margin: 4px 0;
  color: var(--admin-text);
}

.submission-visibility-list {
  display: flex;
  gap: 7px;
  flex-wrap: wrap;
}

.submission-toggle {
  font-size: 12px;
  font-weight: 700;
  border-radius: 999px;
  padding: 5px 10px;
  border: 1px solid var(--admin-border);
}

.submission-toggle.on {
  color: var(--admin-success);
  background: color-mix(in srgb, var(--admin-success) 14%, var(--admin-surface));
  border-color: color-mix(in srgb, var(--admin-success) 45%, var(--admin-border));
}

.submission-toggle.off {
  color: var(--admin-danger);
  background: color-mix(in srgb, var(--admin-danger) 12%, var(--admin-surface));
  border-color: color-mix(in srgb, var(--admin-danger) 40%, var(--admin-border));
}

.submission-about {
  margin: 0;
  white-space: pre-wrap;
  color: var(--admin-text);
  background: color-mix(in srgb, var(--admin-surface-2) 65%, var(--admin-surface));
  border: 1px solid var(--admin-border);
  border-radius: 10px;
  padding: 10px;
  font: inherit;
  max-height: 180px;
  overflow: auto;
}

.submission-bg {
  width: 100%;
  max-height: 240px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid var(--admin-border);
}

.submission-bg--small {
  max-height: 160px;
}

.submission-empty {
  color: var(--admin-muted);
  border: 1px dashed var(--admin-border);
  border-radius: 10px;
  padding: 10px;
  text-align: center;
}

.submission-theme-swatches {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}

.swatch-row {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--admin-text);
}

.swatch-color {
  width: 18px;
  height: 18px;
  border-radius: 6px;
  border: 1px solid var(--admin-border);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.35);
  display: inline-block;
}

.submission-preview-pane {
  min-width: 0;
}

.submission-mini-preview {
  border: 1px solid var(--admin-border);
  border-radius: 12px;
  padding: 10px;
  background:
    radial-gradient(120% 160% at 100% 0%, color-mix(in srgb, var(--mini-accent) 20%, transparent) 0%, transparent 55%),
    color-mix(in srgb, var(--admin-surface-2) 72%, var(--admin-surface));
}

.submission-mini-preview .mini-header {
  font-size: 12px;
  font-weight: 700;
  color: var(--mini-accent);
  margin-bottom: 8px;
}

.submission-mini-preview .mini-card {
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--mini-accent) 35%, var(--admin-border));
  padding: 10px;
  background-color: color-mix(in srgb, var(--mini-panel) var(--mini-opacity), transparent);
  background-size: cover;
  background-position: center;
}

.submission-mini-preview .mini-title {
  color: var(--mini-text);
  font-weight: 800;
  font-size: 14px;
}

.submission-mini-preview .mini-subtitle {
  margin-top: 4px;
  color: color-mix(in srgb, var(--mini-text) 85%, var(--admin-muted));
  font-size: 12px;
}

.submission-mini-preview .mini-tabs {
  margin-top: 10px;
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.submission-mini-preview .mini-tabs span {
  font-size: 11px;
  font-weight: 700;
  border-radius: 999px;
  padding: 3px 8px;
  border: 1px solid transparent;
}

.submission-mini-preview .mini-tabs .tab-on {
  color: var(--mini-accent);
  background: color-mix(in srgb, var(--mini-accent) 18%, transparent);
  border-color: color-mix(in srgb, var(--mini-accent) 35%, transparent);
}

.submission-mini-preview .mini-tabs .tab-off {
  color: var(--admin-muted);
  background: color-mix(in srgb, var(--admin-muted) 14%, transparent);
  border-color: color-mix(in srgb, var(--admin-muted) 30%, transparent);
}

.submission-actions {
  display: flex;
  gap: 8px;
  margin-top: 12px;
}

.submission-actions--design {
  border-top: 1px solid var(--admin-border);
  margin-top: 14px;
  padding-top: 12px;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
}

.submission-reject-wrap {
  flex: 1 1 420px;
  display: grid;
  gap: 6px;
}

.submission-reject-wrap label {
  color: var(--admin-muted);
  font-size: 12px;
  font-weight: 700;
}

.reject-reason-input {
  min-height: 68px;
  resize: vertical;
}

.submission-actions-buttons {
  display: inline-flex;
  gap: 8px;
  flex-wrap: wrap;
}

@media (max-width: 900px) {
  .admin-main { padding: 12px; }
  .admin-content { padding: 12px; }
  .admin-table,
  .user-table,
  .admin-main table { min-width: 620px; }
  .submission-layout { grid-template-columns: 1fr; }
  .submission-grid { grid-template-columns: 1fr; }
  .submission-actions--design { align-items: stretch; }
  .submission-actions-buttons { width: 100%; }
  .submission-actions-buttons .btn-approve,
  .submission-actions-buttons .btn-reject { flex: 1 1 180px; }
}

@media (max-width: 640px) {
  .submission-header {
    flex-wrap: wrap;
  }
  .submission-badges {
    margin-left: 0;
    width: 100%;
  }
}
