/* VoltCharge PC 门户 — 统一主题（蓝靛浅色） */
:root {
  --p-bg: #eef1f8;
  --p-bg-soft: #f7f9fd;
  --p-card: #ffffff;
  --p-border: #dfe5f0;
  --p-text: #1a2332;
  --p-muted: #647089;
  --p-accent: #5b6cff;
  --p-accent-hover: #4654e8;
  --p-accent-light: #eef0ff;
  --p-accent-dark: #3d4ed8;
  --p-accent-ring: rgba(91, 108, 255, 0.18);
  --p-warn: #e05252;
  --p-warn-bg: #fef2f2;
  --p-success: #1f9d66;
  --p-success-bg: #ecfdf5;
  --p-shadow: 0 1px 2px rgba(26, 35, 50, 0.04), 0 8px 24px rgba(26, 35, 50, 0.06);
  --p-radius: 0.75rem;
  --p-font: 'Geist', 'PingFang SC', 'Microsoft YaHei', system-ui, sans-serif;
  --p-display: 'Space Grotesk', 'PingFang SC', sans-serif;
}

.portal-page {
  min-height: 100vh;
  color: var(--p-text);
  font-family: var(--p-font);
  background:
    radial-gradient(ellipse 75% 55% at 0% -10%, rgba(91, 108, 255, 0.12), transparent 52%),
    radial-gradient(ellipse 55% 40% at 100% 0%, rgba(147, 164, 255, 0.1), transparent 48%),
    linear-gradient(180deg, var(--p-bg-soft) 0%, var(--p-bg) 100%);
}

.portal-page .text-white { color: var(--p-text) !important; }
.portal-page .text-primary { color: var(--p-accent) !important; }
.portal-page .text-on-surface-variant { color: var(--p-muted) !important; }
.portal-page .text-error { color: var(--p-warn) !important; }
.portal-page .text-glow-gold { text-shadow: none !important; }
.portal-page .neon-glow-gold { box-shadow: 0 4px 14px var(--p-accent-ring) !important; }

.portal-page .glass-card {
  background: var(--p-card);
  border: 1px solid var(--p-border);
  box-shadow: var(--p-shadow);
  backdrop-filter: none;
}

.portal-page .vc-input,
.portal-page input.vc-input,
.portal-page select.vc-input,
.portal-page textarea.vc-input {
  width: 100%;
  appearance: none;
  background: var(--p-bg-soft) !important;
  border: 1px solid var(--p-border) !important;
  color: var(--p-text) !important;
  padding: 0.625rem 0.875rem;
  border-radius: 0.5rem;
  outline: none;
  font-size: 0.9375rem;
  caret-color: var(--p-accent);
  transition: border-color 0.15s, box-shadow 0.15s;
}

.portal-page .vc-input::placeholder { color: #9aa3b5 !important; }

.portal-page .vc-input:focus {
  border-color: #a5b0ff !important;
  box-shadow: 0 0 0 3px var(--p-accent-ring) !important;
}

.portal-page .vc-input:-webkit-autofill {
  -webkit-text-fill-color: var(--p-text) !important;
  -webkit-box-shadow: 0 0 0 1000px var(--p-bg-soft) inset !important;
}

.portal-page select.vc-input option { background: #fff; color: var(--p-text); }

.portal-page .vc-checkbox {
  accent-color: var(--p-accent);
}

.portal-page .vc-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background: linear-gradient(135deg, var(--p-accent) 0%, var(--p-accent-dark) 100%);
  color: #fff !important;
  font-weight: 600;
  border: none;
  border-radius: 0.5rem;
  cursor: pointer;
  transition: filter 0.15s, transform 0.1s;
}

.portal-page .vc-btn-primary:hover { filter: brightness(1.05); }
.portal-page .vc-btn-primary:active { transform: scale(0.98); }
.portal-page .vc-btn-primary:disabled { opacity: 0.55; cursor: not-allowed; }

.portal-page .vc-btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background: #fff;
  color: var(--p-accent) !important;
  font-weight: 500;
  border: 1px solid #c8cff9;
  border-radius: 0.5rem;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}

.portal-page .vc-btn-outline:hover {
  background: var(--p-accent-light);
  border-color: #a5b0ff;
}

.portal-page .vc-status {
  display: inline-flex;
  align-items: center;
  padding: 0.15rem 0.55rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
  border: 1px solid transparent;
}

.portal-page .vc-status.ok { background: var(--p-success-bg); color: var(--p-success); border-color: #bbf7d0; }
.portal-page .vc-status.pending { background: #fffbeb; color: #d97706; border-color: #fde68a; }
.portal-page .vc-status.fail { background: var(--p-warn-bg); color: var(--p-warn); border-color: #fecaca; }
.portal-page .vc-status.neutral { background: #f1f5f9; color: var(--p-muted); border-color: var(--p-border); }

.portal-page .vc-table th {
  font-weight: 500;
  color: var(--p-muted);
  border-bottom: 1px solid var(--p-border);
}

.portal-page .vc-table td {
  border-bottom: 1px solid #eef1f7;
  color: var(--p-text);
}

.portal-page .vc-table tr:hover td { background: #f8faff; }

.portal-page .hidden { display: none !important; }

.portal-page .pulse-dot {
  background: var(--p-accent);
  animation: portal-pulse 2s infinite;
}

@keyframes portal-pulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 0 0 var(--p-accent-ring); }
  70% { opacity: 0.7; box-shadow: 0 0 0 6px transparent; }
}
