/* Final loaded stylesheet for the mobile UI. */
body { font-size: 16px; }
.app-shell { padding: 8px 12px calc(76px + env(safe-area-inset-bottom)); }
.mobile-header { gap: 8px; padding: 7px 0 10px; align-items: center; }
.install-button { min-height: 38px; padding: 0 13px; font-size: 13px; }
.eyebrow { margin-bottom: 3px; font-size: 10px; }
h1 { font-size: 26px; }
h2 { margin-bottom: 4px; font-size: 22px; }
h3 { margin-bottom: 8px; font-size: 18px; }
.wallet-pill { min-width: 86px; padding: 8px 10px; border-radius: 16px; }
.wallet-pill span, .balance-card span { font-size: 12px; }
.wallet-pill strong { margin-top: 2px; font-size: 18px; }
.install-tip { gap: 12px; margin-bottom: 12px; padding: 14px; border-radius: 20px; }
.install-tip strong { font-size: 16px; }
.install-tip p { font-size: 14px; line-height: 1.55; }
.install-tip button { min-height: 44px; padding: 0 14px; border-radius: 14px; font-size: 14px; }
.user-card { gap: 8px; margin-bottom: 10px; padding: 12px; border-radius: 20px; }
.login-form-card { gap: 8px; }
.login-success-card { gap: 10px; padding: 0; }
.login-success-card strong { font-size: 16px; }
.login-success-card p { margin-top: 1px; font-size: 13px; }
.login-dot { flex: 0 0 11px; width: 11px; height: 11px; box-shadow: 0 0 0 4px rgba(255, 127, 189, 0.14); }
label { gap: 6px; font-size: 14px; }
.username-row { gap: 8px; }
input, select { min-height: 42px; padding: 0 12px; border-radius: 13px; font-size: 15px; }
textarea { min-height: 72px; height: 72px; padding: 12px; border-radius: 14px; line-height: 1.5; font-size: 15px; overflow: hidden; resize: none; }
.username-row button, .copy-button { min-height: 42px; padding: 0 14px; border-radius: 13px; font-size: 14px; }
.user-meta { gap: 8px; font-size: 12px; }
.tab-panel { gap: 12px; padding: 14px; border-radius: 22px; }
.section-title { gap: 10px; }
.section-title p, .pay-card p, .rule-card p, .balance-card p { line-height: 1.45; font-size: 13px; }
.number-badge { flex: 0 0 36px; width: 36px; height: 36px; border-radius: 13px; font-size: 12px; }
.tool-form { gap: 11px; }
.form-grid { gap: 9px; }
.upload-box { min-height: 96px; border-radius: 16px; }
.upload-copy { gap: 4px; }
.upload-copy strong { font-size: 17px; }
.upload-copy span { font-size: 13px; }
#upload-preview { height: 132px; }
.primary-button { min-height: 50px; border-radius: 16px; font-size: 17px; }
.ghost-button { min-height: 40px; padding: 0 13px; border-radius: 13px; font-size: 14px; }
.result-area { margin-top: 10px; }
.status-line { padding: 10px 12px; border-radius: 16px; font-size: 13px; }
.result-card { margin-top: 10px; padding: 12px; border-radius: 20px; }
.result-header { gap: 8px; margin-bottom: 10px; }
.balance-card, .pay-card, .rule-card { padding: 12px; border-radius: 20px; }
.balance-card strong { margin: 2px 0 4px; font-size: 30px; }
.copy-row { gap: 8px; margin-bottom: 8px; padding: 8px; border-radius: 13px; }
.bottom-tabs { gap: 7px; padding: 7px 10px calc(7px + env(safe-area-inset-bottom)); }
.tab-button { min-height: 56px; border-radius: 16px; }
.tab-icon { width: 26px; height: 26px; border-radius: 9px; font-size: 13px; }
.tab-button strong { font-size: 13px; }
.tab-button em { top: 3px; right: 5px; font-size: 9px; }

@media (max-width: 360px) {
  .app-shell { padding-left: 10px; padding-right: 10px; }
  h1 { font-size: 24px; }
  .install-button { min-height: 36px; padding: 0 11px; }
  input, select { min-height: 40px; }
  textarea { min-height: 68px; height: 68px; }
  .primary-button { min-height: 48px; }
}
