/**
 * ZMGJ — UI Kit 套4「极光玻璃」Aurora Glass
 * 浅底 + 蓝金紫柔光 + 磨砂玻璃卡片 + 轻高光描边
 */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;0,9..40,800&family=Noto+Sans+SC:wght@400;500;600;700&display=swap');

:root {
  --z-font: 'DM Sans', 'Noto Sans SC', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --z-ink: #070b14;
  --z-ink-soft: #1a2235;
  --z-muted: #5c6b8a;
  --z-line: rgba(15, 23, 42, 0.08);
  --z-line-strong: rgba(15, 23, 42, 0.12);
  --z-glass-border: rgba(255, 255, 255, 0.72);
  --z-surface-solid: #ffffff;
  --z-gold: #c9a227;
  --z-gold-mid: #e8b224;
  --z-gold-bright: #f5d033;
  --z-up: #059669;
  --z-down: #dc2626;
  --z-radius-lg: 1.4rem;
  --z-radius-xl: 1.85rem;
  --z-shadow-1: 0 4px 28px rgba(79, 70, 229, 0.06), 0 2px 12px rgba(7, 11, 20, 0.04);
  --z-shadow-2: 0 22px 56px rgba(79, 70, 229, 0.1), 0 12px 32px rgba(7, 11, 20, 0.08);
  --z-shadow-gold: 0 8px 32px rgba(232, 178, 36, 0.28);
  --z-blur: 18px;
}

/* ——— App shell：极光底（高对比，防 Tailwind 覆盖） ——— */
html {
  /* layout-adapter.js 可覆盖 --z-fluid-root；未设置时用 clamp 随视口缩放根字号 */
  font-size: var(--z-fluid-root, clamp(14px, 2.6vmin + 11px, 17px));
  min-height: 100%;
  background-color: #dde4f8 !important;
  background-image:
    linear-gradient(165deg, #e8ecff 0%, #f3e8ff 38%, #fff4d6 72%, #e0f2fe 100%) !important;
  background-attachment: fixed !important;
}

body.zmgj-app {
  font-family: var(--z-font) !important;
  color: var(--z-ink);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  background-color: transparent !important;
  background-image:
    radial-gradient(ellipse 95% 85% at 12% -8%, rgba(251, 191, 36, 0.55), transparent 48%),
    radial-gradient(ellipse 80% 70% at 92% 8%, rgba(129, 140, 248, 0.42), transparent 46%),
    radial-gradient(ellipse 65% 55% at 50% 102%, rgba(34, 211, 238, 0.28), transparent 50%),
    radial-gradient(ellipse 55% 45% at 0% 55%, rgba(192, 132, 252, 0.32), transparent 42%) !important;
  background-attachment: fixed !important;
}

.zmgj-app .text-primary {
  color: var(--z-gold-mid) !important;
}

/* Tailwind CDN 未扩展 text-muted 时，全站次要文字用设计令牌 */
.zmgj-app .text-muted {
  color: var(--z-muted) !important;
}

/* ——— 顶栏：高透玻璃 ——— */
.zmgj-app nav.h-16.border-b,
.zmgj-app header.h-14.border-b {
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.78) 0%,
    rgba(255, 255, 255, 0.62) 100%
  ) !important;
  backdrop-filter: blur(var(--z-blur)) saturate(1.45);
  -webkit-backdrop-filter: blur(var(--z-blur)) saturate(1.45);
  border-color: var(--z-glass-border) !important;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.95),
    0 10px 40px rgba(99, 102, 241, 0.07);
}

.zmgj-app nav.h-16.border-b img,
.zmgj-app header img {
  box-shadow: 0 4px 16px rgba(99, 102, 241, 0.12), 0 2px 8px rgba(7, 11, 20, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.95);
}

.zmgj-app #site-name-desktop,
.zmgj-app #site-name-mobile {
  color: var(--z-ink) !important;
  letter-spacing: -0.03em;
  font-weight: 800 !important;
}

/* 导航胶囊 */
.zmgj-app .nav-link {
  color: var(--z-muted) !important;
  font-weight: 600;
  font-size: 13px;
  padding: 0.45rem 1rem;
  border-radius: 9999px;
  transition: color 0.2s, background 0.2s, box-shadow 0.2s, transform 0.15s;
}
.zmgj-app .nav-link:hover {
  color: var(--z-ink-soft) !important;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: var(--z-shadow-1);
}
.zmgj-app .nav-link.active {
  color: var(--z-ink) !important;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 250, 255, 0.9) 100%);
  box-shadow:
    0 2px 16px rgba(129, 140, 248, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 1);
  border: 1px solid rgba(199, 210, 254, 0.55);
}

.zmgj-app #top-guest-actions button.border-gray-300,
.zmgj-app #top-guest-actions-mobile button.border-gray-300 {
  background: rgba(255, 255, 255, 0.88) !important;
  border-color: var(--z-line-strong) !important;
  color: var(--z-ink-soft) !important;
  border-radius: 9999px !important;
  font-weight: 700 !important;
  transition: transform 0.15s, box-shadow 0.2s;
}
.zmgj-app #top-guest-actions button.border-gray-300:hover,
.zmgj-app #top-guest-actions-mobile button.border-gray-300:hover {
  box-shadow: var(--z-shadow-1);
  transform: translateY(-1px);
}

.zmgj-app #top-guest-actions button.bg-blue-600,
.zmgj-app #top-guest-actions-mobile button.bg-blue-600 {
  background: linear-gradient(135deg, #fde68a 0%, var(--z-gold-mid) 38%, var(--z-gold) 100%) !important;
  color: var(--z-ink) !important;
  border: none !important;
  border-radius: 9999px !important;
  font-weight: 800 !important;
  box-shadow: var(--z-shadow-gold);
  letter-spacing: 0.02em;
}
.zmgj-app #top-guest-actions button.bg-blue-600:hover,
.zmgj-app #top-guest-actions-mobile button.bg-blue-600:hover {
  filter: brightness(1.05);
  transform: translateY(-1px);
}

.zmgj-app #top-recharge-btn {
  border-radius: 9999px !important;
  font-weight: 800 !important;
  letter-spacing: 0.03em;
  box-shadow: var(--z-shadow-gold);
  border: 1px solid rgba(255, 255, 255, 0.45) !important;
}

/* 底部 Dock */
.zmgj-app nav.fixed.bottom-0.h-16 {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.82) 0%, rgba(248, 250, 255, 0.78) 100%) !important;
  backdrop-filter: blur(22px) saturate(1.5);
  -webkit-backdrop-filter: blur(22px) saturate(1.5);
  border-top: 1px solid var(--z-glass-border) !important;
  box-shadow: 0 -14px 48px rgba(99, 102, 241, 0.1);
  padding-bottom: env(safe-area-inset-bottom, 0);
}

.zmgj-app nav.fixed.bottom-0 .nav-btn {
  transition: color 0.2s, transform 0.15s;
}
.zmgj-app nav.fixed.bottom-0 .nav-btn.active {
  color: var(--z-gold-mid) !important;
}

/* 首页大卡片外光 */
.zmgj-app .home-hero-banner {
  border: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow:
    0 28px 80px rgba(4, 8, 18, 0.42),
    0 0 0 1px rgba(129, 140, 248, 0.15);
}

.zmgj-app #home-yuebao-card {
  box-shadow:
    0 28px 80px rgba(4, 8, 18, 0.38),
    0 0 0 1px rgba(34, 211, 238, 0.12);
}

.zmgj-app #page-home .rounded-2xl.border.border-slate-100 {
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.94) 0%, rgba(252, 253, 255, 0.88) 100%);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-color: var(--z-glass-border) !important;
  box-shadow: var(--z-shadow-1);
}

/* 全局卡片：玻璃 */
.zmgj-app .zmgj-card {
  background: linear-gradient(155deg, rgba(255, 255, 255, 0.94) 0%, rgba(255, 255, 255, 0.78) 100%);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid var(--z-glass-border);
  border-radius: var(--z-radius-lg);
  box-shadow: var(--z-shadow-1), inset 0 1px 0 rgba(255, 255, 255, 0.9);
  transition: box-shadow 0.25s ease, border-color 0.25s ease, transform 0.2s ease;
}
.zmgj-app .zmgj-card:hover {
  border-color: rgba(251, 191, 36, 0.45);
  box-shadow: var(--z-shadow-2), inset 0 1px 0 rgba(255, 255, 255, 1);
  transform: translateY(-2px);
}

/* 弹窗 */
.zmgj-app .modal-mask,
body .modal-mask {
  background: rgba(4, 8, 22, 0.52) !important;
  backdrop-filter: blur(10px) saturate(1.15);
  -webkit-backdrop-filter: blur(10px) saturate(1.15);
}

.zmgj-app .modal-mask > .bg-white,
.zmgj-app .modal-mask .bg-white.rounded-3xl,
.zmgj-app .modal-mask .bg-white.rounded-2xl {
  background: linear-gradient(168deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 250, 255, 0.94) 100%) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--z-glass-border);
  box-shadow: var(--z-shadow-2), 0 0 0 1px rgba(129, 140, 248, 0.06);
}

.zmgj-app .ticker-up {
  color: var(--z-up) !important;
}
.zmgj-app .ticker-down {
  color: var(--z-down) !important;
}

/* ——— 认证页：更强极光 ——— */
body.zmgj-auth-page {
  font-family: var(--z-font) !important;
  min-height: 100dvh;
  color: var(--z-ink);
  -webkit-font-smoothing: antialiased;
  background-color: transparent !important;
  background-image:
    radial-gradient(ellipse 100% 80% at 85% -15%, rgba(251, 191, 36, 0.5), transparent 50%),
    radial-gradient(ellipse 90% 70% at 0% 20%, rgba(129, 140, 248, 0.45), transparent 48%),
    radial-gradient(ellipse 60% 50% at 100% 85%, rgba(34, 211, 238, 0.3), transparent 45%),
    linear-gradient(165deg, #eef2ff 0%, #fdf4ff 45%, #fff7ed 100%) !important;
  background-attachment: fixed !important;
}

.zmgj-auth-card {
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.92) 0%, rgba(252, 253, 255, 0.82) 100%);
  backdrop-filter: blur(22px) saturate(1.35);
  -webkit-backdrop-filter: blur(22px) saturate(1.35);
  border: 1px solid var(--z-glass-border);
  border-radius: var(--z-radius-xl);
  box-shadow: var(--z-shadow-2), inset 0 1px 0 rgba(255, 255, 255, 0.95);
}

.zmgj-auth-page .zmgj-lang,
.zmgj-auth-page a[data-workspace-url] {
  border-radius: 9999px;
  padding: 0.3rem 0.65rem;
  font-size: 11px;
  font-weight: 600;
  border: 1px solid var(--z-line);
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(8px);
  color: var(--z-muted);
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.zmgj-auth-page a[data-workspace-url]:hover {
  color: var(--z-gold-mid);
  border-color: rgba(251, 191, 36, 0.5);
  background: rgba(255, 255, 255, 0.95);
}

.zmgj-input {
  transition: border-color 0.2s, box-shadow 0.2s;
  border-radius: 0.85rem !important;
  background: rgba(255, 255, 255, 0.85) !important;
}
.zmgj-input:focus {
  outline: none;
  border-color: rgba(129, 140, 248, 0.55) !important;
  box-shadow: 0 0 0 4px rgba(129, 140, 248, 0.12);
}

.zmgj-btn-gold {
  background: linear-gradient(135deg, #fef3c7 0%, var(--z-gold-mid) 35%, var(--z-gold) 100%);
  color: var(--z-ink);
  font-weight: 800;
  border: none;
  letter-spacing: 0.04em;
  transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s;
  box-shadow: var(--z-shadow-gold);
}
.zmgj-btn-gold:hover:not(:disabled) {
  transform: translateY(-2px);
  filter: brightness(1.03);
  box-shadow: 0 14px 36px rgba(232, 178, 36, 0.38);
}
.zmgj-btn-gold:disabled {
  opacity: 0.65;
  cursor: not-allowed;
}

.zmgj-btn-dark {
  background: linear-gradient(135deg, #334155 0%, #0f172a 100%);
  color: #fff;
  font-weight: 700;
  border-radius: 0.85rem;
  transition: opacity 0.2s, transform 0.2s, box-shadow 0.2s;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.25);
}
.zmgj-btn-dark:hover:not(:disabled) {
  opacity: 0.95;
  transform: translateY(-1px);
}

/* ——— 管理端：与主站同系极光底（html 铺底 + body 柔光层） ——— */
html:has(body.zmgj-admin) {
  min-height: 100%;
  background-color: #dde4f8 !important;
  background-image:
    linear-gradient(165deg, #e8ecff 0%, #f3e8ff 40%, #fff4d6 75%, #e0f2fe 100%) !important;
  background-attachment: fixed !important;
}

body.zmgj-admin {
  font-family: var(--z-font);
  background-color: transparent !important;
  background-image:
    radial-gradient(ellipse 90% 70% at 95% -5%, rgba(129, 140, 248, 0.22), transparent 45%),
    radial-gradient(ellipse 70% 60% at 0% 100%, rgba(251, 191, 36, 0.14), transparent 48%) !important;
  background-attachment: fixed !important;
  color: var(--z-ink-soft);
  -webkit-font-smoothing: antialiased;
}

.zmgj-admin .admin-main-panel section h2 {
  letter-spacing: -0.03em;
  font-weight: 800;
  color: var(--z-ink);
}

.zmgj-admin .premium-card {
  border-radius: var(--z-radius-lg);
  transition: box-shadow 0.25s ease, border-color 0.25s ease, transform 0.2s ease;
  border: 1px solid var(--z-glass-border);
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.95) 0%, rgba(255, 255, 255, 0.88) 100%);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.zmgj-admin .premium-card:hover {
  box-shadow: var(--z-shadow-2);
  transform: translateY(-1px);
  border-color: rgba(199, 210, 254, 0.65);
}

/* =============================================================================
   全局：主站 .zmgj-app 内 Tailwind 常用「灰/白底」统一为极光玻璃体系
   （不改动 HTML；用更高语义覆盖工具类）
   ============================================================================= */

.zmgj-app #page-live,
.zmgj-app #page-news,
.zmgj-app #page-history,
.zmgj-app #page-trade,
.zmgj-app #page-agent {
  background-color: transparent !important;
}

.zmgj-app .bg-gray-50,
.zmgj-app .bg-gray-50\/50 {
  background-color: rgba(248, 250, 255, 0.94) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.zmgj-app .bg-gray-100 {
  background-color: rgba(235, 242, 255, 0.62) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.zmgj-app .bg-white {
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.97) 0%, rgba(252, 253, 255, 0.9) 100%) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.zmgj-app .bg-black,
.zmgj-app .aspect-video.bg-black {
  background-color: #000 !important;
  backdrop-filter: none !important;
}

.zmgj-app .border-gray-50 {
  border-color: rgba(199, 210, 254, 0.42) !important;
}
.zmgj-app .border-gray-100 {
  border-color: rgba(199, 210, 254, 0.52) !important;
}
.zmgj-app .border-gray-200 {
  border-color: rgba(165, 180, 252, 0.42) !important;
}
.zmgj-app .border-gray-300 {
  border-color: rgba(165, 180, 252, 0.55) !important;
}

.zmgj-app .divide-gray-100 > :not([hidden]) ~ :not([hidden]) {
  border-color: rgba(199, 210, 254, 0.4) !important;
}

.zmgj-app .modal-mask .bg-white {
  background: linear-gradient(168deg, rgba(255, 255, 255, 0.99) 0%, rgba(246, 248, 255, 0.95) 100%) !important;
  backdrop-filter: blur(20px) saturate(1.25);
  -webkit-backdrop-filter: blur(20px) saturate(1.25);
}

.zmgj-app input:not([type="checkbox"]):not([type="radio"]):not([type="file"]):not([type="range"]),
.zmgj-app select,
.zmgj-app textarea {
  border-color: rgba(165, 180, 252, 0.45) !important;
}

/* 管理后台：Tailwind 白/灰底与表格表面 */
body.zmgj-admin .bg-white,
body.zmgj-admin .bg-gray-50,
body.zmgj-admin .bg-gray-100 {
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.96) 0%, rgba(252, 253, 255, 0.9) 100%) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

body.zmgj-admin .bg-gray-100 {
  background: rgba(237, 242, 255, 0.75) !important;
}

body.zmgj-admin .border-gray-200,
body.zmgj-admin .border-gray-100 {
  border-color: rgba(165, 180, 252, 0.45) !important;
}

body.zmgj-admin table {
  background: rgba(255, 255, 255, 0.92);
  border-radius: var(--z-radius-lg);
  overflow: hidden;
  box-shadow: var(--z-shadow-1);
}

body.zmgj-admin input,
body.zmgj-admin select,
body.zmgj-admin textarea {
  border-color: rgba(165, 180, 252, 0.45) !important;
  border-radius: 0.65rem;
}

/* 后台侧栏保留可读渐变，仅压一层玻璃感 */
body.zmgj-admin .sidebar {
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

/* ——— 全站内容与弹窗随分辨率收缩（前台 .zmgj-app） ——— */
/* 注意：勿对全站 img 使用 height:auto，否则会覆盖 Tailwind 的 h-*，顶栏 logo 会被撑满一行宽度 */
.zmgj-app #logo-desktop,
.zmgj-app #logo-mobile {
  width: auto;
  max-height: 2.75rem;
  object-fit: contain;
  flex-shrink: 0;
}
.zmgj-app .modal-mask {
  padding-left: max(0.5rem, env(safe-area-inset-left, 0px)) !important;
  padding-right: max(0.5rem, env(safe-area-inset-right, 0px)) !important;
  padding-bottom: max(0.5rem, env(safe-area-inset-bottom, 0px)) !important;
}
.zmgj-app .modal-mask > div {
  width: min(100%, calc(100vw - 1rem)) !important;
  max-width: min(36rem, calc(100vw - 1rem)) !important;
  max-height: min(92dvh, 92vh) !important;
  overflow-x: hidden;
}
@media (min-width: 768px) {
  .zmgj-app .modal-mask > div {
    max-width: min(36rem, 90vw) !important;
  }
}
.zmgj-app .adaptive-shell {
  width: min(100%, var(--adapt-vw, 100vw)) !important;
  max-width: min(1200px, 100%) !important;
}
