* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; background: #fff; color: #222; }
body.ctps { min-height: 100vh; display: flex; flex-direction: column; }

.topbar { display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; color: #fff; font-weight: 600; font-size: 16px; }
.ctps-topbar { background: #1351b4; }
.topbar-back { cursor: pointer; font-size: 22px; }

.screen { flex: 1; padding: 18px 16px; }

.gov-card { background: #fff; border: 1px solid #e0e0e0; border-radius: 8px;
  padding: 18px; margin-bottom: 14px; }
.gov-card h2 { margin: 0 0 10px; color: #1351b4; font-size: 20px; }
.gov-card p { margin: 0 0 14px; line-height: 1.4; }

.gov-button { display: inline-block; padding: 12px 22px; border-radius: 4px;
  border: 0; background: #1351b4; color: #fff; font-size: 15px; font-weight: 600;
  cursor: pointer; text-decoration: none; }
.gov-button.full { display: block; width: 100%; text-align: center; }
.gov-button.secondary { background: #fff; color: #1351b4; border: 1px solid #1351b4; }

.gov-input { display: block; width: 100%; padding: 12px; font-size: 15px;
  border: 1px solid #ccc; border-radius: 4px; margin-bottom: 14px; }

.gov-alert { background: #fff4e6; color: #b35400; padding: 12px; border-left: 4px solid #f08800;
  border-radius: 4px; margin-bottom: 14px; }

.gov-loader { text-align: center; padding: 40px 0; color: #555; }
.gov-loader .spinner { width: 36px; height: 36px; border: 4px solid #e0e0e0;
  border-top-color: #1351b4; border-radius: 50%; animation: spin 1s linear infinite;
  margin: 0 auto 12px; }
@keyframes spin { to { transform: rotate(360deg); } }
