/* ============================================================
   Skydrel House Rent Manager — Frontend CSS v1.4
   Spacious, clean, beautiful animations
   ============================================================ */

:root {
  --bhr-primary:       #1e3a5f;
  --bhr-primary-hover: #162d4a;
  --bhr-primary-light: #f0f6ff;
  --bhr-primary-mid:   #c0d4ee;
  --bhr-accent:        #2563eb;
  --bhr-success:       #15803d;
  --bhr-success-light: #f0fdf4;
  --bhr-danger:        #b91c1c;
  --bhr-danger-light:  #fef2f2;
  --bhr-warning:       #b45309;
  --bhr-warning-light: #fffbeb;
  --bhr-text:          #1a202c;
  --bhr-text-muted:    #64748b;
  --bhr-text-light:    #94a3b8;
  --bhr-border:        #e2e8f0;
  --bhr-bg:            #f4f7fb;
  --bhr-card:          #ffffff;
  --bhr-radius:        10px;
  --bhr-radius-sm:     6px;
  --bhr-shadow:        0 1px 3px rgba(0,0,0,.05), 0 4px 16px rgba(0,0,0,.06);
  --bhr-shadow-md:     0 4px 20px rgba(0,0,0,.09);
  --bhr-sidebar-w:     250px;
  --bhr-ease:          cubic-bezier(.4,0,.2,1);
}

/* ── Base reset ────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
.bhr-wrap {
  font-family:'Segoe UI',system-ui,Arial,sans-serif;
  color:var(--bhr-text); line-height:1.7; font-size:14px;
  background:var(--bhr-bg);
}

/* ── Navigation Progress Bar ───────────────────── */
#bhr-progress-bar {
  position:fixed; top:0; left:0; width:0; height:3px;
  background:linear-gradient(90deg,var(--bhr-accent),#60a5fa);
  z-index:999999; transition:width .3s var(--bhr-ease);
  border-radius:0 2px 2px 0;
  box-shadow:0 0 8px rgba(37,99,235,.5);
}

/* ── Registration container ────────────────────── */
.bhr-container {
  max-width:820px; margin:40px auto 60px;
  background:var(--bhr-card); border-radius:var(--bhr-radius);
  box-shadow:var(--bhr-shadow-md); padding:48px 52px;
  border:1px solid var(--bhr-border);
  animation:bhrSlideUp .35s var(--bhr-ease);
}
@media(max-width:640px){ .bhr-container{ padding:28px 20px; margin:20px 16px; } }

@keyframes bhrSlideUp{
  from{ opacity:0; transform:translateY(18px); }
  to  { opacity:1; transform:none; }
}
@keyframes bhrFadeIn{
  from{ opacity:0; } to{ opacity:1; }
}
@keyframes bhrPop{
  0%  { transform:scale(.96); opacity:0; }
  60% { transform:scale(1.01); }
  100%{ transform:scale(1);  opacity:1; }
}

/* ── Page header ───────────────────────────────── */
.bhr-header {
  text-align:center; margin-bottom:40px;
  padding-bottom:28px; border-bottom:1px solid var(--bhr-border);
}
.bhr-header h1 { font-size:26px; font-weight:700; color:var(--bhr-primary); margin-bottom:8px; }
.bhr-header p  { color:var(--bhr-text-muted); font-size:15px; }

/* ── Step nav ──────────────────────────────────── */
.bhr-steps-nav {
  display: flex;
  align-items: stretch;
  justify-content: center;
  gap: 0;
  margin-bottom: 36px;
  flex-wrap: wrap;
}
.bhr-step-pill {
  display: flex; align-items: center; gap: 7px;
  padding: 10px 16px; font-size: 13px; font-weight: 600;
  white-space: nowrap; color: var(--bhr-text-muted);
  background: #f1f5f9; border: 1px solid var(--bhr-border);
  transition: all .2s var(--bhr-ease); cursor: default;
}
.bhr-step-pill:first-child { border-radius: var(--bhr-radius-sm) 0 0 var(--bhr-radius-sm); }
.bhr-step-pill:last-child  { border-radius: 0 var(--bhr-radius-sm) var(--bhr-radius-sm) 0; }
.bhr-step-pill.active    { background: var(--bhr-primary); color: #fff; border-color: var(--bhr-primary); }
.bhr-step-pill.completed { background: var(--bhr-success); color: #fff; border-color: var(--bhr-success); }
.bhr-step-num {
  width: 22px; height: 22px; border-radius: 50%; font-size: 11px; font-weight: 800;
  background: rgba(255,255,255,.25); display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
@media (max-width: 540px) {
  .bhr-steps-nav { justify-content: flex-start; overflow-x: auto; flex-wrap: nowrap; padding-bottom: 4px; }
  .bhr-step-pill { padding: 8px 12px; font-size: 12px; }
  .bhr-step-lbl  { display: inline; }
}
.bhr-step-connector { display: none; }

/* ── Step content ──────────────────────────────── */
.bhr-step { display:none; }
.bhr-step.active { display:block; animation:bhrSlideUp .25s var(--bhr-ease); }
.bhr-step-title {
  font-size:18px; font-weight:700; margin:0 0 24px;
  padding-bottom:14px; border-bottom:2px solid var(--bhr-border); color:var(--bhr-primary);
}
.bhr-section-subtitle {
  font-size:11px; font-weight:700; margin:28px 0 14px;
  color:var(--bhr-text-light); text-transform:uppercase; letter-spacing:.8px;
}

/* ── Grid ──────────────────────────────────────── */
.bhr-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.bhr-grid-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:18px; }
.bhr-full   { grid-column:1/-1; }
@media(max-width:600px){ .bhr-grid-2,.bhr-grid-3{ grid-template-columns:1fr; } }

/* ── Form fields ───────────────────────────────── */
.bhr-field { display:flex; flex-direction:column; gap:6px; }
.bhr-field label { font-size:13px; font-weight:600; color:var(--bhr-text); }
.bhr-req { color:var(--bhr-danger); }

.bhr-field input,
.bhr-field select,
.bhr-field textarea {
  padding:10px 14px; border:1.5px solid var(--bhr-border);
  border-radius:var(--bhr-radius-sm); font-size:14px;
  background:#fff; color:var(--bhr-text); width:100%;
  font-family:inherit; transition:border-color .15s, box-shadow .15s;
  appearance:auto;
}
.bhr-field input:focus,
.bhr-field select:focus,
.bhr-field textarea:focus {
  outline:none; border-color:var(--bhr-accent);
  box-shadow:0 0 0 3px rgba(37,99,235,.10);
}
.bhr-field-error { border-color:var(--bhr-danger)!important; box-shadow:0 0 0 3px rgba(185,28,28,.1)!important; }
.bhr-readonly { background:#f8fafc!important; color:var(--bhr-text-muted); cursor:not-allowed; }
.bhr-hint { font-size:12px; color:var(--bhr-text-muted); }
.bhr-hint-link { font-size:12px; }
.bhr-hint-link a { color:var(--bhr-accent); }

/* Match indicator */
.bhr-match-indicator { font-size:12px; font-weight:600; padding:4px 10px; border-radius:4px; margin-top:4px; display:none; }
.bhr-match-ok   { display:block; background:#f0fdf4; color:var(--bhr-success); }
.bhr-match-fail { display:block; background:var(--bhr-danger-light); color:var(--bhr-danger); }

/* ── File zones ────────────────────────────────── */
.bhr-file-zone {
  position:relative; border:1.5px dashed var(--bhr-border);
  border-radius:var(--bhr-radius-sm); padding:16px; text-align:center;
  cursor:pointer; background:#fafbfc;
  transition:border-color .15s, background .15s;
}
.bhr-file-zone:hover,.bhr-file-zone.dragover { border-color:var(--bhr-accent); background:var(--bhr-primary-light); }
.bhr-file-zone input[type=file] { position:absolute; inset:0; opacity:0; cursor:pointer; width:100%; height:100%; }
.bhr-file-hint  { font-size:13px; color:var(--bhr-text-muted); display:block; }
.bhr-file-name  { font-size:12px; font-weight:600; color:var(--bhr-success); margin-top:6px; word-break:break-all; }

/* ── Buttons ───────────────────────────────────── */
.bhr-btn {
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  padding:10px 22px; border-radius:var(--bhr-radius-sm); font-size:14px;
  font-weight:600; cursor:pointer; border:1.5px solid transparent;
  transition:all .15s var(--bhr-ease); text-decoration:none;
  white-space:nowrap; font-family:inherit;
}
.bhr-btn-primary { background:var(--bhr-primary); color:#fff; border-color:var(--bhr-primary); }
.bhr-btn-primary:hover { background:var(--bhr-primary-hover); transform:translateY(-1px); box-shadow:0 4px 12px rgba(30,58,95,.3); }
.bhr-btn-ghost  { background:#fff; color:var(--bhr-text); border-color:var(--bhr-border); }
.bhr-btn-ghost:hover { background:var(--bhr-bg); }
.bhr-btn-success{ background:var(--bhr-success); color:#fff; border-color:var(--bhr-success); }
.bhr-btn-success:hover{ background:#166534; }
.bhr-btn-danger { background:var(--bhr-danger); color:#fff; border-color:var(--bhr-danger); }
.bhr-btn-danger:hover{ background:#991b1b; }
.bhr-btn-block  { width:100%; }
.bhr-btn-sm     { padding:6px 14px; font-size:12px; }
.bhr-btn:disabled { opacity:.5; cursor:not-allowed; transform:none!important; box-shadow:none!important; }
.bhr-btn:active { transform:translateY(0)!important; }

.bhr-actions {
  display:flex; gap:12px; justify-content:flex-end;
  margin-top:32px; padding-top:22px; border-top:1px solid var(--bhr-border);
}

/* ── Alerts ────────────────────────────────────── */
.bhr-alert {
  padding:14px 18px; border-radius:var(--bhr-radius-sm);
  margin-bottom:20px; font-size:14px; border:1px solid;
  animation:bhrFadeIn .2s ease;
}
.bhr-alert-warning { background:var(--bhr-warning-light); border-color:#fcd34d; color:#78350f; }
.bhr-alert-danger  { background:var(--bhr-danger-light);  border-color:#fca5a5; color:#7f1d1d; }
.bhr-alert-success { background:var(--bhr-success-light); border-color:#86efac; color:#14532d; }
.bhr-info-box {
  background:var(--bhr-primary-light); border:1px solid var(--bhr-primary-mid);
  border-left:3px solid var(--bhr-primary);
  border-radius:var(--bhr-radius-sm); padding:14px 18px; font-size:13px; margin:16px 0;
}
.bhr-warning-box {
  background:var(--bhr-warning-light); border:1px solid #fcd34d;
  border-left:3px solid var(--bhr-warning);
  border-radius:var(--bhr-radius-sm); padding:14px 18px; font-size:13px; margin:16px 0;
}
.bhr-paid-banner {
  background:var(--bhr-success-light); border:1px solid #86efac;
  border-left:3px solid var(--bhr-success);
  border-radius:var(--bhr-radius-sm); padding:14px 18px;
  font-size:14px; font-weight:600; color:#14532d;
  display:flex; align-items:center; gap:10px; margin-bottom:24px;
}

/* ── Floor builder ─────────────────────────────── */
.bhr-floor-block {
  border:1px solid var(--bhr-border); border-radius:var(--bhr-radius-sm);
  margin-bottom:18px; overflow:hidden;
  transition:box-shadow .15s;
}
.bhr-floor-block:hover{ box-shadow:var(--bhr-shadow); }
.bhr-floor-header {
  background:#f5f8fc; padding:12px 18px; font-weight:700; font-size:14px;
  color:var(--bhr-primary); display:flex; align-items:center; justify-content:space-between;
  border-bottom:1px solid var(--bhr-border);
}
.bhr-floor-body { padding:18px; }
.bhr-compartment-block {
  background:#fafbfc; border:1px solid var(--bhr-border);
  border-radius:var(--bhr-radius-sm); padding:16px; margin-bottom:14px;
}
.bhr-comp-header { font-weight:700; font-size:13px; margin-bottom:12px; color:var(--bhr-primary); }
.bhr-comp-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:12px; }

/* ── Compartment row (clean, not congested) ──── */
.bhr-compartments-list { padding:14px 18px; }
.bhr-compartment-row {
  display:grid;
  grid-template-columns: 1fr 1fr 1.4fr auto;
  gap:10px; align-items:center;
  padding:10px; margin-bottom:8px;
  background:#fafbfc; border:1px solid var(--bhr-border);
  border-radius:6px;
}
.bhr-compartment-row input {
  padding:9px 12px; border:1px solid var(--bhr-border);
  border-radius:6px; font-size:14px; font-family:inherit;
  background:#fff;
}
.bhr-compartment-row input:focus {
  outline:none; border-color:var(--bhr-accent);
  box-shadow:0 0 0 3px rgba(37,99,235,.1);
}
@media (max-width:540px) {
  .bhr-compartment-row { grid-template-columns: 1fr 1fr; }
  .bhr-compartment-row .bhr-remove-comp-btn { grid-column: 2; justify-self:end; }
}
.bhr-floor-header {
  flex-wrap:wrap; gap:8px;
}

/* ── Plans ─────────────────────────────────────── */
.bhr-plan-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:14px; margin-bottom:24px; }
.bhr-plan-card { cursor:pointer; }
.bhr-plan-card input[type=radio]{ position:absolute; opacity:0; pointer-events:none; }
.bhr-plan-inner {
  border:1.5px solid var(--bhr-border); border-radius:var(--bhr-radius);
  padding:20px 14px; text-align:center;
  transition:all .2s var(--bhr-ease); position:relative; background:#fff;
}
.bhr-plan-card:hover .bhr-plan-inner { border-color:var(--bhr-primary); transform:translateY(-2px); box-shadow:var(--bhr-shadow); }
.bhr-plan-card input:checked + .bhr-plan-inner {
  border-color:var(--bhr-primary); background:var(--bhr-primary-light);
  box-shadow:0 0 0 3px var(--bhr-primary-mid); transform:translateY(-2px);
}
.bhr-plan-duration{ font-weight:600; font-size:13px; margin-bottom:8px; color:var(--bhr-text-muted); }
.bhr-plan-price  { font-size:20px; font-weight:700; color:var(--bhr-primary); }
.bhr-plan-badge  {
  position:absolute; top:-10px; left:50%; transform:translateX(-50%);
  background:var(--bhr-success); color:#fff; font-size:10px; font-weight:700;
  padding:2px 10px; border-radius:999px;
}

/* ── Payment info ──────────────────────────────── */
.bhr-payment-box {
  background:#fafbfc; border:1px solid var(--bhr-border);
  border-radius:var(--bhr-radius-sm); padding:20px; margin:20px 0; max-width:480px;
}
.bhr-payment-box h4 { margin:0 0 14px; font-size:14px; font-weight:700; color:var(--bhr-primary); }
.bhr-payment-details { display:grid; gap:0; }
.bhr-payment-row {
  display:flex; justify-content:space-between; align-items:center;
  font-size:13px; padding:8px 0; border-bottom:1px solid var(--bhr-border);
}
.bhr-payment-row:last-child{ border-bottom:none; }
.bhr-payment-row span{ color:var(--bhr-text-muted); }
.bhr-payment-qr{ margin-top:16px; text-align:center; }
.bhr-payment-qr img{ max-width:150px; border-radius:6px; border:1px solid var(--bhr-border); }

/* ── Info table (payment method display) ───────── */
.bhr-info-table { display:grid; gap:0; margin:12px 0; border:1px solid var(--bhr-border); border-radius:var(--bhr-radius-sm); overflow:hidden; }
.bhr-info-row { display:flex; justify-content:space-between; padding:9px 14px; font-size:13px; border-bottom:1px solid var(--bhr-border); }
.bhr-info-row:last-child{ border-bottom:none; }
.bhr-info-row span{ color:var(--bhr-text-muted); }
.bhr-info-row code { font-family:monospace; font-size:12px; background:#f1f5f9; padding:2px 6px; border-radius:3px; word-break:break-all; }

/* ── Pay tabs ──────────────────────────────────── */
.bhr-pay-tabs { display:flex; gap:0; margin-bottom:20px; border:1px solid var(--bhr-border); border-radius:var(--bhr-radius-sm); overflow:hidden; }
.bhr-pay-tab {
  flex:1; padding:10px 14px; font-size:13px; font-weight:600; cursor:pointer;
  background:#f5f7fa; border:none; border-right:1px solid var(--bhr-border);
  color:var(--bhr-text-muted); transition:all .15s; font-family:inherit;
}
.bhr-pay-tab:last-child{ border-right:none; }
.bhr-pay-tab:hover{ background:#eef2f7; color:var(--bhr-primary); }
.bhr-pay-tab-active{ background:#fff; color:var(--bhr-primary); font-weight:700; border-bottom:2px solid var(--bhr-primary)!important; }
.bhr-pay-panel { animation:bhrFadeIn .2s ease; }
.bhr-pay-desc { font-size:13px; color:var(--bhr-text-muted); margin-bottom:14px; }
.bhr-pay-not-configured { color:var(--bhr-warning); font-style:italic; }
.bhr-pay-qr { text-align:center; margin:12px 0; }
.bhr-pay-qr img { max-width:140px; border-radius:6px; border:1px solid var(--bhr-border); }
.bhr-pay-qr p { font-size:12px; color:var(--bhr-text-muted); margin-top:6px; }

/* ── Gateway cards ─────────────────────────────── */
.bhr-gw-card {
  border:1.5px solid var(--bhr-border); border-radius:var(--bhr-radius);
  padding:18px 20px; transition:border-color .15s, box-shadow .15s;
}
.bhr-gw-active { border-color:var(--bhr-primary-mid); background:var(--bhr-primary-light); }
.bhr-gw-header { display:flex; align-items:center; gap:10px; }

/* ── Documentation ─────────────────────────────── */
.bhr-doc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.bhr-doc-card{
  border:1.5px dashed var(--bhr-border); border-radius:var(--bhr-radius-sm);
  padding:20px 14px; text-align:center; display:flex; flex-direction:column; align-items:center;
  transition:border-color .15s;
}
.bhr-doc-card:hover{ border-color:var(--bhr-primary); }
.bhr-doc-icon{ font-size:24px; margin-bottom:10px; }
.bhr-doc-card label{ font-size:13px; font-weight:600; display:block; margin-bottom:10px; }
.bhr-doc-card .bhr-file-zone{ width:100%; }
@media(max-width:600px){ .bhr-doc-grid{ grid-template-columns:1fr; } }

/* ── Consent ───────────────────────────────────── */
.bhr-consent-box{ margin:20px 0; padding:14px 16px; background:var(--bhr-primary-light); border-radius:var(--bhr-radius-sm); border:1px solid var(--bhr-primary-mid); }
.bhr-consent-label{ display:flex; align-items:center; gap:10px; font-size:14px; cursor:pointer; }
.bhr-consent-label a{ color:var(--bhr-accent); }

/* ── Login page ────────────────────────────────── */
.bhr-login-wrap {
  display:flex; align-items:center; justify-content:center;
  min-height:90vh; padding:24px 16px; background:var(--bhr-bg);
}
.bhr-login-card {
  background:#fff; border-radius:var(--bhr-radius); border:1px solid var(--bhr-border);
  box-shadow:var(--bhr-shadow-md); padding:44px 40px; width:100%; max-width:460px;
  animation:bhrPop .3s var(--bhr-ease);
}
.bhr-login-header { text-align:center; margin-bottom:32px; }
.bhr-login-header h1 { font-size:24px; font-weight:700; color:var(--bhr-primary); margin-bottom:6px; }
.bhr-login-header p  { color:var(--bhr-text-muted); font-size:14px; }
.bhr-login-foot { text-align:center; font-size:13px; color:var(--bhr-text-muted); margin-top:22px; }
.bhr-login-foot a{ color:var(--bhr-accent); font-weight:600; }

.bhr-pin-wrap{ position:relative; display:flex; }
.bhr-pin-wrap input{ flex:1; border-radius:var(--bhr-radius-sm) 0 0 var(--bhr-radius-sm)!important; }
.bhr-toggle-pin {
  padding:0 14px; background:#f5f7fa; border:1.5px solid var(--bhr-border);
  border-left:none; border-radius:0 var(--bhr-radius-sm) var(--bhr-radius-sm) 0;
  cursor:pointer; font-size:15px; color:var(--bhr-text-muted);
  transition:background .12s;
}
.bhr-toggle-pin:hover{ background:var(--bhr-bg); }

/* ── Dashboard layout ──────────────────────────── */
/* ============================================================
   Dashboard layout — fast, responsive, mobile-friendly
   Designed to NOT interfere with WordPress theme header/footer
   ============================================================ */
.bhr-owner-dashboard,.bhr-tenant-dashboard{
  background:var(--bhr-bg);
  position:relative;
  /* Reset any inherited theme margins */
  margin:0;
  /* Push content slightly down to avoid theme header collisions */
  padding-top:0;
}
.bhr-dashboard-layout{
  display:flex;
  align-items:stretch;
  /* No min-height — layout sizes to content, so footer renders directly below */
}

.bhr-sidebar {
  width:var(--bhr-sidebar-w); background:#fff;
  border-right:1px solid var(--bhr-border); flex-shrink:0;
  display:flex; flex-direction:column;
}
.bhr-sidebar-profile {
  padding:28px 20px 22px; border-bottom:1px solid var(--bhr-border); text-align:center;
}
.bhr-profile-img {
  width:64px; height:64px; border-radius:50%; object-fit:cover;
  margin:0 auto 12px; display:block; border:2px solid var(--bhr-border);
}
.bhr-profile-avatar {
  width:64px; height:64px; border-radius:50%; background:var(--bhr-primary-light);
  font-size:24px; display:flex; align-items:center; justify-content:center;
  margin:0 auto 12px; color:var(--bhr-primary);
}
.bhr-profile-name { font-weight:700; font-size:14px; margin-bottom:3px; }
.bhr-profile-id   { font-size:11px; color:var(--bhr-text-muted); font-family:monospace; margin-bottom:6px; }

.bhr-nav { padding:12px 0 24px; flex:1; }
.bhr-nav-item {
  display:flex; align-items:center; padding:11px 20px;
  text-decoration:none; color:var(--bhr-text); font-size:13px; font-weight:500;
  border-left:3px solid transparent;
  transition:background .1s, color .1s, border-color .1s;
  cursor:pointer; user-select:none;
}
.bhr-nav-item:hover { background:var(--bhr-bg); color:var(--bhr-primary); }
.bhr-nav-item.active {
  background:var(--bhr-primary-light); color:var(--bhr-primary);
  border-left-color:var(--bhr-primary); font-weight:700;
}
.bhr-badge{
  background:var(--bhr-danger); color:#fff; border-radius:999px;
  font-size:10px; padding:1px 6px; margin-left:auto; font-weight:700;
}
.bhr-live-dot{
  display:inline-block; width:7px; height:7px; border-radius:50%;
  background:var(--bhr-success); margin-left:4px; vertical-align:middle;
  animation:bhrPulse 2s ease infinite;
}
@keyframes bhrPulse{ 0%,100%{ opacity:1; } 50%{ opacity:.4; } }

.bhr-main { flex:1; padding:28px 32px 40px; background:var(--bhr-bg); min-width:0; }

/* ── Section visibility — no animations for speed ── */
.bhr-section { display:none; }
.bhr-section.active { display:block; }
.bhr-section h2{
  font-size:19px; font-weight:700; margin:0 0 24px;
  color:var(--bhr-primary); padding-bottom:12px;
  border-bottom:1px solid var(--bhr-border);
}

/* ── Mobile menu button (hidden on desktop) ── */
.bhr-mobile-menu-btn {
  display:none;
  position:fixed; top:14px; left:14px;
  z-index:1001; background:var(--bhr-primary); color:#fff;
  width:42px; height:42px; border-radius:8px; border:none;
  font-size:20px; cursor:pointer;
  box-shadow:0 2px 8px rgba(0,0,0,.2);
  align-items:center; justify-content:center;
}
.bhr-mobile-menu-btn:hover { background:var(--bhr-accent); }
.bhr-mobile-overlay {
  display:none;
  position:fixed; inset:0; background:rgba(0,0,0,.4);
  z-index:999;
}

/* ── Mobile responsive ── */
@media (max-width:900px){
  .bhr-mobile-menu-btn { display:flex; }
  .bhr-main { padding:70px 16px 24px; }
  .bhr-sidebar {
    position:fixed; top:0; left:-100%;
    width:280px; max-width:85vw; height:100vh; z-index:1000;
    transition:left .25s ease;
    box-shadow:2px 0 16px rgba(0,0,0,.15);
    overflow-y:auto;
  }
  body.bhr-mobile-menu-open .bhr-sidebar { left:0; }
  body.bhr-mobile-menu-open .bhr-mobile-overlay { display:block; }
  .bhr-dashboard-layout { display:block; }
}

@media (max-width:540px){
  .bhr-main { padding:64px 12px 20px; }
  .bhr-section h2 { font-size:17px; }
}

/* ── Stats ─────────────────────────────────────── */
.bhr-stats-grid{
  display:grid; grid-template-columns:repeat(auto-fill,minmax(170px,1fr));
  gap:16px; margin-bottom:28px;
}
.bhr-stat-card{
  background:#fff; border-radius:var(--bhr-radius); padding:24px 20px;
  text-align:center; box-shadow:var(--bhr-shadow); border:1px solid var(--bhr-border);
  transition:transform .2s var(--bhr-ease), box-shadow .2s;
}
.bhr-stat-card:hover{ transform:translateY(-3px); box-shadow:var(--bhr-shadow-md); }
.bhr-stat-value { font-size:24px; font-weight:700; color:var(--bhr-primary); margin-bottom:4px; }
.bhr-stat-label { font-size:11px; color:var(--bhr-text-muted); font-weight:600; text-transform:uppercase; letter-spacing:.6px; }

/* ── Cards ─────────────────────────────────────── */
.bhr-card {
  background:#fff; border-radius:var(--bhr-radius); padding:24px;
  box-shadow:var(--bhr-shadow); border:1px solid var(--bhr-border); margin-bottom:18px;
}
.bhr-card h3{ margin:0 0 18px; font-size:15px; font-weight:700; color:var(--bhr-text); }

/* ── Tables ────────────────────────────────────── */
.bhr-table-wrap{ overflow-x:auto; border-radius:var(--bhr-radius); border:1px solid var(--bhr-border); }
.bhr-table{
  width:100%; border-collapse:collapse; background:#fff; font-size:13px;
}
.bhr-table th{
  background:#f5f8fc; color:var(--bhr-primary); font-weight:700;
  padding:12px 16px; text-align:left; font-size:11px;
  text-transform:uppercase; letter-spacing:.5px; border-bottom:1px solid var(--bhr-border);
}
.bhr-table td{
  padding:12px 16px; border-bottom:1px solid #f0f4f8; vertical-align:middle;
}
.bhr-table tr:last-child td{ border-bottom:none; }
.bhr-table tr:hover td { background:#fafcff; transition:background .1s; }

/* ── Status badges ─────────────────────────────── */
.bhr-status{
  display:inline-block; padding:3px 10px; border-radius:4px;
  font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.4px;
}
.bhr-status-pending         { background:#fef3c7; color:#92400e; }
.bhr-status-verified        { background:#dcfce7; color:#14532d; }
.bhr-status-rejected        { background:#fee2e2; color:#7f1d1d; }
.bhr-status-paid            { background:#dcfce7; color:#14532d; }
.bhr-status-unpaid          { background:#fee2e2; color:#7f1d1d; }
.bhr-status-pending_renewal { background:#e0e7ff; color:#3730a3; }
.bhr-penalty { color:var(--bhr-danger); font-weight:700; }

/* ── Building summary ──────────────────────────── */
.bhr-building-summary{
  background:#fff; border:1px solid var(--bhr-border); border-radius:var(--bhr-radius);
  padding:18px 22px; margin-bottom:14px;
}
.bhr-building-header{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:8px; }
.bhr-building-header h3{ margin:0; font-size:15px; font-weight:700; }
.bhr-tag{
  background:var(--bhr-primary-light); color:var(--bhr-primary);
  border-radius:4px; font-size:11px; font-weight:700; padding:2px 8px;
  border:1px solid var(--bhr-primary-mid);
}
.bhr-tag-pending{ background:#fef3c7; color:#92400e; border-color:#fcd34d; }
.bhr-building-stats{ display:flex; flex-wrap:wrap; gap:14px; font-size:12px; color:var(--bhr-text-muted); }

/* ── Manage Rent ───────────────────────────────── */
.bhr-rent-all-bar{
  background:#fff; border:1px solid var(--bhr-border); border-radius:var(--bhr-radius-sm);
  padding:16px 20px; margin-bottom:20px;
  display:flex; align-items:center; gap:12px; flex-wrap:wrap;
}
.bhr-rent-all-bar label{ font-weight:600; font-size:13px; white-space:nowrap; }
.bhr-rent-all-bar select{ padding:8px 12px; border:1px solid var(--bhr-border); border-radius:var(--bhr-radius-sm); font-size:13px; }
.bhr-rent-all-bar input[type=number]{ width:130px; padding:8px 12px; border:1px solid var(--bhr-border); border-radius:var(--bhr-radius-sm); font-size:13px; }
.bhr-rent-input{ width:115px; padding:7px 10px; border:1px solid var(--bhr-border); border-radius:4px; font-size:13px; }

/* ── Verify tenant ─────────────────────────────── */
.bhr-tenant-verify-card{
  background:#fff; border:1px solid var(--bhr-border); border-radius:var(--bhr-radius);
  padding:22px; margin-bottom:16px; box-shadow:var(--bhr-shadow);
}
.bhr-verify-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:12px; margin:16px 0; }
.bhr-verify-grid>div{ display:flex; flex-direction:column; gap:3px; }
.bhr-verify-grid label{ font-size:11px; color:var(--bhr-text-muted); font-weight:700; text-transform:uppercase; }
.bhr-verify-grid span{ font-size:13px; font-weight:600; }
.bhr-verify-actions{ display:flex; gap:10px; flex-wrap:wrap; }

/* ── Chat ──────────────────────────────────────── */
.bhr-chat-layout{
  background:#fff; border:1px solid var(--bhr-border); border-radius:var(--bhr-radius);
  overflow:hidden; display:flex; flex-direction:column; height:520px;
}
.bhr-chat-messages{
  flex:1; overflow-y:auto; padding:18px; display:flex;
  flex-direction:column; gap:12px; background:#f8fafc; scroll-behavior:smooth;
}
.bhr-chat-form{ border-top:1px solid var(--bhr-border); padding:14px 18px; background:#fff; }
.bhr-chat-recipient{ margin-bottom:10px; display:flex; align-items:center; gap:10px; font-size:13px; }
.bhr-chat-recipient select{ flex:1; padding:7px 10px; border:1px solid var(--bhr-border); border-radius:var(--bhr-radius-sm); font-size:13px; }
.bhr-chat-form textarea{
  width:100%; border:1px solid var(--bhr-border); border-radius:var(--bhr-radius-sm);
  padding:10px 14px; font-size:13px; resize:vertical; font-family:inherit;
  transition:border-color .12s;
}
.bhr-chat-form textarea:focus{ outline:none; border-color:var(--bhr-accent); }
.bhr-chat-media-row{ display:flex; align-items:center; gap:10px; margin-top:10px; }
.bhr-chat-media-btn{ padding:7px 14px; border:1px solid var(--bhr-border); border-radius:var(--bhr-radius-sm); font-size:13px; cursor:pointer; background:var(--bhr-bg); font-weight:500; }

.bhr-msg-bubble{
  max-width:72%; padding:10px 15px; border-radius:14px;
  font-size:13px; line-height:1.5; animation:bhrFadeIn .18s ease;
}
.bhr-msg-owner{ background:var(--bhr-primary); color:#fff; align-self:flex-end; border-bottom-right-radius:4px; }
.bhr-msg-tenant{ background:#fff; border:1px solid var(--bhr-border); align-self:flex-start; border-bottom-left-radius:4px; }
.bhr-msg-sender{ font-size:10px; opacity:.7; margin-bottom:3px; font-weight:700; text-transform:uppercase; }
.bhr-msg-meta  { font-size:10px; opacity:.55; margin-top:4px; }
.bhr-msg-media img{ max-width:180px; border-radius:8px; margin-top:6px; display:block; }
.bhr-chat-loading{ text-align:center; color:var(--bhr-text-muted); padding:48px 20px; font-size:13px; }

/* ── Filters ───────────────────────────────────── */
.bhr-rent-filters{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:16px; }
.bhr-rent-filters input,.bhr-rent-filters select{ padding:8px 12px; border:1px solid var(--bhr-border); border-radius:var(--bhr-radius-sm); font-size:13px; }
.bhr-img-link{ color:var(--bhr-accent); font-size:12px; font-weight:600; }

/* ── Detail list ───────────────────────────────── */
.bhr-detail-list{ display:grid; }
.bhr-detail-list>div{ display:flex; justify-content:space-between; align-items:center; font-size:13px; padding:9px 0; border-bottom:1px solid #f0f4f8; }
.bhr-detail-list span{ color:var(--bhr-text-muted); }

/* ── Plan status ───────────────────────────────── */
.bhr-plan-status{ display:grid; }
.bhr-plan-status-row{ display:flex; justify-content:space-between; padding:10px 0; border-bottom:1px solid var(--bhr-border); font-size:13px; }
.bhr-plan-status-row span{ color:var(--bhr-text-muted); }
.bhr-text-success{ color:var(--bhr-success); }
.bhr-text-danger { color:var(--bhr-danger); }

/* ── PIN card ──────────────────────────────────── */
.bhr-pin-card{ max-width:420px; }

/* ── Modal ─────────────────────────────────────── */
.bhr-modal-overlay{
  position:fixed; inset:0; background:rgba(0,0,0,.42);
  display:flex; align-items:center; justify-content:center; z-index:99999; padding:20px;
  backdrop-filter:blur(1px); animation:bhrFadeIn .15s ease;
}
.bhr-modal-box{
  background:#fff; border-radius:var(--bhr-radius); padding:36px;
  max-width:500px; width:100%; max-height:85vh; overflow-y:auto;
  position:relative; box-shadow:var(--bhr-shadow-md); border:1px solid var(--bhr-border);
  animation:bhrPop .22s var(--bhr-ease);
}
.bhr-modal-center{ text-align:center; }
.bhr-modal-close{
  position:absolute; top:14px; right:16px; background:#f0f4f8;
  border:1px solid var(--bhr-border); width:28px; height:28px;
  border-radius:50%; font-size:13px; cursor:pointer;
  display:flex; align-items:center; justify-content:center; color:var(--bhr-text-muted);
  transition:background .12s;
}
.bhr-modal-close:hover{ background:var(--bhr-border); }
.bhr-id-display{
  background:var(--bhr-primary-light); border:2px solid var(--bhr-primary);
  border-radius:var(--bhr-radius-sm); padding:16px 22px;
  font-size:22px; font-weight:900; letter-spacing:2px; color:var(--bhr-primary);
  margin:18px auto; font-family:monospace;
}
.bhr-modal-body{ font-size:13px; line-height:1.7; color:var(--bhr-text-muted); }

/* ── Toast ─────────────────────────────────────── */
.bhr-toast{
  position:fixed; bottom:24px; right:24px; background:#1a202c; color:#fff;
  padding:12px 20px; border-radius:var(--bhr-radius-sm); font-size:13px;
  font-weight:500; z-index:999999; box-shadow:var(--bhr-shadow-md);
  max-width:340px; animation:bhrSlideUp .2s var(--bhr-ease);
}
.bhr-toast-success{ background:var(--bhr-success); }
.bhr-toast-error  { background:var(--bhr-danger); }
.bhr-toast-warning{ background:var(--bhr-warning); }

/* ── Empty state ───────────────────────────────── */
.bhr-empty-state{
  text-align:center; padding:52px 20px; color:var(--bhr-text-muted); font-size:14px;
  background:#fff; border-radius:var(--bhr-radius); border:1px solid var(--bhr-border);
}
.bhr-divider{ border:none; border-top:1px solid var(--bhr-border); margin:28px 0; }

/* ── House photo grid ──────────────────────────── */
.bhr-house-photos-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:10px; margin:14px 0 22px; }
@media(max-width:600px){ .bhr-house-photos-grid{ grid-template-columns:repeat(3,1fr); } }
.bhr-photo-slot .bhr-file-zone.bhr-photo-zone{
  height:90px; padding:0; overflow:hidden; display:flex;
  align-items:center; justify-content:center; flex-direction:column;
}
.bhr-photo-zone-inner{ text-align:center; pointer-events:none; }
.bhr-photo-preview-thumb{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; border-radius:var(--bhr-radius-sm); }

/* ── Owner/building preview ────────────────────── */
#bhr_owner_building_preview{
  background:#fff; border:1px solid var(--bhr-border);
  border-left:3px solid var(--bhr-primary);
  border-radius:var(--bhr-radius-sm); padding:18px; margin:18px 0;
  animation:bhrFadeIn .2s ease;
}
.bhr-confirm-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media(max-width:520px){ .bhr-confirm-grid{ grid-template-columns:1fr; } }
.bhr-confirm-owner-box,.bhr-confirm-building-box{
  background:#fafbfc; border-radius:var(--bhr-radius-sm); padding:16px; border:1px solid var(--bhr-border);
}
.bhr-confirm-label{ font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; color:var(--bhr-text-muted); margin-bottom:12px; }
.bhr-building-photos-strip img{ transition:opacity .15s; cursor:pointer; }
.bhr-building-photos-strip img:hover{ opacity:.85; }

/* ── Progress bar nav ──────────────────────────── */
#bhr-progress-bar-wrap{ position:fixed; top:0; left:0; right:0; height:3px; z-index:9999; background:transparent; pointer-events:none; }
#bhr-progress-bar{ height:3px; width:0; background:linear-gradient(90deg,var(--bhr-accent),#60a5fa); transition:width .3s var(--bhr-ease); }

/* ============================================================
   PIN Setup Modal — Compact, typeable
   ============================================================ */

.bhr-pin-setup-modal {
  background: #fff; border-radius: 12px; overflow: hidden;
  width: 100%; max-width: 320px;
  box-shadow: 0 16px 48px rgba(0,0,0,.2);
  animation: bhrPop .25s var(--bhr-ease);
}
.bhr-pin-setup-header {
  background: linear-gradient(135deg, var(--bhr-primary) 0%, #2d5f9e 100%);
  padding: 18px 20px 14px; text-align: center; color: #fff;
}
.bhr-pin-setup-check {
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(255,255,255,.2);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 8px;
}
.bhr-pin-setup-header h2 { font-size: 15px; font-weight: 700; margin: 0 0 3px; }
.bhr-pin-setup-header p  { font-size: 11px; color: rgba(255,255,255,.75); margin: 0; }
.bhr-pin-setup-body      { padding: 16px 18px 18px; }

.bhr-pin-id-section {
  text-align: center; padding: 10px 12px;
  background: var(--bhr-primary-light); border-radius: 7px;
  border: 1px solid var(--bhr-primary-mid); margin-bottom: 14px;
}
.bhr-pin-id-label { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--bhr-text-muted); margin-bottom: 4px; }
.bhr-pin-id-value { font-size: 15px; font-weight: 900; font-family: 'Courier New', monospace; color: var(--bhr-primary); letter-spacing: 1px; word-break: break-all; margin-bottom: 4px; }
.bhr-pin-id-note  { font-size: 10px; color: var(--bhr-text-muted); margin: 0; }
.bhr-pin-divider  { height: 1px; background: var(--bhr-border); margin: 0 0 12px; }

.bhr-pin-create-section { text-align: center; }
.bhr-pin-create-title   { font-size: 13px; font-weight: 700; color: var(--bhr-text); margin-bottom: 3px; }
.bhr-pin-create-desc    { font-size: 11px; color: var(--bhr-text-muted); margin-bottom: 10px; }

/* Dot row */
.bhr-pin-dot-row { display: flex; justify-content: center; gap: 9px; margin-bottom: 4px; }
.bhr-pin-dot {
  width: 11px; height: 11px; border-radius: 50%;
  border: 2px solid var(--bhr-border); background: transparent;
  transition: all .12s var(--bhr-ease);
}
.bhr-pin-dot.filled  { background: var(--bhr-primary); border-color: var(--bhr-primary); transform: scale(1.1); }
.bhr-pin-dot.error   { background: var(--bhr-danger); border-color: var(--bhr-danger); animation: bhrShake .3s ease; }
.bhr-pin-dot.success { background: var(--bhr-success); border-color: var(--bhr-success); }
@keyframes bhrShake {
  0%,100%{ transform:translateX(0); } 25%{ transform:translateX(-4px); }
  75%    { transform:translateX(4px); }
}

/* Typeable PIN input — always visible */
.bhr-pin-visible-input {
  width: 150px; margin: 8px auto 2px; display: block;
  text-align: center; letter-spacing: 8px; font-size: 20px;
  font-family: 'Courier New', monospace; font-weight: 700;
  padding: 7px 10px; border: 1.5px solid var(--bhr-border);
  border-radius: var(--bhr-radius-sm); background: #f8fafc;
  transition: border-color .15s; -webkit-appearance: none;
}
.bhr-pin-visible-input:focus { outline: none; border-color: var(--bhr-accent); background: #fff; box-shadow: 0 0 0 3px rgba(37,99,235,.1); }
.bhr-pin-hidden-input { position: absolute; opacity: 0; pointer-events: none; width: 0; height: 0; }

.bhr-pin-state { font-size: 11px; font-weight: 600; min-height: 15px; margin: 3px 0; text-align: center; }
.bhr-pin-state.ok    { color: var(--bhr-success); }
.bhr-pin-state.error { color: var(--bhr-danger); }

/* Compact keypad */
.bhr-keypad {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 5px; margin: 8px auto 0; max-width: 200px;
}
.bhr-key {
  background: #f5f7fa; border: 1px solid var(--bhr-border);
  border-radius: 7px; font-size: 15px; font-weight: 600;
  padding: 9px 0; cursor: pointer; font-family: inherit;
  color: var(--bhr-text); transition: all .1s var(--bhr-ease); user-select: none;
}
.bhr-key:hover  { background: #eef2f7; }
.bhr-key:active { background: var(--bhr-primary-light); transform: scale(.95); }
.bhr-key-clear  { font-size: 9px; font-weight: 700; color: var(--bhr-text-muted); }
.bhr-key-del    { font-size: 15px; }
.bhr-pin-row-label { text-align: center; font-size: 11px; color: var(--bhr-text-muted); margin: 4px 0 0; }

/* Upload progress bar */
.bhr-upload-progress-wrap {
  display: none; margin-top: 16px;
  background: #f0f4f8; border-radius: 8px; padding: 14px 18px;
}
.bhr-upload-progress-wrap.visible { display: block; animation: bhrFadeIn .2s ease; }
.bhr-upload-progress-label { font-size: 13px; font-weight: 600; color: var(--bhr-primary); margin-bottom: 8px; display: flex; justify-content: space-between; }
.bhr-upload-progress-bar-bg { height: 8px; background: #dde3ea; border-radius: 999px; overflow: hidden; }
.bhr-upload-progress-bar    { height: 100%; background: linear-gradient(90deg, var(--bhr-primary), var(--bhr-accent)); border-radius: 999px; transition: width .3s ease; width: 0%; }
.bhr-upload-progress-hint   { font-size: 11px; color: var(--bhr-text-muted); margin-top: 6px; text-align: center; }

/* ============================================================
   Biometric login
   ============================================================ */

.bhr-biometric-section { margin-top: 20px; text-align: center; }

.bhr-biometric-divider {
  display: flex; align-items: center; gap: 12px;
  margin: 0 0 16px; color: var(--bhr-text-light); font-size: 12px;
}
.bhr-biometric-divider::before,
.bhr-biometric-divider::after {
  content: ''; flex: 1; height: 1px; background: var(--bhr-border);
}

.bhr-biometric-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  width: 100%; padding: 12px 20px;
  background: #fff; border: 1.5px solid var(--bhr-border);
  border-radius: var(--bhr-radius-sm); font-size: 14px; font-weight: 600;
  cursor: pointer; font-family: inherit; color: var(--bhr-text);
  transition: all .15s var(--bhr-ease);
}

.bhr-biometric-btn:hover {
  border-color: var(--bhr-primary); color: var(--bhr-primary);
  background: var(--bhr-primary-light);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(30,58,95,.1);
}

.bhr-biometric-btn svg { flex-shrink: 0; }

.bhr-biometric-note {
  margin-top: 8px; font-size: 11px; color: var(--bhr-text-light);
}

.bhr-biometric-processing {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--bhr-text-muted); margin-top: 10px;
}

/* Pulse ring for biometric scanning */
@keyframes bhrBioPulse {
  0%   { transform:scale(1); opacity:.7; }
  100% { transform:scale(2.2); opacity:0; }
}

.bhr-bio-scanning {
  position: relative; display: inline-flex;
  align-items: center; justify-content: center;
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--bhr-primary-light); margin: 12px auto;
}

.bhr-bio-scanning::after {
  content: '';
  position: absolute; inset: 0; border-radius: 50%;
  border: 2px solid var(--bhr-primary);
  animation: bhrBioPulse .9s ease-out infinite;
}

/* ============================================================
   Login panels — forgot ID / forgot PIN / OTP
   ============================================================ */

/* Panel transition */
.bhr-login-panel { animation: bhrFadeIn .22s var(--bhr-ease); }

/* Login links row */
.bhr-login-links {
  display: flex;
  justify-content: space-between;
  margin: 4px 0 0;
}
.bhr-text-link {
  font-size: 12px;
  color: var(--bhr-accent);
  text-decoration: none;
  font-weight: 500;
  transition: color .12s;
}
.bhr-text-link:hover { color: var(--bhr-primary); text-decoration: underline; }

/* Label sub-text */
.bhr-label-sub { font-size: 11px; font-weight: 400; color: var(--bhr-text-muted); }

/* Back button */
.bhr-back-btn {
  display: inline-flex; align-items: center; gap: 4px;
  background: none; border: none; color: var(--bhr-text-muted);
  font-size: 13px; cursor: pointer; padding: 0; margin-bottom: 20px;
  font-family: inherit; font-weight: 500;
  transition: color .12s;
}
.bhr-back-btn:hover { color: var(--bhr-primary); }

/* OTP instruction block */
.bhr-otp-instruction {
  text-align: center;
  padding: 20px 16px;
  background: var(--bhr-primary-light);
  border-radius: var(--bhr-radius-sm);
  border: 1px solid var(--bhr-primary-mid);
  margin-bottom: 20px;
}
.bhr-otp-icon {
  font-size: 32px;
  margin-bottom: 10px;
  display: block;
  font-style: normal;
}
.bhr-otp-instruction p { margin: 0 0 6px; font-size: 14px; color: var(--bhr-text); }
.bhr-otp-note { font-size: 12px !important; color: var(--bhr-text-muted) !important; }

/* OTP input — large and centred */
.bhr-otp-input {
  text-align: center !important;
  letter-spacing: 8px !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  font-family: 'Courier New', monospace !important;
  padding: 12px 14px !important;
}

/* Form message (success/error under form) */
.bhr-form-msg {
  margin-top: 12px;
  padding: 10px 14px;
  border-radius: var(--bhr-radius-sm);
  font-size: 13px;
  font-weight: 500;
  animation: bhrFadeIn .2s ease;
}
.bhr-form-msg.ok    { background: var(--bhr-success-light); color: var(--bhr-success); border: 1px solid #86efac; }
.bhr-form-msg.error { background: var(--bhr-danger-light);  color: var(--bhr-danger);  border: 1px solid #fca5a5; }
.bhr-form-msg.info  { background: var(--bhr-primary-light); color: var(--bhr-primary); border: 1px solid var(--bhr-primary-mid); }

/* Success step */
.bhr-success-step {
  text-align: center;
  padding: 28px 16px;
}
.bhr-success-step-icon {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: var(--bhr-success);
  color: #fff; font-size: 28px; font-style: normal;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 16px;
  animation: bhrPop .3s var(--bhr-ease);
}
.bhr-success-step h3 { font-size: 18px; font-weight: 700; margin: 0 0 10px; }
.bhr-success-step p  { color: var(--bhr-text-muted); font-size: 14px; margin: 0 0 20px; }

/* Resend link */
.bhr-resend-link {
  text-align: center;
  font-size: 12px;
  color: var(--bhr-text-muted);
  margin-top: 12px;
}
.bhr-resend-link a { color: var(--bhr-accent); cursor: pointer; }

/* ============================================================
   Forgot ID / PIN modal popup
   ============================================================ */

/* text-button (replaces anchor links to avoid # jump) */
.bhr-text-btn {
  background: none; border: none; padding: 0; margin: 0;
  font-size: 12px; font-weight: 600; color: var(--bhr-accent);
  cursor: pointer; font-family: inherit;
  transition: color .12s;
  text-decoration: none;
}
.bhr-text-btn:hover { color: var(--bhr-primary); text-decoration: underline; }

/* login-links row */
.bhr-login-links {
  display: flex; justify-content: space-between; margin: 6px 0 0;
}

/* forgot modal overlay */
.bhr-forgot-modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.45);
  display: flex; align-items: center; justify-content: center;
  z-index: 99999; padding: 20px;
  backdrop-filter: blur(2px);
  animation: bhrFadeIn .18s ease;
}

/* re-use .bhr-modal-overlay for the forgot modals */
#bhr_modal_forgot_id,
#bhr_modal_forgot_pin {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.45);
  display: flex; align-items: center; justify-content: center;
  z-index: 99999; padding: 20px;
  backdrop-filter: blur(2px);
  animation: bhrFadeIn .18s ease;
}

/* modal box */
.bhr-forgot-modal {
  background: #fff; border-radius: 12px;
  width: 100%; max-width: 400px;
  box-shadow: 0 20px 60px rgba(0,0,0,.2);
  overflow: hidden;
  animation: bhrPop .22s var(--bhr-ease);
  max-height: 90vh; overflow-y: auto;
}

/* modal header */
.bhr-forgot-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 22px 16px;
  border-bottom: 1px solid var(--bhr-border);
}
.bhr-forgot-modal-header h2 {
  font-size: 17px; font-weight: 700; color: var(--bhr-primary); margin: 0;
}
.bhr-modal-x {
  background: #f0f4f8; border: 1px solid var(--bhr-border);
  width: 28px; height: 28px; border-radius: 50%;
  font-size: 13px; cursor: pointer; color: var(--bhr-text-muted);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; transition: background .12s;
  font-family: inherit;
}
.bhr-modal-x:hover { background: var(--bhr-border); color: var(--bhr-text); }

/* modal body (each step) */
.bhr-forgot-step { padding: 22px; }

.bhr-forgot-desc { font-size: 14px; color: var(--bhr-text-muted); margin: 0 0 18px; line-height: 1.6; }

/* OTP sent notice */
.bhr-otp-sent-notice {
  text-align: center;
  background: var(--bhr-primary-light); border: 1px solid var(--bhr-primary-mid);
  border-radius: 8px; padding: 16px; margin-bottom: 18px;
}
.bhr-otp-sent-icon { font-size: 28px; display: block; margin-bottom: 8px; font-style: normal; }
.bhr-otp-sent-notice p { margin: 0; font-size: 13px; color: var(--bhr-text); }

/* success state */
.bhr-forgot-success { text-align: center; padding: 8px 0; }
.bhr-forgot-success-icon {
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--bhr-success); color: #fff;
  font-size: 26px; font-style: normal;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 14px;
  animation: bhrPop .3s var(--bhr-ease);
}
.bhr-forgot-success h3 { font-size: 18px; font-weight: 700; margin: 0 0 8px; }
.bhr-forgot-success p  { color: var(--bhr-text-muted); font-size: 14px; margin: 0; }

/* PIN dot row label */
.bhr-pin-row-label {
  text-align: center; font-size: 12px;
  color: var(--bhr-text-muted); margin: 6px 0 0;
}
