/* ═══════════════════════════════════════════════════════════════
   Amara Staff Portal — portal.css  v3.0
   Brand: #194846 (primary) · #c9a84c (secondary / gold)
   Fonts: Cormorant Garamond (display) · DM Sans (body)
═══════════════════════════════════════════════════════════════ */

:root {
  --p:        #194846;
  --p2:       #1d5552;
  --p3:       #0f2f2e;
  --g:        #c9a84c;
  --g2:       #e3c47a;
  --g3:       #8a6e2a;
  --white:    #ffffff;
  --off:      #f6f4f0;
  --bg:       #f2f0eb;
  --surface:  #ffffff;
  --border:   #ddd9d0;
  --text:     #1a1a1a;
  --muted:    #6b6560;
  --success:  #1a6b3c;
  --error:    #c0392b;
  --warning:  #b5620e;
  --shadow:   0 4px 24px rgba(25,72,70,0.10);
  --shadow-lg:0 8px 40px rgba(25,72,70,0.16);
  --radius:   14px;
  --radius-sm:8px;
  --font-d:   'Cormorant Garamond', Georgia, serif;
  --font-b:   'DM Sans', system-ui, sans-serif;
  --trans:    all .22s cubic-bezier(.4,0,.2,1);
}

.asp-root *, .asp-root *::before, .asp-root *::after {
  box-sizing: border-box; margin: 0; padding: 0;
}
.asp-root {
  font-family: var(--font-b);
  color: var(--text);
  font-size: 15px;
  line-height: 1.6;
  min-height: 100vh;
  background: var(--bg);
}
.asp-hide { display: none !important; }

/* ── AUTH BG ── */
.asp-auth-bg {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px 16px;
  background:
    radial-gradient(ellipse 80% 60% at 20% 20%, rgba(25,72,70,.18) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 80% 80%, rgba(201,168,76,.12) 0%, transparent 60%),
    linear-gradient(160deg, #0e2d2b 0%, #194846 40%, #1a3d3b 70%, #0d2220 100%);
  overflow: hidden;
}
.asp-orb {
  position: absolute; border-radius: 50%; filter: blur(60px); pointer-events: none;
  animation: asp-drift 12s ease-in-out infinite;
}
.asp-o1 { width:400px;height:400px;background:rgba(201,168,76,.10);top:-10%;left:-10%;animation-delay:0s; }
.asp-o2 { width:280px;height:280px;background:rgba(25,72,70,.25);bottom:5%;right:-5%;animation-delay:-4s; }
.asp-o3 { width:200px;height:200px;background:rgba(201,168,76,.08);top:50%;left:50%;animation-delay:-8s; }
@keyframes asp-drift {
  0%,100%{transform:translate(0,0) scale(1);}
  33%{transform:translate(30px,-20px) scale(1.05);}
  66%{transform:translate(-20px,30px) scale(.95);}
}

/* ── AUTH CARD ── */
.asp-auth-card {
  position: relative;
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(20px);
  border-radius: 24px;
  padding: 40px 36px;
  width: 100%;
  max-width: 420px;
  box-shadow: 0 24px 80px rgba(0,0,0,.35), 0 0 0 1px rgba(201,168,76,.2);
  animation: asp-card-in .5s cubic-bezier(.22,1,.36,1) both;
}
.asp-auth-card-wide { max-width: 640px; }
@keyframes asp-card-in {
  from{opacity:0;transform:translateY(24px) scale(.97);}
  to{opacity:1;transform:translateY(0) scale(1);}
}

/* ── LOGO ── */
.asp-logo { text-align:center; margin-bottom:24px; }
.asp-logo-name {
  display:block; font-family:var(--font-d); font-size:2.4rem; font-weight:700;
  color:var(--p); letter-spacing:-.5px; line-height:1;
}
.asp-logo-sub {
  display:block; font-size:12px; letter-spacing:3px; text-transform:uppercase;
  color:var(--g3); margin-top:2px;
}
.asp-logo-badge {
  display:inline-flex; align-items:center; gap:6px; margin-top:10px;
  background:var(--p); color:var(--g2); font-size:11px; letter-spacing:1.5px;
  text-transform:uppercase; font-weight:600; padding:4px 14px 4px 10px; border-radius:100px;
}
.asp-pulse {
  width:8px;height:8px;border-radius:50%;background:var(--g);
  animation:asp-pulse-anim 1.8s ease-in-out infinite;
}
@keyframes asp-pulse-anim {
  0%,100%{opacity:1;transform:scale(1);}
  50%{opacity:.5;transform:scale(1.4);}
}

/* ── AUTH TABS ── */
.asp-auth-tabs {
  display:flex; background:var(--off); border-radius:100px; padding:4px; margin-bottom:24px;
}
.asp-atab {
  flex:1; border:none; background:none; padding:8px 16px; border-radius:100px;
  font-family:var(--font-b); font-size:13px; font-weight:600; color:var(--muted); cursor:pointer;
  transition:var(--trans);
}
.asp-atab.asp-atab-on { background:var(--p); color:var(--white); box-shadow:0 2px 8px rgba(25,72,70,.3); }

/* ── FORM GROUPS ── */
.asp-fg { margin-bottom:16px; }
.asp-fg label {
  display:block; font-size:12px; font-weight:600; text-transform:uppercase;
  letter-spacing:.8px; color:var(--muted); margin-bottom:6px;
}
.asp-fg input, .asp-fg select, .asp-fg textarea {
  width:100%; padding:11px 14px; border:1.5px solid var(--border);
  border-radius:var(--radius-sm); font-family:var(--font-b); font-size:14px;
  color:var(--text); background:var(--white); transition:var(--trans); outline:none;
}
.asp-fg input:focus, .asp-fg select:focus, .asp-fg textarea:focus {
  border-color:var(--p); box-shadow:0 0 0 3px rgba(25,72,70,.1);
}
.asp-fg textarea { resize:vertical; min-height:80px; }
.asp-fg-2 { display:grid; grid-template-columns:1fr 1fr; gap:12px; }

/* ── BUTTONS ── */
.asp-btn-primary {
  background:linear-gradient(135deg,var(--p) 0%,var(--p2) 100%);
  color:var(--white); border:none; border-radius:var(--radius-sm);
  padding:13px 24px; font-family:var(--font-b); font-size:14px; font-weight:600;
  cursor:pointer; transition:var(--trans); box-shadow:0 4px 16px rgba(25,72,70,.3);
}
.asp-btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(25,72,70,.4);}
.asp-btn-primary:active{transform:translateY(0);}
.asp-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;}
.asp-btn-full { width:100%; margin-top:8px; }

.asp-btn-gold {
  background:linear-gradient(135deg,var(--g) 0%,var(--g2) 100%);
  color:var(--p3); border:none; border-radius:var(--radius-sm);
  padding:11px 20px; font-family:var(--font-b); font-size:14px; font-weight:700;
  cursor:pointer; transition:var(--trans); box-shadow:0 3px 12px rgba(201,168,76,.3);
}
.asp-btn-gold:hover{transform:translateY(-1px);box-shadow:0 5px 16px rgba(201,168,76,.4);}

.asp-btn-ghost {
  background:transparent; color:var(--p); border:1.5px solid var(--p);
  border-radius:var(--radius-sm); padding:10px 20px; font-family:var(--font-b);
  font-size:14px; font-weight:600; cursor:pointer; transition:var(--trans);
}
.asp-btn-ghost:hover{background:var(--p);color:var(--white);}

.asp-btn-danger {
  background:var(--error); color:#fff; border:none; border-radius:var(--radius-sm);
  padding:10px 18px; font-family:var(--font-b); font-size:13px; font-weight:600;
  cursor:pointer; transition:var(--trans);
}
.asp-btn-danger:hover{background:#a93226;}
.asp-btn-sm{padding:6px 14px!important;font-size:12px!important;}

/* ── MESSAGES ── */
.asp-msg { border-radius:var(--radius-sm); padding:10px 14px; font-size:13px; font-weight:500; margin-bottom:16px; }
.asp-msg-err  { background:#fdf0ee; color:var(--error); border:1px solid #f5c6c1; }
.asp-msg-ok   { background:#edf7f1; color:var(--success); border:1px solid #b5dfca; }
.asp-msg-warn { background:#fef9ee; color:var(--warning); border:1px solid #f5dba0; }

.asp-auth-hint { text-align:center; font-size:12px; color:var(--muted); margin-top:14px; }

/* ── AVATAR UPLOAD ── */
.asp-av-upload-center { display:flex; flex-direction:column; align-items:center; margin-bottom:20px; }
.asp-av-circle {
  width:90px;height:90px; border-radius:50%; background:var(--off);
  border:3px solid var(--border); display:flex; align-items:center; justify-content:center;
  cursor:pointer; position:relative; overflow:hidden; transition:var(--trans); font-size:26px;
}
.asp-av-circle:hover{border-color:var(--p);}
.asp-av-circle img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.asp-av-hover {
  position:absolute; inset:0; background:rgba(25,72,70,.6); color:#fff;
  display:flex;align-items:center;justify-content:center; font-size:20px;
  opacity:0; transition:var(--trans); border-radius:50%;
}
.asp-av-circle:hover .asp-av-hover{opacity:1;}
.asp-av-hint{text-align:center;font-size:11px;color:var(--muted);margin-top:8px;line-height:1.5;}
.asp-file-hidden{display:none;}

/* ── TOP NAV ── */
.asp-topnav {
  display:flex; align-items:center; justify-content:space-between;
  background:var(--p); padding:0 24px; height:64px;
  box-shadow:0 2px 12px rgba(0,0,0,.15); position:sticky; top:0; z-index:100;
}
.asp-brand{display:flex;align-items:baseline;gap:8px;}
.asp-brand-name{font-family:var(--font-d);font-size:1.6rem;font-weight:700;color:var(--white);letter-spacing:-.3px;}
.asp-brand-tag{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--g2);font-weight:600;}
.asp-nav-right{display:flex;align-items:center;gap:16px;}
.asp-nav-user{display:flex;align-items:center;gap:10px;}
.asp-nav-av {
  width:40px;height:40px;border-radius:50%;background:var(--g);display:flex;
  align-items:center;justify-content:center;font-size:15px;font-weight:700;
  color:var(--p3);overflow:hidden;flex-shrink:0;border:2px solid rgba(255,255,255,.25);
}
.asp-nav-av img{width:100%;height:100%;object-fit:cover;}
.asp-nav-info{display:none;}
@media(min-width:600px){.asp-nav-info{display:block;}}
.asp-nav-name{font-size:13px;font-weight:600;color:var(--white);}
.asp-nav-role{font-size:11px;color:var(--g2);}
.asp-btn-logout {
  background:rgba(255,255,255,.12);color:rgba(255,255,255,.85);
  border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);
  padding:7px 14px;font-size:12px;font-weight:600;cursor:pointer;
  transition:var(--trans);font-family:var(--font-b);
}
.asp-btn-logout:hover{background:rgba(255,255,255,.2);color:#fff;}

/* ── TAB BARS ── */
.asp-tabnav {
  background:var(--p3); display:flex; overflow-x:auto; scrollbar-width:none;
  border-bottom:2px solid rgba(201,168,76,.2);
}
.asp-tabnav::-webkit-scrollbar{display:none;}
.asp-tab {
  flex-shrink:0; padding:14px 20px; border:none; background:none;
  color:rgba(255,255,255,.55); font-family:var(--font-b); font-size:13px; font-weight:600;
  cursor:pointer; border-bottom:3px solid transparent; transition:var(--trans);
}
.asp-tab:hover{color:rgba(255,255,255,.85);}
.asp-tab.asp-tab-on{color:var(--g);border-bottom-color:var(--g);}

.asp-staff-tabnav {
  background:var(--white); display:flex; border-bottom:2px solid var(--border); padding:0 16px;
}
.asp-stab {
  padding:13px 18px; border:none; background:none; color:var(--muted);
  font-family:var(--font-b); font-size:13px; font-weight:600; cursor:pointer;
  border-bottom:3px solid transparent; margin-bottom:-2px; transition:var(--trans);
}
.asp-stab:hover{color:var(--p);}
.asp-stab.asp-stab-on{color:var(--p);border-bottom-color:var(--p);}

/* ── MAIN ── */
.asp-main{padding:28px 24px;max-width:1200px;margin:0 auto;}

/* ── STAT CARDS ── */
.asp-stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:28px;}
.asp-stat-card {
  background:var(--white); border-radius:var(--radius); padding:22px 20px;
  box-shadow:var(--shadow); border:1px solid var(--border); position:relative; overflow:hidden; transition:var(--trans);
}
.asp-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);}
.asp-stat-card::before {
  content:''; position:absolute; top:0;left:0;right:0; height:3px;
  background:linear-gradient(90deg,var(--p),var(--g));
}
.asp-stat-num{font-family:var(--font-d);font-size:2.4rem;font-weight:700;color:var(--p);line-height:1;}
.asp-stat-lbl{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-top:6px;}
.asp-stat-icon{position:absolute;top:18px;right:18px;font-size:22px;opacity:.3;}

/* ── CLOCK BLOCK ── */
.asp-clock-block {
  background:linear-gradient(135deg,var(--p) 0%,var(--p2) 100%);
  border-radius:20px; padding:32px 28px; color:var(--white); margin-bottom:28px;
  box-shadow:0 8px 32px rgba(25,72,70,.3); position:relative; overflow:hidden;
}
.asp-clock-block::after {
  content:''; position:absolute; top:-40px;right:-40px; width:200px;height:200px;
  border-radius:50%; background:rgba(201,168,76,.08); pointer-events:none;
}
.asp-clock-label{font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--g2);font-weight:600;margin-bottom:4px;}
.asp-clock-time{font-family:var(--font-d);font-size:3rem;font-weight:700;line-height:1;margin-bottom:6px;color:var(--white);}
.asp-clock-date{font-size:13px;color:rgba(255,255,255,.7);margin-bottom:20px;}
.asp-clock-status {
  display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);
  border-radius:100px;padding:6px 14px;font-size:13px;font-weight:600;margin-bottom:20px;
}
.asp-clock-dot{width:10px;height:10px;border-radius:50%;background:#6ec97f;animation:asp-pulse-anim 1.8s infinite;}
.asp-clock-dot.asp-dot-off{background:rgba(255,255,255,.4);animation:none;}
.asp-clock-actions{display:flex;gap:12px;flex-wrap:wrap;}
.asp-btn-clock-in {
  background:linear-gradient(135deg,var(--g) 0%,var(--g2) 100%); color:var(--p3); border:none;
  border-radius:100px; padding:14px 32px; font-family:var(--font-b); font-size:15px; font-weight:700;
  cursor:pointer; transition:var(--trans); box-shadow:0 4px 16px rgba(201,168,76,.4);
}
.asp-btn-clock-in:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(201,168,76,.5);}
.asp-btn-clock-in:disabled{opacity:.6;cursor:not-allowed;transform:none;}
.asp-btn-clock-out {
  background:rgba(255,255,255,.15);color:#fff;border:2px solid rgba(255,255,255,.4);
  border-radius:100px;padding:12px 28px;font-family:var(--font-b);font-size:15px;font-weight:700;cursor:pointer;transition:var(--trans);
}
.asp-btn-clock-out:hover{background:rgba(255,255,255,.25);}
.asp-btn-clock-out:disabled{opacity:.6;cursor:not-allowed;}
.asp-clock-elapsed{font-size:12px;color:rgba(255,255,255,.6);margin-top:12px;}
.asp-gps-info{font-size:11px;color:rgba(255,255,255,.6);margin-top:8px;display:flex;align-items:center;gap:6px;}

/* ── SECTION CARDS ── */
.asp-section{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);margin-bottom:24px;overflow:hidden;}
.asp-section-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border);}
.asp-section-title{font-family:var(--font-d);font-size:1.2rem;font-weight:700;color:var(--p);}
.asp-section-body{padding:20px 22px;}

/* ── TABLE ── */
.asp-table-wrap{overflow-x:auto;}
.asp-table{width:100%;border-collapse:collapse;font-size:13px;}
.asp-table th{text-align:left;padding:10px 14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);background:var(--off);border-bottom:2px solid var(--border);}
.asp-table td{padding:12px 14px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;}
.asp-table tr:last-child td{border-bottom:none;}
.asp-table tr:hover td{background:rgba(25,72,70,.025);}

/* ── BADGES ── */
.asp-role-badge{display:inline-block;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:700;letter-spacing:.5px;}
.asp-role-RN{background:#e0f0ff;color:#1565c0;}
.asp-role-LPN{background:#e8f5e9;color:#2e7d32;}
.asp-role-CNA{background:#fff8e1;color:#f57f17;}
.asp-role-Caregiver{background:#fce4ec;color:#c62828;}
.asp-role-Admin{background:rgba(25,72,70,.12);color:var(--p);}
.asp-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:600;}
.asp-badge-active{background:#e6f9ec;color:#1a6b3c;}
.asp-badge-done{background:var(--off);color:var(--muted);}

/* ── PROFILE ── */
.asp-profile-hero {
  background:linear-gradient(135deg,var(--p) 0%,var(--p3) 100%);
  border-radius:20px;padding:32px 28px;display:flex;align-items:center;gap:24px;margin-bottom:24px;color:var(--white);
}
.asp-profile-av {
  width:80px;height:80px;border-radius:50%;background:var(--g);display:flex;align-items:center;
  justify-content:center;font-size:28px;font-weight:700;color:var(--p3);overflow:hidden;flex-shrink:0;
  border:3px solid rgba(255,255,255,.3);cursor:pointer;position:relative;
}
.asp-profile-av img{width:100%;height:100%;object-fit:cover;}
.asp-profile-av:hover .asp-av-hover{opacity:1;}
.asp-profile-name{font-family:var(--font-d);font-size:1.8rem;font-weight:700;line-height:1.1;}
.asp-profile-role{font-size:13px;color:var(--g2);margin-top:4px;}
.asp-profile-email{font-size:12px;color:rgba(255,255,255,.6);margin-top:3px;}

/* ── ADMIN OVERVIEW ── */
.asp-live-badge{display:inline-flex;align-items:center;gap:6px;background:#e6f9ec;color:#1a6b3c;font-size:11px;font-weight:700;padding:4px 12px;border-radius:100px;letter-spacing:.5px;}
.asp-active-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;padding:20px 22px;}
.asp-active-card {
  background:var(--off);border-radius:12px;padding:16px;border:1px solid var(--border);
  display:flex;gap:12px;align-items:flex-start;transition:var(--trans);
}
.asp-active-card:hover{border-color:var(--p);box-shadow:0 2px 12px rgba(25,72,70,.1);}
.asp-ac-av{width:40px;height:40px;border-radius:50%;background:var(--p);color:var(--g2);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0;overflow:hidden;}
.asp-ac-av img{width:100%;height:100%;object-fit:cover;}
.asp-ac-name{font-size:14px;font-weight:600;color:var(--text);}
.asp-ac-role{font-size:11px;color:var(--muted);}
.asp-ac-time{font-size:12px;color:var(--p2);margin-top:4px;font-weight:500;}
.asp-ac-loc{font-size:11px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px;}

/* ── FILTERS ── */
.asp-filters{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;padding:18px 22px;border-bottom:1px solid var(--border);background:var(--off);}
.asp-filters .asp-fg{margin-bottom:0;}
.asp-filters label{font-size:11px;}
.asp-filters input,.asp-filters select{padding:8px 12px;font-size:13px;}

/* ── STAFF CARDS ── */
.asp-staff-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;padding:20px 22px;}
.asp-staff-card {
  background:var(--off);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;text-align:center;transition:var(--trans);position:relative;
}
.asp-staff-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--p);}
.asp-staff-card-av{width:64px;height:64px;border-radius:50%;background:var(--p);color:var(--g2);margin:0 auto 12px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;overflow:hidden;border:2px solid var(--border);}
.asp-staff-card-av img{width:100%;height:100%;object-fit:cover;}
.asp-staff-card-name{font-size:15px;font-weight:600;color:var(--text);margin-bottom:4px;}
.asp-staff-card-email{font-size:12px;color:var(--muted);margin-bottom:8px;}
.asp-staff-card-actions{display:flex;gap:8px;justify-content:center;margin-top:12px;}
.asp-inactive-overlay{position:absolute;top:10px;right:10px;background:var(--error);color:#fff;font-size:10px;font-weight:700;padding:2px 8px;border-radius:100px;}

/* ── EXPORT ── */
.asp-export-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;padding:20px 22px;}
.asp-export-card{background:var(--off);border:1px solid var(--border);border-radius:var(--radius);padding:22px;text-align:center;cursor:pointer;transition:var(--trans);}
.asp-export-card:hover{border-color:var(--p);background:#fff;box-shadow:var(--shadow);}
.asp-export-card-icon{font-size:32px;margin-bottom:10px;}
.asp-export-card-title{font-size:14px;font-weight:600;color:var(--text);}
.asp-export-card-sub{font-size:12px;color:var(--muted);margin-top:4px;}

/* ── MODAL ── */
.asp-modal-bg {
  position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;z-index:9999;padding:16px;
  animation:asp-bg-in .2s ease both;
}
@keyframes asp-bg-in{from{opacity:0;}to{opacity:1;}}
.asp-modal {
  background:var(--white);border-radius:20px;width:100%;max-width:540px;max-height:90vh;
  display:flex;flex-direction:column;box-shadow:0 24px 80px rgba(0,0,0,.3);
  animation:asp-modal-in .3s cubic-bezier(.22,1,.36,1) both;
}
@keyframes asp-modal-in{from{opacity:0;transform:translateY(32px) scale(.96);}to{opacity:1;transform:translateY(0) scale(1);}}
.asp-modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);}
.asp-modal-head h3{font-family:var(--font-d);font-size:1.3rem;color:var(--p);}
.asp-modal-close{width:32px;height:32px;border-radius:50%;background:var(--off);border:none;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:var(--trans);}
.asp-modal-close:hover{background:var(--border);color:var(--text);}
.asp-modal-body{padding:24px;overflow-y:auto;flex:1;}
.asp-modal-foot{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;}

/* ── TOAST ── */
.asp-toast {
  position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--p3);color:var(--white);padding:12px 22px;border-radius:100px;
  font-size:13px;font-weight:500;box-shadow:0 8px 24px rgba(0,0,0,.3);z-index:99999;
  opacity:0;transition:all .3s cubic-bezier(.22,1,.36,1);pointer-events:none;white-space:nowrap;
}
.asp-toast.asp-toast-show{opacity:1;transform:translateX(-50%) translateY(0);}
.asp-toast.asp-toast-err{background:var(--error);}
.asp-toast.asp-toast-ok{background:var(--success);}
.asp-toast.asp-toast-gold{background:var(--g3);}
.asp-toast.asp-toast-warn{background:var(--warning);}

/* ── GPS BAR ── */
.asp-gps-bar {
  position:fixed;bottom:0;left:0;right:0;background:var(--p3);color:var(--white);
  padding:10px 20px;display:flex;align-items:center;gap:12px;font-size:13px;z-index:999;
}
.asp-gps-spin{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:var(--g);border-radius:50%;animation:asp-spin .8s linear infinite;flex-shrink:0;}
@keyframes asp-spin{to{transform:rotate(360deg);}}

/* ── LOADER ── */
.asp-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px;color:var(--muted);}
.asp-loader-ring{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--p);border-radius:50%;animation:asp-spin .8s linear infinite;}

/* ── EMPTY STATE ── */
.asp-empty{text-align:center;padding:48px 20px;color:var(--muted);}
.asp-empty-icon{font-size:36px;margin-bottom:10px;}
.asp-empty-text{font-size:14px;}

/* ── RESPONSIVE ── */
@media(max-width:600px){
  .asp-main{padding:16px 14px;}
  .asp-auth-card{padding:28px 20px;}
  .asp-fg-2{grid-template-columns:1fr;}
  .asp-topnav{padding:0 14px;}
  .asp-clock-time{font-size:2.4rem;}
  .asp-profile-hero{flex-direction:column;text-align:center;}
  .asp-stats-row{grid-template-columns:1fr 1fr;}
}


/* ═══ VITALS GRID (Visit Notes form) ═══════════════════════ */
.asp-vitals-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 0;
}
@media (max-width: 600px) {
  .asp-vitals-grid { grid-template-columns: 1fr; }
}
/* Allow wide tables to scroll horizontally */
.asp-table-scroll { min-width: 900px; }

/* ═══ MOBILE BOTTOM NAV ═════════════════════════════════════════ */
.asp-bottom-nav {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: var(--white);
  border-top: 1px solid var(--border);
  z-index: 200;
  padding: 6px 0 env(safe-area-inset-bottom, 6px);
  box-shadow: 0 -4px 16px rgba(0,0,0,.08);
}
.asp-bnav-btn {
  flex: 1; display: flex; flex-direction: column; align-items: center; gap: 3px;
  padding: 6px 4px; border: none; background: none; cursor: pointer;
  color: var(--muted); transition: var(--trans); font-family: var(--font-b);
}
.asp-bnav-btn.asp-bnav-on { color: var(--p); }
.asp-bnav-icon { font-size: 20px; }
.asp-bnav-lbl  { font-size: 10px; font-weight: 600; letter-spacing: .3px; }
@media(max-width:600px) {
  .asp-bottom-nav { display: flex; }
  .asp-staff-tabnav { display: none; }
  .asp-main { padding-bottom: 72px; }
}

/* ═══ MAPS TAB ══════════════════════════════════════════════════ */
.asp-map-container {
  min-height: 400px;
  border-radius: 0 0 var(--radius) var(--radius);
  overflow: hidden;
  background: var(--off);
  display: flex; align-items: center; justify-content: center;
}
.asp-map-link {
  color: var(--p); text-decoration: none; font-size: 12px; font-weight: 600;
  display: inline-flex; align-items: center; gap: 3px;
  padding: 2px 8px; border-radius: 100px;
  background: rgba(25,72,70,.08);
  transition: var(--trans);
}
.asp-map-link:hover { background: var(--p); color: #fff; }
.asp-map-legend { background: var(--white); }
.asp-map-fallback {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 40px 20px; gap: 12px;
}
.asp-map-pins-list {
  display: flex; flex-direction: column; gap: 8px; width: 100%; max-width: 420px;
  margin-top: 12px;
}
.asp-map-pin-link {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px; background: var(--off); border-radius: 10px;
  border: 1px solid var(--border); text-decoration: none; color: var(--text);
  transition: var(--trans); font-size: 13px;
}
.asp-map-pin-link:hover { border-color: var(--p); background: #fff; }
.asp-map-pin-av {
  width: 34px; height: 34px; border-radius: 50%; background: var(--p); color: var(--g2);
  display: flex; align-items: center; justify-content: center; font-size: 12px;
  font-weight: 700; flex-shrink: 0;
}
.asp-map-pin-link span { font-size: 11px; color: var(--muted); }

/* ═══ ANALYTICS CHARTS ══════════════════════════════════════════ */
.asp-chart-wrap { position: relative; height: 220px; }
@media(max-width:700px) {
  .asp-chart-wrap { height: 180px; }
  [style*="grid-template-columns:1fr 1fr"] { grid-template-columns: 1fr !important; }
}

/* ═══ STATUS BADGES ═════════════════════════════════════════════ */
.asp-status-badge {
  position: absolute; top: 10px; left: 10px;
  font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 100px;
}
.asp-status-pending   { background: #fff3cd; color: #856404; }
.asp-status-suspended { background: #f8d7da; color: #842029; }

/* ═══════════════════════════════════════
   v4.1 — Activity Logs, Roles, Visits
═══════════════════════════════════════ */

/* Action badge in activity logs */
.asp-action-badge {
  display: inline-block;
  background: rgba(25,72,70,.08);
  color: #194846;
  padding: 3px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
}

/* Role tags in modal */
.asp-role-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(25,72,70,.12);
  color: #194846;
  border-radius: 20px;
  padding: 4px 10px 4px 12px;
  font-size: 12px;
  font-weight: 600;
}
.asp-role-tag-del {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--muted);
  font-size: 13px;
  padding: 0 2px;
  line-height: 1;
  border-radius: 50%;
  transition: color .15s, background .15s;
}
.asp-role-tag-del:hover { color: #c0392b; background: rgba(192,57,43,.1); }

/* Gold button */
.asp-btn-gold {
  background: var(--gold);
  color: var(--primary);
  font-weight: 700;
  border: none;
  border-radius: 8px;
  padding: 10px 20px;
  cursor: pointer;
  font-size: 14px;
  transition: opacity .15s;
}
.asp-btn-gold:hover { opacity: .85; }
.asp-btn-sm.asp-btn-gold { padding: 6px 14px; font-size: 12px; }

/* ═══════════════════════════════════════
   v4.1.1 — Pending approval banner
═══════════════════════════════════════ */

/* Admin dashboard — pending staff notification banner */
.asp-pending-banner {
  display: flex;
  align-items: center;
  gap: 14px;
  background: linear-gradient(135deg, #fff8ed 0%, #fff3da 100%);
  border: 1.5px solid #f59000;
  border-radius: 12px;
  padding: 16px 20px;
  margin-bottom: 20px;
  box-shadow: 0 2px 12px rgba(245,144,0,.12);
}
.asp-pending-banner-icon {
  font-size: 28px;
  flex-shrink: 0;
  animation: asp-bell-shake 2.5s ease-in-out infinite;
}
@keyframes asp-bell-shake {
  0%,100% { transform: rotate(0); }
  10%      { transform: rotate(-12deg); }
  20%      { transform: rotate(12deg); }
  30%      { transform: rotate(-8deg); }
  40%      { transform: rotate(8deg); }
  50%      { transform: rotate(0); }
}
.asp-pending-banner-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.asp-pending-banner-body strong {
  font-size: 15px;
  color: #7a4400;
  font-weight: 700;
}
.asp-pending-banner-body span {
  font-size: 13px;
  color: #a06020;
  line-height: 1.4;
}

/* Signup — pending approval rich message box */
.asp-signup-pending-box {
  background: linear-gradient(135deg, #f0f7f6 0%, #e8f5f3 100%);
  border: 1.5px solid #c9e8e4;
  border-radius: 12px;
  padding: 24px;
  text-align: center;
  margin-top: 8px;
}


/* Boot loader — shown while auto-restoring session on page reload */
.asp-boot-loader {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  z-index: 9999;
}

/* ═══ v4.3.0 — Shift tracking, live search, GPS improvements ═══ */

/* Active shift card on staff dashboard */
.asp-shift-active-section { border-left: 4px solid #1a6b3c; }
.asp-active-shift-card { background: linear-gradient(135deg,#f0faf4,#e8f7ee); border-radius:10px; padding:16px 20px; }
.asp-active-shift-row { display:flex; align-items:center; gap:12px; padding:6px 0; border-bottom:1px solid rgba(26,107,60,.1); }
.asp-active-shift-row:last-child { border-bottom:none; }
.asp-active-shift-lbl { font-size:12px; color:#1a6b3c; font-weight:600; text-transform:uppercase; letter-spacing:.5px; min-width:70px; }
.asp-active-shift-val { font-size:13px; color:#194846; }

/* Currently On Shift banner in My Shifts */
.asp-shift-active-banner { background:linear-gradient(135deg,#e8f7ee,#f0faf4); border:1.5px solid #1a6b3c; border-radius:8px; padding:12px 18px; margin-bottom:12px; display:flex; align-items:center; gap:10px; font-size:14px; color:#1a6b3c; font-weight:600; }
.asp-live-dot { width:10px; height:10px; background:#1a6b3c; border-radius:50%; animation:asp-pulse-dot 1.5s ease-in-out infinite; flex-shrink:0; }
@keyframes asp-pulse-dot { 0%,100%{opacity:1;transform:scale(1);} 50%{opacity:.5;transform:scale(1.3);} }

/* Boot loader */
.asp-boot-loader { position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#fff;z-index:9999; }

/* GPS bar improvements */
.asp-gps-bar { background:linear-gradient(135deg,#194846,#1d5552); }

/* ═══════════════════════════════════════════════
   v4.3.2 — PWA Install Button + Staff Responsive
═══════════════════════════════════════════════ */

/* ── Staff Management header bar ── */
.asp-staff-mgmt-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  padding: 18px 22px;
  border-bottom: 1px solid var(--border);
  background: var(--off);
}

/* Controls: search input + action buttons side by side */
.asp-staff-mgmt-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: nowrap;
}

/* Search input — styled to match the portal's input language */
.asp-staff-search-input {
  height: 38px;
  padding: 0 14px;
  font-size: 13px;
  font-family: var(--font-b);
  color: var(--text);
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  outline: none;
  transition: border-color .2s, box-shadow .2s;
  min-width: 200px;
  width: 240px;
}

.asp-staff-search-input:focus {
  border-color: var(--p);
  box-shadow: 0 0 0 3px rgba(25,72,70,.10);
}

.asp-staff-search-input::placeholder {
  color: var(--muted);
  opacity: 1;
}

/* Button cluster */
.asp-staff-mgmt-btns {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-shrink: 0;
}

/* Mobile: stack controls vertically, full-width search */
@media (max-width: 600px) {
  .asp-staff-mgmt-header {
    flex-direction: column;
    align-items: stretch;
    padding: 14px 16px;
    gap: 10px;
  }
  .asp-staff-mgmt-controls {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
  .asp-staff-search-input {
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
  }
  .asp-staff-mgmt-btns {
    width: 100%;
  }
  .asp-staff-mgmt-btns button {
    flex: 1;
    justify-content: center;
    text-align: center;
  }
}


/* Tabnav horizontal scroll on small screens */
@media (max-width: 768px) {
  .asp-tabnav {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    flex-wrap: nowrap;
    white-space: nowrap;
  }
  .asp-tabnav::-webkit-scrollbar { display: none; }
  .asp-tabnav .asp-tab { flex-shrink: 0; }

  .asp-section-head {
    flex-wrap: wrap;
    gap: 8px;
  }
  /* Filter rows stack nicely on mobile */
  .asp-filters {
    flex-direction: column;
    align-items: stretch;
  }
  .asp-filters .asp-fg { width: 100%; }
  .asp-filters input,
  .asp-filters select { width: 100%; box-sizing: border-box; }
  .asp-filters button  { width: 100%; }
}

/* ══════════════════════════════════════════════════════════════════
   PWA INSTALL BANNER  v4.5.0
   Fixed bottom bar — slides up when .asp-pwa-banner-show is added.
   Branded: teal bg, gold CTA.
   ══════════════════════════════════════════════════════════════════ */

.asp-pwa-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  background: #194846;
  border-top: 2px solid #c9a84c;
  box-shadow: 0 -4px 20px rgba(0,0,0,0.25);
  padding: 10px 16px 12px;
  transform: translateY(110%);
  transition: transform 0.38s cubic-bezier(0.34, 1.3, 0.64, 1);
  will-change: transform;
  /* Leave room for iOS home indicator */
  padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px));
}

/* When JS adds this class the banner slides into view */
.asp-pwa-banner.asp-pwa-banner-show {
  transform: translateY(0);
}

/* Push bottom-nav up when banner is visible */
.asp-pwa-banner.asp-pwa-banner-show ~ * #asp-bottom-nav,
.asp-bottom-nav {
  transition: bottom 0.38s ease;
}

.asp-pwa-banner-inner {
  display: flex;
  align-items: center;
  gap: 10px;
  max-width: 640px;
  margin: 0 auto;
}

.asp-pwa-banner-icon {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
}

.asp-pwa-banner-icon img {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  display: block;
}

.asp-pwa-banner-body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.asp-pwa-banner-body strong {
  font-size: 14px;
  font-weight: 700;
  color: #c9a84c;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.asp-pwa-banner-body span {
  font-size: 12px;
  color: rgba(255,255,255,0.75);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.asp-pwa-btn-install {
  flex-shrink: 0;
  background: #c9a84c;
  color: #194846;
  border: none;
  border-radius: 8px;
  padding: 8px 16px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.2s, transform 0.15s;
  white-space: nowrap;
}

.asp-pwa-btn-install:hover,
.asp-pwa-btn-install:focus {
  background: #e0bc60;
  transform: scale(1.04);
  outline: none;
}

.asp-pwa-btn-install:active {
  transform: scale(0.97);
}

.asp-pwa-btn-dismiss {
  flex-shrink: 0;
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.5);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 50%;
  transition: color 0.2s, background 0.2s;
}

.asp-pwa-btn-dismiss:hover {
  color: #fff;
  background: rgba(255,255,255,0.12);
}

/* iOS hint row — shown below the main row on Safari/iPhone */
.asp-pwa-ios-hint {
  margin-top: 8px;
  font-size: 12px;
  color: rgba(255,255,255,0.8);
  text-align: center;
  line-height: 1.5;
  padding: 6px 8px;
  background: rgba(255,255,255,0.07);
  border-radius: 6px;
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}

.asp-pwa-ios-hint strong {
  color: #c9a84c;
}

/* When bottom nav is present, add bottom margin so banner
   doesn't sit on top of navigation */
@media (max-width: 640px) {
  .asp-pwa-banner {
    /* Extra bottom padding so it clears the bottom nav (60px tall) */
    padding-bottom: calc(70px + env(safe-area-inset-bottom, 0px));
  }
  /* But if app is in standalone (installed), no bottom nav overlap */
  @media (display-mode: standalone) {
    .asp-pwa-banner {
      padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px));
    }
  }
}
