:root {
  color: #2f3640;
  --admin-bg: #eef1f4;
  --admin-bg-soft: #f5f7f9;
  --admin-surface: #fafbfd;
  --admin-card: #ffffff;
  --admin-card-soft: #f3f5f7;
  --admin-border: #dde3e8;
  --admin-border-strong: #c8d0d8;
  --admin-text: #2f3640;
  --admin-muted: #7c8792;
  --admin-muted-strong: #58626e;
  --admin-accent: #66717d;
  --admin-accent-soft: #eef2f5;
  --admin-dark: #313944;
  --admin-warning: #f6f1df;
  --admin-warning-text: #8c6b1f;
  --admin-danger-soft: #f8ecef;
  --admin-danger-text: #b45468;
  --admin-success-soft: #edf5ef;
  --admin-success-text: #44735a;
  --admin-shadow: 0 24px 52px rgba(37, 44, 57, 0.08);
  font-family: "Geist", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;
}

html,
body,
#app {
  min-height: 100vh;
}

body {
  color: var(--admin-text);
  background:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.9), transparent 24%),
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.72), transparent 26%),
    linear-gradient(180deg, #f8fafb 0%, #f1f4f6 46%, #eceff3 100%) !important;
}

input::placeholder,
textarea::placeholder {
  color: #a0a9b2 !important;
}

.admin-stage,
.login-page {
  background: transparent !important;
}

.admin-shell,
.login-card {
  background: rgba(255, 255, 255, 0.96) !important;
  border: 1px solid var(--admin-border) !important;
  box-shadow: var(--admin-shadow) !important;
}

.admin-sidebar {
  background: rgba(250, 251, 252, 0.96) !important;
  border-right: 1px solid var(--admin-border) !important;
  color: var(--admin-text) !important;
}

.admin-main {
  background:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.58), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.64) 0%, rgba(245, 247, 249, 0.86) 100%) !important;
}

.mobile-overlay.visible {
  background: rgba(36, 43, 53, 0.36) !important;
}

.mobile-bar {
  border: 1px solid var(--admin-border) !important;
  background: rgba(255, 255, 255, 0.92) !important;
  box-shadow: 0 14px 34px rgba(37, 44, 57, 0.08) !important;
}

.sidebar-close,
.hamburger-button,
.header-pill,
.head-chip,
.meta-chip.soft,
.search-trigger,
.pagination-button,
.page-pill,
.theme-card,
.upload-block,
.user-card,
.search-popover {
  background: var(--admin-card-soft) !important;
  border-color: var(--admin-border) !important;
  color: var(--admin-muted-strong) !important;
}

.brand-title {
  display: flex;
  align-items: center;
  gap: 10px;
}

.brand-version {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid var(--admin-border);
  background: var(--admin-card-soft);
  color: var(--admin-accent);
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.nav-dot {
  background: #c8d0d8 !important;
}

.nav-item:hover,
.theme-btn:hover,
.sidebar-close:hover,
.hamburger-button:hover,
.search-trigger:hover,
.pagination-button:hover,
.page-pill:hover {
  background: #eef2f5 !important;
  color: var(--admin-text) !important;
}

.nav-item.active {
  background: var(--admin-accent-soft) !important;
  color: var(--admin-accent) !important;
  box-shadow: inset 0 0 0 1px var(--admin-border-strong) !important;
}

.nav-item.active .nav-dot {
  background: var(--admin-accent) !important;
}

.nav-item.active .nav-copy small {
  color: var(--admin-muted) !important;
}

.primary-button,
.submit-button,
.logout-button,
.summary-card.accent,
.meta-chip:not(.soft),
.thumb-badge.accent,
.image-badge.accent {
  background: var(--admin-dark) !important;
  color: #ffffff !important;
}

.secondary-button,
.compact-button {
  background: var(--admin-card-soft) !important;
  border: 1px solid var(--admin-border) !important;
  color: var(--admin-muted-strong) !important;
}

.state-card,
.summary-card,
.hero-card,
.panel-card,
.table-card,
.map-modal,
.image-modal,
.preview-card,
.theme-card,
.upload-block,
.search-popover {
  background: rgba(255, 255, 255, 0.94) !important;
  border: 1px solid var(--admin-border) !important;
  box-shadow: 0 18px 40px rgba(37, 44, 57, 0.08) !important;
}

.panel-soft,
.preview-card,
.theme-card,
.upload-block,
.asset-dropzone,
.asset-thumb-card.empty {
  background: #ffffff !important;
}

.bar-track,
.mini-bar-track {
  background: var(--admin-card-soft) !important;
}

.bar-fill {
  background: var(--area-accent, #7c8792) !important;
}

.bar-column {
  padding: 14px 12px 12px !important;
  border-radius: 24px !important;
  border: 1px solid var(--area-ring, rgba(102, 113, 125, 0.16)) !important;
  background: var(--area-surface, #f3f5f7) !important;
  box-shadow: none !important;
}

.bar-chart {
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
}

.insight-grid {
  grid-template-columns: 1fr !important;
}

.mini-bar-fill {
  background: var(--admin-accent) !important;
}

.table-row {
  margin: 10px 12px !important;
  padding: 18px 20px !important;
  border-radius: 22px !important;
  border: 1px solid var(--admin-border) !important;
  border-left: 1px solid var(--admin-border) !important;
  background: #ffffff !important;
  box-shadow: none !important;
}

.table-row + .table-row {
  border-top: none !important;
}

.table-row:hover {
  transform: none !important;
  border-color: var(--admin-border-strong) !important;
}

.table-row .merchant-cell strong {
  color: var(--admin-text) !important;
}

.table-row .merchant-cell small,
.table-row > span:not(.area-chip) {
  color: var(--admin-muted-strong) !important;
}

.area-chip {
  padding: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--admin-muted-strong) !important;
  border: 0 !important;
  box-shadow: none !important;
}

.merchant-avatar {
  background: var(--admin-dark) !important;
  color: #ffffff !important;
  box-shadow: none !important;
}

.table-card,
.table-head,
.table-scroll {
  background: #ffffff !important;
}

.dashboard-page .dashboard-header.hero-card {
  display: none !important;
}

.dashboard-page .overview-strip {
  display: block !important;
}

.dashboard-page .summary-grid {
  grid-template-columns: repeat(3, minmax(220px, 1fr)) !important;
  gap: 16px !important;
}

.dashboard-page .summary-card {
  min-height: 176px !important;
  padding: 24px 24px 22px !important;
  justify-content: space-between !important;
  gap: 14px !important;
  background: linear-gradient(180deg, #ffffff 0%, #f7f9fb 100%) !important;
  border: 1px solid var(--admin-border) !important;
  box-shadow: 0 18px 40px rgba(37, 44, 57, 0.06) !important;
}

.dashboard-page .summary-card span {
  color: var(--admin-muted) !important;
  font-size: 0.95rem !important;
}

.dashboard-page .summary-card strong {
  color: var(--admin-text) !important;
  font-size: clamp(2.3rem, 4vw, 3.2rem) !important;
  letter-spacing: -0.07em !important;
}

.dashboard-page .summary-card small {
  color: var(--admin-muted-strong) !important;
  line-height: 1.55 !important;
  font-size: 0.98rem !important;
}

.dashboard-page .summary-card.accent {
  background: linear-gradient(180deg, #ffffff 0%, #f3f6f9 100%) !important;
  border-color: var(--admin-border-strong) !important;
  color: var(--admin-text) !important;
}

.dashboard-page .summary-card.accent span,
.dashboard-page .summary-card.accent strong,
.dashboard-page .summary-card.accent small {
  color: var(--admin-text) !important;
}

.dashboard-page .insight-grid {
  gap: 16px !important;
}

.dashboard-page .panel-card {
  padding: 24px 26px !important;
}

.dashboard-page .panel-head {
  margin-bottom: 6px !important;
}

.dashboard-page .bar-chart {
  gap: 16px !important;
}

.login-card {
  border-radius: 34px !important;
}

.preview-board {
  background: #ffffff !important;
  border: 1px solid var(--admin-border) !important;
  box-shadow: none !important;
}

.kitty-showcase {
  position: relative;
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0;
  width: min(100%, 320px);
  min-height: 280px;
  padding: 20px 22px !important;
}

.kitty-showcase::before {
  content: "";
  position: absolute;
  inset: 14px 18px;
  border-radius: 26px;
  background: #ffffff;
  border: 1px solid var(--admin-border);
  box-shadow: none;
}

.kitty-showcase::after {
  content: "";
  position: relative;
  z-index: 1;
  width: min(100%, 228px);
  aspect-ratio: 3 / 2;
  background: url("/static/admin-party-flag.svg") center / contain no-repeat;
  filter: drop-shadow(0 12px 18px rgba(37, 44, 57, 0.08));
}

.kitty-showcase > * {
  position: relative;
  z-index: 1;
}

.kitty-image,
.kitty-spark,
.login-copy .lead,
.form-copy p,
.kitty-badge,
.kitty-caption {
  display: none !important;
}

.login-form,
.form-card,
.side-card {
  background: rgba(255, 255, 255, 0.98) !important;
  border: 1px solid var(--admin-border) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85) !important;
}

.login-form input,
.field input,
.field textarea,
.field select,
.search-input {
  background: var(--admin-card-soft) !important;
  border: 1px solid var(--admin-border) !important;
  color: var(--admin-text) !important;
}

.head-chip.soft,
.meta-chip.soft,
.gallery-empty,
.map-box,
.map-modal-stage,
.asset-thumb-card,
.thumb-card {
  background: var(--admin-card-soft) !important;
  border-color: var(--admin-border) !important;
  box-shadow: none !important;
}

.flag-cloth {
  background: var(--flag-accent, #7c8792) !important;
}

.flag-pole {
  background: var(--flag-accent-strong, #58626e) !important;
}

.flag-pin {
  background: var(--flag-surface, #c8d0d8) !important;
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.96) !important;
}

.asset-kicker {
  color: var(--admin-accent) !important;
}

.map-modal-backdrop,
.image-modal-backdrop {
  background: rgba(26, 32, 41, 0.55) !important;
}

.image-modal-stage {
  background: #10161d !important;
}

.danger-button {
  background: #f5e9ec !important;
  color: #8a4f5c !important;
}

.danger-button:hover {
  background: #eed8dd !important;
}

@media (max-width: 820px) {
  .dashboard-page .summary-grid {
    grid-template-columns: 1fr !important;
  }

  .preview-board {
    min-height: 220px !important;
  }

  .kitty-showcase {
    width: min(100%, 280px);
    padding: 16px 16px 12px !important;
  }

  .kitty-showcase::after {
    width: min(100%, 138px);
  }
}
