/* ──────────────────────────────────────────────────────────────────────────
   aevisit 全站样式 — CSS 变量驱动的深/浅双主题
   主题由 <html data-theme="dark|light"> 切换(base.html 头部无闪烁脚本设置)。
   默认深色;data-theme="light" 覆盖为浅色。所有颜色一律走 var(),勿硬编码。
   设计目标:有层次(bg<surface<card,靠边框+阴影分层)、高对比、信息密度合理。
   ────────────────────────────────────────────────────────────────────────── */
:root {
  --bg:        #0a0c11;   /* 页面最底 */
  --surface:   #11151d;   /* 顶栏/侧边栏 */
  --card:      #161b25;   /* 卡片/表格/图表容器 */
  --card-2:    #1c2230;   /* 卡片内的输入框等再上一层 */
  --border:    #262d3a;   /* 常规描边 */
  --border-soft:#1e242f;  /* 更弱的分隔线 */
  --text:      #eef1f6;   /* 主文字(提亮) */
  --muted:     #9aa4b4;   /* 次要文字 */
  --faint:     #687184;   /* 占位/弱化 */
  --primary:   #4f7dff;   /* 主色(更鲜亮的蓝) */
  --primary-fg:#ffffff;
  --primary-soft: rgba(79,125,255,.14);
  --danger:    #f0506a;
  --danger-soft: rgba(240,80,106,.14);
  --ok:        #34d27b;
  --warn:      #f5a524;
  --warn-soft: rgba(245,165,36,.16);
  --shadow:    0 1px 2px rgba(0,0,0,.4), 0 8px 24px rgba(0,0,0,.28);
  --shadow-sm: 0 1px 3px rgba(0,0,0,.35);
  --radius:    14px;
  --radius-sm: 9px;
}

:root[data-theme="light"] {
  --bg:        #eef1f6;
  --surface:   #ffffff;
  --card:      #ffffff;
  --card-2:    #f4f6fa;
  --border:    #e1e5ee;
  --border-soft:#eceef4;
  --text:      #131722;
  --muted:     #5a6474;
  --faint:     #9aa3b2;
  --primary:   #2563eb;
  --primary-fg:#ffffff;
  --primary-soft: rgba(37,99,235,.10);
  --danger:    #e23744;
  --danger-soft: rgba(226,55,68,.10);
  --ok:        #16a34a;
  --warn:      #b8730a;
  --warn-soft: rgba(184,115,10,.12);
  --shadow:    0 1px 2px rgba(16,24,40,.06), 0 8px 24px rgba(16,24,40,.08);
  --shadow-sm: 0 1px 3px rgba(16,24,40,.08);
  --radius:    14px;
  --radius-sm: 9px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  font-family: -apple-system, "PingFang SC", "Microsoft YaHei", "Segoe UI", sans-serif;
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  font-size: 14px;
  line-height: 1.5;
}
a { color: inherit; }
::selection { background: var(--primary-soft); }

/* ── 顶栏 ────────────────────────────────────────────────────────────────── */
.topbar {
  display: flex; justify-content: space-between; align-items: center;
  height: 58px; padding: 0 22px;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 30;
}
.topbar .brand { font-weight: 700; font-size: 15px; letter-spacing: .2px; display: flex; align-items: center; gap: 8px; }
.topbar-right { display: flex; align-items: center; gap: 16px; font-size: 13px; }
.topbar-right .user-name { color: var(--text); font-weight: 600; }
.topbar-right a { color: var(--muted); text-decoration: none; transition: color .15s; }
.topbar-right a:hover { color: var(--text); }
.lang-switch { display: inline-flex; gap: 2px; padding: 2px; border: 1px solid var(--border); border-radius: 8px; background: var(--card-2); }
.lang-switch a {
  padding: 3px 9px; border-radius: 6px; color: var(--muted); font-size: 12px; font-weight: 600;
}
.lang-switch a.active { color: var(--primary-fg); background: var(--primary); }

/* ── 布局:左侧边栏 + 右内容 ─────────────────────────────────────────────── */
.layout { display: flex; min-height: calc(100vh - 58px); }
.sidebar {
  width: 216px; flex-shrink: 0;
  background: var(--surface); border-right: 1px solid var(--border);
  padding: 16px 12px; position: sticky; top: 58px; align-self: flex-start;
  height: calc(100vh - 58px); overflow-y: auto;
}
.sidebar a {
  display: flex; align-items: center; gap: 11px;
  padding: 10px 13px; margin-bottom: 3px; border-radius: 10px;
  color: var(--muted); text-decoration: none; font-size: 14px; font-weight: 500;
  transition: background .15s, color .15s;
}
.sidebar a:hover { background: var(--card-2); color: var(--text); }
.sidebar a.active { background: var(--primary); color: var(--primary-fg); box-shadow: 0 4px 12px var(--primary-soft); }
.sidebar a .ic { width: 18px; text-align: center; font-size: 15px; }

.content { flex: 1; min-width: 0; padding: 26px 30px; }
.content-inner { max-width: 1220px; margin: 0 auto; }

.foot { text-align: center; color: var(--faint); padding: 22px; font-size: 12px; }

/* ── KPI 卡片 ────────────────────────────────────────────────────────────── */
.kpis { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 8px; }
.kpi {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 18px 22px; min-width: 158px;
  box-shadow: var(--shadow-sm); position: relative; overflow: hidden;
}
.kpi::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: var(--primary); opacity: .85;
}
.kpi .num { font-size: 30px; font-weight: 750; letter-spacing: -.5px; }
.kpi .lbl { color: var(--muted); font-size: 13px; margin-top: 4px; }

/* ── 区块标题 / 图表 ─────────────────────────────────────────────────────── */
.section-title {
  font-size: 15px; font-weight: 700; margin: 30px 0 14px;
  display: flex; align-items: center; gap: 8px;
}
.chart-label { color: var(--muted); font-size: 13px; margin: 8px 0; }
.chart {
  height: 320px; background: var(--card);
  border: 1px solid var(--border); border-radius: var(--radius);
  padding: 12px; box-shadow: var(--shadow-sm);
}

/* ── 预警卡片网格 ────────────────────────────────────────────────────────── */
.alert-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.alert-card {
  background: var(--card); border: 1px solid var(--border);
  border-left: 3px solid var(--faint); border-radius: var(--radius);
  padding: 16px 18px; text-decoration: none; color: inherit; display: block;
  box-shadow: var(--shadow-sm); transition: transform .12s, border-color .12s, box-shadow .12s;
}
.alert-card:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.alert-card.red { border-left-color: var(--danger); background: linear-gradient(100deg, var(--danger-soft), transparent 60%), var(--card); }
.alert-card.yellow { border-left-color: var(--warn); background: linear-gradient(100deg, var(--warn-soft), transparent 60%), var(--card); }
.alert-card .dim { color: var(--muted); font-size: 13px; }
.alert-card .cnt { font-size: 27px; font-weight: 750; margin-top: 6px; letter-spacing: -.5px; }

/* ── 表格 ────────────────────────────────────────────────────────────────── */
table {
  width: 100%; border-collapse: collapse;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm);
}
th, td {
  padding: 9px 14px; text-align: left;
  border-bottom: 1px solid var(--border-soft); font-size: 13.5px;
}
thead th {
  color: var(--muted); font-weight: 600; font-size: 12px;
  text-transform: uppercase; letter-spacing: .4px;
  background: var(--card-2);
}
tbody tr { transition: background .12s; }
tbody tr:hover { background: var(--card-2); }
tbody tr:last-child td { border-bottom: none; }

/* ── 标签页(分析视角切换 + 系统管理 Tab 复用) ──────────────────────────── */
.tabs { display: flex; gap: 6px; margin: 16px 0; flex-wrap: wrap;
  background: var(--card-2); padding: 5px; border-radius: 11px; border: 1px solid var(--border); width: fit-content; }
.tab {
  padding: 7px 15px; border-radius: 7px; cursor: pointer;
  color: var(--muted); font-size: 13.5px; font-weight: 500; user-select: none;
  transition: background .12s, color .12s; background: transparent; border: none;
}
.tab:hover { color: var(--text); }
.tab.active { color: var(--primary-fg); background: var(--primary); box-shadow: var(--shadow-sm); }

.tab-pane { display: none; }
.tab-pane.active { display: block; animation: fade .18s ease; }
@keyframes fade { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

/* ── 徽标 ────────────────────────────────────────────────────────────────── */
.badge { padding: 2px 9px; border-radius: 20px; font-size: 12px; font-weight: 600; }
.badge.red { background: var(--danger-soft); color: var(--danger); }
.badge.yellow { background: var(--warn-soft); color: var(--warn); }

/* ── 表单控件 ────────────────────────────────────────────────────────────── */
input[type=text], input[type=number], input[type=url], input[type=password],
input[type=file], select {
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: 7px 11px; font-size: 13.5px;
  background: var(--card-2); color: var(--text); transition: border-color .12s, box-shadow .12s;
}
input:focus, select:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-soft); }
input::placeholder { color: var(--faint); }
select option { background: var(--card); color: var(--text); }
label { font-size: 12px; color: var(--muted); }

.btn {
  padding: 7px 15px; border-radius: var(--radius-sm); border: 1px solid var(--border);
  cursor: pointer; font-size: 13.5px; font-weight: 500;
  background: var(--card-2); color: var(--text); transition: all .12s;
}
.btn:hover { border-color: var(--primary); color: var(--text); }
.btn-primary { background: var(--primary); color: var(--primary-fg); border-color: var(--primary); }
.btn-primary:hover { filter: brightness(1.08); border-color: var(--primary); }
.btn-danger  { background: var(--danger); color: #fff; border-color: var(--danger); }
.btn-danger:hover { filter: brightness(1.06); }
.btn-sm { padding: 4px 10px; font-size: 12.5px; }
.btn:disabled { opacity: .45; cursor: not-allowed; }

.form-row { display: flex; gap: 14px; flex-wrap: wrap; align-items: flex-end; margin-bottom: 14px; }
.form-col { display: flex; flex-direction: column; gap: 5px; }

/* ── 状态标记 ────────────────────────────────────────────────────────────── */
.tag-ok   { color: var(--ok); font-weight: 700; }
.tag-fail { color: var(--danger); font-weight: 700; }
.tag-none { color: var(--faint); }
.masked   { font-family: ui-monospace, "SF Mono", monospace; color: var(--muted); }
.hint     { font-size: 12px; color: var(--faint); margin-top: 4px; }

h2 { font-size: 22px; font-weight: 750; letter-spacing: -.4px; }

/* ── 响应式:窄屏侧边栏转横向 ───────────────────────────────────────────── */
@media (max-width: 820px) {
  .layout { flex-direction: column; }
  .sidebar {
    width: 100%; height: auto; position: static;
    display: flex; gap: 6px; overflow-x: auto; padding: 10px;
    border-right: none; border-bottom: 1px solid var(--border);
  }
  .sidebar a { margin-bottom: 0; white-space: nowrap; }
  .content { padding: 16px; }
  .alert-grid { grid-template-columns: 1fr; }
}
