/* Untreatable.com — site-specific styles (generator + landing hero) */

/* landing hero */
.hero { text-align: center; margin-bottom: 56px; }
.hero h1 { margin-bottom: 20px; }
.hero .lede { margin: 0 auto 28px; }
.hero .cta-row { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* example mini-cards on landing */
.examples {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 14px; margin: 32px 0;
}
.ex-card {
  background: var(--paper); color: var(--paper-ink);
  padding: 18px; border-radius: 2px;
  transform: rotate(var(--r, 0deg));
  box-shadow: 0 10px 30px rgba(0,0,0,.4);
  font-family: var(--font-serif);
}
.ex-card .ex-label {
  font-family: var(--font-mono); font-size: 9px; letter-spacing: 2px;
  opacity: .6; text-transform: uppercase; margin-bottom: 6px;
}
.ex-card .ex-name { font-style: italic; font-weight: 900; font-size: 18px; line-height: 1.2; }
.ex-card .ex-latin { font-family: var(--font-mono); font-size: 11px; opacity: .55; margin-top: 4px; font-style: italic; }

/* feature row (landing) */
.features {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
  margin: 40px 0;
}
@media (max-width: 640px) { .features { grid-template-columns: 1fr; } }
.features .feat {
  background: var(--bg-2); border: 1px solid var(--border);
  padding: 22px; border-radius: 2px;
}
.features .feat .k {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 3px;
  color: var(--accent); text-transform: uppercase; margin-bottom: 8px;
}

/* ---- generator form ---- */
.form-card {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 2px;
  padding: 32px;
  margin-bottom: 32px;
  position: relative;
}
.form-card::before {
  content: 'CASE FILE'; position: absolute;
  top: -10px; left: 24px;
  background: var(--bg); padding: 2px 12px;
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 3px;
  color: var(--ink-dim);
}
label {
  display: block; font-family: var(--font-mono);
  font-size: 13px; letter-spacing: 2px;
  color: var(--ink); text-transform: uppercase;
  margin-bottom: 10px; margin-top: 20px;
  font-weight: bold;
}
label:first-of-type { margin-top: 0; }
input, textarea {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--border);
  color: var(--ink);
  font-family: inherit; font-size: 18px;
  padding: 10px 0; outline: none;
  transition: border-color .2s;
  line-height: 1.4;
}
input::placeholder, textarea::placeholder { color: var(--ink-dim); opacity: .65; }
input:focus, textarea:focus { border-color: var(--accent); }

/* Kill Chrome/Safari autofill's default pale-yellow/white background + black text
   which blows up the dark theme. The inset shadow trick keeps the form-card
   background showing through, and we force the text color back to --ink.
   The 5000s transition is a hack that delays the browser's default re-apply. */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover,
textarea:-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0 1000px var(--bg-2) inset !important;
  -webkit-text-fill-color: var(--ink) !important;
  caret-color: var(--ink) !important;
  transition: background-color 5000s ease-in-out 0s !important;
}
textarea {
  resize: vertical;
  min-height: 110px;
  line-height: 1.5;
  padding: 12px 0;
  box-sizing: border-box;
}
@media (max-width: 560px) {
  textarea { min-height: 160px; font-size: 17px; }
  /* mobile: shorter placeholder since the long example clips */
  #symptoms { min-height: 140px; }
}

.btn.full { width: 100%; margin-top: 28px; padding: 18px; }

/* Secondary CTA — ghost-style random button */
.btn-alt {
  display: block;
  width: 100%;
  margin-top: 12px;
  padding: 14px;
  background: transparent;
  color: var(--ink);
  border: 1px dashed var(--border);
  font-family: var(--font-mono);
  font-size: 13px; letter-spacing: 2px;
  text-transform: uppercase; font-weight: bold;
  cursor: pointer;
  transition: border-color .15s, color .15s;
}
.btn-alt:hover { border-color: var(--accent); color: var(--accent); }

/* Condition of the day */
.cod-card {
  background: var(--paper);
  color: var(--paper-ink);
  padding: 28px 32px;
  border-radius: 2px;
  box-shadow: 0 14px 40px rgba(0,0,0,.4);
  position: relative;
  margin-top: 18px;
}
.cod-card::before {
  content:''; position: absolute; inset: 8px;
  border: 1px solid rgba(0,0,0,.12);
  pointer-events: none;
}
/* ====== Assessment loader (first-visit only; ~1.8s) ====== */
.assess-loader {
  display: none;
  max-width: 720px;
  margin: 32px auto 0;
  padding: 0 24px;
}
.assess-loader.active { display: block; animation: assessFade .25s ease; }
@keyframes assessFade { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }
.assess-loader-card {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 2px;
  padding: 36px 32px 30px;
  position: relative;
}
.assess-loader-head {
  position: absolute;
  top: -10px; left: 24px;
  background: var(--bg);
  padding: 2px 14px;
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 3px;
  color: var(--accent);
  text-transform: uppercase;
}
.assess-loader-text {
  font-family: var(--font-mono);
  font-size: 13px; letter-spacing: 1.5px;
  color: var(--ink);
  text-transform: uppercase;
  margin-bottom: 20px;
  min-height: 18px;
  transition: opacity .15s;
}
.assess-loader-bar {
  height: 4px;
  background: rgba(255,255,255,.06);
  border-radius: 2px;
  overflow: hidden;
}
.assess-loader-fill {
  height: 100%;
  width: 0%;
  background: var(--accent);
  box-shadow: 0 0 12px rgba(196,30,58,.35);
}
@media (max-width: 520px) {
  .assess-loader { padding: 0 16px; }
  .assess-loader-card { padding: 30px 22px 24px; }
  .assess-loader-text { font-size: 12px; letter-spacing: 1px; }
}

/* Deep-red brand pinned top-right of the on-page COD card so any screenshot
   users take carries the URL. Sits inline with the stamp (opposite corner)
   so cropping has to lose one or the other.
   .pod-brand shares the same rule — identical purpose on the prescription card. */
.cod-brand, .pod-brand {
  position: absolute;
  top: 26px; right: 32px;
  font-family: var(--font-mono);
  font-weight: 900;
  font-size: 15px;
  letter-spacing: 2.5px;
  color: #8b0000;
  z-index: 2;
  pointer-events: none;
}
@media (max-width: 520px) {
  .cod-brand, .pod-brand { top: 20px; right: 20px; font-size: 12px; letter-spacing: 2px; }
}

/* ====== Prescription of the Day (POD) ====== */
/* Cream paper card, cloned from .cod-card pattern. Lives on /prescribe. */
.pod-card {
  background: var(--paper);
  color: var(--paper-ink);
  padding: 28px 32px;
  border-radius: 2px;
  box-shadow: 0 14px 40px rgba(0,0,0,.4);
  position: relative;
  margin-top: 18px;
}
.pod-card::before {
  content:''; position: absolute; inset: 8px;
  border: 1px solid rgba(0,0,0,.12);
  pointer-events: none;
}
.pod-stamp {
  display: inline-block;
  border: 3px solid var(--stamp, #8b0000);
  color: var(--stamp, #8b0000);
  padding: 5px 12px;
  font-family: var(--font-mono);
  font-weight: bold; font-size: 12px;
  letter-spacing: 3px;
  transform: rotate(-4deg);
  margin-bottom: 16px;
}
.pod-eyebrow {
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 3px;
  color: var(--paper-ink-dim);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.pod-name {
  display: block;
  font-family: var(--font-serif);
  font-size: 30px; font-weight: 900; font-style: italic;
  color: var(--paper-ink);
  line-height: 1.15;
  margin-bottom: 4px;
}
.pod-translation {
  font-family: var(--font-mono);
  font-size: 14px; font-style: italic;
  color: var(--paper-ink-dim);
  margin-bottom: 20px;
}
.pod-section {
  margin-bottom: 16px;
}
.pod-section:last-child {
  margin-bottom: 4px;
}
.pod-section-label {
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 2.5px;
  color: var(--paper-ink-dim);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.pod-section-text {
  font-size: 15px; line-height: 1.55;
  color: var(--paper-ink);
}
.cod-stamp {
  display: inline-block;
  border: 3px solid var(--stamp-color, var(--stamp));
  color: var(--stamp-color, var(--stamp));
  padding: 5px 12px;
  font-family: var(--font-mono);
  font-weight: bold; font-size: 12px;
  letter-spacing: 3px;
  transform: rotate(-4deg);
  margin-bottom: 16px;
}
.cod-name {
  display: block;
  font-family: var(--font-serif);
  font-size: 30px; font-weight: 900; font-style: italic;
  color: var(--paper-ink);
  text-decoration: none;
  line-height: 1.15;
  margin-bottom: 4px;
}
.cod-name:hover { color: var(--stamp); text-decoration: none; }
.cod-latin {
  font-family: var(--font-mono);
  font-size: 14px; font-style: italic;
  color: var(--paper-ink-dim);
  margin-bottom: 18px;
}
.cod-desc {
  font-size: 16px; line-height: 1.55;
  color: var(--paper-ink);
  margin-bottom: 20px;
}
.cod-cta {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 2px;
  font-weight: bold; text-transform: uppercase;
  color: var(--stamp); text-decoration: none;
  border-bottom: 2px solid var(--stamp);
  padding-bottom: 2px;
}
.cod-cta:hover { color: var(--accent); border-color: var(--accent); }

/* COD action button row */
.cod-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
  margin-top: 18px;
}
/* Primary "Diagnose me with this" spans the full row under the share/save/copy
   trio, so the commit action reads as the deliberate final step. */
.cod-actions .cod-btn.primary {
  grid-column: 1 / -1;
  padding: 20px 14px;
  font-size: 15px;
  letter-spacing: 2.5px;
  font-weight: 900;
}
.cod-btn {
  background: var(--bg-2);
  border: 1px solid var(--border);
  color: var(--ink);
  padding: 13px 10px;
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 1.5px;
  text-transform: uppercase;
  cursor: pointer;
  text-align: center;
  text-decoration: none;
  font-weight: bold;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  transition: border-color .15s, background .15s, color .15s;
}
.cod-btn:hover {
  border-color: var(--accent); color: var(--accent);
  text-decoration: none;
}
.cod-btn.primary {
  background: var(--accent); border-color: var(--accent); color: #fff;
}
.cod-btn.primary:hover { background: transparent; color: var(--accent); }
.cod-btn.fb { background: #1877f2; border-color: #1877f2; color: #fff; }
.cod-btn.fb:hover { background: #0e65d1; border-color: #0e65d1; color: #fff; }
.cod-btn.x  { background: #000; border-color: #444; color: #fff; }
.cod-btn.x:hover  { background: #111; border-color: #fff; color: #fff; }
.cod-btn svg { width: 14px; height: 14px; fill: currentColor; flex-shrink: 0; }

/* /conditions index page */
.idx-group { margin: 40px 0; }
.idx-stamp {
  display: inline-block;
  border: 3px solid var(--stamp-color, var(--accent));
  color: var(--stamp-color, var(--accent));
  padding: 6px 14px;
  font-family: var(--font-mono);
  font-weight: bold; font-size: 14px;
  letter-spacing: 3px;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.idx-count {
  color: var(--ink-dim); font-weight: normal;
  margin-left: 4px; letter-spacing: 1px;
}
.idx-list {
  list-style: none; padding: 0; margin: 0;
  display: grid; grid-template-columns: 1fr; gap: 0;
}
.idx-list li {
  border-bottom: 1px solid var(--border);
}
.idx-list a {
  display: block;
  padding: 12px 0;
  color: var(--ink);
  text-decoration: none;
  font-size: 15px;
  transition: padding-left .1s;
}
.idx-list a:hover { padding-left: 10px; color: var(--accent); background: rgba(226,58,86,0.04); text-decoration: none; }
.idx-list a strong { font-family: var(--font-serif); font-style: italic; font-size: 17px; display: block; }
.idx-list .idx-desc {
  display: block;
  font-size: 13px; color: var(--ink-dim);
  margin-top: 2px;
  font-family: var(--font-serif);
}

/* Breadcrumbs */
.breadcrumbs {
  margin: 0 0 24px;
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 1.5px;
  color: var(--ink-dim);
  text-transform: uppercase;
}
.breadcrumbs ol { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 4px; }
.breadcrumbs li { display: inline; }
.breadcrumbs li + li::before {
  content: ' › ';
  margin: 0 6px;
  opacity: .5;
}
.breadcrumbs a { color: var(--ink); text-decoration: none; }
.breadcrumbs a:hover { color: var(--accent); text-decoration: none; }
.breadcrumbs span[aria-current="page"] { color: var(--ink); }

/* Category hub (/conditions) */
.cat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 18px;
  margin: 30px 0;
}
.cat-card {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 2px;
  padding: 24px 22px;
  text-decoration: none;
  color: var(--ink);
  display: flex; flex-direction: column; gap: 10px;
  transition: border-color .15s, transform .1s;
  min-height: 150px;
}
.cat-card:hover {
  border-color: var(--accent);
  transform: translateY(-2px);
  text-decoration: none;
}
.cat-label {
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 900;
}
.cat-desc {
  color: var(--ink);
  font-size: 14px;
  line-height: 1.5;
  flex: 1;
}
.cat-count {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent);
  margin-top: 4px;
  font-weight: bold;
}
.idx-total {
  text-align: center;
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 2px;
  color: var(--ink-dim);
  text-transform: uppercase;
  margin-top: 30px;
}

/* Pagination */
.pagination {
  text-align: center;
  margin: 36px 0 8px;
  font-family: var(--font-mono);
  font-size: 13px; letter-spacing: 2px;
  text-transform: uppercase;
}
.pagination a {
  color: var(--ink);
  text-decoration: none;
  padding: 0 8px;
}
.pagination a:hover { color: var(--accent); }
.pagination .pag-current {
  color: var(--accent);
  font-weight: bold;
  padding: 0 8px;
}

/* Symptoms list on condition detail pages */
.symptoms-box h3 {
  font-family: var(--font-mono);
  font-size: 13px; letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 8px;
}
.symptoms-list {
  list-style: none;
  padding: 0;
  margin: 14px 0 0;
}
.symptoms-list li {
  padding: 10px 0 10px 26px;
  position: relative;
  border-bottom: 1px dashed var(--border);
  color: var(--ink);
  font-size: 16px;
  line-height: 1.55;
}
.symptoms-list li:last-child { border-bottom: 0; }
.symptoms-list li::before {
  content: '▸';
  position: absolute;
  left: 4px; top: 10px;
  color: var(--accent);
}

/* Related conditions on /diagnoses/<slug> pages */
.related-box h3 {
  font-family: var(--font-mono);
  font-size: 13px; letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 8px;
}
.related-list {
  list-style: none; padding: 0; margin: 14px 0 0;
}
.related-list li {
  border-bottom: 1px solid var(--border);
  padding: 0;
}
.related-list li:last-child { border-bottom: 0; }
.related-list a {
  display: block;
  padding: 14px 0;
  color: var(--ink);
  text-decoration: none;
  transition: padding-left .12s, background .12s;
}
.related-list a:hover {
  padding-left: 10px;
  background: rgba(226,58,86,0.05);
  color: var(--accent);
  text-decoration: none;
}
.related-list a strong {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 17px;
  font-weight: 900;
}
.related-teaser {
  color: var(--ink-dim);
  font-size: 14px;
  font-family: var(--font-serif);
}

/* result card */
#result { display: none; animation: fadeIn .5s ease; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: none; } }

.diagnosis {
  background: var(--paper);
  color: var(--paper-ink);
  padding: 48px 40px;
  margin-bottom: 24px;
  position: relative;
  font-family: var(--font-serif);
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
  border-radius: 2px;
}
.diagnosis::before {
  content: ''; position: absolute; inset: 8px;
  border: 1px solid rgba(0,0,0,.15);
  pointer-events: none;
}
.dx-header {
  display: flex; justify-content: space-between;
  align-items: start; margin-bottom: 32px;
  padding-bottom: 16px; border-bottom: 2px solid var(--paper-ink);
}
.dx-clinic {
  font-family: var(--font-mono);
  font-size: 13px; letter-spacing: 2px;
  text-transform: uppercase; color: var(--paper-ink-dim);
}
.dx-clinic strong { display: block; font-size: 15px; margin-bottom: 4px; color: var(--paper-ink); }
.dx-stamp {
  transform: rotate(-8deg);
  border: 3px solid var(--stamp-color, var(--stamp));
  color: var(--stamp-color, var(--stamp));
  padding: 8px 16px;
  font-family: var(--font-mono);
  font-weight: bold; font-size: 14px;
  letter-spacing: 3px; opacity: .85;
  white-space: nowrap;
}
.dx-stamp.slam { animation: stampSlam .45s cubic-bezier(.2,1.5,.3,1) both; }
@keyframes stampSlam {
  0%   { transform: rotate(-8deg) scale(3); opacity: 0; }
  55%  { transform: rotate(-8deg) scale(.9); opacity: 1; }
  75%  { transform: rotate(-10deg) scale(1.06); }
  100% { transform: rotate(-8deg) scale(1); opacity: .85; }
}
.dx-label {
  font-family: var(--font-mono);
  font-size: 13px; letter-spacing: 3px;
  text-transform: uppercase; color: var(--paper-ink-dim);
  font-weight: bold;
  margin-bottom: 12px;
}
.dx-name {
  font-size: 32px; font-weight: 900;
  line-height: 1.15; margin-bottom: 8px;
  font-style: italic;
}
.dx-latin {
  font-family: var(--font-mono);
  font-size: 15px; color: var(--paper-ink-dim);
  margin-bottom: 28px; font-style: italic;
}
.dx-section { margin-bottom: 22px; }
.dx-section p { line-height: 1.6; font-size: 17px; }
.dx-footer {
  margin-top: 32px; padding-top: 20px;
  border-top: 1px dashed rgba(0,0,0,.3);
  display: flex; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 1.5px;
  color: var(--paper-ink-dim); text-transform: uppercase;
}
.actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
}
/* Breathing room between the generated slip/card and the Save/Copy/Share
   action row. Targets #result .actions specifically so it only applies on
   result-output pages (homepage diagnosis, /prescribe, /create/diagnosis,
   /create/prescription) — not the /prescribe static showcase actions. */
#result .actions {
  margin-top: 28px;
}
.disclaimer {
  margin-top: 14px;
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 2px;
  text-align: center; text-transform: uppercase;
  color: var(--ink-dim);
}

/* Live character counter below textareas */
.char-counter {
  margin-top: 6px;
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--ink-dim);
  text-align: right;
  transition: color .15s;
}
.char-counter.warn { color: #fac800; }               /* amber */
.char-counter.hot  { color: #ff4a4a; font-weight: bold; }  /* bright red */

/* name + age row (side by side, narrow age column).
   Align the INPUTS, not the labels, so if a label wraps the two fields
   still sit on the same baseline. */
.name-age-row {
  display: flex; gap: 20px; align-items: flex-end;
  /* The following element is a label (`Patient gender`) which has
     margin-top:20px, but the row has no matching bottom breathing room.
     14px bottom here + 20px on the next label = 34px total, reads right. */
  margin-bottom: 14px;
}
.name-age-row .name-col { flex: 1 1 auto; min-width: 0; }
.name-age-row .age-col  { flex: 0 0 96px; }
.name-age-row .age-col label { white-space: nowrap; }
.name-age-row .age-col input[type="number"] {
  text-align: left;
  font-variant-numeric: tabular-nums;
  -moz-appearance: textfield;
}
.name-age-row .age-col input[type="number"]::-webkit-outer-spin-button,
.name-age-row .age-col input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none; margin: 0;
}
@media (max-width: 480px) {
  .name-age-row .age-col { flex: 0 0 76px; }
}

/* gender select — classic radios (circle + label) */
.gender-row {
  display: flex; flex-wrap: wrap; gap: 22px;
  padding: 8px 0;
  margin: 0;
}
.gender-opt {
  display: inline-flex; align-items: center; gap: 10px;
  cursor: pointer; user-select: none;
  font-family: var(--font-mono); font-size: 13px;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--ink-dim);
  margin: 0; padding: 6px 0;
  font-weight: bold;
  background: none; border: none; border-radius: 0;
  transition: color .15s;
}
.gender-opt::before {
  content: '';
  width: 18px; height: 18px;
  border: 2px solid var(--ink-dim);
  border-radius: 50%;
  flex-shrink: 0;
  box-sizing: border-box;
  transition: border-color .15s, box-shadow .15s;
}
.gender-opt input { position: absolute; opacity: 0; pointer-events: none; }
.gender-opt:has(input:checked) { color: var(--ink); }
.gender-opt:has(input:checked)::before {
  border-color: var(--accent);
  box-shadow: inset 0 0 0 4px var(--accent);
}
.gender-opt:hover { color: var(--ink); }
.gender-opt:hover::before { border-color: var(--accent); }

/* photo upload */
label .optional {
  text-transform: none; letter-spacing: 0;
  font-size: 12px; font-weight: normal;
  color: var(--ink-dim); margin-left: 6px;
}
.photo-row {
  display: flex; align-items: center; gap: 14px; padding: 6px 0;
  border-bottom: 1px solid var(--border);
}
.photo-btn {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--ink);
  background: transparent;
  border: 1px dashed var(--ink-dim);
  padding: 10px 16px;
  cursor: pointer;
  transition: border-color .2s, color .2s;
}
.photo-btn:hover { border-color: var(--accent); color: var(--accent); }
#photoPreview {
  display: none;
  width: 56px; height: 56px; object-fit: cover;
  border: 2px solid var(--ink-dim);
  filter: grayscale(.3) contrast(1.05);
}
#photoPreview.on { display: block; }
.photo-clear {
  background: none; border: 1px solid var(--border);
  color: var(--ink-dim); width: 28px; height: 28px;
  font-size: 18px; cursor: pointer; padding: 0;
  line-height: 1;
}
.photo-clear:hover { color: var(--accent); border-color: var(--accent); }
.photo-note {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 1.5px;
  color: var(--ink-dim);
  text-transform: uppercase;
  margin-top: 10px;
  line-height: 1.5;
}

/* patient row on the diagnosis card */
.dx-patient-row {
  display: flex; justify-content: flex-start; align-items: flex-start;
  gap: 40px; margin-bottom: 24px;
}
.dx-patient-info { flex: 0 1 auto; }
.dx-patient-info #dxPatient {
  font-size: 22px; font-weight: bold; margin-top: 2px;
}
.dx-age-info { flex: 0 0 auto; }
.dx-age-info #dxAge {
  font-size: 22px; font-weight: bold; margin-top: 2px;
  font-variant-numeric: tabular-nums;
}
.dx-photo-wrap { margin-left: auto; }
.dx-photo-wrap {
  flex-shrink: 0; text-align: center;
  transform: rotate(2deg);
}
.dx-photo-wrap img {
  width: 110px; height: 130px; object-fit: cover;
  border: 4px solid #fff;
  box-shadow: 0 4px 14px rgba(0,0,0,.3);
  filter: grayscale(.4) contrast(1.05);
  display: block;
}
.dx-photo-cap {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 2px;
  margin-top: 6px; color: var(--paper-ink-dim);
}
@media (max-width: 480px) {
  .dx-photo-wrap img { width: 86px; height: 100px; }
}

/* FAQ accordion (native <details>) */
.faq-item {
  border-bottom: 1px solid var(--border);
  padding: 14px 0;
}
.faq-item summary {
  cursor: pointer;
  list-style: none;
  font-size: 18px; font-weight: bold;
  color: var(--ink);
  position: relative;
  padding-right: 32px;
  line-height: 1.45;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: '+';
  position: absolute; right: 0; top: 0;
  font-family: var(--font-mono);
  font-size: 20px; line-height: 1;
  color: var(--accent);
  transition: transform .2s;
}
.faq-item[open] summary::after { content: '−'; }
.faq-item summary:hover { color: var(--accent); }
.faq-item p { margin-top: 12px; color: var(--ink); font-size: 16px; line-height: 1.65; }
.act {
  background: var(--bg-2);
  border: 1px solid var(--border);
  color: var(--ink);
  padding: 14px 10px;
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 2px;
  text-transform: uppercase; cursor: pointer;
  transition: all .2s;
  font-weight: bold;
}
.act { display: inline-flex; align-items: center; justify-content: center; gap: 6px; text-decoration: none; }
.act:hover { background: var(--accent); border-color: var(--accent); text-decoration: none; }
.act.primary { background: var(--accent); border-color: var(--accent); color: #fff; }
.act.primary:hover { background: transparent; color: var(--accent); }
.act.fb  { background: #1877f2; border-color: #1877f2; color: #fff; }
.act.fb:hover  { background: #0e65d1; border-color: #0e65d1; color: #fff; }
.act.x   { background: #000; border-color: #444; color: #fff; }
.act.x:hover   { background: #111; border-color: #fff; color: #fff; }
.act.pin { background: #e60023; border-color: #e60023; color: #fff; }
.act.pin:hover { background: #bc001c; border-color: #bc001c; color: #fff; }
.act svg { width: 14px; height: 14px; fill: currentColor; flex-shrink: 0; }

/* Prank-a-friend CTA banner below actions */
.prank-cta {
  margin-top: 18px; padding: 18px 22px;
  background: var(--bg-2);
  border: 1px dashed var(--border);
  border-radius: 2px;
  display: flex; justify-content: space-between; align-items: center;
  gap: 14px; flex-wrap: wrap;
  font-family: var(--font-mono);
  font-size: 13px; letter-spacing: 1.5px;
  text-transform: uppercase;
}
.prank-cta .msg { color: var(--ink-dim); }
.prank-cta .msg strong { color: var(--ink); }
.prank-cta a {
  color: #fff; background: var(--accent);
  padding: 10px 16px; border-radius: 2px;
  font-weight: bold; letter-spacing: 2px;
  text-decoration: none;
}
.prank-cta a:hover { box-shadow: 0 0 20px var(--accent-glow); text-decoration: none; }

/* /create form layout */
.form-grid {
  display: grid; grid-template-columns: 1fr 1.5fr; gap: 18px;
}
@media (max-width: 560px) { .form-grid { grid-template-columns: 1fr; } }
.field-hint {
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 0.5px;
  color: var(--ink-dim);
  margin-top: 8px; line-height: 1.5;
  text-transform: none;
}
.field-hint em { color: var(--accent); font-style: normal; }

/* Category chips (Diagnose: your ex / your mum / ...) */
.chips {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  margin: 0 0 28px;
}
.chips-label {
  font-family: var(--font-mono); font-size: 13px; letter-spacing: 2px;
  color: var(--ink-dim); text-transform: uppercase;
  margin-right: 4px;
}
.chip {
  background: transparent; color: var(--ink);
  border: 1px solid var(--border); border-radius: 20px;
  padding: 9px 16px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 1.5px;
  text-transform: uppercase; cursor: pointer;
  transition: all .15s;
  font-weight: bold;
}
.chip:hover { border-color: var(--accent); color: var(--accent); }
.chip.active { background: var(--accent); color: #fff; border-color: var(--accent); }

/* "Send this to someone" CTA under actions */
.send-this {
  margin-top: 14px;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 13px; letter-spacing: 2px;
  color: var(--ink-dim); text-transform: uppercase;
  line-height: 1.5;
}
.send-this strong { color: var(--accent); }

/* Follow-us modal (post-diagnose FB push) */
.modal-backdrop {
  position: fixed; inset: 0; background: rgba(0,0,0,.75);
  z-index: 400; display: flex; align-items: center; justify-content: center;
  padding: 20px;
  animation: fadeIn .2s ease;
}
.modal-card {
  background: var(--paper); color: var(--paper-ink);
  max-width: 420px; width: 100%;
  padding: 36px 32px;
  position: relative; border-radius: 2px;
  box-shadow: 0 20px 60px rgba(0,0,0,.6);
  animation: fadeIn .3s ease;
}
.modal-card::before {
  content:''; position: absolute; inset: 8px;
  border: 1px solid rgba(0,0,0,.15);
  pointer-events: none;
}
.modal-card .eyebrow { color: rgba(0,0,0,.55); margin-bottom: 8px; }
.modal-card .eyebrow::before, .modal-card .eyebrow::after { color: rgba(0,0,0,.3); }
.modal-card h2 {
  font-family: var(--font-serif);
  font-size: 28px; line-height: 1.2;
  margin-bottom: 12px; font-style: italic;
}
.modal-card p {
  font-size: 15px; line-height: 1.5;
  color: rgba(0,0,0,.75); margin-bottom: 22px;
}
.modal-card .modal-fb {
  display: inline-flex; align-items: center; gap: 10px;
  background: #1877f2; color: #fff;
  padding: 14px 22px; border-radius: 2px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 2px;
  text-decoration: none; text-transform: uppercase; font-weight: bold;
}
.modal-card .modal-fb:hover { background: #0e65d1; text-decoration: none; }
.modal-card .modal-fb svg { width: 16px; height: 16px; fill: currentColor; }
.modal-card .modal-close {
  position: absolute; top: 10px; right: 14px;
  background: none; border: none; cursor: pointer;
  font-size: 22px; line-height: 1; color: rgba(0,0,0,.5);
  padding: 4px 8px;
}
.modal-card .modal-close:hover { color: var(--accent); }
.modal-card .modal-dismiss {
  display: block; margin-top: 14px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 2px;
  color: rgba(0,0,0,.5); background: none; border: none; cursor: pointer;
  text-transform: uppercase;
}
.modal-card .modal-dismiss:hover { color: var(--accent); }

@media (max-width: 560px) {
  .dx-name { font-size: 26px; }
  .diagnosis { padding: 28px 20px; }
  .dx-header { flex-direction: column; gap: 16px; }
  .form-card { padding: 24px 20px; }
  .wrap { padding: 24px 16px 60px; }
  .topnav { padding: 14px 16px; }
  .topnav nav a { margin-left: 14px; }
}

/* =============================================================================
   V2 LAYOUT — sticky dark header, ticker, 2-col hero, archive gallery,
   testimonials, CTA strip, dark footer grid. Applied on index.html only.
   Interior pages (/create, /about, /privacy, /conditions/*) still use the
   original single-column layout via the pre-V2 rules above.
   ============================================================================= */

/* Dark V2 nav — applied when class "topnav-v2" is present.
   Non-sticky (body has overflow-x:hidden which breaks position:sticky, and
   Gray doesn't want sticky anyway). Full-bleed dark band with ℞ seal brand. */
.topnav-v2 {
  background: rgba(10,10,15,.92);
  border-bottom: 1px solid var(--border);
  max-width: none;               /* full bleed */
  margin: 0;
  padding: 14px 32px;
  letter-spacing: 3px;
  font-size: 13px;
  position: relative;
  /* Must sit strictly above the ticker (z-index:2) so the mobile dropdown
     nav (trapped inside this stacking context) renders over the ticker bar.
     Base .topnav { z-index: 2 } was tying — we need > 2 here. */
  z-index: 10;
  /* Cluster the right-side controls together (search / hamburger / nav).
     Base .topnav uses space-between which scattered them across the bar. */
  justify-content: flex-end;
  gap: 22px;
}
.topnav-v2 .brand { margin-right: auto; }  /* pushes brand to the far left */
.topnav-v2 .brand {
  display: inline-flex; align-items: center; gap: 12px;
  font-size: 15px; line-height: 1;
  /* Kill the default link underline (base.css has a:hover {text-decoration:underline}).
     Also suppresses the iOS tap-flash which was visibly cutting across the ℞ glyph. */
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;
}
.topnav-v2 .brand:hover,
.topnav-v2 .brand:active,
.topnav-v2 .brand:focus { text-decoration: none; }
.topnav-v2 .brand-seal {
  /* Image mark replaces the font-rendered ℞. The 2000×2000 source handles
     any display size cleanly; no optical-centering tweaks needed — the
     asset is pre-centered. */
  width: 56px; height: 56px;
  flex-shrink: 0;
  display: inline-block;
  vertical-align: middle;
}
.topnav-v2 nav a { font-size: 13px; letter-spacing: 2px; }
@media (max-width: 820px) {
  .topnav-v2 {
    padding: 12px 14px;
    gap: 10px;                   /* tighter so brand + search + menu fit in one row at 375px */
    flex-wrap: nowrap;           /* never stack on 2 lines */
  }
  .topnav-v2 .brand { font-size: 13px; letter-spacing: 2px; gap: 10px; }
  .topnav-v2 .brand-seal { width: 44px; height: 44px; }
  .topnav-v2 .search-nav-btn { width: 32px; height: 32px; }
  .topnav-v2 .hamburger { padding: 6px 10px; }
  /* Dropdown must cover more ground than just the topnav — give it an opaque
     background and a higher min-width so it doesn't collide with the ticker
     content that sits immediately below the header. */
  .topnav-v2 nav#mainNav {
    min-width: 200px;
    background: #12121a;
    box-shadow: 0 14px 36px rgba(0,0,0,.6);
  }
}
@media (max-width: 380px) {
  .topnav-v2 .brand { font-size: 12px; letter-spacing: 1.5px; }
}

/* Live ticker */
.ticker {
  position: relative; z-index: 2;
  background: var(--bg-2);
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}
.ticker-inner {
  display: inline-flex; gap: 54px;
  padding: 10px 0;
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 2px; text-transform: uppercase;
  /* Near-white on dark bg-2 for maximum legibility while scrolling */
  color: #f5f3ed;
  white-space: nowrap;
  animation: ticker-scroll 160s linear infinite;
  will-change: transform;
  /* Force hardware compositing for crisper anti-aliasing during the scroll —
     kills the subpixel shimmer on the red strong tags. */
  transform: translateZ(0);
  backface-visibility: hidden;
  -webkit-font-smoothing: antialiased;
}
.ticker-inner span {
  display: inline-flex; align-items: center; gap: 10px;
  flex-shrink: 0;
}
.ticker-inner i.dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
  display: inline-block;
}
.ticker-inner strong {
  /* Vivid saturated red that pops against near-white base text */
  color: #ff3d5a;
  font-weight: bold;
}
.ticker-inner .dot {
  /* Match the strong red for a consistent accent pulse */
  background: #ff3d5a;
}
@keyframes ticker-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .ticker-inner { animation: none; transform: translateX(0); }
}

/* V2 wrap — wider than legacy 760px so the 2-col hero can breathe */
.wrap.v2 {
  max-width: 1180px;
  padding: 48px 32px 80px;
}
@media (max-width: 560px) {
  .wrap.v2 { padding: 28px 18px 60px; }
}

/* Small scroll-margin so scrollIntoView / anchor links have breathing room */
.wrap.v2 #result,
.wrap.v2 #form,
.wrap.v2 #faq,
.wrap.v2 #codCard,
.wrap.v2 section[id] { scroll-margin-top: 20px; }

/* Hero: 2-col on desktop, stacked on mobile */
.hero-v2 {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 64px;
  align-items: start;
  margin-bottom: 72px;
}
.hero-left { max-width: 600px; }
.hero-left .eyebrow { margin-bottom: 26px; }
.hero-left h1 {
  font-size: clamp(52px, 6.5vw, 90px);
  line-height: .94;
  letter-spacing: -2.5px;
  margin-bottom: 26px;
  font-weight: 900;
}
.hero-left h1 em {
  font-style: italic;
  color: #c41e3a;           /* deeper, more saturated than the pink-leaning --accent */
  text-shadow: 0 0 50px rgba(196,30,58,.4);
}
.hero-left .lede { margin-bottom: 32px; font-size: 19px; }
.hero-right { position: relative; }

/* Two-stat strip inside the hero */
.stats-row {
  display: flex; gap: 40px;
  padding: 22px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  margin-bottom: 28px;
}
.stat .num {
  font-size: 30px; font-weight: 900;
  color: #c41e3a;           /* match hero "wrong" — deeper saturated red */
  line-height: 1;
  margin-bottom: 6px;
  font-variant-numeric: tabular-nums;
  font-family: var(--font-serif);
}
.stat .lbl {
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 2px;
  color: var(--ink-dim); text-transform: uppercase;
}

/* Hero inline testimonial — helps balance the long form-card column */
.hero-testi {
  border-left: 2px solid var(--accent);
  padding: 6px 0 6px 18px;
  max-width: 460px;
}
.hero-testi q {
  display: block;
  font-size: 16px; line-height: 1.55;
  font-style: italic;
  color: var(--ink);
  margin-bottom: 10px;
  quotes: "\201C" "\201D";
}
.hero-testi .testi-author {
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 2px;
  color: var(--ink-dim); text-transform: uppercase;
}

@media (max-width: 960px) {
  .hero-v2 { grid-template-columns: 1fr; gap: 40px; margin-bottom: 56px; }
  .hero-left { max-width: none; }
  .hero-left h1 { font-size: clamp(42px, 9vw, 64px); letter-spacing: -1.5px; }
}

/* CASE FILE · NEW ADMISSION ribbon on the form-card (V2 only) */
.form-card.form-card-ribbon {
  position: relative;
  overflow: visible;
}
.form-card.form-card-ribbon::before {
  content: 'CASE FILE · NEW ADMISSION';
  position: absolute;
  top: -10px; left: 24px;
  background: var(--bg);
  padding: 2px 14px;
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 3px;
  color: var(--accent);
  z-index: 2;
}
.form-card.form-card-ribbon::after {
  content: ''; position: absolute;
  top: 16px; right: 20px;
  width: 52px; height: 52px;
  border: 2px solid var(--stamp);
  border-radius: 50%;
  background:
    linear-gradient(45deg, transparent 48%, var(--stamp) 48%, var(--stamp) 52%, transparent 52%);
  opacity: .22;
  pointer-events: none;
}

/* Generic section header for V2 sections */
.section-header {
  margin: 0 0 28px;
  max-width: 720px;
}
.section-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 3px;
  color: var(--accent); text-transform: uppercase;
  margin-bottom: 12px;
}
.section-sub {
  font-size: 16px; color: var(--ink);
  font-style: italic; max-width: 620px;
  margin-top: 10px;
}

/* Case-files archive gallery */
.archive-wrap { margin: 80px 0 64px; }
.case-gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
/* 2-column variant — used on /create lander where larger cards breathe better
   (fewer, longer entries; each with a submitter byline). */
.case-gallery.case-gallery-2col {
  grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 780px) {
  .case-gallery.case-gallery-2col { grid-template-columns: 1fr; }
}
.case-card {
  background: var(--paper);
  color: var(--paper-ink);
  padding: 24px 22px 46px;
  border-radius: 12px;              /* modern rounded — was 2px */
  position: relative;
  text-decoration: none;
  transform: rotate(-.5deg);
  transition: transform .25s, box-shadow .25s;
  box-shadow: 0 16px 36px rgba(0,0,0,.45);
  min-height: 200px;
  display: flex; flex-direction: column;
}
.case-card:hover { box-shadow: 0 22px 48px rgba(0,0,0,.55); }
.case-card:nth-child(2) { transform: rotate(.7deg); }
.case-card:nth-child(3) { transform: rotate(-.3deg); }
.case-card:nth-child(4) { transform: rotate(.4deg); }
.case-card:nth-child(5) { transform: rotate(-.6deg); }
.case-card:nth-child(6) { transform: rotate(.25deg); }
.case-card:hover { transform: rotate(0deg) translateY(-4px); text-decoration: none; }
.case-card::before {
  content: ''; position: absolute; inset: 6px;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 8px;               /* match outer radius, offset by inset */
  pointer-events: none;
}
.case-head {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 9px; letter-spacing: 2px;
  text-transform: uppercase; opacity: .65;
  margin-bottom: 14px; padding-bottom: 10px;
  border-bottom: 1px solid rgba(0,0,0,.15);
}
.case-card-name {
  font-size: 20px; font-weight: 900;
  font-style: italic; line-height: 1.15;
  margin-bottom: 6px;
  color: var(--paper-ink);
}
.case-card-latin {
  font-family: var(--font-mono);
  font-size: 11px; font-style: italic;
  opacity: .55; margin-bottom: 10px;
}
.case-card-desc {
  font-size: 13px; line-height: 1.5;
  opacity: .95;
  margin: 0;
}
.case-card-stamp {
  position: absolute; bottom: 14px; right: 14px;
  transform: rotate(-8deg);
  border: 2px solid var(--stamp); color: var(--stamp);
  padding: 3px 8px;
  font-family: var(--font-mono);
  font-weight: bold; font-size: 9px;
  letter-spacing: 2px; opacity: .75;
}
/* Patient-submission byline on /create lander showcase cards */
.case-attrib {
  margin-top: 14px;
  padding-top: 10px;
  border-top: 1px dashed rgba(60,50,35,0.25);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 1px;
  color: var(--paper-ink-dim, rgba(60,50,35,0.7));
  text-transform: uppercase;
}
.archive-cta {
  text-align: center; margin-top: 36px;
}
@media (max-width: 960px) { .case-gallery { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .case-gallery { grid-template-columns: 1fr; gap: 18px; } }

/* Services grid — scaffolded, gated by [data-live-services] count on wrapper */
.services-wrap { margin: 64px 0 48px; }
.services-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.service {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 28px 22px;
  text-decoration: none; color: inherit;
  position: relative;
  transition: border-color .2s, transform .2s, box-shadow .2s;
  display: flex; flex-direction: column;
  min-height: 240px;
}
.service:hover {
  border-color: var(--accent);
  transform: translateY(-2px);
  box-shadow: 0 20px 40px rgba(196,30,58,.12);
  text-decoration: none;
}
.service .rx-icon {
  width: 44px; height: 44px;
  border: 2px solid var(--accent);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--accent);
  font-family: var(--font-serif);
  font-size: 20px; font-weight: bold;
  margin-bottom: 16px;
  flex-shrink: 0;
}
.service h3 {
  font-size: 20px; font-weight: 900;
  margin-bottom: 6px; letter-spacing: -.5px;
}
.service .service-latin {
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 1px;
  color: var(--ink-dim); font-style: italic;
  margin-bottom: 12px;
  text-transform: lowercase;
}
.service p {
  font-size: 13px; line-height: 1.55;
  color: var(--ink-dim);
  margin-bottom: auto;
}
.service .service-cta {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 2px;
  color: var(--accent); text-transform: uppercase;
  margin-top: 18px;
}
.service .badge-new {
  position: absolute; top: 14px; right: 14px;
  background: var(--accent); color: #fff;
  font-family: var(--font-mono);
  font-size: 9px; letter-spacing: 2px;
  padding: 3px 8px; border-radius: 2px;
}
/* Hide the [data-coming-soon] services until they ship */
.service[data-coming-soon="true"] { display: none; }
@media (max-width: 960px) { .services-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .services-grid { grid-template-columns: 1fr; } }

/* Testimonials */
.testimonials-wrap { margin: 72px 0 40px; }
.testimonials {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.testi {
  border-left: 2px solid var(--accent);
  padding: 6px 0 6px 20px;
}
.testi q {
  display: block;
  font-size: 17px; line-height: 1.5;
  font-style: italic;
  color: var(--ink);
  margin-bottom: 14px;
  quotes: "\201C" "\201D";
}
.testi .testi-author {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 2px;
  color: var(--ink-dim); text-transform: uppercase;
}
@media (max-width: 960px) { .testimonials { grid-template-columns: 1fr; gap: 22px; } }

/* CTA strip — "Know someone worse?" */
.cta-strip {
  margin: 80px 0 24px;
  padding: 56px 32px;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 16px;              /* rounded card, not a full-bleed strip */
  text-align: center;
  box-shadow: 0 10px 40px rgba(0,0,0,.25);
}
.cta-strip h2 {
  font-size: clamp(28px, 3.6vw, 46px);
  margin-bottom: 16px;
  line-height: 1.05;
}
.cta-strip p {
  font-size: 17px; color: var(--ink);
  max-width: 560px; margin: 0 auto 24px;
  font-style: italic;
  line-height: 1.55;
}

/* V2 grid footer */
.footer-v2 {
  max-width: 1180px; margin: 72px auto 0;
  padding: 44px 32px 20px;
  border-top: 1px solid var(--border);
  position: relative; z-index: 1;
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 1.5px;
  color: var(--ink-dim);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 36px;
}
.footer-seal {
  /* Image mark replaces the font-rendered ℞ — see .topnav-v2 .brand-seal.
     Footer is the brand-presence surface; sized substantially larger than
     the header so the mark anchors the column. */
  width: 220px; height: 220px;
  max-width: 100%;
  display: block;
  margin-bottom: 22px;
}
@media (max-width: 720px) {
  .footer-seal { width: 160px; height: 160px; }
}
.footer-v2 h4 {
  font-size: 11px; letter-spacing: 2px;
  color: var(--ink); text-transform: uppercase;
  margin-bottom: 16px;
  font-family: var(--font-mono);
  font-weight: bold;
}
.footer-v2 a {
  display: block; color: #ffffff; text-decoration: none;
  margin-bottom: 10px; text-transform: uppercase;
}
.footer-v2 a:hover { color: var(--accent); text-decoration: none; }
.footer-brand-block strong {
  color: var(--ink); display: block; margin-bottom: 10px; font-weight: bold;
  font-size: 12px; letter-spacing: 2px;
}
.footer-brand-block p {
  font-size: 12px; line-height: 1.7; color: var(--ink-dim);
  text-transform: none; letter-spacing: .5px; margin: 0;
  max-width: 320px;
}
.footer-bottom {
  display: flex; justify-content: space-between;
  padding: 18px 0 0;
  border-top: 1px solid var(--border);
  font-size: 10px; letter-spacing: 2px;
  color: var(--ink-dim); text-transform: uppercase;
  flex-wrap: wrap; gap: 12px;
}
@media (max-width: 960px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) {
  .footer-grid { grid-template-columns: 1fr; gap: 28px; }
  .footer-v2 { padding: 36px 18px 16px; margin-top: 56px; }
}

/* =============================================================================
   Global search modal (Cmd+K). Mounted on every page via /assets/js/search.js
   ============================================================================= */
.search-nav-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 34px; height: 34px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 50%;
  color: var(--ink-dim);
  cursor: pointer;
  transition: border-color .15s, color .15s;
  padding: 0;
  flex-shrink: 0;
}
.search-nav-btn:hover { border-color: var(--accent); color: var(--accent); }
.search-nav-btn svg { width: 14px; height: 14px; stroke-width: 2; }

.search-modal {
  position: fixed; inset: 0;
  z-index: 1000;
  display: flex; align-items: flex-start; justify-content: center;
  padding: 8vh 16px 16px;
}
.search-modal[hidden] { display: none; }
.search-backdrop {
  position: absolute; inset: 0;
  background: rgba(5, 5, 10, .78);
  -webkit-backdrop-filter: blur(4px);
          backdrop-filter: blur(4px);
}
.search-card {
  position: relative; z-index: 1;
  width: 100%; max-width: 640px;
  max-height: 80vh;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 30px 80px rgba(0,0,0,.6);
  display: flex; flex-direction: column;
  overflow: hidden;
}
.search-input-row {
  display: flex; align-items: center;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  gap: 14px;
}
.search-input-icon {
  color: var(--ink-dim);
  flex-shrink: 0;
  width: 18px; height: 18px;
}
.search-input {
  flex: 1;
  background: transparent;
  border: none;
  color: var(--ink);
  font-family: var(--font-serif);
  font-size: 18px;
  outline: none;
  padding: 4px 0;
  line-height: 1.4;
  /* kill the underline that comes from base input styles */
  border-bottom: 0;
}
.search-input::placeholder { color: var(--ink-dim); opacity: .7; }
.search-esc {
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 1.5px;
  padding: 4px 8px;
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--ink-dim);
  text-transform: uppercase;
  background: transparent;
}

.search-results {
  flex: 1;
  overflow-y: auto;
  padding: 8px 0;
}
.search-hint {
  padding: 18px 22px 12px;
  display: flex; flex-wrap: wrap; align-items: center; gap: 10px;
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 2px; text-transform: uppercase;
  color: var(--ink-dim);
}
.search-hint-label { color: var(--ink-dim); margin-right: 4px; }
.search-chip {
  background: transparent;
  border: 1px dashed var(--border);
  color: var(--ink-dim);
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 1.5px;
  padding: 6px 12px;
  border-radius: 4px;
  cursor: pointer;
  text-transform: uppercase;
  transition: border-color .15s, color .15s;
}
.search-chip:hover { border-color: var(--accent); color: var(--accent); }

.search-empty {
  padding: 28px 22px;
  color: var(--ink-dim);
  font-style: italic;
  text-align: center;
  line-height: 1.6;
}
.search-empty strong { color: var(--ink); font-style: normal; }

.search-result {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 12px 20px;
  color: var(--ink);
  text-decoration: none;
  cursor: pointer;
  border-left: 2px solid transparent;
  transition: background .1s, border-color .1s;
}
.search-result:hover, .search-result.selected {
  background: rgba(255,255,255,.04);
  border-left-color: var(--accent);
  text-decoration: none;
}
.search-result-stamp {
  flex-shrink: 0;
  font-family: var(--font-mono);
  font-size: 9px; letter-spacing: 1.5px;
  padding: 4px 7px;
  border: 1px solid;
  border-radius: 3px;
  font-weight: bold;
  margin-top: 2px;
  min-width: 68px;
  text-align: center;
}
.search-result-body { flex: 1; min-width: 0; }
.search-result-name {
  font-size: 16px; line-height: 1.3;
  font-weight: bold;
  font-style: italic;
  font-family: var(--font-serif);
  margin-bottom: 4px;
  color: var(--ink);
}
.search-result-desc {
  font-size: 13px; line-height: 1.5;
  color: var(--ink-dim);
}
/* Rx-type badge inside search-result-name — visually marks a prescription
   result so mixed DX/RX lists are scannable. */
.search-result-type {
  display: inline-block;
  font-size: 10px;
  letter-spacing: 2px;
  font-family: var(--font-mono);
  font-style: normal;
  font-weight: bold;
  text-transform: uppercase;
  color: var(--accent);
  border: 1px solid var(--accent);
  padding: 1px 6px;
  margin-right: 6px;
  vertical-align: 2px;
  border-radius: 2px;
}
.search-result mark {
  background: rgba(226,58,86,.25);
  color: var(--ink);
  padding: 0 2px;
  border-radius: 2px;
}
.search-more {
  padding: 14px 22px;
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--ink-dim);
  text-align: center;
  border-top: 1px solid var(--border);
}
.search-footer {
  display: flex; gap: 22px;
  padding: 12px 20px;
  border-top: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 1.5px;
  color: var(--ink-dim);
  text-transform: uppercase;
}
.search-footer kbd {
  display: inline-block;
  padding: 2px 6px;
  margin-right: 4px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 3px;
  font-family: inherit;
  font-size: 10px;
}

@media (max-width: 560px) {
  .search-modal { padding: 6vh 10px 10px; }
  .search-card { max-height: 88vh; }
  .search-input { font-size: 16px; }  /* prevents iOS zoom */
  .search-footer { display: none; }
  .search-esc { display: none; }
  .search-result-stamp { min-width: 56px; font-size: 8px; }
  .search-result-name { font-size: 15px; }
}

/* =========================================================================
   PHARMACY / PRESCRIPTION SECTION — /prescribe, /prescribe/create, /rx/<slug>
   ========================================================================= */

/* Legacy .breadcrumb (singular) rules removed — /prescribe now uses the
   canonical .breadcrumbs (plural) markup defined earlier with shared hover
   treatment across all pages. */

/* Hero H1 on /prescribe — smaller than default site H1 so the italic
   'prescription' doesn't land on its own line with a descender that
   overhangs the next line. Paired with a forced <br> in the HTML. */
.hero-h1-rx {
  font-size: clamp(40px, 5.2vw, 68px);
  line-height: 1.02;
  letter-spacing: -1px;
}

/* Form-card variant: Pharmacy Counter ribbon (replaces the default CASE FILE) */
.form-card-rx::before { content: 'PHARMACY COUNTER · NEW REQUEST'; }
.form-card-rx::after {
  content: '℞';
  position: absolute;
  top: 14px; right: 18px;
  font-family: Georgia, serif; font-style: italic;
  font-size: 44px; color: var(--stamp, #8b0000);
  opacity: .22; line-height: 1; pointer-events: none;
}

/* Chip variant that sits inline inside a form-card (tighter spacing) */
.chips-inline {
  margin: 20px 0 4px;
  padding-top: 18px;
  border-top: 1px dashed var(--border);
}
.chips-inline .chips-label { margin-bottom: 10px; }

/* -------------------------------------------------------------------------
   Sample / live Rx slip  (display version — rotated for vibe; downloadable
   share-card renders straight via canvas, rotation is display-only)
   ------------------------------------------------------------------------- */
.sample-section { max-width: 1180px; margin: 0 auto; padding: 0 32px; }

.sample-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 48px;
  align-items: center;
  margin-top: 32px;
}
@media (max-width: 820px) {
  .sample-grid { grid-template-columns: 1fr; gap: 32px; }
}

/* The paper Rx slip itself. Keeps the 'paper on a dark page' feel of the
   diagnosis card but uses pharmacy-specific layout: clinic head, patient
   row, prescribed-treatment block, side-effects callout, footer with
   pharmacist signature + DISPENSED stamp. */
.rx-slip {
  /* Scoped type stack — matches canvas output (Option A font set) */
  --rx-serif: "Libre Caslon Text", Georgia, "Times New Roman", serif;
  --rx-mono: "IBM Plex Mono", "Courier New", ui-monospace, monospace;
  --rx-script: "Caveat", "Segoe Script", "Lucida Handwriting", cursive;

  background: #f2ecdc;
  color: #1a1a1a;
  padding: 32px 28px;
  border-radius: 2px;
  font-family: var(--rx-serif);
  box-shadow: 0 20px 60px rgba(0,0,0,.45);
  position: relative;
  max-width: 560px;
  margin: 0 auto;
}
.rx-slip::before {
  content: '';
  position: absolute; inset: 8px;
  border: 1px solid rgba(0,0,0,.14);
  pointer-events: none;
  border-radius: 1px;
}
.rx-slip-sample {
  transform: rotate(-.7deg);
  transition: transform .3s;
}
.rx-slip-sample:hover { transform: rotate(0deg); }

.rx-slip-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  padding-bottom: 14px;
  border-bottom: 2px solid #1a1a1a;
  margin-bottom: 20px;
}
.rx-clinic {
  font-family: var(--rx-mono);
  font-size: 13px; letter-spacing: 2px;
  font-weight: bold; margin-bottom: 3px;
}
.rx-sub {
  font-family: var(--rx-mono);
  font-size: 10px; letter-spacing: 2px;
  color: var(--paper-ink-dim);
  text-transform: uppercase;
}
.rx-glyph {
  font-size: 44px; line-height: 1;
  color: #8b0000;
  font-style: italic;
  font-family: Georgia, serif;
}

.rx-meta {
  display: flex; justify-content: space-between;
  font-family: var(--rx-mono);
  font-size: 10px; letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--paper-ink-dim);
  margin-bottom: 16px;
}

.rx-slip .rx-label {
  font-family: var(--rx-mono);
  font-size: 10px; letter-spacing: 2px;
  text-transform: uppercase; font-weight: bold;
  margin-bottom: 6px; margin-top: 0;
  color: var(--paper-ink-dim);
}

.rx-patient {
  font-size: 17px; font-weight: bold;
  margin-bottom: 16px;
  padding-bottom: 6px;
  border-bottom: 1px dashed rgba(0,0,0,.3);
}
.rx-complaint {
  font-size: 14px; line-height: 1.55;
  font-style: italic;
  color: var(--paper-ink);
  margin-bottom: 20px;
}
.rx-prescribed {
  border-top: 1px solid rgba(0,0,0,.2);
  padding-top: 16px; margin-bottom: 20px;
}
.rx-name {
  font-size: 24px; font-weight: 500;
  font-style: italic; line-height: 1.2;
  margin-bottom: 4px;
}
.rx-trans {
  font-family: var(--rx-mono);
  font-size: 12px;
  font-style: italic;
  color: var(--paper-ink-dim);
  margin-bottom: 14px;
}
.rx-dosage {
  width: 100%; font-size: 13px;
  line-height: 1.7;
  border-collapse: collapse;
}
.rx-dosage td { padding: 3px 0; vertical-align: top; }
.rx-dosage .dk {
  font-family: var(--rx-mono);
  font-size: 10px; letter-spacing: 1.5px;
  color: var(--paper-ink-dim);
  text-transform: uppercase; font-weight: bold;
  padding-right: 14px; width: 110px;
}
.rx-sideeffects {
  background: rgba(139,0,0,.06);
  border-left: 3px solid #8b0000;
  padding: 10px 14px;
  margin-bottom: 20px;
  font-size: 12.5px; line-height: 1.55;
  color: var(--paper-ink);
}
.rx-sideeffects-label {
  display: block; margin-bottom: 4px;
  font-family: var(--rx-mono);
  font-size: 10px; letter-spacing: 2px;
  text-transform: uppercase; color: #8b0000;
  font-weight: bold;
}
.rx-footer {
  display: flex; justify-content: space-between;
  align-items: flex-end;
  padding-top: 14px;
  border-top: 1px dashed rgba(0,0,0,.3);
}
.rx-sig {
  font-family: var(--rx-script);
  font-size: 22px; font-style: italic;
  color: #1a1a1a; line-height: 1; margin-bottom: 2px;
}
.rx-sig-line {
  border-top: 1px solid rgba(0,0,0,.4);
  padding-top: 3px;
  font-family: var(--rx-mono);
  font-size: 10px; letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--paper-ink-dim);
}
.rx-stamp {
  transform: rotate(-6deg);
  border: 3px solid #8b0000;
  color: #8b0000;
  padding: 5px 11px;
  font-family: var(--rx-mono);
  font-weight: bold; font-size: 11px;
  letter-spacing: 2.5px; opacity: .85;
}

/* Sample-side 'Every Rx is unique' explainer */
.sample-explain h3 {
  font-size: 28px; font-weight: 900;
  letter-spacing: -.5px; margin-bottom: 14px;
}
.sample-explain h3 em { font-style: italic; color: var(--accent); }
.sample-explain p {
  font-size: 15px; line-height: 1.7;
  color: var(--ink-dim); margin-bottom: 14px;
}
.rx-bullets {
  list-style: none; padding: 0; margin-top: 20px;
}
.rx-bullets li {
  font-family: var(--rx-mono);
  font-size: 12px; letter-spacing: 1.5px;
  color: var(--ink); text-transform: uppercase;
  padding-left: 22px; position: relative;
  margin-bottom: 10px;
}
.rx-bullets li::before {
  content: '℞'; position: absolute;
  left: 0; color: var(--accent);
  font-family: Georgia, serif; font-style: italic;
  font-size: 14px; top: -1px;
}

/* -------------------------------------------------------------------------
   How it works (3-step grid)
   ------------------------------------------------------------------------- */
.hiw-wrap { max-width: 1180px; margin: 0 auto; padding: 0 32px; }
.hiw-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 32px;
}
@media (max-width: 820px) {
  .hiw-grid { grid-template-columns: 1fr; gap: 14px; }
}
.hiw-step {
  background: var(--bg-2);
  border: 1px solid var(--border);
  padding: 22px 22px;
  border-radius: 2px;
}
.hiw-num {
  display: inline-block;
  font-family: var(--rx-mono);
  font-size: 11px; letter-spacing: 3px;
  color: var(--accent); text-transform: uppercase;
  border: 1px solid var(--accent);
  padding: 2px 8px;
  margin-bottom: 14px;
}
.hiw-step h3 {
  font-size: 20px; font-weight: 900;
  letter-spacing: -.3px;
  margin-bottom: 8px; margin-top: 0;
  color: var(--ink);
  text-transform: none;  /* override inherited label caps */
}
.hiw-step p {
  font-size: 14px; line-height: 1.6;
  color: var(--ink-dim); margin: 0;
}

/* -------------------------------------------------------------------------
   Popular dispensations grid — paper Rx-slip cards, same visual language
   as the homepage's /conditions case-card archive gallery.
   ------------------------------------------------------------------------- */
.rx-featured { max-width: 1180px; margin: 0 auto; padding: 0 32px; }
.rx-featured-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 32px;
}
@media (max-width: 960px) {
  .rx-featured-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .rx-featured-grid { grid-template-columns: 1fr; gap: 18px; }
}
.rx-card {
  background: var(--paper);
  color: var(--paper-ink);
  padding: 22px 22px 46px;
  border-radius: 12px;
  position: relative;
  text-decoration: none;
  transform: rotate(-.5deg);
  transition: transform .25s, box-shadow .25s;
  box-shadow: 0 16px 36px rgba(0,0,0,.45);
  min-height: 210px;
  display: flex; flex-direction: column;
}
.rx-card:hover {
  box-shadow: 0 22px 48px rgba(0,0,0,.55);
  transform: rotate(0deg) translateY(-4px);
}
.rx-card:nth-child(2) { transform: rotate(.7deg); }
.rx-card:nth-child(3) { transform: rotate(-.3deg); }
.rx-card:nth-child(4) { transform: rotate(.4deg); }
.rx-card:nth-child(5) { transform: rotate(-.6deg); }
.rx-card:nth-child(6) { transform: rotate(.25deg); }
.rx-card:nth-child(2):hover,
.rx-card:nth-child(3):hover,
.rx-card:nth-child(4):hover,
.rx-card:nth-child(5):hover,
.rx-card:nth-child(6):hover { transform: rotate(0deg) translateY(-4px); }
.rx-card::before {
  content: ''; position: absolute; inset: 6px;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 8px;
  pointer-events: none;
}
/* Faint ℞ watermark in top-right to identify these as Rx, not diagnoses. */
.rx-card::after {
  content: '℞';
  position: absolute; top: 14px; right: 16px;
  font-family: Georgia, serif; font-style: italic;
  font-size: 30px; line-height: 1;
  color: var(--stamp);
  opacity: .18;
  pointer-events: none;
}
.rx-card-head {
  display: flex; justify-content: space-between;
  font-family: var(--rx-mono);
  font-size: 10px; letter-spacing: 2px;
  text-transform: uppercase; font-weight: bold;
  margin-bottom: 14px; padding-bottom: 10px;
  padding-right: 34px;    /* clear the ℞ watermark */
  border-bottom: 1px solid rgba(0,0,0,.18);
  color: var(--paper-ink-dim);
}
.rx-card-name {
  font-size: 21px; font-weight: 900;
  font-style: italic; line-height: 1.15;
  margin-bottom: 6px;
  color: var(--paper-ink);
}
.rx-card-lat {
  font-family: var(--rx-mono);
  font-size: 12px; font-style: italic;
  margin-bottom: 12px;
  color: var(--paper-ink-dim);
}
.rx-card-desc {
  font-size: 14px; line-height: 1.55;
  margin: 0;
  color: var(--paper-ink);
}
.rx-card-stamp {
  position: absolute; bottom: 14px; right: 14px;
  transform: rotate(-8deg);
  border: 2px solid var(--stamp); color: var(--stamp);
  padding: 3px 8px;
  font-family: var(--rx-mono);
  font-weight: bold; font-size: 9px;
  letter-spacing: 2px; opacity: .8;
}

/* Pharmacy-page section header centering — applies only inside these wrappers
   so the homepage's archive/testimonials/services keep their own alignment. */
.sample-section .section-header,
.rx-featured .section-header,
.hiw-wrap .section-header,
.pharmacy-testimonials .section-header {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 28px;
}
.sample-section .section-sub,
.rx-featured .section-sub,
.hiw-wrap .section-sub,
.pharmacy-testimonials .section-sub {
  margin-left: auto;
  margin-right: auto;
}

/* Kill all text decoration inside rx cards, including on hover. The card
   itself is an <a> so global a:hover underline cascades to children. */
.rx-card,
.rx-card *,
.rx-card:hover,
.rx-card:hover * {
  text-decoration: none;
}

/* -------------------------------------------------------------------------
   Live result area (after form submission on /prescribe)
   Uses .rx-slip + .rx-slip-live; reuses .actions + .act for share buttons.
   ------------------------------------------------------------------------- */
.rx-result-wrap {
  max-width: 680px;
  margin: 56px auto 0;
  padding: 0 20px;
}
/* Live slip sits straight (no rotation) — display-only tilt is on .rx-slip-sample. */
.rx-slip-live { margin: 0 auto; transform: none; }

/* (html2canvas export approach retired — canvas is now hand-drawn sync via
    buildRxCard() in rx-generator.js, matching the diagnosis-card pattern from
    generator.js. No off-screen DOM clone needed.) */
.rx-result-wrap .actions {
  margin-top: 28px;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}
.rx-result-wrap .send-this {
  margin: 18px auto 0;
  text-align: center;
  font-family: var(--rx-mono);
  font-size: 12px; letter-spacing: 2px;
  color: var(--ink-dim);
  text-transform: uppercase;
}
