:root { --bmr-teal:#1b6055; --bmr-teal-light:#eaf7f4; --bmr-border:#dee2e6; }

/* intlTelInput overrides — match our field-ctrl style */
.iti { width: 100%; }
.iti__tel-input {
  width: 100%; border: 1.5px solid #ddd; border-radius: 8px;
  padding: .55rem .9rem .55rem 3.5rem; font-size: .88rem;
  outline: none; transition: border-color .2s; background: #fff;
}
.iti__tel-input:focus { border-color: var(--bmr-teal); box-shadow: 0 0 0 3px rgba(27,96,85,.1); }
.iti__tel-input.error { border-color: #ef4444; }

/* ── Step tabs ── */
.step-tabs { display:flex; gap:0; border-bottom:2px solid var(--bmr-border); margin-bottom:1.5rem; }
.step-tab {
  display:flex; align-items:center; gap:.5rem;
  padding:.65rem 1.25rem; font-size:.83rem; font-weight:600;
  color:#aaa; border-bottom:3px solid transparent; margin-bottom:-2px;
  cursor:default; white-space:nowrap;
}
.step-tab.active { color:var(--bmr-teal); border-bottom-color:var(--bmr-teal); }
.step-tab.done   { color:#10b981; }
.step-tab-num {
  width:24px; height:24px; border-radius:50%;
  background:#e5e7eb; display:flex; align-items:center; justify-content:center;
  font-size:.75rem; font-weight:700; flex-shrink:0;
}
.step-tab.active .step-tab-num { background:var(--bmr-teal); color:#fff; }
.step-tab.done   .step-tab-num { background:#10b981; color:#fff; }

/* ── Form card ── */
.form-card { background:#fff; border-radius:14px; border:1px solid var(--bmr-border); overflow:hidden; }
.form-card-header { padding:1.1rem 1.5rem; border-bottom:1px solid var(--bmr-border); }
.form-card-header h5 { font-size:1rem; font-weight:700; margin:0; }
.form-card-header p  { font-size:.82rem; color:#888; margin:.15rem 0 0; }
.form-card-body { padding:1.5rem; }

/* ── Section label ── */
.section-label {
  font-size:.78rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color:#888; margin:1.5rem 0 .75rem; padding-bottom:.4rem;
  border-bottom:1px solid var(--bmr-border);
}
.section-label:first-child { margin-top:0; }

/* ── Fields ── */
.field-label { font-size:.82rem; font-weight:600; color:#444; margin-bottom:.3rem; display:block; }
.field-label .req { color:#ef4444; }
.field-ctrl {
  width:100%; border:1.5px solid #ddd; border-radius:8px;
  padding:.55rem .9rem; font-size:.88rem; outline:none; transition:border-color .2s; background:#fff;
}
.field-ctrl:focus { border-color:var(--bmr-teal); box-shadow:0 0 0 3px rgba(27,96,85,.1); }
.field-ctrl.error { border-color:#ef4444; }
select.field-ctrl { cursor:pointer; }
textarea.field-ctrl { resize:vertical; min-height:80px; }
.field-group { margin-bottom:1rem; }

/* Eye-toggle input */
.input-eye { position:relative; }
.input-eye .field-ctrl { padding-right:2.5rem; }
.eye-btn {
  position:absolute; right:.6rem; top:50%; transform:translateY(-50%);
  background:none; border:none; cursor:pointer; color:#f59e0b; padding:2px;
}

/* ── Profile picture uploader ── */
.avatar-col {
  display:flex; flex-direction:column; align-items:center; justify-content:flex-start;
  padding-top:.25rem;
}
.avatar-circle {
  position:relative; width:140px; height:140px; border-radius:50%;
  background:#f3f4f6; border:2.5px dashed #d1d5db;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; flex-shrink:0;
}
.avatar-circle img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.avatar-placeholder {
  display:flex; flex-direction:column; align-items:center; gap:.3rem;
  color:#c4c4c4;
}
.avatar-placeholder i { font-size:2.2rem; }
.avatar-edit-btn {
  position:absolute; bottom:6px; right:6px;
  width:30px; height:30px; border-radius:50%;
  background:#fff; border:1.5px solid #e5e7eb;
  box-shadow:0 1px 4px rgba(0,0,0,.12);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:#f59e0b; font-size:.8rem;
  transition:background .15s;
}
.avatar-edit-btn:hover { background:#fffbeb; }
.avatar-hint { font-size:.72rem; color:#aaa; margin-top:.6rem; text-align:center; max-width:130px; line-height:1.4; }

/* ── Membership summary card ── */
.summary-card {
  background:var(--bmr-teal-light); border:1.5px solid #c8e6e0;
  border-radius:10px; padding:1rem 1.25rem; margin-top:1.5rem;
}
.summary-card h6 { font-size:.78rem; font-weight:700; color:#888; text-transform:uppercase; letter-spacing:.05em; margin-bottom:.75rem; }
.summary-row { display:flex; gap:1rem; flex-wrap:wrap; }
.summary-col { flex:1; min-width:140px; background:#fff; border-radius:8px; padding:.75rem 1rem; border:1px solid #c8e6e0; }
.summary-col .label { font-size:.75rem; color:#888; font-weight:600; margin-bottom:.2rem; }
.summary-col .value { font-size:1.05rem; font-weight:800; color:var(--bmr-teal); }
.summary-col .sub   { font-size:.72rem; color:#aaa; margin-top:.2rem; }
.discount-note { font-size:.75rem; color:#059669; margin-top:.5rem; font-weight:600; }

/* ── Payment summary ── */
.pay-summary { border:1.5px solid var(--bmr-border); border-radius:10px; overflow:hidden; }
.pay-summary .row-item { display:flex; justify-content:space-between; padding:.65rem 1rem; font-size:.88rem; border-bottom:1px solid var(--bmr-border); }
.pay-summary .row-item:last-child { border-bottom:none; }
.pay-summary .row-total { font-weight:800; color:var(--bmr-teal); }

/* ── Payment method cards (Step 3) ── */
.method-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:.85rem; }
@media(max-width:576px){ .method-grid { grid-template-columns:1fr; } }
.method-card {
  border:2px solid var(--bmr-border); border-radius:12px;
  padding:1rem .85rem; cursor:pointer; text-align:center;
  transition:border-color .2s, background .2s; position:relative;
}
.method-card:hover  { border-color:#a7d7cf; background:#f9fefe; }
.method-card.active { border-color:var(--bmr-teal); background:var(--bmr-teal-light); }
.method-icon { font-size:1.6rem; margin-bottom:.4rem; }
.method-name { font-size:.86rem; font-weight:700; color:#333; }
.method-desc { font-size:.73rem; color:#888; margin-top:.15rem; }
.method-check {
  position:absolute; top:.4rem; right:.4rem;
  width:17px; height:17px; border-radius:50%;
  background:var(--bmr-teal); color:#fff; font-size:.58rem;
  display:none; align-items:center; justify-content:center;
}
.method-card.active .method-check { display:flex; }

/* ── QR + countdown (reused from payment page) ── */
.qr-wrap {
  text-align:center; padding:1.5rem 1rem;
  background:linear-gradient(135deg,#f0faf8 0%,#e6f4f1 100%);
  border-radius:12px; border:1.5px solid #c8e6e0; margin-top:.75rem;
}
.qr-img { border-radius:10px; border:4px solid #fff; box-shadow:0 4px 18px rgba(27,96,85,.18); margin-bottom:.75rem; }
.countdown-ring {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.3rem .85rem; border-radius:20px;
  background:#fff; box-shadow:0 1px 6px rgba(0,0,0,.08);
  font-size:.86rem; margin-bottom:.65rem;
}
.countdown-ring .dot { width:8px; height:8px; border-radius:50%; background:var(--bmr-teal); }
.countdown-ring .dot.pulse { animation:pulse-dot 1s ease-in-out infinite; }
.countdown-ring .dot.red   { background:#ef4444; animation:none; }
.countdown-ring .time { font-weight:800; font-family:monospace; font-size:.98rem; }
.countdown-ring .time.red  { color:#ef4444; }
@keyframes pulse-dot { 0%,100%{ opacity:1; } 50%{ opacity:.3; } }

/* ── info-box for bank details ── */
.info-box {
  background:#f8f9fa; border:1.5px solid var(--bmr-border);
  border-radius:10px; padding:.85rem 1rem; margin-bottom:.85rem;
}
.info-row { display:flex; justify-content:space-between; padding:.3rem 0; font-size:.86rem; border-bottom:1px solid #eee; }
.info-row:last-child { border-bottom:none; }
.info-label { color:#888; font-weight:600; }
.info-value { font-weight:700; color:#333; }

/* ── Footer actions ── */
.form-footer { padding:1rem 1.5rem; border-top:1px solid var(--bmr-border); display:flex; justify-content:space-between; align-items:center; }

/* ── Success ── */
.success-wrap { text-align:center; padding:3rem 1.5rem; }
.success-icon { font-size:4rem; color:var(--bmr-teal); margin-bottom:1rem; }
.ref-badge { display:inline-block; background:var(--bmr-teal); color:#fff; font-size:.95rem; font-weight:700; border-radius:8px; padding:.45rem 1.4rem; letter-spacing:.06em; margin-top:.5rem; }
