/* ── RxVoice — Professional Medical UI v3 ────────────────────────── */
:root {
  --bg: #f0f2f5;
  --surface: #ffffff;
  --surface2: #f8f9fb;
  --border: #e4e7ec;
  --text: #1a1d23;
  --text-2: #5a6272;
  --text-3: #9aa0b0;

  --primary: #1a5276;
  --primary-light: #d6e8f5;
  --primary-dark: #0f3352;
  --primary-mid: #2471a3;

  --doctor: #1a4d3e;
  --doctor-light: #d4ede5;

  --success: #1a5c2e;
  --success-light: #d4edda;
  --warning: #7a4b00;
  --warning-light: #fff3cd;
  --error: #7a1a1a;
  --error-light: #fde8e8;
  --info: #1a3a7a;
  --info-light: #d4e3fa;

  --radius: 10px;
  --radius-lg: 16px;
  --shadow: 0 1px 3px rgba(0,0,0,.07),0 4px 16px rgba(0,0,0,.05);
  --shadow-lg: 0 4px 24px rgba(0,0,0,.10);

  --font-serif: 'DM Serif Display',Georgia,serif;
  --font-sans: 'DM Sans',system-ui,sans-serif;

  /* Sidebar */
  --sb-width: 240px;
  --sb-bg: #0f1f2e;
  --sb-border: rgba(255,255,255,.08);
  --sb-text: rgba(255,255,255,.82);
  --sb-text-muted: rgba(255,255,255,.42);
  --sb-active-bg: rgba(255,255,255,.12);
  --sb-hover-bg: rgba(255,255,255,.07);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;}
body{font-family:var(--font-sans);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;display:flex;flex-direction:column;}

/* ══ SIDEBAR SHELL ═══════════════════════════════════════════════ */
.app-shell{display:flex;min-height:100vh;}

.sidebar{
  width:var(--sb-width);flex-shrink:0;
  background:var(--sb-bg);
  display:flex;flex-direction:column;
  position:fixed;left:0;top:0;height:100vh;
  z-index:200;overflow:hidden;
  transition:transform .25s ease;
}
.sidebar-brand{
  padding:20px 18px 16px;
  border-bottom:1px solid var(--sb-border);
  flex-shrink:0;
}
.sidebar-brand-link{display:flex;align-items:center;gap:10px;text-decoration:none;}
.sidebar-brand-icon{font-size:1.4rem;}
.sidebar-brand-name{font-family:var(--font-serif);font-size:1.25rem;color:#fff;letter-spacing:-.3px;}

.sidebar-nav{flex:1;overflow-y:auto;padding:12px 10px;scrollbar-width:none;}
.sidebar-nav::-webkit-scrollbar{display:none;}

.nav-group-label{
  font-size:.65rem;font-weight:800;letter-spacing:.1em;
  text-transform:uppercase;color:var(--sb-text-muted);
  padding:12px 10px 5px;margin-top:4px;
}
.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 10px;border-radius:8px;
  text-decoration:none;color:var(--sb-text);
  font-size:.875rem;font-weight:500;
  transition:background .15s,color .15s;
  cursor:pointer;margin-bottom:2px;
}
.nav-item:hover{background:var(--sb-hover-bg);color:#fff;}
.nav-item.active{background:var(--sb-active-bg);color:#fff;font-weight:700;}
.nav-item.active .ni{opacity:1;}
.ni{font-size:1rem;width:20px;text-align:center;flex-shrink:0;opacity:.8;}
.nav-logout{color:rgba(231,76,60,.8)!important;}
.nav-logout:hover{background:rgba(231,76,60,.12)!important;color:#e74c3c!important;}

.sidebar-footer{
  border-top:1px solid var(--sb-border);
  padding:12px 10px;flex-shrink:0;
}
.sidebar-user-chip{
  display:flex;align-items:center;gap:10px;
  padding:8px 10px;margin-bottom:6px;border-radius:8px;
  background:rgba(255,255,255,.05);
}
.suc-avatar{
  width:32px;height:32px;border-radius:8px;
  background:var(--primary-mid);color:#fff;
  font-size:.85rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.suc-info{min-width:0;}
.suc-role{font-size:.75rem;font-weight:700;color:#fff;line-height:1.2;}
.suc-email{font-size:.68rem;color:var(--sb-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

.app-content{
  margin-left:var(--sb-width);
  flex:1;display:flex;flex-direction:column;min-height:100vh;
}

/* Mobile sidebar */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:199;}
.sidebar-overlay.show{display:block;}
.topbar-mobile{display:none;align-items:center;gap:14px;padding:14px 18px;background:var(--sb-bg);position:sticky;top:0;z-index:198;}
.topbar-btn{background:none;border:none;color:#fff;font-size:1.3rem;cursor:pointer;padding:4px;}
.topbar-title{font-family:var(--font-serif);color:#fff;font-size:1.1rem;}

@media(max-width:900px){
  .sidebar{transform:translateX(-100%);}
  .sidebar.open{transform:translateX(0);}
  .app-content{margin-left:0;}
  .topbar-mobile{display:flex;}
}

/* ══ NAVBAR (public/guest) ════════════════════════════════════════ */
.navbar{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;box-shadow:0 1px 0 rgba(0,0,0,.06);}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);}
.brand-icon{font-size:1.5rem;}
.brand-name{font-family:var(--font-serif);font-size:1.4rem;color:var(--primary);letter-spacing:-.5px;}
.nav-links{display:flex;align-items:center;gap:8px;}
.nav-links a{text-decoration:none;color:var(--text-2);font-size:.9rem;font-weight:500;padding:6px 12px;border-radius:6px;transition:background .15s,color .15s;}
.nav-links a:hover{background:var(--bg);color:var(--text);}
.btn-logout{background:var(--bg)!important;border:1px solid var(--border);color:var(--error)!important;}

/* ══ MAIN CONTENT ════════════════════════════════════════════════ */
.main-content{flex:1;}
.page-wrap{max-width:1280px;margin:0 auto;padding:28px 24px;}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;}
.page-header h2{font-family:var(--font-serif);font-size:1.75rem;color:var(--text);line-height:1.2;}
.page-sub{color:var(--text-2);font-size:.88rem;margin-top:3px;}

/* ══ DASHBOARD STATS ══════════════════════════════════════════════ */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;}
.kpi-card{
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--radius);padding:16px 18px;
  display:flex;align-items:center;gap:14px;
  text-decoration:none;color:inherit;
  transition:box-shadow .15s,transform .15s,border-color .15s;
  position:relative;overflow:hidden;
}
.kpi-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--kpi-color,var(--primary));}
.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--kpi-color,var(--primary));}
.kpi-icon{font-size:1.6rem;flex-shrink:0;}
.kpi-body{min-width:0;}
.kpi-num{font-family:var(--font-serif);font-size:1.7rem;line-height:1;color:var(--kpi-color,var(--primary));}
.kpi-label{font-size:.72rem;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;margin-top:2px;}
.kpi-delta{font-size:.7rem;color:var(--success);font-weight:700;display:flex;align-items:center;gap:3px;margin-top:3px;}
.kpi-delta.down{color:var(--error);}

.kpi-blue{--kpi-color:#2563eb;} .kpi-green{--kpi-color:#16a34a;} .kpi-purple{--kpi-color:#7c3aed;}
.kpi-orange{--kpi-color:#d97706;} .kpi-teal{--kpi-color:#0891b2;} .kpi-rose{--kpi-color:#e11d48;}
.kpi-cyan{--kpi-color:#0e7490;} .kpi-amber{--kpi-color:#b45309;}

@media(max-width:1100px){.kpi-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:768px){.kpi-grid{grid-template-columns:repeat(2,1fr);}}

/* Dashboard panels */
.dash-row{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:16px;}
.dash-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:16px;}
@media(max-width:1100px){.dash-row{grid-template-columns:1fr;}.dash-row-3{grid-template-columns:1fr 1fr;}}
@media(max-width:768px){.dash-row-3{grid-template-columns:1fr;}}

.panel{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;}
.panel-hdr{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--border);background:var(--surface2);}
.panel-hdr h3{font-size:.9rem;font-weight:700;color:var(--text);margin:0;}
.panel-body{padding:14px 16px;}

/* Mini progress / chart bars */
.mini-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:.82rem;}
.mini-bar-label{width:90px;flex-shrink:0;color:var(--text-2);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.mini-bar-track{flex:1;height:6px;background:var(--bg);border-radius:3px;overflow:hidden;}
.mini-bar-fill{height:100%;border-radius:3px;background:var(--primary);}
.mini-bar-val{width:35px;text-align:right;font-weight:700;color:var(--text);flex-shrink:0;}

.activity-item{display:flex;gap:10px;padding:9px 0;border-bottom:1px solid var(--bg);align-items:flex-start;}
.activity-item:last-child{border-bottom:none;}
.activity-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);flex-shrink:0;margin-top:6px;}
.activity-dot.green{background:#16a34a;}.activity-dot.orange{background:#d97706;}.activity-dot.purple{background:#7c3aed;}
.activity-text{font-size:.82rem;color:var(--text-2);line-height:1.4;}
.activity-time{font-size:.72rem;color:var(--text-3);margin-top:2px;}

/* Donut placeholder */
.donut-wrap{display:flex;flex-direction:column;align-items:center;gap:10px;padding:10px 0;}
.donut-svg{width:100px;height:100px;}
.donut-legend{width:100%;display:flex;flex-direction:column;gap:5px;}
.donut-leg-row{display:flex;align-items:center;gap:7px;font-size:.78rem;}
.donut-leg-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}

/* Quick actions */
.quick-acts{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px;}

/* ══ REPORTS ══════════════════════════════════════════════════════ */
.report-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:20px;}
.report-tab{padding:8px 16px;border-radius:8px;border:1.5px solid var(--border);background:var(--surface);font-size:.85rem;font-weight:600;cursor:pointer;color:var(--text-2);transition:all .15s;}
.report-tab.active,.report-tab:hover{background:var(--primary);color:#fff;border-color:var(--primary);}
.report-section{display:none;}.report-section.active{display:block;}

/* Horizontal bar chart */
.h-bar-chart{display:flex;flex-direction:column;gap:10px;padding:8px 0;}
.h-bar-row{display:grid;grid-template-columns:140px 1fr 50px;align-items:center;gap:10px;font-size:.82rem;}
.h-bar-name{font-weight:600;color:var(--text-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.h-bar-track{height:22px;background:var(--bg);border-radius:4px;overflow:hidden;position:relative;}
.h-bar-fill{height:100%;border-radius:4px;display:flex;align-items:center;padding-left:8px;font-size:.72rem;font-weight:700;color:#fff;transition:width .8s ease;}
.h-bar-count{font-weight:800;color:var(--text);text-align:right;}

/* Stat comparison */
.stat-compare-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
.stat-compare-card{text-align:center;padding:16px;background:var(--surface2);border-radius:var(--radius);border:1px solid var(--border);}
.stat-compare-num{font-family:var(--font-serif);font-size:1.8rem;color:var(--primary);}
.stat-compare-label{font-size:.72rem;font-weight:700;text-transform:uppercase;color:var(--text-2);letter-spacing:.05em;margin-top:4px;}

/* ══ AVAILABILITY SLOTS ════════════════════════════════════════════ */
.availability-slots-wrap{display:flex;flex-direction:column;gap:10px;}
.avail-slot-row{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:10px;align-items:center;padding:12px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);}
.avail-slot-row .field{margin-bottom:0;}
.btn-remove-slot{background:var(--error-light);color:var(--error);border:none;border-radius:6px;width:32px;height:32px;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.btn-add-slot{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;color:var(--primary);background:var(--primary-light);border:none;border-radius:8px;padding:9px 16px;cursor:pointer;}

/* ══ MEDICAL HISTORY ═══════════════════════════════════════════════ */
.history-timeline{display:flex;flex-direction:column;gap:0;position:relative;}
.history-timeline::before{content:'';position:absolute;left:18px;top:0;bottom:0;width:2px;background:var(--border);}
.timeline-item{display:flex;gap:16px;padding-bottom:20px;position:relative;}
.timeline-dot{width:38px;height:38px;border-radius:50%;background:var(--primary-light);border:3px solid var(--primary);display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0;z-index:1;margin-top:2px;}
.timeline-card{flex:1;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:14px 16px;}
.timeline-date{font-size:.72rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;}
.timeline-title{font-weight:700;color:var(--text);font-size:.92rem;margin-bottom:4px;}
.timeline-desc{font-size:.83rem;color:var(--text-2);line-height:1.5;}

/* History summary pills */
.history-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px;}
.history-chip{padding:5px 12px;border-radius:50px;font-size:.78rem;font-weight:700;background:var(--primary-light);color:var(--primary);border:1px solid #c2d8ec;}

/* ══ DOCTOR APPLICATION FORM ══════════════════════════════════════ */
.apply-hero{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);padding:48px 24px;text-align:center;color:#fff;}
.apply-hero h1{font-family:var(--font-serif);font-size:2rem;margin-bottom:8px;}
.apply-hero p{opacity:.8;font-size:.95rem;}
.apply-wrap{max-width:760px;margin:0 auto;padding:32px 24px;}

/* Application cards (admin list) */
.app-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:16px 20px;display:flex;align-items:center;gap:16px;margin-bottom:12px;}
.app-card-avatar{width:48px;height:48px;border-radius:50%;background:var(--primary-light);color:var(--primary);font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.app-card-body{flex:1;}
.app-card-name{font-weight:700;font-size:.95rem;color:var(--text);}
.app-card-meta{font-size:.8rem;color:var(--text-2);margin-top:2px;}
.app-card-actions{display:flex;gap:8px;}
.badge-pending-app{background:#fef3c7;color:#92400e;padding:3px 10px;border-radius:50px;font-size:.72rem;font-weight:700;}
.badge-approved-app{background:var(--success-light);color:var(--success);padding:3px 10px;border-radius:50px;font-size:.72rem;font-weight:700;}
.badge-rejected-app{background:var(--error-light);color:var(--error);padding:3px 10px;border-radius:50px;font-size:.72rem;font-weight:700;}

/* ══ AUTH ═════════════════════════════════════════════════════════ */
.auth-wrap{min-height:calc(100vh - 60px);display:flex;align-items:center;justify-content:center;padding:32px 16px;background:linear-gradient(135deg,#e8f0f7 0%,#f5f4f0 50%,#e8f4ee 100%);}
.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:40px;width:100%;max-width:440px;}
.auth-brand{text-align:center;margin-bottom:32px;}
.auth-icon{font-size:2.5rem;display:block;margin-bottom:8px;}
.auth-brand h1{font-family:var(--font-serif);font-size:1.8rem;color:var(--primary);margin-bottom:4px;}
.auth-brand p{color:var(--text-2);font-size:.9rem;}
.auth-footer{text-align:center;margin-top:20px;font-size:.9rem;color:var(--text-2);}
.auth-footer a{color:var(--primary);font-weight:600;}
.demo-box{margin-top:24px;padding:14px 16px;background:var(--primary-light);border:1px solid #c2d8ec;border-radius:8px;font-size:.85rem;}
.demo-box strong{display:block;margin-bottom:8px;color:var(--primary);}
.demo-creds{display:flex;flex-direction:column;gap:4px;color:var(--primary-dark);font-family:monospace;}

/* ══ FORMS ════════════════════════════════════════════════════════ */
.field{margin-bottom:16px;}
.field label{display:block;font-size:.82rem;font-weight:700;color:var(--text-2);margin-bottom:5px;text-transform:uppercase;letter-spacing:.04em;}
.field input,.field select,.field textarea{width:100%;padding:9px 13px;border:1.5px solid var(--border);border-radius:8px;font-family:var(--font-sans);font-size:.93rem;background:var(--surface);color:var(--text);transition:border-color .15s,box-shadow .15s;outline:none;}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);}
.field textarea{resize:vertical;}
.field-hint{font-size:.78rem;color:var(--text-3);margin-left:8px;font-weight:400;text-transform:none;}
.field-opt{font-size:.78rem;color:var(--text-3);font-weight:400;text-transform:none;}
.req{color:var(--error);}
.field-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(175px,1fr));gap:14px;}
.form-section{font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--primary);margin:24px 0 12px;padding-top:20px;border-top:1px solid var(--border);}
.form-section:first-child{margin-top:0;padding-top:0;border-top:none;}
.form-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow);}
.form-actions{display:flex;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border);}

/* ══ BUTTONS ══════════════════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 20px;border-radius:8px;font-size:.88rem;font-weight:700;text-decoration:none;border:1.5px solid transparent;cursor:pointer;transition:all .15s;font-family:var(--font-sans);}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);}
.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);}
.btn-secondary{background:var(--surface);color:var(--text-2);border-color:var(--border);}
.btn-secondary:hover{background:var(--bg);color:var(--text);}
.btn-ghost{background:transparent;color:var(--text-2);border-color:transparent;}
.btn-ghost:hover{background:var(--bg);color:var(--text);}
.btn-success{background:#16a34a;color:#fff;border-color:#16a34a;}
.btn-success:hover{background:#15803d;}
.btn-danger{background:var(--error);color:#fff;border-color:var(--error);}
.btn-danger:hover{opacity:.9;}
.btn-sm{padding:6px 13px;font-size:.8rem;}
.btn-lg{padding:12px 28px;font-size:.95rem;}
.btn-block{width:100%;justify-content:center;}

/* ══ ALERTS ═══════════════════════════════════════════════════════ */
.alert{padding:12px 16px;border-radius:8px;font-size:.9rem;margin-bottom:18px;border:1px solid transparent;}
.alert-success{background:var(--success-light);color:var(--success);border-color:#a8d5b4;}
.alert-error{background:var(--error-light);color:var(--error);border-color:#f5b8b8;}
.alert-warning{background:var(--warning-light);color:var(--warning);border-color:#fcd89a;}
.alert-info{background:var(--info-light);color:var(--info);border-color:#a8c4f0;}

/* ══ TABLES ═══════════════════════════════════════════════════════ */
.table-wrap{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);overflow:auto;box-shadow:var(--shadow);}
.data-table{width:100%;border-collapse:collapse;}
.data-table th{background:var(--surface2);padding:10px 14px;text-align:left;font-size:.75rem;font-weight:800;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);}
.data-table td{padding:12px 14px;border-bottom:1px solid var(--bg);font-size:.88rem;vertical-align:middle;}
.data-table tr:last-child td{border-bottom:none;}
.data-table tr:hover td{background:var(--surface2);}
.table-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;}
.table-card-hdr{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--border);background:var(--surface2);}
.table-card-hdr h3{margin:0;font-size:.9rem;font-weight:700;}

/* ══ BADGES ═══════════════════════════════════════════════════════ */
.badge{display:inline-block;padding:3px 10px;border-radius:50px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;}
.badge-pending{background:var(--warning-light);color:var(--warning);}
.badge-reviewed{background:var(--info-light);color:var(--info);}
.badge-prescribed{background:var(--success-light);color:var(--success);}
.badge-draft{background:var(--bg);color:var(--text-2);}
.badge-approved{background:var(--success-light);color:var(--success);}

/* ══ STATS (old pattern compat) ═══════════════════════════════════ */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:28px;}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 22px;box-shadow:var(--shadow);border-top:3px solid var(--primary);}
.stat-card-doctor{border-top-color:var(--doctor);}
.stat-num{font-family:var(--font-serif);font-size:2rem;color:var(--primary);line-height:1;}
.stat-card-doctor .stat-num{color:var(--doctor);}
.stat-label{color:var(--text-2);font-size:.83rem;margin-top:4px;}

/* ══ APPOINTMENTS ══════════════════════════════════════════════════ */
.appointments-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px;}
.appt-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);transition:box-shadow .2s;}
.appt-card:hover{box-shadow:var(--shadow-lg);}
.appt-card-prescribed{border-left:3px solid var(--success);}
.appt-card-pending{border-left:3px solid var(--warning);}
.appt-card-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;}
.patient-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-light);color:var(--primary);font-weight:700;font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.appt-meta{font-size:.78rem;color:var(--text-3);}
.appt-problem{font-size:.86rem;color:var(--text-2);margin-bottom:10px;line-height:1.5;}
.appt-actions{display:flex;gap:8px;}

/* Detail grid */
.appt-detail-grid{display:grid;grid-template-columns:1fr 1.8fr;gap:22px;align-items:start;}
@media(max-width:900px){.appt-detail-grid{grid-template-columns:1fr;}}
.info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:18px;overflow:hidden;}
.info-card-title{padding:11px 16px;background:var(--surface2);border-bottom:1px solid var(--border);font-size:.8rem;font-weight:800;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;}
.info-card-body{padding:16px;}

/* ══ VOICE / RECORDING ════════════════════════════════════════════ */
.voice-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px;}
.voice-status{font-size:.85rem;color:var(--text-2);}
.voice-indicator{display:flex;align-items:flex-end;gap:3px;height:24px;}
.voice-indicator span{display:block;width:4px;background:#e74c3c;border-radius:2px;animation:wave 1s ease-in-out infinite;}
.voice-indicator span:nth-child(1){height:8px;animation-delay:0s;}
.voice-indicator span:nth-child(2){height:16px;animation-delay:.15s;}
.voice-indicator span:nth-child(3){height:22px;animation-delay:.3s;}
.voice-indicator span:nth-child(4){height:12px;animation-delay:.45s;}
@keyframes wave{0%,100%{transform:scaleY(1);}50%{transform:scaleY(.3);}}
.voice-textarea{font-family:var(--font-sans)!important;background:#fffdf5!important;border-color:#d4c97a!important;}
.ai-parse-wrap{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap;}
.ai-hint{font-size:.78rem;color:var(--text-3);}
.rx-form-actions{display:flex;gap:12px;margin-top:18px;}
.approved-badge{background:var(--success-light);color:var(--success);padding:10px 16px;border-radius:8px;font-weight:700;margin-bottom:16px;}

/* ══ UPLOAD ZONE ══════════════════════════════════════════════════ */
.upload-zone{border:2px dashed var(--border);border-radius:8px;padding:22px;text-align:center;position:relative;cursor:pointer;transition:border-color .15s;}
.upload-zone:hover{border-color:var(--primary);}
.file-input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%!important;height:100%;}
.upload-icon{font-size:2rem;display:block;margin-bottom:8px;}
.upload-label p{font-size:.88rem;color:var(--text-2);}
.upload-label small{color:var(--text-3);font-size:.78rem;}
.image-preview img{max-width:100%;max-height:220px;border-radius:6px;}
.hidden{display:none!important;}
.text-muted{color:var(--text-3);font-size:.83rem;}

/* ══ EMPTY STATE ══════════════════════════════════════════════════ */
.empty-state{text-align:center;padding:56px 24px;color:var(--text-2);}
.empty-icon{font-size:3rem;margin-bottom:14px;}

/* ══ DOCTOR AVAILABILITY (multi-slot) ════════════════════════════ */
.day-picker{display:flex;gap:8px;flex-wrap:wrap;}
.day-tog input{display:none;}
.day-tog span{display:block;padding:7px 12px;border:2px solid var(--border);border-radius:8px;font-size:.8rem;font-weight:700;cursor:pointer;color:var(--text-3);transition:all .15s;}
.day-tog input:checked+span{border-color:var(--primary);background:var(--primary-light);color:var(--primary);}
.day-tog span:hover{border-color:var(--primary);}
.chk-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:600;font-size:.88rem;}
.chk-label input{width:18px;height:18px;}

/* ══ PHOTO / MISC ═════════════════════════════════════════════════ */
.photo-wrap{display:flex;gap:20px;align-items:flex-start;flex-wrap:wrap;}
.curr-photo{width:88px;height:88px;border-radius:50%;object-fit:cover;border:3px solid var(--primary-light);}
.photo-ph{width:88px;height:88px;border-radius:50%;background:var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:2.4rem;border:3px solid var(--primary-light);}

/* ══ PRESCRIPTION DOC ════════════════════════════════════════════ */
.toolbar{background:var(--surface);border-bottom:1px solid var(--border);padding:12px 24px;}
.toolbar-inner{max-width:900px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;}
.rx-document{max-width:860px;margin:28px auto;background:#fff;border:1px solid #d4cfc8;border-radius:4px;box-shadow:0 8px 32px rgba(0,0,0,.12);padding:48px 54px;font-family:var(--font-sans);}
.rx-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:20px;}
.rx-clinic-name{font-family:var(--font-serif);font-size:1.55rem;color:var(--primary);margin-bottom:4px;}
.rx-clinic p{font-size:.83rem;color:var(--text-2);line-height:1.8;}
.rx-doctor-info{text-align:right;}
.rx-doctor-info h2{font-family:var(--font-serif);font-size:1.15rem;color:var(--text);margin-bottom:4px;}
.rx-doctor-info p{font-size:.8rem;color:var(--text-2);line-height:1.8;}
.rx-divider{height:2px;background:linear-gradient(to right,var(--primary),var(--doctor));margin:14px 0;}
.rx-patient-bar{display:flex;flex-wrap:wrap;gap:0;border:1px solid var(--border);border-radius:6px;overflow:hidden;margin-bottom:22px;}
.rx-patient-field{flex:1;min-width:110px;padding:9px 13px;border-right:1px solid var(--border);}
.rx-patient-field:last-child{border-right:none;}
.rx-patient-field label{display:block;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);margin-bottom:2px;}
.rx-patient-field span{font-size:.88rem;font-weight:600;color:var(--text);}
.rx-section{margin-bottom:18px;}
.rx-section-label{font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:4px 10px;display:inline-block;border-radius:4px;margin-bottom:8px;background:var(--surface2);color:var(--text-2);}
.rx-label-diag{background:#edf3fb;color:#1a3a7a;}.rx-label-med{background:#f0faf4;color:#1a5c2e;}.rx-label-test{background:#fdf5e8;color:#7a4b00;}.rx-label-advice{background:#f5f0fb;color:#5a1a7a;}
.rx-section-body{font-size:.88rem;line-height:1.8;color:var(--text);padding-left:2px;}
.rx-medicines{display:flex;flex-direction:column;gap:6px;}
.rx-med-row{display:flex;gap:10px;align-items:baseline;}
.rx-med-num{min-width:22px;height:22px;background:var(--primary);color:#fff;border-radius:50%;font-size:.68rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.rx-followup{background:#fef9e7;border:1px solid #f9d876;padding:9px 15px;border-radius:6px;font-size:.88rem;margin-bottom:18px;color:#7a5800;}
.rx-footer{display:flex;justify-content:space-between;align-items:flex-end;margin-top:40px;padding-top:18px;border-top:1px solid var(--border);}
.rx-sig-line{width:180px;height:1px;background:var(--text);margin-bottom:6px;}
.rx-signature p{font-weight:600;font-size:.88rem;}
.rx-signature small{color:var(--text-3);font-size:.78rem;}
.stamp-circle{width:70px;height:70px;border:3px solid var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;opacity:.3;}
.rx-meta{text-align:center;margin-top:22px;color:var(--text-3);font-size:.73rem;}
.problem-img{max-width:100%;border-radius:6px;cursor:pointer;transition:all .2s;}
.problem-img.zoomed{max-width:none;width:100%;}

/* ══ FOOTER ═══════════════════════════════════════════════════════ */
.footer{padding:16px 24px;text-align:center;font-size:.78rem;color:var(--text-3);border-top:1px solid var(--border);background:var(--surface);}

/* ══ RESPONSIVE ═══════════════════════════════════════════════════ */
@media(max-width:768px){
  .nav-inner{padding:0 16px;}
  .page-wrap{padding:18px 14px;}
  .page-header{flex-direction:column;}
  .auth-card{padding:26px 18px;}
  .form-card{padding:18px;}
  .rx-document{padding:22px 18px;margin:12px;}
  .rx-header{flex-direction:column;}
  .rx-doctor-info{text-align:left;}
  .appointments-grid{grid-template-columns:1fr;}
  .nav-links a{padding:5px 8px;font-size:.82rem;}
  .kpi-grid{grid-template-columns:repeat(2,1fr);}
}
