/* IPS v2 — Healthcare app aesthetic. Calm blue/teal, white surfaces, full status system. */
:root {
  --v2-font: "Plus Jakarta Sans", "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;

  /* Brand */
  --v2-primary: #1E6FB8;
  --v2-primary-700: #155C99;
  --v2-primary-600: #1E6FB8;
  --v2-primary-500: #3B89D1;
  --v2-primary-100: #DBEAFE;
  --v2-primary-50: #EBF3FB;

  --v2-teal: #00A39D;
  --v2-teal-700: #007A75;
  --v2-teal-50: #E0F5F3;

  --v2-ink: #0F172A;
  --v2-ink-2: #1E293B;
  --v2-ink-3: #475569;
  --v2-muted: #64748B;
  --v2-muted-2: #94A3B8;

  --v2-line: #E2E8F0;
  --v2-line-2: #CBD5E1;

  --v2-bg: #F8FAFC;
  --v2-surface: #FFFFFF;
  --v2-surface-soft: #F1F5F9;

  /* Tile tints (for category icons / dashboards) */
  --v2-tint-blue: #EBF3FB;
  --v2-tint-teal: #E0F5F3;
  --v2-tint-amber: #FEF3DA;
  --v2-tint-rose: #FCEDEE;
  --v2-tint-violet: #EFEAFB;
  --v2-tint-mint: #E6F6EC;

  --v2-on-blue: #1E6FB8;
  --v2-on-teal: #007A75;
  --v2-on-amber: #B26B00;
  --v2-on-rose: #C2185B;
  --v2-on-violet: #6633A8;
  --v2-on-mint: #15803D;

  /* Status */
  --v2-success: #16A34A;
  --v2-success-50: #DCFCE7;
  --v2-warning: #F59E0B;
  --v2-warning-50: #FEF3C7;
  --v2-error: #DC2626;
  --v2-error-50: #FEE2E2;
  --v2-info: #2563EB;
  --v2-info-50: #DBEAFE;

  /* Shadow */
  --v2-sh-1: 0 1px 2px rgba(15, 23, 42, 0.04), 0 1px 1px rgba(15, 23, 42, 0.03);
  --v2-sh-2: 0 4px 12px rgba(15, 23, 42, 0.06), 0 2px 4px rgba(15, 23, 42, 0.04);
  --v2-sh-3: 0 12px 28px rgba(15, 23, 42, 0.10), 0 4px 8px rgba(15, 23, 42, 0.05);
  --v2-sh-blue: 0 8px 24px rgba(30, 111, 184, 0.18);

  /* Radii */
  --v2-r-sm: 8px;
  --v2-r: 12px;
  --v2-r-lg: 16px;
  --v2-r-xl: 22px;
  --v2-r-full: 999px;
}

/* Screen frame */
.ips2 * { box-sizing: border-box; }
.ips2 {
  width: 390px;
  min-height: 844px;
  background: var(--v2-bg);
  color: var(--v2-ink);
  font-family: var(--v2-font);
  font-size: 14px;
  line-height: 1.45;
  position: relative;
  overflow: hidden;
  letter-spacing: -0.005em;
}
.ips2.surface-white { background: var(--v2-surface); }

/* Status bar */
.ips2-status {
  height: 50px;
  padding: 18px 22px 0;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  font-weight: 600;
  font-size: 15px;
  letter-spacing: -0.01em;
  color: var(--v2-ink);
}
.ips2-status .icons { display: flex; gap: 5px; align-items: center; }
.ips2-status.light { color: #fff; }

/* Top app bar */
.ips2-top {
  padding: 6px 18px 12px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.ips2-top .back {
  width: 38px; height: 38px; border-radius: 999px;
  background: var(--v2-surface); border: 1px solid var(--v2-line);
  display: grid; place-items: center; flex-shrink: 0;
}
.ips2-top .title { font-size: 17px; font-weight: 700; letter-spacing: -0.01em; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ips2-top .actions { display: flex; gap: 6px; }
.ips2-top .icon-btn {
  width: 38px; height: 38px; border-radius: 999px;
  background: var(--v2-surface); border: 1px solid var(--v2-line);
  display: grid; place-items: center; position: relative;
}

/* Type */
.t-eyebrow { font-size: 11px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--v2-primary); }
.t-eyebrow.muted { color: var(--v2-muted); }
.t-eyebrow.teal { color: var(--v2-on-teal); }
.t-h1 { font-size: 28px; font-weight: 800; line-height: 1.15; letter-spacing: -0.022em; color: var(--v2-ink); }
.t-h2 { font-size: 22px; font-weight: 700; line-height: 1.2; letter-spacing: -0.018em; color: var(--v2-ink); }
.t-h3 { font-size: 17px; font-weight: 700; line-height: 1.25; letter-spacing: -0.012em; color: var(--v2-ink); }
.t-h4 { font-size: 15px; font-weight: 600; line-height: 1.3; letter-spacing: -0.008em; color: var(--v2-ink); }
.t-body { font-size: 14px; color: var(--v2-ink-3); line-height: 1.5; }
.t-body-sm { font-size: 12.5px; color: var(--v2-muted); line-height: 1.45; }
.t-meta { font-size: 11.5px; color: var(--v2-muted); font-weight: 500; }
.t-num { font-size: 26px; font-weight: 800; letter-spacing: -0.02em; color: var(--v2-ink); }

/* Cards */
.v2-card { background: var(--v2-surface); border-radius: var(--v2-r-lg); box-shadow: var(--v2-sh-1); border: 1px solid var(--v2-line); }
.v2-card.flat { box-shadow: none; }
.v2-card.tint-blue { background: var(--v2-tint-blue); border-color: transparent; }
.v2-card.tint-teal { background: var(--v2-tint-teal); border-color: transparent; }
.v2-card.tint-amber { background: var(--v2-tint-amber); border-color: transparent; }
.v2-card.tint-rose { background: var(--v2-tint-rose); border-color: transparent; }
.v2-card.elev { box-shadow: var(--v2-sh-2); }
.v2-card.brand { background: var(--v2-primary); color: #fff; border-color: transparent; box-shadow: var(--v2-sh-blue); }

/* Buttons */
.v2-btn {
  height: 50px; padding: 0 22px; border-radius: var(--v2-r-full);
  font-family: var(--v2-font); font-size: 15px; font-weight: 600; letter-spacing: -0.005em;
  background: var(--v2-primary); color: #fff; border: none;
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  cursor: pointer;
}
.v2-btn.block { width: 100%; }
.v2-btn.ghost { background: var(--v2-surface); color: var(--v2-ink); border: 1px solid var(--v2-line-2); }
.v2-btn.soft { background: var(--v2-primary-50); color: var(--v2-primary); }
.v2-btn.teal { background: var(--v2-teal); }
.v2-btn.danger { background: var(--v2-error); }
.v2-btn.sm { height: 38px; padding: 0 16px; font-size: 13px; }
.v2-btn.xs { height: 30px; padding: 0 12px; font-size: 12px; font-weight: 600; }

/* Chip / badge */
.v2-chip {
  display: inline-flex; align-items: center; gap: 5px;
  height: 26px; padding: 0 10px; border-radius: 999px;
  background: var(--v2-surface-soft); color: var(--v2-ink-2);
  font-size: 12px; font-weight: 600;
}
.v2-chip.solid { background: var(--v2-primary); color: #fff; }
.v2-chip.blue { background: var(--v2-primary-50); color: var(--v2-primary); }
.v2-chip.teal { background: var(--v2-teal-50); color: var(--v2-on-teal); }
.v2-chip.success { background: var(--v2-success-50); color: var(--v2-success); }
.v2-chip.warning { background: var(--v2-warning-50); color: #92400E; }
.v2-chip.error { background: var(--v2-error-50); color: var(--v2-error); }
.v2-chip.info { background: var(--v2-info-50); color: var(--v2-info); }
.v2-chip.amber { background: var(--v2-tint-amber); color: var(--v2-on-amber); }
.v2-chip.rose { background: var(--v2-tint-rose); color: var(--v2-on-rose); }
.v2-chip.outline { background: transparent; border: 1px solid var(--v2-line-2); color: var(--v2-ink-2); }
.v2-chip.xs { height: 22px; padding: 0 8px; font-size: 11px; }
.v2-chip.lg { height: 32px; padding: 0 14px; font-size: 13px; }

/* Inputs */
.v2-input {
  background: var(--v2-surface); border: 1.5px solid var(--v2-line);
  border-radius: var(--v2-r); padding: 14px 16px;
  display: flex; align-items: center; gap: 10px;
}
.v2-input.focus { border-color: var(--v2-primary); box-shadow: 0 0 0 4px rgba(30, 111, 184, 0.08); }
.v2-input.error { border-color: var(--v2-error); }
.v2-input .label { font-size: 11px; font-weight: 600; color: var(--v2-muted); text-transform: uppercase; letter-spacing: 0.04em; }
.v2-input .val { font-size: 15px; color: var(--v2-ink); }
.v2-input .val.empty { color: var(--v2-muted-2); }
.v2-input.stack { flex-direction: column; align-items: flex-start; gap: 4px; }

/* Avatar */
.v2-avatar {
  width: 40px; height: 40px; border-radius: 999px;
  background: var(--v2-tint-blue); color: var(--v2-on-blue);
  display: grid; place-items: center;
  font-weight: 700; font-size: 14px;
  flex-shrink: 0;
}
.v2-avatar.lg { width: 56px; height: 56px; font-size: 18px; }
.v2-avatar.xl { width: 88px; height: 88px; font-size: 28px; }
.v2-avatar.teal { background: var(--v2-tint-teal); color: var(--v2-on-teal); }
.v2-avatar.amber { background: var(--v2-tint-amber); color: var(--v2-on-amber); }
.v2-avatar.rose { background: var(--v2-tint-rose); color: var(--v2-on-rose); }
.v2-avatar.violet { background: var(--v2-tint-violet); color: var(--v2-on-violet); }
.v2-avatar.mint { background: var(--v2-tint-mint); color: var(--v2-on-mint); }
.v2-avatar.brand { background: var(--v2-primary); color: #fff; }
.v2-avatar.ring { border: 3px solid #fff; box-shadow: var(--v2-sh-1); }

/* Tile (square w/ icon) */
.v2-tile {
  border-radius: var(--v2-r); padding: 12px;
  display: flex; flex-direction: column; align-items: flex-start; gap: 8px;
}
.v2-tile .ico {
  width: 36px; height: 36px; border-radius: 10px;
  display: grid; place-items: center;
  background: rgba(255,255,255,0.7);
}

/* Bottom nav */
.ips2-tab {
  position: absolute; left: 0; right: 0; bottom: 0;
  height: 86px; padding: 10px 8px 28px;
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(16px);
  border-top: 1px solid var(--v2-line);
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 2px;
  z-index: 5;
}
.ips2-tab .t {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 3px; color: var(--v2-muted);
  position: relative;
}
.ips2-tab .t.on { color: var(--v2-primary); }
.ips2-tab .t .lbl { font-size: 10.5px; font-weight: 600; }
.ips2-tab .t .pill {
  position: absolute; top: 4px;
  width: 22px; height: 22px; border-radius: 999px;
  background: var(--v2-primary-50);
  opacity: 0; transition: opacity .15s;
}
.ips2-tab .t.on .pill { opacity: 1; }

.ips2-safe { position: absolute; left: 0; right: 0; bottom: 0; height: 34px; display: flex; align-items: center; justify-content: center; }
.ips2-safe::after { content: ""; width: 134px; height: 5px; border-radius: 3px; background: var(--v2-ink); opacity: 0.9; }

/* Scroll area */
.ips2-scroll { padding: 0 18px 110px; }

/* List row */
.v2-row { display: flex; align-items: center; gap: 12px; padding: 12px 16px; background: var(--v2-surface); }
.v2-row + .v2-row { border-top: 1px solid var(--v2-line); }

/* Section header */
.v2-section-h {
  display: flex; justify-content: space-between; align-items: center;
  margin: 22px 0 12px;
}
.v2-section-h .t { font-size: 16px; font-weight: 700; letter-spacing: -0.01em; }
.v2-section-h .a { font-size: 13px; font-weight: 600; color: var(--v2-primary); }

/* Sponsored frame */
.v2-sponsored {
  background: var(--v2-surface); border-radius: var(--v2-r-lg);
  border: 1px solid var(--v2-line); padding: 14px;
  position: relative;
}
.v2-sponsored .ad-label {
  position: absolute; top: 12px; right: 12px;
  font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--v2-muted-2); padding: 3px 7px; border: 1px solid var(--v2-line); border-radius: 4px;
}

/* Placeholder image */
.v2-img {
  background: linear-gradient(135deg, var(--v2-tint-blue), var(--v2-tint-teal));
  border-radius: var(--v2-r); position: relative; overflow: hidden;
}
.v2-img::after {
  content: ""; position: absolute; inset: 0;
  background-image: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.5), transparent 50%),
                    radial-gradient(circle at 70% 70%, rgba(30,111,184,0.15), transparent 50%);
}
.v2-img .tag {
  position: absolute; bottom: 10px; left: 10px;
  background: rgba(15,23,42,0.7); color: #fff;
  padding: 4px 8px; border-radius: 4px;
  font-size: 10px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase;
  z-index: 1;
}
.v2-img.brand { background: linear-gradient(135deg, var(--v2-primary), var(--v2-teal)); }
.v2-img.brand::after {
  background-image: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.3), transparent 50%),
                    radial-gradient(circle at 70% 70%, rgba(0,0,0,0.18), transparent 50%);
}
.v2-img.amber { background: linear-gradient(135deg, var(--v2-tint-amber), #FCD34D); }
.v2-img.rose { background: linear-gradient(135deg, var(--v2-tint-rose), #F9A8D4); }
.v2-img.mint { background: linear-gradient(135deg, var(--v2-tint-mint), #86EFAC); }
.v2-img.violet { background: linear-gradient(135deg, var(--v2-tint-violet), #C4B5FD); }

/* Segmented control */
.v2-seg {
  background: var(--v2-surface-soft); border-radius: var(--v2-r-full);
  padding: 4px; display: flex; gap: 2px;
}
.v2-seg .s { flex: 1; text-align: center; padding: 9px 8px; font-size: 13px; font-weight: 600; color: var(--v2-muted); border-radius: 999px; }
.v2-seg .s.on { background: #fff; color: var(--v2-ink); box-shadow: var(--v2-sh-1); }

/* Tabs underline */
.v2-tabs { display: flex; gap: 2px; border-bottom: 1px solid var(--v2-line); }
.v2-tabs .t { padding: 12px 4px; font-size: 13px; font-weight: 600; color: var(--v2-muted); margin-right: 18px; position: relative; }
.v2-tabs .t.on { color: var(--v2-primary); }
.v2-tabs .t.on::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 2px; background: var(--v2-primary); border-radius: 2px;
}

/* Switch */
.v2-switch { width: 40px; height: 24px; border-radius: 999px; background: var(--v2-line-2); position: relative; flex-shrink: 0; }
.v2-switch.on { background: var(--v2-primary); }
.v2-switch::after { content: ""; position: absolute; top: 2px; left: 2px; width: 20px; height: 20px; border-radius: 999px; background: #fff; box-shadow: var(--v2-sh-1); transition: left .15s; }
.v2-switch.on::after { left: 18px; }

/* Step progress */
.v2-steps { display: flex; align-items: center; gap: 4px; }
.v2-steps span { flex: 1; height: 4px; background: var(--v2-line); border-radius: 4px; }
.v2-steps span.on { background: var(--v2-primary); }
.v2-steps span.done { background: var(--v2-success); }

/* Brand mark */
.v2-mark {
  display: inline-flex; align-items: center; gap: 8px;
}
.v2-mark .logo {
  width: 32px; height: 32px; border-radius: 8px;
  background: var(--v2-primary);
  display: grid; place-items: center;
  color: #fff; font-weight: 800; font-size: 14px;
  letter-spacing: -0.04em;
  box-shadow: var(--v2-sh-blue);
}
.v2-mark .wm { line-height: 1.05; }
.v2-mark .wm .one { font-size: 13px; font-weight: 700; color: var(--v2-ink); }
.v2-mark .wm .two { font-size: 9.5px; font-weight: 600; letter-spacing: 0.06em; color: var(--v2-muted); text-transform: uppercase; }

/* Admin dark */
.ips2.admin { background: #0B1320; color: #E2E8F0; }
.ips2.admin .ips2-status { color: #E2E8F0; }
.ips2.admin .ips2-top .back, .ips2.admin .ips2-top .icon-btn { background: #1E293B; border-color: rgba(255,255,255,0.08); color: #E2E8F0; }
.ips2.admin .t-h1, .ips2.admin .t-h2, .ips2.admin .t-h3, .ips2.admin .t-h4 { color: #F1F5F9; }
.ips2.admin .t-body { color: #94A3B8; }
.ips2.admin .t-body-sm, .ips2.admin .t-meta { color: #64748B; }
.ips2.admin .v2-card { background: #1E293B; border-color: rgba(255,255,255,0.08); }
.ips2.admin .v2-card.brand { background: var(--v2-primary); }
.ips2.admin .v2-card.flat { background: transparent; }
.ips2.admin .v2-input { background: #1E293B; border-color: rgba(255,255,255,0.08); }
.ips2.admin .v2-input .val { color: #E2E8F0; }
.ips2.admin .v2-seg { background: #1E293B; }
.ips2.admin .v2-seg .s.on { background: #334155; color: #F1F5F9; }
.ips2.admin .v2-row { background: transparent; border-color: rgba(255,255,255,0.06); }
.ips2.admin .v2-tabs { border-color: rgba(255,255,255,0.08); }
.ips2.admin .v2-tabs .t { color: #64748B; }
.ips2.admin .v2-tabs .t.on { color: var(--v2-primary-500); }
.ips2.admin .v2-chip { background: #334155; color: #CBD5E1; }
.ips2.admin .v2-chip.outline { background: transparent; border-color: rgba(255,255,255,0.16); color: #CBD5E1; }
.ips2.admin .v2-btn.ghost { background: #1E293B; color: #E2E8F0; border-color: rgba(255,255,255,0.1); }

/* Helpers */
.flex { display: flex; }
.between { display: flex; justify-content: space-between; align-items: center; }
.col { display: flex; flex-direction: column; }
.gap-4 { gap: 4px; }
.gap-6 { gap: 6px; }
.gap-8 { gap: 8px; }
.gap-10 { gap: 10px; }
.gap-12 { gap: 12px; }
.gap-16 { gap: 16px; }
.mt-4 { margin-top: 4px; }
.mt-6 { margin-top: 6px; }
.mt-8 { margin-top: 8px; }
.mt-10 { margin-top: 10px; }
.mt-12 { margin-top: 12px; }
.mt-16 { margin-top: 16px; }
.mt-18 { margin-top: 18px; }
.mt-22 { margin-top: 22px; }
.mt-28 { margin-top: 28px; }
