  /* ===== patient journey timeline ===== */
  .journey-hero{display:grid;grid-template-columns:1.45fr .95fr;gap:14px;margin-bottom:14px}
  @media(max-width:720px){.journey-hero{grid-template-columns:1fr}}
  body.mview .journey-hero{grid-template-columns:1fr}
  .journey-target,.journey-goals,.journey-walk{background:#fff;border:1px solid var(--line-2);border-radius:var(--r-lg);box-shadow:var(--shadow)}
  .journey-target{padding:17px 18px}
  .jt-top{display:flex;justify-content:space-between;gap:10px;font-size:11px;color:var(--ink-3);margin-bottom:8px}
  .jt-top span:first-child{font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-2)}
  .jt-main{display:flex;align-items:flex-end;gap:8px;margin-bottom:10px}
  .jt-main strong{font-family:var(--display);font-size:32px;line-height:1;color:var(--green)}
  .jt-main span{font-size:12.5px;color:var(--ink-2);padding-bottom:4px}
  .jt-bar{height:7px;background:var(--green-soft);border-radius:99px;overflow:hidden;margin-bottom:10px}
  .jt-bar i{display:block;height:100%;background:var(--green);border-radius:99px}
  .journey-target p{font-size:12.5px;color:var(--ink-2);line-height:1.5;margin:0}
  .source-strip{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:12px;padding-top:12px;border-top:1px solid var(--line-2)}
  .source-strip span{font-size:11.5px;font-weight:700;color:var(--green)}
  .source-strip b{font-size:11px;color:var(--ink-3);font-weight:600}
  .source-strip button{margin-left:auto;font-size:11px;font-weight:700;color:var(--green);background:var(--green-soft);border-radius:999px;padding:6px 10px}
  .journey-walk{display:flex;align-items:center;gap:14px;padding:17px}
  .jw-icon{width:52px;height:52px;border-radius:15px;background:var(--saffron-soft);color:var(--saffron-ink);display:grid;place-items:center;flex:none}
  .jw-icon svg{width:25px;height:25px}
  .jw-label{font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);margin-bottom:4px}
  .jw-value{font-family:var(--display);font-weight:700;font-size:20px;color:var(--ink)}
  .jw-sub{font-size:11.5px;color:var(--ink-3);margin-top:3px;line-height:1.4}
  .journey-goals{padding:16px;margin-bottom:14px}
  .jg-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:13px;flex-wrap:wrap}
  .jg-head h4{font-size:14px;margin:0 0 3px}
  .jg-head span{font-size:12px;color:var(--ink-3)}
  .walk-reminder{display:none;grid-template-columns:repeat(3,1fr);gap:8px;background:var(--saffron-soft);border:1px solid #F0D9A8;border-radius:12px;padding:10px;margin-bottom:13px}
  .walk-reminder.on{display:grid}
  .walk-reminder button{font-size:11.5px;font-weight:700;color:var(--saffron-ink);background:#fff;border:1px solid #F0D9A8;border-radius:9px;padding:8px}
  .jg-days{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:13px}
  .jg-day{min-width:0;border:1px solid var(--line);background:var(--surface-2);border-radius:12px;padding:8px 4px;text-align:center}
  .jg-day span{display:block;font-size:10px;color:var(--ink-3);font-weight:700;letter-spacing:.04em}
  .jg-day b{display:block;font-size:11px;color:var(--ink-2);margin-top:4px}
  .jg-day.done{background:var(--green);border-color:var(--green)}
  .jg-day.done span,.jg-day.done b{color:#fff}
  .jg-day.on{border-color:var(--saffron);background:var(--saffron-soft)}
  .jg-list{display:grid;grid-template-columns:repeat(4,1fr);gap:9px}
  @media(max-width:720px){.jg-list{grid-template-columns:repeat(2,1fr)}}
  body.mview .jg-list{grid-template-columns:repeat(2,1fr)}
  .jg-item{border:1px solid var(--line);border-radius:12px;padding:10px;background:var(--surface-2);min-height:64px;display:flex;flex-direction:column;justify-content:space-between;gap:8px}
  .jg-item span{font-size:12px;color:var(--ink-2);line-height:1.35}
  .jg-item b{font-size:11.5px;color:var(--ink-3)}
  .jg-item.done{background:#fff;border-color:var(--green-soft)}
  .jg-item.done b{color:var(--green)}
  .journey-activity{background:#fff;border:1px solid var(--line-2);border-radius:var(--r-lg);box-shadow:var(--shadow);padding:16px;margin-bottom:14px}
  .ja-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:13px;flex-wrap:wrap}
  .ja-head h4{font-size:14px;margin:0 0 3px}
  .ja-head span{font-size:12px;color:var(--ink-3)}
  .ja-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:4px;margin-bottom:14px}
  .ja-tabs button{font-size:12.5px;font-weight:700;color:var(--ink-3);padding:8px;border-radius:9px}
  .ja-tabs button.on{background:#fff;color:var(--green);box-shadow:0 1px 4px rgba(0,0,0,.08)}
  .ja-chart{height:118px;border-bottom:2px solid var(--line);display:flex;align-items:flex-end;gap:10px;padding:0 2px 8px;margin-bottom:12px;background:linear-gradient(to bottom,transparent 0,transparent 48%,var(--line-2) 49%,transparent 50%)}
  .ja-chart i{flex:1;max-width:20px;background:var(--green);border-radius:7px 7px 2px 2px;min-height:3px}
  .ja-summary{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;margin-bottom:8px}
  .ja-summary strong{font-size:18px;color:var(--ink)}
  .ja-summary span{font-size:12px;color:var(--ink-3)}
  .empty-state{border:1px dashed var(--line);border-radius:12px;background:var(--surface-2);padding:14px;margin-bottom:10px}
  .empty-state strong{display:block;font-size:13px;color:var(--ink);margin-bottom:4px}
  .empty-state span{display:block;font-size:12px;color:var(--ink-3);line-height:1.45;margin-bottom:10px}
  .empty-state div{display:flex;gap:8px;flex-wrap:wrap}
  .ja-list{border-top:1px solid var(--line-2)}
  .ja-list div{display:grid;grid-template-columns:78px 1fr;gap:8px;padding:11px 0;border-bottom:1px solid var(--line-2)}
  .ja-list div:last-child{border-bottom:none;padding-bottom:0}
  .ja-list span{font-size:11.5px;color:var(--ink-3)}
  .ja-list b{font-size:13px;color:var(--ink)}
  .ja-list em{grid-column:2;font-style:normal;font-size:12px;color:var(--ink-3);margin-top:-5px}
  .journey-fab{position:sticky;bottom:22px;margin-left:auto;width:58px;z-index:20}
  .jf-main{width:58px;height:58px;border-radius:50%;background:var(--green);color:#fff;box-shadow:0 10px 28px rgba(31,93,68,.28);display:grid;place-items:center}
  .jf-main svg{width:24px;height:24px;transition:.2s}
  .journey-fab.open .jf-main svg{transform:rotate(45deg)}
  .jf-menu{position:absolute;right:0;bottom:68px;display:none;gap:10px;flex-direction:column;align-items:flex-end}
  .journey-fab.open .jf-menu{display:flex}
  .jf-menu button{display:flex;align-items:center;gap:10px;white-space:nowrap;background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 12px 8px 8px;box-shadow:var(--shadow);font-size:12.5px;font-weight:600;color:var(--ink)}
  .jf-menu button span{width:32px;height:32px;border-radius:50%;background:var(--surface-2);color:var(--green);display:grid;place-items:center;font-size:11px;font-weight:800}
  .data-modal{display:none;position:fixed;inset:0;z-index:1200;align-items:flex-end;justify-content:center}
  .data-modal.on{display:flex}
  .dm-backdrop{position:absolute;inset:0;background:rgba(14,31,24,.45)}
  .dm-panel{position:relative;width:min(520px,100%);background:var(--surface);border-radius:20px 20px 0 0;box-shadow:0 -8px 32px rgba(0,0,0,.18);padding:18px 22px 24px}
  .dm-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
  .dm-top strong{font-size:28px;font-family:var(--display);font-weight:700;color:var(--ink)}
  .dm-top button{font-size:13px;font-weight:700;color:var(--green);padding:8px}
  .dm-top button:first-child{font-size:30px;color:var(--ink-2);line-height:1}
  .dm-time{display:grid;grid-template-columns:1fr auto auto;gap:22px;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);padding:16px 0;font-size:14px}
  .dm-time span{font-weight:700;color:var(--ink)}
  .dm-time b{font-weight:600;color:var(--ink-2)}
  .dm-field{padding:20px 0 24px;border-bottom:1px solid var(--line-2)}
  .dm-field>span{font-size:18px;font-weight:700;color:var(--ink)}
  .dm-field>em{float:right;font-style:normal;font-size:14px;font-weight:700;color:var(--ink-2)}
  .dm-picker{clear:both;display:grid;grid-template-columns:repeat(3,1fr) 20px repeat(3,1fr);align-items:center;gap:6px;text-align:center;margin-top:24px}
  .dm-picker span,.dm-picker b,.dm-picker i{font-style:normal;font-size:21px;color:var(--ink-3);padding:9px 0}
  .dm-picker b{font-size:26px;color:var(--ink);border-top:2px solid var(--line);border-bottom:2px solid var(--line)}
  .dm-presets{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}
  .dm-presets button{font-size:12px;font-weight:700;color:var(--ink-2);background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:8px 12px}
  .safety-note{background:#FFF8EC;border:1px solid #F0D9A8;border-radius:12px;padding:11px 13px;font-size:12px;line-height:1.45;color:var(--saffron-ink);margin:12px 0}
  .care-insights{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}
  .care-insights.compact{grid-template-columns:repeat(2,1fr);margin-bottom:18px}
  .ci-card{background:#fff;border:1px solid var(--line-2);border-radius:var(--r-md);padding:13px;box-shadow:var(--shadow)}
  .ci-card.warn{background:#FFF8EC;border-color:#F0D9A8}
  .ci-label{font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px}
  .ci-card strong{display:block;font-size:13.5px;color:var(--ink);margin-bottom:5px}
  .ci-card span{display:block;font-size:12px;color:var(--ink-2);line-height:1.45}
  @media(max-width:760px){.care-insights,.care-insights.compact{grid-template-columns:1fr}.walk-reminder{grid-template-columns:1fr}.source-strip button{margin-left:0}}
  .tl-card.walk{background:var(--green-soft);border-color:#CFE5D9}
  .tl-card.meal{background:#fff;border-color:var(--line-2)}
  .tl-points{display:inline-flex;align-items:center;border-radius:99px;background:#fff;border:1px solid var(--line);padding:4px 8px;font-size:11px;font-weight:700;color:var(--green);margin-top:9px}
  .cp-history{margin-bottom:18px}
  .cp-hist-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}
  .cp-hist-head h5{font-size:13px;font-weight:600;margin:0}
  .tl-month{font-size:10.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin:4px 0 11px 34px}
  .tl-item{display:flex;gap:14px}
  .tl-axis{width:20px;flex:none;display:flex;justify-content:center;position:relative}
  .tl-axis:before{content:'';position:absolute;top:0;bottom:-14px;left:9px;width:2px;background:var(--line)}
  .tl-item:last-child .tl-axis:before{display:none}
  .tl-dot{width:13px;height:13px;border-radius:50%;border:3px solid var(--surface);box-shadow:0 0 0 1px var(--line);margin-top:4px;z-index:1}
  .tl-card{flex:1;background:var(--surface-2);border:1px solid var(--line-2);border-radius:var(--r-md);padding:13px 14px;margin-bottom:14px}
  .tl-card.rx{background:#FFF8EC;border-color:#F0D9A8}
  .tl-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:5px}
  .tl-type{font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
  .tl-date{font-size:11px;color:var(--ink-3);white-space:nowrap}
  .tl-title{font-size:13px;font-weight:600;margin-bottom:3px}
  .tl-detail{font-size:12.5px;color:var(--ink-2);line-height:1.5}
  .tl-rx{list-style:none;margin:9px 0 0;display:grid;gap:5px}
  .tl-rx li{font-size:12px;color:var(--ink);padding-left:16px;position:relative}
  .tl-rx li:before{content:'';position:absolute;left:2px;top:7px;width:5px;height:5px;border-radius:50%;background:var(--saffron)}
  .tl-rxbtn{display:flex;gap:8px;margin-top:11px}
  .tl-pill{font-size:11px;font-weight:500;color:var(--saffron-ink);background:#fff;border:1px solid #F0D9A8;border-radius:99px;padding:5px 11px;cursor:pointer}
  .tl-pill:hover{background:var(--saffron-soft)}

  /* prescription sidebar */
  #rx-modal{display:none;position:fixed;inset:0;z-index:1000;justify-content:flex-end}
  #rx-modal.on{display:flex}
  .rx-overlay{position:absolute;inset:0;background:rgba(23,37,29,.35)}
  .rx-panel{position:relative;background:#fff;width:340px;height:100%;padding:28px 22px 36px;z-index:1;overflow-y:auto;display:flex;flex-direction:column;box-shadow:-4px 0 24px rgba(0,0,0,.08)}
  .rx-panel-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}
  .rx-panel-label{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--saffron-ink);margin-bottom:3px}
  .rx-panel-date{font-size:12px;color:var(--ink-3)}
  .rx-close{background:var(--surface-2);border:1px solid var(--line);border-radius:50%;width:30px;height:30px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-2);flex:none}
  .rx-panel-title{font-size:15px;font-weight:600;color:var(--ink);margin:0 0 16px}
  .rx-panel-items{list-style:none;margin:0 0 auto;display:grid;gap:9px}
  .rx-panel-items li{font-size:13px;color:var(--ink);padding:10px 14px 10px 38px;background:var(--saffron-soft);border-radius:var(--r-md);position:relative;line-height:1.45}
  .rx-panel-items li:before{content:'';position:absolute;left:14px;top:14px;width:7px;height:7px;border-radius:50%;background:var(--saffron)}
  .rx-panel-by{font-size:12px;color:var(--ink-3);margin-top:24px;padding-top:16px;border-top:1px solid var(--line)}
