@import url('https://fonts.googleapis.com/css2?family=Inconsolata:wght@400;600;700&family=Poppins:wght@500;600;700;800&family=Roboto:wght@400;500;600;700&display=swap');
*{margin:0;padding:0;box-sizing:border-box;}

/* ── Design tokens ── */
:root{
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:20px; --s-6:24px; --s-8:32px;
  --r-sm:4px; --r-md:8px; --r-lg:12px; --r-pill:999px;
  --t-micro:11px; --t-sm:12px; --t-body:13px; --t-input:14px; --t-h3:15px; --t-h2:18px; --t-display:22px;
  --slate-0:#fff; --slate-50:#F8FAFC; --slate-100:#F1F5F9; --slate-200:#E2E8F0;
  --slate-300:#CBD5E1; --slate-400:#94A3B8; --slate-500:#64748B;
  --slate-600:#475569; --slate-700:#334155; --slate-900:#0F172A;
  --blue-50:#EFF6FF; --blue-100:#DBEAFE; --blue-200:#BFDBFE;
  --blue-500:#3B82F6; --blue-600:#2563EB; --blue-700:#1D4ED8;
  --green-600:#16A34A; --amber-700:#92400E; --red-600:#DC2626;
  --gray-500:#6B7280; /* legacy gray that doesn't fit the slate ramp; used for muted labels and footer text */
  --border:1px solid #E5E7EB;
  --shadow-card:0 1px 3px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);
  --label-tracking:.06em;
}

body{font-family:'Roboto',sans-serif;background:#F8FAFC;color:#111827;line-height:1.6;font-size:15px;-webkit-font-smoothing:antialiased;}

/* ── Header ── */
.hdr{background:#fff;height:52px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;border-bottom:1px solid rgba(0,0,0,.08);}
.hdr-brand{display:flex;align-items:center;gap:8px;}
.hdr-brand img{border-radius:6px;}
.hdr-brand span{font-family:'Poppins',sans-serif;font-size:16px;font-weight:700;letter-spacing:-.3px;}
.hdr-brand span em{font-style:normal;color:#3B82F6;}
.hdr-actions{display:flex;align-items:center;gap:8px;}
.hdr-badge{padding:2px 8px;border-radius:100px;font-size:10px;font-weight:700;background:#FEF3C7;color:#92400E;letter-spacing:.06em;}
.hdr-cta{display:inline-flex;align-items:center;padding:7px 14px;background:#3B82F6;color:#fff;border-radius:8px;font-size:13px;font-weight:600;text-decoration:none;transition:background .15s;}
.hdr-cta:hover{background:#2563EB;}

/* ── Banner ── */
.banner{background:linear-gradient(135deg,#EFF6FF,#DBEAFE);border-bottom:1px solid #93C5FD;padding:8px 24px;text-align:center;font-size:13px;color:#1E40AF;}
.banner strong{font-weight:700;}
.banner a{color:#1E40AF;font-weight:700;}

/* ── Main container ── */
.main{max-width:820px;margin:0 auto;padding:20px 24px 60px;}

/* ── Card (the core unit) ── */
.card{background:#fff;border:1px solid #E2E8F0;border-radius:12px;box-shadow:var(--shadow-card);overflow:hidden;margin-bottom:16px;}

/* ── Drug bar (dark header) ── */
.drug-bar{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;background:#0F172A;color:#fff;}
.drug-bar-left .drug-name{font-family:'Poppins',sans-serif;font-size:18px;font-weight:700;letter-spacing:-.01em;}
.drug-bar-left .drug-generic{font-size:11px;color:rgba(255,255,255,.45);margin-top:2px;}
.drug-bar-right{text-align:right;}
.drug-bar-right .drug-jcode{font-family:'Inconsolata',monospace;font-size:14px;font-weight:700;color:#BFDBFE;letter-spacing:.02em;}
.drug-bar-right .drug-meta{font-size:10px;color:rgba(255,255,255,.45);margin-top:2px;}

/* ── Info grid ── */
.info-grid{display:grid;grid-template-columns:1fr 1fr 1.2fr;background:#fff;border-bottom:1px solid #E2E8F0;}
.info-cell{padding:10px 20px;text-align:center;position:relative;}
.info-cell + .info-cell{border-left:1px solid #F1F5F9;}
.info-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#94A3B8;margin-bottom:2px;}
.info-val{font-family:'Inconsolata',monospace;font-size:13px;font-weight:600;color:#475569;}
.info-cell.hero .info-val{font-size:18px;font-weight:700;color:#1D4ED8;}
.info-sub{font-size:10px;color:#94A3B8;margin-top:1px;}
.info-flash{transition:background .4s ease-out;}
.info-flash.flash-on{background:#EFF6FF !important;transition:none;}

/* ── SAD (Self-Administered Drug) banner — replaces info-grid when the
      selected drug is on the CMS SAD Exclusion List. Amber, high-contrast,
      same outer shape as .info-grid so the layout doesn't jump. ── */
.sad-banner{background:#FFFBEB;border-bottom:1px solid #F59E0B;border-top:3px solid #D97706;padding:14px 20px;}
.sad-banner-title{font-family:'Poppins',sans-serif;font-size:12px;font-weight:700;color:#92400E;text-transform:uppercase;letter-spacing:.05em;margin:0 0 6px;display:flex;align-items:center;gap:6px;}
.sad-banner-title::before{content:'⚠';font-size:14px;}
.sad-banner-body{font-size:12px;line-height:1.5;color:#78350F;margin:0;}
.sad-banner-body strong{color:#451A03;}
.sad-banner-link{display:inline-block;margin-top:6px;font-size:11px;font-weight:600;color:#B45309;text-decoration:underline;}
.sad-banner-link:hover{color:#78350F;}
.sad-banner-meta{margin-top:6px;font-size:10px;color:#A16207;font-style:italic;}
.sad-banner-meta-warn{color:#991B1B;font-weight:600;font-style:normal;background:#FEF2F2;padding:4px 8px;border-left:3px solid #DC2626;border-radius:3px;margin-top:4px;}

/* Per-line SAD pill used in the Cost Breakdown next to drug names */
.ce-sad-pill{display:inline-block;margin-left:8px;padding:2px 7px;border-radius:100px;background:#FEF3C7;color:#92400E;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;vertical-align:middle;}
/* "Modifier makes it covered" variant — green, signals all-clear */
.ce-sad-pill-ok{display:inline-block;margin-left:8px;padding:2px 7px;border-radius:100px;background:#DCFCE7;color:#14532D;font-size:9px;font-weight:700;letter-spacing:.05em;vertical-align:middle;}
/* Inline modifier editor chip — shown only on SAD route-dependent lines */
.ce-mod-chip{display:inline-block;margin-left:6px;padding:2px 8px;border-radius:100px;background:#EFF6FF;color:#1E40AF;font-size:10px;font-weight:700;font-family:'Inconsolata',monospace;letter-spacing:.04em;cursor:pointer;border:1px dashed #93C5FD;vertical-align:middle;}
.ce-mod-chip:hover{background:#DBEAFE;border-style:solid;}

/* ── Dose row ── */
.dose-row{display:flex;gap:12px;padding:16px 20px;border-top:1px solid #E5E7EB;align-items:flex-end;flex-wrap:wrap;}
.dose-field{display:flex;flex-direction:column;gap:2px;}
.dose-field label{font-size:10px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;}
.dose-field input,.dose-field select{height:34px;padding:0 8px;border:1px solid #E2E8F0;border-radius:8px;font-size:14px;color:#111827;background:#fff;outline:none;transition:border-color .15s;font-family:'Inconsolata',monospace;font-weight:600;}
.dose-field select{font-family:'Roboto',sans-serif;font-weight:400;}
input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
input[type=number]{-moz-appearance:textfield;appearance:textfield;}
.dose-field input:focus,.dose-field select:focus{border-color:#3B82F6;}
.dose-field input{width:80px;}
.dose-field select{width:90px;}

/* ── Step circles ── */
.step-num{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#0F172A;color:#fff;font-family:'Poppins',sans-serif;font-size:11px;font-weight:700;flex-shrink:0;}

/* ── Section label ── */
.sec-label{font-family:'Poppins',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#9CA3AF;padding:16px 20px 0;display:flex;align-items:center;gap:8px;}

/* ── Programs (compact list) ── */
.progs{padding:16px 20px;border-top:1px solid #E5E7EB;}
.progs-hdr{font-family:'Poppins',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#9CA3AF;margin-bottom:8px;display:flex;align-items:center;gap:6px;}
.progs-hdr .cnt{font-family:'Inconsolata',monospace;font-size:10px;font-weight:700;background:#DBEAFE;color:#1D4ED8;padding:1px 7px;border-radius:100px;}
.prog{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;border-radius:8px;border:1px solid #F3F4F6;margin-bottom:4px;transition:background .15s;}
.prog:hover{background:#F9FAFB;}
.prog.best{border-color:#DBEAFE;}
.prog-left .prog-name{font-size:12px;font-weight:500;color:#111827;}
.prog-left .prog-type{font-size:10px;color:#9CA3AF;}
.prog-right{text-align:right;}
.prog-right .prog-cost{font-family:'Inconsolata',monospace;font-size:14px;font-weight:700;color:#111827;}
.prog-right .prog-max{font-size:10px;color:#94A3B8;}
.badge{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:2px 7px;border-radius:100px;margin-left:4px;}
.badge-open{background:#DBEAFE;color:#1D4ED8;}
.badge-closed{background:#FEE2E2;color:#DC2626;}
.badge-best{background:#1D4ED8;color:#fff;}
.prog-toggle{font-size:11px;color:#3B82F6;cursor:pointer;font-weight:500;margin-top:4px;padding:2px 0;}
.prog-toggle:hover{text-decoration:underline;}
.prog-extra{display:none;}
.prog-extra.open{display:block;}

/* ── Insurance pills ── */
.ins-row{padding:16px 20px;border-top:1px solid #E5E7EB;}
.ins-pills{display:flex;gap:6px;flex-wrap:wrap;}
.ins-pill{flex:1;min-width:100px;padding:10px 12px;border:1px solid #E2E8F0;border-radius:8px;background:#fff;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .15s;font-size:12px;font-weight:600;color:#4B5563;}
.ins-pill:hover{border-color:#3B82F6;}
.ins-pill:has(input:checked){border:2px solid #3B82F6;background:#EFF6FF;color:#1D4ED8;padding:9px 11px;}
.ins-pill input[type="radio"]{accent-color:#3B82F6;margin:0;}

/* ── Benefits (compact) ── */
.benefits{padding:16px 20px;border-top:1px solid #E5E7EB;display:none;}
.benefits.vis{display:block;}
.ben-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:10px;}
.ben-pair{display:flex;gap:8px;align-items:end;}
.ben-field{flex:1;}
.ben-field label{font-size:10px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px;display:block;}
.ben-field input{width:100%;height:34px;padding:0 8px 0 22px;border:1px solid #E2E8F0;border-radius:8px;font-size:14px;color:#111827;background:#fff;outline:none;font-family:'Inconsolata',monospace;font-weight:600;transition:border-color .15s;}
.ben-field input:focus{border-color:#3B82F6;}
.ben-field .dollar{position:relative;}
.ben-field .dollar::before{content:'$';position:absolute;left:8px;top:50%;transform:translateY(-50%);font-family:'Inconsolata',monospace;font-size:14px;font-weight:600;color:#9CA3AF;pointer-events:none;}
.ben-bar{height:8px;background:#F3F4F6;border-radius:4px;overflow:hidden;margin:3px 0 0;}
.ben-bar .fill{height:100%;border-radius:4px;transition:width .4s ease-out;}
.ben-bar .fill.ded{background:#D97706;}
.ben-bar .fill.oop{background:#3B82F6;}
.ben-remaining{display:flex;justify-content:space-between;font-size:11px;color:#9CA3AF;margin-top:2px;}
.ben-remaining strong{color:#111827;font-weight:600;}
.coins-row{display:flex;align-items:center;gap:6px;margin-top:4px;}
.coins-row input{width:60px;height:34px;padding:0 8px;border:1px solid #E2E8F0;border-radius:8px;font-size:14px;text-align:center;font-weight:600;color:#111827;outline:none;font-family:'Inconsolata',monospace;}
.coins-row input:focus{border-color:#3B82F6;}
.coins-row .sep{font-size:14px;color:#9CA3AF;font-weight:600;}
.coins-legend{display:flex;gap:30px;font-size:10px;color:#9CA3AF;margin-top:2px;}

/* ── Estimate boxes ── */
.estimate{padding:16px 20px;border-top:1px solid #E5E7EB;display:none;}
.estimate.vis{display:block;}
.est-boxes{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.est-box{padding:16px;border-radius:8px;text-align:center;}
.est-box.without{background:#F8FAFC;border:1px solid #E2E8F0;}
.est-box.with{background:#EFF6FF;border:1px solid #BFDBFE;}
.est-box .est-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px;}
.est-box.without .est-label{color:var(--gray-500);}
.est-box.with .est-label{color:#1D4ED8;}
.est-box .est-val{font-family:'Inconsolata',monospace;font-size:22px;font-weight:700;}
.est-box.without .est-val{color:#111827;}
.est-box.with .est-val{color:#1D4ED8;}
.est-box .est-sub{font-size:10px;color:#9CA3AF;margin-top:2px;}
.est-savings{text-align:center;margin-top:8px;font-size:12px;color:#1D4ED8;font-weight:600;}

/* ── Copy template ── */
.copy-section{padding:16px 20px;border-top:1px solid #E5E7EB;}
.copy-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.copy-hdr-left{display:flex;align-items:center;gap:8px;}
.copy-output{background:#F8FAFC;border:1px solid #E5E7EB;border-radius:8px;padding:14px;font-family:'Inconsolata',monospace;font-size:12px;line-height:1.7;color:#374151;white-space:pre-wrap;word-break:break-word;max-height:260px;overflow-y:auto;}
.copy-btn-v3{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:#0F172A;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;font-family:'Roboto',sans-serif;}
.copy-btn-v3:hover{background:#1E293B;}
.copy-btn-v3.copied{background:#16A34A;}
.customize-link{font-size:11px;color:#9CA3AF;text-decoration:none;transition:color .15s;}
.customize-link:hover{color:#3B82F6;}

/* ── CTA at bottom of card ── */
.card-cta{display:block;text-align:center;padding:14px 20px;background:#3B82F6;color:#fff;font-family:'Poppins',sans-serif;font-size:13px;font-weight:600;text-decoration:none;transition:background .2s;letter-spacing:.01em;}
.card-cta:hover{background:#2563EB;}

/* ── Cost Estimate Grid (clean typography-based, no badges) ── */
.ce-grid{width:100%;border-collapse:collapse;}
.ce-grid thead th{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#94A3B8;padding:0 8px 6px;text-align:right;white-space:nowrap;}
.ce-grid thead th:first-child{text-align:left;}
.ce-grid thead th:nth-child(2){text-align:left;}
.ce-grid tbody td{padding:9px 8px;border-top:1px solid #F3F4F6;font-size:13px;vertical-align:middle;}
.ce-grid tbody tr:first-child td{border-top:1px solid #E5E7EB;}
.ce-grid tbody tr:hover{background:#F8FAFC;}
/* Unified item typography — differentiate only via left rail, not font */
.ce-grid tbody td:nth-child(2){font-weight:600;color:#111827;font-style:normal;}
.ce-name{text-transform:none;}
.ce-grid tbody tr.ce-drug td:first-child{box-shadow:inset 3px 0 0 #3B82F6;}
.ce-grid tbody tr.ce-admin td:first-child,
.ce-grid tbody tr.ce-office td:first-child{box-shadow:inset 3px 0 0 transparent;}
.ce-name{color:inherit;}
.ce-cpt{color:#9CA3AF;font-family:'Inconsolata',monospace;font-size:11px;margin-left:6px;font-weight:500;}
.ce-mono{font-family:'Inconsolata',monospace;font-weight:600;text-align:right;white-space:nowrap;}
.ce-muted{color:#9CA3AF;font-size:11px;}
.ce-grid tfoot td{padding:10px 8px;border-top:2px solid #E5E7EB;font-weight:700;font-size:11px;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;}
.ce-grid tfoot .ce-mono{font-size:14px;color:#111827;text-transform:none;letter-spacing:0;}
.ce-grid .ce-detail-col{display:none;}
.ce-grid.ce-show-detail .ce-detail-col{display:table-cell;}
.ce-detail-toggle{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:#475569;text-decoration:none;font-weight:600;padding:6px 12px;border:1px solid #E2E8F0;border-radius:8px;background:#fff;cursor:pointer;transition:all .15s;margin-left:12px;}
.ce-detail-toggle:hover{border-color:#3B82F6;color:#3B82F6;}
.ce-detail-toggle.on{background:#EFF6FF;border-color:#3B82F6;color:#1D4ED8;}
.ce-remove-btn{width:20px;height:20px;border:none;background:transparent;color:#D1D5DB;border-radius:4px;cursor:pointer;font-size:16px;line-height:1;padding:0;transition:all .15s;}
.ce-remove-btn:hover{color:#DC2626;background:#FEE2E2;}
/* ── Editable cells — click-to-edit ── */
.ce-editable{cursor:pointer;border-radius:4px;padding:2px 4px;margin:-2px -4px;transition:background .12s,box-shadow .12s;border:1px solid transparent;}
.ce-editable:hover{background:#EFF6FF;border-color:#BFDBFE;}
.ce-editable-input{border:1.5px solid #3B82F6;border-radius:5px;padding:3px 6px;font-size:inherit;font-family:inherit;font-weight:inherit;color:inherit;outline:none;background:#fff;box-shadow:0 0 0 3px rgba(59,130,246,.12);width:100%;box-sizing:border-box;}
.ce-editable-input.ce-edit-mono{font-family:'Inconsolata',monospace;text-align:right;}
.ce-editable-input.ce-edit-name{font-weight:600;}
.ce-editable-input.ce-edit-code{font-family:'Inconsolata',monospace;font-size:11px;color:#9CA3AF;font-weight:500;width:70px;}

/* ── Drug details collapsible ── */
.details-row{border-top:1px solid #E5E7EB;}
.details-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#F8FAFC;border:none;cursor:pointer;font-family:'Roboto',sans-serif;font-size:11px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;transition:background .15s;}
.details-toggle:hover{background:#F3F4F6;color:#111827;}
.details-toggle .chev{transition:transform .2s;font-size:10px;color:#9CA3AF;}
.details-toggle.open{background:#F3F4F6;color:#111827;}
.details-toggle.open .chev{transform:rotate(90deg);color:#3B82F6;}
.details-body{padding:16px 20px;background:#F8FAFC;border-top:1px solid #E5E7EB;display:none;font-size:12px;color:#374151;line-height:1.6;}
.details-body.open{display:block;}
.details-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:100px;font-size:10px;font-weight:600;margin-right:6px;margin-bottom:4px;text-transform:uppercase;letter-spacing:.06em;}
.chip-default{background:#F3F4F6;color:var(--gray-500);border:1px solid #E5E7EB;}
.chip-info{background:#EFF6FF;color:#1D4ED8;border:1px solid #BFDBFE;}
.chip-alert{background:#0F172A;color:#fff;}
.details-empty{color:#9CA3AF;font-style:italic;font-size:11px;}
.details-kv{display:flex;gap:10px;padding:4px 0;font-size:12px;}
.details-kv-label{color:#9CA3AF;font-weight:600;min-width:110px;font-size:10px;text-transform:uppercase;letter-spacing:.06em;padding-top:2px;}
.details-kv-val{color:#374151;flex:1;}

/* ── Program expand accordion ── */
.prog{position:relative;}
.prog.expanded{background:#F8FAFC;border-color:#D1D5DB;}
.prog-details{flex:0 0 100%;order:99;padding:10px 0 2px;margin-top:8px;border-top:1px solid #E5E7EB;font-size:12px;color:#374151;line-height:1.6;display:none;}
.prog-details.open{display:block;}
.prog-details-close{float:right;font-size:10px;color:#9CA3AF;background:none;border:none;cursor:pointer;padding:2px 6px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;}
.prog-details-close:hover{color:#111827;}
.prog-details-row{display:flex;gap:10px;padding:3px 0;font-size:11px;}
.prog-details-label{color:#9CA3AF;font-weight:600;min-width:100px;font-size:10px;text-transform:uppercase;letter-spacing:.06em;padding-top:2px;}
.prog-details-val{color:#374151;flex:1;}
.prog-details-val a{color:#3B82F6;text-decoration:none;font-weight:600;}
.prog-details-val a:hover{text-decoration:underline;}
.prog-expand-link{display:inline-block;padding:2px 6px;border-radius:4px;transition:background .15s;}
.prog-expand-link:hover{background:#EFF6FF;}

/* ── Vial selector ── */
.vial-section{padding:12px 20px;background:#F8FAFC;border-top:1px solid #E5E7EB;display:none;}
.vial-section.show{display:block;}
.vial-toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:11px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;}
.vial-toggle .chev{transition:transform .2s;font-size:10px;}
.vial-toggle.open .chev{transform:rotate(90deg);}
.vial-body{margin-top:8px;display:none;}
.vial-body.open{display:block;}
.vial-opt{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid #E5E7EB;border-radius:6px;margin-bottom:4px;background:#fff;font-size:12px;cursor:pointer;}
.vial-opt input{accent-color:#3B82F6;}
.vial-opt .vial-strength{font-family:'Inconsolata',monospace;font-weight:600;color:#111827;}
.vial-opt .vial-desc{color:var(--gray-500);font-size:11px;flex:1;}
.vial-wastage{margin-top:6px;padding:6px 10px;background:#FEF3C7;border-radius:6px;font-size:11px;color:#92400E;}

/* ── ICD validation message ── */
.icd-val-msg{margin-top:6px;padding:6px 10px;border-radius:6px;font-size:11px;line-height:1.5;}
.icd-val-msg.icd-err{background:#FEE2E2;border:1px solid #FECACA;color:#991B1B;}
.icd-val-msg.icd-warn{background:#FEF3C7;border:1px solid #FDE68A;color:#92400E;}
.icd-val-msg.icd-ok{background:#DCFCE7;border:1px solid #BBF7D0;color:#166534;}

/* ── NOC / NDC inline ── */
.noc-inline{padding:12px 20px;border-top:1px solid #E5E7EB;background:#FFFBEB;display:none;}
.noc-inline.show{display:block;}
.noc-inline label{font-size:10px;font-weight:600;color:#92400E;text-transform:uppercase;letter-spacing:.06em;}
.noc-inline input{width:100%;height:32px;padding:0 10px;border:1px solid #FDE68A;border-radius:6px;font-family:'Inconsolata',monospace;font-size:13px;margin-top:4px;outline:none;}
.noc-inline input:focus{border-color:#D97706;}
.noc-inline .noc-msg{font-size:11px;color:#92400E;margin-top:4px;}

/* ── Locked section state (gated until previous step complete) ── */
.step-locked{position:relative;pointer-events:none;opacity:.5;transition:opacity .2s;}
.step-locked::after{content:attr(data-locked-msg);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#0F172A;color:#fff;padding:6px 14px;border-radius:100px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;pointer-events:none;z-index:5;}
.step-locked *{pointer-events:none !important;}
/* ICD-10 diagnosis picker must stay interactive even while programs section
   is locked — users enter the diagnosis BEFORE dose to drive matching. */
.step-locked #v3-icd-row,
.step-locked #v3-icd-row *{pointer-events:auto !important;opacity:1 !important;}

/* ── Autocomplete dropdown (drug search + ICD-10) ── */
.ac-wrap{position:relative;}
/* Cost Breakdown context callouts — compact single-line chips */
.ce-context{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin:0 0 10px;}
.ce-context .ce-chip{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#F8FAFC;border:1px solid #E2E8F0;border-radius:6px;min-width:0;}
.ce-context .ce-chip svg{width:13px;height:13px;flex-shrink:0;color:#64748B;}
.ce-context .ce-chip-label{font-size:9px;font-weight:700;color:#64748B;text-transform:uppercase;letter-spacing:.06em;flex-shrink:0;}
.ce-context .ce-chip-value{font-family:'Roboto',sans-serif;font-size:12px;font-weight:600;color:#0F172A;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1;}
.ce-context .ce-chip.chip-empty .ce-chip-value{color:#94A3B8;font-weight:500;}
@media (max-width: 640px){
  .ce-context{grid-template-columns:1fr;}
}
.ac-list{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:100;background:#fff;border:1px solid #E2E8F0;border-radius:10px;box-shadow:0 12px 32px rgba(15,23,42,.12);max-height:320px;overflow-y:auto;display:none;}
.ac-list.open{display:block;}
.ac-item{padding:12px 16px;font-size:14px;color:#111827;cursor:pointer;border-bottom:1px solid #F3F4F6;display:flex;align-items:center;gap:12px;transition:background .1s;}
.ac-item:last-child{border-bottom:none;}
.ac-item:first-child{border-radius:10px 10px 0 0;}
.ac-item:last-child{border-radius:0 0 10px 10px;}
.ac-item:only-child{border-radius:10px;}
.ac-item:hover,.ac-item.highlighted{background:#EFF6FF;}
.ac-item .ac-code{font-family:'Inconsolata',monospace;font-size:13px;font-weight:700;color:#1D4ED8;min-width:60px;flex-shrink:0;}
.ac-item .ac-name{flex:1;color:#374151;line-height:1.3;}
.ac-item .ac-generic{font-size:12px;color:#94A3B8;display:block;margin-top:1px;}

/* ── Hero hint ── */
.hero-hint{font-size:12px;color:#94A3B8;text-align:center;padding:10px 0 0;transition:opacity .2s;}

/* ── Inline validation ── */
.val-msg{font-size:11px;margin-top:3px;font-weight:500;line-height:1.3;display:none;}
.val-msg.show{display:block;}
.val-msg.error{color:#DC2626;}
.val-msg.warn{color:#D97706;}

/* ── Hidden ── */
.v3-hidden{display:none !important;}
.hidden{display:none !important;}

/* ── Responsive ── */
@media(max-width:640px){
  /* Header */
  .hdr{padding:0 12px;height:48px;}
  .hdr-brand span{font-size:14px;}
  .hdr-actions{gap:6px;}
  .hdr-reset{font-size:11px;padding:4px 8px;}
  .user-avatar{width:30px;height:30px;font-size:13px;}
  /* Hero */
  .hero-card{padding:16px;}
  .hero-header{gap:10px;margin-bottom:12px;}
  .hero-title{font-size:18px;}
  .hero-sub{font-size:12px;}
  .hero-meta{width:100%;}
  .hero-pill{width:100%;}
  .hero-pill select{flex:1;}
  .hero-search{height:44px;}
  .hero-search input{height:44px;font-size:14px;padding:0 12px 0 40px;}
  .hero-search svg{left:12px;top:13px;}
  /* Cards */
  .card{padding:14px 12px;}
  .drug-bar{flex-direction:column;align-items:flex-start;gap:6px;}
  .drug-bar-right{text-align:left;}
  .info-grid{grid-template-columns:1fr;}
  .dose-row{flex-direction:column;}
  .ins-pills{flex-direction:column;}
  .ben-grid{grid-template-columns:1fr;}
  .est-boxes{grid-template-columns:1fr;}
  /* Autocomplete dropdown */
  .ac-list{max-height:240px;}
  .ac-item{padding:10px 12px;font-size:13px;}
  .ac-item .ac-code{min-width:50px;font-size:12px;}
  /* Cost breakdown */
  .ce-context{grid-template-columns:1fr;}
  /* Assist table */
  .assist-table col.c-disease{display:none;}
  .assist-table col.c-covers {display:none;}
  .assist-table th:nth-child(2),.assist-table td:nth-child(2),
  .assist-table th:nth-child(5),.assist-table td:nth-child(5){display:none;}
  .assist-table col.c-program{width:40%;}
  .assist-table col.c-upto  {width:22%;}
  .assist-table col.c-type  {width:16%;}
  .assist-table col.c-status{width:12%;}
  .assist-table col.c-next  {width:10%;}
  /* Estimate boxes */
  .est-box{padding:16px;}
  /* Add line modal */
  #addLineModal .alm-card{margin:12px;max-width:100%;}
  #addLineModal .alm-row{grid-template-columns:1fr;}
  /* Sub overlay */
  #subOverlay .sub-card{padding:32px 24px;}
  /* User menu */
  .user-menu-panel{min-width:220px;right:-8px;}
  /* Footer */
  .v3-footer-inner{flex-direction:column;text-align:center;}
}

/* ── Copay Assistance Programs table ── */
/* The #assistProgramsTable wrapper holds a <table.assist-table>. Cells are
   compact by design — long strings (e.g. verbose program names, prose max
   benefit values) get single-line truncation with the full value preserved
   via a browser tooltip on the cell (title attr set in renderAssistRow). */
#assistProgramsTable{overflow-x:auto;}
.assist-table{width:100%;border-collapse:separate;border-spacing:0;font-size:12px;table-layout:fixed;}
.assist-table thead th{font-size:10px;font-weight:600;color:#6B7280;text-transform:uppercase;letter-spacing:.06em;padding:8px 10px;border-bottom:1px solid #E5E7EB;text-align:left;white-space:nowrap;}
.assist-table tbody td{padding:10px;border-bottom:1px solid #F3F4F6;vertical-align:top;overflow:hidden;}
.assist-table tbody tr{cursor:pointer;transition:background .12s;}
.assist-table tbody tr:hover{background:#F8FAFC;}
.assist-table tbody tr.assist-best{background:#EFF6FF;box-shadow:inset 3px 0 0 #3B82F6;}
.assist-table tbody tr.assist-best:hover{background:#DBEAFE;}
/* Column widths (applied via <colgroup>) so the table scales but no single
   column dominates. Program name gets the most room, badges are narrow. */
.assist-table col.c-program{width:30%;}
.assist-table col.c-disease{width:14%;}
.assist-table col.c-upto  {width:16%;}
.assist-table col.c-type  {width:10%;}
.assist-table col.c-covers{width:12%;}
.assist-table col.c-status{width:9%;}
.assist-table col.c-next  {width:9%;}
/* Cell content rules — two-line clamp for prose, no-wrap for badges/prices */
.assist-table td.a-name{font-weight:500;color:#0F172A;line-height:1.35;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}
.assist-table td.a-disease{font-size:11px;color:#64748B;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}
.assist-table td.a-upto{white-space:nowrap;font-weight:600;color:#0F172A;text-overflow:ellipsis;}
.assist-table td.a-upto .upto-sub{display:block;font-size:10px;font-weight:400;color:#64748B;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.assist-table td.a-nowrap{white-space:nowrap;}
.assist-table td.a-next{white-space:nowrap;text-align:right;}

/* Badges inside the assist table */
.assist-badge{display:inline-block;padding:2px 8px;border-radius:100px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;line-height:1.5;white-space:nowrap;margin-right:4px;}
.assist-badge--grant      {background:#EDE9FE;color:#5B21B6;}
.assist-badge--copay      {background:#DBEAFE;color:#1E40AF;}
.assist-badge--free       {background:#D1FAE5;color:#065F46;}
.assist-badge--drug       {background:#E0F2FE;color:#0369A1;}
.assist-badge--admin      {background:#FEF3C7;color:#92400E;}
.assist-badge--open       {background:#DCFCE7;color:#166534;}
.assist-badge--closed     {background:#FEE2E2;color:#991B1B;}
.assist-badge--waitlist   {background:#FEF3C7;color:#92400E;}
.assist-badge--re_enrollment{background:#FEF3C7;color:#92400E;}
.assist-badge--unknown    {background:#F3F4F6;color:#6B7280;}
.assist-badge--best       {background:#3B82F6;color:#FFFFFF;margin-left:6px;}

/* ── Add Line Item modal ── */
#addLineModal{position:fixed;inset:0;z-index:1500;background:rgba(15,23,42,.5);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:24px;}
#addLineModal .alm-card{max-width:420px;width:100%;background:#fff;border-radius:14px;box-shadow:0 20px 48px rgba(0,0,0,.16);overflow:hidden;}
#addLineModal .alm-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid #F1F5F9;background:linear-gradient(180deg,#F8FAFC 0%,#fff 100%);}
#addLineModal .alm-header h3{font-family:'Poppins',sans-serif;font-size:15px;font-weight:700;color:#0F172A;margin:0;}
#addLineModal .alm-close{background:none;border:none;font-size:22px;color:#94A3B8;cursor:pointer;padding:0 4px;line-height:1;}
#addLineModal .alm-close:hover{color:#0F172A;}
#addLineModal .alm-body{padding:20px 24px;}
#addLineModal .alm-field{margin-bottom:14px;}
#addLineModal .alm-field label{display:block;font-size:10px;font-weight:600;color:#64748B;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;}
#addLineModal .alm-field input,#addLineModal .alm-field select{width:100%;height:38px;padding:0 12px;border:1px solid #E2E8F0;border-radius:8px;font-size:14px;color:#0F172A;background:#fff;outline:none;font-family:'Roboto',sans-serif;}
#addLineModal .alm-field input:focus,#addLineModal .alm-field select:focus{border-color:#3B82F6;}
#addLineModal .alm-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
#addLineModal .alm-preview{padding:12px;background:#F8FAFC;border:1px solid #E2E8F0;border-radius:8px;font-size:12px;color:#64748B;margin-bottom:14px;min-height:36px;}
#addLineModal .alm-preview .alm-desc{color:#0F172A;font-weight:600;}
#addLineModal .alm-preview .alm-rate{font-family:'Inconsolata',monospace;color:#3B82F6;font-weight:700;}
#addLineModal .alm-footer{display:flex;gap:8px;justify-content:flex-end;padding:16px 24px;border-top:1px solid #F1F5F9;}
#addLineModal .alm-footer button{height:36px;padding:0 20px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:'Roboto',sans-serif;}
#addLineModal .alm-cancel{background:#fff;border:1px solid #E2E8F0;color:#64748B;}
#addLineModal .alm-cancel:hover{background:#F8FAFC;}
#addLineModal .alm-add{background:#3B82F6;border:none;color:#fff;}
#addLineModal .alm-add:hover{background:#2563EB;}
#addLineModal .alm-dose-section{padding:14px;margin-bottom:14px;background:#F8FAFC;border:1px solid #E2E8F0;border-radius:10px;}
#addLineModal .alm-mode-toggle{display:flex;gap:14px;margin-bottom:12px;}
#addLineModal .alm-mode-option{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:#0F172A;cursor:pointer;}
#addLineModal .alm-mode-option input[type="radio"]{margin:0;accent-color:#3B82F6;}
#addLineModal .alm-drug-hint{padding:8px 10px;background:#EFF6FF;border:1px solid #BFDBFE;border-radius:6px;color:#1E40AF;font-size:11px;margin-bottom:10px;}
#addLineModal .alm-drug-hint.alm-drug-hint-warn{background:#FEF3C7;border-color:#FDE68A;color:#92400E;}
#addLineModal .alm-calc-summary{padding:10px 12px;background:#fff;border:1px solid #E2E8F0;border-radius:6px;font-size:12px;color:#0F172A;margin-top:4px;}
#addLineModal .alm-calc-summary .alm-calc-units{font-family:'Inconsolata',monospace;color:#3B82F6;font-weight:700;font-size:14px;}
