/* TASK-FE-PATIENT-PORTAL-WEB-MOCKUP */
.pp-login {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.pp-login-card {
  width: 100%;
  max-width: 420px;
  background: var(--ent-surface, #0F1C30);
  border: 1px solid var(--ent-border, rgba(255,255,255,0.08));
  border-radius: 18px;
  padding: 36px 30px;
  text-align: center;
}
.pp-login-brand { display: flex; gap: 8px; justify-content: center; align-items: center; margin-block-end: 20px; color: var(--ent-primary, #00D4B4); font-size: 14px; }
.pp-login-ic { font-size: 22px; }
.pp-login-card h1 { font-size: 20px; margin: 0 0 6px; }
.pp-login-sub { color: var(--ent-mute, rgba(232,238,245,0.62)); font-size: 13px; margin: 0 0 20px; }
.pp-login-card label { display: flex; flex-direction: column; gap: 6px; font-size: 13px; text-align: start; margin-block-end: 14px; }
.pp-login-card label span { font-weight: 600; }
.pp-input {
  background: var(--ent-bg, #0B1524);
  border: 1px solid var(--ent-border, rgba(255,255,255,0.08));
  color: var(--ent-text, #E8EEF5);
  padding: 12px 14px;
  border-radius: 10px;
  font-family: inherit;
  font-size: 15px;
  min-height: 44px;
}
.pp-input:focus { outline: 2px solid #00D4B4; outline-offset: 1px; }

.pp-full { width: 100%; justify-content: center; margin-block-start: 6px; }

.pp-otp-box { display: flex; gap: 6px; justify-content: center; padding-block: 10px; }
.pp-otp {
  width: 44px;
  height: 52px;
  text-align: center;
  font-size: 20px;
  border-radius: 8px;
  border: 1px solid var(--ent-border, rgba(255,255,255,0.12));
  background: var(--ent-bg, #0B1524);
  color: var(--ent-text, #E8EEF5);
  font-family: 'Consolas','Monaco',monospace;
}

.pp-login-alt { display: block; margin-block-start: 20px; color: var(--ent-mute, rgba(232,238,245,0.62)); font-size: 13px; text-decoration: none; }
.pp-login-alt:hover { color: #00D4B4; }

.pp-status { min-height: 20px; margin-block-start: 8px; font-size: 13px; font-weight: 600; }
.pp-status.ok { color: #00D4B4; }
.pp-status.err { color: #FF4D4F; }

/* App */
.pp-app { max-width: 760px; margin: 0 auto; padding: 20px 16px 40px; }
.pp-topbar {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 0;
  border-block-end: 1px solid var(--ent-border, rgba(255,255,255,0.08));
  margin-block-end: 12px;
}
.pp-topbar-brand { font-weight: 700; font-size: 16px; display: flex; gap: 8px; align-items: center; }
.pp-topbar-user { display: flex; gap: 10px; align-items: center; font-size: 13px; }
.pp-signout { padding: 6px 14px; min-height: 36px; font-size: 12px; }

.pp-nav {
  display: flex;
  gap: 4px;
  background: var(--ent-surface, #0F1C30);
  border-radius: 12px;
  padding: 4px;
  margin-block-end: 14px;
}
.pp-nav-btn {
  flex: 1;
  background: transparent;
  border: 0;
  color: var(--ent-mute, rgba(232,238,245,0.62));
  padding: 10px 8px;
  border-radius: 8px;
  cursor: pointer;
  font-family: inherit;
  font-size: 13.5px;
  min-height: 44px;
}
.pp-nav-btn.active { background: rgba(0,212,180,0.15); color: #00D4B4; }

.pp-content h2 { font-size: 16px; margin: 14px 0 10px; }
.pp-card-row { margin-block-end: 8px; }
.pp-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--ent-primary, #00D4B4);
  color: #0B1524;
  padding: 10px 16px;
  border-radius: 10px;
  text-decoration: none;
  font-weight: 700;
  font-size: 13.5px;
  min-height: 44px;
}
.pp-cta-ic { font-size: 18px; }

.pp-appt {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 14px;
  background: var(--ent-surface, #0F1C30);
  border: 1px solid var(--ent-border, rgba(255,255,255,0.08));
  border-radius: 12px;
  padding: 14px;
  margin-block-end: 8px;
}
.pp-appt-date { text-align: center; padding-inline-end: 14px; border-inline-end: 1px solid var(--ent-border, rgba(255,255,255,0.06)); }
.pp-appt-day { font-size: 26px; font-weight: 800; }
.pp-appt-month { font-size: 11px; color: var(--ent-mute, rgba(232,238,245,0.55)); font-family: monospace; }
.pp-appt-time { font-size: 13px; color: #00D4B4; font-family: 'Consolas','Monaco',monospace; margin-block-start: 4px; }
.pp-appt-doctor { font-weight: 700; font-size: 14.5px; }
.pp-appt-meta { font-size: 12.5px; color: var(--ent-mute, rgba(232,238,245,0.62)); margin-block: 2px 6px; }

.pp-chip { display: inline-block; font-size: 11px; padding: 3px 10px; border-radius: 999px; font-weight: 600; }
.pp-chip.ok   { background: rgba(0,212,180,0.15); color: #00D4B4; }
.pp-chip.warn { background: rgba(255,193,0,0.15);  color: #FFC100; }
.pp-chip.done { background: rgba(148,163,184,0.2); color: #94A3B8; }
.pp-chip.bad  { background: rgba(255,77,79,0.15);  color: #FF4D4F; }

.pp-rx {
  background: var(--ent-surface, #0F1C30);
  border: 1px solid var(--ent-border, rgba(255,255,255,0.08));
  border-radius: 12px;
  padding: 14px 16px;
  margin-block-end: 8px;
}
.pp-rx-head { display: flex; justify-content: space-between; align-items: center; gap: 10px; margin-block-end: 8px; }
.pp-rx-date { font-size: 12px; color: var(--ent-mute, rgba(232,238,245,0.55)); margin-inline-start: 10px; }
.pp-rx-meds { list-style: none; padding: 0; margin: 0 0 10px; font-size: 13.5px; }
.pp-rx-meds li { padding: 4px 0; border-block-end: 1px solid rgba(255,255,255,0.05); }
.pp-rx-meds li:last-child { border-block-end: 0; }
.pp-rx-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.pp-rx-btn { padding: 8px 14px; min-height: 40px; font-size: 12.5px; }

.pp-profile-card {
  background: var(--ent-surface, #0F1C30);
  border: 1px solid var(--ent-border, rgba(255,255,255,0.08));
  border-radius: 14px;
  padding: 24px;
  text-align: center;
}
.pp-avatar {
  width: 80px; height: 80px;
  border-radius: 50%;
  background: rgba(91,141,239,0.15);
  display: flex; align-items: center; justify-content: center;
  font-size: 36px;
  margin: 0 auto 14px;
}
.pp-profile-fields {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 10px;
  text-align: start;
  margin-block-end: 20px;
}
.pp-profile-fields label { font-size: 11px; color: var(--ent-mute, rgba(232,238,245,0.55)); text-transform: uppercase; letter-spacing: 0.5px; }
.pp-profile-fields > div { background: rgba(0,0,0,0.15); padding: 10px 12px; border-radius: 8px; font-size: 14px; }
.pp-profile-fields > div > div { margin-block-start: 4px; font-weight: 600; }

.pp-mono { font-family: 'Consolas','Monaco',monospace; font-size: 13px; }
.pp-empty { color: var(--ent-mute, rgba(232,238,245,0.55)); text-align: center; padding: 20px; }
.pp-empty a { color: #00D4B4; text-decoration: none; font-weight: 600; }

@media (max-width: 480px) {
  .pp-appt { grid-template-columns: 64px 1fr; padding: 12px; gap: 10px; }
  .pp-appt-day { font-size: 22px; }
  .pp-nav-btn { font-size: 12px; }
  .pp-login-card { padding: 24px 20px; }
}
