/* ===========================================================================
   Portal styles — Doctor / Nurse / User / Administrative
   Extends the dark teal healthcare theme from styles.css
   =========================================================================== */
:root{
  --doctor:#14b8a6;   /* teal */
  --nurse:#a855f7;    /* purple */
  --user:#3b82f6;     /* blue */
  --admin:#f59e0b;    /* amber */
  --pharmacy:#10b981; /* green/emerald */
  --hospital:#06b6d4; /* cyan */
  --lab:#6366f1;      /* indigo */
  --radiology:#a855f7;/* purple */
  --surgical:#14b8a6; /* teal */
  --ambulance:#ef4444; /* red */
}
.portal-body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:#000;color:var(--text);
  display:flex;justify-content:center;
}
#portal-root{
  width:100%;max-width:440px;min-height:100vh;
  background:var(--bg);position:relative;overflow-x:hidden;
  display:flex;flex-direction:column;
}

/* ---------- Shared screen ---------- */
.scr{flex:1;display:flex;flex-direction:column;padding:0 0 40px}
.scr-pad{padding:0 22px}

.top-brand{
  display:flex;align-items:center;gap:12px;padding:26px 22px 8px;
}
.top-brand .logo{
  width:46px;height:46px;border-radius:13px;flex-shrink:0;
  background:var(--teal-soft);display:grid;place-items:center;color:var(--teal);font-size:24px;
}
.top-brand h1{font-size:18px;font-weight:800;line-height:1.15}
.top-brand h1 span{color:var(--teal)}
.top-brand p{font-size:12px;color:var(--muted);margin-top:2px}

.scr-back{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--muted);font-size:14px;font-weight:600;
  margin:14px 22px 0;background:none;
}
.scr-back i{font-size:13px}

/* ---------- Portal chooser ---------- */
.hero-head{padding:30px 22px 6px;text-align:center}
.hero-head .badge{
  display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;
  color:var(--teal);background:var(--teal-soft);padding:7px 14px;border-radius:30px;margin-bottom:16px;
}
.hero-head h2{font-size:26px;font-weight:800;line-height:1.2;margin-bottom:8px}
.hero-head p{font-size:13.5px;color:var(--muted);line-height:1.5;max-width:320px;margin:0 auto}

.portal-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:24px 22px 8px}
.portal-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 16px;text-align:left;position:relative;overflow:hidden;
  display:flex;flex-direction:column;gap:12px;transition:transform .15s,border-color .15s;
}
.portal-card:active{transform:scale(.97)}
.portal-card .pc-ico{
  width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-size:23px;
}
.portal-card h3{font-size:16px;font-weight:700}
.portal-card p{font-size:12px;color:var(--muted);line-height:1.45;flex:1}
.portal-card .pc-go{
  display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;
}
.portal-card .glow{position:absolute;top:-30px;right:-30px;width:90px;height:90px;border-radius:50%;filter:blur(30px);opacity:.35}

.pc-doctor .pc-ico{background:rgba(20,184,166,.16);color:var(--doctor)}
.pc-doctor .pc-go,.pc-doctor .glow{color:var(--doctor)} .pc-doctor .glow{background:var(--doctor)}
.pc-nurse  .pc-ico{background:rgba(168,85,247,.16);color:var(--nurse)}
.pc-nurse  .pc-go{color:var(--nurse)} .pc-nurse .glow{background:var(--nurse)}
.pc-user   .pc-ico{background:rgba(59,130,246,.16);color:var(--user)}
.pc-user   .pc-go{color:var(--user)} .pc-user .glow{background:var(--user)}
.pc-admin  .pc-ico{background:rgba(245,158,11,.16);color:var(--admin)}
.pc-admin  .pc-go{color:var(--admin)} .pc-admin .glow{background:var(--admin)}
.pc-pharmacy .pc-ico{background:rgba(16,185,129,.16);color:var(--pharmacy)}
.pc-pharmacy .pc-go{color:var(--pharmacy)} .pc-pharmacy .glow{background:var(--pharmacy)}

.chooser-foot{padding:20px 22px;text-align:center;color:var(--muted);font-size:12.5px}
.chooser-foot a{color:var(--teal);font-weight:700;text-decoration:none}

/* ---------- Auth form ---------- */
.auth-head{padding:8px 22px 4px}
.auth-head .role-chip{
  display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;
  padding:7px 14px;border-radius:30px;margin-bottom:16px;
}
.auth-head h2{font-size:25px;font-weight:800;margin-bottom:6px}
.auth-head p{font-size:13px;color:var(--muted);line-height:1.5}

.role-doctor{--accent:var(--doctor)}
.role-nurse {--accent:var(--nurse)}
.role-user  {--accent:var(--user)}
.role-admin {--accent:var(--admin)}
.role-pharmacy{--accent:var(--pharmacy)}
.role-chip.doctor{background:rgba(20,184,166,.16);color:var(--doctor)}
.role-chip.nurse {background:rgba(168,85,247,.16);color:var(--nurse)}
.role-chip.user  {background:rgba(59,130,246,.16);color:var(--user)}
.role-chip.admin {background:rgba(245,158,11,.16);color:var(--admin)}
.role-chip.pharmacy{background:rgba(16,185,129,.16);color:var(--pharmacy)}

.auth-form{padding:18px 22px 0;display:flex;flex-direction:column;gap:15px;min-width:0;overflow:hidden}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:12.5px;font-weight:600;color:var(--muted)}
.field .inp{
  display:flex;align-items:center;gap:11px;
  background:var(--surface);border:1px solid var(--line);border-radius:13px;padding:13px 15px;
  transition:border-color .15s;min-width:0;overflow:hidden;
}
.field .inp:focus-within{border-color:var(--accent,var(--teal))}
.field .inp i{color:var(--muted);font-size:15px;width:18px;text-align:center}
.field .inp input,.field .inp select{
  flex:1;background:none;border:none;outline:none;color:var(--text);font-size:14px;min-width:0;
}
.field .inp select{appearance:none}
.field .inp option{background:var(--surface);color:var(--text)}
.field .inp .toggle-pw{color:var(--muted);font-size:15px;cursor:pointer}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px;min-width:0}
.two-col>.field{min-width:0;overflow:hidden}
.two-col>.field label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}

.row-between{display:flex;align-items:center;justify-content:space-between;font-size:12.5px}
.row-between label{display:flex;align-items:center;gap:7px;color:var(--muted)}
.row-between a{color:var(--accent,var(--teal));font-weight:600;text-decoration:none}

.btn-primary{
  width:100%;background:var(--accent,var(--teal));color:#04201d;
  font-weight:800;font-size:15px;padding:15px;border-radius:13px;margin-top:4px;
  display:flex;align-items:center;justify-content:center;gap:9px;
}
.btn-primary:active{opacity:.85}
.btn-primary[disabled]{opacity:.55}

.auth-alt{text-align:center;font-size:13px;color:var(--muted);padding:20px 22px}
.auth-alt a{color:var(--accent,var(--teal));font-weight:700;text-decoration:none}

.form-msg{font-size:13px;padding:11px 14px;border-radius:11px;display:none}
.form-msg.show{display:block}
.form-msg.err{background:rgba(239,68,68,.13);color:#fca5a5;border:1px solid rgba(239,68,68,.3)}
.form-msg.ok {background:var(--teal-soft);color:#7ee0d3;border:1px solid rgba(20,184,166,.3)}

.demo-hint{
  margin:16px 22px 0;font-size:12px;color:var(--muted);
  background:var(--surface);border:1px dashed var(--line);border-radius:12px;padding:12px 14px;line-height:1.55;
}
.demo-hint b{color:var(--text)}

/* ---------- Dashboard ---------- */
.dash-top{
  display:flex;align-items:center;gap:13px;padding:24px 22px 18px;
  background:linear-gradient(180deg,#0d2530,#0a1a22);border-bottom:1px solid var(--line);
}
.dash-top .avatar{
  width:50px;height:50px;border-radius:14px;display:grid;place-items:center;font-size:21px;font-weight:800;color:#04201d;
}
.dash-top .who{flex:1;min-width:0}
.dash-top .who h2{font-size:17px;font-weight:800}
.dash-top .who p{font-size:12.5px;color:var(--muted);margin-top:2px}
.dash-top .logout{color:var(--muted);font-size:19px}

.welcome{padding:22px 22px 4px}
.welcome h3{font-size:22px;font-weight:800;margin-bottom:5px}
.welcome p{font-size:13px;color:var(--muted);line-height:1.5}

.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px;padding:18px 22px 6px}
.stat{
  background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:16px;
}
.stat .s-ico{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;font-size:17px;margin-bottom:11px}
.stat .s-val{font-size:24px;font-weight:800;line-height:1}
.stat .s-lbl{font-size:12px;color:var(--muted);margin-top:5px}

.panel{padding:20px 22px 4px}
.panel h4{font-size:16px;font-weight:800;margin-bottom:13px}
.list-item{
  display:flex;align-items:center;gap:13px;
  background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px;margin-bottom:11px;
}
.list-item .li-ico{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-size:16px;flex-shrink:0}
.list-item .li-txt{flex:1;min-width:0}
.list-item .li-txt h5{font-size:14px;font-weight:700}
.list-item .li-txt p{font-size:12px;color:var(--muted);margin-top:2px}
.li-tag{font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;white-space:nowrap}
.tag-green{background:var(--teal-soft);color:var(--teal)}
.tag-amber{background:rgba(245,158,11,.16);color:var(--admin)}
.tag-red{background:rgba(239,68,68,.14);color:#fca5a5}

.accent-doctor{background:rgba(20,184,166,.16);color:var(--doctor)}
.accent-nurse {background:rgba(168,85,247,.16);color:var(--nurse)}
.accent-user  {background:rgba(59,130,246,.16);color:var(--user)}
.accent-admin {background:rgba(245,158,11,.16);color:var(--admin)}
.accent-pharmacy{background:rgba(16,185,129,.16);color:var(--pharmacy)}

.spin{animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===========================================================================
   Multi-portal additions: top bar, closeable menu, features, uploads, reviews
   =========================================================================== */

/* ---- Top bar ---- */
.pbar{
  position:sticky;top:0;z-index:30;
  display:flex;align-items:center;gap:12px;padding:14px 16px;
  background:rgba(8,16,23,.92);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.pbar-menu,.pbar-home{
  width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  background:var(--surface);border:1px solid var(--line);color:var(--text);font-size:17px;text-decoration:none;
  transition:transform .12s,border-color .12s;
}
.pbar-menu:active,.pbar-home:active{transform:scale(.92)}
.pbar-menu:hover,.pbar-home:hover{border-color:var(--teal)}
.pbar-title{flex:1;min-width:0}
.pbar-title h1{font-size:16px;font-weight:800;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pbar-title p{font-size:11.5px;color:var(--muted);margin-top:1px}

/* ---- Closeable drawer menu ---- */
.pm-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.6);opacity:0;visibility:hidden;
  transition:opacity .25s,visibility .25s;z-index:40;backdrop-filter:blur(2px);
}
.pm-overlay.show{opacity:1;visibility:visible}
.pm-drawer{
  position:fixed;top:0;left:0;height:100%;width:82%;max-width:330px;z-index:50;
  background:linear-gradient(180deg,#0c1c25,#081017);
  border-right:1px solid var(--line);
  transform:translateX(-105%);transition:transform .28s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;box-shadow:8px 0 40px rgba(0,0,0,.5);
}
.pm-drawer.show{transform:translateX(0)}
.pm-head{display:flex;align-items:center;justify-content:space-between;padding:20px 18px 8px}
.pm-brand{font-size:16px;font-weight:800;color:var(--teal);display:flex;align-items:center;gap:9px}
.pm-close{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;
  background:var(--surface);border:1px solid var(--line);color:var(--text);font-size:17px}
.pm-close:active{transform:scale(.9)}
.pm-user{display:flex;align-items:center;gap:12px;margin:10px 16px 6px;padding:14px;
  background:var(--surface);border:1px solid var(--line);border-radius:15px}
.pm-user .pm-ava{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;
  background:var(--teal-soft);color:var(--teal);font-weight:800;font-size:17px}
.pm-user b{font-size:14.5px;display:block}
.pm-user small{font-size:12px;color:var(--muted)}
.pm-list{flex:1;overflow-y:auto;padding:12px 12px 6px;display:flex;flex-direction:column;gap:4px}
.pm-item{display:flex;align-items:center;gap:14px;width:100%;text-align:left;
  padding:13px 14px;border-radius:13px;color:var(--text);font-size:14.5px;font-weight:600;background:none;
  transition:background .12s}
.pm-item i:first-child{width:20px;text-align:center;color:var(--muted);font-size:16px}
.pm-item span{flex:1}
.pm-item:hover{background:var(--surface)}
.pm-item.active{background:var(--teal-soft);color:var(--teal)}
.pm-item.active i{color:var(--teal)}
.pm-badge{background:#ef4444;color:#fff;font-size:10px;font-weight:800;font-style:normal;
  min-width:18px;height:18px;border-radius:9px;display:grid;place-items:center;padding:0 5px}
.pm-badge.dark{background:var(--admin);color:#1a1205}
.pm-foot{padding:14px 16px 20px;border-top:1px solid var(--line)}
.pm-logout{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;
  padding:13px;border-radius:13px;font-weight:800;font-size:14px;
  background:rgba(239,68,68,.12);color:#fca5a5;border:1px solid rgba(239,68,68,.25)}
.pm-logout.signin{background:var(--teal-soft);color:var(--teal);border-color:rgba(20,184,166,.3)}
.pm-logout:active{transform:scale(.97)}

/* ---- chooser foot button ---- */
.ghost-btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:14px;
  padding:13px 22px;border-radius:13px;background:var(--surface);border:1px solid var(--line);color:var(--text)}
.ghost-btn:active{transform:scale(.97)}

/* ---- verify banners ---- */
.verify-banner{display:flex;align-items:center;gap:13px;margin:6px 22px 12px;
  padding:14px 15px;border-radius:14px;border:1px solid var(--line);background:var(--surface)}
.verify-banner i:first-child{font-size:22px;flex-shrink:0}
.verify-banner b{font-size:14px;display:block}
.verify-banner p{font-size:12px;color:var(--muted);margin-top:2px;line-height:1.4}
.verify-banner button{margin-left:auto;flex-shrink:0;background:var(--teal);color:#04201d;
  font-weight:800;font-size:12.5px;padding:9px 14px;border-radius:11px}
.verify-banner.warn{border-color:rgba(245,158,11,.3)}.verify-banner.warn i:first-child{color:var(--admin)}
.verify-banner.pend{border-color:rgba(59,130,246,.3)}.verify-banner.pend i:first-child{color:var(--user)}
.verify-banner.rej{border-color:rgba(239,68,68,.3)}.verify-banner.rej i:first-child{color:#fca5a5}
.verify-banner.ok{border-color:rgba(20,184,166,.3)}.verify-banner.ok i:first-child{color:var(--teal)}

/* ---- feature cards ---- */
.feature-grid{display:flex;flex-direction:column;gap:11px}
.feature-card{display:flex;align-items:center;gap:14px;width:100%;text-align:left;
  background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px 15px;
  color:var(--text);font-weight:700;font-size:14.5px;transition:transform .12s,border-color .12s}
.feature-card:active{transform:scale(.98)}
.feature-card>i:first-child{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;
  background:var(--teal-soft);color:var(--teal);font-size:17px;flex-shrink:0}
.feature-card span{flex:1}
.feature-card .go{color:var(--muted);font-size:14px}
.feature-card.locked{opacity:.7}
.feature-card.locked>i:first-child{background:rgba(148,163,184,.12);color:var(--muted)}
.feature-card.locked .go{color:var(--admin)}
.role-user .feature-card>i:first-child{background:rgba(59,130,246,.16);color:var(--user)}
.role-admin .feature-card>i:first-child{background:rgba(245,158,11,.16);color:var(--admin)}

/* ---- textarea in fields ---- */
.field .inp textarea{flex:1;background:none;border:none;outline:none;color:var(--text);
  font-size:14px;font-family:inherit;resize:vertical;line-height:1.5}
.field .inp:has(textarea){align-items:flex-start}

/* ---- upload box ---- */
.upload-box{display:flex;align-items:center;gap:14px;cursor:pointer;
  border:1.5px dashed var(--line);border-radius:14px;padding:16px;margin-top:6px;
  background:var(--surface);transition:border-color .15s}
.upload-box:hover{border-color:var(--teal)}
.upload-box>i{font-size:24px;color:var(--teal)}
.upload-box span{font-size:13px;color:var(--text)}
.upload-box small{color:var(--muted)}

/* ---- document rows / chips ---- */
.doc-list{display:flex;flex-direction:column;gap:9px;margin-bottom:6px}
.doc-row{display:flex;align-items:center;gap:12px;background:var(--surface);
  border:1px solid var(--line);border-radius:12px;padding:12px 13px}
.doc-row>i:first-child{color:var(--teal);font-size:18px}
.doc-meta{flex:1;min-width:0}
.doc-meta b{font-size:13.5px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.doc-meta small{font-size:11.5px;color:var(--muted)}
.doc-del{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;
  background:rgba(239,68,68,.12);color:#fca5a5;font-size:13px;flex-shrink:0}
.doc-del.small-del{width:auto;padding:7px 12px;gap:7px;display:inline-flex;align-items:center;font-size:12px;font-weight:700;margin-top:4px}
.doc-chips{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0}
.doc-chip{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;
  padding:7px 12px;border-radius:20px;background:var(--teal-soft);color:var(--teal);text-decoration:none}
.muted-note{font-size:12.5px;color:var(--muted);line-height:1.5}

/* ---- document detail cards (admin verification panel) ---- */
.doc-section{border-top:1px solid var(--line);padding-top:11px;margin-top:2px}
.doc-section-title{font-size:13px;font-weight:800;color:var(--text);margin:0 0 10px;
  display:flex;align-items:center;gap:8px}
.doc-section-title i{color:var(--admin)}
.doc-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media (max-width:420px){.doc-grid{grid-template-columns:1fr}}
.doc-detail{display:flex;gap:11px;background:var(--bg);border:1px solid var(--line);
  border-radius:12px;padding:10px;align-items:flex-start}
.doc-thumb{width:58px;height:58px;border-radius:9px;object-fit:cover;flex-shrink:0;
  border:1px solid var(--line);background:#000;display:block}
.doc-thumb--file{display:grid;place-items:center;color:var(--admin);font-size:24px}
.doc-detail-info{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.doc-detail-type{font-size:12.5px;color:var(--text);font-weight:800}
.doc-detail-name{font-size:11.5px;color:var(--muted);word-break:break-word;overflow-wrap:anywhere}
.doc-detail-meta{font-size:11px;color:var(--muted);opacity:.85;word-break:break-word}
.doc-view{font-size:11.5px;font-weight:700;color:var(--teal);text-decoration:none;
  display:inline-flex;align-items:center;gap:5px;margin-top:3px}
.doc-view:hover{text-decoration:underline}
.rc-avatar{width:48px;height:48px;border-radius:12px;object-fit:cover;flex-shrink:0;
  border:1px solid var(--line)}

/* ---- list item variations ---- */
.list-item.col{flex-direction:column;align-items:stretch;gap:10px}
.list-item .li-main{display:flex;align-items:center;gap:13px}
.list-item .li-main .li-txt{flex:1;min-width:0}
.li-tags{display:flex;flex-direction:column;gap:5px;align-items:flex-end}
.li-actions{display:flex;gap:9px;flex-wrap:wrap}
.mini{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:800;
  padding:9px 14px;border-radius:11px}
.mini.ok{background:var(--teal-soft);color:var(--teal);border:1px solid rgba(20,184,166,.3)}
.mini.rej{background:rgba(239,68,68,.12);color:#fca5a5;border:1px solid rgba(239,68,68,.25)}
.mini:active{transform:scale(.96)}

/* ---- review cards (admin) ---- */
.review-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;
  padding:15px;margin-bottom:13px;display:flex;flex-direction:column;gap:11px}
.rc-head{display:flex;align-items:center;gap:13px}
.rc-head .li-txt{flex:1;min-width:0}
.rc-detail{display:flex;flex-direction:column;gap:5px;font-size:12.5px;color:var(--muted);line-height:1.45}
.rc-detail b{color:var(--text);font-weight:700}
.rc-appt{background:rgba(20,184,166,.10);border:1px solid rgba(20,184,166,.25);border-radius:8px;padding:6px 9px;color:var(--text)!important}
.rc-appt b{color:var(--teal)!important}
.rc-appt b i{margin-right:4px}

/* ---- toast ---- */
.p-toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);
  z-index:90;display:flex;align-items:center;gap:10px;
  background:#0c1c25;border:1px solid rgba(20,184,166,.4);color:var(--text);
  padding:13px 18px;border-radius:13px;font-size:13.5px;font-weight:600;
  box-shadow:0 12px 40px rgba(0,0,0,.5);opacity:0;transition:opacity .28s,transform .28s;max-width:90%}
.p-toast i{color:var(--teal);font-size:16px}
.p-toast.err{border-color:rgba(239,68,68,.45)}.p-toast.err i{color:#fca5a5}
.p-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---- tag-blue for completed ---- */
.tag-blue{background:rgba(59,130,246,.16);color:#93c5fd}

/* ---- Text overflow fixes for doctor panel ---- */
.li-txt h5,.li-txt p,.pbar-title h1,.pbar-title p,
.rc-detail span,.doc-meta b,.pm-user b,.pm-user small,
.review-card .li-txt h5,.review-card .li-txt p{
  overflow:hidden;text-overflow:ellipsis;word-break:break-word;
}
.li-txt{overflow:hidden;min-width:0}
.li-txt h5{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.li-txt p{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.rc-detail span{word-break:break-word;overflow-wrap:anywhere}
.verify-banner p{word-break:break-word;overflow-wrap:anywhere}
.dash-top .who h2{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash-top .who p{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ---- Ad card styling ---- */
.ad-card{border-color:rgba(20,184,166,.25)}
.ad-title{font-size:16px;font-weight:800;color:var(--text);display:flex;align-items:center;word-break:break-word}

/* ---- Modal overlay ---- */
.modal-overlay{
  position:fixed;inset:0;z-index:60;background:rgba(0,0,0,.7);
  display:flex;align-items:center;justify-content:center;padding:20px;
  backdrop-filter:blur(4px);
}
.modal-box{
  background:var(--bg);border:1px solid var(--line);border-radius:18px;
  width:100%;max-width:400px;max-height:90vh;overflow-y:auto;padding:20px;
}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.modal-head h3{font-size:18px;font-weight:800}
.modal-head button{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;
  background:var(--surface);border:1px solid var(--line);color:var(--text);font-size:16px}

/* ---- Portals item highlight in drawer ---- */
.portals-item{color:var(--teal)!important;font-weight:700!important;border:1px dashed rgba(20,184,166,.3);border-radius:10px;margin-bottom:4px}

/* ===========================================================================
   Doctor Registration Form Styles
   =========================================================================== */

/* ---- Registration sections ---- */
.reg-section{
  background:var(--surface);border:1px solid var(--line);border-radius:16px;
  padding:18px 16px;margin-bottom:14px;min-width:0;overflow:hidden;
}
.reg-section-title{
  font-size:16px;font-weight:800;margin-bottom:14px;color:var(--text);
}
.reg-section .field{margin-bottom:12px}
.reg-section .field:last-child{margin-bottom:0}
.reg-section .field label{display:flex;align-items:center;gap:4px}
.req{color:#ef4444;font-weight:800}

/* ---- Upload areas (photo + documents) ---- */
.upload-area{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:10px;cursor:pointer;
  border:2px dashed var(--line);border-radius:14px;padding:24px 16px;
  background:transparent;transition:border-color .15s,background .15s;
  text-align:center;
}
.upload-area:hover{border-color:var(--teal);background:rgba(20,184,166,.04)}
.upload-area.has-file{border-color:var(--teal);border-style:solid;background:rgba(20,184,166,.06)}
.upload-area-icon{
  font-size:32px;color:var(--muted);
}
.upload-area-icon img{border:2px solid var(--teal)}
.upload-area-text{font-size:13px;color:var(--muted);line-height:1.5}
.upload-area-text small{font-size:11px;opacity:.7}
.upload-area.doc-upload{
  flex-direction:column;padding:22px 16px;
}
.upload-area.doc-upload > i{font-size:22px;color:var(--muted)}
.upload-area.doc-upload.has-file > i{color:var(--teal)}
.upload-area.doc-upload span{font-size:12.5px;color:var(--muted);line-height:1.5}

/* ---- Pending block screen ---- */
.pending-block{animation:fadeInUp .4s ease}
.pending-icon{
  width:90px;height:90px;border-radius:50%;margin:0 auto;
  background:rgba(59,130,246,.14);color:var(--user);
  display:grid;place-items:center;font-size:36px;
  animation:pendingPulse 2s ease-in-out infinite;
}
@keyframes pendingPulse{
  0%,100%{transform:scale(1);opacity:1}
  50%{transform:scale(1.06);opacity:.8}
}
@keyframes fadeInUp{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}

/* ===========================================================================
   RESPONSIVE: Desktop / Laptop (min-width: 768px)
   =========================================================================== */
@media (min-width: 768px) {
  /* Expand portal container */
  #portal-root {
    max-width: 860px;
    border-left: 1px solid var(--line);
    border-right: 1px solid var(--line);
    box-shadow: 0 0 80px rgba(0,0,0,.4);
  }

  /* Portal grid — keep 2 cols but bigger */
  .portal-grid { gap: 18px; padding: 28px 30px 10px; }
  .portal-card { padding: 24px 20px; }

  /* Auth form wider */
  .auth-form { padding: 22px 30px 0; max-width: 540px; margin: 0 auto; }

  /* Dashboard top more spacious */
  .dash-top { padding: 28px 30px 22px; }

  /* Stats — 4 cols on desktop */
  .stat-grid { grid-template-columns: 1fr 1fr 1fr 1fr; padding: 22px 30px 8px; }

  /* Panel wider */
  .panel { padding: 24px 30px 8px; }

  /* Feature grid 2 cols */
  .feature-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

  /* Drawer wider */
  .pm-drawer { width: 380px; max-width: 380px; }

  /* Review cards 2-col layout */
  .panel .review-card { max-width: 100%; }

  /* Two-col fields — keep side by side with more gap */
  .two-col { gap: 16px; }

  /* Auth head center on desktop */
  .auth-head { padding: 12px 30px 8px; text-align: center; }
  .hero-head { max-width: 600px; margin: 0 auto; }

  /* Registration form comfortable */
  .reg-section { padding: 22px 20px; }

  /* Modal centered on desktop */
  .modal-overlay { align-items: center; }
  .modal-box { border-radius: 20px; }

  /* Verify banner wider */
  .verify-banner { margin: 8px 30px 14px; }

  /* Top bar wider */
  .pbar { padding: 16px 24px; }

  /* List items hover effect */
  .list-item { transition: border-color .15s; cursor: default; }
  .list-item:hover { border-color: rgba(20,184,166,.3); }
  .feature-card:hover { border-color: rgba(20,184,166,.3); }
}

/* ===========================================================================
   RESPONSIVE: Large Desktop (min-width: 1200px)
   =========================================================================== */
@media (min-width: 1200px) {
  #portal-root {
    max-width: 1080px;
  }

  /* Portal grid 4 cols on large screens */
  .portal-grid { grid-template-columns: 1fr 1fr 1fr 1fr; padding: 32px 36px 12px; }

  /* Stat grid spacious */
  .stat-grid { padding: 24px 36px 10px; gap: 16px; }

  /* Panel spacious */
  .panel { padding: 28px 36px 10px; }

  /* Feature grid 3 cols */
  .feature-grid { grid-template-columns: 1fr 1fr 1fr; }

  /* Auth form stays centered */
  .auth-form { max-width: 560px; }

  /* Dash top wider */
  .dash-top { padding: 30px 36px 24px; }

  /* Back button wider */
  .scr-back { margin: 16px 36px 0; }
  .verify-banner { margin: 10px 36px 16px; }
}

/* ===========================================================================
   Pharmacy Portal — Checkbox & additional styles
   =========================================================================== */
.pharm-checkbox{
  display:flex;align-items:center;gap:12px;cursor:pointer;
  font-size:14px;font-weight:600;color:var(--text);
  padding:13px 15px;background:var(--surface);border:1px solid var(--line);
  border-radius:13px;transition:border-color .15s;
}
.pharm-checkbox:hover{border-color:var(--pharmacy)}
.pharm-checkbox input[type="checkbox"]{
  width:20px;height:20px;accent-color:var(--pharmacy);cursor:pointer;
  border-radius:6px;
}
.pharm-checkbox span:last-child{flex:1}
.role-pharmacy .feature-card>i:first-child{background:rgba(16,185,129,.16);color:var(--pharmacy)}

/* ===========================================================================
   Global Loading Overlay
   =========================================================================== */
.loading-overlay{
  position:fixed;top:0;left:0;right:0;bottom:0;z-index:10000;
  background:rgba(8,16,23,.85);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .25s ease;
}
.loading-overlay.show{opacity:1;pointer-events:auto}
.loading-content{text-align:center}
.loading-spinner{
  position:relative;width:70px;height:70px;margin:0 auto 18px;
}
.spinner-ring{
  position:absolute;inset:0;
  border:3.5px solid rgba(20,184,166,.15);border-top-color:var(--teal);
  border-radius:50%;animation:spin-ring 1s cubic-bezier(.5,.1,.5,.9) infinite;
}
@keyframes spin-ring{to{transform:rotate(360deg)}}
.loading-icon{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-size:24px;color:var(--teal);animation:pulse-icon 1.5s ease-in-out infinite;
}
@keyframes pulse-icon{0%,100%{opacity:.7;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.15)}}
.loading-text{
  font-size:14px;font-weight:600;color:rgba(255,255,255,.8);
  letter-spacing:.5px;
}

/* ===========================================================================
   Enhanced Admin Pharmacy Panel
   =========================================================================== */
.panel-head-row{
  display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;
}
.panel-head-row h4{margin:0;display:flex;align-items:center}
.count-badge{
  font-size:12px;font-weight:700;padding:4px 12px;border-radius:20px;
  background:rgba(20,184,166,.15);color:var(--teal);
}

/* Filter bar */
.filter-bar{
  display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px;
  padding-bottom:14px;border-bottom:1px solid var(--line);
}
.filter-btn{
  display:inline-flex;align-items:center;gap:5px;
  padding:7px 12px;border-radius:20px;font-size:12px;font-weight:600;
  background:var(--surface);color:var(--muted);
  border:1px solid var(--line);cursor:pointer;transition:all .15s;
}
.filter-btn i{font-size:11px}
.filter-btn em{
  font-style:normal;background:rgba(255,255,255,.06);
  padding:1px 6px;border-radius:10px;font-size:11px;
}
.filter-btn:hover{border-color:var(--teal);color:var(--teal)}
.filter-btn.active{
  background:rgba(20,184,166,.15);color:var(--teal);border-color:var(--teal);
}
.filter-btn.active em{background:rgba(20,184,166,.25)}

/* Pharmacy review card */
.pharm-review-card{margin-bottom:16px}
.pharm-review-card .rc-head{gap:10px}
.pharm-review-card .detail-grid{
  display:grid;grid-template-columns:1fr;gap:6px;
}
@media(min-width:380px){
  .pharm-review-card .detail-grid{grid-template-columns:1fr 1fr}
}
.pharm-review-card .detail-grid span{
  display:flex;align-items:flex-start;gap:2px;font-size:12px;color:var(--muted);line-height:1.5;
}
.pharm-review-card .detail-grid span b{color:var(--text);margin-right:4px;white-space:nowrap}

/* Admin note banner */
.admin-note-banner{
  background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.2);
  border-radius:10px;padding:8px 12px;margin:6px 0 8px;
  font-size:12px;color:#fbbf24;line-height:1.5;
}
.admin-note-banner i{margin-right:6px;color:#f59e0b}

/* Missing doc chip */
.doc-chip.missing{
  background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);
  color:#fca5a5;cursor:default;
}
.doc-chip.missing:hover{background:rgba(239,68,68,.12)}

/* Pharmacy action buttons */
.pharm-actions{
  display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;padding-top:10px;
  border-top:1px solid var(--line);
}
.action-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 16px;border-radius:10px;font-size:12px;font-weight:700;
  border:none;cursor:pointer;transition:all .15s;
}
.action-btn i{font-size:13px}
.action-btn.approve{background:rgba(34,197,94,.15);color:#22c55e}
.action-btn.approve:hover{background:rgba(34,197,94,.25)}
.action-btn.reject{background:rgba(239,68,68,.12);color:#ef4444}
.action-btn.reject:hover{background:rgba(239,68,68,.22)}
.action-btn.info{background:rgba(59,130,246,.12);color:#3b82f6}
.action-btn.info:hover{background:rgba(59,130,246,.22)}
.action-btn.suspend{background:rgba(245,158,11,.12);color:#f59e0b}
.action-btn.suspend:hover{background:rgba(245,158,11,.22)}

/* ===== Hospital / Clinic Portal ===== */
.pc-hospital .pc-ico{background:rgba(6,182,212,.16);color:var(--hospital)}
.pc-hospital .pc-go{color:var(--hospital)} .pc-hospital .glow{background:var(--hospital)}
.role-hospital{--accent:var(--hospital)}
.role-chip.hospital{background:rgba(6,182,212,.16);color:var(--hospital)}
.accent-hospital{background:rgba(6,182,212,.16);color:var(--hospital)}
.role-hospital .feature-card>i:first-child{background:rgba(6,182,212,.16);color:var(--hospital)}

/* Laboratory portal accents */
.pc-lab .pc-ico{background:rgba(99,102,241,.16);color:var(--lab)}
.pc-lab .pc-go{color:var(--lab)} .pc-lab .glow{background:var(--lab)}
.role-lab{--accent:var(--lab)}
.role-chip.lab{background:rgba(99,102,241,.16);color:var(--lab)}
.accent-lab{background:rgba(99,102,241,.16);color:var(--lab)}
.role-lab .feature-card>i:first-child{background:rgba(99,102,241,.16);color:var(--lab)}
.role-lab .svc-opt:hover{border-color:var(--lab)}
.role-lab .svc-opt.on{border-color:var(--lab);background:rgba(99,102,241,.08)}
.role-lab .svc-opt.on .svc-radio i{color:var(--lab)}

/* Radiology portal accents */
.pc-radiology .pc-ico{background:rgba(168,85,247,.16);color:var(--radiology)}
.pc-radiology .pc-go{color:var(--radiology)} .pc-radiology .glow{background:var(--radiology)}
.role-radiology{--accent:var(--radiology)}
.role-chip.radiology{background:rgba(168,85,247,.16);color:var(--radiology)}
.accent-radiology{background:rgba(168,85,247,.16);color:var(--radiology)}
.role-radiology .feature-card>i:first-child{background:rgba(168,85,247,.16);color:var(--radiology)}
.role-radiology .svc-opt:hover{border-color:var(--radiology)}
.role-radiology .svc-opt.on{border-color:var(--radiology);background:rgba(168,85,247,.08)}
.role-radiology .svc-opt.on .svc-radio i{color:var(--radiology)}

/* Surgical items store accents */
.pc-surgical .pc-ico{background:rgba(20,184,166,.16);color:var(--surgical)}
.pc-surgical .pc-go{color:var(--surgical)} .pc-surgical .glow{background:var(--surgical)}
.role-surgical{--accent:var(--surgical)}
.role-chip.surgical{background:rgba(20,184,166,.16);color:var(--surgical)}
.accent-surgical{background:rgba(20,184,166,.16);color:var(--surgical)}
.role-surgical .feature-card>i:first-child{background:rgba(20,184,166,.16);color:var(--surgical)}
.role-surgical .svc-opt:hover{border-color:var(--surgical)}
.role-surgical .svc-opt.on{border-color:var(--surgical);background:rgba(20,184,166,.08)}
.role-surgical .svc-opt.on .svc-radio i{color:var(--surgical)}
.pc-ambulance .pc-ico{background:rgba(239,68,68,.16);color:var(--ambulance)}
.pc-ambulance .pc-go{color:var(--ambulance)} .pc-ambulance .glow{background:var(--ambulance)}
.role-ambulance{--accent:var(--ambulance)}
.role-chip.ambulance{background:rgba(239,68,68,.16);color:var(--ambulance)}
.accent-ambulance{background:rgba(239,68,68,.16);color:var(--ambulance)}
.role-ambulance .feature-card>i:first-child{background:rgba(239,68,68,.16);color:var(--ambulance)}
.role-ambulance .svc-opt:hover{border-color:var(--ambulance)}
.role-ambulance .svc-opt.on{border-color:var(--ambulance);background:rgba(239,68,68,.08)}
.role-ambulance .svc-opt.on .svc-radio i{color:var(--ambulance)}
.btn-add-square{width:52px;flex:0 0 52px;border:none;border-radius:14px;background:var(--teal,#14b8a6);color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:filter .15s}
.btn-add-square:hover{filter:brightness(1.08)}
.dept-chip .fa-xmark:hover{color:#ef4444}

/* Department chips & add row */
.dept-add-row{display:flex;gap:8px;align-items:stretch;margin-bottom:12px}
.dept-add-btn{
  background:var(--teal-soft);color:var(--teal);border:1px solid rgba(20,184,166,.3);
  border-radius:12px;padding:0 20px;font-weight:700;font-size:14px;cursor:pointer;white-space:nowrap;
}
.dept-add-btn:hover{background:var(--teal);color:#04201d}
.dept-chips{display:flex;flex-wrap:wrap;gap:8px}
.dept-chip{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--teal-soft);color:var(--teal);
  padding:7px 12px;border-radius:20px;font-size:13px;font-weight:600;
}
.dept-chip i{cursor:pointer;opacity:.7;font-size:12px}
.dept-chip i:hover{opacity:1;color:#ef4444}
.dept-chip.readonly{background:rgba(6,182,212,.12);color:var(--hospital)}

/* ===========================================================================
   Nearby Hospitals — public room booking page (matches mobile screenshots)
   =========================================================================== */
.nh-screen{flex:1;display:flex;flex-direction:column;padding-bottom:96px;background:var(--bg)}

/* Top brand bar */
.nh-topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 18px 14px;background:#060c11;border-bottom:1px solid var(--line);
}
.nh-brandwrap{display:flex;align-items:center;gap:12px}
.nh-caduceus{font-size:26px;color:#9fb3bd}
.nh-brandwrap h1{font-size:18px;font-weight:800;line-height:1.15;color:#fff}
.nh-topactions{display:flex;align-items:center;gap:10px}
.nh-iconbtn{
  width:38px;height:38px;border-radius:10px;border:none;background:transparent;
  color:#cfe0e6;font-size:18px;display:grid;place-items:center;cursor:pointer;
}
.nh-iconbtn:hover{background:var(--surface)}

/* Sub header (Nearby Hospitals + refresh) */
.nh-search-area{display:flex;align-items:center;gap:14px;padding:18px 18px 6px}
.nh-subback,.nh-refresh{
  width:36px;height:36px;border-radius:10px;border:none;background:transparent;
  color:#cfe0e6;font-size:17px;display:grid;place-items:center;cursor:pointer;flex-shrink:0;
}
.nh-subback:hover,.nh-refresh:hover{background:var(--surface)}
.nh-subhead{flex:1}
.nh-subhead h2{font-size:21px;font-weight:800;color:#fff;line-height:1.2}
.nh-subhead p{font-size:13px;color:var(--muted);margin-top:2px}

/* Controls: search + buttons + radius */
.nh-controls{padding:6px 18px 14px;display:flex;flex-direction:column;gap:12px;border-bottom:1px solid var(--line)}
.nh-searchbox{
  display:flex;align-items:center;gap:10px;background:var(--surface);
  border:1px solid var(--line);border-radius:12px;padding:13px 15px;
}
.nh-searchbox i{color:var(--muted);font-size:15px}
.nh-searchbox input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:14.5px}
.nh-searchbox input::placeholder{color:#6b818c}
.nh-btnrow{display:flex;gap:12px}
.nh-pillbtn{
  flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  background:var(--surface);border:1px solid var(--line);color:#dce8ec;
  padding:13px 12px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;
}
.nh-pillbtn:hover{background:var(--surface-2);border-color:var(--teal)}
.nh-radius{
  align-self:flex-start;background:var(--surface);border:1px solid var(--line);color:var(--text);
  padding:11px 16px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;min-width:110px;
}

/* Hospital cards grid */
.nh-grid{padding:16px 18px;display:flex;flex-direction:column;gap:18px}
.nh-loading,.nh-empty{text-align:center;color:var(--muted);padding:50px 16px}
.nh-empty i{font-size:42px;color:var(--line);margin-bottom:12px;display:block}
.nh-loading i{margin-right:8px}

.nh-card{
  background:linear-gradient(160deg,#0e1c25,#0b1620);border:1px solid var(--line);
  border-radius:16px;overflow:hidden;cursor:pointer;transition:border-color .15s,transform .15s;
}
.nh-card:hover{border-color:var(--teal);transform:translateY(-2px)}
.nh-card-img{
  height:150px;background:linear-gradient(160deg,#11313a,#0c2129);
  display:grid;place-items:center;position:relative;
}
.nh-card-img>i{font-size:54px;color:rgba(20,184,166,.55)}
.nh-fav{
  position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.92);border:none;color:#b9c6cc;font-size:15px;cursor:pointer;
  display:grid;place-items:center;
}
.nh-fav.on{color:#ef4444}
.nh-card-body{padding:16px}
.nh-card-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.nh-card-name h3{font-size:17px;font-weight:800;color:#fff;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.nh-verified{color:#22c55e;font-size:14px}
.nh-card-name p{font-size:12.5px;color:var(--muted);margin-top:5px}
.nh-card-name p i{color:var(--muted);margin-right:4px}
.nh-card-rate{text-align:right;flex-shrink:0}
.nh-star{display:block;font-size:15px;font-weight:800;color:#f5b301}
.nh-star i{font-size:13px;margin-right:2px}
.nh-er{display:block;font-size:11.5px;font-weight:700;color:#ef4444;margin-top:3px}
.nh-tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px}
.nh-tag{
  background:rgba(255,255,255,.05);border:1px solid var(--line);color:#c3d2d8;
  padding:5px 11px;border-radius:16px;font-size:12px;font-weight:500;
}
.nh-tag-more{color:var(--muted)}
.nh-tags-big .nh-tag{background:var(--teal-soft);border-color:transparent;color:var(--teal);padding:7px 14px;font-size:13px}
.nh-card-foot{display:flex;justify-content:space-between;align-items:center;margin-top:14px}
.nh-beds{font-size:13px;color:#c3d2d8}
.nh-beds i{color:var(--muted);margin-right:6px}
.nh-bookbtn{font-size:14px;font-weight:700;color:var(--teal)}
.nh-bookbtn i{margin-left:5px}
.nh-dist{display:inline-block;margin-top:10px;font-size:12px;color:var(--teal)}
.nh-dist i{margin-right:5px}

/* Bottom nav */
.nh-bottomnav{
  position:fixed;left:50%;transform:translateX(-50%);bottom:0;width:100%;max-width:440px;
  display:flex;justify-content:space-around;background:#060c11;border-top:1px solid var(--line);
  padding:8px 4px 10px;z-index:40;
}
.nh-navitem{
  display:flex;flex-direction:column;align-items:center;gap:4px;background:none;border:none;
  color:var(--muted);font-size:11px;cursor:pointer;flex:1;padding:4px 0;
}
.nh-navitem i{font-size:18px}
.nh-navitem.active{color:var(--teal)}

/* Detail / Book modal sheet */
.nh-modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:60;display:flex;align-items:flex-end;
  justify-content:center;opacity:0;transition:opacity .2s;
}
.nh-modal-overlay.show{opacity:1}
.nh-sheet{
  width:100%;max-width:440px;background:#0a141b;border:1px solid var(--line);
  border-radius:22px 22px 0 0;max-height:88vh;display:flex;flex-direction:column;
  transform:translateY(20px);transition:transform .25s;
}
.nh-modal-overlay.show .nh-sheet{transform:translateY(0)}
.nh-sheet-head{
  display:flex;justify-content:space-between;align-items:flex-start;gap:12px;
  padding:22px 22px 16px;border-bottom:1px solid var(--line);
}
.nh-sheet-head h2{font-size:22px;font-weight:800;color:#fff;display:flex;align-items:center;gap:7px}
.nh-sheet-head p{font-size:13px;color:var(--muted);margin-top:4px}
.nh-sheet-close{
  width:34px;height:34px;border-radius:9px;border:none;background:var(--surface);
  color:#cfe0e6;font-size:17px;cursor:pointer;flex-shrink:0;
}
.nh-sheet-scroll{overflow-y:auto;padding:18px 22px 28px}

/* Detail stat grid */
.nh-statgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.nh-stat{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px}
.nh-stat-er{background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.25)}
.nh-stat-top{display:flex;align-items:center;gap:8px;font-size:19px;color:#fff}
.nh-stat-top b{font-size:19px}
.nh-stat small{display:block;color:var(--muted);font-size:12.5px;margin-top:6px}
.nh-sec-title{font-size:17px;font-weight:800;color:#fff;margin:22px 0 12px}
.nh-muted{color:var(--muted)}

/* Rooms list */
.nh-rooms{display:flex;flex-direction:column;gap:12px}
.nh-room{
  display:flex;align-items:center;gap:12px;background:var(--surface);
  border:1px solid var(--line);border-radius:14px;padding:16px;
}
.nh-room-info{flex:1}
.nh-room-info h5{font-size:16px;font-weight:700;color:#fff}
.nh-room-info p{font-size:12.5px;color:var(--muted);margin-top:3px}
.nh-room-avail{font-size:13px;font-weight:600;color:#22c55e;white-space:nowrap}
.nh-room-avail.out{color:var(--muted)}
.nh-room-book{
  background:var(--teal);color:#04201d;border:none;padding:10px 22px;border-radius:11px;
  font-size:14px;font-weight:700;cursor:pointer;
}
.nh-room-book:disabled{background:var(--line);color:var(--muted);cursor:not-allowed}
.nh-room-book:hover:not(:disabled){background:var(--teal-dark)}

/* Booking form */
.nh-form{display:flex;flex-direction:column;gap:18px}
.nh-field label{display:block;font-size:14px;font-weight:600;color:#dce8ec;margin-bottom:8px}
.nh-field label span{color:#ef4444}
.nh-field input,.nh-field textarea{
  width:100%;background:var(--surface);border:1px solid var(--line);border-radius:12px;
  padding:13px 15px;color:var(--text);font-size:14.5px;font-family:inherit;outline:none;
}
.nh-field input:focus,.nh-field textarea:focus{border-color:var(--teal)}
.nh-field input::placeholder,.nh-field textarea::placeholder{color:#6b818c}
.nh-field textarea{resize:vertical}
.nh-summary{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px}
.nh-summary h4{font-size:16px;font-weight:800;color:#fff;margin-bottom:14px}
.nh-sum-row{display:flex;justify-content:space-between;margin-bottom:10px;font-size:14px}
.nh-sum-row span{color:var(--muted)}
.nh-sum-row b{color:#fff;font-weight:600;text-align:right}
.nh-submit{
  background:var(--teal);color:#04201d;border:none;padding:15px;border-radius:13px;
  font-size:15px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;
}
.nh-submit:hover{background:var(--teal-dark)}

/* My bookings cards */
.nh-bk-card{background:linear-gradient(160deg,#0e1c25,#0b1620);border:1px solid var(--line);border-radius:14px;padding:16px}
.nh-bk-top{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px}
.nh-bk-top h3{font-size:16px;font-weight:700;color:#fff}
.nh-status{font-size:11.5px;font-weight:700;padding:4px 11px;border-radius:14px}
.nh-pending{background:rgba(245,179,1,.15);color:#f5b301}
.nh-confirmed{background:rgba(34,197,94,.15);color:#22c55e}
.nh-cancelled{background:rgba(239,68,68,.15);color:#ef4444}
.nh-bk-rows{display:flex;flex-direction:column;gap:8px}
.nh-bk-rows span{font-size:13px;color:#c3d2d8}
.nh-bk-rows span i{margin-right:8px}

/* ===== Nurse — Services Offered grid ===== */
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.svc-opt{
  display:flex;align-items:center;gap:10px;cursor:pointer;
  padding:12px 12px;border:1px solid var(--line);border-radius:12px;
  background:rgba(255,255,255,.02);font-size:14px;color:var(--text);
  user-select:none;transition:.15s;line-height:1.25;
}
.svc-opt:hover{border-color:var(--nurse)}
.svc-opt.on{border-color:var(--nurse);background:rgba(168,85,247,.08)}
.svc-opt .svc-radio i{font-size:18px;color:var(--muted)}
.svc-opt.on .svc-radio i{color:var(--nurse)}
@media (max-width:360px){.svc-grid{grid-template-columns:1fr}}

/* ===========================================================================
   Find a Nurse — redesigned listing (matches mobile mockups)
   =========================================================================== */
.nurse-find{padding:0 0 24px}
.nf-topbar{display:flex;align-items:center;gap:14px;padding:18px 18px 14px}
.nf-back{
  width:40px;height:40px;border-radius:12px;border:1px solid var(--line);
  background:rgba(255,255,255,.03);color:#fff;font-size:16px;cursor:pointer;
  display:grid;place-items:center;flex-shrink:0;
}
.nf-back:hover{border-color:var(--nurse)}
.nf-title h1{font-size:21px;font-weight:800;color:#fff;line-height:1.2}
.nf-title p{font-size:13px;color:var(--muted);margin-top:2px}
.nf-body{padding:0 18px}

/* Search */
.nf-search{
  display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.04);
  border:1px solid var(--line);border-radius:14px;padding:13px 15px;margin-bottom:12px;
}
.nf-search i{color:var(--muted);font-size:15px}
.nf-search input{flex:1;background:none;border:none;outline:none;color:#fff;font-size:14.5px}
.nf-search input::placeholder{color:var(--muted)}

/* Filters */
.nf-filters{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}
.nf-select{position:relative;flex:1;min-width:96px}
.nf-select select{
  width:100%;appearance:none;background:rgba(255,255,255,.04);
  border:1px solid var(--line);border-radius:13px;padding:11px 32px 11px 14px;
  color:#fff;font-size:14px;cursor:pointer;
}
.nf-select i{position:absolute;right:13px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:11px;pointer-events:none}
.nf-ai-btn{
  display:flex;align-items:center;gap:7px;background:rgba(255,255,255,.04);
  border:1px solid var(--line);border-radius:13px;padding:11px 16px;color:#fff;
  font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;
}
.nf-ai-btn i{color:var(--nurse)}
.nf-ai-btn.on{border-color:var(--nurse);background:rgba(168,85,247,.14)}

/* Sections */
.nf-section{margin-bottom:22px}
.nf-section-title{font-size:18px;font-weight:800;color:#fff;margin-bottom:12px}

/* Care packages */
.care-pkg-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:6px;scrollbar-width:none}
.care-pkg-scroll::-webkit-scrollbar{display:none}
.care-pkg{
  flex:0 0 auto;min-width:172px;background:rgba(255,255,255,.03);
  border:1px solid var(--line);border-radius:16px;padding:18px 18px 16px;
}
.care-pkg-dot{display:block;width:34px;height:34px;border-radius:50%;margin-bottom:14px}
.care-pkg h4{font-size:18px;font-weight:800;color:#fff;margin-bottom:6px}
.care-pkg-price{font-size:19px;font-weight:800;color:var(--teal);margin-bottom:6px}
.care-pkg p{font-size:12.5px;color:var(--muted)}

/* Service type */
.svc-type-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:6px;scrollbar-width:none}
.svc-type-scroll::-webkit-scrollbar{display:none}
.svc-type-card{
  flex:0 0 auto;width:84px;background:rgba(255,255,255,.03);border:1px solid var(--line);
  border-radius:16px;padding:16px 8px;display:flex;flex-direction:column;align-items:center;
  gap:9px;cursor:pointer;transition:.15s;
}
.svc-type-card:hover{border-color:var(--teal)}
.svc-type-emoji{font-size:26px;line-height:1}
.svc-type-label{font-size:12.5px;font-weight:600;color:#e6eef0;text-align:center;line-height:1.25}

/* Available head */
.nf-avail-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.nf-map-btn{
  display:flex;align-items:center;gap:7px;background:none;border:none;color:#e6eef0;
  font-size:14px;font-weight:600;cursor:pointer;
}
.nf-map-btn i{color:#fff}

/* Nurse cards */
.nurse-cards{display:flex;flex-direction:column;gap:14px}
.nurse-card{
  background:rgba(255,255,255,.025);border:1px solid var(--line);
  border-radius:18px;padding:16px;transition:.15s;
}
.nurse-card:first-child{border-color:rgba(20,184,166,.45)}
.nurse-card:hover{border-color:var(--teal)}
.nc-top{display:flex;align-items:flex-start;gap:13px}
.nc-avatar{position:relative;width:52px;height:52px;flex-shrink:0}
.nc-avatar img{width:52px;height:52px;border-radius:14px;object-fit:cover}
.nc-avatar > i{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;background:var(--teal-soft);color:var(--teal);font-size:22px}
.nc-verified{
  position:absolute;right:-4px;top:-4px;background:var(--bg);border-radius:50%;
  color:#3b82f6;font-size:16px;line-height:1;
}
.nc-info{flex:1;min-width:0}
.nc-info h4{font-size:17px;font-weight:800;color:#fff;line-height:1.2}
.nc-specialty{font-size:13.5px;color:var(--muted);margin-top:2px}
.nc-meta{font-size:12.5px;color:#aab8bd;margin-top:6px;display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.nc-meta i{color:var(--muted)}
.nc-dot{color:var(--muted)}
.nc-rating{display:flex;align-items:center;gap:5px;font-size:14.5px;font-weight:800;color:#fff;white-space:nowrap}
.nc-rating i{color:#fbbf24;font-size:14px}
.nc-rating span{color:var(--muted);font-weight:600;font-size:13px}

.nc-skills{display:flex;flex-wrap:wrap;gap:8px;margin-top:13px}
.nc-skill{
  background:rgba(255,255,255,.06);border:1px solid var(--line);
  border-radius:10px;padding:6px 12px;font-size:12.5px;font-weight:600;color:#dbe6e8;
}
.nc-skill-more{background:rgba(255,255,255,.03);color:var(--muted)}

.nc-bottom{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:14px}
.nc-rate{display:flex;align-items:center;gap:9px}
.nc-online{width:11px;height:11px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.18)}
.nc-online.off{background:#6b7280;box-shadow:0 0 0 3px rgba(107,114,128,.18)}
.nc-rate-val{font-size:19px;font-weight:800;color:var(--teal)}
.nc-actions{display:flex;align-items:center;gap:9px}
.nc-icon-btn{
  width:42px;height:42px;border-radius:13px;border:1px solid var(--line);
  background:rgba(255,255,255,.04);color:#fff;font-size:15px;cursor:pointer;
  display:grid;place-items:center;transition:.15s;
}
.nc-icon-btn:hover{border-color:var(--teal);color:var(--teal)}
.nc-book-btn{
  background:var(--teal);color:#04201d;border:none;border-radius:13px;
  padding:11px 20px;font-size:14.5px;font-weight:800;cursor:pointer;white-space:nowrap;
}
.nc-book-btn:hover{background:var(--teal-dark)}


/* === SURGICAL STORE MANAGEMENT === */
.li-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.li-stat{background:rgba(20,184,166,.08);border:1px solid rgba(20,184,166,.18);border-radius:14px;padding:12px 6px;text-align:center}
.li-stat .s-val{font-size:20px;font-weight:800;color:var(--surgical,#14b8a6);line-height:1}
.li-stat .s-lbl{font-size:11px;color:var(--muted);margin-top:5px}

.surg-mgmt-list{display:flex;flex-direction:column;gap:10px}
.surg-mgmt-card{display:flex;align-items:center;gap:12px;background:var(--card,#10151f);border:1px solid rgba(148,163,184,.14);border-radius:14px;padding:12px}
.surg-mgmt-icon{width:44px;height:44px;flex:0 0 44px;display:flex;align-items:center;justify-content:center;font-size:22px;background:rgba(20,184,166,.10);border-radius:12px}
.surg-mgmt-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.surg-mgmt-info b{font-size:14px}
.surg-mgmt-info small{font-size:11.5px;color:var(--muted)}
.surg-mgmt-actions{display:flex;gap:8px}
.surg-mgmt-actions button{width:34px;height:34px;border:none;border-radius:10px;background:rgba(148,163,184,.12);color:#cbd5e1;cursor:pointer;transition:filter .15s}
.surg-mgmt-actions button:hover{filter:brightness(1.2)}
.surg-mgmt-actions button.danger{background:rgba(239,68,68,.14);color:#f87171}

.surg-order-card{background:var(--card,#10151f);border:1px solid rgba(148,163,184,.14);border-radius:14px;padding:12px}
.surg-order-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.surg-order-top b{font-size:14px}
.surg-order-items{font-size:12.5px;color:#cbd5e1;margin:8px 0}
.surg-order-bot{display:flex;justify-content:space-between;align-items:center;gap:10px}
.surg-status-select{background:#0b0f17;border:1px solid rgba(148,163,184,.22);color:#e5e7eb;border-radius:9px;padding:6px 8px;font-size:12px;text-transform:capitalize}
.surg-status-pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;text-transform:capitalize}
.surg-status-pill.st-pending{background:rgba(245,158,11,.16);color:#fbbf24}
.surg-status-pill.st-confirmed{background:rgba(59,130,246,.16);color:#60a5fa}
.surg-status-pill.st-processing{background:rgba(168,85,247,.16);color:#c084fc}
.surg-status-pill.st-shipped{background:rgba(14,165,233,.16);color:#38bdf8}
.surg-status-pill.st-delivered{background:rgba(16,185,129,.16);color:#34d399}
.surg-status-pill.st-cancelled{background:rgba(239,68,68,.16);color:#f87171}

.btn-secondary{border:1px solid rgba(148,163,184,.25);background:transparent;color:#cbd5e1;border-radius:12px;padding:12px;font-weight:700;cursor:pointer;font-size:14px}
.btn-secondary:hover{background:rgba(148,163,184,.10)}


/* ========== Admin Entity Cards (Surgical Stores, etc.) ========== */
.admin-entity-card {
  background: var(--surface, #111827);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: 16px;
  margin-bottom: 12px;
}
.ae-top {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 10px;
}
.ae-photo {
  width: 56px;
  height: 56px;
  border-radius: 12px;
  object-fit: cover;
  flex-shrink: 0;
}
.ae-photo--placeholder {
  display: flex; align-items: center; justify-content: center;
  background: rgba(124,58,237,0.15);
  color: #7c3aed;
  font-size: 20px;
}
.ae-info {
  flex: 1;
  min-width: 0;
}
.ae-info b {
  display: block;
  font-size: 15px;
  color: #f1f5f9;
  margin-bottom: 3px;
}
.ae-info small {
  display: block;
  color: #9ca3af;
  font-size: 12px;
  line-height: 1.5;
}
.ae-docs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}
.ae-doc-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  background: rgba(124,58,237,0.12);
  color: #a78bfa;
  border-radius: 8px;
  font-size: 11px;
  text-decoration: none;
  transition: background 0.2s;
}
.ae-doc-link:hover { background: rgba(124,58,237,0.25); }
.ae-note {
  background: rgba(250,204,21,0.08);
  border: 1px solid rgba(250,204,21,0.2);
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 12px;
  color: #fbbf24;
  margin-bottom: 10px;
}
.ae-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.btn-small {
  padding: 6px 12px;
  border-radius: 8px;
  border: none;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  transition: all 0.2s;
}
.btn-approve { background: rgba(16,185,129,0.15); color: #10b981; }
.btn-approve:hover { background: rgba(16,185,129,0.3); }
.btn-reject { background: rgba(239,68,68,0.15); color: #ef4444; }
.btn-reject:hover { background: rgba(239,68,68,0.3); }
.btn-info { background: rgba(59,130,246,0.15); color: #3b82f6; }
.btn-info:hover { background: rgba(59,130,246,0.3); }
.ae-header {
  margin-bottom: 16px;
}
.ae-header h3 {
  font-size: 18px;
  color: #f1f5f9;
  margin: 0 0 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.ae-tabs {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.ae-tab {
  padding: 6px 14px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,0.1);
  background: transparent;
  color: #9ca3af;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
}
.ae-tab:hover { border-color: rgba(124,58,237,0.4); color: #a78bfa; }
.ae-tab.active { background: rgba(124,58,237,0.2); border-color: #7c3aed; color: #a78bfa; }
.ae-empty {
  text-align: center;
  padding: 40px 20px;
  color: #6b7280;
}
.ae-empty p {
  font-size: 14px;
}

/* Surgical status pills */
.surg-status-pill.st-confirmed { background: rgba(16,185,129,0.15); color: #10b981; }
.surg-status-pill.st-cancelled { background: rgba(239,68,68,0.15); color: #ef4444; }
.surg-status-pill.st-pending { background: rgba(250,204,21,0.15); color: #fbbf24; }


/* Portal Fee & Wallet Styles */
.portal-fees-admin { padding: 20px; }
.fee-tabs { display: flex; gap: 8px; margin-bottom: 20px; flex-wrap: wrap; }
.fee-tab { padding: 8px 16px; border: 1px solid var(--border); border-radius: 8px; background: var(--card-bg); cursor: pointer; font-size: 13px; transition: all .2s; }
.fee-tab.active { background: var(--accent); color: white; border-color: var(--accent); }
.fee-config-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; }
.fee-config-card { background: var(--card-bg); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; }
.fcc-header { display: flex; align-items: center; gap: 10px; padding: 14px 16px; background: linear-gradient(135deg, var(--accent-light) 0%, transparent 100%); border-bottom: 1px solid var(--border); }
.fcc-header i { font-size: 20px; color: var(--accent); }
.fcc-header h3 { flex: 1; margin: 0; font-size: 15px; }
.fcc-body { padding: 14px 16px; }
.fee-models { display: flex; gap: 8px; margin-bottom: 10px; }
.fee-model { flex: 1; padding: 10px; border: 1px solid var(--border); border-radius: 8px; text-align: center; font-size: 12px; }
.fee-model.selected { border-color: var(--accent); background: rgba(var(--accent-rgb), 0.05); }
.fee-model i { display: block; margin-bottom: 4px; color: var(--accent); }
.fee-model strong { display: block; font-size: 11px; }
.fee-amount { font-weight: 600; color: var(--accent); }
.fee-desc { font-size: 12px; color: var(--muted); margin: 0; }
.fcc-actions { padding: 10px 16px; border-top: 1px solid var(--border); text-align: right; }
.stats-grid-portal { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; }
.stats-grid-portal .stat-card { background: var(--card-bg); border: 1px solid var(--border); border-radius: 10px; padding: 16px; text-align: center; }
.stats-grid-portal .stat-card i { font-size: 24px; color: var(--accent); margin-bottom: 8px; display: block; }
.stats-grid-portal .stat-card h3 { margin: 4px 0; font-size: 18px; }
.stats-grid-portal .stat-card p { margin: 0; font-size: 12px; color: var(--muted); }
/* Portal Wallet Styles */
.portal-wallet-section { padding: 16px; }
.pw-balance-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; margin-bottom: 20px; }
.pw-balance-card { display: flex; align-items: center; gap: 12px; padding: 16px; background: var(--card-bg); border: 1px solid var(--border); border-radius: 12px; }
.pw-balance-card.main { background: linear-gradient(135deg, var(--accent), var(--accent-dark, #1a6e3a)); color: white; border: none; }
.pw-balance-card.main .pwb-label, .pw-balance-card.main .pwb-amount { color: white; }
.pwb-icon { font-size: 24px; opacity: 0.8; }
.pwb-label { display: block; font-size: 11px; color: var(--muted); text-transform: uppercase; }
.pwb-amount { display: block; font-size: 18px; font-weight: 700; }
.pw-fee-model-section { margin-bottom: 20px; padding: 16px; background: var(--card-bg); border: 1px solid var(--border); border-radius: 12px; }
.pw-fee-model-section h3 { margin: 0 0 12px; font-size: 14px; }
.fee-model-selector { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.fm-option { padding: 14px; border: 2px solid var(--border); border-radius: 10px; text-align: center; cursor: pointer; transition: all .2s; }
.fm-option.active { border-color: var(--accent); background: rgba(var(--accent-rgb), 0.05); }
.fm-option i { display: block; font-size: 24px; color: var(--accent); margin-bottom: 6px; }
.fm-option strong { display: block; margin-bottom: 4px; }
.fm-option span { display: block; font-size: 13px; font-weight: 600; color: var(--accent); }
.fm-option small { display: block; font-size: 11px; color: var(--muted); margin-top: 4px; }
.pw-tabs { display: flex; gap: 6px; margin-bottom: 16px; flex-wrap: wrap; }
.pw-tab { padding: 7px 14px; border: 1px solid var(--border); border-radius: 8px; background: var(--card-bg); cursor: pointer; font-size: 12px; transition: all .2s; }
.pw-tab.active { background: var(--accent); color: white; border-color: var(--accent); }
.txn-list { display: flex; flex-direction: column; gap: 8px; }
.txn-item { display: flex; align-items: center; gap: 12px; padding: 12px; background: var(--card-bg); border: 1px solid var(--border); border-radius: 8px; }
.txn-icon { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 14px; }
.txn-earning .txn-icon { background: #d4edda; color: #155724; }
.txn-withdrawal .txn-icon { background: #fff3cd; color: #856404; }
.txn-fee_deduction .txn-icon { background: #f8d7da; color: #721c24; }
.txn-monthly_fee .txn-icon { background: #d1ecf1; color: #0c5460; }
.txn-info { flex: 1; }
.txn-info strong { display: block; font-size: 13px; }
.txn-info small { color: var(--muted); font-size: 11px; }
.txn-amount { text-align: right; font-weight: 600; font-size: 14px; }
.txn-amount.positive { color: #28a745; }
.txn-amount.negative { color: #dc3545; }
.txn-amount .fee-note { font-size: 10px; color: #dc3545; font-weight: normal; }
.txn-status { text-align: right; }
.pending-fees { margin: 12px 0; }
.fee-item { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; background: var(--card-bg); border: 1px solid #ffc107; border-radius: 8px; margin-bottom: 8px; }
.fee-item .fee-info { display: flex; gap: 16px; align-items: center; }
.modal-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.5); display: flex; align-items: center; justify-content: center; z-index: 9999; }
.modal-content { background: var(--card-bg, #fff); border-radius: 12px; padding: 24px; max-width: 420px; width: 90%; max-height: 80vh; overflow-y: auto; }
.modal-content h3 { margin: 0 0 16px; }
.modal-actions { display: flex; gap: 10px; margin-top: 16px; justify-content: flex-end; }

/* ===== Admin Enhanced Styles ===== */
.mini-stat { background: #f8fafc; border-radius: 10px; padding: 14px 10px; text-align: center; border: 1px solid #e2e8f0; transition: all 0.2s; }
.mini-stat:hover { background: #eef2ff; border-color: #818cf8; transform: translateY(-2px); }
.mini-stat .ms-val { display: block; font-size: 20px; font-weight: 700; color: #1e293b; }
.mini-stat .ms-lbl { display: block; font-size: 11px; color: #64748b; margin-top: 4px; }
.badge-portal { display: inline-block; padding: 2px 8px; border-radius: 12px; font-size: 11px; font-weight: 600; background: #e0e7ff; color: #3730a3; text-transform: capitalize; }
.badge-blue { background: #dbeafe; color: #1d4ed8; }
.badge-green { background: #dcfce7; color: #15803d; }
.badge-red { background: #fee2e2; color: #b91c1c; }
.badge-orange { background: #ffedd5; color: #c2410c; }
.data-tbl { width: 100%; border-collapse: collapse; font-size: 13px; }
.data-tbl th { background: #f1f5f9; padding: 10px 8px; text-align: left; font-weight: 600; font-size: 12px; color: #475569; border-bottom: 2px solid #e2e8f0; }
.data-tbl td { padding: 10px 8px; border-bottom: 1px solid #f1f5f9; }
.data-tbl tr:hover td { background: #f8fafc; }
.tbl-wrap { overflow-x: auto; border-radius: 8px; border: 1px solid #e2e8f0; }
.btn-sm { padding: 5px 10px; font-size: 12px; border: none; border-radius: 6px; cursor: pointer; background: #e2e8f0; color: #475569; transition: all 0.15s; }
.btn-sm:hover { background: #cbd5e1; }
.btn-sm.btn-approve { background: #dcfce7; color: #15803d; }
.btn-sm.btn-approve:hover { background: #bbf7d0; }
.btn-sm.btn-reject { background: #fee2e2; color: #b91c1c; }
.btn-sm.btn-reject:hover { background: #fecaca; }
.btn-primary { padding: 10px 20px; background: linear-gradient(135deg, #6366f1, #8b5cf6); color: #fff; border: none; border-radius: 8px; font-weight: 600; cursor: pointer; font-size: 14px; transition: all 0.2s; }
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(99,102,241,0.3); }
.btn-outline { padding: 10px 20px; background: transparent; color: #6366f1; border: 2px solid #6366f1; border-radius: 8px; font-weight: 600; cursor: pointer; font-size: 14px; }
.btn-outline:hover { background: #eef2ff; }
.modal-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.5); display: flex; align-items: center; justify-content: center; z-index: 9999; padding: 20px; backdrop-filter: blur(4px); }
.modal-box { background: #fff; border-radius: 16px; padding: 24px; width: 100%; animation: modalIn 0.2s ease; box-shadow: 0 20px 60px rgba(0,0,0,0.2); }
.modal-box h3 { margin: 0 0 16px; font-size: 18px; color: #1e293b; }
.modal-box label { display: block; font-size: 13px; font-weight: 600; color: #475569; margin: 12px 0 4px; }
.modal-box input, .modal-box select, .modal-box textarea { width: 100%; padding: 10px 12px; border: 1.5px solid #e2e8f0; border-radius: 8px; font-size: 14px; outline: none; transition: border-color 0.2s; box-sizing: border-box; }
.modal-box input:focus, .modal-box select:focus, .modal-box textarea:focus { border-color: #6366f1; }
@keyframes modalIn { from { opacity: 0; transform: scale(0.95); } to { opacity: 1; transform: scale(1); } }
.settings-form .setting-group { margin-bottom: 20px; padding: 16px; background: #f8fafc; border-radius: 10px; border: 1px solid #e2e8f0; }
.settings-form .setting-group h5 { margin: 0 0 12px; font-size: 14px; color: #1e293b; }
.settings-form label { display: block; font-size: 13px; font-weight: 500; color: #475569; margin: 8px 0 4px; }
.settings-form input[type="text"], .settings-form input[type="email"], .settings-form input[type="number"] { width: 100%; padding: 8px 12px; border: 1.5px solid #e2e8f0; border-radius: 6px; font-size: 13px; box-sizing: border-box; }
.settings-form input[type="checkbox"] { margin-right: 8px; }


/* ===== Wallet payment-method credentials box (added by upgrade_wallet_admin) ===== */
.pm-cred-box{background:#f0fdfa;border:1px solid #99f6e4;border-radius:12px;padding:12px 14px;margin:6px 0 14px;}
.pm-cred-head{font-weight:700;color:#0f766e;display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:14px;}
.pm-cred-row{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:5px 0;border-bottom:1px dashed #ccfbf1;font-size:13px;}
.pm-cred-row:last-child{border-bottom:none;}
.pm-cred-row span{color:#64748b;}
.pm-cred-row b{color:#0f172a;text-align:right;word-break:break-all;}
.pm-cred-copy{cursor:pointer;color:#0d9488;display:inline-flex;align-items:center;gap:6px;}
.pm-cred-copy:hover{text-decoration:underline;}
.pm-cred-note{font-size:12px;color:#475569;background:#ecfeff;border-radius:8px;padding:8px 10px;margin-top:8px;line-height:1.5;}
.pm-cred-empty{font-size:12.5px;color:#64748b;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:10px;padding:10px 12px;margin:6px 0 12px;}
.wf-pay-info{margin:2px 0 4px;}


/* ===== Admin Deposits & Withdrawals — segmented tabs + detail (added by upgrade_wallet_admin) ===== */
.seg-tabs{display:flex;gap:8px;flex-wrap:wrap;}
.seg-btn{flex:1;min-width:90px;border:1px solid #e2e8f0;background:#fff;color:#475569;border-radius:10px;padding:9px 12px;font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:all .15s;}
.seg-btn:hover{border-color:#94a3b8;}
.seg-btn.active{background:#0d9488;border-color:#0d9488;color:#fff;box-shadow:0 2px 8px rgba(13,148,136,.25);}
.wd-detail .pm-cred-row{display:flex;justify-content:space-between;gap:12px;padding:7px 0;border-bottom:1px dashed #e2e8f0;font-size:13.5px;}
.wd-detail .pm-cred-row:last-child{border-bottom:none;}
.wd-detail .pm-cred-row span{color:#64748b;}
.wd-detail .pm-cred-row b{color:#0f172a;text-align:right;word-break:break-all;}
.list-item.col .li-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;}
.li-tag.tag-amber{background:#fef3c7;color:#92400e;}
