:root {
  --bg: #f5f7ff;
  --card: rgba(255, 255, 255, .88);
  --text: #182033;
  --muted: #6d7485;
  --line: #e7eaf4;
  --primary: #536dfe;
  --primary-dark: #3f51d5;
  --accent: #8e5cf7;
  --success: #16a34a;
  --warning: #f59e0b;
  --danger: #dc2626;
  --shadow: 0 24px 70px rgba(36, 53, 112, .16);
  --radius: 24px;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  min-height: 100vh;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", Arial, sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 8% 8%, rgba(83, 109, 254, .22), transparent 34%),
    radial-gradient(circle at 88% 18%, rgba(142, 92, 247, .20), transparent 34%),
    linear-gradient(135deg, #f7f9ff 0%, #eef2ff 100%);
}

body.portal-session-checking #studentLoginView,
body.portal-session-checking #studentView {
  display: none !important;
}

body.portal-session-checking::before {
  content: "正在进入个人中心...";
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #f7fbff 0%, #eef6f2 52%, #f8f5ff 100%);
  color: #334155;
  font-weight: 800;
  z-index: 9999;
}

a { color: var(--primary); text-decoration: none; }
a:hover { color: var(--primary-dark); text-decoration: none; }

.page-shell {
  width: min(1080px, 100%);
  margin: 0 auto;
  padding: 34px 18px;
}

.hero {
  position: relative;
  overflow: hidden;
  border-radius: 32px;
  padding: 34px;
  color: white;
  background: linear-gradient(135deg, #4355dc 0%, #7757f5 58%, #9b5cf7 100%);
  box-shadow: var(--shadow);
}

.hero::after {
  content: "";
  position: absolute;
  width: 260px;
  height: 260px;
  right: -90px;
  top: -85px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .16);
}

.hero .eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .18);
  backdrop-filter: blur(12px);
  font-size: 13px;
  letter-spacing: .5px;
}

.hero h1 {
  margin: 22px 0 10px;
  font-size: clamp(30px, 6vw, 52px);
  line-height: 1.06;
  letter-spacing: -1.6px;
}

.hero p {
  margin: 0;
  width: min(620px, 100%);
  color: rgba(255, 255, 255, .88);
  font-size: 16px;
  line-height: 1.8;
}

.grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(330px, .75fr);
  gap: 22px;
  margin-top: 22px;
  align-items: start;
}

.card {
  border: 1px solid rgba(255,255,255,.74);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
  padding: 24px;
}

.card h2, .card h3 { margin: 0 0 14px; }
.card h2 { font-size: 24px; }
.card h3 { font-size: 18px; }
.card p { color: var(--muted); line-height: 1.8; margin: 8px 0; }

.label {
  display: block;
  margin: 18px 0 8px;
  color: #384057;
  font-weight: 700;
}

.input {
  width: 100%;
  height: 54px;
  border: 1px solid var(--line);
  border-radius: 17px;
  background: #fff;
  padding: 0 16px;
  color: var(--text);
  font-size: 18px;
  outline: none;
  transition: .2s ease;
}

.input:focus {
  border-color: rgba(83,109,254,.65);
  box-shadow: 0 0 0 5px rgba(83,109,254,.12);
}

.checkbox-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 16px 0 18px;
  color: var(--muted);
  line-height: 1.6;
  font-size: 14px;
}

.checkbox-row input { margin-top: 4px; width: 18px; height: 18px; }

.btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  border: 0;
  border-radius: 16px;
  min-height: 48px;
  padding: 0 18px;
  color: #fff;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  font-weight: 800;
  font-size: 16px;
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
  box-shadow: 0 12px 28px rgba(83,109,254,.25);
}

.btn:hover { transform: translateY(-1px); text-decoration: none; }
.btn:disabled { cursor: not-allowed; opacity: .55; transform: none; }
.btn.secondary { color: var(--text); background: #eef2ff; box-shadow: none; }
.btn.ghost { color: var(--primary); background: transparent; box-shadow: none; }
.btn.danger { background: linear-gradient(135deg, #ef4444, #dc2626); }
.btn.small { min-height: 36px; border-radius: 12px; padding: 0 12px; font-size: 13px; }
.full { width: 100%; }

.notice {
  padding: 14px 16px;
  border-radius: 18px;
  background: #f8fafc;
  border: 1px solid var(--line);
  color: var(--muted);
  line-height: 1.7;
}

.notice.success { border-color: rgba(22,163,74,.22); background: rgba(22,163,74,.08); color: #166534; }
.notice.warning { border-color: rgba(245,158,11,.24); background: rgba(245,158,11,.10); color: #8a5600; }
.notice.danger { border-color: rgba(220,38,38,.22); background: rgba(220,38,38,.08); color: #991b1b; }

.steps {
  display: grid;
  gap: 12px;
}
.step {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 10px;
  align-items: start;
}
.step-num {
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  font-weight: 900;
}
.step strong { display: block; margin-bottom: 3px; }
.step span { color: var(--muted); line-height: 1.5; font-size: 14px; }

.result { display: none; margin-top: 18px; }
.result.active { display: block; }
.code-box {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin: 16px 0;
  padding: 18px;
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(83,109,254,.10), rgba(142,92,247,.10));
  border: 1px dashed rgba(83,109,254,.35);
}
.code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: clamp(30px, 10vw, 52px);
  letter-spacing: 8px;
  font-weight: 900;
  color: var(--primary-dark);
}

.admin-list { display: grid; gap: 10px; margin-top: 12px; }
.admin-item {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 8px;
  align-items: center;
  padding: 12px;
  border-radius: 16px;
  background: #fff;
  border: 1px solid var(--line);
}
.admin-item b { display: block; }
.admin-item small { color: var(--muted); }

.footer-note {
  margin-top: 18px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.7;
  text-align: center;
}

.admin-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 20px;
  align-items: start;
}

.sidebar {
  position: sticky;
  top: 18px;
}

.brand {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 18px;
}
.brand strong { font-size: 20px; }
.brand span { color: var(--muted); font-size: 13px; }

.nav { display: grid; gap: 10px; }
.nav button {
  text-align: left;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 13px 14px;
  background: #fff;
  cursor: pointer;
  font-weight: 700;
  color: var(--muted);
}
.nav button.active { color: var(--primary); border-color: rgba(83,109,254,.35); background: #f1f4ff; }

.toolbar {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}

.table-wrap {
  width: 100%;
  overflow-x: auto;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: #fff;
}

table { width: 100%; border-collapse: collapse; min-width: 860px; }
th, td { padding: 12px 14px; text-align: left; border-bottom: 1px solid var(--line); font-size: 14px; }
th { color: #4b5563; background: #f8fafc; }
td { color: #253047; }
tr:last-child td { border-bottom: 0; }

.status {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 0 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  background: #eef2ff;
  color: var(--primary-dark);
}
.status.verified { background: rgba(22,163,74,.12); color: #15803d; }
.status.rejected, .status.expired, .status.limited { background: rgba(220,38,38,.10); color: #b91c1c; }
.status.pending_verify { background: rgba(245,158,11,.14); color: #92400e; }

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.form-grid .span-2 { grid-column: span 2; }
.hidden { display: none !important; }

.toast {
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%) translateY(14px);
  padding: 12px 16px;
  border-radius: 999px;
  color: #fff;
  background: rgba(18, 24, 38, .92);
  opacity: 0;
  pointer-events: none;
  transition: .22s ease;
  z-index: 999;
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

@media (max-width: 860px) {
  .page-shell { padding: 18px 14px; }
  .hero { padding: 26px 22px; border-radius: 26px; }
  .grid, .admin-layout { grid-template-columns: 1fr; }
  .sidebar { position: static; }
  .card { padding: 20px; }
  .admin-item { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .form-grid .span-2 { grid-column: auto; }
}

.stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 10px;
}
.stat-card {
  border: 1px solid var(--line);
  border-radius: 20px;
  background: #fff;
  padding: 18px;
}
.stat-card span { display: block; color: var(--muted); font-size: 14px; margin-bottom: 8px; }
.stat-card strong { font-size: 36px; color: var(--primary-dark); }
.status.pending { background: rgba(245,158,11,.14); color: #92400e; }
.status.approved { background: rgba(83,109,254,.12); color: var(--primary-dark); }
.status.paid { background: rgba(22,163,74,.12); color: #15803d; }
.status.cancelled { background: rgba(107,114,128,.12); color: #4b5563; }
@media (max-width: 560px) { .stats { grid-template-columns: 1fr; } }
.muted { color: var(--muted); font-size: 13px; }
.file-input { padding-top: 13px; font-size: 14px; }

/* V5 报名入口：按手写流程重做，仅中文提示 */
.register-body {
  background:
    radial-gradient(circle at 16% 10%, rgba(91, 125, 255, .18), transparent 30%),
    radial-gradient(circle at 88% 20%, rgba(168, 85, 247, .16), transparent 28%),
    linear-gradient(180deg, #f6f8ff 0%, #eef3ff 100%);
}
.signup-shell {
  width: min(760px, 100%);
  margin: 0 auto;
  padding: 28px 16px 48px;
}
.signup-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.82);
  border-radius: 34px;
  background: rgba(255,255,255,.9);
  box-shadow: 0 24px 72px rgba(50, 64, 130, .16);
  padding: clamp(24px, 6vw, 42px);
  text-align: center;
  backdrop-filter: blur(16px);
}
.signup-card::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 10px;
  background: linear-gradient(90deg, #526dff, #8b5cf6, #38bdf8);
}
.school-line {
  display: inline-flex;
  padding: 8px 14px;
  border-radius: 999px;
  background: #eef2ff;
  color: #4051c8;
  font-weight: 800;
  font-size: 14px;
}
.activity-line {
  margin-top: 18px;
  color: #1f2a44;
  font-size: clamp(20px, 4.6vw, 32px);
  font-weight: 900;
  line-height: 1.25;
}
.signup-card h1 {
  margin: 16px 0 20px;
  font-size: clamp(38px, 12vw, 72px);
  letter-spacing: .08em;
  color: #111827;
}
.signup-form {
  width: min(420px, 100%);
  margin: 0 auto;
  text-align: left;
}
.center-label { text-align: left; }
.big-input {
  height: 58px;
  text-align: center;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: .04em;
}
.rule-row { justify-content: center; text-align: left; }
.text-link {
  border: 0;
  background: transparent;
  padding: 0;
  color: #4051c8;
  font: inherit;
  font-weight: 900;
  text-decoration: none;
  cursor: pointer;
}
.primary-big {
  min-height: 56px;
  font-size: 19px;
  border-radius: 18px;
}
.state-card {
  margin-top: 22px;
  text-align: left;
  border-radius: 24px;
  padding: 20px;
  line-height: 1.8;
}
.state-card h2 {
  margin: 0 0 10px;
  font-size: 24px;
  text-align: center;
}
.state-card p { margin: 8px 0; color: #374151; }
.ok-card { background: rgba(22,163,74,.08); border: 1px solid rgba(22,163,74,.22); }
.warn-card { background: rgba(245,158,11,.10); border: 1px solid rgba(245,158,11,.26); }
.verify-content {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  align-items: center;
  margin: 16px 0;
  padding: 14px;
  border-radius: 18px;
  background: #111827;
  color: white;
}
.verify-content strong {
  font-size: clamp(18px, 5vw, 30px);
  letter-spacing: .08em;
}
.manager-list { display: grid; gap: 12px; margin: 14px 0; }
.manager-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 14px;
  border-radius: 18px;
  background: white;
  border: 1px solid #e5e7eb;
}
.manager-item b { display: block; font-size: 16px; }
.manager-item span { display: block; color: #6b7280; margin-top: 2px; }
.manager-actions { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.reason-list {
  margin: 10px 0 0;
  padding-left: 22px;
  color: #374151;
  line-height: 1.9;
}
.warn-text { color: #7c2d12 !important; font-weight: 650; }
.state-actions { margin-top: 14px; display: flex; gap: 10px; justify-content: center; }
.rule-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(17, 24, 39, .48);
}
.rule-panel {
  width: min(620px, 100%);
  max-height: 84vh;
  overflow: auto;
  border-radius: 26px;
  background: white;
  padding: 24px;
  box-shadow: 0 24px 80px rgba(0,0,0,.2);
  line-height: 1.8;
  position: relative;
}
.rule-panel h2 { margin: 0 0 12px; text-align: center; }
.rule-panel p { color: #374151; }
.close-btn {
  position: absolute;
  top: 12px;
  right: 14px;
  width: 36px;
  height: 36px;
  border: 0;
  border-radius: 12px;
  background: #eef2ff;
  color: #3345c8;
  font-size: 24px;
  cursor: pointer;
}
@media (max-width: 560px) {
  .signup-shell { padding-top: 18px; }
  .signup-card { border-radius: 28px; }
  .verify-content { grid-template-columns: 1fr; text-align: center; }
  .manager-item { grid-template-columns: 1fr; text-align: center; }
  .manager-actions { justify-content: center; }
}

/* V8：三端统一视觉 + 手机优先 + 管理后台左侧菜单 */
:root {
  --v8-bg: #eef4ff;
  --v8-card: rgba(255,255,255,.94);
  --v8-text: #182033;
  --v8-muted: #667085;
  --v8-blue: #2563eb;
  --v8-indigo: #4f46e5;
  --v8-purple: #7c3aed;
  --v8-line: #dbe5f5;
  --v8-soft: #f6f8ff;
  --v8-shadow: 0 14px 40px rgba(31, 54, 116, .13);
}
body {
  background:
    radial-gradient(circle at 0% 0%, rgba(37,99,235,.16), transparent 30%),
    radial-gradient(circle at 95% 4%, rgba(124,58,237,.14), transparent 28%),
    linear-gradient(180deg, #f7faff 0%, var(--v8-bg) 100%);
  color: var(--v8-text);
}
.page-shell { width: min(1180px, 100%); padding: 18px 14px 48px; }
.card, .signup-card {
  background: var(--v8-card);
  border: 1px solid rgba(219,229,245,.92);
  border-radius: 20px;
  box-shadow: var(--v8-shadow);
  backdrop-filter: blur(12px);
}
.card h2 { font-size: 20px; margin-bottom: 8px; }
.card h3 { font-size: 16px; }
.card p { font-size: 14px; line-height: 1.7; }
.entry-hero {
  position: relative;
  overflow: hidden;
  border-radius: 22px;
  padding: 22px;
  color: #fff;
  background: linear-gradient(135deg, var(--v8-blue), var(--v8-indigo) 52%, var(--v8-purple));
  box-shadow: var(--v8-shadow);
}
.entry-hero::after {
  content: '';
  position: absolute;
  right: -44px;
  top: -54px;
  width: 150px;
  height: 150px;
  border-radius: 999px;
  background: rgba(255,255,255,.16);
}
.entry-hero .eyebrow, .hero .eyebrow {
  display: inline-flex;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.18);
  color: #fff;
  font-size: 12px;
  font-weight: 800;
}
.entry-hero h1 {
  position: relative;
  z-index: 1;
  margin: 14px 0 8px;
  font-size: clamp(24px, 6vw, 34px);
  line-height: 1.15;
  letter-spacing: 0;
}
.entry-hero p {
  position: relative;
  z-index: 1;
  margin: 0;
  color: rgba(255,255,255,.9);
  font-size: 14px;
  line-height: 1.75;
}
.compact-entry { grid-template-columns: minmax(0, .9fr) minmax(300px, .64fr); align-items: stretch; }
.compact-dashboard-hero { margin-bottom: 18px; }
.input {
  height: 48px;
  border-radius: 14px;
  border-color: var(--v8-line);
  font-size: 16px;
}
.input:focus { border-color: rgba(37,99,235,.72); box-shadow: 0 0 0 4px rgba(37,99,235,.12); }
.label { margin: 14px 0 7px; font-size: 14px; color: #344054; }
.btn {
  min-height: 44px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--v8-blue), var(--v8-purple));
  box-shadow: 0 10px 22px rgba(37,99,235,.18);
}
.btn.secondary { background: #edf3ff; color: #2451c7; border: 1px solid #dbe7ff; }
.btn.ghost { color: #2451c7; }
.btn.small { min-height: 34px; border-radius: 11px; font-size: 13px; padding: 0 11px; }
.notice { background: #f8fbff; border-color: var(--v8-line); }

/* 报名入口：保留你的手写流程，但视觉更干净 */
.register-body { background: linear-gradient(180deg, #f8fbff 0%, #edf4ff 100%); }
.signup-shell { width: min(680px, 100%); padding: 18px 12px 42px; }
.signup-card { padding: clamp(20px, 5vw, 34px); border-radius: 24px; }
.school-line.plain, .school-line {
  display: block;
  background: transparent;
  color: #1f2937;
  font-size: clamp(16px, 4.2vw, 22px);
  font-weight: 750;
  letter-spacing: .02em;
}
.activity-line.plain, .activity-line {
  margin-top: 8px;
  color: #172033;
  font-size: clamp(19px, 5.4vw, 27px);
  font-weight: 850;
  line-height: 1.35;
}
.signup-card h1 {
  margin: 22px 0 22px;
  font-size: clamp(36px, 10vw, 58px);
  font-weight: 650;
  letter-spacing: .16em;
}
.signup-form { width: min(390px, 100%); }
.big-input { height: 52px; border-radius: 14px; text-align: left; font-size: 19px; }
.primary-big { background: linear-gradient(135deg, #2457e7, #6d45e8); border-radius: 14px; }
.white-state h2 { font-size: clamp(22px, 6vw, 30px); }
.content-box { background: #f6f9ff; border-color: var(--v8-line); }
.content-code { color: #1d4ed8; }
.manager-item { background: #fbfdff; border-color: var(--v8-line); }
.manager-actions .btn:not(.secondary) { background: linear-gradient(135deg, var(--v8-blue), var(--v8-purple)); }

/* 管理后台：桌面左菜单，手机变成顶部按钮菜单 */
.admin-shell {
  display: grid;
  grid-template-columns: 228px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}
.admin-sidebar {
  position: sticky;
  top: 12px;
  padding: 16px;
}
.brand strong { font-size: 18px; }
.brand span { font-size: 12px; color: var(--v8-muted); }
.nav { gap: 8px; }
.nav button {
  border-radius: 13px;
  padding: 12px 13px;
  color: #40506a;
  background: #f9fbff;
  border-color: var(--v8-line);
  font-size: 14px;
}
.nav button.active {
  color: #fff;
  border-color: transparent;
  background: linear-gradient(135deg, var(--v8-blue), var(--v8-purple));
  box-shadow: 0 8px 18px rgba(37,99,235,.18);
}
.admin-content { min-width: 0; padding: 18px; }
.toolbar { gap: 10px; margin-bottom: 12px; align-items: flex-start; }
.toolbar h2 { margin: 0 0 5px; font-size: 20px; }
.toolbar p { margin: 0; color: var(--v8-muted); }
.table-wrap { border-radius: 14px; border-color: var(--v8-line); }
table { min-width: 820px; }
th, td { padding: 11px 12px; font-size: 13px; }
th { background: #f3f7ff; color: #344054; }
.form-grid { gap: 10px; }
.stats { gap: 10px; }
.stat-card { border-radius: 16px; padding: 14px; }
.stat-card strong { font-size: 30px; color: #2457e7; }

.copy-modal {
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: grid;
  place-items: center;
  padding: 16px;
  background: rgba(15, 23, 42, .48);
}
.copy-panel {
  width: min(560px, 100%);
  border-radius: 20px;
  background: #fff;
  padding: 20px;
  box-shadow: 0 24px 80px rgba(0,0,0,.24);
}
.copy-panel h2 { margin: 0 0 8px; font-size: 20px; }
.copy-panel p { margin: 0 0 12px; color: var(--v8-muted); line-height: 1.7; }
#copyTextArea {
  width: 100%;
  min-height: 150px;
  resize: vertical;
  border: 1px solid var(--v8-line);
  border-radius: 14px;
  padding: 12px;
  font-size: 15px;
  line-height: 1.7;
  color: #111827;
  background: #f8fbff;
}

@media (max-width: 860px) {
  .page-shell { padding: 12px 10px 38px; }
  .compact-entry, .grid, .admin-shell { grid-template-columns: 1fr; gap: 12px; }
  .entry-hero { padding: 18px; border-radius: 18px; }
  .entry-hero h1 { font-size: 26px; }
  .card, .signup-card { border-radius: 18px; padding: 16px; }
  .admin-sidebar {
    position: sticky;
    top: 0;
    z-index: 20;
    border-radius: 0 0 18px 18px;
    margin: -12px -10px 0;
    padding: 12px 10px;
  }
  .brand { margin-bottom: 10px; padding: 0 4px; }
  .nav {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 7px;
  }
  .nav button {
    text-align: center;
    padding: 10px 6px;
    font-size: 13px;
  }
  .admin-sidebar .btn.full { min-height: 40px; }
  .admin-content { padding: 14px; }
  .toolbar { display: grid; grid-template-columns: 1fr; }
  .toolbar .input, .toolbar select.input { max-width: none !important; width: 100%; }
  .table-wrap { margin-left: -2px; margin-right: -2px; }
  table { min-width: 760px; }
  .form-grid { grid-template-columns: 1fr; }
  .form-grid .span-2 { grid-column: auto; }
  .stats { grid-template-columns: 1fr 1fr; }
  .state-actions { flex-wrap: wrap; }
}
@media (max-width: 430px) {
  .nav { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .stats { grid-template-columns: 1fr; }
  .signup-card h1 { letter-spacing: .12em; }
}

/* 报名页底部图片：只在报名入口页面显示 */
.register-footer-image {
  display: flex;
  justify-content: center;
  margin: 14px auto 0;
  padding: 0 8px;
}
.register-footer-image img {
  display: block;
  width: min(76vw, 360px);
  height: auto;
  border-radius: 14px;
  box-shadow: 0 12px 32px rgba(40, 55, 110, .14);
  opacity: .96;
}
@media (max-width: 430px) {
  .register-footer-image { margin-top: 12px; }
  .register-footer-image img { width: min(84vw, 330px); border-radius: 12px; }
}

.name-confirm {
  margin: 14px 0 16px;
  padding: 18px;
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(99,102,241,.12), rgba(14,165,233,.12));
  font-size: 26px;
  font-weight: 900;
  color: #24335a;
  text-align: center;
  letter-spacing: .08em;
}
.group-card, .contact-block {
  margin-top: 16px;
}
.group-card {
  padding: 14px;
  border-radius: 18px;
  background: #f8fbff;
  border: 1px solid rgba(102,126,234,.18);
}
.success-state h2 { color: #1d9a63; }
.danger-state h2 { color: #d54848; }


/* 全站公告栏：内容完全由超级管理员后台设置，未开启或无内容时不显示 */
.announcement {
  margin: 0 0 16px;
  padding: 14px 16px;
  border: 1px solid rgba(83,109,254,.18);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(83,109,254,.10), rgba(142,92,247,.08));
  color: #26324c;
  box-shadow: 0 12px 30px rgba(83,109,254,.08);
  line-height: 1.75;
}
.signup-card .announcement { margin: 10px 0 18px; text-align: left; }
.announcement-title {
  font-weight: 900;
  margin-bottom: 6px;
  color: #2f46b6;
  font-size: 15px;
}
.announcement-content {
  font-size: 14px;
  color: #43506b;
  word-break: break-word;
}
.textarea {
  min-height: 120px;
  padding-top: 14px;
  padding-bottom: 14px;
  resize: vertical;
  line-height: 1.6;
}

/* VNext：手机端小弹出菜单，不再常驻占用大面积空间 */
.mobile-menu-bar {
  position: relative;
  z-index: 20;
  margin: 14px 0 18px;
  display: flex;
  justify-content: flex-start;
}
.menu-select-btn {
  border: 1px solid rgba(102,126,234,.22);
  background: linear-gradient(135deg, rgba(102,126,234,.12), rgba(14,165,233,.10));
  color: #26324c;
  border-radius: 999px;
  padding: 10px 15px;
  font-weight: 800;
  font-size: 14px;
  box-shadow: 0 12px 28px rgba(83,109,254,.10);
  max-width: 100%;
}
.menu-popover {
  position: absolute;
  top: 48px;
  left: 0;
  min-width: 190px;
  max-width: calc(100vw - 36px);
  padding: 8px;
  border-radius: 18px;
  border: 1px solid rgba(102,126,234,.18);
  background: rgba(255,255,255,.98);
  box-shadow: 0 22px 50px rgba(39,54,95,.18);
  display: grid;
  gap: 6px;
}
.menu-popover button {
  border: 0;
  border-radius: 13px;
  background: transparent;
  color: #26324c;
  font-weight: 800;
  padding: 11px 12px;
  text-align: left;
}
.menu-popover button.active,
.menu-popover button:hover {
  background: linear-gradient(135deg, rgba(102,126,234,.14), rgba(14,165,233,.10));
  color: #2f46b6;
}
.portal-menu-bar { margin-top: 18px; }
.portal-panel { margin-top: 16px; }

@media (max-width: 780px) {
  .admin-layout { display: block; }
  .admin-sidebar { display: none !important; }
  #adminMobileMenu { display: flex !important; }
  .admin-content { margin-top: 0; }
  .page-shell { padding-left: 14px; padding-right: 14px; }
}
@media (min-width: 781px) {
  #adminMobileMenu { display: none !important; }
}

/* 公告改为弹窗：关闭后不再常驻显示 */
.notice-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
  background: rgba(20,28,50,.42);
  backdrop-filter: blur(8px);
}
.notice-panel {
  position: relative;
  width: min(460px, 100%);
  max-height: min(76vh, 620px);
  overflow: auto;
  padding: 24px;
  border-radius: 26px;
  background: #fff;
  box-shadow: 0 30px 80px rgba(20,28,50,.25);
  border: 1px solid rgba(102,126,234,.16);
}
.notice-panel h2 {
  margin: 0 0 12px;
  font-size: 22px;
  color: #26324c;
}
.notice-modal-content {
  margin: 0 0 18px;
  line-height: 1.8;
  color: #43506b;
  word-break: break-word;
}

/* 个人中心分区 */
.checkin-card {
  margin-top: 16px;
  padding: 18px;
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(102,126,234,.14), rgba(14,165,233,.10));
  border: 1px solid rgba(102,126,234,.18);
}
.checkin-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-weight: 900;
  color: #26324c;
  margin-bottom: 14px;
}
.checkin-head b { color: #2f46b6; font-size: 22px; }
.checkin-row {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
}
.checkin-dot {
  border-radius: 16px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(102,126,234,.16);
  text-align: center;
  font-weight: 900;
  color: #8b96ae;
  padding: 10px 4px;
  line-height: 1.2;
}
.checkin-dot small { font-size: 11px; }
.checkin-dot.active {
  color: #fff;
  background: linear-gradient(135deg, #667eea, #14a5e9);
  box-shadow: 0 10px 24px rgba(83,109,254,.22);
}
.task-card {
  margin-top: 16px;
  padding: 16px;
  border-radius: 20px;
  background: #f8fbff;
  border: 1px solid rgba(102,126,234,.14);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}
.task-card h3 { margin: 0 0 6px; }
.task-card p { margin: 0; color: #6b7280; }
.qr-preview {
  margin-top: 12px;
  padding: 10px;
  border: 1px dashed rgba(102,126,234,.28);
  border-radius: 18px;
  background: #f8fbff;
  text-align: center;
}
.qr-preview img { max-width: 220px; max-height: 220px; border-radius: 12px; }
.payment-status-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 8px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(102,126,234,.10);
}
.payment-status-row:last-child { border-bottom: 0; }
.payment-status-row span { color: #6b7280; font-size: 13px; }
@media (max-width: 560px) {
  .checkin-row { gap: 5px; }
  .checkin-dot { border-radius: 12px; padding: 8px 2px; font-size: 12px; }
  .task-card { display: grid; }
  .payment-status-row { grid-template-columns: 1fr; }
}

/* 2026-06 功能整合补充样式 */
.dashboard-top-card{position:relative;margin-bottom:14px}.admin-top-card{grid-column:1/-1}.fixed-menu-bar{margin-bottom:14px}.mini-stats{margin-top:16px}.bell-btn{position:absolute;right:18px;top:18px;border:0;background:rgba(255,255,255,.92);border-radius:999px;width:44px;height:44px;box-shadow:0 10px 30px rgba(15,23,42,.14);cursor:pointer;font-size:20px}.bell-badge{position:absolute;right:-4px;top:-4px;background:#ef4444;color:#fff;border-radius:999px;min-width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:12px;padding:0 5px}.home-block{margin-top:16px}.weekly-row{grid-template-columns:repeat(7,minmax(48px,1fr));gap:8px}.checkin-dot.done{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border-color:transparent;box-shadow:0 10px 24px rgba(22,163,74,.25)}.checkin-dot.done small{color:#fff}.btn.disabled,.btn:disabled{opacity:.62;filter:grayscale(.35);cursor:not-allowed}.leaderboard-card{padding:18px;border-radius:20px;background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid rgba(148,163,184,.25)}.leaderboard-list{display:grid;gap:12px}.leaderboard-item{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:18px;background:#fff;box-shadow:0 12px 26px rgba(15,23,42,.08)}.leaderboard-item .medal{font-size:28px}.leaderboard-item div{flex:1;display:flex;flex-direction:column}.leaderboard-item span:not(.medal){color:#64748b;font-size:13px}.leaderboard-item strong{font-size:24px}.rank-1{background:linear-gradient(135deg,#fff7ed,#fffbeb);border:1px solid #fde68a}.rank-2{background:linear-gradient(135deg,#f8fafc,#eef2ff)}.rank-3{background:linear-gradient(135deg,#fff7ed,#fef2f2)}.editor-card{padding:18px;border-radius:18px;background:#f8fafc;border:1px solid rgba(148,163,184,.25);margin:14px 0}.toolbar-actions{display:flex;gap:10px;flex-wrap:wrap}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.settings-grid>div{padding:14px;border-radius:16px;background:#f8fafc;border:1px solid rgba(148,163,184,.25);display:flex;flex-direction:column;gap:5px}.settings-grid span{color:#475569}.payment-state{display:flex;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px dashed rgba(148,163,184,.35)}.app-modal{position:fixed;inset:0;background:rgba(15,23,42,.42);backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:18px}.app-modal.hidden{display:none}.app-modal-panel{position:relative;background:#fff;border-radius:24px;box-shadow:0 30px 80px rgba(15,23,42,.28);width:min(560px,100%);padding:28px}.modal-icon{width:64px;height:64px;border-radius:999px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto 12px}.modal-icon.hidden{display:none}.app-modal-panel h2{text-align:center;margin:4px 0 12px}.modal-body{line-height:1.8;color:#334155}.app-modal-panel .state-actions{justify-content:center;margin-top:18px}.notification-drawer{position:fixed;inset:0;background:rgba(15,23,42,.2);z-index:1900;display:flex;justify-content:flex-end}.notification-drawer.hidden{display:none}.notification-panel{width:min(420px,100%);height:100%;background:#fff;box-shadow:-24px 0 60px rgba(15,23,42,.18);padding:22px;overflow:auto}.notification-item{padding:14px;border-radius:16px;background:#f8fafc;margin-bottom:10px;border:1px solid rgba(148,163,184,.22);cursor:pointer}.notification-item.unread{background:#eff6ff;border-color:#93c5fd}.notification-item p{margin:6px 0;color:#475569}.notification-item span{font-size:12px;color:#64748b}.forget-link{margin-top:12px}.hidden.super-action{display:none!important}@media(max-width:760px){.weekly-row{grid-template-columns:repeat(4,1fr)}.admin-layout{display:block}.admin-sidebar{display:none}.admin-content{margin-top:14px}.bell-btn{right:12px;top:12px}.toolbar-actions{width:100%}.toolbar-actions .btn{flex:1}.app-modal-panel{padding:22px}}

/* 统一编辑态：进入新增/修改/设置后隐藏原列表，只保留当前表单 */
.editing-mode > :not(.active-editor) { display: none !important; }
.editing-mode > .active-editor { display: block !important; margin: 0; padding: 22px; background: linear-gradient(180deg,#ffffff,#f8fbff); border: 1px solid rgba(59,130,246,.18); box-shadow: 0 18px 42px rgba(15,23,42,.10); }
.active-editor::before { content: '请填写以下信息'; display: block; font-weight: 800; font-size: 20px; color: #0f172a; margin-bottom: 14px; }
.checkin-dot { min-height: 68px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; }
.checkin-dot.today:not(.done) { border-color: #60a5fa; background: #eff6ff; color: #1d4ed8; }
.checkin-dot small:empty { display: none; }
.success-pop { text-align: center; padding: 4px 0; }
.success-pop p { margin: 8px 0; }
.payment-state a { margin-left: 8px; }
.notification-item b { display:block; font-size: 15px; }
.notification-item:hover { transform: translateY(-1px); box-shadow: 0 12px 28px rgba(15,23,42,.08); }
.app-modal-panel { border: 1px solid rgba(255,255,255,.7); }
.modal-body small { display:block; text-align:center; color:#64748b; margin-top:10px; }

/* 实时同步与站内信可用性修复 */
.bell-btn { z-index: 60; pointer-events: auto; }
.notification-drawer { z-index: 2200; }
.notification-panel { position: relative; }
.notification-item { user-select: none; }
.inline-link { border: 0; background: transparent; padding: 0; font: inherit; cursor: pointer; }
.qr-viewer { text-align: center; }
.qr-viewer img { max-width: min(320px, 86vw); max-height: 56vh; border-radius: 16px; box-shadow: 0 14px 36px rgba(15,23,42,.16); background: #fff; }
.qr-viewer p { margin: 12px 0 0; color: #64748b; }
.notification-detail p { white-space: pre-wrap; word-break: break-word; }

/* clean-v2 refinements */
.one-stat { grid-template-columns: minmax(0, 1fr); }
.clickable-stat { width: 100%; border: 0; text-align: left; cursor: pointer; font: inherit; position: relative; }
.clickable-stat em { display:block; margin-top:6px; color:#64748b; font-style:normal; font-size:12px; }
.clickable-stat:hover { transform: translateY(-1px); box-shadow: 0 16px 34px rgba(37,99,235,.14); }
.chat-task-card { align-items: center; }
.checkin-card .btn { margin-top: 14px; }
.weekly-row { gap: 12px; }
.checkin-dot { min-height: 78px; padding: 10px 6px; }
.checkin-dot em { font-style: normal; font-size: 11px; opacity: .75; }
.checkin-dot.future { background:#f8fafc; border-color:#cbd5e1; color:#475569; }
.checkin-dot.missed { background:#f8fafc; border-color:#e2e8f0; color:#94a3b8; }
.checkin-dot.today:not(.done) { box-shadow: 0 10px 24px rgba(37,99,235,.14); }
.leaderboard-period { font-size: 13px; color: #64748b; margin: 0 0 10px; }
.notification-detail small { color:#64748b; }
@media (max-width:760px){ .weekly-row{grid-template-columns:repeat(3,1fr); gap:10px;} .checkin-dot{min-height:74px;} }

/* clean-v3: 站内信弹窗层级、收款码现代上传、数据维护 */
.app-modal { z-index: 3600; }
.notification-drawer { z-index: 3000; }
.payment-status-list { display: grid; gap: 10px; background: transparent; border: 0; padding: 0; }
.modern-payment-row { grid-template-columns: minmax(0,1fr) auto; padding: 14px 16px; border: 1px solid rgba(148,163,184,.24); border-radius: 16px; background: #f8fbff; box-shadow: 0 8px 18px rgba(15,23,42,.04); }
.modern-payment-row b { display:block; color:#0f172a; margin-bottom:4px; }
.modern-payment-row span { color:#64748b; }
.row-actions { display:flex; gap:8px; flex-wrap:wrap; justify-content:flex-end; }
.modern-upload-card { display:flex; align-items:center; justify-content:space-between; gap:14px; padding:18px; border:1px dashed rgba(37,99,235,.35); border-radius:20px; background:linear-gradient(180deg,#fff,#f8fbff); }
.upload-icon { width:52px; height:52px; flex:0 0 auto; border-radius:18px; display:grid; place-items:center; font-size:30px; color:#2563eb; background:#eaf2ff; font-weight:700; }
.modern-upload-card p { margin:4px 0 0; color:#64748b; }
.visually-hidden-file { position:absolute; left:-9999px; width:1px; height:1px; opacity:0; }
.maintenance-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(170px,1fr)); gap:10px; margin:8px 0 22px; padding:14px; border-radius:18px; background:#fff7f7; border:1px solid rgba(248,113,113,.22); }
@media(max-width:560px){ .modern-payment-row{grid-template-columns:1fr;} .row-actions{justify-content:flex-start;} .modern-upload-card{align-items:flex-start; flex-direction:column;} }


/* 20260610-clean-v4 refinements */
.chat-task-card p { line-height: 1.85; color: #475569; }
.podium-stage { display: grid; grid-template-columns: 1fr 1.18fr 1fr; gap: 12px; align-items: end; margin-top: 14px; padding: 18px 12px 12px; border-radius: 22px; background: linear-gradient(180deg,#fff7ed 0%,#f8fafc 100%); border: 1px solid rgba(251,191,36,.35); }
.podium-slot { min-height: 154px; border-radius: 22px 22px 14px 14px; padding: 16px 12px; text-align: center; display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 6px; box-shadow: 0 16px 32px rgba(15,23,42,.10); position: relative; overflow: hidden; }
.podium-slot::after { content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 30%; background: rgba(255,255,255,.28); }
.podium-slot > * { position: relative; z-index: 1; }
.podium-slot.rank-1 { min-height: 188px; background: linear-gradient(135deg,#f59e0b,#fef3c7); border: 1px solid #fbbf24; transform: translateY(-8px); }
.podium-slot.rank-2 { background: linear-gradient(135deg,#e5e7eb,#f8fafc); border: 1px solid #cbd5e1; }
.podium-slot.rank-3 { background: linear-gradient(135deg,#fed7aa,#fff7ed); border: 1px solid #fdba74; }
.podium-slot.empty { background: #f8fafc; border: 1px dashed #cbd5e1; color: #94a3b8; box-shadow: none; }
.podium-medal { font-size: 34px; }
.podium-slot b { font-size: 17px; color: #111827; }
.podium-slot span { color: #475569; font-size: 12px; }
.podium-slot strong { font-size: 28px; color: #0f172a; }
.podium-slot em { font-style: normal; font-size: 12px; color: #475569; }
.payment-combined-card { border: 1px solid rgba(148,163,184,.24); border-radius: 18px; padding: 12px; background: #f8fbff; gap: 0; }
.payment-card-title { font-weight: 800; color: #0f172a; padding: 2px 4px 10px; }
.payment-combined-card .modern-payment-row { border: 0; border-radius: 14px; box-shadow: none; background: transparent; padding: 12px 8px; }
.payment-combined-card .modern-payment-row + .modern-payment-row { border-top: 1px dashed rgba(148,163,184,.35); }
.compact-payment-row .row-actions { gap: 8px; }
.status { display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; padding: 4px 10px; font-weight: 800; white-space: nowrap; }
.status.rejected { background: rgba(220,38,38,.10); color: #b91c1c; }
.status.approved { background: rgba(22,163,74,.12); color: #15803d; }
.status.pending { background: rgba(245,158,11,.14); color: #92400e; }
@media(max-width:760px){ .podium-stage { grid-template-columns: 1fr; align-items: stretch; } .podium-slot.rank-1 { transform: none; order: -1; } }

/* lucky-v1: 统一后台药丸菜单、煲塔与移动端优化 */
@media(max-width:760px){
  .admin-shell {
    display: block !important;
  }
  .admin-sidebar {
    display: none !important;
  }
  #adminMobileMenu {
    display: flex !important;
    margin: 0 0 16px;
  }
  .admin-content {
    margin-top: 0 !important;
  }
  .admin-top-card {
    margin-bottom: 12px;
  }
  .menu-select-btn {
    min-height: 44px;
  }
  .menu-popover {
    z-index: 1000;
  }
}
.asset-stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.asset-stats .stat-card {
  min-height: 128px;
  background: linear-gradient(180deg,#ffffff,#f8fbff);
  box-shadow: 0 12px 28px rgba(37,99,235,.08);
}
.asset-stats .cash-stat strong {
  color: #16a34a;
}
.lucky-bag-card {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  padding: 20px;
  background:
    radial-gradient(circle at 10% 0%, rgba(251,191,36,.38), transparent 32%),
    radial-gradient(circle at 92% 12%, rgba(239,68,68,.18), transparent 28%),
    linear-gradient(135deg,#fff7ed,#fff1f2 48%,#eef2ff);
  border: 1px solid rgba(251,146,60,.28);
  box-shadow: 0 20px 50px rgba(180,83,9,.12);
  display: grid;
  grid-template-columns: minmax(0,1fr) auto;
  gap: 18px;
  align-items: center;
}
.lucky-bag-card::after {
  content: '';
  position: absolute;
  width: 180px;
  height: 180px;
  right: -70px;
  bottom: -90px;
  border-radius: 999px;
  background: rgba(255,255,255,.52);
}
.lucky-bag-main {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 16px;
}
.lucky-icon {
  width: 62px;
  height: 62px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 900;
  font-size: 26px;
  background: linear-gradient(135deg,#ef4444,#f97316);
  box-shadow: 0 16px 34px rgba(239,68,68,.28);
}
.lucky-bag-card h3 {
  margin: 0 0 6px;
  font-size: 22px;
  color: #7c2d12;
}
.lucky-bag-card p {
  margin: 0 0 10px;
  color: #7c2d12;
  line-height: 1.65;
}
.lucky-progress {
  height: 10px;
  width: min(380px,100%);
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(251,146,60,.22);
  border-radius: 999px;
  overflow: hidden;
}
.lucky-progress span {
  display: block;
  height: 100%;
  width: 0;
  border-radius: inherit;
  background: linear-gradient(90deg,#f97316,#ef4444);
  transition: width .28s ease;
}
#luckyProgressText {
  display: block;
  margin-top: 6px;
  color: #9a3412;
}
.lucky-btn {
  position: relative;
  z-index: 1;
  white-space: nowrap;
  min-width: 132px;
  box-shadow: 0 14px 32px rgba(239,68,68,.18);
}
.lucky-bag-card.ready {
  border-color: rgba(239,68,68,.32);
  box-shadow: 0 24px 58px rgba(239,68,68,.18);
}
.lucky-bag-card.ready .lucky-icon {
  animation: luckyPulse 1.4s ease-in-out infinite;
}
@keyframes luckyPulse {
  0%,100% { transform: translateY(0) rotate(0); }
  50% { transform: translateY(-3px) rotate(-2deg); }
}
.cash-reward-summary {
  padding: 14px 16px;
  border-radius: 18px;
  background: linear-gradient(135deg,#f0fdf4,#eff6ff);
  border: 1px solid rgba(34,197,94,.20);
  color: #14532d;
  margin-bottom: 12px;
  line-height: 1.7;
}
.lucky-modal {
  text-align: center;
  padding: 8px 0;
}
.lucky-modal b {
  color: #dc2626;
  font-size: 20px;
}
.detail-list {
  display: grid;
  gap: 10px;
}
.detail-list > div {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 10px 12px;
  border-radius: 14px;
  background: #f8fafc;
  border: 1px solid rgba(148,163,184,.20);
}
.detail-list b { color: #0f172a; }
.detail-list span { color: #475569; text-align: right; }
.agreement-panel {
  max-height: min(78vh, 760px);
  overflow: auto;
  line-height: 1.8;
}
.agreement-panel h3 {
  margin: 16px 0 6px;
  color: #1e3a8a;
}
.rule-row {
  margin-top: 14px;
  align-items: flex-start;
}
.rule-row .text-link {
  vertical-align: baseline;
}
@media (max-width: 760px) {
  .asset-stats {
    grid-template-columns: 1fr;
  }
  .lucky-bag-card {
    grid-template-columns: 1fr;
    padding: 18px;
  }
  .lucky-bag-main {
    align-items: flex-start;
  }
  .lucky-icon {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    font-size: 22px;
  }
  .lucky-btn {
    width: 100%;
  }
  .weekly-row,
  .checkin-row {
    display: grid;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  .checkin-dot {
    min-height: auto !important;
    padding: 12px 14px !important;
    border-radius: 16px !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    text-align: left !important;
    font-size: 14px !important;
  }
  .checkin-dot small,
  .checkin-dot em {
    margin-left: auto;
    font-size: 12px;
  }
  .detail-list > div {
    display: grid;
  }
  .detail-list span { text-align: left; }
  .toolbar .input#auditSearch { min-width: 100%; }
}

/* zongping helper */
.zongping-page {
  background: linear-gradient(135deg, #f7fbff 0%, #eef6f2 48%, #f8f5ff 100%);
}
.zongping-shell {
  width: min(1240px, 100%);
}
.zongping-hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  padding: 28px;
  border: 1px solid rgba(255,255,255,.82);
  border-radius: 22px;
  background: linear-gradient(135deg, #123c69, #2f6f73 52%, #6d5b9a);
  color: #fff;
  box-shadow: 0 22px 58px rgba(18,60,105,.18);
}
.zongping-hero h1 { margin: 12px 0 8px; font-size: clamp(30px, 5vw, 52px); letter-spacing: 0; }
.zongping-hero p { max-width: 760px; color: rgba(255,255,255,.88); line-height: 1.75; }
.zongping-hero .eyebrow { color: rgba(255,255,255,.78); }
.zongping-hero-actions { display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.zongping-intro-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, .8fr);
  gap: 18px;
  margin-top: 18px;
}
.zongping-intro-card { grid-row: span 2; }
.zongping-rich-text p,
.zongping-declaration p { margin: 8px 0; line-height: 1.8; }
.zongping-status-box { display: grid; gap: 10px; color: var(--muted); line-height: 1.7; }
.zongping-app {
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr) 270px;
  gap: 18px;
  margin-top: 18px;
  align-items: start;
}
.zongping-flow {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
  margin-top: 18px;
  align-items: start;
}
.zongping-flow-head,
.zongping-page-step,
.zongping-tool-reserve {
  width: 100%;
  box-sizing: border-box;
}
.zongping-page-step {
  max-width: 920px;
  margin: 0 auto;
}
.zongping-flow .zongping-step-list {
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}
.zongping-step-panel {
  margin-top: 12px;
}
.zongping-progress,
.zongping-side { position: sticky; top: 18px; }
.zongping-progress-bar {
  height: 10px;
  border-radius: 999px;
  background: #e8edf3;
  overflow: hidden;
  margin: 10px 0 16px;
}
.zongping-progress-bar span {
  display: block;
  height: 100%;
  width: 0;
  border-radius: inherit;
  background: linear-gradient(90deg, #2f6f73, #7c5fb7);
  transition: width .25s ease;
}
.zongping-step-list { display: grid; gap: 9px; }
.zongping-step-pill {
  width: 100%;
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 10px;
  align-items: center;
  text-align: left;
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 8px;
  padding: 10px;
  cursor: default;
  pointer-events: none;
}
.zongping-step-pill span {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  background: #eef6f2;
  color: #2f6f73;
  font-weight: 900;
}
.zongping-step-pill small { display: block; color: var(--muted); margin-top: 2px; }
.zongping-step-pill.active {
  border-color: rgba(47,111,115,.42);
  box-shadow: 0 10px 28px rgba(47,111,115,.12);
}
.zongping-step-pill.active span { background: #2f6f73; color: #fff; }
.zongping-mode-badge {
  padding: 8px 12px;
  border-radius: 999px;
  background: #eef6f2;
  color: #2f6f73;
  font-weight: 800;
}
.zongping-mode-badge.experience { background: #fff6dc; color: #8a5600; }
.zongping-save-state { color: var(--muted); font-size: 13px; }
.zongping-question-card,
.zongping-upload-card {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fbfcff;
  padding: 16px;
  margin: 12px 0;
}
.question-title { font-size: 18px; font-weight: 900; }
.zongping-textarea { min-height: 180px; padding-top: 14px; resize: vertical; line-height: 1.7; }
.zongping-word-row,
.zongping-tool-row,
.zongping-nav-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 10px;
}
.zongping-word-row { justify-content: space-between; color: var(--muted); font-size: 14px; }
.zongping-upload-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}
.zongping-upload-card h3 { margin: 0 0 4px; }
.zongping-upload-card p { margin: 0; color: var(--muted); }
.zongping-attachment-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 12px;
  margin: 12px 0;
}
.attachment-card {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
}
.attachment-card img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
  background: #f3f4f6;
}
.attachment-meta { padding: 10px; display: grid; gap: 3px; }
.attachment-meta b { font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.attachment-meta small { color: var(--muted); }
.attachment-actions { padding: 0 10px 10px; display: flex; gap: 8px; }
.zongping-side .btn { margin-top: 10px; }
.zongping-public-entry { margin-top: 18px; }
.zongping-declaration-mini { margin-bottom: 14px; }
.zongping-detail-block { border-bottom: 1px solid var(--line); padding: 10px 0; }
.code-list { display: grid; gap: 8px; font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }

@media (max-width: 980px) {
  .zongping-app,
  .zongping-flow,
  .zongping-intro-grid {
    grid-template-columns: 1fr;
  }
  .zongping-progress,
  .zongping-side {
    position: static;
  }
  .zongping-hero {
    align-items: flex-start;
    flex-direction: column;
  }
  .zongping-hero-actions {
    justify-content: flex-start;
  }
  .zongping-flow .zongping-step-list {
    display: flex;
    overflow-x: auto;
    gap: 10px;
    padding-bottom: 4px;
    -webkit-overflow-scrolling: touch;
  }
  .zongping-flow .zongping-step-pill {
    min-width: 170px;
    flex: 0 0 auto;
  }
}

@media (max-width: 640px) {
  .zongping-hero,
  .zongping-editor,
  .zongping-progress,
  .zongping-side,
  .zongping-page-step,
  .zongping-tool-reserve {
    border-radius: 14px;
    padding: 16px;
  }
  .zongping-upload-card,
  .zongping-nav-actions {
    align-items: stretch;
    flex-direction: column;
  }
  .zongping-upload-card .btn,
  .zongping-nav-actions .btn {
    width: 100%;
  }
  .zongping-attachment-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* 20260610-v2: 权限、站内信、分页、反馈、煲塔与排行榜优化 */
.menu-dot{
  display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;margin-left:6px;padding:0 6px;border-radius:999px;background:#ef4444;color:#fff;font-size:11px;font-weight:900;vertical-align:middle;box-shadow:0 8px 18px rgba(239,68,68,.28)
}
.pager{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;padding:10px 0;color:#64748b;font-size:13px}.pager-row td{background:#fff!important}.pager .btn[disabled]{opacity:.45;cursor:not-allowed}.small{font-size:12px;padding:7px 10px}.claim-amount-preview{margin:10px 0 14px;padding:13px 14px;border-radius:16px;background:linear-gradient(135deg,#f0fdf4,#eff6ff);border:1px solid rgba(34,197,94,.22);color:#14532d;font-weight:800}.permission-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px;text-align:left}.permission-group{border:1px solid rgba(148,163,184,.24);border-radius:18px;padding:14px;background:#f8fafc}.permission-group h4{margin:0 0 10px;color:#0f172a}.settings-subnav{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0 18px;padding:8px;border-radius:18px;background:#f8fafc;border:1px solid rgba(148,163,184,.22)}.settings-subnav button{border:0;background:transparent;padding:10px 14px;border-radius:999px;font-weight:800;color:#475569;cursor:pointer}.settings-subnav button.active{background:#fff;color:#2563eb;box-shadow:0 10px 24px rgba(37,99,235,.12)}.settings-subpanel{animation:panelFade .18s ease}.feedback-detail{display:grid;gap:10px}.feedback-detail p{margin:0}.feedback-detail-box{padding:12px 14px;border-radius:16px;background:#f8fafc;border:1px solid rgba(148,163,184,.22);white-space:pre-wrap}.status.processing{background:rgba(59,130,246,.12);color:#1d4ed8}.status.resolved{background:rgba(34,197,94,.12);color:#15803d}.status.closed{background:rgba(100,116,139,.12);color:#475569}.notification-split-panel{width:min(840px,100%);padding:24px}.notification-split{display:grid;grid-template-columns:minmax(260px,320px) minmax(0,1fr);gap:16px;height:calc(100% - 86px)}.notification-list-pane{overflow:auto;padding-right:4px}.notification-detail-pane{border:1px solid rgba(148,163,184,.22);border-radius:22px;background:linear-gradient(180deg,#fff,#f8fbff);padding:18px;overflow:auto;min-height:220px}.notification-detail-pane h3{margin:0 0 10px}.notification-detail-pane p{line-height:1.85;white-space:pre-wrap}.notification-item.active{border-color:#2563eb;background:#eff6ff;box-shadow:0 14px 28px rgba(37,99,235,.12)}.notification-item.unread b::after{content:'未读';display:inline-flex;margin-left:8px;padding:2px 6px;border-radius:999px;background:#ef4444;color:#fff;font-size:10px;vertical-align:middle}.lucky-bag-svg svg{width:40px;height:40px;display:block}.lucky-bag-svg{color:#fff;background:linear-gradient(135deg,#ef4444,#f59e0b)}.lucky-open-card,.lucky-result-card{text-align:center;position:relative;overflow:hidden;border-radius:26px;padding:22px;background:radial-gradient(circle at 20% 0%,rgba(251,191,36,.42),transparent 34%),radial-gradient(circle at 86% 12%,rgba(239,68,68,.20),transparent 28%),linear-gradient(135deg,#fff7ed,#fff1f2 52%,#eef2ff);border:1px solid rgba(251,146,60,.28)}.lucky-open-icon{width:118px;height:118px;margin:0 auto 10px;border-radius:32px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#ef4444,#f97316);box-shadow:0 24px 50px rgba(239,68,68,.30);animation:luckyShake 1.3s ease-in-out infinite}.lucky-open-icon svg{width:76px;height:76px}.lucky-open-card h3{margin:8px 0;color:#7c2d12;font-size:26px}.lucky-open-card p,.lucky-result-card p{color:#7c2d12;margin:8px 0;line-height:1.75}.lucky-confirm{background:linear-gradient(135deg,#ef4444,#f97316);box-shadow:0 14px 34px rgba(239,68,68,.24)}.lucky-result-card .amount{font-size:52px;line-height:1;font-weight:1000;color:#dc2626;text-shadow:0 10px 24px rgba(239,68,68,.18);margin:8px 0 10px}.lucky-result-card .amount span{font-size:20px;margin-left:4px}.lucky-result-card .confetti{letter-spacing:10px;color:#f59e0b;font-weight:900;font-size:22px;animation:confettiFloat 1.2s ease-in-out infinite}.cash-reward-summary .cash-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px dashed rgba(148,163,184,.30)}.cash-reward-summary .cash-row:last-child{border-bottom:0}.cash-reward-summary .cash-row b{color:#14532d}.leaderboard-card{background:linear-gradient(180deg,#fff,#f8fbff);border-color:rgba(251,191,36,.22);box-shadow:0 18px 44px rgba(15,23,42,.08)}.podium-stage{grid-template-columns:minmax(0,1fr) minmax(0,1.35fr) minmax(0,1fr);gap:18px;padding:28px 22px 18px;background:radial-gradient(circle at 50% 0%,rgba(251,191,36,.35),transparent 34%),linear-gradient(180deg,#fffbeb,#fff 58%,#f8fafc);box-shadow:inset 0 1px 0 rgba(255,255,255,.75)}.podium-slot{min-height:176px;border-radius:28px 28px 18px 18px}.podium-slot.rank-1{min-height:228px;transform:translateY(-16px);box-shadow:0 26px 60px rgba(245,158,11,.22)}.podium-medal{font-size:42px}.podium-slot strong{font-size:34px}.leaderboard-rest{margin-top:14px;display:grid;gap:8px}.leaderboard-row{display:grid;grid-template-columns:52px minmax(0,1fr) auto;align-items:center;gap:10px;padding:12px 14px;border-radius:16px;background:#fff;border:1px solid rgba(148,163,184,.18)}.leaderboard-row span{color:#64748b;font-weight:800}.leaderboard-row b{color:#0f172a}.leaderboard-row em{font-style:normal;font-weight:900;color:#2563eb}.checkin-card{padding:20px;border-radius:22px;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid rgba(148,163,184,.22)}.checkin-row.weekly-row{grid-template-columns:repeat(auto-fit,minmax(96px,1fr));gap:10px}.checkin-dot{border-radius:18px!important;min-height:74px!important}.form-grid .span-2.notice{padding:12px 14px;border-radius:14px;background:#fff7ed;border:1px solid rgba(251,146,60,.25);color:#9a3412}.table-wrap table .pager-row:hover{background:transparent!important}
@keyframes luckyShake{0%,100%{transform:translateY(0) rotate(0)}30%{transform:translateY(-5px) rotate(-3deg)}60%{transform:translateY(2px) rotate(3deg)}}@keyframes confettiFloat{0%,100%{transform:translateY(0);opacity:.9}50%{transform:translateY(-5px);opacity:1}}@keyframes panelFade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
@media(max-width:760px){.notification-drawer{justify-content:center}.notification-panel{width:100%;height:100%;border-radius:0}.notification-split{grid-template-columns:1fr;height:auto}.notification-detail-pane{min-height:180px}.settings-subnav{overflow:auto;flex-wrap:nowrap}.settings-subnav button{white-space:nowrap}.permission-grid{grid-template-columns:1fr}.podium-stage{grid-template-columns:1fr;padding:16px;gap:12px}.podium-slot{min-height:auto!important;padding:18px}.podium-slot.rank-1{transform:none;order:-1}.leaderboard-row{grid-template-columns:42px minmax(0,1fr) auto}.checkin-row.weekly-row{grid-template-columns:1fr!important}.lucky-open-icon{width:98px;height:98px}.lucky-open-icon svg{width:62px;height:62px}.lucky-result-card .amount{font-size:42px}.asset-stats{grid-template-columns:1fr!important}}

/* 20260611-registration-verification */
.signup-title {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 22px auto 8px !important;
  padding: 8px 18px 10px;
  border-radius: 24px;
  background: linear-gradient(135deg, rgba(37,99,235,.12), rgba(139,92,246,.14));
  color: #12306b !important;
  letter-spacing: .08em !important;
  font-weight: 900 !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8), 0 18px 38px rgba(37,99,235,.12);
}
.signup-title::before,
.signup-title::after {
  content: '';
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, #2563eb, #8b5cf6);
  box-shadow: 0 0 0 6px rgba(37,99,235,.08);
}
.signup-title::before { margin-right: 14px; }
.signup-title::after { margin-left: 14px; }
.signup-subtitle {
  margin: 0 auto 20px;
  color: #64748b;
  font-weight: 700;
}
.register-footer-image { align-items: center; }
@media (min-width: 760px) {
  .register-footer-image { justify-content: center; padding-left: 0; padding-right: 0; }
  .register-footer-image img { width: 360px; object-fit: contain; }
}
.verify-choice-form { display: grid; gap: 12px; margin-top: 16px; text-align: left; }
.verify-option-card {
  display: grid;
  grid-template-columns: auto 52px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 16px;
  border-radius: 20px;
  border: 1px solid rgba(148,163,184,.28);
  background: #fff;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(15,23,42,.05);
  transition: .18s ease;
}
.verify-option-card.active {
  border-color: rgba(37,99,235,.55);
  background: linear-gradient(180deg,#ffffff,#eff6ff);
  box-shadow: 0 18px 38px rgba(37,99,235,.13);
}
.verify-option-card input { width: 18px; height: 18px; }
.verify-option-icon {
  width: 52px;
  height: 52px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  font-weight: 900;
  font-size: 22px;
  color: #2563eb;
  background: #eaf2ff;
}
.verify-option-card b { display: block; color: #0f172a; margin-bottom: 4px; }
.verify-option-card em { display: block; font-style: normal; color: #64748b; line-height: 1.65; font-size: 13px; }
.profile-proof-box { display: grid; gap: 12px; }
.profile-proof-box.hidden { display: none !important; }
.agreement-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0 16px;
}
.agreement-meta span {
  padding: 6px 10px;
  border-radius: 999px;
  background: #eef2ff;
  color: #334155;
  font-size: 12px;
  font-weight: 800;
}
.ai-statement {
  margin-top: 18px !important;
  padding-top: 14px;
  border-top: 1px dashed rgba(148,163,184,.45);
}
.rule-panel.agreement-panel,
.rule-panel { max-height: min(84vh, 760px); overflow: auto; }
@media (max-width: 560px) {
  .verify-option-card { grid-template-columns: auto minmax(0, 1fr); }
  .verify-option-icon { display: none; }
  .signup-title { letter-spacing: .04em !important; }
}

/* 2026-06-11 final package guard: device matched UI */
html[data-device] body::before{content:'';display:none}
.admin-logged-out #adminView{display:none!important}.admin-logged-in #loginView{display:none!important}
.signup-title{font-size:clamp(30px,6vw,48px)!important;letter-spacing:.08em!important;color:#0f172a!important;background:none!important;text-shadow:none!important;margin:14px 0 18px!important}.signup-title span{background:linear-gradient(135deg,#0f172a,#2563eb);-webkit-background-clip:text;background-clip:text;color:transparent}.signup-title::before,.signup-title::after{opacity:.22!important;width:36px!important;height:2px!important}.signup-subtitle{display:none!important}.center-label{text-align:left!important;display:block;margin:0 0 8px 4px}.big-input::placeholder{color:#94a3b8}.filter-toolbar{align-items:stretch}.filter-toolbar .input{min-width:180px}
.bell-btn.inbox-btn{appearance:none;border:1px solid rgba(37,99,235,.20);background:linear-gradient(135deg,#fff,#eff6ff);color:#2563eb;border-radius:999px;min-width:0;width:auto;height:44px;padding:0 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 14px 34px rgba(37,99,235,.16);line-height:1;white-space:nowrap;transform:none!important}.bell-btn.inbox-btn .inbox-icon{width:24px;height:24px;display:grid;place-items:center;flex:0 0 24px}.bell-btn.inbox-btn svg{display:block;width:22px;height:22px}.bell-btn.inbox-btn .inbox-text{font-size:14px;font-weight:900}.bell-badge{position:absolute;top:-7px;right:-7px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;background:#ef4444;color:#fff;font-size:11px;display:inline-flex;align-items:center;justify-content:center;border:2px solid #fff}.bell-badge.hidden{display:none!important}
.verify-choice-form .notice.warning{display:none}.profile-proof-box:not(.hidden){display:grid;gap:12px}.modern-upload-card{align-items:center}.permission-grid{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px}.permission-group{border-radius:20px}.permission-group .checkbox-row{align-items:flex-start;padding:9px 0}.settings-subnav button,.nav button,.menu-popover button{border-radius:999px!important}.pager{font-size:13px}
@media(max-width:760px){html.device-phone .page-shell,html.device-ios-phone .page-shell,html.device-android-phone .page-shell{padding:12px}html.device-phone .admin-top-card{padding-top:62px}.bell-btn.inbox-btn{height:42px;padding:0 12px;border-radius:999px!important}.bell-btn.inbox-btn .inbox-text{display:inline;font-size:13px}.admin-top-card .bell-btn.inbox-btn,.dashboard-top-card .bell-btn.inbox-btn{top:12px;right:12px}.mobile-menu-bar .menu-select-btn,.menu-popover button{border-radius:999px!important}.notification-drawer{position:fixed!important;inset:0!important;display:block!important;background:#fff!important;z-index:5000!important;padding:0!important}.notification-drawer.hidden{display:none!important}.notification-panel,.notification-split-panel{width:100%!important;height:100%!important;max-width:none!important;border-radius:0!important;box-shadow:none!important;padding:16px!important}.notification-split{display:grid!important;grid-template-columns:1fr!important;height:auto!important;gap:12px}.notification-detail-pane{min-height:160px}.permission-grid{display:grid!important;grid-template-columns:1fr!important}.permission-group{padding:14px;border-radius:20px;background:#fff}.permission-group .checkbox-row{border-bottom:1px dashed rgba(148,163,184,.25)}.permission-group .checkbox-row:last-child{border-bottom:0}.filter-toolbar{display:grid!important;grid-template-columns:1fr!important}.filter-toolbar .input{width:100%;min-width:0}.signup-title{font-size:34px!important}.signup-card{border-radius:28px}.table-wrap{overflow-x:auto}}
@media(min-width:761px) and (max-width:1180px){html[data-device-family="tablet"] .admin-layout{grid-template-columns:1fr}html[data-device-family="tablet"] .admin-sidebar{display:none}html[data-device-family="tablet"] .permission-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.notification-split-panel{width:min(820px,calc(100vw - 40px))}}

/* full checked fix: make module submenus and permission editor easier to use on touch devices */
.module-subnav{position:relative;align-items:center}.module-subnav button{min-height:40px}.point-subpanel,.student-subpanel{animation:panelFade .18s ease}.student-subpanel .editor-card,.point-subpanel .editor-card{margin-top:12px}.app-modal-panel:has(.permission-grid){width:min(920px,100%);max-height:min(90vh,860px);overflow:auto}.permission-group .checkbox-row{border-radius:12px;padding:9px 8px}.permission-group .checkbox-row:hover{background:rgba(37,99,235,.06)}@media(max-width:760px){.app-modal{align-items:stretch;padding:10px}.app-modal-panel:has(.permission-grid){width:100%;height:100%;max-height:none;border-radius:24px;padding:18px;overflow:auto}.permission-grid{grid-template-columns:1fr!important;gap:12px}.module-subnav{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}.module-subnav button{white-space:nowrap;flex:0 0 auto}.student-subpanel .editor-card,.point-subpanel .editor-card{padding:14px;border-radius:20px}.student-subpanel .form-grid,.point-subpanel .form-grid{grid-template-columns:1fr}}

/* 20260611 event-repair: compact UI, event codes, upload polish */
.signup-title{font-size:clamp(22px,4.2vw,32px)!important;letter-spacing:.03em!important;margin:10px 0 14px!important;font-weight:800!important;color:#1e293b!important}
.signup-title span{background:none!important;color:#1e293b!important;-webkit-text-fill-color:#1e293b!important}
.signup-title::before,.signup-title::after{width:22px!important;opacity:.14!important}
.signup-shell{min-height:100vh;display:grid;grid-template-columns:minmax(320px,480px) minmax(260px,440px);align-items:center;justify-content:center;gap:26px;padding:28px}
.register-footer-image{margin-top:0;display:flex;justify-content:center;align-items:center;max-width:440px}
.register-footer-image img{width:min(38vw,420px)!important;max-height:min(62vh,520px);object-fit:contain;border-radius:22px;filter:drop-shadow(0 18px 42px rgba(15,23,42,.12))}
.manager-list{display:grid;gap:10px;margin:12px 0}.manager-item{padding:10px 12px!important;border-radius:16px!important;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center}.manager-info b{font-size:14px}.manager-info span{font-size:12px}.manager-actions{display:flex;gap:8px;flex-wrap:wrap}.manual-apply-card .contact-block,.white-state .contact-block{margin-top:12px}.verify-action-panel{position:sticky;bottom:8px;background:rgba(255,255,255,.94);backdrop-filter:blur(10px);border:1px solid rgba(148,163,184,.24);border-radius:18px;padding:12px;margin-top:14px;box-shadow:0 18px 44px rgba(15,23,42,.12)}
.event-chip{display:inline-flex;align-items:center;min-height:22px;padding:2px 8px;margin-right:6px;border-radius:999px;background:#eef2ff;color:#3730a3;font-size:12px;font-weight:900;letter-spacing:.02em}.badge.mini{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:999px;background:#ef4444;color:#fff;font-size:11px;margin-left:5px;padding:0 5px}.badge.mini.hidden{display:none!important}.feedback-split-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;align-items:start}.maintenance-check-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px}.maintenance-check-grid label{padding:12px 14px;border:1px solid rgba(148,163,184,.25);border-radius:16px;background:#fff;display:flex;gap:8px;align-items:center;font-weight:700}.upload-drop{border:1px dashed rgba(37,99,235,.32);background:linear-gradient(180deg,#fff,#f8fbff);border-radius:20px;padding:16px}.file-modern{padding:14px!important;background:#fff!important}.settings-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.admin-list-card,.permission-group{padding:12px!important}.permission-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))!important}.status.approved{background:#dbeafe!important;color:#1d4ed8!important;border-color:#bfdbfe!important}
@media(max-width:900px){.signup-shell{grid-template-columns:1fr;padding:16px}.register-footer-image{max-width:none}.register-footer-image img{width:min(82vw,360px)!important;max-height:280px}.manager-item{grid-template-columns:1fr}.feedback-split-grid{grid-template-columns:1fr}.verify-action-panel{bottom:6px}.signup-title{font-size:26px!important}}


/* 20260611 scope-confirmed repair: registration layout, pills, natural event code */
.signup-shell{max-width:min(960px, calc(100vw - 36px));display:grid;grid-template-columns:minmax(360px,520px) minmax(240px,360px);gap:26px;align-items:center;margin:34px auto;padding:0;}
.signup-card{width:100%;max-width:520px;margin:0;box-shadow:0 24px 70px rgba(15,23,42,.14);}
.register-footer-image{width:100%;max-width:360px;justify-self:center;border-radius:30px;overflow:hidden;box-shadow:0 18px 54px rgba(15,23,42,.12);background:#fff;}
.register-footer-image img{width:100%;height:auto;max-height:420px;object-fit:cover;display:block;}
.signup-title span{font-size:clamp(26px,3vw,38px);letter-spacing:.08em;font-weight:900;background:linear-gradient(135deg,#1e3a8a,#2563eb);-webkit-background-clip:text;background-clip:text;color:transparent;}
.register-flow-card{max-width:680px;margin:0 auto;}
.contact-priority-block{display:flex;flex-direction:column;gap:14px;margin:18px 0;}
.contact-group-bottom{margin-top:8px;opacity:.92;}
.verify-action-top{margin:14px 0 4px;padding:14px;border-radius:18px;background:#fff7ed;border:1px solid rgba(249,115,22,.22);}
.top-actions{margin-top:8px;justify-content:flex-start;}
.verify-content-box{margin-top:12px;}
@media (min-width:1100px){.signup-shell{max-width:980px;grid-template-columns:500px 360px}.signup-card{padding:34px}.register-footer-image img{max-height:460px}}
@media (max-width:860px){.signup-shell{display:flex;flex-direction:column;max-width:min(520px, calc(100vw - 24px));margin:18px auto;gap:16px}.register-footer-image{max-width:300px;opacity:.96}.register-footer-image img{max-height:220px}.signup-card{max-width:100%;padding:26px 18px}.state-card{padding:22px 16px}}
@media (max-width:520px){.register-footer-image{max-width:240px}.manager-item{align-items:flex-start}.manager-actions{width:100%;justify-content:flex-start}.top-actions .btn{width:100%}}
.pill-subnav,.settings-subnav,.module-subnav{gap:8px;flex-wrap:wrap;}
.pill-subnav button,.settings-subnav button,.module-subnav button{border-radius:999px;padding:9px 14px;border:1px solid rgba(37,99,235,.16);background:#f8fafc;font-weight:800;}
.pill-subnav button.active,.settings-subnav button.active,.module-subnav button.active{background:#2563eb;color:#fff;box-shadow:0 10px 24px rgba(37,99,235,.22);}
.natural-code{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe;margin-right:8px;}
.notification-item p{line-height:1.55;margin:.35rem 0 0;}.notification-detail-pane p{line-height:1.7;}
.feedback-admin-panel,.record-subpanel{margin-top:14px;}
.leaderboard-card{border:1px solid rgba(37,99,235,.16);background:linear-gradient(135deg,#eff6ff,#fff);}
.podium-stage{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;align-items:end;margin:14px 0;}
.podium-slot{border-radius:22px;background:#fff;padding:18px 12px;text-align:center;box-shadow:0 12px 30px rgba(15,23,42,.09);border:1px solid rgba(148,163,184,.18);}
.podium-slot.rank-1{transform:translateY(-8px);border-color:rgba(245,158,11,.35)}.podium-medal{font-size:28px}.podium-slot strong{display:block;font-size:22px;color:#2563eb;margin-top:4px}.leaderboard-rest{display:grid;gap:8px}.leaderboard-row{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-radius:14px;background:rgba(255,255,255,.72)}
.compact-link{padding:0;border:0;background:none;font-weight:900;}
.admin-list-card,.permission-group{border-radius:18px;}.toolbar-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
@media (max-width:700px){.podium-stage{grid-template-columns:1fr}.podium-slot.rank-1{transform:none}.leaderboard-card{padding:14px}.feedback-split-grid{grid-template-columns:1fr}}

/* final polish: keep registration page low-key and prevent split/crop/sticky mistakes */
.signup-title{background:transparent!important;box-shadow:none!important;padding:0!important;color:#1f2937!important;letter-spacing:.04em!important;}
.signup-title span{background:none!important;-webkit-text-fill-color:#1f2937!important;color:#1f2937!important;font-size:clamp(24px,2.6vw,32px)!important;letter-spacing:.04em!important;}
.signup-title::before,.signup-title::after{display:none!important;}
.register-footer-image{box-shadow:0 12px 36px rgba(15,23,42,.08);background:transparent;}
.register-footer-image img{object-fit:contain!important;background:transparent;}
.verify-action-top{position:static!important;bottom:auto!important;box-shadow:0 12px 28px rgba(249,115,22,.12)!important;}

/* 20260611 next-scope repair: registration flow, permission tree, mobile balance */
body.register-flow-active .register-footer-image{display:none!important;}
.register-flow-card .verify-content-first{margin:12px 0 14px;border-color:rgba(37,99,235,.28);background:linear-gradient(135deg,#eff6ff,#fff);}
.verify-complete-btn{background:linear-gradient(135deg,#0ea5e9,#2563eb)!important;box-shadow:0 14px 32px rgba(37,99,235,.24);}
.method-detail-card{margin:12px 0;padding:14px;border-radius:18px;background:#f8fbff;border:1px solid rgba(37,99,235,.16);display:grid;gap:12px;}
.verify-choice-list{display:grid;gap:12px;margin-bottom:10px;}
.contact-group-bottom{margin-top:16px;padding-top:14px;border-top:1px dashed rgba(148,163,184,.35);}
@media(min-width:861px){.register-body .signup-shell{grid-template-columns:minmax(420px,560px) minmax(220px,320px);gap:22px;}.register-body.register-flow-active .signup-shell{display:block;max-width:min(720px,calc(100vw - 44px));}.register-body.register-flow-active .signup-card{margin:34px auto;}.signup-card{box-shadow:0 24px 70px rgba(15,23,42,.12)}}
.permission-tree-note{margin-top:12px;}
.permission-parent-row{font-weight:900;background:rgba(37,99,235,.06);border-radius:12px;}
.permission-child-row{padding-left:22px!important;}
.permission-child-row.disabled{opacity:.48;}
.permission-child-row input:disabled{cursor:not-allowed;}
.status.approved{background:#dbeafe!important;color:#1d4ed8!important;border-color:#bfdbfe!important;}
.status.rejected{background:#fee2e2!important;color:#b91c1c!important;}
.cash-reward-summary{padding:14px 16px;border-radius:18px;background:linear-gradient(135deg,#f0fdf4,#eff6ff);border:1px solid rgba(34,197,94,.22);display:grid;gap:5px;}
.cash-reward-summary b{color:#14532d}.cash-reward-summary span{color:#475569;line-height:1.65}
.chat-task-card{border:1px solid rgba(37,99,235,.16);background:linear-gradient(135deg,#eff6ff,#fff);border-radius:22px;padding:18px;}
.chat-task-card h3{margin-top:0}.chat-task-card .btn{white-space:nowrap}
.admin-top-card .inbox-btn{width:auto;min-width:108px;display:inline-flex;align-items:center;gap:8px;justify-content:center;padding:0 14px;}
@media(max-width:760px){
  .admin-top-card{padding:66px 16px 18px!important;display:block!important;text-align:left!important;}
  .admin-top-card h1{font-size:26px!important;line-height:1.2;margin-right:0!important;}
  .admin-top-card .inbox-btn{top:12px!important;right:12px!important;min-width:92px;height:40px!important;padding:0 10px!important;box-shadow:0 10px 24px rgba(15,23,42,.12);}
  .admin-content{padding:14px!important;border-radius:22px!important;}
  .toolbar{display:grid!important;grid-template-columns:1fr!important;align-items:start!important;gap:10px!important;}
  .toolbar .btn,.toolbar-actions .btn{width:100%;}
  .settings-subnav,.pill-subnav,.module-subnav{overflow-x:auto;flex-wrap:nowrap!important;-webkit-overflow-scrolling:touch;padding:7px!important;}
  .settings-subnav button,.pill-subnav button,.module-subnav button{white-space:nowrap;flex:0 0 auto;}
  .notification-panel .toolbar{grid-template-columns:1fr!important;}
  .notification-split-panel{padding:14px!important;}
  .notification-item{padding:12px;border-radius:16px;}
  .permission-child-row{padding-left:12px!important;}
  .register-body .signup-shell{max-width:min(520px,calc(100vw - 22px));}
}

/* 20260611 all-found-fixes: mobile/admin guardrails and non-blank settings panels */
.settings-summary:empty::before{content:'暂无可显示内容，请点击变更设置或刷新页面。';display:block;padding:14px 16px;border-radius:16px;background:#f8fafc;color:#64748b;font-weight:700;}
.notice.error{border-color:rgba(239,68,68,.25)!important;background:#fff1f2!important;color:#991b1b!important;}
@media(max-width:820px){
  .admin-layout{display:block!important;}
  .admin-sidebar{display:none!important;}
  .admin-content,.portal-panel,.card{max-width:100%;overflow:hidden;}
  .table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .table-wrap table{min-width:760px;}
  .settings-subnav,.pill-subnav,.module-subnav{max-width:100%;}
  .form-grid{grid-template-columns:1fr!important;}
  .span-2{grid-column:auto!important;}
  .state-actions{display:grid!important;grid-template-columns:1fr!important;gap:8px!important;}
  .state-actions .btn{width:100%;}
  .app-modal-panel{max-width:calc(100vw - 20px)!important;max-height:calc(100vh - 20px)!important;overflow:auto;}
}


/* 20260612 pro-permission-mail: 全局链接、安全中心、邮箱验证、手机端弹窗与签到优化 */
a, a:hover, .text-link, .text-link:hover { text-decoration: none !important; }
a:hover, .text-link:hover { color: var(--primary-dark, #1d4ed8); }
.rule-panel,.notice-panel,.app-modal-panel{max-height:calc(100dvh - 24px);overflow:auto;}
.agreement-actions{position:sticky;bottom:0;margin-top:16px;padding-top:12px;background:linear-gradient(180deg,rgba(255,255,255,.82),#fff);}
.split-actions{display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-top:14px;}
.split-actions .btn{min-width:150px;}
.verify-option-card.preferred{border-color:rgba(37,99,235,.36);background:linear-gradient(135deg,#eff6ff,#fff);box-shadow:0 14px 34px rgba(37,99,235,.12);}
.verify-option-card .tag{display:inline-flex;margin-left:8px;padding:3px 8px;border-radius:999px;background:#dcfce7;color:#166534;font-size:12px;font-weight:900;vertical-align:middle;}
.verify-summary{padding:14px;border-radius:18px;border:1px solid rgba(37,99,235,.16);background:#f8fbff;text-align:left;line-height:1.7;}
.email-verify-shell{max-width:min(680px,calc(100vw - 24px));display:block;}
.email-verify-card{margin:28px auto;}
.security-grid{display:grid;grid-template-columns:1fr;gap:14px;}
.security-card{border:1px solid rgba(37,99,235,.14);border-radius:20px;padding:16px;background:linear-gradient(135deg,#fff,#f8fbff);}
.security-card h3{margin-top:0;}
.session-current{font-weight:900;color:#166534;}
.weekly-row,.checkin-row.weekly-row{display:grid!important;grid-template-columns:repeat(7,minmax(48px,1fr))!important;gap:6px!important;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px;}
.weekly-row .day-card,.checkin-row.weekly-row .day-card{min-width:48px;padding:7px 4px!important;border-radius:12px!important;font-size:12px!important;}
.weekly-row .day-card strong,.checkin-row.weekly-row .day-card strong{font-size:12px!important;}
.weekly-row .day-card span,.checkin-row.weekly-row .day-card span{font-size:11px!important;}
@media(max-width:560px){
  .split-actions{display:grid;grid-template-columns:1fr;}
  .split-actions .btn{width:100%;min-width:0;}
  .rule-panel,.notice-panel,.app-modal-panel{max-width:calc(100vw - 18px)!important;border-radius:22px!important;padding:18px!important;}
  .weekly-row,.checkin-row.weekly-row{grid-template-columns:repeat(7,52px)!important;}
  .security-card{padding:14px;border-radius:18px;}
}

/* 20260613 full-fix: mobile pills, avatars, security tabs, compact dialogs */
.top-avatar-wrap{position:absolute;right:72px;top:18px;z-index:3}.top-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;border:3px solid rgba(255,255,255,.72);box-shadow:0 12px 28px rgba(43,70,160,.22);background:#fff}.admin-top-card .top-avatar-wrap{right:86px}.qq-confirm-card{display:flex;align-items:center;gap:14px;margin:14px 0;padding:14px;border-radius:18px;background:linear-gradient(135deg,rgba(82,111,255,.10),rgba(151,88,255,.10));border:1px solid rgba(110,130,220,.18)}.qq-confirm-card .qq-avatar{width:58px;height:58px;border-radius:18px;object-fit:cover;background:#eef2ff}.qq-confirm-card b{display:block;font-size:17px}.qq-confirm-card span{display:block;margin-top:4px;color:var(--muted)}.security-subnav{margin:8px 0 16px}.security-subpanel .security-card.full-card{width:100%;box-sizing:border-box}.session-table-wrap td:last-child{min-width:112px}.checkin-dot em{display:none!important}.checkin-dot{min-height:64px}.checkin-dot small{white-space:nowrap}.btn,.menu-select-btn,.settings-subnav button,.pill-subnav button{white-space:nowrap}.app-modal-panel{height:auto!important;max-height:min(82vh,620px);overflow:auto}.app-modal .modal-body{max-height:58vh;overflow:auto}.toolbar-actions{gap:8px}.compact-toolbar{align-items:center}.review-subnav{margin-bottom:16px}
@media (max-width: 760px){
  .page-shell{padding-left:10px;padding-right:10px}.dashboard-top-card,.admin-top-card{padding:22px 16px 18px;overflow:hidden}.top-avatar-wrap{right:62px;top:14px}.top-avatar{width:34px;height:34px;border-width:2px}.admin-top-card .top-avatar-wrap{right:70px}.inbox-btn{transform:scale(.92);transform-origin:top right}.dashboard-top-card .eyebrow,.dashboard-top-card h1,.dashboard-top-card p{max-width:calc(100% - 92px)}
  .toolbar{gap:10px;align-items:flex-start}.toolbar .btn,.toolbar-actions .btn,.security-actions .btn,[data-export],#showWhiteForm,#showImportForm,#showPointForm,#showRewardForm,#showFeedbackForm,#showPasswordForm,#showAdminPasswordForm{width:auto!important;min-width:max-content;min-height:32px;padding:8px 12px!important;border-radius:999px!important;font-size:12px!important;line-height:1!important;white-space:nowrap!important}.toolbar-actions,.security-actions,.state-actions{display:flex;flex-wrap:wrap;gap:8px}.toolbar-actions{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:4px}.filter-toolbar{display:grid;grid-template-columns:1fr;gap:8px}.settings-subnav,.pill-subnav,.module-subnav{display:flex;gap:8px;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:6px}.settings-subnav button,.pill-subnav button,.module-subnav button{flex:0 0 auto;border-radius:999px!important;padding:8px 12px!important;font-size:12px!important;white-space:nowrap!important}.mobile-menu-bar .menu-popover button{white-space:nowrap}.checkin-row{display:grid;grid-template-columns:repeat(7,minmax(42px,1fr));gap:6px}.checkin-dot{min-width:0;min-height:54px;padding:8px 4px;border-radius:14px}.checkin-dot b{font-size:12px}.checkin-dot small{font-size:11px}.app-modal-panel{width:calc(100vw - 28px);max-height:78vh;padding:20px 16px}.app-modal .modal-icon{width:54px;height:54px}.app-modal h2{font-size:20px;margin:8px 0}.notification-panel,.rule-panel,.notice-panel{width:calc(100vw - 24px);max-height:82vh;overflow:auto}.table-wrap{overflow-x:auto}.table-wrap table{min-width:680px}.session-table-wrap table{min-width:0}.session-table-wrap thead{display:none}.session-table-wrap table,.session-table-wrap tbody,.session-table-wrap tr,.session-table-wrap td{display:block;width:100%}.session-table-wrap tr{margin:10px 0;padding:12px;border:1px solid rgba(107,119,163,.14);border-radius:16px;background:#fff}.session-table-wrap td{border:0!important;padding:4px 0!important}.payment-status-list,.security-grid{grid-template-columns:1fr}.qq-confirm-card{padding:12px}.qq-confirm-card .qq-avatar{width:50px;height:50px}.menu-select-btn{font-size:13px!important}.admin-content{padding:14px}.mobile-card-table tbody tr{display:block}
}
@media (max-width: 430px){.checkin-row{grid-template-columns:repeat(7,minmax(38px,1fr));gap:4px}.checkin-dot{min-height:48px;padding:7px 3px}.checkin-dot b{font-size:11px}.checkin-dot small{font-size:10px}.dashboard-top-card .stats{grid-template-columns:1fr 1fr}.toolbar h2{font-size:20px}}

/* 20260613 honest-rework: keep review center as one parent and keep chat review out of normal points UI */
.review-only{display:none!important;}
.review-reset-only{display:none!important;}
body.review-chat-mode .review-only{display:flex!important;}
body.review-reset-mode .review-reset-only{display:flex!important;}
body:not(.review-chat-mode) #pointsSubnav [data-point-panel="chat"]{display:none!important;}
body.review-chat-mode #pointsSubnav{display:none!important;}
@media(max-width:760px){
  .review-subnav{display:flex;overflow-x:auto;flex-wrap:nowrap!important;-webkit-overflow-scrolling:touch;}
  .review-subnav button{white-space:nowrap;flex:0 0 auto;}
}

/* 20260613 admin-backend-followup: mobile admin menu, inline inbox, safety forms */
.icon-btn{width:34px;height:34px;border:1px solid rgba(148,163,184,.28);border-radius:999px;background:#fff;color:#1f2a44;display:inline-grid;place-items:center;font-size:18px;font-weight:900;line-height:1;cursor:pointer;box-shadow:0 8px 20px rgba(15,23,42,.08)}
.icon-btn:hover{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}
.notification-inline-detail{display:none;margin-top:12px}
.notification-inline-card{padding:14px;border-radius:16px;background:#fff;border:1px solid rgba(37,99,235,.16);box-shadow:0 10px 24px rgba(15,23,42,.06)}
.notification-inline-card h3{margin:0 0 8px;font-size:16px}
.notification-inline-card p{white-space:pre-wrap;word-break:break-word;line-height:1.7}
.form-section-title{margin-top:4px;padding:9px 12px;border-radius:14px;background:#eef2ff;color:#1e3a8a;font-weight:900}
body.review-reset-mode #adminSecuritySubnav{display:none!important}
@media(max-width:760px){
  #adminMobileMenu{margin:10px 0 12px}
  #adminMobileMenu .menu-select-btn{width:100%;justify-content:space-between;text-align:left;background:#fff;border:1px solid rgba(148,163,184,.26);box-shadow:0 12px 28px rgba(15,23,42,.08)}
  #adminMobileMenu .menu-popover{left:0;right:0;top:46px;max-width:none;width:100%;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:10px;border-radius:18px}
  #adminMobileMenu .menu-popover button{text-align:center;padding:10px 8px;border:1px solid rgba(148,163,184,.18);background:#f8fafc}
  #adminMobileMenu .menu-popover button.active{background:#2563eb;color:#fff;border-color:#2563eb}
  .notification-detail-pane{display:none!important}
  .notification-inline-detail{display:block}
  .notification-split{display:block!important}
  .notification-list-pane{padding-right:0!important}
  .notification-panel .toolbar{display:flex!important;flex-direction:row;align-items:center!important;justify-content:space-between}
  .notification-panel .state-actions{display:flex!important;grid-template-columns:none!important;width:auto}
  .notification-panel .icon-btn{width:36px;height:36px}
}

/* 20260613-final: 头像改为姓名左侧小图标，不再占用顶部空间 */
.identity-line{display:inline-flex!important;align-items:center;gap:7px;max-width:100%;min-height:28px;margin-top:6px;line-height:1.35;}
.identity-avatar{width:26px!important;height:26px!important;border-radius:50%!important;object-fit:cover!important;flex:0 0 26px;border:2px solid rgba(255,255,255,.78);box-shadow:0 4px 10px rgba(15,23,42,.14);background:#fff;}
.identity-line .hidden{display:none!important;}
.dashboard-top-card .identity-line,.admin-top-card .identity-line{max-width:calc(100% - 92px);}
.qq-confirm-card.compact-avatar-card{display:flex;align-items:center;gap:8px;margin:10px 0 12px;padding:9px 10px;border-radius:14px;background:linear-gradient(135deg,rgba(82,111,255,.08),rgba(151,88,255,.06));border:1px solid rgba(110,130,220,.16);max-width:100%;box-sizing:border-box;}
.qq-confirm-card.compact-avatar-card .qq-avatar{width:30px!important;height:30px!important;border-radius:50%!important;object-fit:cover;flex:0 0 30px;background:#eef2ff;border:1px solid rgba(37,99,235,.14);}
.qq-confirm-card.compact-avatar-card .qq-confirm-text{min-width:0;line-height:1.25;}
.qq-confirm-card.compact-avatar-card b{display:block;font-size:14px!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.qq-confirm-card.compact-avatar-card span{display:block;margin-top:2px;font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.top-avatar-wrap{display:none!important;}
@media(max-width:640px){
  .identity-line{gap:6px;font-size:12px;}
  .identity-avatar{width:23px!important;height:23px!important;flex-basis:23px;border-width:1.5px;}
  .dashboard-top-card .identity-line,.admin-top-card .identity-line{max-width:calc(100% - 74px);}
  .qq-confirm-card.compact-avatar-card{padding:8px 9px;gap:7px;}
  .qq-confirm-card.compact-avatar-card .qq-avatar{width:28px!important;height:28px!important;flex-basis:28px;}
}


/* 2026-06-14: 全局协议、煲塔与移动端统一修复 */
a, .text-link { text-decoration: none !important; }
a:hover, .text-link:hover { text-decoration: none !important; filter: brightness(.92); }
.agreement-panel { width: min(720px, calc(100vw - 28px)); max-height: min(82vh, 760px); display: flex; flex-direction: column; gap: 12px; }
.agreement-scroll-body { max-height: min(48vh, 420px); overflow: auto; padding: 14px; border: 1px solid rgba(99,102,241,.16); border-radius: 18px; background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,250,255,.92)); box-shadow: inset 0 1px 0 rgba(255,255,255,.8); }
.agreement-scroll-body p { margin: 0 0 10px; line-height: 1.78; font-size: 14px; color: #374151; }
.agreement-actions { position: sticky; bottom: 0; background: linear-gradient(180deg, rgba(255,255,255,.70), #fff); padding-top: 10px; }
.baota-stat strong, .cash-stat strong { font-variant-numeric: tabular-nums; }
.baota-actions { display:flex; gap:10px; flex-wrap:wrap; margin-top: 14px; }
.baota-actions .btn { flex:1 1 140px; min-width: 120px; }
.baota-asset-line { margin-top: 8px; font-size: 12px; color:#6366f1; font-weight:700; }
.baota-tower svg { transform-origin: 50% 82%; }
.lucky-bag-card.ready .baota-tower svg { animation: baotaWobble 1.15s ease-in-out infinite; }
@keyframes baotaWobble { 0%,100%{transform:rotate(0deg) translateY(0)} 20%{transform:rotate(-7deg)} 45%{transform:rotate(7deg)} 70%{transform:rotate(-3deg) translateY(2px)} }
.baota-animate-preview { text-align:center; }
.baota-anim-tower { width:64px; height:80px; margin:0 auto 12px; border-radius:16px 16px 8px 8px; display:grid; place-items:center; font-weight:900; color:#fff; background:linear-gradient(160deg,#6366f1,#8b5cf6); box-shadow:0 16px 36px rgba(99,102,241,.3); animation: baotaFall 1.6s ease-in-out infinite; }
@keyframes baotaFall { 0%,60%,100%{transform:rotate(0) translateY(0)} 72%{transform:rotate(-18deg) translateY(8px)} 84%{transform:rotate(14deg) translateY(4px)} }
.tall-textarea { min-height: 180px; }
@media (max-width: 640px) {
  .asset-stats { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }
  .asset-stats .stat-card { padding: 10px 8px; border-radius: 16px; min-height: 86px; }
  .asset-stats .stat-card span { font-size: 11px; }
  .asset-stats .stat-card strong { font-size: 18px; }
  .asset-stats .stat-card em { font-size: 10px; }
  .lucky-bag-main { align-items:flex-start; }
  .lucky-icon { width:44px !important; height:44px !important; min-width:44px !important; }
  .baota-actions { gap:8px; }
  .baota-actions .btn { flex:1 1 100%; min-height: 42px; }
  .agreement-panel { max-height: 88vh; }
  .agreement-scroll-body { max-height: 54vh; font-size: 13px; }
}

/* 20260613 follow-up: mobile menu rollback, top-card spacing, compact dialogs and modern import picker */
.modern-file-picker{
  position:relative;
  display:block;
  padding:0!important;
  border:0!important;
  background:transparent!important;
}
.student-subpanel .modern-upload-card{
  display:block!important;
}
.modern-file-picker input[type="file"]{
  position:absolute;
  inset:0;
  width:1px;
  height:1px;
  opacity:0;
  pointer-events:none;
}
.modern-file-picker label{
  min-height:112px;
  display:grid;
  place-items:center;
  gap:7px;
  padding:20px;
  border:1.5px dashed rgba(37,99,235,.34);
  border-radius:22px;
  background:linear-gradient(180deg,#fff,#f8fbff);
  box-shadow:0 16px 34px rgba(37,99,235,.08);
  color:#1f2a44;
  cursor:pointer;
  text-align:center;
}
.modern-file-picker label::before{
  content:'+';
  width:42px;
  height:42px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#2563eb;
  color:#fff;
  font-size:30px;
  line-height:1;
  font-weight:800;
  box-shadow:0 12px 24px rgba(37,99,235,.22);
}
.modern-file-picker label:hover{
  border-color:#2563eb;
  background:#eff6ff;
}
.modern-file-picker span{
  color:#64748b;
  font-size:13px;
  line-height:1.5;
  word-break:break-word;
}
@media(max-width:760px){
  #adminMobileMenu{margin:8px 0 12px!important;}
  #adminMobileMenu .menu-select-btn{
    width:100%;
    justify-content:space-between;
    text-align:left;
    background:#fff;
    border:1px solid rgba(148,163,184,.26);
    box-shadow:0 12px 28px rgba(15,23,42,.08);
  }
  #adminMobileMenu .menu-popover{
    left:0!important;
    right:0!important;
    top:46px!important;
    width:100%!important;
    max-width:none!important;
    display:flex!important;
    grid-template-columns:none!important;
    gap:8px!important;
    padding:8px!important;
    border-radius:18px!important;
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    white-space:nowrap;
  }
  #adminMobileMenu .menu-popover.hidden{display:none!important;}
  #adminMobileMenu .menu-popover button{
    flex:0 0 auto!important;
    text-align:left!important;
    padding:9px 13px!important;
    border:1px solid rgba(148,163,184,.18)!important;
    border-radius:999px!important;
    background:#f8fafc!important;
  }
  #adminMobileMenu .menu-popover button.active{
    background:#2563eb!important;
    color:#fff!important;
    border-color:#2563eb!important;
  }
  .dashboard-top-card:not(.admin-top-card){
    display:block!important;
    padding-top:64px!important;
    overflow:visible!important;
  }
  .dashboard-top-card:not(.admin-top-card) .bell-btn.inbox-btn{
    top:12px!important;
    right:12px!important;
  }
  .dashboard-top-card:not(.admin-top-card) .eyebrow,
  .dashboard-top-card:not(.admin-top-card) h1,
  .dashboard-top-card:not(.admin-top-card) p,
  .dashboard-top-card:not(.admin-top-card) .identity-line{
    max-width:100%!important;
  }
  .dashboard-top-card:not(.admin-top-card) .asset-stats{
    margin-top:14px;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    width:100%!important;
  }
  .app-modal{
    align-items:flex-start!important;
    padding:10px!important;
    overflow:auto!important;
  }
  .app-modal-panel{
    width:min(94vw,430px)!important;
    max-height:none!important;
    min-height:auto!important;
    padding:18px 14px!important;
    border-radius:20px!important;
    overflow:visible!important;
  }
  .app-modal .modal-body{
    max-height:none!important;
    overflow:visible!important;
    word-break:break-word;
  }
  .app-modal-panel h2{
    font-size:18px!important;
    line-height:1.35!important;
  }
  .app-modal-panel .state-actions{
    display:flex!important;
    justify-content:center!important;
    flex-wrap:wrap!important;
    gap:8px!important;
  }
  .app-modal-panel .state-actions .btn{
    width:auto!important;
    min-width:96px!important;
  }
}

/* 20260613: full leaderboard page and final mobile checkin override */
.leaderboard-page{min-height:100vh;background:#eef4ff;}
.leaderboard-shell{max-width:980px;margin:0 auto;padding:24px;}
.leaderboard-board{padding:22px;}
.leaderboard-topbar h1{margin:0;font-size:30px;}
.leaderboard-topbar p{margin:6px 0 0;color:#64748b;}
.leaderboard-tabs{display:flex;gap:8px;overflow:auto;padding:8px;margin:14px 0 18px;border-radius:16px;background:#f8fafc;border:1px solid rgba(148,163,184,.24);}
.leaderboard-tabs button{border:0;background:transparent;border-radius:12px;padding:10px 14px;font-weight:900;color:#475569;white-space:nowrap;cursor:pointer;}
.leaderboard-tabs button.active{background:#fff;color:#2563eb;box-shadow:0 10px 24px rgba(37,99,235,.12);}
.leaderboard-content .podium-stage{margin-bottom:14px;}
.leaderboard-content .podium-slot{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:6px;}
.leaderboard-content .podium-medal{width:42px;height:42px;border-radius:999px;display:grid;place-items:center;background:#0f172a;color:#fff;font-size:18px;font-weight:1000;}
.leaderboard-content .podium-slot.rank-1 .podium-medal{background:#f59e0b;}
.leaderboard-content .podium-slot.rank-2 .podium-medal{background:#64748b;}
.leaderboard-content .podium-slot.rank-3 .podium-medal{background:#c2410c;}
.leaderboard-row.full-row b{display:flex;flex-direction:column;gap:2px;}
.leaderboard-row.full-row small{font-size:12px;color:#64748b;font-weight:700;}
.checkin-row.weekly-row{grid-template-columns:repeat(7,minmax(48px,1fr))!important;}
@media(max-width:760px){
  .leaderboard-shell{padding:12px;}
  .leaderboard-board{padding:16px;}
  .leaderboard-topbar{align-items:flex-start;}
  .leaderboard-topbar h1{font-size:24px;}
  .leaderboard-content .podium-stage{grid-template-columns:1fr!important;}
  .checkin-row.weekly-row{grid-template-columns:repeat(7,52px)!important;overflow-x:auto!important;}
}

/* 20260613: registration entry desktop should be a centered form, not a split layout */
@media (min-width: 861px) {
  body.register-body:not(.register-flow-active) .signup-shell {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    max-width: min(560px, calc(100vw - 48px)) !important;
    min-height: 100vh !important;
    margin: 0 auto !important;
    padding: 30px 0 34px !important;
    gap: 14px !important;
  }
  body.register-body:not(.register-flow-active) .signup-card {
    width: 100% !important;
    max-width: 520px !important;
    margin: 0 auto !important;
    padding: 30px 32px !important;
  }
  body.register-body:not(.register-flow-active) .signup-title span {
    font-size: clamp(24px, 2vw, 30px) !important;
    letter-spacing: .03em !important;
  }
  body.register-body:not(.register-flow-active) .register-footer-image {
    width: min(300px, 58vw) !important;
    max-width: 300px !important;
    margin: 2px auto 0 !important;
    box-shadow: none !important;
    border-radius: 18px !important;
    background: transparent !important;
  }
  body.register-body:not(.register-flow-active) .register-footer-image img {
    width: 100% !important;
    max-height: 190px !important;
    object-fit: contain !important;
    border-radius: 18px !important;
    filter: drop-shadow(0 10px 24px rgba(15,23,42,.10)) !important;
  }
}

/* 20260613 menu repair: admin mobile menu must match portal's original compact selector */
@media(max-width:780px){
  .admin-shell{
    display:block!important;
  }
  .admin-sidebar{
    display:none!important;
  }
  .admin-top-card{
    margin:0 0 6px!important;
    padding:54px 14px 12px!important;
    min-height:0!important;
    display:block!important;
    text-align:left!important;
    overflow:visible!important;
  }
  .admin-top-card .eyebrow{
    font-size:11px!important;
    margin-bottom:4px!important;
  }
  .admin-top-card h1{
    font-size:22px!important;
    line-height:1.18!important;
    margin:0!important;
  }
  .admin-top-card .identity-line{
    margin-top:5px!important;
    max-width:100%!important;
    font-size:12px!important;
  }
  .admin-top-card .bell-btn.inbox-btn{
    top:10px!important;
    right:10px!important;
    height:38px!important;
    min-width:0!important;
    padding:0 10px!important;
  }
  #adminMobileMenu.mobile-menu-bar{
    display:flex!important;
    justify-content:flex-start!important;
    align-items:flex-start!important;
    position:relative!important;
    z-index:120!important;
    margin:4px 0 8px!important;
    padding:0!important;
    width:auto!important;
  }
  #adminMobileMenu .menu-select-btn{
    width:auto!important;
    max-width:calc(100vw - 28px)!important;
    min-height:0!important;
    display:inline-flex!important;
    align-items:center!important;
    justify-content:flex-start!important;
    gap:4px!important;
    padding:9px 14px!important;
    border:1px solid rgba(102,126,234,.22)!important;
    border-radius:999px!important;
    background:linear-gradient(135deg, rgba(102,126,234,.12), rgba(14,165,233,.10))!important;
    color:#26324c!important;
    box-shadow:0 12px 28px rgba(83,109,254,.10)!important;
    font-size:14px!important;
    font-weight:800!important;
    text-align:left!important;
    white-space:nowrap!important;
  }
  #adminMobileMenu .menu-popover{
    position:absolute!important;
    top:44px!important;
    left:0!important;
    right:auto!important;
    width:auto!important;
    min-width:190px!important;
    max-width:calc(100vw - 36px)!important;
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:6px!important;
    padding:8px!important;
    border-radius:18px!important;
    border:1px solid rgba(102,126,234,.18)!important;
    background:rgba(255,255,255,.98)!important;
    box-shadow:0 22px 50px rgba(39,54,95,.18)!important;
    overflow:visible!important;
    white-space:normal!important;
  }
  #adminMobileMenu .menu-popover.hidden{
    display:none!important;
  }
  #adminMobileMenu .menu-popover button{
    width:100%!important;
    display:block!important;
    padding:11px 12px!important;
    border:0!important;
    border-radius:13px!important;
    background:transparent!important;
    color:#26324c!important;
    box-shadow:none!important;
    text-align:left!important;
    font-size:14px!important;
    font-weight:800!important;
    white-space:nowrap!important;
  }
  #adminMobileMenu .menu-popover button.active,
  #adminMobileMenu .menu-popover button:hover{
    background:linear-gradient(135deg, rgba(102,126,234,.14), rgba(14,165,233,.10))!important;
    color:#2f46b6!important;
    border-color:transparent!important;
  }
  .admin-content{
    margin-top:0!important;
    padding:12px!important;
    border-radius:20px!important;
  }
}

/* 20260614 ui-polish: equal-width tables, record filters, email binding, verify states */
.table-wrap,
.admin-content .table-wrap,
#adminView .table-wrap{
  width:100%!important;
  max-width:100%!important;
  overflow-x:auto!important;
  overflow-y:hidden!important;
  contain:none!important;
  -webkit-overflow-scrolling:touch;
  border-radius:14px!important;
}
.table-wrap table,
.admin-content .table-wrap table,
#adminView .table-wrap table{
  table-layout:fixed!important;
  width:var(--table-min-width, 1200px)!important;
  min-width:var(--table-min-width, 1200px)!important;
  border-collapse:collapse!important;
}
.table-wrap th,
.table-wrap td,
.admin-content .table-wrap th,
.admin-content .table-wrap td,
#adminView .table-wrap th,
#adminView .table-wrap td{
  width:calc(var(--table-min-width, 1200px) / var(--table-cols, 6))!important;
  min-width:0!important;
  max-width:none!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  vertical-align:middle!important;
  line-height:1.45!important;
}
.table-wrap th,
.admin-content .table-wrap th,
#adminView .table-wrap th{
  position:sticky;
  top:0;
  z-index:1;
  background:#f8fafc!important;
}
.table-wrap td:has(button),
.table-wrap td:has(.btn),
.admin-content .table-wrap td:has(button),
.admin-content .table-wrap td:has(.btn),
#adminView .table-wrap td:has(button),
#adminView .table-wrap td:has(.btn){
  white-space:nowrap!important;
  overflow-x:auto!important;
  overflow-y:hidden!important;
  text-overflow:clip!important;
}
.table-wrap td br,
.admin-content .table-wrap td br,
#adminView .table-wrap td br{
  display:none!important;
}
.table-wrap td small,
.admin-content .table-wrap td small,
#adminView .table-wrap td small{
  display:inline!important;
  margin-left:4px!important;
  white-space:nowrap!important;
}
.table-wrap .pager-row td,
.admin-content .table-wrap .pager-row td,
#adminView .table-wrap .pager-row td,
.table-wrap .table-section-row td,
.admin-content .table-wrap .table-section-row td,
#adminView .table-wrap .table-section-row td{
  width:auto!important;
  white-space:normal!important;
  overflow:visible!important;
}
.record-date-filter{
  display:grid!important;
  grid-template-columns:minmax(170px,1fr) minmax(170px,1fr) auto!important;
  gap:14px!important;
  align-items:center!important;
  margin:14px 0 18px!important;
}
.record-date-filter .input{
  min-width:0!important;
}
#clearStudentRecordDates{
  justify-self:end;
  min-height:42px;
  border-radius:999px!important;
}
.email-status-card{
  display:grid;
  gap:4px;
  margin:10px 0 16px;
  padding:14px 16px;
  border:1px solid rgba(37,99,235,.16);
  border-radius:16px;
  background:linear-gradient(180deg,#fff,#f8fbff);
  color:#475569;
}
.email-status-card div{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.email-status-card b{
  color:#0f172a;
}
.email-status-card span,
.email-status-card em{
  font-style:normal;
  color:#64748b;
  overflow:hidden;
  text-overflow:ellipsis;
}
.email-bind-layout{
  display:grid;
  grid-template-columns:minmax(260px,1fr) auto;
  gap:14px;
  align-items:end;
}
.email-input-group .label{
  margin-top:0;
}
.email-actions{
  align-self:end;
  justify-content:flex-end;
}
.email-notify-check{
  grid-column:1 / -1;
  margin:0!important;
  align-items:center!important;
  padding:10px 12px;
  border-radius:14px;
  background:#f8fafc;
  border:1px solid rgba(148,163,184,.22);
}
.email-bind-help{
  grid-column:1 / -1;
  margin:0!important;
  font-size:13px;
}
.email-success-card{
  margin:10px 0 0;
}
.email-success-card h2{
  margin-top:0;
}
body.register-body:not(.register-flow-active) .signup-title{
  display:flex!important;
  justify-content:center!important;
  align-items:center!important;
  text-align:center!important;
  margin:14px 0 18px!important;
}
body.register-body:not(.register-flow-active) .signup-title span{
  font-size:clamp(30px,4vw,42px)!important;
  line-height:1.18!important;
  letter-spacing:0!important;
}
body.register-body:not(.register-flow-active) .school-line,
body.register-body:not(.register-flow-active) .activity-line{
  text-align:center;
}
@media(max-width:760px){
  .record-date-filter{
    grid-template-columns:1fr 1fr!important;
    gap:10px!important;
  }
  #clearStudentRecordDates{
    grid-column:1 / -1;
    justify-self:start;
  }
  .email-bind-layout{
    grid-template-columns:1fr;
  }
  .email-actions{
    justify-content:flex-start;
  }
  .email-status-card div{
    display:grid;
    gap:4px;
  }
  body.register-body:not(.register-flow-active) .signup-title span{
    font-size:clamp(32px,9vw,42px)!important;
  }
}

/* 20260613 table readability repair: equal columns, one-line cells, click for details */
.table-wrap table{
  table-layout:fixed!important;
  min-width:980px!important;
}
.table-wrap th,
.table-wrap td{
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  word-break:normal!important;
  vertical-align:middle!important;
  max-width:0;
}
.table-wrap td br{
  display:none!important;
}
.table-wrap td small{
  display:inline!important;
  margin-left:4px;
  white-space:nowrap!important;
}
.table-wrap td:has(button),
.table-wrap td:has(.btn),
.table-wrap td:has(.text-link),
.table-wrap td:has(input),
.table-wrap .pager-row td{
  overflow:visible!important;
  text-overflow:clip!important;
  max-width:none;
}
.table-wrap .status,
.table-wrap .event-chip,
.table-wrap .compact-link,
.table-wrap .time-short{
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  vertical-align:middle;
}
.time-short{
  cursor:pointer;
  border-bottom:1px dotted rgba(37,99,235,.35);
}
.cell-detail-pop{
  text-align:left;
  white-space:pre-wrap;
  word-break:break-word;
  line-height:1.75;
  padding:10px 12px;
  border-radius:14px;
  background:#f8fafc;
  border:1px solid rgba(148,163,184,.22);
}
@media(max-width:780px){
  .table-wrap table{
    min-width:960px!important;
  }
  .table-wrap th,
  .table-wrap td{
    padding:9px 10px!important;
    font-size:12px!important;
  }
  .admin-top-card{
    padding:46px 12px 8px!important;
    margin-bottom:2px!important;
  }
  .admin-top-card h1{
    font-size:20px!important;
  }
  .admin-top-card .identity-line{
    margin-top:3px!important;
  }
  #adminMobileMenu.mobile-menu-bar{
    margin:-2px 0 6px!important;
  }
  .admin-content{
    padding:10px!important;
  }
}
@media(max-width:430px){
  .table-wrap table{
    min-width:920px!important;
  }
}

/* 20260613 admin menu final repair: follow portal compact menu and remove tall mobile header padding */
@media(max-width:780px){
  .admin-shell{
    display:block!important;
  }
  .admin-sidebar{
    display:none!important;
  }
  .admin-top-card{
    margin:0!important;
    padding:16px 14px 12px!important;
    min-height:0!important;
    display:block!important;
    text-align:left!important;
    overflow:visible!important;
  }
  .admin-top-card .bell-btn.inbox-btn{
    top:12px!important;
    right:12px!important;
    height:38px!important;
    min-width:0!important;
    padding:0 10px!important;
    transform:none!important;
  }
  .admin-top-card .eyebrow,
  .admin-top-card h1,
  .admin-top-card .identity-line{
    max-width:calc(100% - 106px)!important;
  }
  .admin-top-card .eyebrow{
    margin:0 0 8px!important;
    font-size:12px!important;
    line-height:1.2!important;
  }
  .admin-top-card h1{
    margin:0 0 6px!important;
    font-size:22px!important;
    line-height:1.18!important;
  }
  .admin-top-card .identity-line{
    margin-top:0!important;
    min-height:24px!important;
    font-size:12px!important;
    line-height:1.3!important;
  }
  #adminMobileMenu.mobile-menu-bar{
    position:relative!important;
    z-index:20!important;
    display:flex!important;
    justify-content:flex-start!important;
    align-items:center!important;
    width:auto!important;
    margin:14px 0 16px!important;
    padding:0!important;
  }
  #adminMobileMenu .menu-select-btn{
    width:auto!important;
    min-width:0!important;
    max-width:100%!important;
    min-height:0!important;
    display:inline-flex!important;
    align-items:center!important;
    justify-content:flex-start!important;
    gap:4px!important;
    border:1px solid rgba(102,126,234,.22)!important;
    border-radius:999px!important;
    background:linear-gradient(135deg, rgba(102,126,234,.12), rgba(14,165,233,.10))!important;
    color:#26324c!important;
    box-shadow:0 12px 28px rgba(83,109,254,.10)!important;
    padding:10px 15px!important;
    font-size:14px!important;
    line-height:1.2!important;
    font-weight:800!important;
    text-align:left!important;
    white-space:nowrap!important;
  }
  #adminMobileMenu .menu-popover{
    position:absolute!important;
    top:48px!important;
    left:0!important;
    right:auto!important;
    width:auto!important;
    min-width:190px!important;
    max-width:calc(100vw - 36px)!important;
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:6px!important;
    padding:8px!important;
    border-radius:18px!important;
    border:1px solid rgba(102,126,234,.18)!important;
    background:rgba(255,255,255,.98)!important;
    box-shadow:0 22px 50px rgba(39,54,95,.18)!important;
    overflow:visible!important;
    white-space:normal!important;
  }
  #adminMobileMenu .menu-popover.hidden{
    display:none!important;
  }
  #adminMobileMenu .menu-popover button{
    width:100%!important;
    display:block!important;
    border:0!important;
    border-radius:13px!important;
    background:transparent!important;
    color:#26324c!important;
    box-shadow:none!important;
    padding:11px 12px!important;
    text-align:left!important;
    font-size:14px!important;
    line-height:1.25!important;
    font-weight:800!important;
    white-space:nowrap!important;
  }
  #adminMobileMenu .menu-popover button.active,
  #adminMobileMenu .menu-popover button:hover{
    background:linear-gradient(135deg, rgba(102,126,234,.14), rgba(14,165,233,.10))!important;
    color:#2f46b6!important;
  }
  .admin-content{
    margin-top:0!important;
    padding:12px!important;
    border-radius:20px!important;
  }
}

@media(max-width:430px){
  .admin-top-card{
    padding:14px 12px 10px!important;
  }
  .admin-top-card h1{
    font-size:20px!important;
  }
  .admin-top-card .eyebrow,
  .admin-top-card h1,
  .admin-top-card .identity-line{
    max-width:calc(100% - 98px)!important;
  }
  #adminMobileMenu.mobile-menu-bar{
    margin:12px 0 14px!important;
  }
}

/* 20260613 top-card final repair: admin and portal share the same compact mobile header */
@media(max-width:780px){
  .dashboard-top-card,
  .admin-top-card{
    display:block!important;
    position:relative!important;
    margin:0 0 12px!important;
    padding:16px 14px 12px!important;
    min-height:0!important;
    overflow:visible!important;
    text-align:left!important;
  }
  html.device-phone .admin-top-card,
  html.device-ios-phone .admin-top-card,
  html.device-android-phone .admin-top-card,
  .dashboard-top-card:not(.admin-top-card){
    padding:16px 14px 12px!important;
  }
  .dashboard-top-card .bell-btn.inbox-btn,
  .admin-top-card .bell-btn.inbox-btn{
    top:12px!important;
    right:12px!important;
    height:38px!important;
    min-width:0!important;
    padding:0 10px!important;
    transform:none!important;
    z-index:3!important;
  }
  .dashboard-top-card .bell-btn.inbox-btn .inbox-text,
  .admin-top-card .bell-btn.inbox-btn .inbox-text{
    font-size:13px!important;
  }
  .dashboard-top-card .eyebrow,
  .dashboard-top-card h1,
  .dashboard-top-card .identity-line,
  .dashboard-top-card:not(.admin-top-card) .eyebrow,
  .dashboard-top-card:not(.admin-top-card) h1,
  .dashboard-top-card:not(.admin-top-card) p.identity-line,
  .admin-top-card .eyebrow,
  .admin-top-card h1,
  .admin-top-card .identity-line{
    max-width:calc(100% - 104px)!important;
  }
  .dashboard-top-card .eyebrow,
  .admin-top-card .eyebrow{
    margin:0 0 8px!important;
    font-size:12px!important;
    line-height:1.2!important;
  }
  .dashboard-top-card h1,
  .admin-top-card h1{
    margin:0 0 6px!important;
    font-size:22px!important;
    line-height:1.18!important;
  }
  .dashboard-top-card .identity-line,
  .admin-top-card .identity-line{
    margin-top:0!important;
    min-height:24px!important;
    font-size:12px!important;
    line-height:1.3!important;
  }
  .identity-line span{
    min-width:0;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  .dashboard-top-card .asset-stats{
    width:100%!important;
    margin-top:12px!important;
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:8px!important;
  }
  .dashboard-top-card .asset-stats .stat-card{
    min-height:74px!important;
    padding:9px 7px!important;
    border-radius:14px!important;
  }
  .dashboard-top-card .asset-stats .stat-card span{
    font-size:10px!important;
    line-height:1.25!important;
    margin-bottom:5px!important;
  }
  .dashboard-top-card .asset-stats .stat-card strong{
    font-size:17px!important;
    line-height:1.1!important;
  }
  .dashboard-top-card .asset-stats .stat-card em{
    display:none!important;
  }
  .portal-menu-bar,
  #adminMobileMenu.mobile-menu-bar{
    margin:12px 0 14px!important;
  }
  .portal-panel{
    margin-top:0!important;
  }
}

@media(max-width:430px){
  .dashboard-top-card,
  .admin-top-card{
    padding:14px 12px 10px!important;
  }
  .dashboard-top-card h1,
  .admin-top-card h1{
    font-size:20px!important;
  }
  .dashboard-top-card .eyebrow,
  .dashboard-top-card h1,
  .dashboard-top-card .identity-line,
  .dashboard-top-card:not(.admin-top-card) .eyebrow,
  .dashboard-top-card:not(.admin-top-card) h1,
  .dashboard-top-card:not(.admin-top-card) p.identity-line,
  .admin-top-card .eyebrow,
  .admin-top-card h1,
  .admin-top-card .identity-line{
    max-width:calc(100% - 96px)!important;
  }
  .dashboard-top-card .asset-stats{
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:6px!important;
  }
  .dashboard-top-card .asset-stats .stat-card{
    min-height:68px!important;
    padding:8px 5px!important;
  }
  .dashboard-top-card .asset-stats .stat-card span{
    font-size:10px!important;
  }
  .dashboard-top-card .asset-stats .stat-card strong{
    font-size:16px!important;
  }
}

/* 20260613 inbox icon repair: mobile top buttons use icon-only to free header space */
@media(max-width:780px){
  .dashboard-top-card .bell-btn.inbox-btn,
  .admin-top-card .bell-btn.inbox-btn{
    width:38px!important;
    height:38px!important;
    min-width:38px!important;
    padding:0!important;
    border-radius:50%!important;
  }
  .dashboard-top-card .bell-btn.inbox-btn .inbox-text,
  .admin-top-card .bell-btn.inbox-btn .inbox-text{
    display:none!important;
  }
  .dashboard-top-card .bell-btn.inbox-btn .inbox-icon,
  .admin-top-card .bell-btn.inbox-btn .inbox-icon{
    width:22px!important;
    height:22px!important;
    flex-basis:22px!important;
  }
  .dashboard-top-card .bell-btn.inbox-btn svg,
  .admin-top-card .bell-btn.inbox-btn svg{
    width:21px!important;
    height:21px!important;
  }
  .dashboard-top-card .eyebrow,
  .dashboard-top-card h1,
  .dashboard-top-card .identity-line,
  .dashboard-top-card:not(.admin-top-card) .eyebrow,
  .dashboard-top-card:not(.admin-top-card) h1,
  .dashboard-top-card:not(.admin-top-card) p.identity-line,
  .admin-top-card .eyebrow,
  .admin-top-card h1,
  .admin-top-card .identity-line{
    max-width:calc(100% - 56px)!important;
  }
}

/* 20260613 table final repair: equal readable columns, one-line cells, click for detail */
.table-wrap{
  overflow-x:auto!important;
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
}
.table-wrap table{
  table-layout:fixed!important;
  width:100%!important;
  min-width:var(--table-min-width, 1200px)!important;
}
.table-wrap th,
.table-wrap td{
  min-width:0!important;
  max-width:none!important;
  white-space:nowrap!important;
  word-break:keep-all!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  vertical-align:middle!important;
  line-height:1.35!important;
}
.table-wrap td br{
  display:none!important;
}
.table-wrap td small{
  display:inline!important;
  margin-left:4px;
  white-space:nowrap!important;
}
.table-wrap td:has(button),
.table-wrap td:has(.btn),
.table-wrap td:has(.text-link),
.table-wrap td:has(input),
.table-wrap .pager-row td{
  max-width:none!important;
}
.table-wrap td:has(button),
.table-wrap td:has(.btn){
  overflow-x:auto!important;
  overflow-y:hidden!important;
  text-overflow:clip!important;
}
.table-wrap .pager-row td{
  overflow:visible!important;
  text-overflow:clip!important;
}
.table-wrap .status,
.table-wrap .event-chip,
.table-wrap .compact-link,
.table-wrap .time-short{
  max-width:100%;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  white-space:nowrap!important;
  word-break:keep-all!important;
}
.table-wrap .status{
  display:inline-flex!important;
  width:auto!important;
}
.session-table-wrap table{
  display:table!important;
}
.session-table-wrap thead{
  display:table-header-group!important;
}
.session-table-wrap tbody{
  display:table-row-group!important;
}
.session-table-wrap tr{
  display:table-row!important;
  width:auto!important;
  margin:0!important;
  padding:0!important;
  border:0!important;
  border-radius:0!important;
  background:transparent!important;
}
.session-table-wrap th,
.session-table-wrap td{
  display:table-cell!important;
  width:auto!important;
  border-bottom:1px solid var(--line)!important;
  padding:12px 14px!important;
}
.table-wrap td,
.table-wrap th,
.time-short{
  cursor:default;
}
.table-wrap td:not(:has(button)):not(:has(a)):not(:has(input)):not(:has(select)):not(:has(textarea)),
.table-wrap th{
  cursor:pointer;
}
.cell-detail-pop{
  max-width:min(360px, calc(100vw - 28px));
  max-height:min(260px, calc(100vh - 80px));
  overflow:auto;
  white-space:pre-wrap;
  word-break:break-word;
}
.cell-popover{
  position:fixed;
  z-index:6200;
  width:min(360px, calc(100vw - 28px));
  max-height:min(280px, calc(100vh - 70px));
  overflow:auto;
  padding:14px 16px 16px;
  border-radius:16px;
  border:1px solid rgba(148,163,184,.28);
  background:#fff;
  color:#1f2937;
  box-shadow:0 24px 70px rgba(15,23,42,.24);
  line-height:1.7;
}
.cell-popover-close{
  position:absolute;
  top:6px;
  right:8px;
  width:28px;
  height:28px;
  border:0;
  border-radius:999px;
  background:#eef2ff;
  color:#3345c8;
  font-size:18px;
  line-height:1;
  cursor:pointer;
}
.cell-popover-body{
  padding-right:20px;
  white-space:pre-wrap;
  word-break:break-word;
}
@media(max-width:780px){
  .table-wrap table{
    width:var(--table-min-width, 1200px)!important;
    min-width:var(--table-min-width, 1200px)!important;
  }
  .table-wrap th,
  .table-wrap td{
    padding:9px 10px!important;
    font-size:12px!important;
  }
}

/* 20260613 final alignment and table hardening */
.table-wrap table{
  min-width:var(--table-min-width, 1440px)!important;
}
.table-wrap th,
.table-wrap td{
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  white-space:nowrap!important;
  word-break:keep-all!important;
  overflow-wrap:normal!important;
}
.table-wrap td > *,
.table-wrap th > *{
  max-width:100%;
}
.table-wrap .status{
  flex:0 0 auto;
  min-width:max-content;
}
@media(max-width:780px){
  .dashboard-top-card,
  .admin-top-card,
  html.device-phone .admin-top-card,
  html.device-ios-phone .admin-top-card,
  html.device-android-phone .admin-top-card,
  .dashboard-top-card:not(.admin-top-card){
    padding:12px 12px 10px!important;
    margin-bottom:8px!important;
  }
  .dashboard-top-card .bell-btn.inbox-btn,
  .admin-top-card .bell-btn.inbox-btn{
    top:8px!important;
    right:10px!important;
  }
  .dashboard-top-card .eyebrow,
  .admin-top-card .eyebrow{
    margin-bottom:6px!important;
  }
  .dashboard-top-card h1,
  .admin-top-card h1{
    margin-bottom:4px!important;
  }
  .portal-menu-bar,
  #adminMobileMenu.mobile-menu-bar{
    margin:6px 0 12px!important;
  }
  #adminMobileMenu .menu-popover{
    top:42px!important;
  }
  .table-wrap table,
  .session-table-wrap table{
    width:var(--table-min-width, 1440px)!important;
    min-width:var(--table-min-width, 1440px)!important;
  }
  .table-wrap th,
  .table-wrap td{
    min-width:0!important;
    writing-mode:horizontal-tb!important;
  }
}

/* 20260613 mobile overflow and review-table repair */
html,
body{
  max-width:100%;
  overflow-x:hidden!important;
}
#adminView,
#studentView,
.page-shell,
.admin-layout,
.admin-content,
.portal-panel{
  box-sizing:border-box;
  max-width:100%;
  min-width:0;
}
.admin-content,
.portal-panel{
  overflow:visible!important;
}
.table-wrap{
  width:100%;
  max-width:100%;
  box-sizing:border-box;
  contain:inline-size;
}
.table-section-row td{
  cursor:default!important;
  background:#f8fafc!important;
  color:#0f172a;
  font-weight:900;
  overflow:visible!important;
  text-overflow:clip!important;
}
.table-section-row td b{
  margin-right:8px;
}
.table-section-row td span{
  color:#64748b;
  font-size:12px;
  font-weight:800;
}
.notification-meta{
  display:flex;
  flex-wrap:wrap;
  gap:6px 10px;
  margin:8px 0;
  color:#64748b;
  font-size:12px;
  line-height:1.5;
}
.notification-meta span{
  display:inline-flex;
  align-items:center;
  max-width:100%;
  padding:2px 7px;
  border-radius:999px;
  background:#f1f5f9;
  color:#475569;
  font-weight:700;
}
.notification-content-box{
  margin-top:10px;
  padding:12px 14px;
  border-radius:14px;
  background:#f8fafc;
  border:1px solid rgba(148,163,184,.22);
  color:#334155;
  line-height:1.75;
  white-space:pre-wrap;
  word-break:break-word;
}
.notification-formatted h3{
  margin-bottom:6px!important;
}
.notification-item p{
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.notification-inline-detail .notification-item p,
.notification-formatted p{
  display:block;
  overflow:visible;
}
.badge.mini.hidden{
  display:none!important;
}
@media(max-width:780px){
  .page-shell{
    width:100%;
    overflow-x:hidden!important;
  }
  .mobile-menu-bar,
  #adminMobileMenu.mobile-menu-bar,
  .portal-menu-bar{
    width:100%;
    max-width:100%;
    box-sizing:border-box;
  }
  .menu-select-btn{
    max-width:100%;
    min-width:0!important;
  }
  .menu-popover{
    box-sizing:border-box;
    max-width:calc(100vw - 24px)!important;
  }
  #adminMobileMenu .menu-popover{
    width:100%!important;
    max-width:100%!important;
    left:0!important;
    right:auto!important;
  }
  .toolbar,
  .filter-toolbar,
  .toolbar-actions,
  .settings-subnav,
  .module-subnav,
  .pill-subnav{
    max-width:100%;
    box-sizing:border-box;
  }
  .dashboard-top-card,
  .admin-top-card{
    transform:none!important;
  }
}

/* 20260614 final convergence: icon-only inbox, centered dialogs, compact mobile top cards */
.bell-btn.inbox-btn{
  width:44px!important;
  min-width:44px!important;
  height:44px!important;
  padding:0!important;
  border-radius:50%!important;
  gap:0!important;
}
.bell-btn.inbox-btn .inbox-text{
  display:none!important;
}
.bell-btn.inbox-btn .inbox-icon{
  width:24px!important;
  height:24px!important;
  flex:0 0 24px!important;
}
.bell-btn.inbox-btn svg{
  width:22px!important;
  height:22px!important;
}
.app-modal{
  align-items:center!important;
  justify-content:center!important;
  padding:18px!important;
  overflow:auto!important;
}
.app-modal-panel{
  width:min(560px, calc(100vw - 32px))!important;
  max-height:calc(100dvh - 36px)!important;
  overflow:auto!important;
}
.app-modal .modal-body{
  max-height:calc(100dvh - 220px)!important;
  overflow:auto!important;
}
@media(max-width:780px){
  .dashboard-top-card,
  .admin-top-card,
  html.device-phone .admin-top-card,
  html.device-ios-phone .admin-top-card,
  html.device-android-phone .admin-top-card,
  .dashboard-top-card:not(.admin-top-card){
    padding:14px 12px 12px!important;
    margin:0 0 8px!important;
    min-height:0!important;
    overflow:visible!important;
  }
  .dashboard-top-card .bell-btn.inbox-btn,
  .admin-top-card .bell-btn.inbox-btn{
    top:10px!important;
    right:10px!important;
    width:40px!important;
    min-width:40px!important;
    height:40px!important;
  }
  .dashboard-top-card .eyebrow,
  .dashboard-top-card h1,
  .dashboard-top-card .identity-line,
  .dashboard-top-card:not(.admin-top-card) .eyebrow,
  .dashboard-top-card:not(.admin-top-card) h1,
  .dashboard-top-card:not(.admin-top-card) p.identity-line,
  .admin-top-card .eyebrow,
  .admin-top-card h1,
  .admin-top-card .identity-line{
    max-width:calc(100% - 54px)!important;
  }
  .dashboard-top-card .eyebrow,
  .admin-top-card .eyebrow{
    margin:0 0 6px!important;
  }
  .dashboard-top-card h1,
  .admin-top-card h1{
    margin:0 0 4px!important;
    line-height:1.18!important;
  }
  .dashboard-top-card .asset-stats{
    margin-top:10px!important;
  }
  .app-modal{
    align-items:center!important;
    justify-content:center!important;
    padding:12px!important;
  }
  .app-modal-panel{
    width:calc(100vw - 24px)!important;
    max-height:calc(100dvh - 24px)!important;
    padding:18px 14px!important;
    border-radius:20px!important;
    overflow:auto!important;
  }
  .app-modal .modal-body{
    max-height:calc(100dvh - 190px)!important;
    overflow:auto!important;
  }
}

/* 20260614 hard-fix: stable modal actions and readable admin tables */
#modalActions.state-actions,
.app-modal-panel .state-actions#modalActions{
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:10px!important;
  width:100%!important;
  flex-wrap:wrap!important;
}
#modalActions .modal-action-cancel{
  margin-right:auto!important;
  order:1;
}
#modalActions .modal-action-confirm{
  margin-left:0!important;
  order:2;
}
.admin-content .table-wrap,
#adminView .table-wrap{
  width:100%!important;
  max-width:100%!important;
  overflow-x:auto!important;
  overflow-y:visible!important;
  contain:none!important;
  border-radius:12px!important;
}
.admin-content .table-wrap table,
#adminView .table-wrap table{
  table-layout:auto!important;
  width:max-content!important;
  min-width:100%!important;
  border-collapse:separate!important;
  border-spacing:0!important;
}
.admin-content .table-wrap th,
.admin-content .table-wrap td,
#adminView .table-wrap th,
#adminView .table-wrap td{
  max-width:260px!important;
  min-width:72px!important;
  padding:11px 12px!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  line-height:1.45!important;
  vertical-align:middle!important;
}
.admin-content .table-wrap th,
#adminView .table-wrap th{
  position:sticky;
  top:0;
  z-index:1;
  background:#f8fafc!important;
}
.admin-content .table-wrap td:nth-child(1),
#adminView .table-wrap td:nth-child(1){
  min-width:116px!important;
}
.admin-content .table-wrap td:has(button),
.admin-content .table-wrap td:has(.btn),
#adminView .table-wrap td:has(button),
#adminView .table-wrap td:has(.btn){
  min-width:150px!important;
  max-width:300px!important;
  white-space:normal!important;
  overflow:visible!important;
  text-overflow:clip!important;
}
.admin-content .table-wrap td small,
#adminView .table-wrap td small{
  display:block!important;
  margin:3px 0 0!important;
  max-width:100%!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.admin-content .table-wrap td br,
#adminView .table-wrap td br{
  display:block!important;
}
.admin-content .table-wrap .table-section-row td,
#adminView .table-wrap .table-section-row td,
.admin-content .table-wrap .pager-row td,
#adminView .table-wrap .pager-row td{
  max-width:none!important;
  white-space:normal!important;
  overflow:visible!important;
}
#tab-registrations .table-wrap table{min-width:1320px!important;}
#tab-rewards .table-wrap table{min-width:1260px!important;}
#tab-points .table-wrap table{min-width:1120px!important;}
#tab-students .table-wrap table{min-width:980px!important;}
#tab-feedback .table-wrap table{min-width:1060px!important;}
#tab-audit .table-wrap table{min-width:1180px!important;}
#tab-password .table-wrap table{min-width:980px!important;}
body.review-chat-mode #adminCurrentLabel::after{
  content:" · 聊天数上报审核";
}
body.review-chat-mode .nav [data-tab="points"],
body.review-chat-mode #adminMenuPopover [data-tab="points"]{
  color:inherit!important;
  background:transparent!important;
  box-shadow:none!important;
}
@media(max-width:780px){
  #modalActions.state-actions,
  .app-modal-panel .state-actions#modalActions{
    flex-wrap:nowrap!important;
  }
  #modalActions .btn{
    min-width:88px!important;
    width:auto!important;
    flex:0 0 auto!important;
  }
  .admin-content .table-wrap,
  #adminView .table-wrap{
    margin-left:0!important;
    margin-right:0!important;
  }
  .admin-content .table-wrap th,
  .admin-content .table-wrap td,
  #adminView .table-wrap th,
  #adminView .table-wrap td{
    padding:9px 10px!important;
    font-size:12px!important;
    max-width:220px!important;
  }
  .admin-content .table-wrap td:has(button),
  .admin-content .table-wrap td:has(.btn),
  #adminView .table-wrap td:has(button),
  #adminView .table-wrap td:has(.btn){
    min-width:142px!important;
    max-width:240px!important;
  }
}

/* 20260614 review/email/sidebar/avatar leaderboard update */
@media (min-width:781px){
  .portal-menu-bar{display:none!important;}
  .portal-layout{display:grid;grid-template-columns:228px minmax(0,1fr);gap:14px;align-items:start;}
  .portal-sidebar{position:sticky;top:12px;display:flex!important;flex-direction:column;gap:12px;padding:16px;border-radius:18px;}
  .portal-content{min-width:0;}
  .portal-content>.portal-panel{margin:0;}
}
@media (max-width:780px){
  .portal-layout{display:block;}
  .portal-sidebar{display:none!important;}
}
.portal-sidebar .portal-side-title{display:flex!important;flex-direction:column!important;align-items:flex-start!important;gap:4px!important;margin:0 0 4px!important;}
.portal-sidebar .portal-side-title strong{font-size:18px!important;color:#0f172a!important;line-height:1.25!important;}
.portal-sidebar .portal-side-title span{display:block!important;width:auto!important;height:auto!important;background:none!important;border-radius:0!important;color:#64748b!important;font-size:12px!important;}
.portal-sidebar .nav{display:grid;gap:8px;}
.portal-sidebar .nav button{width:100%;text-align:left;border-radius:13px!important;padding:12px 13px!important;background:#f9fbff!important;border-color:var(--v8-line)!important;color:#40506a!important;font-size:14px!important;}
.portal-sidebar .nav button.active{color:#fff!important;border-color:transparent!important;background:linear-gradient(135deg,var(--v8-blue),var(--v8-purple))!important;box-shadow:0 8px 18px rgba(37,99,235,.18)!important;}
.portal-sidebar #portalSidebarLogout{margin-top:4px!important;}
.checkin-streak{margin:6px 0 12px;color:#2563eb;font-weight:900;font-size:13px;}
.chat-task-card{display:flex;align-items:center;justify-content:space-between;gap:14px;}
.chat-task-card>div{min-width:0;}
.chat-task-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;}
.email-status-card{padding:14px 16px;border-radius:16px;background:linear-gradient(135deg,#f8fafc,#eff6ff);border:1px solid rgba(37,99,235,.16);margin:12px 0;}
.email-status-card div{display:flex;flex-direction:column;gap:3px;}
.email-status-card b{color:#0f172a;}
.email-status-card span,.email-status-card em{color:#64748b;font-style:normal;}
.email-bind-layout{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:end;margin-top:12px;}
.email-input-group{min-width:0;}
.email-notify-check{align-self:center;padding:10px 12px;border-radius:14px;background:#f8fafc;border:1px solid rgba(148,163,184,.24);}
.email-bind-help{grid-column:1/-1;margin:0;}
.admin-email-notify{margin-top:8px;width:max-content;max-width:100%;}
.podium-stage.avatar-podium{display:grid!important;grid-template-columns:minmax(0,1fr) minmax(0,1.22fr) minmax(0,1fr)!important;align-items:end!important;gap:14px!important;background:linear-gradient(180deg,#f8fbff,#fff)!important;border:1px solid rgba(37,99,235,.14)!important;border-radius:18px!important;padding:22px 14px 14px!important;}
.podium-slot.avatar-rank{border-radius:18px!important;background:#fff!important;border:1px solid rgba(148,163,184,.22)!important;box-shadow:0 14px 30px rgba(15,23,42,.08)!important;min-height:168px!important;gap:6px!important;overflow:visible!important;}
.podium-slot.avatar-rank::after{display:none!important;}
.podium-slot.avatar-rank.rank-1{min-height:204px!important;transform:translateY(-10px)!important;border-color:rgba(245,158,11,.36)!important;}
.rank-avatar-wrap{position:relative;width:78px;height:78px;margin:0 auto 4px;}
.rank-avatar-wrap img{width:78px;height:78px;border-radius:50%;object-fit:cover;border:4px solid #fff;box-shadow:0 12px 26px rgba(15,23,42,.16);background:#eef2ff;}
.rank-avatar-wrap span{position:absolute;right:-2px;bottom:-2px;width:26px;height:26px;border-radius:50%;display:grid;place-items:center;background:#0f172a;color:#fff;font-weight:1000;font-size:13px;border:2px solid #fff;}
.podium-slot.avatar-rank.rank-1 .rank-avatar-wrap{width:92px;height:92px;}
.podium-slot.avatar-rank.rank-1 .rank-avatar-wrap img{width:92px;height:92px;border-color:#fef3c7;}
.podium-slot.avatar-rank.rank-1 .rank-avatar-wrap span{background:#f59e0b;}
.podium-slot.avatar-rank.rank-2 .rank-avatar-wrap span{background:#64748b;}
.podium-slot.avatar-rank.rank-3 .rank-avatar-wrap span{background:#c2410c;}
.podium-slot.avatar-rank small{font-size:12px;color:#64748b;font-weight:800;}
.leaderboard-row.avatar-row{display:grid!important;grid-template-columns:44px 42px minmax(0,1fr) auto!important;align-items:center!important;gap:10px!important;}
.leaderboard-avatar{width:42px;height:42px;border-radius:50%;object-fit:cover;background:#eef2ff;border:2px solid #fff;box-shadow:0 8px 18px rgba(15,23,42,.12);}
.leaderboard-row.avatar-row b{display:flex!important;flex-direction:column!important;gap:2px!important;min-width:0!important;}
.leaderboard-row.avatar-row small{font-size:12px;color:#64748b;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.lucky-result-card .confetti{letter-spacing:0!important;}
@media(max-width:780px){
  .chat-task-card{align-items:stretch;flex-direction:column;}
  .chat-task-actions{justify-content:stretch;}
  .chat-task-actions .btn{flex:1;}
  .email-bind-layout{grid-template-columns:1fr;}
  .email-notify-check{width:100%;box-sizing:border-box;}
  .lucky-bag-card{padding:12px!important;border-radius:16px!important;}
  .lucky-bag-main{gap:10px!important;align-items:flex-start!important;}
  .lucky-icon{width:42px!important;height:42px!important;min-width:42px!important;border-radius:14px!important;}
  .lucky-bag-svg svg{width:26px!important;height:26px!important;}
  .lucky-bag-card h3{font-size:16px!important;margin:0 0 4px!important;}
  .lucky-bag-card p{font-size:12px!important;margin:0 0 6px!important;line-height:1.45!important;}
  .lucky-progress{height:7px!important;margin:6px 0!important;}
  .baota-asset-line,#luckyProgressText{font-size:12px!important;}
  .baota-actions{display:grid!important;grid-template-columns:1fr 1fr!important;gap:8px!important;}
  .podium-stage.avatar-podium{grid-template-columns:1fr!important;padding:14px!important;}
  .podium-slot.avatar-rank{min-height:auto!important;padding:14px!important;transform:none!important;}
  .podium-slot.avatar-rank.rank-1{order:-1;transform:none!important;min-height:auto!important;}
  .rank-avatar-wrap,.rank-avatar-wrap img{width:64px!important;height:64px!important;}
  .podium-slot.avatar-rank.rank-1 .rank-avatar-wrap,.podium-slot.avatar-rank.rank-1 .rank-avatar-wrap img{width:72px!important;height:72px!important;}
  .leaderboard-row.avatar-row{grid-template-columns:38px 36px minmax(0,1fr) auto!important;padding:10px!important;}
  .leaderboard-avatar{width:36px;height:36px;}
}

/* 20260614 continuation: keep weekly check-in as seven compact cells on phones */
.checkin-row.weekly-row{
  display:grid!important;
  grid-template-columns:repeat(7,minmax(0,1fr))!important;
  gap:6px!important;
  overflow:visible!important;
}
.checkin-row.weekly-row .checkin-dot{
  min-width:0!important;
  min-height:54px!important;
  padding:7px 2px!important;
  border-radius:12px!important;
}
.checkin-row.weekly-row .checkin-dot b{
  display:block!important;
  font-size:12px!important;
  line-height:1.15!important;
}
.checkin-row.weekly-row .checkin-dot small{
  display:block!important;
  font-size:10px!important;
  line-height:1.15!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
@media(max-width:380px){
  .checkin-row.weekly-row{gap:4px!important;}
  .checkin-row.weekly-row .checkin-dot{
    min-height:50px!important;
    padding:6px 1px!important;
  }
  .checkin-row.weekly-row .checkin-dot b{font-size:11px!important;}
  .checkin-row.weekly-row .checkin-dot small{font-size:9px!important;}
}

/* 20260614 portal inbox: match admin controls and show full content */
.notification-drawer .notification-panel.notification-split-panel{
  display:flex!important;
  flex-direction:column!important;
  width:min(860px,100%)!important;
  height:100dvh!important;
  max-height:none!important;
  box-sizing:border-box!important;
  overflow:hidden!important;
}
.notification-panel .toolbar{
  flex:0 0 auto!important;
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:12px!important;
}
.notification-panel .toolbar h2{
  margin:0!important;
}
.notification-panel .state-actions{
  flex:0 0 auto!important;
  display:flex!important;
  align-items:center!important;
  gap:8px!important;
  width:auto!important;
}
.notification-panel .icon-btn{
  width:36px!important;
  height:36px!important;
  min-width:36px!important;
  padding:0!important;
}
.notification-split{
  flex:1 1 auto!important;
  min-height:0!important;
  height:auto!important;
}
.notification-list-pane,
.notification-detail-pane{
  min-height:0!important;
  max-height:none!important;
  overflow:auto!important;
  -webkit-overflow-scrolling:touch!important;
}
.notification-content-box{
  white-space:pre-wrap!important;
  word-break:break-word!important;
  line-height:1.75!important;
}
#feedbackRelatedEventCode[readonly],
#feedbackTitle[readonly]{
  background:#f1f5f9!important;
  color:#64748b!important;
  border-color:#cbd5e1!important;
  cursor:not-allowed!important;
}
@media(max-width:760px){
  .notification-drawer{
    display:flex!important;
    justify-content:stretch!important;
    background:#fff!important;
  }
  .notification-drawer.hidden{
    display:none!important;
  }
  .notification-drawer .notification-panel.notification-split-panel{
    width:100%!important;
    height:100dvh!important;
    padding:14px!important;
    border-radius:0!important;
  }
  .notification-split{
    display:grid!important;
    grid-template-rows:minmax(180px,42%) minmax(0,1fr)!important;
    grid-template-columns:1fr!important;
    gap:10px!important;
  }
  .notification-list-pane{
    padding-right:0!important;
    border-bottom:1px solid rgba(148,163,184,.20)!important;
    padding-bottom:10px!important;
  }
  .notification-detail-pane{
    display:block!important;
    min-height:0!important;
    padding:14px!important;
  }
  .notification-inline-detail{
    display:none!important;
  }
}
.portal-entry-actions{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  margin-top:14px;
}
.portal-entry-actions .btn{
  box-sizing:border-box;
  text-align:center;
  text-decoration:none;
}
.app-open-shell{
  min-height:100vh;
  display:grid;
  place-items:center;
}
.app-open-card{
  max-width:520px;
}
.app-open-copy{
  text-align:center;
  line-height:1.8;
  margin:8px 0 18px;
}
.app-open-actions{
  justify-content:center;
}
.admin-app-downloads{
  margin-top:16px;
  padding:14px;
  border:1px solid var(--v8-line);
  border-radius:18px;
  background:#f8fbff;
  display:grid;
  gap:8px;
}
.admin-app-downloads strong{
  font-size:15px;
  color:#0f172a;
}
.admin-app-downloads span{
  font-size:12px;
  color:var(--v8-muted);
}
.admin-app-downloads .btn{
  text-align:center;
  justify-content:center;
}
.admin-mobile-app-downloads{
  display:grid;
  gap:6px;
  padding:8px 10px 4px;
  margin:2px 0 4px;
  border-top:1px solid rgba(148,163,184,.18);
  border-bottom:1px solid rgba(148,163,184,.18);
}
.admin-mobile-app-downloads a{
  display:block;
  padding:9px 11px;
  border-radius:13px;
  background:#f8fbff;
  color:#2563eb;
  font-weight:800;
  text-align:left;
}
@media(min-width:781px){
  .portal-content{
    min-width:0;
    padding-top:2px;
  }
  .portal-panel{
    margin-top:12px;
    overflow:visible!important;
  }
  .portal-panel:first-child{
    margin-top:0;
  }
}
@media(max-width:780px){
  .portal-layout{
    display:block;
  }
  .portal-content{
    min-width:0;
    padding-top:0;
  }
  .portal-content > .portal-panel{
    margin-top:12px;
  }
  .portal-content > .portal-panel:first-child{
    margin-top:0;
  }
  .portal-panel,
  .card{
    overflow:visible!important;
  }
  .mobile-menu-bar.portal-menu-bar{
    margin:8px 0 12px!important;
    z-index:30;
  }
  .portal-menu-bar .menu-popover{
    width:100%;
    left:0;
    right:0;
    box-sizing:border-box;
  }
  .chat-task-card,
  .portal-entry-actions{
    flex-direction:column;
    align-items:stretch;
  }
  .chat-task-actions,
  .state-actions{
    justify-content:stretch;
  }
  .chat-task-actions .btn,
  .state-actions .btn{
    width:100%;
  }
  .portal-sidebar .nav button{
    white-space:nowrap;
  }
}
@media(max-width:520px){
  .portal-content > .portal-panel{
    margin-top:10px;
  }
  .home-block{
    margin-top:12px;
  }
}
@media(max-width:520px){
  .portal-entry-actions{
    grid-template-columns:1fr;
  }
  .app-open-actions .btn{
    width:100%;
  }
}

/* 20260615 portal inbox fix: prevent the student inbox from reserving a blank detail area on web/mobile. */
.portal-notification-drawer .notification-panel.notification-split-panel{
  width:min(860px, calc(100vw - 24px))!important;
  height:min(720px, calc(100dvh - 28px))!important;
  margin:auto 12px auto auto!important;
  border-radius:24px!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
}
.portal-notification-drawer .notification-split{
  flex:1 1 auto!important;
  min-height:0!important;
  display:grid!important;
  grid-template-columns:minmax(260px, 320px) minmax(0, 1fr)!important;
  gap:16px!important;
  height:auto!important;
}
.portal-notification-drawer .notification-list-pane,
.portal-notification-drawer .notification-detail-pane{
  min-height:0!important;
  overflow:auto!important;
}
.portal-notification-drawer .notification-detail-pane{
  display:block!important;
}
.portal-notification-drawer .notification-inline-detail{
  display:none!important;
}
@media(max-width:760px){
  .portal-notification-drawer{
    align-items:stretch!important;
    justify-content:stretch!important;
  }
  .portal-notification-drawer .notification-panel.notification-split-panel{
    width:100%!important;
    height:100dvh!important;
    margin:0!important;
    border-radius:0!important;
    padding:14px!important;
  }
  .portal-notification-drawer .notification-split{
    display:block!important;
    flex:1 1 auto!important;
    min-height:0!important;
    overflow:auto!important;
  }
  .portal-notification-drawer .notification-list-pane{
    overflow:visible!important;
    padding:0!important;
    border-bottom:0!important;
  }
  .portal-notification-drawer .notification-detail-pane{
    display:none!important;
  }
  .portal-notification-drawer .notification-inline-detail{
    display:block!important;
  }
}

/* 20260615 zongping-entry-and-compact-checkin */
.zongping-capability-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin:12px 0 14px;
}
.zongping-capability-grid div{
  padding:12px;
  border:1px solid rgba(47,111,115,.16);
  border-radius:12px;
  background:#f8fbff;
  min-width:0;
}
.zongping-capability-grid b{
  display:block;
  color:#0f172a;
  font-size:13px;
  margin-bottom:5px;
}
.zongping-capability-grid span{
  display:block;
  color:#64748b;
  font-size:12px;
  line-height:1.55;
}
.zongping-user-card{
  display:grid;
  gap:6px;
  padding:14px 16px;
  border:1px solid rgba(47,111,115,.18);
  border-left:4px solid #2f6f73;
  border-radius:8px;
  background:#f8fbff;
  margin:12px 0 14px;
}
.zongping-user-card>span{
  color:#2f6f73;
  font-size:12px;
  font-weight:900;
}
.zongping-user-card b{
  color:#0f172a;
  font-size:16px;
}
.zongping-user-card #identitySummary{
  display:grid;
  gap:4px;
}
.zongping-user-card #identitySummary span{
  color:#475569;
  line-height:1.55;
}
.zongping-helper-modal{
  display:grid;
  gap:10px;
  text-align:left;
}
.zongping-helper-status{
  display:grid;
  gap:5px;
  padding:12px 14px;
  border:1px solid rgba(47,111,115,.18);
  border-left:4px solid #2f6f73;
  border-radius:8px;
  background:#f8fbff;
}
.zongping-helper-status span{
  color:#2f6f73;
  font-size:12px;
  font-weight:900;
}
.zongping-helper-status b{
  color:#0f172a;
  font-size:16px;
}
.zongping-helper-status p{
  margin:0;
  color:#475569;
  line-height:1.55;
}
.zongping-capability-grid.compact{
  margin-top:10px;
}
.zongping-auth-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  margin-top:12px;
}
.zongping-auth-box{
  border:1px solid rgba(47,111,115,.16);
  border-radius:14px;
  background:#fbfcff;
  padding:14px;
  min-width:0;
}
.zongping-auth-box h3{
  margin:0 0 6px;
  color:#0f172a;
}
.zongping-auth-box p{
  margin:0 0 12px;
  color:#64748b;
  line-height:1.65;
}
.zongping-qr-box{
  display:grid;
  justify-items:center;
  gap:10px;
  margin-top:12px;
}
.zongping-qr-box img{
  width:220px;
  height:220px;
  max-width:100%;
  border:1px solid rgba(148,163,184,.24);
  border-radius:12px;
  background:#fff;
  padding:8px;
  box-sizing:border-box;
}
.zongping-code-box{
  display:grid;
  gap:8px;
  margin-top:12px;
  padding:12px;
  border-radius:12px;
  background:#f8fafc;
  border:1px solid rgba(148,163,184,.24);
}
.zongping-code-box b{
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:24px;
  letter-spacing:2px;
  color:#0f172a;
  word-break:break-all;
}
.zongping-code-box span{
  color:#64748b;
  line-height:1.55;
}
.zongping-entry-builder{
  margin:12px 0;
  padding:14px;
  border:1px solid rgba(47,111,115,.16);
  border-radius:14px;
  background:#fbfcff;
}
.zongping-entry-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.zongping-entry-head b{
  display:block;
  color:#0f172a;
}
.zongping-entry-head span{
  display:block;
  margin-top:3px;
  color:#64748b;
  font-size:12px;
  line-height:1.45;
}
.zongping-entry-list{
  display:grid;
  gap:10px;
}
.zongping-entry-card{
  padding:12px;
  border:1px solid rgba(148,163,184,.24);
  border-radius:12px;
  background:#fff;
}
.zongping-entry-card-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
}
.zongping-entry-fields{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
}
.zongping-entry-fields textarea{
  min-height:76px;
  grid-column:span 3;
}
.attachment-actions{
  flex-wrap:wrap;
}
.attachment-actions .btn{
  flex:1 1 auto;
}
#activationCard .notice{
  margin:0;
}
body.zongping-activation-only .zongping-intro-grid{
  grid-template-columns:minmax(0, 760px);
  justify-content:center;
}
body.zongping-activation-only #activationCard{
  display:block;
  width:100%;
}
body.zongping-activation-only #activationCard.hidden{
  display:none;
}
body.zongping-activation-only #activationCard p{
  color:#475569;
  line-height:1.75;
}
.declaration-gate-body{
  display:grid;
  gap:12px;
  max-height:min(50vh,420px);
  overflow:auto;
  padding-right:4px;
  text-align:left;
}
.declaration-gate-lead{
  padding:12px 14px;
  border:1px solid rgba(47,111,115,.22);
  border-radius:8px;
  background:#f0fdfa;
  color:#134e4a;
  font-size:16px;
  font-weight:800;
  line-height:1.7;
}
.declaration-gate-copy{
  display:grid;
  gap:8px;
  color:#334155;
  font-size:14px;
}
.declaration-gate-body p{
  margin:0;
  line-height:1.85;
}
.declaration-countdown{
  margin-top:12px;
}
.zongping-authorize-hero h1{
  font-size:clamp(28px,4vw,44px);
}
.zongping-authorize-card,
.zongping-authorize-side{
  border-radius:8px;
}
.authorize-page-title{
  display:grid;
  gap:6px;
  margin-bottom:14px;
}
.authorize-page-title span,
.zongping-authorize-side>span{
  color:#2f6f73;
  font-size:13px;
  font-weight:900;
}
.authorize-page-title h2,
.zongping-authorize-side h2{
  margin:0;
  font-size:26px;
  line-height:1.25;
  color:#0f172a;
}
.authorize-page-title p,
.zongping-authorize-side p{
  margin:0;
  color:#475569;
  line-height:1.75;
}
.authorize-declaration-wrap{
  margin-top:12px;
}
.authorize-declaration-wrap summary{
  cursor:pointer;
  font-weight:900;
  color:#2f6f73;
}
.authorization-confirm-copy{
  display:grid;
  gap:8px;
  text-align:left;
}
.authorization-confirm-copy p{
  margin:0;
  line-height:1.7;
}
#categoryStep.no-experience-mode label[for="categoryContent"],
#categoryStep.no-experience-mode #entryBuilder,
#categoryStep.no-experience-mode #categoryContent,
#categoryStep.no-experience-mode .zongping-word-row,
#categoryStep.no-experience-mode .zongping-tool-row,
#categoryStep.no-experience-mode .zongping-upload-card,
#categoryStep.no-experience-mode #attachmentGrid,
#categoryStep.no-experience-mode .zongping-ai-note{
  display:none!important;
}
.checkin-card{
  padding:14px!important;
}
.checkin-head{
  margin-bottom:4px!important;
}
.checkin-streak{
  margin:4px 0 10px!important;
  font-size:12px!important;
}
.checkin-row.weekly-row{
  display:grid!important;
  grid-template-columns:repeat(7,minmax(0,1fr))!important;
  gap:5px!important;
  overflow:visible!important;
  padding-bottom:0!important;
}
.checkin-row.weekly-row .checkin-dot{
  min-width:0!important;
  min-height:46px!important;
  padding:6px 1px!important;
  border-radius:10px!important;
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
  gap:2px!important;
}
.checkin-row.weekly-row .checkin-dot b{
  font-size:11px!important;
  line-height:1.1!important;
}
.checkin-row.weekly-row .checkin-dot small{
  max-width:100%!important;
  font-size:9px!important;
  line-height:1.1!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.checkin-card #checkinBtn{
  margin-top:10px!important;
  min-height:38px!important;
}
.checkin-source-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:28px;
  height:15px;
  padding:0 4px;
  border-radius:999px;
  background:rgba(255,255,255,.24);
  color:inherit;
  font-size:9px;
  line-height:1;
  font-weight:800;
}
.checkin-offline-summary{
  margin-top:10px;
  padding:9px 10px;
  border-radius:12px;
  background:#f8fafc;
  border:1px solid rgba(148,163,184,.24);
  color:#475569;
  font-size:12px;
  line-height:1.6;
}
.offline-device-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto auto;
  gap:12px;
  align-items:center;
  padding:14px;
  border-radius:16px;
  background:#f8fafc;
  border:1px solid rgba(148,163,184,.24);
}
.offline-device-card b,
.offline-device-card span,
.offline-device-card em{
  display:block;
}
.offline-device-card span,
.offline-device-card em{
  color:#64748b;
  font-size:12px;
  font-style:normal;
}
@media(max-width:760px){
  .zongping-capability-grid{
    grid-template-columns:1fr;
  }
  .zongping-auth-grid{
    grid-template-columns:1fr;
  }
  .zongping-entry-head{
    align-items:stretch;
    flex-direction:column;
  }
  .zongping-entry-fields{
    grid-template-columns:1fr;
  }
  .zongping-entry-fields textarea{
    grid-column:auto;
  }
  .checkin-card{
    padding:12px!important;
  }
  .checkin-row.weekly-row{
    gap:4px!important;
  }
  .checkin-row.weekly-row .checkin-dot{
    min-height:40px!important;
    padding:5px 1px!important;
    border-radius:9px!important;
  }
  .checkin-row.weekly-row .checkin-dot b{
    font-size:10px!important;
  }
	  .checkin-row.weekly-row .checkin-dot small{
	    font-size:8px!important;
	  }
	  .offline-device-card{
	    grid-template-columns:1fr;
	    align-items:stretch;
	  }
	}
@media(max-width:380px){
  .checkin-row.weekly-row{
    gap:3px!important;
  }
  .checkin-row.weekly-row .checkin-dot{
    min-height:38px!important;
  }
  .checkin-row.weekly-row .checkin-dot b{
    font-size:9px!important;
  }
  .checkin-row.weekly-row .checkin-dot small{
    font-size:7px!important;
  }
}

/* 20260615 zongping mobile wizard: one question per page */
@media(max-width:760px){
  .zongping-page .page-shell{
    padding:10px!important;
  }
  .zongping-hero{
    padding:18px!important;
    border-radius:16px!important;
    gap:12px!important;
  }
  .zongping-hero h1{
    font-size:30px!important;
    margin:8px 0 6px!important;
  }
  .zongping-hero p{
    font-size:13px!important;
    line-height:1.55!important;
    margin:0!important;
  }
  .zongping-flow{
    gap:10px!important;
    margin-top:10px!important;
  }
  .zongping-progress.zongping-flow-head{
    position:sticky!important;
    top:0!important;
    z-index:18!important;
    padding:12px!important;
    border-radius:14px!important;
    box-shadow:0 12px 28px rgba(15,23,42,.08)!important;
  }
  .zongping-flow-head .toolbar{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:8px!important;
  }
  .zongping-flow-head h2{
    font-size:16px!important;
    margin:0 0 3px!important;
    line-height:1.25!important;
  }
  .zongping-flow-head p{
    font-size:12px!important;
    margin:0!important;
  }
  .zongping-flow-head .state-actions{
    display:flex!important;
    flex-direction:row!important;
    justify-content:space-between!important;
    align-items:center!important;
    gap:8px!important;
  }
  .zongping-save-state,
  .zongping-mode-badge{
    font-size:11px!important;
    padding:6px 8px!important;
  }
  .zongping-progress-bar{
    height:7px!important;
    margin:8px 0 10px!important;
  }
  .zongping-flow .zongping-step-list{
    position:relative!important;
    display:grid!important;
    grid-template-columns:repeat(12,minmax(0,1fr))!important;
    gap:4px!important;
    overflow:visible!important;
    padding:34px 0 0!important;
  }
  .zongping-flow .zongping-step-list::before{
    content:attr(data-current-name) " · " attr(data-current-detail);
    position:absolute;
    left:0;
    top:0;
    right:0;
    color:#0f172a;
    font-size:12px;
    font-weight:900;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .zongping-flow .zongping-step-pill{
    min-width:0!important;
    width:100%!important;
    height:26px!important;
    padding:0!important;
    display:grid!important;
    grid-template-columns:1fr!important;
    place-items:center!important;
    border-radius:8px!important;
  }
  .zongping-flow .zongping-step-pill span{
    width:100%!important;
    height:100%!important;
    border-radius:7px!important;
    font-size:11px!important;
  }
  .zongping-flow .zongping-step-pill b,
  .zongping-flow .zongping-step-pill small{
    display:none!important;
  }
  .zongping-page-step{
    max-width:none!important;
    padding:14px!important;
    border-radius:16px!important;
    margin:0 0 76px!important;
  }
  .zongping-page-step>.toolbar{
    display:block!important;
    margin-bottom:8px!important;
  }
  .zongping-page-step .eyebrow{
    font-size:11px!important;
  }
  .zongping-page-step h2{
    font-size:22px!important;
    line-height:1.25!important;
    margin:6px 0!important;
  }
  .zongping-page-step p{
    line-height:1.55!important;
  }
  .zongping-step-panel{
    margin-top:8px!important;
  }
  .zongping-question-card{
    padding:14px!important;
    border-radius:14px!important;
    margin:8px 0 10px!important;
  }
  .question-title{
    font-size:18px!important;
    line-height:1.35!important;
  }
  .zongping-question-card p{
    font-size:13px!important;
    margin:8px 0 0!important;
  }
  .zongping-question-card .state-actions{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:8px!important;
    margin-top:12px!important;
  }
  .zongping-textarea{
    min-height:44dvh!important;
    font-size:15px!important;
    line-height:1.75!important;
    border-radius:14px!important;
  }
  .zongping-word-row{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:4px!important;
    font-size:12px!important;
  }
  .zongping-tool-row{
    display:grid!important;
    grid-template-columns:1fr 1fr!important;
    gap:8px!important;
  }
  .zongping-tool-row .btn{
    width:100%!important;
    min-width:0!important;
    white-space:normal!important;
    line-height:1.25!important;
  }
  .zongping-ai-note{
    font-size:12px!important;
    line-height:1.55!important;
  }
  .zongping-upload-card{
    padding:12px!important;
    border-radius:14px!important;
  }
  .zongping-upload-card h3{
    font-size:16px!important;
  }
  .zongping-upload-card p{
    font-size:12px!important;
  }
  .zongping-attachment-grid{
    grid-template-columns:1fr!important;
  }
  .attachment-card{
    display:grid!important;
    grid-template-columns:86px minmax(0,1fr)!important;
    align-items:center!important;
  }
  .attachment-card img{
    width:86px!important;
    height:86px!important;
    aspect-ratio:auto!important;
  }
  .attachment-actions{
    grid-column:1/-1;
    padding:0 10px 10px!important;
  }
  .zongping-nav-actions{
    position:sticky!important;
    bottom:0!important;
    z-index:16!important;
    display:grid!important;
    grid-template-columns:1fr 1fr!important;
    gap:8px!important;
    margin:14px -14px -14px!important;
    padding:10px 14px calc(10px + env(safe-area-inset-bottom))!important;
    background:rgba(255,255,255,.96)!important;
    border-top:1px solid rgba(148,163,184,.24)!important;
    backdrop-filter:blur(10px)!important;
  }
  .zongping-nav-actions .btn{
    width:100%!important;
    min-width:0!important;
  }
  .zongping-entry-builder{
    padding:12px!important;
    border-radius:14px!important;
  }
  .attachment-actions{
    display:grid!important;
    grid-template-columns:1fr 1fr 1fr!important;
    gap:6px!important;
  }
  .attachment-actions .btn{
    width:100%!important;
    padding:0 8px!important;
  }
  #saveDraftBtn{
    grid-column:1/-1!important;
    order:-1!important;
  }
  #basicStep .form-grid{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:10px!important;
  }
  #finalSummary .settings-grid{
    grid-template-columns:1fr!important;
  }
  .zongping-tool-reserve{
    padding:14px!important;
    border-radius:16px!important;
  }
}
@media(max-width:380px){
  .zongping-tool-row{
    grid-template-columns:1fr!important;
  }
  .zongping-textarea{
    min-height:40dvh!important;
  }
}

/* 20260615 zongping-flow-fixes */
.zongping-entry-actions{align-items:stretch}
.zongping-entry-actions .btn{min-width:150px;white-space:normal}
.zongping-entry-status{overflow-wrap:anywhere}
.inline-field-actions{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:8px;align-items:stretch}
.inline-field-actions .btn{min-width:72px}
.school-suggest-list{display:grid;gap:8px;margin-top:8px}
.school-suggest-item{width:100%;display:grid;gap:4px;text-align:left;border:1px solid #dbe5f0;background:#fff;border-radius:10px;padding:10px 12px;cursor:pointer;color:#0f172a}
.school-suggest-item span{font-size:12px;color:#64748b;line-height:1.5}
.label.compact{margin:0 0 6px;font-size:12px;color:#475569}
.zongping-entry-fields .span-3{grid-column:1/-1}
.zongping-entry-fields.official-duty-fields textarea{min-height:92px}
.zongping-package-actions{display:flex;justify-content:flex-end;margin:10px 0 0;padding:0;background:transparent}
.zongping-package-meta{color:#475569;font-size:13px;font-weight:800}
.zongping-package-trigger{width:auto!important;min-height:34px!important;padding:8px 12px!important;font-size:12px!important;border-radius:999px!important}
.zongping-natural-input{min-height:180px;resize:vertical;line-height:1.75}
.compact-entry-actions{gap:8px!important;justify-content:flex-end!important;margin:0!important}
.zongping-entry-builder.structured-collapsed #entryList{display:none}
.zongping-entry-builder.structured-expanded #entryList{display:grid}
.zongping-entry-builder.structured-collapsed{background:#fff}
.zongping-entry-builder.structured-expanded{background:#fbfcff}
.activation-other-school-field.hidden,
#activationClassHint.hidden{display:none!important}
#categoryStep.detail-collapsed-mode label[for="categoryContent"],
#categoryStep.detail-collapsed-mode #entryBuilder,
#categoryStep.detail-collapsed-mode #categoryContent,
#categoryStep.detail-collapsed-mode .zongping-word-row,
#categoryStep.detail-collapsed-mode .zongping-tool-row,
#categoryStep.detail-collapsed-mode .zongping-upload-card,
#categoryStep.detail-collapsed-mode #attachmentGrid,
#categoryStep.detail-collapsed-mode .zongping-ai-note{display:none!important}
.tool-code-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;margin-top:10px}
.authorization-row{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 0;border-bottom:1px dashed rgba(148,163,184,.28)}
.authorization-row:last-child{border-bottom:0}
.authorization-row span{display:block;color:#64748b;font-size:12px;line-height:1.5}
.scan-video{display:block;width:100%;max-height:52vh;object-fit:cover;border-radius:16px;background:#0f172a;margin-bottom:12px}
.checkin-card .checkin-head{display:grid!important;grid-template-columns:1fr;justify-items:center;text-align:center;gap:4px}
.checkin-card .checkin-head b{display:flex;align-items:center;justify-content:center;min-width:72px;text-align:center}
.checkin-card .checkin-streak{text-align:center}
.checkin-row.weekly-row .checkin-dot{align-items:center!important;text-align:center!important}
@media(max-width:760px){
  .zongping-entry-actions{display:grid;grid-template-columns:1fr!important}
  .zongping-entry-actions .btn{width:100%;min-width:0}
  .inline-field-actions{grid-template-columns:1fr 1fr}
  .inline-field-actions .input{grid-column:1/-1}
  .inline-field-actions .btn{width:100%;min-width:0}
  .tool-code-row{grid-template-columns:1fr}
  .authorization-row{align-items:stretch;flex-direction:column}
}

/* 20260619 admin submenu: second-level menus stay in one horizontal row. */
@media (min-width:781px){
  #adminView .settings-subnav:not(.hidden):not(.review-only):not(.review-reset-only),
  body.review-chat-mode #adminView .settings-subnav.review-only:not(.hidden),
  body.review-reset-mode #adminView .settings-subnav.review-reset-only:not(.hidden){
    display:flex!important;
    flex-direction:row!important;
    flex-wrap:nowrap!important;
    align-items:center!important;
    justify-content:flex-start!important;
    width:100%!important;
    min-width:0!important;
    max-width:100%!important;
    gap:8px!important;
    overflow-x:auto!important;
    overflow-y:hidden!important;
    -webkit-overflow-scrolling:touch!important;
  }
  #adminView .settings-subnav > button{
    display:inline-flex!important;
    width:auto!important;
    min-width:max-content!important;
    min-height:40px!important;
    text-align:center!important;
    justify-content:center!important;
    white-space:nowrap!important;
    line-height:1.2!important;
    flex:0 0 auto!important;
  }
}

@media (max-width:780px){
  #adminView .settings-subnav:not(.hidden):not(.review-only):not(.review-reset-only),
  body.review-chat-mode #adminView .settings-subnav.review-only:not(.hidden),
  body.review-reset-mode #adminView .settings-subnav.review-reset-only:not(.hidden),
  .portal-panel .pill-subnav:not(.hidden){
    display:flex!important;
    flex-direction:row!important;
    flex-wrap:nowrap!important;
    align-items:center!important;
    width:100%!important;
    max-width:100%!important;
    overflow-x:auto!important;
    overflow-y:hidden!important;
    -webkit-overflow-scrolling:touch!important;
  }
  #adminView .settings-subnav > button,
  .portal-panel .pill-subnav > button{
    width:auto!important;
    min-width:max-content!important;
    white-space:nowrap!important;
    flex:0 0 auto!important;
  }
}

body.review-chat-mode #adminView #pointsSubnav,
body.review-reset-mode #adminView #adminSecuritySubnav{
  display:none!important;
}

/* 20260619 zongping fill/auth rebuild */
body.zongping-fill-only #introView,
body.zongping-fill-only #toolAuthView,
body.zongping-fill-only #packageActions,
body.zongping-activation-only #packageActions{
  display:none!important;
}
body.zongping-auth-only #introView,
body.zongping-auth-only #appView{
  display:none!important;
}
.zongping-tool-view{
  margin-top:18px;
}
.zongping-tool-view .zongping-tool-reserve{
  padding:22px;
}
.zongping-auth-grid{
  align-items:stretch;
  gap:16px;
}
.zongping-auth-box{
  display:grid;
  align-content:start;
  gap:10px;
}
.zongping-auth-box .notice{
  margin-top:4px;
}
.zongping-step-pill{
  cursor:pointer!important;
  pointer-events:auto!important;
  font:inherit;
}
.zongping-step-pill:hover{
  border-color:rgba(47,111,115,.42);
  box-shadow:0 8px 20px rgba(47,111,115,.10);
}
.zongping-step-pill.skipped span{
  background:#f1f5f9;
  color:#64748b;
}
#categoryStep.skip-mode label[for="categoryContent"],
#categoryStep.skip-mode #entryBuilder,
#categoryStep.skip-mode #categoryContent,
#categoryStep.skip-mode .zongping-word-row,
#categoryStep.skip-mode .zongping-tool-row,
#categoryStep.skip-mode .zongping-upload-card,
#categoryStep.skip-mode #attachmentGrid,
#categoryStep.skip-mode .zongping-ai-note,
#categoryStep.skip-mode #categoryConfirmedRow{
  display:none!important;
}
@media(max-width:760px){
  .zongping-flow .zongping-step-list{
    grid-template-columns:repeat(11,minmax(0,1fr))!important;
  }
  .zongping-nav-actions{
    grid-template-columns:.82fr .82fr 1.36fr!important;
    align-items:center!important;
  }
  .zongping-nav-actions .btn{
    min-height:42px!important;
    padding:9px 8px!important;
    white-space:normal!important;
    line-height:1.2!important;
  }
  #saveDraftBtn{
    grid-column:auto!important;
    order:0!important;
  }
  .zongping-tool-view{
    margin-top:14px;
  }
  .zongping-tool-view .zongping-tool-reserve{
    padding:14px!important;
  }
}
@media(max-width:380px){
  .zongping-nav-actions{
    grid-template-columns:1fr 1fr!important;
  }
  #nextStepBtn{
    grid-column:1/-1!important;
  }
}

/* 20260619 zongping fill interaction repair */
body.zongping-fill-only .zongping-shell{
  width:min(1160px,100%);
}
body.zongping-fill-only .zongping-hero{
  margin-bottom:16px;
}
body.zongping-fill-only .zongping-flow{
  display:grid;
  grid-template-columns:minmax(240px,300px) minmax(0,1fr);
  gap:16px;
  align-items:start;
}
body.zongping-fill-only .zongping-flow.hidden{
  display:none!important;
}
body.zongping-fill-only .zongping-progress.zongping-flow-head{
  position:sticky;
  top:14px;
  max-height:calc(100dvh - 28px);
  overflow:auto;
}
body.zongping-fill-only .zongping-editor{
  min-width:0;
}
.zongping-decision-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr;
  gap:10px!important;
  justify-content:stretch!important;
}
.zongping-decision-actions .btn{
  width:100%;
  min-width:0;
  white-space:normal;
  text-align:center;
  line-height:1.25;
}
.zongping-decision-notice{
  margin:10px 0 12px;
}
.zongping-question-card{
  background:linear-gradient(180deg,#fff,#f8fbff);
}
#categoryStep.no-experience-mode .zongping-question-card,
#categoryStep.skip-mode .zongping-question-card{
  margin-bottom:10px;
}
#categoryStep.no-experience-mode #categoryConfirmedRow{
  display:none!important;
}
.zongping-entry-builder:not(.hidden),
.zongping-upload-card:not(.hidden),
.zongping-ai-note:not(.hidden),
.zongping-attachment-grid:not(.hidden){
  margin-top:12px;
}
.zongping-textarea{
  min-height:220px;
}
.zongping-tool-row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
}
.zongping-tool-row .btn{
  min-width:132px;
}
.zongping-auth-box .state-actions{
  justify-content:flex-start;
  margin-top:4px;
}
.zongping-auth-box .tool-code-row{
  margin-top:12px;
}
.zongping-auth-box #qrAuthState{
  margin-top:12px;
}
.zongping-auth-list{
  display:grid;
  gap:8px;
}
.zongping-tool-view .zongping-auth-grid{
  gap:20px;
}
.zongping-tool-view .zongping-auth-box{
  padding:18px;
  gap:12px;
}
.zongping-tool-view .zongping-auth-box .state-actions{
  gap:10px;
  margin-top:2px;
}
.zongping-tool-view .tool-code-row{
  gap:10px;
  align-items:center;
  margin-top:8px;
}
.zongping-tool-view #qrAuthState{
  margin-top:8px!important;
}
.zongping-auth-list{
  gap:10px;
}
.authorization-row{
  gap:14px;
  padding:12px 0;
}
.authorization-row .btn{
  flex:0 0 auto;
}
.zongping-tool-view .zongping-auth-box{
  min-height:220px;
}
.zongping-tool-view .zongping-auth-box p{
  margin-bottom:8px;
}
.zongping-tool-view .zongping-auth-box .btn{
  white-space:normal;
  line-height:1.25;
}
.zongping-tool-view .zongping-auth-box .notice,
.zongping-tool-view .zongping-auth-list{
  overflow-wrap:anywhere;
}
.zongping-authorize-card .zongping-status-box{
  padding:14px;
  border:1px solid rgba(47,111,115,.14);
  border-radius:8px;
  background:#f8fbff;
}
.zongping-authorize-card .zongping-status-box>div{
  display:grid;
  grid-template-columns:108px minmax(0,1fr);
  gap:10px;
  align-items:start;
}
.zongping-authorize-card .zongping-status-box b{
  color:#0f172a;
}
.zongping-authorize-card .zongping-status-box span{
  overflow-wrap:anywhere;
}
@media(max-width:900px){
  body.zongping-fill-only .zongping-flow{
    grid-template-columns:1fr;
  }
  body.zongping-fill-only .zongping-progress.zongping-flow-head{
    position:sticky;
    top:0;
    max-height:none;
  }
}
@media(max-width:760px){
  body.zongping-fill-only .zongping-flow{
    display:grid!important;
    grid-template-columns:1fr!important;
  }
  .zongping-decision-actions{
    grid-template-columns:1fr!important;
  }
  .zongping-decision-actions #expandDetailBtn{
    order:-1;
  }
  .zongping-nav-actions{
    grid-template-columns:1fr 1fr!important;
    gap:8px!important;
  }
  #nextStepBtn{
    grid-column:1/-1!important;
    order:-1;
  }
  #saveDraftBtn{
    grid-column:auto!important;
    order:0!important;
  }
  .zongping-auth-box .state-actions{
    display:grid!important;
    grid-template-columns:1fr!important;
  }
  .zongping-tool-view .tool-code-row{
    grid-template-columns:1fr!important;
  }
  .zongping-authorize-card .zongping-status-box>div{
    grid-template-columns:1fr;
    gap:2px;
  }
  .zongping-auth-box #qrAuthState{
    margin-top:14px!important;
  }
}

/* 20260628 zongping assistant mobile and activation polish */
.activation-risk-panel{
  display:grid;
  gap:8px;
  margin:12px 0 16px;
  padding:12px;
  border:1px solid rgba(47,111,115,.18);
  border-radius:8px;
  background:#f8fbff;
}
.activation-risk-panel b{
  color:#0f172a;
  font-size:15px;
  line-height:1.35;
}
.activation-risk-panel span{
  color:#475569;
  font-size:13px;
  line-height:1.65;
}
.activation-help-actions{
  justify-content:flex-start!important;
  margin-top:2px!important;
}
.activation-help-actions .btn{
  min-width:120px;
}
body.zongping-activation-only .zongping-intro-grid{
  grid-template-columns:minmax(0,760px)!important;
}
body.zongping-activation-only #activationCard{
  max-width:760px;
}
body.zongping-activation-only #activationCard .state-actions{
  align-items:stretch;
}

@media(max-width:760px){
  body.zongping-fill-only{
    min-height:100dvh;
    background:#f6f8fb;
  }
  body.zongping-fill-only .zongping-shell{
    padding:8px!important;
    width:100%!important;
  }
  body.zongping-fill-only .zongping-hero{
    display:grid!important;
    grid-template-columns:minmax(0,1fr) auto;
    align-items:center;
    gap:8px!important;
    margin:0 0 8px!important;
    padding:10px 12px!important;
    border-radius:10px!important;
  }
  body.zongping-fill-only .zongping-hero h1{
    font-size:19px!important;
    margin:2px 0 0!important;
    line-height:1.2!important;
  }
  body.zongping-fill-only .zongping-hero .eyebrow{
    font-size:10px!important;
    line-height:1.2!important;
  }
  body.zongping-fill-only .zongping-hero p{
    display:none!important;
  }
  body.zongping-fill-only .zongping-hero-actions{
    display:flex!important;
    gap:6px!important;
  }
  body.zongping-fill-only .zongping-hero-actions .btn{
    min-height:34px!important;
    padding:7px 9px!important;
    font-size:12px!important;
    white-space:nowrap!important;
  }
  body.zongping-fill-only .zongping-flow{
    gap:8px!important;
    margin-top:0!important;
    padding-bottom:calc(76px + env(safe-area-inset-bottom))!important;
  }
  body.zongping-fill-only .zongping-progress.zongping-flow-head{
    position:sticky!important;
    top:0!important;
    z-index:20!important;
    max-height:none!important;
    overflow:hidden!important;
    padding:8px 10px!important;
    border-radius:10px!important;
    box-shadow:0 8px 18px rgba(15,23,42,.08)!important;
  }
  body.zongping-fill-only .zongping-flow-head .toolbar{
    grid-template-columns:minmax(0,1fr)!important;
    gap:5px!important;
  }
  body.zongping-fill-only .zongping-flow-head h2{
    font-size:14px!important;
    margin:0!important;
    white-space:nowrap!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
  }
  body.zongping-fill-only .zongping-flow-head p{
    font-size:11px!important;
    line-height:1.3!important;
    white-space:nowrap!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
  }
  body.zongping-fill-only .zongping-flow-head .state-actions{
    gap:6px!important;
  }
  body.zongping-fill-only .zongping-save-state,
  body.zongping-fill-only .zongping-mode-badge{
    min-height:24px!important;
    padding:4px 7px!important;
    font-size:10px!important;
    line-height:1.2!important;
    border-radius:999px!important;
  }
  body.zongping-fill-only .zongping-progress-bar{
    height:5px!important;
    margin:6px 0 7px!important;
  }
  body.zongping-fill-only .zongping-flow .zongping-step-list{
    display:flex!important;
    gap:6px!important;
    overflow-x:auto!important;
    overflow-y:hidden!important;
    padding:22px 0 2px!important;
    scroll-snap-type:x proximity;
    -webkit-overflow-scrolling:touch;
  }
  body.zongping-fill-only .zongping-flow .zongping-step-list::before{
    font-size:11px!important;
    line-height:1.2!important;
  }
  body.zongping-fill-only .zongping-flow .zongping-step-pill{
    flex:0 0 34px!important;
    width:34px!important;
    height:28px!important;
    scroll-snap-align:start;
  }
  body.zongping-fill-only .zongping-flow .zongping-step-pill span{
    font-size:11px!important;
  }
  body.zongping-fill-only .zongping-page-step{
    margin:0!important;
    padding:12px!important;
    border-radius:10px!important;
  }
  body.zongping-fill-only .zongping-page-step>.toolbar{
    margin-bottom:6px!important;
  }
  body.zongping-fill-only .zongping-page-step h2{
    font-size:19px!important;
    margin:3px 0!important;
  }
  body.zongping-fill-only .zongping-page-step p{
    font-size:13px!important;
  }
  body.zongping-fill-only .zongping-question-card{
    padding:11px!important;
    border-radius:10px!important;
    margin:6px 0 8px!important;
  }
  body.zongping-fill-only .question-title{
    font-size:16px!important;
  }
  body.zongping-fill-only .zongping-entry-builder{
    padding:10px!important;
    border-radius:10px!important;
  }
  body.zongping-fill-only .zongping-entry-head{
    gap:8px!important;
  }
  body.zongping-fill-only .zongping-entry-head b{
    font-size:14px!important;
  }
  body.zongping-fill-only .zongping-entry-head span{
    font-size:12px!important;
    line-height:1.45!important;
  }
  body.zongping-fill-only .compact-entry-actions{
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:6px!important;
  }
  body.zongping-fill-only .compact-entry-actions .btn{
    min-width:0!important;
    min-height:34px!important;
    padding:7px 6px!important;
    font-size:12px!important;
    white-space:normal!important;
  }
  body.zongping-fill-only .zongping-natural-input{
    min-height:132px!important;
    font-size:14px!important;
    line-height:1.65!important;
  }
  body.zongping-fill-only .zongping-entry-fields{
    grid-template-columns:1fr!important;
  }
  body.zongping-fill-only .zongping-entry-fields textarea,
  body.zongping-fill-only .zongping-entry-fields .span-3{
    grid-column:auto!important;
  }
  body.zongping-fill-only .zongping-textarea{
    min-height:30dvh!important;
    font-size:14px!important;
    line-height:1.65!important;
    border-radius:10px!important;
  }
  body.zongping-fill-only .zongping-tool-row{
    grid-template-columns:1fr!important;
  }
  body.zongping-fill-only .zongping-upload-card{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:10px!important;
    padding:11px!important;
    border-radius:10px!important;
  }
  body.zongping-fill-only .zongping-upload-card .btn{
    width:100%!important;
  }
  body.zongping-fill-only .zongping-nav-actions{
    position:fixed!important;
    left:0!important;
    right:0!important;
    bottom:0!important;
    z-index:30!important;
    display:grid!important;
    grid-template-columns:1fr 1.25fr!important;
    gap:8px!important;
    margin:0!important;
    padding:8px max(10px,env(safe-area-inset-left)) calc(8px + env(safe-area-inset-bottom)) max(10px,env(safe-area-inset-right))!important;
    background:rgba(255,255,255,.97)!important;
    border-top:1px solid rgba(148,163,184,.28)!important;
    box-shadow:0 -10px 24px rgba(15,23,42,.10)!important;
    backdrop-filter:blur(12px)!important;
  }
  body.zongping-fill-only .zongping-nav-actions .btn{
    min-height:42px!important;
    padding:9px 8px!important;
    font-size:14px!important;
  }
  body.zongping-fill-only #nextStepBtn{
    grid-column:auto!important;
    order:0!important;
  }
}

@media(max-width:760px){
  body.zongping-activation-only .zongping-shell{
    padding:10px!important;
  }
  body.zongping-activation-only .zongping-hero{
    padding:14px!important;
    border-radius:10px!important;
  }
  body.zongping-activation-only .zongping-hero h1{
    font-size:24px!important;
  }
  body.zongping-activation-only #activationCard{
    padding:14px!important;
    border-radius:10px!important;
  }
  body.zongping-activation-only #activationForm{
    grid-template-columns:1fr!important;
    gap:10px!important;
  }
  body.zongping-activation-only #activationForm .span-2,
  body.zongping-activation-only .activation-risk-panel{
    grid-column:auto!important;
  }
  body.zongping-activation-only .activation-help-actions,
  body.zongping-activation-only #activationForm .state-actions{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:8px!important;
  }
  body.zongping-activation-only .activation-help-actions .btn,
  body.zongping-activation-only #activationForm .state-actions .btn{
    width:100%!important;
  }
}

/* 20260629 zongping mobile redeem entry: keep redemption controls fully visible. */
body.zongping-page .zongping-intro-card,
body.zongping-page .zongping-entry-status,
body.zongping-page .zongping-entry-actions{
  min-width:0!important;
  max-width:100%!important;
  box-sizing:border-box!important;
}
body.zongping-page .zongping-shell,
body.zongping-page .zongping-hero,
body.zongping-page .zongping-hero-actions,
body.zongping-page .zongping-intro-grid{
  min-width:0!important;
  max-width:100%!important;
  box-sizing:border-box!important;
}
body.zongping-page .zongping-entry-status{
  overflow-wrap:anywhere!important;
  word-break:break-word!important;
}
body.zongping-page .zongping-entry-actions{
  width:100%!important;
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(min(180px,100%),1fr))!important;
  gap:10px!important;
  align-items:stretch!important;
  justify-content:stretch!important;
  overflow:visible!important;
}
body.zongping-page .state-actions.zongping-entry-actions{
  flex-wrap:initial!important;
}
body.zongping-page .zongping-entry-actions .btn{
  width:100%!important;
  min-width:0!important;
  max-width:100%!important;
  min-height:44px!important;
  height:auto!important;
  box-sizing:border-box!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:10px 12px!important;
  text-align:center!important;
  white-space:normal!important;
  overflow-wrap:anywhere!important;
  line-height:1.35!important;
}
@media(max-width:760px){
  body.zongping-page .zongping-shell{
    max-width:100vw!important;
    overflow-x:hidden!important;
  }
  body.zongping-page .zongping-hero{
    display:grid!important;
    grid-template-columns:minmax(0,1fr)!important;
    padding:18px!important;
    gap:14px!important;
    overflow:hidden!important;
  }
  body.zongping-page .zongping-hero-actions{
    display:grid!important;
    grid-template-columns:minmax(0,1fr)!important;
    justify-content:stretch!important;
  }
  body.zongping-page .zongping-hero-actions .btn{
    width:100%!important;
    min-width:0!important;
    white-space:normal!important;
  }
  body.zongping-page .zongping-intro-grid{
    grid-template-columns:minmax(0,1fr)!important;
  }
  body.zongping-page .zongping-intro-card{
    padding-left:14px!important;
    padding-right:14px!important;
    overflow:hidden!important;
  }
  body.zongping-page .zongping-entry-actions{
    grid-template-columns:minmax(0,1fr)!important;
  }
}

/* 20260629 zongping redeem mobile hard stop: no clipped action buttons. */
body.zongping-page{
  overflow-x:hidden!important;
}
body.zongping-page .page-shell,
body.zongping-page .zongping-shell,
body.zongping-page #introView,
body.zongping-page #introCard,
body.zongping-page #activationCard,
body.zongping-page .zongping-intro-card,
body.zongping-page .zongping-entry-actions,
body.zongping-page .zongping-entry-actions>*{
  min-width:0!important;
  max-width:100%!important;
  box-sizing:border-box!important;
}
body.zongping-page .zongping-entry-actions{
  flex:initial!important;
}
body.zongping-page .zongping-entry-actions .btn{
  min-width:0!important;
  max-width:100%!important;
  width:100%!important;
  white-space:normal!important;
  overflow:visible!important;
  text-overflow:clip!important;
  overflow-wrap:anywhere!important;
  word-break:break-word!important;
}
@media(max-width:760px){
  body.zongping-page .page-shell{
    width:100%!important;
    padding-left:10px!important;
    padding-right:10px!important;
  }
  body.zongping-page .zongping-intro-card,
  body.zongping-page #activationCard{
    padding:14px!important;
    overflow:visible!important;
  }
  body.zongping-page .zongping-entry-actions{
    display:grid!important;
    grid-template-columns:minmax(0,1fr)!important;
    justify-items:stretch!important;
    align-items:stretch!important;
  }
}
