/* ===========================================================================
   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 */
}
.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)}

.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-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)}

.auth-form{padding:18px 22px 0;display:flex;flex-direction:column;gap:15px}
.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;
}
.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;
}
.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}

.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)}

.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}

/* ---- 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}

/* ---- 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)}
