/* ═══════════════════════════════════════════════════════════════
   Family Doctor — Patient Portal Stylesheet
   Injected on the frontend [fd_patient_portal] page only
   ═══════════════════════════════════════════════════════════════ */

:root {
  --fdp-primary:   #0891b2;
  --fdp-primary-d: #0e7490;
  --fdp-primary-l: #e0f2fe;
  --fdp-success:   #059669;
  --fdp-success-l: #d1fae5;
  --fdp-warning:   #d97706;
  --fdp-warning-l: #fef3c7;
  --fdp-danger:    #dc2626;
  --fdp-danger-l:  #fee2e2;
  --fdp-text:      #1f2937;
  --fdp-text-2:    #6b7280;
  --fdp-border:    #e5e7eb;
  --fdp-bg:        #f8fafc;
  --fdp-card:      #ffffff;
  --fdp-radius:    14px;
  --fdp-shadow:    0 2px 8px rgba(0,0,0,.08);
  --fdp-shadow-lg: 0 12px 32px rgba(0,0,0,.12);
}

.fdp-wrap * { box-sizing: border-box; }
.fdp-wrap { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Inter, sans-serif; color: var(--fdp-text); max-width: 900px; margin: 0 auto; padding: 16px; }

/* ── Login Box ──────────────────────────────────────────────── */
.fdp-login-box {
  max-width: 440px; margin: 60px auto;
  background: var(--fdp-card); border-radius: var(--fdp-radius);
  box-shadow: var(--fdp-shadow-lg); padding: 40px;
}
.fdp-login-logo { text-align: center; margin-bottom: 32px; }
.fdp-logo-icon { font-size: 48px; display: block; margin-bottom: 8px; }
.fdp-login-logo h2 { font-size: 22px; font-weight: 800; margin: 0 0 4px; color: var(--fdp-primary); }
.fdp-login-logo p  { font-size: 14px; color: var(--fdp-text-2); margin: 0; }

/* ── Alerts ─────────────────────────────────────────────────── */
.fdp-alert { padding: 12px 16px; border-radius: 8px; font-size: 14px; margin-bottom: 16px; }
.fdp-alert-error   { background: var(--fdp-danger-l);  color: #7f1d1d; border-left: 4px solid var(--fdp-danger); }
.fdp-alert-success { background: var(--fdp-success-l); color: #065f46; border-left: 4px solid var(--fdp-success); }
.fdp-error { background: var(--fdp-warning-l); padding: 16px; border-radius: 10px; color: #78350f; }

/* ── Form Fields ────────────────────────────────────────────── */
.fdp-field { margin-bottom: 18px; }
.fdp-field label { display: block; font-size: 13px; font-weight: 600; color: var(--fdp-text-2); margin-bottom: 6px; }
.fdp-input, .fdp-field input, .fdp-field select, .fdp-field textarea {
  width: 100%; border: 2px solid var(--fdp-border); border-radius: 8px;
  padding: 11px 14px; font-size: 14px; transition: border-color .2s;
  background: #fff; font-family: inherit;
}
.fdp-input:focus,
.fdp-field input:focus,
.fdp-field select:focus,
.fdp-field textarea:focus {
  outline: none; border-color: var(--fdp-primary);
  box-shadow: 0 0 0 3px rgba(8,145,178,.12);
}
.fdp-field textarea { resize: vertical; }

/* ── Buttons ────────────────────────────────────────────────── */
.fdp-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 11px 20px; border-radius: 8px; font-size: 14px; font-weight: 600;
  cursor: pointer; border: none; font-family: inherit; transition: all .15s;
}
.fdp-btn-primary { background: var(--fdp-primary); color: #fff; }
.fdp-btn-primary:hover { background: var(--fdp-primary-d); }
.fdp-btn-ghost { background: transparent; border: 2px solid var(--fdp-border); color: var(--fdp-text); }
.fdp-btn-ghost:hover { border-color: var(--fdp-primary); color: var(--fdp-primary); }
.fdp-btn-full { width: 100%; justify-content: center; }
.fdp-btn-sm { padding: 7px 14px; font-size: 13px; }
.fdp-btn:disabled { opacity: .55; cursor: not-allowed; }

/* ── Portal Header ──────────────────────────────────────────── */
.fdp-header {
  display: flex; align-items: center; justify-content: space-between;
  background: linear-gradient(135deg, var(--fdp-primary), var(--fdp-primary-d));
  color: #fff; border-radius: var(--fdp-radius); padding: 20px 24px; margin-bottom: 20px;
}
.fdp-header-left { display: flex; align-items: center; gap: 14px; }
.fdp-avatar {
  width: 52px; height: 52px; border-radius: 14px; background: rgba(255,255,255,.25);
  font-size: 20px; font-weight: 800; display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.fdp-welcome { font-size: 18px; font-weight: 700; }
.fdp-sub { font-size: 13px; opacity: .8; margin-top: 2px; }

/* ── Info Strip ─────────────────────────────────────────────── */
.fdp-info-strip {
  display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 20px;
  background: var(--fdp-card); border-radius: var(--fdp-radius);
  box-shadow: var(--fdp-shadow); padding: 16px 20px;
}
.fdp-info-item { display: flex; flex-direction: column; gap: 2px; min-width: 120px; }
.fdp-info-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--fdp-text-2); }
.fdp-info-value { font-size: 14px; font-weight: 600; }
.fdp-allergy .fdp-info-value { color: var(--fdp-danger); }

/* ── Tabs ───────────────────────────────────────────────────── */
.fdp-tabs {
  display: flex; flex-wrap: wrap; gap: 4px;
  border-bottom: 2px solid var(--fdp-border); margin-bottom: 20px;
}
.fdp-tab {
  padding: 10px 16px; font-size: 13px; font-weight: 600;
  border: none; background: none; cursor: pointer; color: var(--fdp-text-2);
  border-bottom: 3px solid transparent; margin-bottom: -2px;
  border-radius: 6px 6px 0 0; transition: all .15s; font-family: inherit;
}
.fdp-tab:hover  { color: var(--fdp-primary); background: var(--fdp-primary-l); }
.fdp-tab.active { color: var(--fdp-primary); border-bottom-color: var(--fdp-primary); }
.fdp-pane       { display: none; }
.fdp-pane.active { display: block; }

/* ── Cards ──────────────────────────────────────────────────── */
.fdp-card {
  background: var(--fdp-card); border-radius: var(--fdp-radius);
  box-shadow: var(--fdp-shadow); padding: 20px; margin-bottom: 14px;
}
.fdp-card:last-child { margin-bottom: 0; }

/* ── Visit Cards ────────────────────────────────────────────── */
.fdp-visit-card { border-left: 4px solid var(--fdp-primary); }
.fdp-visit-date { font-size: 13px; color: var(--fdp-text-2); margin-bottom: 6px; }
.fdp-visit-diagnosis { font-size: 16px; font-weight: 700; margin-bottom: 8px; }
.fdp-visit-plan { font-size: 14px; color: var(--fdp-text); line-height: 1.6; }
.fdp-vitals { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 12px; }
.fdp-vital-pill {
  background: var(--fdp-bg); border: 1px solid var(--fdp-border);
  border-radius: 20px; padding: 4px 12px; font-size: 12px; font-weight: 600;
}
.fdp-vital-pill span { color: var(--fdp-text-2); font-weight: 400; }

/* ── Prescription Cards ─────────────────────────────────────── */
.fdp-rx-card { }
.fdp-rx-name { font-size: 16px; font-weight: 700; margin-bottom: 4px; }
.fdp-rx-meta { display: flex; flex-wrap: wrap; gap: 8px; margin: 6px 0; }
.fdp-rx-tag { background: var(--fdp-primary-l); color: var(--fdp-primary); padding: 3px 10px; border-radius: 20px; font-size: 12px; font-weight: 600; }
.fdp-rx-tag.chronic { background: var(--fdp-warning-l); color: var(--fdp-warning); }
.fdp-rx-tag.stopped { background: var(--fdp-border); color: var(--fdp-text-2); }
.fdp-rx-instructions { font-size: 13px; color: var(--fdp-text-2); margin-top: 6px; }

/* ── Lab Result Rows ────────────────────────────────────────── */
.fdp-lab-group { margin-bottom: 20px; }
.fdp-lab-group-title { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--fdp-text-2); margin-bottom: 10px; }
.fdp-lab-row {
  display: flex; align-items: center; gap: 12px; padding: 12px 16px;
  border-radius: 10px; background: var(--fdp-bg); margin-bottom: 8px;
  border: 1px solid var(--fdp-border);
}
.fdp-lab-name  { flex: 1; font-weight: 600; font-size: 14px; }
.fdp-lab-val   { font-size: 18px; font-weight: 800; min-width: 80px; text-align: right; }
.fdp-lab-ref   { font-size: 11px; color: var(--fdp-text-2); text-align: right; min-width: 80px; }
.fdp-lab-badge { min-width: 64px; text-align: center; }
.fdp-badge     { display: inline-block; padding: 3px 10px; border-radius: 20px; font-size: 12px; font-weight: 700; }
.fdp-badge-normal   { background: var(--fdp-success-l); color: var(--fdp-success); }
.fdp-badge-high     { background: var(--fdp-danger-l);  color: var(--fdp-danger); }
.fdp-badge-low      { background: var(--fdp-warning-l); color: var(--fdp-warning); }
.fdp-badge-critical { background: #450a0a; color: #fca5a5; }
.fdp-badge-pending  { background: var(--fdp-primary-l); color: var(--fdp-primary); }
.fdp-badge-active   { background: var(--fdp-success-l); color: var(--fdp-success); }
.fdp-badge-stopped  { background: var(--fdp-border); color: var(--fdp-text-2); }

/* ── Image Gallery ──────────────────────────────────────────── */
.fdp-image-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px,1fr)); gap: 14px; }
.fdp-image-item { border: 2px solid var(--fdp-border); border-radius: 10px; overflow: hidden; cursor: pointer; transition: border-color .2s; }
.fdp-image-item:hover { border-color: var(--fdp-primary); }
.fdp-image-item img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; }
.fdp-image-caption { padding: 8px 10px; font-size: 12px; font-weight: 600; text-transform: uppercase; }

/* ── Appointment Items ──────────────────────────────────────── */
.fdp-appt {
  display: flex; gap: 14px; align-items: center;
  padding: 14px 16px; border-radius: 10px; background: var(--fdp-bg); margin-bottom: 10px;
  border: 1px solid var(--fdp-border);
}
.fdp-appt-date {
  min-width: 54px; text-align: center;
  background: var(--fdp-primary); color: #fff; border-radius: 10px; padding: 8px 6px;
  flex-shrink: 0;
}
.fdp-appt-day   { font-size: 22px; font-weight: 900; line-height: 1; }
.fdp-appt-month { font-size: 11px; text-transform: uppercase; }
.fdp-appt-body  { flex: 1; }
.fdp-appt-reason { font-size: 14px; font-weight: 600; }
.fdp-appt-time  { font-size: 12px; color: var(--fdp-text-2); margin-top: 2px; }
.fdp-badge-completed { background: var(--fdp-success-l); color: var(--fdp-success); }
.fdp-badge-missed    { background: var(--fdp-danger-l);  color: var(--fdp-danger);  }
.fdp-badge-pending   { background: var(--fdp-primary-l); color: var(--fdp-primary); }

/* ── Loading / Empty ────────────────────────────────────────── */
.fdp-loading { display: flex; align-items: center; gap: 10px; padding: 32px; color: var(--fdp-text-2); justify-content: center; }
.fdp-spinner { width: 24px; height: 24px; border: 3px solid var(--fdp-border); border-top-color: var(--fdp-primary); border-radius: 50%; animation: fdp-spin .6s linear infinite; flex-shrink: 0; }
@keyframes fdp-spin { to { transform: rotate(360deg); } }
.fdp-empty { text-align: center; padding: 48px 20px; color: var(--fdp-text-2); }
.fdp-empty-icon { font-size: 48px; display: block; margin-bottom: 10px; opacity: .5; }
.fdp-empty h4 { font-size: 16px; color: var(--fdp-text); margin-bottom: 4px; }

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 600px) {
  .fdp-header { flex-direction: column; gap: 12px; align-items: flex-start; }
  .fdp-tabs { overflow-x: auto; flex-wrap: nowrap; }
  .fdp-tab { white-space: nowrap; }
  .fdp-lab-ref { display: none; }
  .fdp-login-box { padding: 24px; }
}
