/* ============================================================
   IVF Pulse OS — Patient profile surfaces
   Header, collapsible AI Summary, and the clinical tabs
   (Consultation Notes, Record Vitals, Case Record, Medical
   History, Logs, Patient Performance). Builds on design-system
   tokens + os.css.
   ============================================================ */

/* ---------------- Profile header card ---------------- */
.pheader { background: var(--surface-card); border-radius: var(--radius-lg); box-shadow: var(--shadow-card); padding: 18px 20px; margin-bottom: 14px; }
.pheader__top { display: flex; align-items: center; gap: 12px; }
.pheader__top .nm { font: var(--fw-semibold) 18px/1.2 var(--font-sans); color: var(--text-primary); }
.pheader__chev { margin-left: auto; background: transparent; border: 0; cursor: pointer; color: var(--text-tertiary); font-size: 20px; transition: transform var(--dur-base) var(--ease-standard); }
.pheader--collapsed .pheader__chev { transform: rotate(180deg); }
.pheader__grid { display: grid; grid-template-columns: 1.1fr 1fr auto; gap: 24px; margin-top: 16px; align-items: start; }
.pinfo { display: flex; flex-direction: column; gap: 9px; }
.pinfo .r { display: flex; gap: 12px; font: 400 13px/1.3 var(--font-sans); }
.pinfo .r label { color: var(--text-tertiary); min-width: 52px; }
.pinfo .r span { color: var(--text-primary); font-weight: var(--fw-medium); }
.visitboxes { display: flex; gap: 10px; }
.visitbox { border-radius: var(--radius-md); padding: 9px 14px; min-width: 100px; }
.visitbox label { display: block; font: 400 10px/1.3 var(--font-sans); color: var(--text-tertiary); margin-bottom: 3px; }
.visitbox b { font: var(--fw-semibold) 13px/1.3 var(--font-sans); color: var(--text-primary); }
.visitbox--first { background: #F4EFFF; box-shadow: inset 0 0 0 1px #D7C8F2; }
.visitbox--last { background: var(--green-100); box-shadow: inset 0 0 0 1px var(--green-200); }
.visitbox--doctor { background: var(--warning-tint); box-shadow: inset 0 0 0 1px rgba(230,162,0,.3); }

/* ---------------- Collapsible AI Summary ---------------- */
.aisum { background: var(--ai-banner); box-shadow: var(--ring); border-radius: var(--radius-md); margin-bottom: 18px; overflow: hidden; }
.aisum__head { display: flex; align-items: center; gap: 9px; padding: 12px 16px; cursor: pointer;
  font: var(--fw-semibold) 13px/1.3 var(--font-sans); color: var(--primary); }
.aisum__head .sp { font-size: 16px; }
.aisum__head .chev { margin-left: auto; transition: transform var(--dur-base) var(--ease-standard); font-size: 18px; }
.aisum--open .aisum__head .chev { transform: rotate(180deg); }
.aisum__body { padding: 2px 16px 14px 39px; }
.aisum__body ul { margin: 0; padding-left: 16px; display: flex; flex-direction: column; gap: 6px; }
.aisum__body li { font: 400 12.5px/1.5 var(--font-sans); color: var(--primary); }

/* ---------------- Tab bar row (tabs + context action) ---------------- */
.tabrow { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; }
.tabrow .detail-tabs { flex: 1; margin-bottom: 0; }
.tabrow + * { margin-top: 18px; }
.tabaction { margin-bottom: 8px; }

/* ---------------- Record Vitals ---------------- */
.vitgrid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; }
@media (max-width: 1180px) { .vitgrid { grid-template-columns: repeat(3, 1fr); } }
.vitfield { background: var(--surface-card); box-shadow: var(--ring); border-radius: var(--radius-md); padding: 14px 15px; }
.vitfield label { display: block; font: var(--fw-semibold) 11px/1.3 var(--font-sans); letter-spacing: .03em; text-transform: uppercase; color: var(--text-tertiary); margin-bottom: 9px; }
.vitfield input { width: 100%; border: 0; outline: none; background: transparent; font: 400 14px/1.4 var(--font-sans); color: var(--text-primary); }
.vitfield input::placeholder { color: var(--text-disabled); }
.vitfield--filled { box-shadow: inset 0 0 0 1px var(--primary-tint-16); }
.savebar { display: flex; justify-content: center; margin-top: 24px; }

/* ---------------- Consultation Notes ---------------- */
.cnform { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 980px) { .cnform { grid-template-columns: 1fr; } }
.cnfield { background: var(--surface-page-2); box-shadow: var(--ring); border-radius: var(--radius-md); padding: 14px 16px; }
.cnfield > label { font: var(--fw-semibold) 13px/1.3 var(--font-sans); color: var(--text-primary); }
.cnfield .desc { font: 400 12px/1.4 var(--font-sans); color: var(--text-tertiary); margin-left: 6px; }
.cnfield textarea { width: 100%; margin-top: 10px; border: 0; box-shadow: var(--ring); border-radius: var(--radius-sm);
  background: var(--surface-card); padding: 10px 12px; min-height: 78px; font: 400 13px/1.5 var(--font-sans); color: var(--text-primary); resize: vertical; }
.cnfield textarea:focus { outline: none; box-shadow: inset 0 0 0 1.5px var(--primary); }
.cnsection { background: var(--surface-page-2); box-shadow: var(--ring); border-radius: var(--radius-md); padding: 16px; margin-top: 16px; }
.cnsection__head { display: flex; align-items: baseline; gap: 8px; margin-bottom: 4px; }
.cnsection__head b { font: var(--fw-semibold) 14px/1.3 var(--font-sans); color: var(--text-primary); }
.cnsection__head .desc { font: 400 12px/1.4 var(--font-sans); color: var(--text-tertiary); }
.rxgrid { display: grid; grid-template-columns: 1.2fr 1fr .8fr .8fr 1fr auto; gap: 12px; align-items: end; margin-top: 14px; }
.rxgrid .addmed { align-self: end; }
.addmed-row { display: flex; justify-content: center; margin-top: 12px; }
.summrow { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; margin-top: 14px; align-items: center; }
.toggle-field { display: flex; flex-direction: column; gap: 8px; }
.toggle-field > label { font: var(--fw-semibold) 11px/1.3 var(--font-sans); letter-spacing: .03em; text-transform: uppercase; color: var(--text-tertiary); }

/* ---------------- Case Record ---------------- */
.crtabs { margin-bottom: 14px; }
.visitcard { box-shadow: var(--ring); border-radius: var(--radius-md); overflow: hidden; margin-bottom: 12px; background: var(--surface-card); }
.visitcard__top { display: flex; align-items: center; gap: 18px; padding: 14px 16px; }
.visitcard__date { width: 100px; flex: none; }
.visitcard__date b { display: block; font: var(--fw-semibold) 15px/1.2 var(--font-sans); color: var(--text-primary); }
.visitcard__date small { font: 400 12px/1.3 var(--font-sans); color: var(--text-tertiary); }
.visitcard__meta { flex: 1; min-width: 0; }
.visitcard__meta b { font: var(--fw-medium) 14px/1.3 var(--font-sans); color: var(--text-primary); }
.visitcard__meta div { font: 400 12.5px/1.3 var(--font-sans); color: var(--text-tertiary); margin-top: 2px; }
.visitcard .aisum { margin: 0; border-radius: 0; box-shadow: none; border-top: var(--hairline); }

/* ---------------- Medical History (master-detail) ---------------- */
.mhgrid { display: grid; grid-template-columns: 270px 1fr 300px; gap: 16px; align-items: start; }
@media (max-width: 1180px) { .mhgrid { grid-template-columns: 240px 1fr; } .mhgrid .mhai { display: none; } }
.mhlist { display: flex; flex-direction: column; gap: 8px; max-height: 560px; overflow-y: auto; }
.mhhead { font: var(--fw-semibold) 14px/1.3 var(--font-sans); color: var(--text-primary); margin-bottom: 12px; }
.mhitem { display: flex; align-items: center; gap: 10px; padding: 11px 13px; border-radius: var(--radius-md);
  box-shadow: var(--ring); cursor: pointer; background: var(--surface-card); transition: var(--transition-base); }
.mhitem:hover { box-shadow: var(--ring-primary); }
.mhitem--active { box-shadow: inset 0 0 0 1.5px var(--primary); background: var(--primary-tint-08); }
.mhitem__ic { width: 34px; height: 34px; border-radius: var(--radius-sm); flex: none; display: flex; align-items: center; justify-content: center;
  font-size: 17px; background: var(--surface-sunken); color: var(--text-tertiary); }
.mhitem__m { flex: 1; min-width: 0; }
.mhitem__m b { display: block; font: var(--fw-medium) 13px/1.3 var(--font-sans); color: var(--text-primary); }
.mhitem__m small { font: 400 11.5px/1.3 var(--font-sans); color: var(--text-tertiary); }
.mhpreview { background: var(--surface-card); box-shadow: var(--ring); border-radius: var(--radius-md); padding: 22px; min-height: 360px; }
.mhpreview__title { font: var(--fw-semibold) 16px/1.3 var(--font-sans); color: var(--text-primary); margin: 0 0 4px; }
.mhpreview__sub { font: 400 12.5px/1.4 var(--font-sans); color: var(--text-tertiary); margin: 0 0 18px; }
.mhpreview .ln { height: 9px; border-radius: 3px; background: var(--grey-200); margin-bottom: 11px; }
.mhrow { display: flex; justify-content: space-between; padding: 9px 0; border-bottom: var(--hairline); font: 400 13px/1.4 var(--font-sans); }
.mhrow span { color: var(--text-tertiary); } .mhrow b { color: var(--text-primary); font-weight: var(--fw-medium); }

/* ---------------- Logs (HIS event feed) ---------------- */
.logfeed { position: relative; padding-left: 6px; }
.logitem { display: flex; gap: 14px; position: relative; padding-bottom: 18px; }
.logitem::before { content: ""; position: absolute; left: 13px; top: 26px; bottom: -4px; width: 2px; background: var(--grey-200); }
.logitem:last-child::before { display: none; }
.logitem__dot { width: 28px; height: 28px; border-radius: 50%; flex: none; display: flex; align-items: center; justify-content: center;
  font-size: 15px; z-index: 1; background: var(--surface-card); box-shadow: var(--ring); color: var(--text-tertiary); }
.logitem__dot--ai { background: var(--primary-tint-12); color: var(--primary); box-shadow: none; }
.logitem__dot--ok { background: var(--success-tint); color: var(--success-dark); box-shadow: none; }
.logitem__c { flex: 1; padding-top: 3px; }
.logitem__c b { font: var(--fw-medium) 13.5px/1.4 var(--font-sans); color: var(--text-primary); }
.logitem__c p { font: 400 12.5px/1.4 var(--font-sans); color: var(--text-tertiary); margin: 2px 0 0; }
.logitem__time { font: 400 11.5px/1.3 var(--font-sans); color: var(--text-disabled); white-space: nowrap; flex: none; padding-top: 4px; }

/* ---------------- Patient Performance ---------------- */
.perfgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 980px) { .perfgrid { grid-template-columns: 1fr; } }
.perftable { width: 100%; border-collapse: collapse; }
