/* ============================================================
   NurseLink India — Complete Responsive Stylesheet
   Product of Nirogo Technologies Pvt. Ltd.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&family=Fraunces:ital,wght@0,300;0,600;1,300&display=swap');

/* ── VARIABLES ─────────────────────────────────────────────── */
:root {
  --primary:     #1a6b5a;
  --primary-d:   #114a3e;
  --primary-l:   #e6f4f1;
  --accent:      #f5a623;
  --accent-d:    #d4891a;
  --danger:      #e53935;
  --success:     #2e7d32;
  --warn:        #f57c00;
  --text:        #1a1a2e;
  --text-2:      #4a4a6a;
  --text-3:      #7a7a9a;
  --border:      #e0e0f0;
  --bg:          #f7f8fc;
  --white:       #ffffff;
  --shadow-s:    0 2px 8px rgba(0,0,0,.08);
  --shadow-m:    0 4px 20px rgba(0,0,0,.12);
  --shadow-l:    0 8px 40px rgba(0,0,0,.16);
  --radius:      12px;
  --radius-s:    8px;
  --sidebar-w:   240px;
  --nav-h:       64px;
  --font-body:   'DM Sans', sans-serif;
  --font-display:'Fraunces', serif;
}

/* ── RESET ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-tap-highlight-color:transparent; }
body {
  font-family: var(--font-body);
  color: var(--text);
  background: var(--bg);
  line-height: 1.6;
  overflow-x: hidden;
}
img { max-width:100%; display:block; }
a  { color:inherit; text-decoration:none; }
button { cursor:pointer; font-family:var(--font-body); border:none; background:none; }
input, select, textarea { font-family:var(--font-body); }
ul { list-style:none; }

/* ── UTILITY ────────────────────────────────────────────────── */
.hidden   { display:none !important; }
.flex     { display:flex; }
.flex-col { display:flex; flex-direction:column; }
.items-center { align-items:center; }
.justify-between { justify-content:space-between; }
.gap-1    { gap:8px; }
.gap-2    { gap:16px; }
.gap-3    { gap:24px; }
.text-sm  { font-size:.85rem; }
.text-xs  { font-size:.75rem; }
.fw-600   { font-weight:600; }
.text-center { text-align:center; }
.ml-auto  { margin-left:auto; }
.w-full   { width:100%; }
.mt-1     { margin-top:8px; }
.mt-2     { margin-top:16px; }

/* ── TYPOGRAPHY ─────────────────────────────────────────────── */
h1,h2,h3,h4 { font-family:var(--font-display); line-height:1.2; }
.display-lg { font-size:clamp(2rem,5vw,3.6rem); font-weight:600; }
.display-md { font-size:clamp(1.6rem,3vw,2.4rem); font-weight:600; }
.section-label {
  font-size:.78rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--primary); font-weight:600; font-family:var(--font-body);
}

/* ── BUTTONS ────────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:10px 20px; border-radius:8px;
  font-size:.9rem; font-weight:600;
  transition:all .2s; cursor:pointer; border:none;
  white-space:nowrap;
}
.btn-primary { background:var(--primary); color:#fff; }
.btn-primary:hover { background:var(--primary-d); transform:translateY(-1px); box-shadow:var(--shadow-m); }
.btn-outline { background:transparent; color:var(--primary); border:2px solid var(--primary); }
.btn-outline:hover { background:var(--primary-l); }
.btn-accent  { background:var(--accent); color:#fff; }
.btn-accent:hover { background:var(--accent-d); transform:translateY(-1px); }
.btn-ghost   { background:rgba(255,255,255,.15); color:#fff; border:2px solid rgba(255,255,255,.4); }
.btn-ghost:hover { background:rgba(255,255,255,.25); }
.btn-danger  { background:var(--danger); color:#fff; }
.btn-sm      { padding:6px 14px; font-size:.82rem; }
.btn-lg      { padding:14px 28px; font-size:1rem; }
.btn-icon    { padding:8px; border-radius:8px; }
.btn-block   { width:100%; justify-content:center; }

/* ── BADGES / CHIPS ─────────────────────────────────────────── */
.badge {
  display:inline-flex; align-items:center; gap:4px;
  padding:3px 10px; border-radius:20px; font-size:.75rem; font-weight:600;
}
.badge-success { background:#e8f5e9; color:var(--success); }
.badge-warn    { background:#fff3e0; color:var(--warn); }
.badge-danger  { background:#ffebee; color:var(--danger); }
.badge-info    { background:#e3f2fd; color:#1565c0; }
.badge-primary { background:var(--primary-l); color:var(--primary); }
.urgent-tag    { background:#ffebee; color:var(--danger); border-radius:6px; padding:2px 8px; font-size:.72rem; font-weight:700; }

/* ── CARDS ──────────────────────────────────────────────────── */
.card {
  background:var(--white); border-radius:var(--radius);
  box-shadow:var(--shadow-s); border:1px solid var(--border);
  overflow:hidden;
}
.card-body { padding:20px; }
.card-hover:hover { box-shadow:var(--shadow-m); transform:translateY(-2px); transition:all .2s; }

/* ── NAV ────────────────────────────────────────────────────── */
.nl-nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  height:var(--nav-h); background:var(--white);
  border-bottom:1px solid var(--border);
  display:flex; align-items:center;
  padding:0 clamp(16px,4vw,40px);
  gap:24px; box-shadow:var(--shadow-s);
}
.nav-logo {
  display:flex; align-items:center; gap:10px;
  font-family:var(--font-display); font-size:1.3rem; font-weight:600;
  color:var(--primary); white-space:nowrap;
}
.nav-logo-icon {
  width:36px; height:36px; background:var(--primary);
  border-radius:10px; display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:1rem;
}
.nav-links { display:flex; align-items:center; gap:4px; margin-left:auto; }
.nav-link {
  padding:8px 14px; border-radius:8px; font-size:.88rem;
  color:var(--text-2); font-weight:500; transition:all .15s;
  cursor:pointer; white-space:nowrap;
}
.nav-link:hover   { background:var(--bg); color:var(--primary); }
.nav-link.active  { background:var(--primary-l); color:var(--primary); font-weight:600; }
.nav-cta-group    { display:flex; gap:8px; align-items:center; }
.nav-hamburger    { display:none; flex-direction:column; gap:5px; padding:8px; }
.nav-hamburger span { display:block; width:22px; height:2px; background:var(--text); border-radius:2px; transition:.3s; }
.nav-hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity:0; }
.nav-hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Mobile nav drawer */
.nav-mobile-drawer {
  position:fixed; top:var(--nav-h); left:0; right:0; bottom:0;
  background:var(--white); z-index:999; padding:20px;
  transform:translateX(-100%); transition:.3s ease;
  overflow-y:auto;
}
.nav-mobile-drawer.open { transform:translateX(0); }
.nav-mobile-drawer .nav-link { display:block; padding:14px 16px; border-bottom:1px solid var(--border); font-size:1rem; }

/* ── PAGES ──────────────────────────────────────────────────── */
.nl-page { padding-top:var(--nav-h); min-height:100vh; }

/* ── HERO ───────────────────────────────────────────────────── */
.hero {
  background:linear-gradient(135deg, var(--primary-d) 0%, var(--primary) 60%, #2d9b85 100%);
  padding:clamp(60px,10vw,120px) clamp(16px,5vw,60px);
  position:relative; overflow:hidden;
}
.hero::before {
  content:""; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.hero-inner {
  max-width:1100px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr;
  gap:48px; align-items:center; position:relative;
}
.hero-content { color:#fff; }
.hero-eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.3);
  border-radius:20px; padding:6px 14px; font-size:.82rem;
  color:rgba(255,255,255,.9); font-weight:500; margin-bottom:20px;
}
.hero h1 { color:#fff; margin-bottom:20px; }
.hero-sub { font-size:clamp(.95rem,2vw,1.15rem); color:rgba(255,255,255,.85); margin-bottom:32px; max-width:500px; }
.hero-cta-row { display:flex; gap:12px; flex-wrap:wrap; }
.hero-stats {
  display:flex; gap:24px; margin-top:40px; flex-wrap:wrap;
}
.hero-stat-item { text-align:left; }
.hero-stat-item strong { display:block; font-size:1.6rem; font-weight:700; color:#fff; }
.hero-stat-item span  { font-size:.82rem; color:rgba(255,255,255,.75); }
.hero-visual {
  display:flex; flex-direction:column; gap:14px;
}
.hero-card-float {
  background:rgba(255,255,255,.12); backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.2); border-radius:14px;
  padding:16px 20px; color:#fff;
}
.hero-card-float .hcf-title { font-size:.8rem; opacity:.75; margin-bottom:6px; }
.hero-card-float .hcf-val   { font-size:1.4rem; font-weight:700; }
.fill-bar { height:6px; background:rgba(255,255,255,.2); border-radius:3px; margin-top:8px; overflow:hidden; }
.fill-bar-inner { height:100%; background:var(--accent); border-radius:3px; }

/* ── HOW IT WORKS ───────────────────────────────────────────── */
.section { padding:clamp(48px,8vw,96px) clamp(16px,5vw,60px); }
.section-inner { max-width:1100px; margin:0 auto; }
.section-header { text-align:center; margin-bottom:48px; }
.section-header p { color:var(--text-2); max-width:560px; margin:12px auto 0; }

.steps-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.step-card {
  background:var(--white); border-radius:var(--radius); padding:28px 24px;
  border:1px solid var(--border); position:relative; text-align:center;
}
.step-num {
  width:48px; height:48px; border-radius:50%;
  background:var(--primary-l); color:var(--primary);
  font-weight:700; font-size:1.2rem;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 16px;
}
.step-card h3 { font-size:1.05rem; margin-bottom:8px; }
.step-card p  { font-size:.88rem; color:var(--text-2); }

/* ── FEATURES ───────────────────────────────────────────────── */
.features-bg { background:var(--primary-l); }
.features-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.feature-item {
  background:var(--white); border-radius:var(--radius); padding:24px;
  border:1px solid var(--border);
}
.feature-icon {
  width:44px; height:44px; border-radius:10px;
  background:var(--primary-l); color:var(--primary);
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; margin-bottom:14px;
}
.feature-item h4 { font-size:.95rem; margin-bottom:6px; }
.feature-item p  { font-size:.85rem; color:var(--text-2); }

/* ── DUAL CTA ───────────────────────────────────────────────── */
.dual-cta-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.dual-cta-card {
  border-radius:var(--radius); padding:clamp(24px,4vw,48px);
  position:relative; overflow:hidden;
}
.dual-cta-card.nurse-card    { background:linear-gradient(135deg,var(--primary),var(--primary-d)); color:#fff; }
.dual-cta-card.hospital-card { background:linear-gradient(135deg,#1a3c6b,#0d2240); color:#fff; }
.dual-cta-card h2   { color:#fff; margin-bottom:12px; }
.dual-cta-card p    { color:rgba(255,255,255,.8); margin-bottom:24px; font-size:.92rem; }
.dual-cta-badge {
  display:inline-block; background:rgba(255,255,255,.2);
  border-radius:6px; padding:3px 10px; font-size:.75rem;
  font-weight:600; margin-bottom:12px; letter-spacing:.05em;
}

/* ── TESTIMONIALS ───────────────────────────────────────────── */
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.testimonial-card  { background:var(--white); border-radius:var(--radius); padding:24px; border:1px solid var(--border); }
.testimonial-stars { color:var(--accent); font-size:1rem; margin-bottom:10px; }
.testimonial-text  { font-size:.88rem; color:var(--text-2); margin-bottom:16px; font-style:italic; }
.testimonial-author { display:flex; align-items:center; gap:10px; }
.testimonial-avatar {
  width:40px; height:40px; border-radius:50%;
  background:var(--primary-l); color:var(--primary);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:.9rem;
}
.testimonial-author-info strong { display:block; font-size:.88rem; }
.testimonial-author-info span   { font-size:.78rem; color:var(--text-3); }

/* ── FOOTER ─────────────────────────────────────────────────── */
.site-footer {
  background:var(--text); color:rgba(255,255,255,.75);
  padding:clamp(40px,6vw,64px) clamp(16px,5vw,60px) 24px;
}
.footer-inner { max-width:1100px; margin:0 auto; }
.footer-top {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:40px; margin-bottom:40px;
}
.footer-brand h3     { font-family:var(--font-display); color:#fff; font-size:1.2rem; margin-bottom:8px; }
.footer-brand p      { font-size:.85rem; line-height:1.7; max-width:280px; }
.footer-brand .nirogo-credit { font-size:.78rem; margin-top:12px; color:rgba(255,255,255,.5); }
.footer-col h4       { color:#fff; font-size:.85rem; font-weight:600; margin-bottom:14px; letter-spacing:.05em; text-transform:uppercase; }
.footer-col a        { display:block; font-size:.85rem; color:rgba(255,255,255,.65); margin-bottom:8px; transition:.15s; }
.footer-col a:hover  { color:#fff; }
.footer-divider      { border:none; border-top:1px solid rgba(255,255,255,.1); margin-bottom:20px; }
.footer-bottom       { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.footer-bottom p     { font-size:.78rem; }
.footer-badges       { display:flex; gap:8px; flex-wrap:wrap; }
.footer-badge        { background:rgba(255,255,255,.08); border-radius:6px; padding:4px 10px; font-size:.72rem; color:rgba(255,255,255,.6); }

/* ── DASHBOARD LAYOUT ───────────────────────────────────────── */
.dash-layout {
  display:flex; min-height:calc(100vh - var(--nav-h));
  padding-top:var(--nav-h); /* already done by .nl-page, handled per page */
}
.dash-sidebar {
  width:var(--sidebar-w); flex-shrink:0;
  background:var(--white); border-right:1px solid var(--border);
  position:fixed; top:var(--nav-h); left:0; bottom:0;
  overflow-y:auto; z-index:100;
  transition:transform .3s;
}
.dash-sidebar-header { padding:20px 16px 12px; border-bottom:1px solid var(--border); }
.dash-sidebar-header .role-label { font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; color:var(--text-3); }
.dash-sidebar-header .dash-name  { font-weight:600; font-size:.95rem; margin-top:2px; }
.dash-nav { padding:12px 8px; }
.dash-nav-item {
  display:flex; align-items:center; gap:10px;
  padding:10px 12px; border-radius:8px; margin-bottom:2px;
  font-size:.88rem; font-weight:500; color:var(--text-2);
  cursor:pointer; transition:.15s;
}
.dash-nav-item:hover  { background:var(--bg); color:var(--primary); }
.dash-nav-item.active { background:var(--primary-l); color:var(--primary); font-weight:600; }
.dash-nav-item .icon  { width:18px; text-align:center; font-size:1rem; }
.dash-main { margin-left:var(--sidebar-w); flex:1; padding:clamp(16px,3vw,32px); }
.dash-panel-title { font-family:var(--font-display); font-size:1.5rem; margin-bottom:4px; }
.dash-panel-sub   { font-size:.88rem; color:var(--text-2); margin-bottom:24px; }

/* Sidebar overlay for mobile */
.sidebar-overlay {
  display:none; position:fixed; inset:0; background:rgba(0,0,0,.4);
  z-index:99; top:var(--nav-h);
}
.sidebar-overlay.show { display:block; }

/* Mobile sidebar toggle btn */
.sidebar-toggle-btn {
  display:none; position:fixed; bottom:24px; right:24px;
  width:52px; height:52px; border-radius:50%;
  background:var(--primary); color:#fff;
  box-shadow:var(--shadow-m); font-size:1.3rem;
  align-items:center; justify-content:center; z-index:200;
}

/* ── STAT CARDS ─────────────────────────────────────────────── */
.stats-row { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:24px; }
.stat-card { background:var(--white); border-radius:var(--radius); padding:20px; border:1px solid var(--border); }
.stat-card .stat-label { font-size:.78rem; color:var(--text-3); margin-bottom:4px; font-weight:500; text-transform:uppercase; letter-spacing:.05em; }
.stat-card .stat-value { font-size:1.8rem; font-weight:700; color:var(--text); font-family:var(--font-display); }
.stat-card .stat-change{ font-size:.78rem; color:var(--success); margin-top:4px; }
.stat-card .stat-icon  { float:right; font-size:1.4rem; margin-top:-28px; opacity:.3; }

/* ── SHIFT CARDS ────────────────────────────────────────────── */
.shift-grid    { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:16px; }
.shift-card    { background:var(--white); border-radius:var(--radius); border:1px solid var(--border); padding:20px; transition:.2s; }
.shift-card:hover { box-shadow:var(--shadow-m); border-color:var(--primary); }
.shift-card-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:12px; }
.shift-title   { font-weight:600; font-size:1rem; margin-bottom:2px; }
.shift-hospital{ font-size:.82rem; color:var(--text-2); }
.shift-meta    { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:14px; }
.shift-meta-item { display:flex; align-items:center; gap:5px; font-size:.8rem; color:var(--text-2); }
.shift-pay     { font-size:1.2rem; font-weight:700; color:var(--primary); }
.shift-pay-label { font-size:.75rem; color:var(--text-3); }
.shift-actions { display:flex; gap:8px; margin-top:14px; flex-wrap:wrap; }

/* ── NURSE CARDS ────────────────────────────────────────────── */
.nurse-grid  { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:16px; }
.nurse-card  { background:var(--white); border-radius:var(--radius); border:1px solid var(--border); padding:20px; text-align:center; transition:.2s; }
.nurse-card:hover { box-shadow:var(--shadow-m); }
.nurse-avatar {
  width:64px; height:64px; border-radius:50%;
  background:var(--primary-l); color:var(--primary);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:1.3rem; margin:0 auto 12px;
}
.nurse-name  { font-weight:600; font-size:1rem; margin-bottom:4px; }
.nurse-spec  { font-size:.82rem; color:var(--text-2); margin-bottom:8px; }
.nurse-stats-row { display:flex; justify-content:center; gap:16px; margin-bottom:14px; }
.nurse-stat  { text-align:center; }
.nurse-stat strong { display:block; font-size:1rem; font-weight:700; }
.nurse-stat span   { font-size:.72rem; color:var(--text-3); }
.nurse-skills { display:flex; flex-wrap:wrap; gap:4px; justify-content:center; margin-bottom:14px; }
.skill-tag { background:var(--primary-l); color:var(--primary); font-size:.72rem; padding:3px 8px; border-radius:20px; font-weight:500; }

/* ── FILTERS BAR ────────────────────────────────────────────── */
.filters-bar { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:20px; }
.filters-bar select, .filters-bar input {
  padding:8px 12px; border:1px solid var(--border); border-radius:8px;
  font-size:.85rem; background:var(--white); color:var(--text);
  min-width:130px; outline:none;
}
.filters-bar select:focus, .filters-bar input:focus { border-color:var(--primary); }

/* ── FORM ───────────────────────────────────────────────────── */
.form-grid  { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-group.full { grid-column:1/-1; }
.form-label { font-size:.85rem; font-weight:600; color:var(--text); }
.form-input {
  width:100%; padding:10px 14px; border:1.5px solid var(--border);
  border-radius:8px; font-size:.9rem; color:var(--text);
  background:var(--white); outline:none; transition:.15s;
}
.form-input:focus { border-color:var(--primary); box-shadow:0 0 0 3px var(--primary-l); }
.form-select { appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%234a4a6a'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 12px center; padding-right:32px; }
.form-section { margin-bottom:28px; }
.form-section h3 { font-size:1rem; margin-bottom:16px; padding-bottom:8px; border-bottom:1px solid var(--border); }

/* ── MODALS ─────────────────────────────────────────────────── */
.modal-backdrop {
  position:fixed; inset:0; background:rgba(0,0,0,.55);
  z-index:2000; display:flex; align-items:center; justify-content:center;
  padding:16px;
}
.modal-box {
  background:var(--white); border-radius:16px;
  width:100%; max-width:440px; max-height:90vh; overflow-y:auto;
  box-shadow:var(--shadow-l); position:relative;
}
.modal-header {
  padding:24px 24px 0; display:flex;
  justify-content:space-between; align-items:center;
  margin-bottom:20px;
}
.modal-header h2 { font-size:1.3rem; }
.modal-close { font-size:1.4rem; color:var(--text-3); cursor:pointer; padding:4px; }
.modal-close:hover { color:var(--text); }
.modal-body { padding:0 24px 24px; }
.modal-tabs { display:flex; gap:0; border-bottom:1px solid var(--border); margin-bottom:20px; }
.modal-tab {
  flex:1; padding:10px; text-align:center; font-size:.88rem;
  font-weight:600; cursor:pointer; border-bottom:2px solid transparent;
  color:var(--text-3); transition:.15s;
}
.modal-tab.active { color:var(--primary); border-bottom-color:var(--primary); }
.form-error { color:var(--danger); font-size:.82rem; margin-top:4px; display:block; }

/* ── TABLES ─────────────────────────────────────────────────── */
.table-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch; }
.data-table { width:100%; border-collapse:collapse; font-size:.88rem; }
.data-table th { background:var(--bg); padding:10px 14px; text-align:left; font-weight:600; font-size:.78rem; text-transform:uppercase; letter-spacing:.05em; color:var(--text-3); border-bottom:1px solid var(--border); white-space:nowrap; }
.data-table td { padding:12px 14px; border-bottom:1px solid var(--border); vertical-align:middle; }
.data-table tr:last-child td { border-bottom:none; }
.data-table tr:hover td { background:var(--bg); }

/* ── PROFILE ────────────────────────────────────────────────── */
.profile-header {
  background:linear-gradient(135deg,var(--primary-d),var(--primary));
  border-radius:var(--radius); padding:28px; color:#fff; margin-bottom:20px;
  display:flex; align-items:center; gap:20px;
}
.profile-avatar-lg {
  width:72px; height:72px; border-radius:50%;
  background:rgba(255,255,255,.2); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:1.6rem; font-weight:700; flex-shrink:0;
}
.profile-header h2 { color:#fff; font-size:1.4rem; }
.profile-header p  { color:rgba(255,255,255,.8); font-size:.88rem; margin-top:4px; }

/* ── NOTIFICATIONS ──────────────────────────────────────────── */
.notif-list { display:flex; flex-direction:column; gap:10px; }
.notif-item {
  background:var(--white); border-radius:var(--radius);
  border:1px solid var(--border); padding:14px 16px;
  display:flex; align-items:flex-start; gap:12px;
}
.notif-item.unread { border-left:3px solid var(--primary); background:var(--primary-l); }
.notif-icon { font-size:1.2rem; flex-shrink:0; margin-top:2px; }
.notif-text { font-size:.88rem; color:var(--text); }
.notif-time { font-size:.75rem; color:var(--text-3); margin-top:3px; }

/* ── TOAST ──────────────────────────────────────────────────── */
.toast-container {
  position:fixed; bottom:24px; right:24px; z-index:9999;
  display:flex; flex-direction:column; gap:8px; pointer-events:none;
}
.toast {
  background:var(--text); color:#fff; padding:12px 20px;
  border-radius:10px; font-size:.88rem; box-shadow:var(--shadow-l);
  animation:toastIn .3s ease; max-width:320px; pointer-events:all;
}
.toast.success { background:var(--success); }
.toast.error   { background:var(--danger); }
@keyframes toastIn { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }

/* ── RATING MODAL ───────────────────────────────────────────── */
.rating-stars-input { display:flex; gap:8px; font-size:2rem; margin:16px 0; }
.rating-star { cursor:pointer; color:var(--border); transition:.15s; }
.rating-star.active, .rating-star:hover { color:var(--accent); }

/* ── COMPANY / LEGAL PAGES ──────────────────────────────────── */
.company-page { max-width:780px; margin:0 auto; padding:clamp(24px,4vw,48px) clamp(16px,4vw,40px); }
.company-page h1 { margin-bottom:8px; }
.company-page .meta { color:var(--text-3); font-size:.85rem; margin-bottom:32px; }
.company-page h2 { font-size:1.15rem; margin:28px 0 10px; color:var(--primary-d); }
.company-page h3 { font-size:1rem; margin:20px 0 8px; }
.company-page p  { color:var(--text-2); margin-bottom:12px; line-height:1.75; }
.company-page ul { padding-left:20px; margin-bottom:12px; }
.company-page ul li { color:var(--text-2); font-size:.92rem; margin-bottom:6px; list-style:disc; line-height:1.6; }
.company-page a  { color:var(--primary); text-decoration:underline; }
.legal-box { background:var(--primary-l); border-radius:var(--radius); padding:20px; margin-bottom:24px; border-left:4px solid var(--primary); }
.legal-box p { margin:0; color:var(--primary-d); font-weight:500; }
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin:24px 0; }
.contact-card { background:var(--white); border-radius:var(--radius); border:1px solid var(--border); padding:20px; }
.contact-card h4 { font-size:.85rem; text-transform:uppercase; letter-spacing:.05em; color:var(--text-3); margin-bottom:6px; }
.contact-card a  { color:var(--primary); font-weight:600; text-decoration:none; }
.pricing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin:24px 0; }
.pricing-card { background:var(--white); border-radius:var(--radius); border:2px solid var(--border); padding:24px; text-align:center; }
.pricing-card.featured { border-color:var(--primary); position:relative; }
.pricing-card .plan-name { font-weight:700; font-size:.95rem; text-transform:uppercase; letter-spacing:.08em; margin-bottom:8px; }
.pricing-card .plan-price { font-size:2rem; font-weight:700; font-family:var(--font-display); color:var(--primary); }
.pricing-card .plan-period { font-size:.78rem; color:var(--text-3); margin-bottom:16px; }
.pricing-card ul { text-align:left; margin:0 0 20px; }
.pricing-card ul li { font-size:.85rem; padding:5px 0; border-bottom:1px solid var(--border); color:var(--text-2); list-style:none; }
.pricing-card ul li::before { content:"✓ "; color:var(--success); font-weight:700; }
.careers-grid { display:grid; gap:16px; margin:24px 0; }
.career-card { background:var(--white); border-radius:var(--radius); border:1px solid var(--border); padding:20px; display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.career-card h4 { font-size:1rem; margin-bottom:4px; }
.career-card p  { font-size:.85rem; color:var(--text-2); margin:0; }

/* ── LOADING ────────────────────────────────────────────────── */
.spinner { display:inline-block; width:20px; height:20px; border:2px solid rgba(255,255,255,.3); border-top-color:#fff; border-radius:50%; animation:spin .6s linear infinite; }
@keyframes spin { to{transform:rotate(360deg)} }
.loading-state { text-align:center; padding:48px 20px; color:var(--text-3); }

/* ── EMPTY STATE ────────────────────────────────────────────── */
.empty-state { text-align:center; padding:48px 20px; }
.empty-icon  { font-size:3rem; margin-bottom:12px; }
.empty-state h3 { font-size:1.1rem; margin-bottom:8px; }
.empty-state p  { font-size:.88rem; color:var(--text-2); }

/* ── NMC VERIFICATION ───────────────────────────────────────── */
.nmc-verify-box {
  background:var(--primary-l); border-radius:var(--radius);
  padding:16px; margin-top:12px; display:flex;
  align-items:center; gap:10px;
}
.nmc-verify-box.success { background:#e8f5e9; }
.nmc-verify-box.error   { background:#ffebee; }
.nmc-verify-icon { font-size:1.4rem; }
.nmc-verify-text strong { display:block; font-size:.88rem; }
.nmc-verify-text span   { font-size:.78rem; color:var(--text-3); }

/* ── EARNINGS ───────────────────────────────────────────────── */
.earnings-summary {
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-bottom:20px;
}
.earn-card { background:var(--white); border-radius:var(--radius); border:1px solid var(--border); padding:20px; text-align:center; }
.earn-card .earn-val { font-size:1.8rem; font-weight:700; color:var(--primary); font-family:var(--font-display); }
.earn-card .earn-label { font-size:.8rem; color:var(--text-3); margin-top:4px; }

/* ── RESPONSIVE ─────────────────────────────────────────────── */

/* 1100px - tighten grid */
@media (max-width:1100px) {
  .footer-top { grid-template-columns:1fr 1fr; }
  .stats-row  { grid-template-columns:repeat(2,1fr); }
}

/* 900px - tablet */
@media (max-width:900px) {
  .hero-inner    { grid-template-columns:1fr; }
  .hero-visual   { display:none; }
  .steps-grid    { grid-template-columns:1fr 1fr; }
  .features-grid { grid-template-columns:1fr 1fr; }
  .dual-cta-grid { grid-template-columns:1fr; }
  .testimonials-grid { grid-template-columns:1fr 1fr; }
  .pricing-grid  { grid-template-columns:1fr; }
  .contact-grid  { grid-template-columns:1fr; }
  .earnings-summary { grid-template-columns:1fr 1fr; }
  /* Sidebar collapse */
  .dash-sidebar {
    transform:translateX(-100%);
  }
  .dash-sidebar.mobile-open {
    transform:translateX(0);
    box-shadow:var(--shadow-l);
  }
  .dash-main { margin-left:0; }
  .sidebar-toggle-btn { display:flex; }
  /* Nav */
  .nav-links .nav-link { display:none; }
  .nav-hamburger { display:flex; }
  .nav-cta-group .btn { display:none; }
  .nav-cta-group .btn:last-child { display:inline-flex; }
}

/* 640px - mobile */
@media (max-width:640px) {
  .steps-grid    { grid-template-columns:1fr; }
  .features-grid { grid-template-columns:1fr; }
  .testimonials-grid { grid-template-columns:1fr; }
  .form-grid     { grid-template-columns:1fr; }
  .stats-row     { grid-template-columns:1fr 1fr; }
  .earnings-summary { grid-template-columns:1fr; }
  .footer-top    { grid-template-columns:1fr; gap:24px; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .hero-cta-row  { flex-direction:column; }
  .hero-cta-row .btn { width:100%; justify-content:center; }
  .hero-stats    { gap:16px; }
  .modal-box     { max-width:100%; border-radius:12px 12px 0 0; position:fixed; bottom:0; left:0; right:0; max-height:85vh; }
  .modal-backdrop { align-items:flex-end; padding:0; }
  .shift-grid    { grid-template-columns:1fr; }
  .nurse-grid    { grid-template-columns:1fr; }
  .dual-cta-card { padding:24px; }
  .company-page  { padding:24px 16px; }
  .career-card   { flex-direction:column; align-items:flex-start; }
}

/* 380px - very small */
@media (max-width:380px) {
  .stats-row  { grid-template-columns:1fr; }
  .btn-block-xs { width:100%; justify-content:center; }
}
