/* =====================================================================
   tebChart — consumer site. Warm editorial "patient handout" aesthetic:
   cream paper, deep navy ink, Persian-gold accents, serif voice.
   Deliberately NOT the dark corporate tebscribe.com. Zero JS required,
   zero trackers, zero cookies — the site practices what the app preaches.
   ===================================================================== */
:root{
  --navy:#071125;
  --navy-2:#0B1B36;
  --navy-3:#122747;
  --ink:#1F2937;
  --ink-soft:#4B5563;
  --cream:#FAF6EC;
  --cream-2:#F3ECDC;
  --paper:#FFFDF7;
  --gold:#C9A136;
  --gold-deep:#A5831F;
  --teal:#0A6470;
  --teal-soft:#EAF4F4;
  --hair:rgba(31,41,55,.14);
  --hair-gold:rgba(201,161,54,.4);
  --display:"Fraunces",Georgia,"Times New Roman",serif;
  --body:"Source Serif 4",Georgia,serif;
  --sans:-apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",sans-serif;
  --maxw:1080px;
  --radius:18px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  /* 50+ readability: generous base size, calm line length */
  font-size:19px;line-height:1.65;
  background:var(--cream);color:var(--ink);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* soft paper grain */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0.55 0 0 0 0 0.5 0 0 0 0 0.4 0 0 0 0.035 0'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)'/%3E%3C/svg%3E");
}
main,header,footer{position:relative;z-index:1}
a{color:var(--teal);text-decoration:none}
a:hover{text-decoration:underline;text-underline-offset:3px}
img,svg{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- header ---------- */
.site-header{
  border-bottom:1px solid var(--hair);
  background:color-mix(in srgb,var(--cream) 88%,transparent);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  position:sticky;top:0;z-index:50;
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;min-height:64px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:600;font-size:1.25rem;color:var(--navy)}
.brand:hover{text-decoration:none}
.brand svg{width:30px;height:30px}
.nav{display:flex;gap:22px;align-items:center;font-family:var(--sans);font-size:.85rem;font-weight:600;letter-spacing:.01em}
.nav a{color:var(--ink-soft)}
.nav a[aria-current="page"]{color:var(--navy);border-bottom:2px solid var(--gold);padding-bottom:2px}
.nav a:hover{color:var(--navy);text-decoration:none}
.nav .cta{
  background:var(--navy);color:#fff;border-radius:999px;
  padding:9px 18px;border-bottom:none;
}
.nav .cta:hover{background:var(--navy-3);color:#fff}
@media(max-width:640px){.nav{gap:14px}.nav .hide-sm{display:none}}

/* ---------- type ---------- */
h1,h2,h3{font-family:var(--display);color:var(--navy);line-height:1.14;font-weight:600;letter-spacing:-.01em}
h1{font-size:clamp(2.3rem,5.6vw,3.6rem)}
h2{font-size:clamp(1.7rem,3.4vw,2.3rem)}
h3{font-size:1.15rem;line-height:1.35}
.lede{font-size:clamp(1.08rem,2vw,1.3rem);color:var(--ink-soft);max-width:34em}
.eyebrow{
  font-family:var(--sans);font-size:.76rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);
  display:flex;align-items:center;gap:10px;margin-bottom:14px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--gold)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-weight:700;font-size:1rem;
  border-radius:999px;padding:15px 28px;transition:transform .18s ease,box-shadow .18s ease;
}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--navy);color:#fff;box-shadow:0 10px 26px rgba(7,17,37,.22)}
.btn-primary:hover{box-shadow:0 14px 32px rgba(7,17,37,.3);color:#fff}
.btn-quiet{border:1.5px solid var(--hair);color:var(--navy);background:var(--paper)}
.btn small{display:block;font-weight:500;font-size:.68rem;opacity:.75;letter-spacing:.02em}

/* ---------- hero ---------- */
.hero{padding:84px 0 60px;position:relative;overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.08fr .92fr;gap:56px;align-items:center}
@media(max-width:860px){.hero .wrap{grid-template-columns:1fr;gap:48px}.hero{padding:56px 0 40px}}
.hero h1 em{font-style:italic;color:var(--teal)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px;align-items:center}
.hero-note{font-family:var(--sans);font-size:.8rem;color:var(--ink-soft);margin-top:16px;display:flex;gap:8px;align-items:center}
.hero-note svg{width:15px;height:15px;flex:none}

/* discharge-paper motif behind phone */
.stage{position:relative;display:flex;justify-content:center;padding:16px 0}
.sheet{
  position:absolute;background:var(--paper);border:1px solid var(--hair);
  border-radius:8px;box-shadow:0 18px 40px rgba(7,17,37,.10);
}
.sheet-1{width:230px;height:300px;transform:rotate(-9deg) translate(-120px,10px)}
.sheet-2{width:230px;height:300px;transform:rotate(6deg) translate(120px,26px)}
.sheet::before{
  content:"";position:absolute;inset:26px 22px auto 22px;height:10px;border-radius:3px;
  background:var(--cream-2);box-shadow:0 22px 0 var(--cream-2),0 44px 0 var(--cream-2),0 66px 0 var(--cream-2),0 88px 0 var(--cream-2),0 110px 0 var(--cream-2);
}
.sheet::after{
  content:"";position:absolute;top:18px;left:22px;width:52px;height:5px;border-radius:3px;background:var(--gold);opacity:.55;
}

/* CSS phone mock of the discharge-role home */
.phone{
  position:relative;width:300px;border-radius:44px;background:var(--navy);
  padding:12px;box-shadow:0 30px 70px rgba(7,17,37,.32),0 4px 14px rgba(7,17,37,.18);
}
.phone-screen{background:#F5F7F9;border-radius:34px;overflow:hidden;padding:20px 14px 14px;position:relative}
.phone-title{font-family:var(--display);font-weight:700;font-size:1.06rem;text-align:center;color:#0B1B36;margin-bottom:12px}
.app-card{
  background:#fff;border-radius:16px;padding:13px 14px;margin-bottom:10px;
  display:flex;gap:11px;align-items:flex-start;box-shadow:0 2px 8px rgba(7,17,37,.06);
}
.app-card .ic{
  flex:none;width:34px;height:34px;border-radius:10px;display:grid;place-items:center;
}
.app-card .ic svg{width:18px;height:18px}
.app-card b{font-family:var(--sans);font-size:.86rem;color:#111827;display:block;font-weight:700}
.app-card span{font-family:var(--sans);font-size:.72rem;color:#6B7280;line-height:1.35;display:block;margin-top:2px}
.ic-teal{background:#E3F1F2;color:var(--teal)}
.ic-gold{background:#F6EED8;color:var(--gold-deep)}
.ic-navy{background:#E6EAF2;color:var(--navy-2)}
.phone-cta{
  background:var(--teal);color:#fff;text-align:center;border-radius:14px;
  font-family:var(--sans);font-size:.8rem;font-weight:700;padding:11px;margin-top:2px;
}
.scanline{
  position:absolute;left:8%;right:8%;height:3px;border-radius:3px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  top:22%;opacity:0;animation:scan 4.5s ease-in-out infinite;
}
@keyframes scan{
  0%,55%,100%{opacity:0;top:22%}
  60%{opacity:.95}
  90%{opacity:.9;top:78%}
  95%{opacity:0}
}
@media(prefers-reduced-motion:reduce){
  .scanline{animation:none;opacity:0}
  .btn{transition:none}
  .reveal{opacity:1 !important;transform:none !important;transition:none !important}
}

/* ---------- sections ---------- */
section{padding:64px 0}
.band-navy{
  background:linear-gradient(180deg,var(--navy) 0%,var(--navy-2) 100%);
  color:#EDF0F6;
}
.band-navy h1,.band-navy h2,.band-navy h3{color:#fff}
.band-navy .lede{color:rgba(237,240,246,.78)}
.band-aqua{background:var(--teal-soft)}
.band-paper{background:var(--paper);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}

/* ER doctor letter */
.letter{
  background:var(--paper);border:1px solid var(--hair);border-radius:var(--radius);
  padding:clamp(28px,5vw,52px);position:relative;max-width:760px;margin:0 auto;
  box-shadow:0 16px 44px rgba(7,17,37,.07);
}
.letter::before{
  content:"";position:absolute;top:0;left:48px;width:64px;height:5px;
  background:var(--gold);border-radius:0 0 4px 4px;
}
.letter p{margin-bottom:1.1em}
.letter .sig{font-family:var(--display);font-style:italic;font-size:1.2rem;color:var(--navy);margin-top:1.4em;margin-bottom:0}
.letter .sig small{display:block;font-family:var(--sans);font-style:normal;font-size:.78rem;color:var(--ink-soft);margin-top:5px;letter-spacing:.02em}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:44px}
@media(max-width:820px){.steps{grid-template-columns:1fr}}
.step{
  background:var(--paper);border:1px solid var(--hair);border-radius:var(--radius);
  padding:28px 26px;position:relative;
}
.step .num{
  font-family:var(--display);font-size:2.6rem;font-weight:600;color:var(--gold);
  line-height:1;margin-bottom:14px;font-style:italic;
}
.step h3{margin-bottom:8px}
.step p{font-size:.95rem;color:var(--ink-soft)}

/* privacy promise rows */
.promises{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:40px}
@media(max-width:760px){.promises{grid-template-columns:1fr}}
.promise{
  display:flex;gap:14px;align-items:flex-start;
  background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.1);
  border-radius:14px;padding:18px 20px;
}
.promise svg{flex:none;width:22px;height:22px;color:var(--gold);margin-top:3px}
.promise b{font-family:var(--sans);font-size:.95rem;display:block;color:#fff;margin-bottom:3px}
.promise span{font-family:var(--sans);font-size:.85rem;color:rgba(237,240,246,.72);line-height:1.5}

/* feature grid */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:44px}
@media(max-width:820px){.features{grid-template-columns:1fr}}
.feature{padding:4px 0}
.feature .fic{
  width:44px;height:44px;border-radius:13px;background:var(--teal-soft);color:var(--teal);
  display:grid;place-items:center;margin-bottom:14px;border:1px solid rgba(10,100,112,.14);
}
.feature .fic svg{width:22px;height:22px}
.feature h3{margin-bottom:6px}
.feature p{font-size:.95rem;color:var(--ink-soft)}

/* pricing */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px;align-items:stretch}
@media(max-width:820px){.plans{grid-template-columns:1fr}}
.plan{
  background:var(--paper);border:1.5px solid var(--hair);border-radius:var(--radius);
  padding:30px 26px;display:flex;flex-direction:column;gap:6px;
}
.plan.hot{border-color:var(--gold);box-shadow:0 18px 44px rgba(201,161,54,.16);position:relative}
.plan .tag{
  position:absolute;top:-13px;left:24px;background:var(--gold);color:var(--navy);
  font-family:var(--sans);font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  padding:5px 12px;border-radius:999px;
}
.plan h3{font-size:1.05rem}
.plan .price{font-family:var(--display);font-size:2rem;font-weight:600;color:var(--navy)}
.plan .price small{font-family:var(--sans);font-size:.78rem;color:var(--ink-soft);font-weight:500}
.plan ul{list-style:none;margin-top:10px;font-family:var(--sans);font-size:.86rem;color:var(--ink-soft)}
.plan li{padding:6px 0 6px 24px;position:relative}
.plan li::before{content:"✓";position:absolute;left:0;color:var(--teal);font-weight:700}
.plan .note{font-family:var(--sans);font-size:.75rem;color:var(--ink-soft);margin-top:auto;padding-top:14px}

/* FAQ */
.faq{max-width:760px;margin:36px auto 0}
.faq details{
  border-bottom:1px solid var(--hair);padding:6px 0;
}
.faq summary{
  cursor:pointer;font-family:var(--sans);font-weight:700;font-size:1rem;color:var(--navy);
  padding:16px 30px 16px 0;list-style:none;position:relative;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";position:absolute;right:4px;top:50%;transform:translateY(-50%);
  font-family:var(--display);font-size:1.5rem;color:var(--gold);transition:transform .2s;
}
.faq details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq details p{padding:0 0 18px;color:var(--ink-soft);font-size:.98rem;max-width:60ch}

/* legal / prose pages */
.prose{max-width:760px;margin:0 auto}
.prose h1{margin-bottom:10px}
.prose .updated{font-family:var(--sans);font-size:.8rem;color:var(--ink-soft);margin-bottom:36px}
.prose h2{font-size:1.35rem;margin:44px 0 12px}
.prose h3{margin:28px 0 8px}
.prose p,.prose li{color:var(--ink);font-size:1rem;margin-bottom:12px}
.prose ul{padding-left:22px;margin-bottom:14px}
.prose .callout{
  background:var(--teal-soft);border:1px solid rgba(10,100,112,.16);border-radius:14px;
  padding:20px 24px;font-size:.98rem;margin:26px 0;
}

/* footer */
.site-footer{
  background:var(--navy);color:rgba(237,240,246,.72);
  padding:52px 0 40px;margin-top:0;font-family:var(--sans);font-size:.85rem;
}
.site-footer .wrap{display:flex;flex-wrap:wrap;gap:28px;justify-content:space-between;align-items:flex-start}
.site-footer a{color:rgba(237,240,246,.85)}
.site-footer .fbrand{font-family:var(--display);font-size:1.15rem;color:#fff;display:flex;gap:9px;align-items:center;margin-bottom:8px}
.site-footer .fbrand svg{width:24px;height:24px}
.site-footer nav{display:flex;gap:20px;flex-wrap:wrap}
.site-footer .fine{width:100%;border-top:1px solid rgba(255,255,255,.12);margin-top:26px;padding-top:20px;font-size:.76rem;color:rgba(237,240,246,.5);line-height:1.6}

/* reveals */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- discharge checklist page ---------- */
.checklist-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:26px}
.checklist-note{font-family:var(--sans);font-size:.82rem;color:var(--ink-soft)}
.check-group{
  background:var(--paper);border:1px solid var(--hair);border-radius:var(--radius);
  padding:24px 28px;margin-bottom:18px;break-inside:avoid;
}
.check-group h2{
  font-size:1.28rem;display:flex;align-items:center;gap:12px;margin-bottom:14px;
}
.check-num{
  flex:none;width:34px;height:34px;border-radius:10px;background:var(--teal);color:#fff;
  font-family:var(--display);font-size:1.05rem;display:inline-grid;place-items:center;
}
.checklist{list-style:none;padding:0}
.checklist li{border-top:1px solid var(--hair)}
.checklist li:first-child{border-top:none}
.checklist label{
  display:flex;gap:14px;align-items:flex-start;cursor:pointer;
  padding:11px 2px;font-size:1.02rem;color:var(--ink);line-height:1.5;
}
.checklist input[type="checkbox"]{
  flex:none;appearance:none;-webkit-appearance:none;margin:0;
  width:24px;height:24px;border:2px solid var(--teal);border-radius:7px;
  background:var(--paper);cursor:pointer;position:relative;transition:background .12s ease;
}
.checklist input[type="checkbox"]:checked{background:var(--teal)}
.checklist input[type="checkbox"]:checked::after{
  content:"";position:absolute;left:7px;top:2.5px;width:6px;height:12px;
  border:solid #fff;border-width:0 3px 3px 0;transform:rotate(45deg);
}
.checklist label:has(input:checked){color:var(--ink-soft);text-decoration:line-through;text-decoration-color:var(--hair-gold)}
.checklist-disclaimer{
  font-family:var(--sans);font-size:.86rem;color:var(--ink-soft);
  background:var(--teal-soft);border:1px solid rgba(10,100,112,.16);border-radius:14px;
  padding:16px 20px;margin:8px 0 32px;line-height:1.55;break-inside:avoid;
}
.checklist-cta{
  display:flex;gap:24px;align-items:center;justify-content:space-between;flex-wrap:wrap;
  background:var(--navy);color:#EDF0F6;border-radius:var(--radius);padding:28px 30px;margin-bottom:48px;
}
.checklist-cta h3{color:#fff;margin-bottom:6px}
.checklist-cta p{font-size:.95rem;color:rgba(237,240,246,.8);max-width:46ch}
.print-footer{display:none}

@media print{
  :root{--maxw:100%}
  body{background:#fff;font-size:12pt}
  body::before{display:none}
  .no-print{display:none !important}
  .site-header,.site-footer{display:none}
  section{padding:0 !important}
  .wrap{max-width:100% !important;padding:0}
  h1{font-size:22pt;margin-bottom:6pt}
  .lede{font-size:11pt;color:#333;max-width:100%}
  .eyebrow{color:#7a5f14}
  .check-group{border:1px solid #bbb;box-shadow:none;padding:12px 16px;margin-bottom:10px;page-break-inside:avoid}
  .check-group h2{font-size:13pt}
  .check-num{background:#0A6470 !important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .checklist label{padding:6px 0;font-size:11pt}
  .checklist input[type="checkbox"]{width:16px;height:16px;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .print-footer{display:block;text-align:center;font-family:var(--sans);font-size:8pt;color:#666;margin-top:10pt;padding-top:6pt;border-top:1px solid #ccc}
}
