/* MedSync — Auth + sidebar additions */

.ms-auth {
  display: grid;
  grid-template-columns: minmax(420px, 520px) 1fr;
  height: 100vh;
  background: var(--bg);
}
.ms-auth-form {
  padding: 32px 48px;
  display: flex; flex-direction: column;
  overflow-y: auto;
}
.ms-auth-brand { display: flex; align-items: center; gap: 12px; margin-bottom: 36px; }
.ms-auth-card { width: 100%; max-width: 380px; margin: auto 0; display: flex; flex-direction: column; }
.ms-auth-foot {
  margin-top: 32px; display: flex; gap: 12px; align-items: center;
  font-size: 11.5px; color: var(--ink-4);
}
.ms-auth-foot a { color: var(--ink-4); text-decoration: none; }
.ms-auth-foot a:hover { color: var(--ink); }

.ms-auth-side {
  background: linear-gradient(150deg, oklch(0.45 0.10 220) 0%, oklch(0.32 0.10 230) 100%);
  color: white;
  padding: 60px;
  display: flex; align-items: center; justify-content: flex-start;
  position: relative;
  overflow: hidden;
}
.ms-auth-side::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 20% 100%, rgba(255,255,255,0.08), transparent 50%),
    radial-gradient(circle at 80% 0%, rgba(255,255,255,0.06), transparent 50%);
  pointer-events: none;
}
.ms-auth-pitch { position: relative; max-width: 520px; }
.ms-auth-pitch-stats { display: flex; gap: 32px; margin-top: 40px; }
.ms-auth-stat-num { font-family: var(--font-display); font-size: 28px; font-weight: 500; color: white; letter-spacing: -0.02em; }
.ms-auth-stat-label { font-size: 12px; color: rgba(255,255,255,0.7); margin-top: 2px; }
.ms-auth-bullets { list-style: none; padding: 0; margin: 24px 0 0; display: flex; flex-direction: column; gap: 12px; }
.ms-auth-bullets li { display: flex; align-items: center; gap: 10px; color: rgba(255,255,255,0.86); font-size: 14px; }

.ms-sso-btn {
  appearance: none; width: 100%; height: 44px;
  border: 1px solid var(--line-strong); background: var(--surface);
  border-radius: 10px; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  font-size: 13.5px; font-weight: 500; color: var(--ink);
  transition: background .12s, border-color .12s;
}
.ms-sso-btn:hover { background: var(--bg-soft); border-color: var(--ink-5); }

.ms-auth-divider {
  display: flex; align-items: center; gap: 12px;
  color: var(--ink-4); font-size: 11.5px;
  margin: 18px 0;
}
.ms-auth-divider::before, .ms-auth-divider::after { content: ""; flex: 1; height: 1px; background: var(--line); }

.ms-auth-password-form {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.ms-auth-field {
  display: block;
  min-width: 0;
}
.ms-auth-field .field-label {
  display: block;
  margin: 0 0 6px;
  font-size: 12px;
  line-height: 1.25;
}
.ms-auth-label-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 6px;
}
.ms-auth-label-row .field-label {
  margin: 0;
}
.ms-auth-label-row a {
  color: var(--primary);
  font-size: 12px;
  line-height: 1.25;
  text-decoration: none;
  white-space: nowrap;
}
.ms-auth-password-wrap {
  position: relative;
}
.ms-auth-password-wrap .input {
  padding-right: 58px;
}
.ms-auth-password-wrap button {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  appearance: none;
  border: 0;
  background: transparent;
  color: var(--ink-4);
  cursor: pointer;
  font-size: 11px;
  font-weight: 500;
  line-height: 1;
}

.ms-check { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--ink-3); cursor: pointer; }
.ms-check input { width: 14px; height: 14px; accent-color: var(--primary); }

.ms-password-rules {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}
.ms-password-rules span {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 7px;
  border-radius: 999px;
  background: var(--bg-soft);
  color: var(--ink-4);
  border: 1px solid var(--line);
  font-size: 11.5px;
  line-height: 1;
}
.ms-password-rules span.is-met {
  color: var(--accent-success);
  background: color-mix(in oklch, var(--accent-success) 10%, white);
  border-color: color-mix(in oklch, var(--accent-success) 26%, white);
}

.ms-auth-switch { text-align: center; margin-top: 24px; font-size: 13px; color: var(--ink-3); }
.ms-auth-switch a { color: var(--primary); cursor: pointer; font-weight: 500; }
.ms-auth-switch a:hover { text-decoration: underline; }

.ms-step-pip { width: 24px; height: 4px; border-radius: 999px; transition: background .2s; }

.ms-role {
  appearance: none; width: 100%;
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px;
  border: 1px solid var(--line-strong);
  background: var(--surface);
  border-radius: 12px;
  cursor: pointer;
  transition: all .12s;
}
.ms-role:hover { border-color: var(--ink-5); background: var(--bg-soft); }
.ms-role.is-active { border-color: var(--primary); background: var(--primary-soft); color: var(--primary-ink); box-shadow: 0 0 0 3px color-mix(in oklch, var(--primary) 12%, transparent); }
.ms-role-icon {
  width: 36px; height: 36px; border-radius: 9px;
  background: var(--bg-sunk); color: var(--ink-2);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.ms-role.is-active .ms-role-icon { background: var(--primary); color: white; }

.ms-size-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
.ms-size {
  appearance: none; cursor: pointer; text-align: left;
  padding: 12px 14px;
  border: 1px solid var(--line-strong);
  background: var(--surface);
  border-radius: 10px;
  transition: all .12s;
}
.ms-size:hover { border-color: var(--ink-5); }
.ms-size.is-active { border-color: var(--primary); background: var(--primary-soft); }

@media (max-width: 900px) {
  .ms-auth { grid-template-columns: 1fr; }
  .ms-auth-side { display: none; }
}
