:root {
  --bg: #eef4ff;
  --surface: #ffffff;
  --surface-soft: rgba(255, 255, 255, 0.9);
  --text: #183153;
  --muted: #6f86a7;
  --primary: #0f67d3;
  --primary-deep: #0a4ca8;
  --primary-soft: #dceaff;
  --accent: #ff7b49;
  --border: rgba(17, 77, 160, 0.12);
  --shadow: 0 16px 40px rgba(13, 71, 145, 0.14);
  --radius-xl: 28px;
  --radius-lg: 22px;
  --radius-md: 16px;
  --radius-sm: 12px;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
  font-family: "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;
  background: #eef2f7;
  color: var(--text);
}

body {
  display: flex;
  justify-content: center;
  padding: 0;
}

button,
input {
  font: inherit;
}

button {
  border: 0;
  background: none;
  cursor: pointer;
}

.app-shell {
  width: 100%;
  display: flex;
  justify-content: center;
  position: relative;
}

.phone-stage {
  width: min(100%, 402px);
  min-height: 100vh;
  background: #fff;
  border-radius: 0;
  overflow: hidden;
  position: relative;
  touch-action: pan-y;
  overscroll-behavior: contain;
}

.screen {
  display: none;
  min-height: 100vh;
  position: absolute;
  inset: 0;
  width: 100%;
  background: inherit;
  will-change: transform;
  backface-visibility: hidden;
}

.screen.active {
  display: flex;
  flex-direction: column;
  z-index: 2;
}

.screen.screen-underlay {
  display: flex;
  flex-direction: column;
  z-index: 1;
}

.screen.transition-disabled {
  transition: none !important;
}

.screen-home {
  background: #fff;
}

.home-shot {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.home-shot-image {
  width: 100%;
  display: block;
}

.shot-stage {
  position: relative;
  width: 100%;
  overflow: hidden;
  container-type: inline-size;
}

.shot-image {
  width: 100%;
  display: block;
}

.screen-card-home,
.screen-card-detail {
  background: #fff;
}

.success-toast {
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) scale(0.96);
  min-width: 104px;
  padding: 11px 16px;
  border-radius: 14px;
  background: rgba(24, 31, 46, 0.86);
  color: #fff;
  text-align: center;
  font-size: 15px;
  line-height: 1.2;
  letter-spacing: 0.02em;
  opacity: 0;
  pointer-events: none;
  z-index: 30;
}

.success-toast.visible {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.face-scan-shell {
  position: absolute;
  left: 19.9%;
  top: 20.8%;
  width: 60.2%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: #ffffff;
  box-shadow:
    0 0 0 10px rgba(255, 255, 255, 0.98),
    0 10px 30px rgba(70, 149, 224, 0.08);
}

.face-scan-ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  display: grid;
  place-items: center;
}

.face-scan-ring::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background:
    conic-gradient(
      from -84deg,
      #97d8ff 0deg,
      #6bc4ff 52deg,
      #2f9df3 118deg,
      #2b93ea 152deg,
      rgba(223, 229, 236, 0.96) 152deg,
      rgba(223, 229, 236, 0.96) 216deg,
      #d7edf9 216deg,
      #97d8ff 266deg,
      #5cb9fb 326deg,
      #3095eb 360deg
    );
}

.face-scan-ring::before {
  content: "";
  position: absolute;
  inset: 9px;
  border-radius: 50%;
  background: #ffffff;
}

.face-scan-inner {
  position: relative;
  z-index: 1;
  width: calc(100% - 22px);
  height: calc(100% - 22px);
  border-radius: 50%;
  overflow: hidden;
  background: #d6d6d6;
}

.camera-preview-shell {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(234, 239, 246, 0.9), rgba(226, 231, 239, 0.86)),
    #d9d9d9;
}

.camera-preview {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scaleX(-1);
  display: block;
}

.shot-hotspot {
  position: absolute;
  background: transparent;
  z-index: 4;
  -webkit-tap-highlight-color: transparent;
}

.entry-hotspot {
  position: absolute;
  background: transparent;
}

.login-hotspot {
  position: absolute;
  left: 73.6%;
  top: 26.9%;
  width: 17.2%;
  height: 2.95%;
  border-radius: 12px;
}

.proof-hotspot {
  left: 54.5%;
  top: 46.1%;
  width: 37.2%;
  height: 7.35%;
  border-radius: 10px;
}

.back-hotspot {
  left: 2%;
  top: 0.6%;
  width: 16%;
  height: 5.2%;
}

.consent-agree-hotspot {
  left: 4.1%;
  top: 80.5%;
  width: 91.6%;
  height: 6%;
  border-radius: 999px;
}

.consent-password-hotspot {
  left: 4.1%;
  top: 88.2%;
  width: 91.6%;
  height: 5.9%;
  border-radius: 999px;
}

.face-close-hotspot {
  left: 1.8%;
  top: 0.6%;
  width: 15%;
  height: 7.5%;
}

.password-entry {
  position: absolute;
  left: 18.4%;
  top: 22.1%;
  width: 63.5%;
  height: 8.4%;
}

.password-digits {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 10px;
  width: 100%;
  height: 100%;
}

.password-digit {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #3a3a3a;
  font-size: 34px;
  font-weight: 700;
  line-height: 1;
}

.password-digit.filled::before {
  content: "•";
}

.password-input {
  position: absolute;
  inset: 0;
  z-index: 2;
  opacity: 0.015;
  border: 0;
  outline: none;
  background: transparent;
  color: transparent;
  caret-color: transparent;
  font-size: 16px;
  -webkit-text-security: disc;
  appearance: none;
}

.password-message {
  position: absolute;
  left: 0;
  right: 0;
  top: 43.8%;
  margin: 0;
  text-align: center;
  font-size: 13px;
  color: #d93025;
}

.password-submit-hotspot {
  left: 4.3%;
  top: 35.7%;
  width: 91.3%;
  height: 7.3%;
  border-radius: 10px;
}

.screen-proof-query {
  background: #ffffff;
}

.screen-proof-result {
  background:
    linear-gradient(180deg, #eef6ff 0%, #ffffff 28%);
}

.card-home-proof-hotspot {
  left: 50.3%;
  top: 50.3%;
  width: 45.9%;
  height: 12.3%;
  border-radius: 14px;
  z-index: 12;
  touch-action: manipulation;
  pointer-events: auto;
}

.card-home-eye-hotspot {
  right: 2.8%;
  top: 0.35%;
  width: 9.4%;
  height: 5.6%;
  border-radius: 50%;
}

.card-home-avatar-hotspot {
  right: 5.2%;
  top: 5.95%;
  width: 20.2%;
  height: 15.4%;
  border-radius: 10px;
}

.detail-back-hotspot {
  left: 0.8%;
  top: 0.6%;
  width: 24%;
  height: 8.2%;
}

.proof-query-back-hotspot {
  left: 1.2%;
  top: 6.1%;
  width: 14.5%;
  height: 5.6%;
}

.proof-query-submit-hotspot {
  left: 4.65%;
  top: 34.05%;
  width: 90.8%;
  height: 7.45%;
  border-radius: 12px;
  z-index: 8;
  touch-action: manipulation;
}

.proof-result-shell {
  flex: 1;
  min-height: 100vh;
  padding: calc(18px + env(safe-area-inset-top)) 18px 28px;
  display: flex;
  flex-direction: column;
}

.proof-result-back {
  width: 28px;
  height: 28px;
  position: relative;
  margin-bottom: 18px;
}

.proof-result-back::before {
  content: "";
  position: absolute;
  left: 8px;
  top: 8px;
  width: 10px;
  height: 10px;
  border-top: 2px solid #1a2a45;
  border-left: 2px solid #1a2a45;
  transform: rotate(-45deg);
}

.proof-result-card {
  margin-top: 8px;
  padding: 24px;
  border-radius: 24px;
  background: #ffffff;
  border: 1px solid rgba(17, 77, 160, 0.08);
  box-shadow: 0 18px 34px rgba(17, 77, 160, 0.08);
}

.proof-result-card h2,
.proof-result-card p {
  margin: 0;
}

.proof-result-tag {
  display: inline-flex;
  margin-bottom: 14px;
  padding: 7px 12px;
  border-radius: 999px;
  background: #e9f2ff;
  color: #1f67d2;
  font-size: 12px;
  font-weight: 700;
}

.proof-result-card h2 {
  font-size: 24px;
  line-height: 1.3;
  color: #1c2d49;
}

.proof-result-card p {
  margin-top: 10px;
  color: #60708d;
  font-size: 14px;
  line-height: 1.65;
}

.card-home-live,
.card-detail-live {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.card-home-line,
.card-detail-line,
.card-detail-value {
  position: absolute;
  display: block;
  white-space: nowrap;
  color: #1e1f21;
  line-height: 1;
  font-weight: 400;
  font-family: "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;
}

.card-detail-value {
  color: #111111;
}

.card-home-line,
.card-detail-line {
  letter-spacing: 0;
}

.card-home-name-line {
  left: 6.85%;
  top: 15.35%;
  font-size: 5.06cqw;
}

.card-home-ssn-line {
  left: 6.8%;
  top: 20.28%;
  font-size: 4.96cqw;
}

.card-home-bank-line {
  left: 15.2%;
  top: 25.16%;
  font-size: 4.84cqw;
}

.card-detail-card-name-line {
  left: 6.8%;
  top: 12.94%;
  font-size: 5.04cqw;
}

.card-detail-card-ssn-line {
  left: 6.8%;
  top: 17.84%;
  font-size: 4.94cqw;
}

.card-detail-card-bank-line {
  left: 15.2%;
  top: 22.72%;
  font-size: 4.8cqw;
}

.card-detail-name,
.card-detail-ssn,
.card-detail-region,
.card-detail-card-number,
.card-detail-bank-card-value {
  right: 4.7%;
  text-align: right;
}

.card-detail-name {
  top: 35.75%;
  font-size: 5.18cqw;
}

.card-detail-ssn {
  top: 43.34%;
  font-size: 5.06cqw;
}

.card-detail-region {
  top: 51.1%;
  font-size: 4.92cqw;
}

.card-detail-card-number {
  top: 58.8%;
  font-size: 5.1cqw;
}

.card-detail-bank-card-value {
  top: 66.32%;
  font-size: 5.08cqw;
}

.status-row,
.title-row,
.search-bar,
.hero-top,
.hero-footer,
.quick-tools,
.panel-title,
.city-cards,
.simple-header,
.section-head,
.captcha-row,
.result-hero,
.summary-strip {
  display: flex;
  align-items: center;
}

.status-row,
.title-row,
.hero-footer,
.search-bar,
.panel-title,
.simple-header,
.summary-strip {
  justify-content: space-between;
}

.status-row {
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 8px;
}

.signal-group {
  display: flex;
  align-items: center;
  gap: 8px;
}

.signal-bars {
  width: 18px;
  height: 12px;
  display: inline-block;
  background:
    linear-gradient(to top, #fff 100%, transparent 0) left bottom/3px 4px no-repeat,
    linear-gradient(to top, #fff 100%, transparent 0) 5px bottom/3px 7px no-repeat,
    linear-gradient(to top, #fff 100%, transparent 0) 10px bottom/3px 9px no-repeat,
    linear-gradient(to top, #fff 100%, transparent 0) right bottom/3px 12px no-repeat;
}

.battery {
  width: 24px;
  height: 12px;
  border: 1.6px solid #fff;
  border-radius: 3px;
  position: relative;
}

.battery::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 14px;
  height: 6px;
  border-radius: 1px;
  background: #fff;
}

.battery::before {
  content: "";
  position: absolute;
  right: -4px;
  top: 3px;
  width: 2px;
  height: 4px;
  border-radius: 2px;
  background: #fff;
}

.title-row h1,
.simple-header h2,
.query-banner h3,
.tips-card h4,
.result-name {
  margin: 0;
}

.title-row h1 {
  font-size: 30px;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.nav-icon {
  width: 24px;
  height: 24px;
  position: relative;
}

.nav-icon span,
.back-btn::before {
  content: "";
  width: 10px;
  height: 10px;
  border-top: 2px solid currentColor;
  border-left: 2px solid currentColor;
  transform: rotate(-45deg);
  display: block;
}

.nav-icon span {
  color: #fff;
  margin-top: 6px;
  margin-left: 6px;
}

.header-actions {
  display: flex;
  gap: 8px;
}

.circle-action {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
  font-size: 18px;
  display: grid;
  place-items: center;
}

.search-bar {
  gap: 8px;
  margin-top: 16px;
}

.city-pill {
  color: rgba(255, 255, 255, 0.9);
  font-size: 13px;
}

.search-input {
  flex: 1;
  min-height: 38px;
  padding: 0 12px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.96);
  color: #90a0bf;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
}

.search-btn {
  min-width: 56px;
  height: 38px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
  font-weight: 700;
}

.home-body {
  flex: 1;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #f5f8ff 16%);
  padding: 0 14px 84px;
}

.hero-card {
  padding: 18px;
  background:
    linear-gradient(140deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.04)),
    linear-gradient(180deg, #8dbbff 0%, #72a8fa 100%);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.hero-top {
  gap: 14px;
  align-items: flex-start;
}

.seal-mark {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #fff 0%, #ffe2d7 42%, #ff7f4d 100%);
  display: grid;
  place-items: center;
  color: #d6421c;
  font-weight: 700;
  box-shadow: inset 0 0 0 4px rgba(255, 255, 255, 0.8);
}

.hero-title {
  margin: 0;
  font-size: 18px;
  font-weight: 700;
}

.hero-subtitle {
  margin: 8px 0 0;
  font-size: 15px;
  opacity: 0.9;
}

.hero-footer {
  margin-top: 24px;
  gap: 12px;
}

.hero-footer p {
  margin: 0;
  font-size: 13px;
  opacity: 0.92;
}

.primary-mini,
.primary-btn {
  background: linear-gradient(180deg, #ffffff 0%, #edf4ff 100%);
  color: var(--primary-deep);
  font-weight: 700;
}

.primary-mini {
  min-width: 64px;
  height: 38px;
  border-radius: 12px;
}

.quick-tools {
  justify-content: space-between;
  margin: 18px 0 16px;
  color: #fff;
}

.tool-item {
  width: 22%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  color: #fff;
  font-size: 13px;
}

.tool-icon {
  width: 32px;
  height: 32px;
  border-radius: 10px;
  border: 1.8px solid rgba(255, 255, 255, 0.85);
  position: relative;
}

.tool-scan::before,
.tool-scan::after,
.tool-code::before,
.tool-service::before,
.tool-version::before {
  content: "";
  position: absolute;
}

.tool-scan::before {
  inset: 7px;
  border: 1.8px dashed rgba(255, 255, 255, 0.9);
}

.tool-code::before {
  inset: 7px;
  background:
    linear-gradient(#fff 0 0) left top/7px 7px no-repeat,
    linear-gradient(#fff 0 0) right top/7px 7px no-repeat,
    linear-gradient(#fff 0 0) left bottom/7px 7px no-repeat,
    linear-gradient(#fff 0 0) right bottom/7px 7px no-repeat;
}

.tool-service::before {
  left: 8px;
  right: 8px;
  top: 9px;
  height: 12px;
  border: 1.8px solid #fff;
  border-top-left-radius: 5px;
  border-top-right-radius: 5px;
}

.tool-version::before {
  left: 6px;
  right: 6px;
  top: 8px;
  bottom: 8px;
  border: 1.8px solid #fff;
  border-radius: 6px;
}

.panel {
  background: var(--surface-soft);
  border-radius: var(--radius-lg);
  box-shadow: 0 12px 28px rgba(20, 67, 133, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.7);
}

.service-panel {
  padding: 16px 10px 10px;
}

.service-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 14px;
}

.service-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  text-align: left;
  color: var(--text);
  min-height: 54px;
  position: relative;
}

.service-item.hot::before {
  content: "热";
  position: absolute;
  left: -6px;
  top: -6px;
  width: 18px;
  height: 18px;
  border-radius: 6px;
  background: #ff4d4d;
  color: #fff;
  font-size: 11px;
  display: grid;
  place-items: center;
}

.service-item span:last-child {
  font-size: 14px;
  line-height: 1.35;
}

.service-badge {
  width: 30px;
  height: 30px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  flex: none;
}

.badge-orange {
  background: linear-gradient(180deg, #ffb15d 0%, #ff8b2c 100%);
}

.badge-blue {
  background: linear-gradient(180deg, #6e9eff 0%, #4071f3 100%);
}

.badge-gold {
  background: linear-gradient(180deg, #ffc972 0%, #ff9e3d 100%);
}

.badge-coral {
  background: linear-gradient(180deg, #ff9b86 0%, #ff7456 100%);
}

.badge-red {
  background: linear-gradient(180deg, #ff9985 0%, #ff6c56 100%);
}

.badge-amber {
  background: linear-gradient(180deg, #ffbf75 0%, #ff9752 100%);
}

.badge-yellow {
  background: linear-gradient(180deg, #ffcd72 0%, #ffb136 100%);
}

.badge-indigo {
  background: linear-gradient(180deg, #6f8dff 0%, #4f66e6 100%);
}

.topic-panel {
  margin-top: 18px;
  padding: 16px;
}

.panel-title {
  margin-bottom: 14px;
}

.panel-title span {
  font-size: 15px;
  font-weight: 700;
}

.panel-title strong {
  color: var(--accent);
  font-size: 22px;
  font-weight: 800;
}

.city-cards {
  gap: 12px;
}

.city-card {
  flex: 1;
  min-height: 96px;
  padding: 16px;
  border-radius: 18px;
  background: linear-gradient(180deg, #f8fbff 0%, #ebf3ff 100%);
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.city-card p {
  margin: 0 0 4px;
  font-size: 16px;
  font-weight: 700;
}

.city-card span {
  color: var(--muted);
  font-size: 13px;
}

.city-card-icon {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  position: relative;
}

.city-card-icon::before {
  content: "";
  position: absolute;
  inset: 10px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.9);
}

.city-card-blue {
  background: linear-gradient(180deg, #5d9cff 0%, #3477ea 100%);
}

.city-card-teal {
  background: linear-gradient(180deg, #54b1f4 0%, #2577da 100%);
}

.bottom-nav {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  padding: 10px 8px calc(10px + env(safe-area-inset-bottom));
  background: rgba(255, 255, 255, 0.92);
  border-top: 1px solid rgba(15, 103, 211, 0.12);
  backdrop-filter: blur(12px);
}

.nav-tab {
  color: #8b95a8;
  font-size: 13px;
}

.nav-tab.active {
  color: var(--primary);
  font-weight: 700;
}

.screen-query,
.screen-result {
  background:
    radial-gradient(circle at top right, rgba(88, 159, 255, 0.18), transparent 28%),
    linear-gradient(180deg, #f4f8ff 0%, #eef4ff 100%);
}

.screen-password,
.screen-face,
.screen-auth {
  background: #fff;
}

.simple-header {
  padding: calc(18px + env(safe-area-inset-top)) 18px 14px;
  min-height: 76px;
}

.simple-header h2 {
  font-size: 22px;
  font-weight: 700;
}

.back-btn {
  width: 28px;
  height: 28px;
  color: var(--text);
  display: grid;
  place-items: center;
}

.page-body {
  flex: 1;
  padding: 10px 16px 28px;
}

.query-banner {
  padding: 22px;
  border-radius: 24px;
  background:
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.34), transparent 30%),
    linear-gradient(135deg, #0f67d3 0%, #2f8bff 100%);
  color: #fff;
  box-shadow: var(--shadow);
}

.eyebrow {
  margin: 0 0 10px;
  display: inline-flex;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.16);
  font-size: 12px;
}

.query-banner h3 {
  font-size: 24px;
  line-height: 1.35;
}

.muted-text {
  margin: 10px 0 0;
  font-size: 14px;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.86);
}

.form-card,
.tips-card,
.result-list article,
.summary-strip,
.result-hero {
  background: var(--surface);
  border-radius: 24px;
  border: 1px solid rgba(17, 77, 160, 0.08);
  box-shadow: 0 18px 34px rgba(17, 77, 160, 0.08);
}

.form-card,
.tips-card {
  margin-top: 16px;
  padding: 18px;
}

.section-head {
  justify-content: space-between;
  margin-bottom: 16px;
  gap: 16px;
}

.section-head p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}

.section-tag {
  padding: 7px 12px;
  border-radius: 999px;
  background: var(--primary-soft);
  color: var(--primary);
  font-size: 12px;
  font-weight: 700;
}

.field {
  display: block;
  margin-bottom: 14px;
}

.field span {
  display: block;
  margin-bottom: 8px;
  font-size: 14px;
  font-weight: 600;
}

.field input {
  width: 100%;
  height: 50px;
  padding: 0 14px;
  border-radius: 14px;
  border: 1px solid rgba(17, 77, 160, 0.14);
  background: #f7faff;
  color: var(--text);
  outline: none;
}

.field input:focus {
  border-color: rgba(15, 103, 211, 0.48);
  box-shadow: 0 0 0 4px rgba(15, 103, 211, 0.12);
}

.captcha-row {
  gap: 12px;
  align-items: flex-end;
}

.compact-field {
  flex: 1;
  margin-bottom: 0;
}

.captcha-box {
  width: 108px;
  height: 50px;
  border-radius: 14px;
  background:
    linear-gradient(135deg, rgba(15, 103, 211, 0.08) 25%, transparent 25%) -10px 0/20px 20px,
    linear-gradient(225deg, rgba(15, 103, 211, 0.08) 25%, transparent 25%) -10px 0/20px 20px,
    linear-gradient(315deg, rgba(15, 103, 211, 0.08) 25%, transparent 25%) 0 0/20px 20px,
    linear-gradient(45deg, rgba(15, 103, 211, 0.08) 25%, transparent 25%) 0 0/20px 20px,
    #e8f1ff;
  color: var(--primary-deep);
  border: 1px solid rgba(15, 103, 211, 0.14);
}

#captcha-code {
  display: inline-block;
  font-size: 24px;
  font-weight: 800;
  letter-spacing: 0.18em;
  transform: rotate(-4deg);
}

.helper-text,
.error-text,
.tips-card li,
.result-meta,
.record-detail,
.record-footer {
  font-size: 13px;
  line-height: 1.6;
}

.helper-text {
  margin: 12px 0 6px;
  color: var(--muted);
}

.error-text {
  min-height: 22px;
  margin: 0 0 10px;
  color: #d93025;
}

.primary-btn {
  width: 100%;
  height: 52px;
  border-radius: 16px;
  background: linear-gradient(180deg, #1f81ff 0%, #0f67d3 100%);
  color: #fff;
  box-shadow: 0 14px 26px rgba(15, 103, 211, 0.26);
}

.tips-card h4 {
  font-size: 17px;
  margin-bottom: 8px;
}

.tips-card ul {
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
}

.result-hero {
  padding: 18px;
  gap: 14px;
}

.profile-mark {
  width: 54px;
  height: 54px;
  border-radius: 18px;
  background: linear-gradient(180deg, #0f67d3 0%, #5ba7ff 100%);
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 24px;
  font-weight: 800;
  flex: none;
}

.result-name {
  font-size: 20px;
}

.result-meta {
  margin: 6px 0 0;
  color: var(--muted);
}

.summary-strip {
  margin-top: 14px;
  padding: 18px;
  gap: 14px;
}

.summary-strip > div {
  flex: 1;
}

.summary-strip strong {
  display: block;
  font-size: 20px;
  margin-bottom: 6px;
  color: var(--primary-deep);
}

.summary-strip span {
  color: var(--muted);
  font-size: 13px;
}

.result-list {
  margin-top: 14px;
  display: grid;
  gap: 14px;
}

.result-list article {
  padding: 16px;
}

.record-header,
.record-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.record-title {
  margin: 0;
  font-size: 17px;
  font-weight: 700;
}

.record-status {
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
}

.record-status.active {
  color: #137333;
  background: #e6f4ea;
}

.record-status.paused {
  color: #b06000;
  background: #fff3e0;
}

.record-detail {
  margin: 12px 0;
  color: var(--text);
}

.record-detail strong {
  color: var(--primary-deep);
}

.record-footer {
  color: var(--muted);
}

@media (max-width: 420px) {
  body {
    padding: 0;
  }

  .phone-stage,
  .screen {
    width: 100%;
    min-height: 100vh;
    border-radius: 0;
  }
}
