:root{
  /* —— 主题：午夜极光 · 统一冷色阶 + 克制玻璃高光 —— */
  --bg-deep: #121820;
  --bg: #181f2c;
  --bg-soft: #1f2838;
  --surface-1: rgba(255,255,255,.075);
  --surface-2: rgba(255,255,255,.125);
  --surface-glass: rgba(255,255,255,.1);
  --glass-blur: 28px;
  --glass-sat: 165%;
  --glass-edge: rgba(255,255,255,.32);
  --glass-shine: rgba(255,255,255,.55);
  --panel: var(--surface-1);
  --panel2: var(--surface-2);
  --text: rgba(255,255,255,.96);
  --text-secondary: rgba(255,255,255,.78);
  --muted: var(--text-secondary);
  --text-tertiary: rgba(255,255,255,.5);
  --line: rgba(255,255,255,.14);
  --line-strong: rgba(255,255,255,.24);
  /* 主色：青玉（略降饱和，更耐看） */
  --accent: #5ed4c8;
  --accent-dim: rgba(94,212,200,.16);
  --accent-glow: rgba(94,212,200,.38);
  /* 辅色：长春花蓝 */
  --accent2: #94b4ff;
  --accent2-dim: rgba(148,180,255,.14);
  /* 点缀：极淡紫，用于氛围光 */
  --accent-mist: rgba(180,170,255,.12);
  --danger: #ff9494;
  --warn: #e8cc7a;
  --ok: #6ee7b0;
  --shadow-sm: 0 6px 28px rgba(5, 10, 22, .35);
  --shadow: 0 20px 56px rgba(5, 10, 22, .45);
  --shadow-lg: 0 28px 72px rgba(5, 10, 22, .5);
  --radius: 16px;
  --radius2: 12px;
  --radius-pill: 999px;
  --content-max: 1180px;
  --space-section: clamp(16px, 3vw, 28px);
  --ease-out: cubic-bezier(.22, 1, .36, 1);
  color-scheme: dark;
}

*{box-sizing:border-box}
html,body{height:100%}
html, body{
  max-width: 100%;
  overflow-x: hidden;
}
body{
  margin:0;
  color:var(--text);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  background-color: var(--bg-deep);
  background-image:
    radial-gradient(ellipse 1000px 580px at 6% -8%, rgba(148,180,255,.16), transparent 58%),
    radial-gradient(ellipse 880px 520px at 96% 4%, rgba(94,212,200,.11), transparent 54%),
    radial-gradient(ellipse 720px 440px at 48% 108%, var(--accent-mist), transparent 52%),
    radial-gradient(ellipse 520px 360px at 72% 32%, rgba(255,255,255,.03), transparent 65%),
    linear-gradient(168deg, var(--bg-deep) 0%, var(--bg) 38%, var(--bg-soft) 100%);
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", "PingFang SC", "Noto Sans CJK SC", "Microsoft YaHei", Arial, sans-serif;
}

::selection{
  background: var(--accent-dim);
  color: var(--text);
}

.app{
  min-height:100%;
  min-height:100dvh;
  display:flex;
  flex-direction:column;
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
  padding-left: env(safe-area-inset-left);
  padding-right: env(safe-area-inset-right);
}

.adminNotice{
  padding:10px 18px;
  font-size:14px;
  line-height:1.45;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.adminNotice--warn{
  background:rgba(255,209,102,.12);
  color:rgba(255,248,220,.95);
}
.adminNotice--danger{
  background:rgba(255,107,107,.14);
  color:rgba(255,230,230,.96);
}
.topbar{
  position:sticky; top:0; z-index:10;
  padding:0;
  backdrop-filter: saturate(var(--glass-sat)) blur(var(--glass-blur));
  -webkit-backdrop-filter: saturate(var(--glass-sat)) blur(var(--glass-blur));
  background:
    linear-gradient(180deg, rgba(255,255,255,.14) 0%, rgba(148,180,255,.05) 42%, rgba(255,255,255,.03) 100%);
  border-bottom: 1px solid var(--glass-edge);
  box-shadow:
    0 1px 0 rgba(255,255,255,.1) inset,
    0 16px 48px rgba(5, 10, 22, .4);
}
.topbar__inner{
  max-width: var(--content-max);
  margin: 0 auto;
  width: 100%;
  display: flex;
  gap: clamp(12px, 2.5vw, 24px);
  align-items: flex-end;
  justify-content: space-between;
  padding: clamp(14px, 2.2vw, 20px) clamp(14px, 2.5vw, 24px) clamp(12px, 1.8vw, 16px);
}
.brand{
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}
.brand__mark{
  flex-shrink: 0;
  width: 10px;
  height: 40px;
  border-radius: 6px;
  background: linear-gradient(180deg, var(--accent) 0%, var(--accent2) 100%);
  box-shadow: 0 0 20px var(--accent-glow);
}
.brand__text{ min-width: 0; }
.brand__title{
  font-weight: 800;
  letter-spacing: .04em;
  font-size: clamp(17px, 1.1rem + 0.3vw, 19px);
  line-height: 1.25;
  background: linear-gradient(90deg, rgba(255,255,255,.98) 0%, rgba(255,255,255,.88) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.brand__subtitle{
  color: var(--text-tertiary);
  font-size: 12px;
  margin-top: 4px;
  letter-spacing: .02em;
}
.nav{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  justify-content:flex-end;
}
.nav__link{
  color: var(--text-secondary);
  text-decoration:none;
  padding: 9px 14px;
  border-radius: var(--radius-pill);
  border: 1px solid transparent;
  font-size: 13px;
  font-weight: 550;
  transition: color .2s var(--ease-out), background .2s var(--ease-out), border-color .2s var(--ease-out), box-shadow .2s var(--ease-out);
}
.nav__link:hover{
  color: var(--text);
  border-color: rgba(255,255,255,.28);
  background: rgba(255,255,255,.12);
  box-shadow: 0 0 0 1px rgba(255,255,255,.08), 0 8px 24px rgba(5, 10, 22, .28);
}
.nav__link:focus-visible{
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.main{
  flex:1;
  padding: var(--space-section);
  max-width: var(--content-max);
  width:100%;
  margin:0 auto;
}
.main--content{
  padding-top: clamp(12px, 2vw, 22px);
  padding-bottom: clamp(20px, 4vw, 36px);
}

.footer{
  margin-top: auto;
  border-top:1px solid var(--glass-edge);
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  background: linear-gradient(180deg, rgba(255,255,255,.08) 0%, rgba(255,255,255,.02) 100%);
}
.footer__inner{
  max-width: var(--content-max);
  margin: 0 auto;
  display:flex;
  gap:12px;
  justify-content:space-between;
  align-items:center;
  flex-wrap: wrap;
  padding: 14px clamp(14px, 2.5vw, 24px);
}
.footer__left{color:var(--muted); font-size:12px}
.footer__right{display:flex; gap:10px; flex-wrap:wrap}

.toast{
  position:fixed; left:50%; transform:translateX(-50%);
  top:78px;
  min-width: 260px;
  max-width: min(620px, calc(100% - 24px));
  padding:12px 16px;
  border-radius: var(--radius2);
  backdrop-filter: saturate(180%) blur(22px);
  -webkit-backdrop-filter: saturate(180%) blur(22px);
  background: linear-gradient(135deg, rgba(255,255,255,.12) 0%, rgba(148,180,255,.06) 50%, rgba(255,255,255,.04) 100%);
  border: 1px solid var(--glass-edge);
  box-shadow: var(--shadow-sm), 0 0 40px rgba(94,212,200,.1);
  display:none;
  z-index: 100;
}
.toast--show{display:block}

.grid{
  display:grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, .85fr);
  gap: clamp(14px, 2vw, 20px);
  align-items: start;
}
@media (max-width: 980px){
  .grid{grid-template-columns:1fr}
}

.card{
  position: relative;
  backdrop-filter: saturate(var(--glass-sat)) blur(22px);
  -webkit-backdrop-filter: saturate(var(--glass-sat)) blur(22px);
  background:
    linear-gradient(150deg, rgba(255,255,255,.1) 0%, rgba(148,180,255,.04) 35%, transparent 65%),
    linear-gradient(180deg, rgba(255,255,255,.07) 0%, rgba(255,255,255,.03) 100%);
  border:1px solid var(--glass-edge);
  border-radius: var(--radius);
  box-shadow:
    var(--shadow-sm),
    0 0 0 1px rgba(255,255,255,.04) inset,
    0 1px 0 rgba(255,255,255,.08) inset;
  overflow:hidden;
  transition: box-shadow .25s var(--ease-out), border-color .25s var(--ease-out), transform .25s var(--ease-out);
}
.card:hover{
  border-color: rgba(255,255,255,.38);
  box-shadow:
    var(--shadow),
    0 0 0 1px rgba(255,255,255,.08) inset,
    0 1px 0 rgba(255,255,255,.12) inset;
}
.card__hd{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding: clamp(14px, 2vw, 18px) clamp(14px, 2vw, 18px) clamp(12px, 1.5vw, 14px);
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.06) 0%, transparent 100%);
}
.card__title{
  font-weight: 750;
  font-size: clamp(15px, 0.95rem + 0.2vw, 17px);
  letter-spacing: .02em;
}
.card__bd{padding: clamp(14px, 2vw, 18px)}

.card__hd .tag{
  border-color: var(--accent-dim);
  background: var(--accent-dim);
  color: var(--accent);
  font-weight: 600;
}

.kpis{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
  gap: 12px;
}
.kpi{
  padding: 14px 14px;
  border-radius: var(--radius2);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  background: linear-gradient(160deg, rgba(255,255,255,.14), rgba(255,255,255,.05));
  border: 1px solid rgba(255,255,255,.2);
  box-shadow: 0 1px 0 rgba(255,255,255,.1) inset;
}
.kpi__label{color: var(--text-secondary); font-size: 12px; font-weight: 500; letter-spacing: .02em}
.kpi__value{
  font-size: clamp(20px, 1.1rem + 1vw, 26px);
  font-weight: 800;
  margin-top: 8px;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
  background: linear-gradient(115deg, #fff 0%, rgba(200,230,255,.92) 45%, rgba(180,245,235,.88) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.row{display:flex; gap:10px; flex-wrap:wrap; align-items:center}
.row--end{justify-content:flex-end}

.btn{
  appearance:none;
  border: 1px solid rgba(255,255,255,.26);
  background: linear-gradient(180deg, rgba(255,255,255,.16) 0%, rgba(255,255,255,.08) 100%);
  color: var(--text);
  padding:10px 14px;
  border-radius: var(--radius2);
  cursor:pointer;
  font-weight:650;
  font-size: 14px;
  transition: background .2s var(--ease-out), border-color .2s var(--ease-out), transform .15s var(--ease-out), box-shadow .2s var(--ease-out);
  box-shadow: 0 1px 0 rgba(255,255,255,.12) inset;
}
.btn:hover{
  background: linear-gradient(180deg, rgba(255,255,255,.22) 0%, rgba(255,255,255,.12) 100%);
  border-color: rgba(255,255,255,.38);
}
.btn:active{ transform: scale(.98); }
.btn:focus-visible{
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.btn:disabled{opacity:.55; cursor:not-allowed; transform:none}
.btn--primary{
  border-color: rgba(94,212,200,.45);
  background: linear-gradient(180deg, rgba(94,212,200,.28), rgba(94,212,200,.1));
  color: #f2fffc;
  box-shadow: 0 0 24px rgba(94,212,200,.18), 0 1px 0 rgba(255,255,255,.18) inset;
}
.btn--primary:hover{
  background: linear-gradient(180deg, rgba(94,212,200,.38), rgba(94,212,200,.16));
  border-color: rgba(94,212,200,.58);
}
.btn--danger{
  border-color: rgba(255,123,123,.45);
  background: linear-gradient(180deg, rgba(255,123,123,.18), rgba(255,123,123,.06));
}
.btn--ghost{
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.2);
  color: var(--text-secondary);
  box-shadow: none;
}
.btn--ghost:hover{
  color: var(--text);
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.32);
}
.btn--nav{
  font-weight: 600;
  padding: 9px 16px;
}

.input, .select, .textarea{
  width:100%;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.1);
  color: var(--text);
  padding: 11px 12px;
  outline:none;
  /* iOS Safari / WKWebView：输入框字号 <16px 会聚焦时自动缩放整页，导致「画面变大」 */
  font-size: 16px;
  line-height: 1.35;
}
.input:focus, .select:focus, .textarea:focus{
  border-color: rgba(94,212,200,.5);
  box-shadow: 0 0 0 3px var(--accent-dim);
}
.textarea{min-height: 92px; resize: vertical}
.help{color: var(--muted); font-size: 12px; margin-top: 6px}
.label{color: var(--muted); font-size: 12px; margin-bottom: 6px}
.field{margin-bottom: 12px}

/* 档案详情：修改档案主按钮在手机上好点 */
.profile-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:stretch;
}
.profile-actions .btn--primary{
  flex:1 1 100%;
  justify-content:center;
  text-align:center;
}
@media (min-width: 520px){
  .profile-actions .btn--primary{ flex:0 1 auto; }
}
.input--readonly{
  opacity:.92;
  cursor:default;
  background:rgba(255,255,255,.06);
}

.searchbar{
  display:flex; gap:10px; align-items:center;
}
.searchbar__input{flex:1}

.table{
  width:100%;
  border-collapse: collapse;
  overflow:hidden;
  border-radius: var(--radius2);
  font-size: 14px;
}
.table thead{
  background: rgba(255,255,255,.04);
}
.table th, .table td{
  text-align:left;
  padding:12px 12px;
  border-bottom:1px solid var(--line);
  vertical-align: top;
}
.table th{
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .04em;
}
.table tbody tr:last-child td{ border-bottom: none; }
.table tr:hover td{background: rgba(94,212,200,.07)}
.tableWrap{
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.table--profiles{
  min-width: 820px;
}
.table--profiles .cell-main{
  min-width: 240px;
}
.table--profiles .cell-main .muted{
  display: inline-block;
  max-width: 280px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.table--profiles td,
.table--profiles th{
  white-space: nowrap;
}
/* 隐患台账：按户合并，明细堆叠在最后一列 */
.table--hazards{
  min-width: 520px;
}
.table--hazards .hazardGroupCell{
  padding: 10px 12px;
  min-width: 200px;
}
.hazardStack{
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.hazardLine{
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px 10px;
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
}
.hazardLine__no{
  font-size: 12px;
  color: var(--text-tertiary);
  font-variant-numeric: tabular-nums;
}
.hazardLine__txt{
  flex: 1 1 200px;
  min-width: 0;
  line-height: 1.45;
}
.hazardGroupRow td{
  vertical-align: top;
}
.mono{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;}
.tag{
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 9px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  font-size: 12px;
  color: var(--muted);
  white-space: nowrap;
}
.tag--ok{border-color: rgba(84,242,139,.35); color: rgba(84,242,139,.95); background: rgba(84,242,139,.10)}
.tag--warn{border-color: rgba(255,209,102,.35); color: rgba(255,209,102,.95); background: rgba(255,209,102,.10)}
.tag--danger{border-color: rgba(255,107,107,.35); color: rgba(255,107,107,.95); background: rgba(255,107,107,.10)}
.tag--info{border-color: rgba(138,180,255,.4); color: var(--accent2); background: var(--accent2-dim)}

.split{
  display:flex; gap:10px; flex-wrap:wrap; align-items:center; justify-content:space-between;
}
.divider{height:1px; background: rgba(255,255,255,.10); margin:14px 0}
.empty{color: var(--muted); padding: 12px; border:1px dashed rgba(255,255,255,.18); border-radius: 14px}
.muted{color: var(--muted)}

.card__bd a:not(.btn):not(.nav__link){
  color: var(--accent2);
  text-decoration: none;
  border-bottom: 1px solid rgba(138,180,255,.35);
  transition: color .15s var(--ease-out), border-color .15s var(--ease-out);
}
.card__bd a:not(.btn):not(.nav__link):hover{
  color: #c8d9ff;
  border-bottom-color: rgba(200,217,255,.55);
}

.mediaGrid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:10px;
}
@media (max-width: 980px){
  .mediaGrid{grid-template-columns: repeat(2, minmax(0, 1fr))}
}
@media (max-width: 560px){
  .mediaGrid{grid-template-columns: 1fr}
}
.mediaItem{
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  border-radius: 14px;
  overflow:hidden;
}
.mediaItem img{
  width:100%;
  height: 160px;
  object-fit: cover;
  display:block;
  background: rgba(0,0,0,.22);
}
.mediaItem__meta{padding:10px}
.mediaItem__title{
  font-weight:750;
  font-size: 13px;
  margin-bottom:8px;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.mediaItem__actions{display:flex; gap:8px; flex-wrap:wrap}

.videoUploadRow{
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 4px;
}
/* 勿 display:none，部分手机系统无法通过程序 click 唤起选文件 */
.videoFileNative{
  position: absolute;
  left: -9999px;
  top: 0;
  width: 1px;
  height: 1px;
  margin: 0;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
  opacity: 0.02;
}
.videoList{display:flex; flex-direction:column; gap:10px}
.videoItem{
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  border-radius: 14px;
  padding:10px;
}
/* 完整显示画面：勿用 cover 固定竖框裁切横屏/竖屏视频；全屏时同样用 contain 避免「铺满但缺边」 */
.videoThumb{
  display: block;
  width: 100%;
  max-width: 100%;
  max-height: min(72vh, 560px);
  height: auto;
  border-radius: 12px;
  background: #000;
  object-fit: contain;
  object-position: center;
}
.videoThumb:fullscreen,
.videoThumb:-webkit-full-screen{
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  border-radius: 0;
  object-fit: contain;
}
.videoItem__hd{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  margin-bottom:10px;
}
.videoItem__title{min-width:0}

.shotBoard{
  padding: 12px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  background: rgba(255,255,255,.03);
}
.shotBoard__title{
  font-size: 26px;
  font-weight: 800;
  margin-bottom: 12px;
}
.shotGrid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 12px;
}
.shotItem{
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  min-height: 120px;
}
.shotItem img{
  width: 100%;
  height: 120px;
  object-fit: cover;
  display: block;
}
/* 手机端可点：避免仅依赖 click 绑定在可写权限内导致只读账号无法预览 */
.shotItem img.photoTapOpen{
  touch-action: manipulation;
  -webkit-tap-highlight-color: rgba(255,255,255,.12);
  -webkit-user-select: none;
  user-select: none;
}
.shotDel{
  position: absolute;
  right: 6px;
  top: 6px;
  z-index: 3;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  border: 0;
  background: rgba(255,71,87,.96);
  color: #fff;
  font-size: 18px;
  line-height: 24px;
  cursor: pointer;
}
.shotCheck{
  position: absolute;
  left: 6px;
  bottom: 6px;
  z-index: 2;
  font-size: 12px;
  color: #fff;
  background: rgba(0,0,0,.46);
  border-radius: 999px;
  padding: 4px 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.shotCheck input{
  margin: 0;
  width: 16px;
  height: 16px;
  cursor: pointer;
  accent-color: #ff4757;
}
.shotAdd{
  min-height: 120px;
  border-radius: 14px;
  border: 1px dashed rgba(255,255,255,.26);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  cursor: pointer;
  background: rgba(255,255,255,.02);
}
.shotAdd__icon{
  font-size: 28px;
  line-height: 1;
}
.shotAdd__text{
  margin-top: 6px;
  font-size: 12px;
}

.imgPreviewMask{
  position: fixed;
  inset: 0;
  z-index: 1200;
  backdrop-filter: saturate(160%) blur(12px);
  -webkit-backdrop-filter: saturate(160%) blur(12px);
  background: rgba(5, 10, 22, .82);
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 100dvh;
  box-sizing: border-box;
}
.imgPreviewTop{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  flex-shrink:0;
  border-bottom:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.45);
}
.imgPreviewTitle{
  font-weight: 700;
  color: rgba(255,255,255,.9);
  text-align:center;
}
.imgPreviewBody{
  flex:1;
  min-height:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:4px 6px;
  box-sizing:border-box;
}
.imgPreviewBody img{
  max-width:min(100%,100vw);
  max-height:min(100%,calc(100dvh - 48px));
  max-height:min(100%,calc(100vh - 48px));
  width:auto;
  height:auto;
  object-fit:contain;
  border-radius:10px;
}

.authMask{
  position: fixed;
  inset: 0;
  z-index: 1400;
  backdrop-filter: saturate(180%) blur(18px);
  -webkit-backdrop-filter: saturate(180%) blur(18px);
  background: rgba(5, 10, 22, .48);
  display:flex;
  align-items:center;
  justify-content:center;
}
.authCard{
  width:min(420px, calc(100% - 28px));
  border-radius: var(--radius);
  border:1px solid var(--glass-edge);
  backdrop-filter: saturate(var(--glass-sat)) blur(28px);
  -webkit-backdrop-filter: saturate(var(--glass-sat)) blur(28px);
  background: linear-gradient(165deg, rgba(255,255,255,.2) 0%, rgba(255,255,255,.06) 100%);
  box-shadow: var(--shadow-lg), 0 0 0 1px rgba(255,255,255,.08) inset;
  padding:20px;
}

/* 删除等高风险操作确认弹窗：替代原生 confirm，提升 iOS 兼容性 */
.confirmMask{
  position: fixed;
  inset: 0;
  z-index: 1450;
  backdrop-filter: saturate(180%) blur(18px);
  -webkit-backdrop-filter: saturate(180%) blur(18px);
  background: rgba(5, 10, 22, .48);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px;
}
.confirmCard{
  width: min(420px, calc(100% - 16px));
  border-radius: var(--radius);
  border: 1px solid var(--glass-edge);
  backdrop-filter: saturate(var(--glass-sat)) blur(28px);
  -webkit-backdrop-filter: saturate(var(--glass-sat)) blur(28px);
  background: linear-gradient(165deg, rgba(255,255,255,.22) 0%, rgba(255,255,255,.07) 100%);
  box-shadow: var(--shadow-lg), 0 0 0 1px rgba(255,255,255,.08) inset;
  padding: 18px;
}
.confirmTitle{
  font-size: 16px;
  font-weight: 760;
  margin-bottom: 8px;
}
.confirmText{
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.55;
  word-break: break-word;
  white-space: pre-line;
}
.confirmActions{
  margin-top: 14px;
  display: flex;
  gap: 10px;
  justify-content: flex-end;
}

/* 全局上传进度（XHR upload progress）：视口正中 + 玻璃拟态光效 */
.uploadProgress{
  position: fixed;
  inset: 0;
  z-index: 1900;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: max(16px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right)) max(16px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left));
  background: rgba(8, 12, 22, .48);
  backdrop-filter: saturate(175%) blur(26px);
  -webkit-backdrop-filter: saturate(175%) blur(26px);
  /* 全屏拦截点击/触摸，避免上传过程中误触背后页面 */
  pointer-events: auto;
  touch-action: none;
  overscroll-behavior: none;
  -webkit-user-select: none;
  user-select: none;
}
.uploadProgress[hidden]{
  display: none !important;
}
.uploadProgress__box{
  position: relative;
  width: min(400px, calc(100% - 28px));
  padding: 22px 22px 18px;
  border-radius: 20px;
  backdrop-filter: saturate(220%) blur(20px);
  -webkit-backdrop-filter: saturate(220%) blur(20px);
  background:
    linear-gradient(155deg, rgba(94,212,200,.12) 0%, transparent 42%),
    linear-gradient(200deg, rgba(148,180,255,.08) 0%, transparent 50%),
    linear-gradient(180deg, rgba(255,255,255,.12) 0%, rgba(255,255,255,.04) 100%);
  border: 1px solid rgba(255,255,255,.3);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.1) inset,
    0 28px 80px rgba(5, 10, 22, .45),
    0 0 88px rgba(94,212,200,.14),
    0 0 40px rgba(148,180,255,.1);
  overflow: hidden;
  animation: uploadCardGlow 2.8s ease-in-out infinite;
}
@keyframes uploadCardGlow{
  0%, 100%{ box-shadow: 0 0 0 1px rgba(255,255,255,.08) inset, 0 28px 80px rgba(5, 10, 22, .42), 0 0 88px rgba(94,212,200,.12), 0 0 44px rgba(148,180,255,.08); }
  50%{ box-shadow: 0 0 0 1px rgba(255,255,255,.12) inset, 0 32px 88px rgba(5, 10, 22, .48), 0 0 104px rgba(94,212,200,.18), 0 0 52px rgba(148,180,255,.12); }
}
.uploadProgress__box::before{
  content: "";
  position: absolute;
  top: -40%;
  left: -30%;
  width: 70%;
  height: 90%;
  background: radial-gradient(ellipse at center, rgba(94,212,200,.16), transparent 65%);
  pointer-events: none;
}
.uploadProgress__box::after{
  content: "";
  position: absolute;
  bottom: -30%;
  right: -20%;
  width: 55%;
  height: 70%;
  background: radial-gradient(ellipse at center, rgba(148,180,255,.12), transparent 70%);
  pointer-events: none;
}
.uploadProgress__label{
  position: relative;
  z-index: 1;
  font-size: 15px;
  font-weight: 750;
  letter-spacing: .06em;
  margin-bottom: 14px;
  color: rgba(255,255,255,.98);
  text-shadow: 0 0 24px rgba(94,212,200,.28);
}
.uploadProgress__track{
  position: relative;
  z-index: 1;
  height: 12px;
  border-radius: 999px;
  background: rgba(8, 12, 22, .4);
  box-shadow: inset 0 2px 6px rgba(5, 10, 22, .4);
  overflow: hidden;
}
.uploadProgress__track--pulse{
  animation: uploadTrackPulse 1.1s ease-in-out infinite;
}
@keyframes uploadTrackPulse{
  0%, 100%{ opacity: .72; }
  50%{ opacity: 1; }
}
.uploadProgress__fill{
  position: relative;
  height: 100%;
  width: 0%;
  border-radius: 999px;
  background: linear-gradient(90deg,
    rgba(65,195,185,.98) 0%,
    rgba(94,212,200,1) 38%,
    rgba(185,248,235,.95) 100%);
  box-shadow:
    0 0 18px rgba(94,212,200,.55),
    0 0 36px rgba(94,212,200,.25);
  transition: width 0.08s ease-out;
}
.uploadProgress__fill::after{
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(255,255,255,.45) 45%,
    transparent 90%);
  transform: translateX(-120%);
  animation: uploadBarShine 1.35s ease-in-out infinite;
}
@keyframes uploadBarShine{
  0%{ transform: translateX(-120%); opacity: .4; }
  50%{ opacity: .95; }
  100%{ transform: translateX(120%); opacity: .4; }
}
.uploadProgress__fill--indeterminate{
  animation: uploadFillShimmer 1.2s ease-in-out infinite;
}
@keyframes uploadFillShimmer{
  0%, 100%{ opacity: .75; filter: brightness(1); }
  50%{ opacity: 1; filter: brightness(1.12); }
}
.uploadProgress__meta{
  position: relative;
  z-index: 1;
  margin-top: 12px;
  font-size: 12px;
  color: rgba(255,255,255,.72);
  line-height: 1.45;
}

/* 首页：非 admin 说明（与 .help 区分，便于移动端行距） */
.publicHint{
  margin-bottom: 12px;
  line-height: 1.55;
  color: var(--muted);
  font-size: 13px;
}
.publicHint strong{
  color: rgba(255,255,255,.88);
  font-weight: 650;
}

/* —— 手机 / 窄屏排版 —— */
@media (max-width: 720px){
  .topbar__inner{
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
    padding: 12px 12px 10px;
    padding-top: max(12px, env(safe-area-inset-top));
  }
  .brand__mark{ height: 36px; width: 8px; }
  .brand__title{ font-size: 17px; letter-spacing: .04em; }
  .brand__subtitle{ font-size: 11px; }
  /* 顶栏链接单行横向滑动，避免折成多行难看 */
  .nav{
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
    align-items: center;
    justify-content: flex-start;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    margin: 0 -4px;
    padding: 2px 4px 6px;
  }
  .nav::-webkit-scrollbar{ height: 3px; }
  .nav::-webkit-scrollbar-thumb{
    background: rgba(255,255,255,.22);
    border-radius: 999px;
  }
  .nav__link{
    flex: 0 0 auto;
    padding: 9px 12px;
    font-size: 13px;
  }
  .nav .btn{
    flex: 0 0 auto;
    margin-left: 2px;
    padding: 9px 14px;
    font-size: 13px;
  }

  .main{
    padding: 12px;
    padding-bottom: max(14px, env(safe-area-inset-bottom));
    min-width: 0;
  }
  .footer{
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    padding: 12px;
    padding-bottom: max(12px, env(safe-area-inset-bottom));
  }
  .footer__left{ line-height: 1.45; }

  .toast{
    top: max(72px, calc(env(safe-area-inset-top) + 52px));
    min-width: unset;
    width: calc(100% - 20px);
  }

  .grid{ gap: 12px; }
  .card__hd{
    padding: 12px 12px 10px;
    align-items: flex-start;
  }
  .card__title{
    min-width: 0;
    line-height: 1.35;
  }
  .card__bd{ padding: 12px; }

  .searchbar{
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .searchbar .btn{ width: 100%; }

  .kpis{ gap: 8px; }
  .kpi{ padding: 10px 10px; }
  .kpi__value{ font-size: 19px; }
  .tableWrap{
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,.08);
  }
  .table--profiles{
    min-width: 680px;
  }

  .btn{ padding: 11px 14px; }
  .field{ margin-bottom: 14px; }
}

@media (max-width: 380px){
  .kpi__value{ font-size: 17px; }
  .brand__title{ font-size: 16px; }
}

