/* PSPF Banking Hall Survey — Frontier Markets Advisory CI */
:root {
  --fma-navy: #252E63;
  --fma-navy-dark: #1a2149;
  --fma-red: #D33826;
  --fma-red-dark: #b12c1d;
  --fma-light: #f4f5f9;
  --fma-ink: #1f2333;
}

* { box-sizing: border-box; }

body {
  background: var(--fma-light);
  color: var(--fma-ink);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  -webkit-text-size-adjust: 100%;
  overscroll-behavior-y: contain; /* no pull-to-refresh wiping an interview */
}

/* touch: kill double-tap zoom delay, give press feedback everywhere */
.btn, .form-check, .form-select, .form-control, button, label { touch-action: manipulation; }
.btn { transition: transform 120ms ease; }
.btn:active { transform: scale(0.97); }
@media (prefers-reduced-motion: reduce) {
  .btn, .q-block .form-check { transition: none; }
  .btn:active { transform: none; }
}

/* ---- Header ---- */
.app-header {
  background: var(--fma-navy);
  color: #fff;
  padding: 0.75rem 1rem;
  position: sticky;
  top: 0;
  z-index: 1030;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.app-header img { height: 34px; width: auto; }
.app-header .title { font-size: 0.95rem; font-weight: 600; line-height: 1.1; }
.app-header .subtitle { font-size: 0.72rem; opacity: 0.75; }

/* connection pill */
.conn-pill {
  font-size: 0.7rem; font-weight: 600; padding: 0.2rem 0.55rem;
  border-radius: 999px; white-space: nowrap;
}
.conn-online  { background: #1f7a44; color: #fff; }
.conn-offline { background: var(--fma-red); color: #fff; }

/* ---- Layout ---- */
.wrap { max-width: 760px; margin: 0 auto; padding: 1rem; }

.card-fma {
  background: #fff; border: 1px solid #e3e5ee; border-radius: 12px;
  padding: 1.25rem; margin-bottom: 1rem; box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}

.section-tag {
  display: inline-block; background: var(--fma-navy); color: #fff;
  font-size: 0.72rem; font-weight: 700; letter-spacing: 0.04em;
  padding: 0.25rem 0.6rem; border-radius: 6px; margin-bottom: 0.75rem;
}
.q-label { font-weight: 600; margin-bottom: 0.4rem; display: block; }
.q-block { margin-bottom: 1.35rem; }
.q-help  { font-size: 0.875rem; color: #5a6070; margin-bottom: 0.5rem; }

/* Full-row 48px tappable option rows (all radio/checkbox groups) */
.q-block .form-check {
  position: relative; display: flex; align-items: center;
  min-height: 48px; margin: 0 0 8px;
  padding: 0.55rem 0.75rem 0.55rem 2.75rem;
  border: 1px solid #e3e5ee; border-radius: 8px; background: #fff;
  transition: background-color 120ms ease, border-color 120ms ease;
}
.q-block .form-check-input {
  position: absolute; left: 0.75rem; top: 50%; transform: translateY(-50%);
  width: 1.35rem; height: 1.35rem; margin: 0;
}
.q-block .form-check-label { display: block; width: 100%; font-size: 1rem; }
.q-block .form-check-label::after { content: ""; position: absolute; inset: 0; }
.q-block .form-check:has(.form-check-input:checked) {
  border-color: var(--fma-navy); background: rgba(37,46,99,0.07);
}
.q-block .form-check:has(.form-check-input:checked) .form-check-label {
  color: var(--fma-navy); font-weight: 600;
}
.q-block .form-check:active { background: #e9ebf4; }

/* brand buttons */
.btn-fma {
  background: var(--fma-red); border-color: var(--fma-red); color: #fff; font-weight: 600;
}
.btn-fma:hover, .btn-fma:focus { background: var(--fma-red-dark); border-color: var(--fma-red-dark); color: #fff; }
.btn-fma:disabled { background: #c9ccd8; border-color: #c9ccd8; }
.btn-navy { background: var(--fma-navy); border-color: var(--fma-navy); color: #fff; font-weight: 600; }
.btn-navy:hover, .btn-navy:focus { background: var(--fma-navy-dark); border-color: var(--fma-navy-dark); color: #fff; }

.form-check-input:checked { background-color: var(--fma-navy); border-color: var(--fma-navy); }
.form-select { font-size: 1rem; min-height: 48px; }
.form-select:focus, .form-control:focus {
  border-color: var(--fma-navy); box-shadow: 0 0 0 0.2rem rgba(37,46,99,0.15);
}
.form-control { min-height: 48px; font-size: 1rem; }

/* disclaimer banner */
.disclaimer {
  background: #fff6e5; border: 1px solid #ffd98a; border-radius: 10px;
  padding: 0.75rem 0.9rem; font-size: 0.875rem; margin-bottom: 1rem;
}
.disclaimer strong { color: var(--fma-red-dark); }

/* single-tap pill rows (B3 ranks, B8 scale, province quick-pick) */
.chip-block { padding: 0.5rem 0; border-bottom: 1px solid #eef0f5; }
.chip-block:last-child { border-bottom: 0; }
.chip-label { font-size: 1rem; font-weight: 600; margin-bottom: 0.25rem; }
.chip-group { display: flex; flex-wrap: wrap; gap: 8px; }
.chip-group .btn {
  min-width: 48px; min-height: 44px; font-size: 1rem; padding: 0.4rem 0.6rem;
  border-color: #c9ccd8; color: var(--fma-ink);
  display: flex; align-items: center; justify-content: center;
}
.chip-group .btn-check:checked + .btn {
  background: var(--fma-navy); border-color: var(--fma-navy); color: #fff;
}
.province-pill.active { background: var(--fma-navy); border-color: var(--fma-navy); color: #fff; }

/* B6 Yes/No grid */
.grid-row {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.55rem 0; border-bottom: 1px solid #eef0f5;
}
.grid-row:last-child { border-bottom: 0; }
.grid-row .grid-label { flex: 1 1 auto; font-size: 1rem; }
.grid-row .grid-control { flex: 0 0 auto; }
.yn-group .btn-check + .btn {
  min-width: 76px; min-height: 48px; font-size: 1rem;
  display: flex; align-items: center; justify-content: center;
}

/* sticky answered-count bar */
#progressBar {
  position: sticky; bottom: 0; z-index: 1020;
  background: var(--fma-navy); color: #fff;
  padding: 0.6rem 1rem; border-radius: 8px 8px 0 0;
  font-size: 1rem; text-align: center; min-height: 44px;
  cursor: pointer; margin-bottom: 0.5rem;
}
#progressBar.complete { background: #1f7a44; }
.q-flash { outline: 2px solid var(--fma-navy); outline-offset: 2px; border-radius: 8px; }

/* cancel: deliberately separated from Submit */
#cancelBtn { margin-top: 1rem; min-height: 44px; }

/* status screens */
.screen { display: none; }
.screen.active { display: block; }

.result-ok { text-align: center; padding: 2rem 1rem; }
.result-ok .tick {
  width: 72px; height: 72px; border-radius: 50%; background: #1f7a44; color: #fff;
  font-size: 2.4rem; line-height: 72px; margin: 0 auto 1rem;
}
.result-ok .record-no { font-size: 2rem; font-weight: 800; color: var(--fma-navy); }
.result-err {
  background: #fdecea; border: 1px solid #f5b5ad; color: var(--fma-red-dark);
  border-radius: 10px; padding: 0.9rem; margin-top: 1rem; font-weight: 600;
}

.req { color: var(--fma-red); }
.small-muted { font-size: 0.85rem; color: #5d6373; }

footer.app-foot { text-align: center; padding: 1.5rem 1rem 2.5rem; font-size: 0.8rem; color: #6b7080; }
