/* ═══════════════════════════════════════════════
   TENANCE — SHARED UI COMPONENTS
   Buttons, badges, search bars, forms, table,
   modal overlay, tabs, photo upload, section header.
═══════════════════════════════════════════════ */

/* ── Page header ── */
.ph { margin-bottom: 15px; }
.ph-t { font-size: 20px; font-weight: 700; color: var(--t1); letter-spacing: -.3px; }
.ph-s { font-size: 12px; color: var(--t2); margin-top: 3px; }

/* ── Toolbar row ── */
.tbar { display: flex; align-items: center; justify-content: space-between; gap: 9px; margin-bottom: 13px; flex-wrap: wrap; }

/* ── Search bar ── */
.srch {
  display: flex; align-items: center; gap: 7px;
  background: var(--card); border: 1px solid var(--border2);
  border-radius: 9px; padding: 8px 11px;
  flex: 1; max-width: 250px;
}
.srch svg { width: 13px; height: 13px; color: var(--t3); flex-shrink: 0; }
.srch input { background: none; border: none; outline: none; font-size: 12px; color: var(--t1); flex: 1; font-family: var(--font); }
.srch input::placeholder { color: var(--t3); }

/* ── Buttons ── */
.bg {
  background: var(--goldd); color: #1a0e00;
  border: none; border-radius: 9px; padding: 8px 15px;
  font-size: 12px; font-weight: 700; cursor: pointer;
  font-family: var(--font); display: flex; align-items: center; gap: 5px;
  transition: background .13s;
}
.bg:hover { background: var(--gold); }
.bo {
  background: transparent; color: var(--t2);
  border: 1px solid var(--border2); border-radius: 9px;
  padding: 8px 12px; font-size: 12px; font-weight: 500;
  cursor: pointer; font-family: var(--font); transition: all .13s;
}
.bo:hover { background: var(--hover); color: var(--t1); }
.bsm { padding: 4px 9px; font-size: 10px; border-radius: 7px; }

/* ── Status badges ── */
.bdg { font-size: 9px; font-weight: 700; padding: 2px 8px; border-radius: 20px; display: inline-block; letter-spacing: .3px; }
.b-ok   { background: rgba(60,160,70,.17);   color: #6ae07a; }
.b-w    { background: rgba(180,120,20,.19);  color: #d4a84e; }
.b-er   { background: rgba(180,40,40,.17);   color: #e07070; }
.b-i    { background: rgba(50,100,200,.17);  color: #80b0e8; }
.b-pend { background: rgba(224,155,107,.17); color: #e09b6b; }

/* ── Form inside panel (add forms) ── */
.af { background: var(--card); border: 1px solid var(--border2); border-radius: 14px; padding: 16px; margin-bottom: 14px; display: none; }
.af.on { display: block; }
.fg  { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.fg .full { grid-column: 1 / -1; }
.fg2 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }
.sf { margin-bottom: 0; }
.sl { font-size: 9px; font-weight: 700; color: var(--t2); margin-bottom: 5px; text-transform: uppercase; letter-spacing: .06em; }
.si {
  width: 100%; background: var(--card2);
  border: 1.5px solid var(--border2); border-radius: 8px;
  padding: 9px 11px; font-size: 12px; color: var(--t1);
  outline: none; font-family: var(--font);
  transition: border-color .13s; -webkit-appearance: none;
}
.si:focus { border-color: var(--goldd); }

/* ── Data table ── */
.twrap { background: var(--card); border-radius: 12px; overflow: hidden; border: 1px solid var(--border); }
table { width: 100%; border-collapse: collapse; }
th { text-align: left; padding: 10px 13px; font-size: 9px; font-weight: 700; color: var(--t3); text-transform: uppercase; letter-spacing: .08em; border-bottom: 1px solid var(--border2); }
td { padding: 10px 13px; font-size: 12px; color: var(--t1); border-bottom: 1px solid var(--border); vertical-align: middle; }
tbody tr:last-child td { border-bottom: none; }
tbody tr[onclick]:hover td { background: rgba(200,146,58,.04); }
tbody tr[onclick]:active td { background: rgba(200,146,58,.08); }
.tdfl { display: flex; align-items: center; gap: 8px; }

/* ── Modal overlay ── */
.overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.65); z-index: 300; align-items: center; justify-content: center; }
.overlay.on { display: flex; }
.modal {
  background: #191f1a; border-radius: 18px; padding: 24px;
  width: 400px; max-width: 92vw;
  border: 1px solid var(--border2);
  box-shadow: 0 30px 80px rgba(0,0,0,.6);
  max-height: 88vh; overflow-y: auto;
}
.modal::-webkit-scrollbar { width: 3px; }
.mh { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.mt2 { font-size: 15px; font-weight: 700; color: var(--t1); }
.mx { background: none; border: none; color: var(--t3); font-size: 18px; cursor: pointer; padding: 2px 5px; line-height: 1; }
.mx:hover { color: var(--t1); }
.mav2 { width: 56px; height: 56px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 18px; font-weight: 700; color: #fff; margin: 0 auto 11px; border: 2px solid rgba(255,255,255,.2); }
.mname { font-size: 16px; font-weight: 700; color: var(--t1); text-align: center; margin-bottom: 2px; }
.mprop { font-size: 11px; color: var(--t2); text-align: center; margin-bottom: 12px; }
.tidbox { background: rgba(224,155,107,.1); border: 1px solid rgba(224,155,107,.25); border-radius: 9px; padding: 10px 12px; margin: 11px 0; display: flex; align-items: center; justify-content: space-between; }
.tid-lbl { font-size: 9px; color: var(--gold); font-weight: 700; text-transform: uppercase; letter-spacing: .06em; margin-bottom: 2px; }
.tid-val { font-size: 16px; font-weight: 900; color: var(--gold); letter-spacing: 2px; }
.tid-copy { background: var(--goldd); color: #1a0e00; border: none; border-radius: 7px; padding: 5px 11px; font-size: 10px; font-weight: 700; cursor: pointer; font-family: var(--font); }
.mrow2 { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; border-bottom: 1px solid var(--border); }
.mrow2:last-child { border-bottom: none; }
.mk { font-size: 11px; color: var(--t2); }
.mv { font-size: 11px; font-weight: 700; color: var(--t1); }

/* ── Section inner tabs ── */
.ptabs { display: flex; gap: 4px; margin-bottom: 14px; background: var(--card2); border-radius: 10px; padding: 4px; }
.ptab { flex: 1; text-align: center; padding: 7px; font-size: 12px; font-weight: 600; color: var(--t2); cursor: pointer; border-radius: 8px; transition: all .13s; }
.ptab.on { background: var(--goldd); color: #fff; }

/* ── Tenant ID tag ── */
.tid { font-size: 8px; font-weight: 700; background: rgba(224,155,107,.13); color: var(--gold); padding: 2px 6px; border-radius: 4px; letter-spacing: .04em; }

/* ── Photo upload widget ── */
.photo-upload { display: flex; align-items: center; gap: 8px; margin-top: 8px; }
.photo-thumb {
  width: 40px; height: 40px; border-radius: 7px;
  background: var(--hover); border: 1px solid var(--border2);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; cursor: pointer; transition: background .13s; overflow: hidden;
}
.photo-thumb:hover { background: rgba(255,255,255,.08); }
.photo-thumb img { width: 100%; height: 100%; object-fit: cover; }
