/* ══════════════════════════ ROLE STYLES ══════════════════════════ */

/* Role badge pill */
.rbadge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:99px;
  font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}
.rbadge.guest  {background:rgba(82,82,90,.18); color:#a0a0a8;border:1px solid rgba(82,82,90,.3)}
.rbadge.client {background:rgba(96,165,250,.12);color:#60a5fa;border:1px solid rgba(96,165,250,.25)}
.rbadge.master {background:rgba(52,211,153,.12);color:#34d399;border:1px solid rgba(52,211,153,.25)}
.rbadge.admin  {background:rgba(245,158,11,.12);color:#f59e0b;border:1px solid rgba(245,158,11,.25)}
.rbadge.owner  {background:rgba(255,107,0,.12); color:#FF6B00;border:1px solid rgba(255,107,0,.28)}

/* Avatar ring by role */
.nav-avatar.r-client{box-shadow:0 0 0 2px #60a5fa}
.nav-avatar.r-master{box-shadow:0 0 0 2px #34d399}
.nav-avatar.r-admin {box-shadow:0 0 0 2px #f59e0b}
.nav-avatar.r-owner {box-shadow:0 0 0 2px #FF6B00}

/* Drawer role footer */
.drawer-role-footer{padding:16px 20px;border-top:1px solid var(--line);
  display:flex;align-items:center;gap:12px}
.drf-av{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-family:'Oswald',sans-serif;font-size:16px;font-weight:700;flex-shrink:0}
.drf-av.guest {background:var(--surface);color:var(--text3)}
.drf-av.client{background:rgba(96,165,250,.15);color:#60a5fa}
.drf-av.master{background:rgba(52,211,153,.15);color:#34d399}
.drf-av.admin {background:rgba(245,158,11,.15);color:#f59e0b}
.drf-av.owner {background:rgba(255,107,0,.12); color:#FF6B00}
.drf-name{font-size:14px;font-weight:700}
.drf-btn{margin-left:auto;padding:6px 13px;border-radius:6px;font-size:12px;font-weight:600;
  background:var(--orange-dim);border:1px solid var(--orange-brd);color:var(--orange);
  cursor:pointer;transition:.2s var(--ease);white-space:nowrap}
.drf-btn:hover{background:rgba(255,107,0,.2)}

/* Locked page */
.locked-wrap{min-height:55vh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;padding:48px 20px;gap:14px}
.locked-ico{font-size:54px;opacity:.35}
.locked-title{font-family:'Oswald',sans-serif;font-size:22px;font-weight:700}
.locked-sub{font-size:14px;color:var(--text2);max-width:300px;line-height:1.65}

/* ── MASTER DASHBOARD ── */
.mast-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}
.mast-stat{padding:16px 18px;border-radius:8px}
.mast-stat-num{font-family:'Oswald',sans-serif;font-size:24px;font-weight:700;color:var(--orange)}
.mast-stat-lbl{font-size:11px;color:var(--text3);margin-top:3px;font-weight:600;text-transform:uppercase;letter-spacing:1px}
.mast-stat-ch{font-size:11px;color:var(--green);margin-top:2px}

.sched-list{display:flex;flex-direction:column;gap:10px}
.sched-slot{display:grid;grid-template-columns:60px 1fr auto;gap:14px;
  align-items:center;padding:14px 18px;border-radius:8px}
.sched-time{font-family:'Oswald',sans-serif;font-size:16px;font-weight:700;
  color:var(--orange);line-height:1}
.sched-sub{font-size:10px;color:var(--text3);font-family:'Mulish',sans-serif;margin-top:2px}
.sched-name{font-weight:700;font-size:14px;margin-bottom:2px}
.sched-svc{font-size:12px;color:var(--text2)}
.sched-car{font-size:11px;color:var(--text3);margin-top:2px}
.sched-btn{padding:7px 14px;border-radius:6px;font-size:11px;font-weight:700;
  cursor:pointer;transition:.2s var(--ease);white-space:nowrap}
.sched-btn.go  {background:var(--orange-dim);color:var(--orange);border:1px solid var(--orange-brd)}
.sched-btn.go:hover{background:rgba(255,107,0,.2)}
.sched-btn.done{background:rgba(34,197,94,.1);color:var(--green);border:1px solid rgba(34,197,94,.25)}
.sched-free{font-size:13px;color:var(--text3);font-style:italic}

/* ── OWNER PANEL ── */
.owner-hero{background:linear-gradient(135deg,rgba(255,107,0,.07),transparent);
  border-bottom:1px solid var(--orange-brd);padding:44px 0 0}
.owner-tabs{display:flex;gap:0;overflow-x:auto;scrollbar-width:none}
.owner-tabs::-webkit-scrollbar{display:none}
.owner-tab{font-family:'Oswald',sans-serif;font-size:12px;font-weight:600;letter-spacing:1px;
  text-transform:uppercase;padding:12px 20px;color:var(--text2);border-bottom:2px solid transparent;
  transition:.2s var(--ease);white-space:nowrap;flex-shrink:0;cursor:pointer}
.owner-tab:hover{color:var(--text)}
.owner-tab.active{color:var(--orange);border-bottom-color:var(--orange)}
.owner-pane{display:none;padding:32px 0;animation:pageIn .25s var(--ease) both}
.owner-pane.active{display:block}

.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px}
.kpi-card{padding:20px;border-radius:8px}
.kpi-emo{font-size:20px;margin-bottom:10px}
.kpi-lbl{font-size:10px;font-weight:700;color:var(--text3);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px}
.kpi-num{font-family:'Oswald',sans-serif;font-size:26px;font-weight:700;line-height:1}
.kpi-ch{font-size:11px;margin-top:4px}
.kpi-ch.up{color:var(--green)}.kpi-ch.flat{color:var(--text3)}

.bar-row{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.bar-label{font-size:13px;font-weight:600;min-width:180px}
.bar-track{flex:1;height:7px;background:var(--surface2);border-radius:99px;overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--orange),var(--orange-l));border-radius:99px}
.bar-val{font-family:'Oswald',sans-serif;font-size:13px;color:var(--orange);min-width:80px;text-align:right}

/* Staff table */
.staff-wrap{border:1px solid var(--line);border-radius:8px;overflow:hidden;overflow-x:auto}
.staff-tbl{width:100%;border-collapse:collapse;min-width:540px}
.staff-tbl th{padding:11px 16px;background:var(--surface2);text-align:left;
  font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text3)}
.staff-tbl td{padding:13px 16px;font-size:13px;border-top:1px solid var(--line);vertical-align:middle}
.staff-tbl tbody tr:hover td{background:rgba(255,255,255,.02)}
.role-sel{background:var(--surface);border:1px solid var(--line);border-radius:5px;
  padding:5px 10px;font-size:12px;color:var(--text);cursor:pointer;outline:none;
  transition:.2s var(--ease);font-family:'Mulish',sans-serif}
.role-sel:focus{border-color:var(--orange-brd)}

/* Permission matrix */
.perm-wrap{border:1px solid var(--line);border-radius:8px;overflow:hidden;overflow-x:auto}
.perm-tbl{width:100%;border-collapse:collapse;min-width:480px}
.perm-tbl th,.perm-tbl td{padding:10px 14px;border:1px solid var(--line);font-size:12px}
.perm-tbl th{background:var(--surface2);color:var(--text3);font-weight:700;
  letter-spacing:1px;text-transform:uppercase;white-space:nowrap}
.perm-tbl td:first-child{font-weight:600;color:var(--text2);background:rgba(255,255,255,.02)}
.perm-yes{color:var(--green);font-size:16px;display:block;text-align:center}
.perm-no {color:var(--text3);font-size:14px;display:block;text-align:center}

/* Section block */
.owner-block{background:var(--surface);border:1px solid var(--line);
  border-radius:10px;padding:24px;margin-bottom:20px}
.owner-block-title{font-family:'Oswald',sans-serif;font-size:14px;font-weight:600;
  text-transform:uppercase;letter-spacing:1px;color:var(--orange);margin-bottom:18px;
  display:flex;align-items:center;gap:8px}

/* Responsive */
@media(max-width:900px){
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .mast-stats{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:560px){
  .kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .kpi-num{font-size:20px}
  .mast-stats{grid-template-columns:repeat(2,1fr);gap:8px}
  .sched-slot{grid-template-columns:52px 1fr;grid-template-rows:auto auto}
  .sched-btn{grid-column:2;margin-top:4px}
  .bar-label{min-width:120px;font-size:12px}
}

/* ── Staff panel role selector ─────────────────── */
.role-sel {
  background: var(--surface);
  border: 1.5px solid var(--line);
  border-radius: 7px;
  padding: 5px 10px;
  font-size: 12px;
  color: var(--text);
  font-family: 'Mulish', sans-serif;
  cursor: pointer;
  outline: none;
  transition: border-color .2s;
}
.role-sel:focus { border-color: var(--orange); }
.role-sel:hover { border-color: var(--orange-brd); }

/* ── Staff filter row active ────────────────────── */
.admin-filter-btn.active {
  background: var(--orange);
  color: #fff;
  border-color: var(--orange);
}

/* ── Add user modal fields ──────────────────────── */
.owiz-field { margin-bottom: 12px; }
.owiz-field label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 5px;
}
.owiz-input {
  width: 100%;
  background: var(--surface);
  border: 1.5px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
  font-size: 14px;
  color: var(--text);
  font-family: 'Mulish', sans-serif;
  outline: none;
  transition: border-color .2s;
  box-sizing: border-box;
}
.owiz-input:focus { border-color: var(--orange); }
