:root {
    --paper: #faf7ef;
    --paper-2: #f1ece0;
    --paper-3: #e4dcc7;
    --ink: #14110d;
    --ink-2: #3a332a;
    --ink-soft: #736756;
    --rx: #c73a0f;
    --rx-deep: #8a2608;
    --apothecary: #2d4a3e;
    --stamp: #a83217;
    --slate: #2a3b47;
    --slate-soft: #5a6b78;
    --f-display: "Fraunces", Georgia, serif;
    --f-sans: "Instrument Sans", system-ui, sans-serif;
    --f-mono: "JetBrains Mono", ui-monospace, monospace;
  }
  * { box-sizing: border-box; margin: 0; padding: 0; }
  html, body {
    background: var(--paper);
    color: var(--ink);
    font-family: var(--f-sans);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
  }
  body {
    min-height: 100vh;
    position: relative;
  }
  body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 1;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0.09 0 0 0 0 0.08 0 0 0 0 0.06 0 0 0 0.35 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    opacity: 0.08;
    mix-blend-mode: multiply;
  }
  #app { position: relative; z-index: 2; max-width: 1360px; margin: 0 auto; padding: 0 40px; }
  @media (max-width: 640px) { #app { padding: 0 20px; } }
  button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; }
  a { color: var(--rx-deep); }
  ::selection { background: var(--rx); color: var(--paper); }

  /* Header */
  .rule { border-top: 1px solid rgba(20,17,13,0.35); }
  .rule-thick { border-top: 2px solid var(--ink); }
  .rule-double { border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink); height: 4px; }
  header { padding: 24px 0 32px; }
  .topstrip { display: flex; justify-content: space-between; align-items: center; padding: 10px 0; font-family: var(--f-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.22em; color: var(--ink-soft); }

  /* Drawer primary source callout — lives inside each carrier/adjudicator record, not above the tool */
  .drawer-source-cta {
    margin: 0 0 22px;
    padding: 14px 16px;
    border: 1.5px solid rgba(20,17,13,0.38);
    background: linear-gradient(90deg, rgba(45,74,62,0.10), rgba(199,58,15,0.05));
    box-shadow: 3px 3px 0 rgba(20,17,13,0.10);
  }
  .drawer-source-cta-head {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: flex-start;
    margin-bottom: 10px;
  }
  .drawer-source-kicker {
    font-family: var(--f-mono);
    font-size: 9.5px;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--apothecary);
    font-weight: 700;
  }
  .drawer-source-title {
    font-family: var(--f-display);
    font-size: 16px;
    line-height: 1.3;
    color: var(--ink);
    margin-top: 2px;
  }
  .drawer-source-note {
    font-family: var(--f-display);
    font-style: italic;
    font-size: 12.5px;
    line-height: 1.38;
    color: var(--ink-soft);
    margin-top: 3px;
  }
  .drawer-source-links {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
  }
  .drawer-source-links a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 7px 10px;
    border: 1.5px solid rgba(45,74,62,0.45);
    background: rgba(250,247,239,0.84);
    color: var(--apothecary);
    text-decoration: none;
    font-family: var(--f-mono);
    font-size: 9.5px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    white-space: nowrap;
    transition: background 0.15s, color 0.15s, border-color 0.15s, transform 0.15s;
  }
  .drawer-source-links a:hover {
    background: var(--ink);
    border-color: var(--ink);
    color: var(--paper);
    transform: translate(-1px, -1px);
  }
  .drawer-source-links a.secondary {
    color: var(--slate);
    border-color: rgba(42,59,71,0.35);
  }
  @media (max-width: 640px) {
    .drawer-source-cta-head { flex-direction: column; }
    .drawer-source-links a { flex: 1 1 auto; white-space: normal; text-align: center; }
  }

  .wordmark-wrap { padding: 36px 0 20px; text-align: center; }
  .wordmark { display: inline-flex; align-items: baseline; gap: 4px; }
  .wordmark h1 {
    font-family: var(--f-display);
    font-weight: 300;
    line-height: 0.85;
    letter-spacing: -0.035em;
    font-size: clamp(3.5rem, 11vw, 9.5rem);
    font-variation-settings: "SOFT" 40, "opsz" 144;
  }
  .wordmark h1 .r { font-style: italic; color: var(--rx); }
  .wordmark .tld {
    font-family: var(--f-mono);
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.28em;
    transform: translateY(-0.3em);
    color: var(--ink-soft);
  }
  .tagline {
    font-family: var(--f-display);
    text-align: center;
    font-size: clamp(1.1rem, 2vw, 1.5rem);
    max-width: 760px;
    margin: 0 auto;
    line-height: 1.4;
    color: var(--ink-2);
    font-weight: 400;
  }
  .tagline span { color: var(--rx-deep); font-style: italic; }
  .stats { display: grid; grid-template-columns: repeat(4, 1fr); max-width: 760px; margin: 36px auto 0; font-family: var(--f-mono); font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em; border-top: 1px solid rgba(20,17,13,0.3); border-bottom: 1px solid rgba(20,17,13,0.3); }
  .stat { text-align: center; padding: 14px 0; }
  .stat + .stat { border-left: 1px solid rgba(20,17,13,0.3); }
  .stat-num { font-family: var(--f-display); font-size: clamp(1.5rem, 2.6vw, 2.1rem); line-height: 1; font-weight: 400; }
  .stat-label { margin-top: 6px; font-size: 9px; color: var(--ink-soft); letter-spacing: 0.12em; }


  .homepage-context {
    max-width: 920px;
    margin: 28px auto 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
  }
  .homepage-context-card {
    border: 1px solid rgba(20,17,13,0.24);
    background: rgba(255,255,255,0.35);
    padding: 14px 16px;
    text-align: left;
  }
  .homepage-context-card b {
    display: block;
    font-family: var(--f-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--apothecary);
    margin-bottom: 6px;
  }
  .homepage-context-card span {
    display: block;
    font-family: var(--f-display);
    font-size: 14px;
    line-height: 1.45;
    color: var(--ink-2);
  }
  .homepage-context-links {
    max-width: 920px;
    margin: 10px auto 0;
    text-align: center;
    font-family: var(--f-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
  }
  .homepage-context-links a { color: var(--ink-soft); text-decoration: none; margin: 0 8px; }
  .homepage-context-links a:hover { color: var(--rx); text-decoration: underline; }
  @media (max-width: 820px) { .homepage-context { grid-template-columns: 1fr; } }

  /* Section nav */
  .section-nav {
    margin-top: 36px;
    border-top: 1.5px solid var(--ink);
    border-bottom: 1.5px solid var(--ink);
    display: flex;
    overflow-x: auto;
    background: var(--paper);
  }
  .section-nav button {
    padding: 16px 26px;
    font-family: var(--f-display);
    font-size: 18px;
    font-weight: 400;
    border-right: 1px solid rgba(20,17,13,0.3);
    white-space: nowrap;
    transition: background 0.15s, color 0.15s;
    flex-shrink: 0;
    color: var(--ink-2);
  }
  .section-nav button:last-child { border-right: none; }
  .section-nav button:hover { background: var(--paper-2); color: var(--ink); }
  .section-nav button.active { background: var(--ink); color: var(--paper); }
  .section-nav button .num { font-family: var(--f-mono); font-size: 9px; color: var(--ink-soft); margin-right: 8px; letter-spacing: 0.08em; font-weight: 500; }
  .section-nav button.active .num { color: rgba(250,247,239,0.55); }
  @media (max-width: 640px) { .section-nav button { padding: 13px 16px; font-size: 15px; } }

  /* Section header */
  .section-header {
    padding: 44px 0 24px;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
  }
  .section-header h2 {
    font-family: var(--f-display);
    font-size: clamp(1.8rem, 4.5vw, 3rem);
    line-height: 1;
    letter-spacing: -0.02em;
    font-weight: 400;
  }
  .section-header h2 em { color: var(--rx); font-style: italic; }
  .section-header .meta {
    font-family: var(--f-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--ink-soft);
  }

  /* Search bar */
  .search-wrap { position: relative; max-width: 760px; margin: 0 0 24px; }
  .search-box { display: flex; align-items: center; border: 1.5px solid var(--ink); background: #fff; transition: border-color 0.2s; }
  .search-box:focus-within { border-color: var(--rx); }
  .search-box svg { margin-left: 16px; color: var(--ink-soft); flex-shrink: 0; }
  .search-box input { flex: 1; background: transparent; border: none; padding: 14px 14px; font-family: var(--f-display); font-size: clamp(15px, 1.8vw, 17px); color: var(--ink); outline: none; }
  .search-box input::placeholder { color: rgba(115, 103, 86, 0.7); font-style: italic; }
  .search-box button.clear { margin-right: 12px; padding: 6px; color: var(--ink); }
  .search-box button.clear:hover { color: var(--rx); }

  /* Category tabs */
  .subtabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    border-top: 1px solid rgba(20,17,13,0.35);
    border-bottom: 1px solid rgba(20,17,13,0.35);
    margin-bottom: 32px;
  }
  .subtabs button {
    padding: 11px 22px;
    font-family: var(--f-display);
    font-size: 15px;
    border-right: 1px solid rgba(20,17,13,0.25);
    transition: background 0.15s, color 0.15s;
    color: var(--ink-2);
  }
  .subtabs button:last-child { border-right: none; }
  .subtabs button:hover { background: var(--paper-2); }
  .subtabs button.active { background: var(--ink); color: var(--paper); }
  .subtabs button sup { font-family: var(--f-mono); font-size: 10px; margin-left: 6px; color: var(--ink-soft); }
  .subtabs button.active sup { color: rgba(250,247,239,0.6); }

  /* Topic filter strip — policy-topic filter (vacation, methadone, etc.) */
  .topic-filter {
    display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
    padding: 10px 0 20px;
    margin-top: -24px; margin-bottom: 20px;
  }
  .topic-filter-label {
    font-family: var(--f-mono); font-size: 10px; text-transform: uppercase;
    letter-spacing: 0.14em; color: var(--ink-soft); margin-right: 4px;
  }
  .topic-filter button {
    padding: 6px 14px;
    font-family: var(--f-display); font-size: 13px;
    background: transparent;
    border: 1px solid rgba(20,17,13,0.3);
    border-radius: 999px;
    color: var(--ink-2);
    cursor: pointer;
    transition: all 0.15s;
  }
  .topic-filter button:hover {
    background: var(--paper-2);
    border-color: var(--apothecary);
  }
  .topic-filter button.active {
    background: var(--apothecary);
    border-color: var(--apothecary);
    color: var(--paper);
  }
  .topic-filter button.topic-clear {
    color: var(--ink-soft);
    border-color: transparent;
    text-decoration: underline;
    font-size: 11px;
    padding: 6px 10px;
  }
  .topic-filter button.topic-clear:hover {
    background: transparent;
    color: var(--rx);
  }

  /* Card grids — simplified, no paper-stack offset */
  .grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 24px; padding-bottom: 40px; }
  .card {
    background: var(--paper); border: 1.5px solid var(--ink); position: relative; padding: 22px 24px;
    text-align: left; display: flex; flex-direction: column; min-height: 240px;
    cursor: pointer; transition: transform 0.18s ease, box-shadow 0.18s ease; font: inherit; color: inherit; width: 100%;
    box-shadow: 0 0 0 rgba(20,17,13,0);
  }
  .card:hover { transform: translate(-2px, -2px); box-shadow: 4px 4px 0 var(--ink); }
  .card-top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 14px; }
  .card-meta { font-family: var(--f-mono); font-size: 9px; text-transform: uppercase; letter-spacing: 0.18em; color: var(--ink-soft); }
  .card-meta .cat { color: var(--rx); margin-top: 3px; font-weight: 500; }
  .card-arrow { color: var(--ink-soft); transition: transform 0.2s, color 0.2s; }
  .card:hover .card-arrow { color: var(--rx); transform: translate(2px, -2px); }
  .card-name { font-family: var(--f-display); font-size: 24px; line-height: 1.1; letter-spacing: -0.01em; margin-bottom: 4px; font-weight: 400; }
  .card-provider { font-size: 12px; color: var(--ink-soft); font-style: italic; margin-bottom: 14px; }
  .card-spacer { flex: 1; }
  .card-divider { border-top: 1px solid rgba(20,17,13,0.25); margin: 14px 0; }
  .card-dl { font-family: var(--f-mono); font-size: 11px; display: flex; flex-direction: column; gap: 5px; }
  .card-dl .row { display: flex; justify-content: space-between; gap: 8px; }
  .card-dl dt { text-transform: uppercase; letter-spacing: 0.05em; color: var(--ink-soft); }
  .card-dl dd { max-width: 60%; text-align: right; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .card-dl .row.primary dd { font-weight: 700; }
  .card-badges { margin-top: 14px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
  .chip { display: inline-flex; align-items: center; gap: 4px; font-family: var(--f-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.05em; }
  .chip.travel { color: var(--apothecary); }
  .chip.notes { color: var(--ink-2); }
  .chip.rej { color: var(--rx-deep); }
  .chip.early { color: var(--ink-2); }
  .chip.contact { color: var(--apothecary); }

  /* Drawer */
  .drawer-backdrop { position: fixed; inset: 0; background: rgba(20,17,13,0.6); backdrop-filter: blur(2px); z-index: 40; opacity: 0; pointer-events: none; transition: opacity 0.3s; }
  .drawer-backdrop.open { opacity: 1; pointer-events: auto; }
  .drawer { position: fixed; top: 0; right: 0; height: 100%; width: 100%; max-width: 720px; background: var(--paper); z-index: 50; overflow-y: auto; border-left: 2px solid var(--ink); transform: translateX(100%); transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1); }
  .drawer.open { transform: translateX(0); }
  .drawer-header { position: sticky; top: 0; z-index: 10; display: flex; justify-content: space-between; align-items: center; padding: 14px 24px; border-bottom: 2px solid var(--ink); background: var(--ink); color: var(--paper); font-family: var(--f-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.2em; }
  .drawer-header button { color: var(--paper); padding: 4px; }
  .drawer-header button:hover { color: var(--rx); }
  .drawer-body { padding: 40px 40px; }
  @media (max-width: 640px) { .drawer-body { padding: 32px 24px; } }
  .drawer-cat { font-family: var(--f-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.22em; color: var(--rx); margin-bottom: 10px; }
  .drawer-name { font-family: var(--f-display); font-size: clamp(1.8rem, 4.5vw, 2.75rem); line-height: 1; letter-spacing: -0.015em; margin-bottom: 12px; font-weight: 400; }
  .drawer-prov { font-family: var(--f-display); font-style: italic; font-size: 17px; color: var(--ink-soft); margin-bottom: 22px; }

  .section { margin-bottom: 38px; }
  .sec-head { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; }
  .sec-head .icon { color: var(--rx); display: inline-flex; font-family: var(--f-mono); font-size: 13px; }
  .sec-head h3 { font-family: var(--f-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.2em; color: var(--ink-2); font-weight: 500; }
  .sec-head .rule-s { flex: 1; border-top: 1px solid rgba(20,17,13,0.3); margin-left: 8px; }

  /* Benefit card preview */
  .benefit { position: relative; padding: 22px; border: 1.5px solid var(--ink); overflow: hidden; background: var(--paper); aspect-ratio: 1.586 / 1; max-width: 420px; }
  .benefit svg.guilloche { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0.05; pointer-events: none; }
  .benefit-inner { position: relative; display: flex; flex-direction: column; height: 100%; justify-content: space-between; }
  .benefit-top { display: flex; justify-content: space-between; align-items: flex-start; }
  .benefit-label { font-family: var(--f-mono); font-size: 9px; text-transform: uppercase; letter-spacing: 0.2em; color: var(--ink-soft); }
  .benefit-name { font-family: var(--f-display); font-size: 19px; line-height: 1.1; margin-top: 4px; padding-right: 16px; }
  .benefit-rx { font-family: var(--f-display); font-size: 22px; font-style: italic; color: var(--rx); }
  .benefit-lines { font-family: var(--f-mono); font-size: 10px; display: flex; flex-direction: column; gap: 5px; }
  .benefit-lines div { display: flex; justify-content: space-between; gap: 8px; }
  .benefit-lines span.k { color: var(--ink-soft); text-transform: uppercase; }
  .benefit-lines span.v { max-width: 60%; text-align: right; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .benefit-lines .primary span.v { font-weight: 700; }

  /* IDs table */
  .ids { font-family: var(--f-mono); font-size: 13px; }
  .ids .row { display: flex; justify-content: space-between; align-items: center; padding: 11px 0; gap: 16px; border-bottom: 1px solid rgba(20,17,13,0.15); }
  .ids dt { color: var(--ink-soft); text-transform: uppercase; font-size: 10px; letter-spacing: 0.05em; }
  .ids dd button { text-align: right; transition: color 0.2s; }
  .ids dd button:hover { color: var(--rx); }

  /* Notes lists */
  .notes-list { list-style: none; display: flex; flex-direction: column; gap: 11px; }
  .notes-list li { display: flex; gap: 14px; color: var(--ink-2); line-height: 1.55; font-size: 14px; }
  .notes-list .num { font-family: var(--f-mono); font-size: 11px; color: var(--rx); margin-top: 4px; flex-shrink: 0; }
  .vsupply { padding: 18px 20px; border: 1px solid rgba(20,17,13,0.3); background: var(--paper-2); }
  .vsupply ul { list-style: none; display: flex; flex-direction: column; gap: 11px; }
  .vsupply li { display: flex; gap: 12px; line-height: 1.55; font-size: 14px; color: var(--ink-2); }
  .vsupply .bullet { color: var(--rx); font-weight: 700; flex-shrink: 0; }

  /* Data tables */
  .data-table { width: 100%; border-collapse: collapse; font-size: 13px; margin: 0 0 16px; }
  .data-table th { text-align: left; padding: 10px 12px 10px 0; font-family: var(--f-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--ink-soft); border-bottom: 1.5px solid var(--ink); font-weight: 500; }
  .data-table td { padding: 11px 12px 11px 0; border-bottom: 1px solid rgba(20,17,13,0.12); line-height: 1.5; vertical-align: top; color: var(--ink-2); }
  .data-table td.mono { font-family: var(--f-mono); font-size: 12px; white-space: nowrap; padding-right: 10px; }
  .data-table tr:last-child td { border-bottom: none; }
  .data-table .code {
    display: inline-block; font-family: var(--f-mono); font-size: 11px; font-weight: 700;
    color: var(--rx); background: rgba(199,58,15,0.08); padding: 3px 7px; border: 1px solid rgba(199,58,15,0.25); letter-spacing: 0.05em;
    white-space: normal; line-height: 1.35; max-width: 100px;
  }

  /* Comments feature disabled for v1 launch */
  .comments-slot { display: none !important; }

  /* Jurisdiction banner — prominent notice at top of carrier drawer */
  .jurisdiction-banner {
    margin: 0 0 24px;
    padding: 14px 18px;
    background: rgba(199,58,15,0.06);
    border: 1px solid rgba(199,58,15,0.25);
    border-left: 4px solid var(--rx);
  }
  .jurisdiction-banner-label {
    font-family: var(--f-mono); font-size: 10px; text-transform: uppercase;
    letter-spacing: 0.14em; color: var(--rx); font-weight: 700; margin-bottom: 6px;
  }
  .jurisdiction-banner-text {
    font-family: var(--f-serif); font-size: 13.5px; line-height: 1.55; color: var(--ink-2);
  }

  .search-inline {
    width: 100%; border: none; border-bottom: 1.5px solid var(--ink); background: transparent;
    padding: 10px 0; font-family: var(--f-display); font-style: italic; font-size: 16px;
    outline: none; margin-bottom: 16px;
  }
  .search-inline:focus { border-bottom-color: var(--rx); }

  /* Contact pill */
  .contact-block { display: grid; gap: 8px; }
  .contact-row { display: flex; align-items: baseline; gap: 12px; padding: 10px 14px; background: var(--paper-2); border-left: 3px solid var(--apothecary); }
  .contact-row .phone { font-family: var(--f-mono); font-size: 14px; font-weight: 700; color: var(--ink); }
  .contact-row .note { font-family: var(--f-display); font-style: italic; font-size: 13px; color: var(--ink-soft); }
  .contact-row .email { font-family: var(--f-mono); font-size: 11px; color: var(--ink-soft); }

  /* Early refill block */
  .early-block { padding: 16px 20px; background: var(--paper-2); border-left: 3px solid var(--rx); }
  .early-block .summary { font-family: var(--f-display); font-size: 19px; font-style: italic; color: var(--ink); margin-bottom: 10px; line-height: 1.3; }
  .early-block ul { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: var(--ink-2); line-height: 1.5; }
  .early-block ul li::before { content: "· "; color: var(--rx); }

  /* Source pills */
  .src-pill {
    display: inline-block; font-family: var(--f-mono); font-size: 9px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.08em; padding: 2px 7px; margin-left: 4px;
    border: 1px solid currentColor; vertical-align: 1px; cursor: pointer; white-space: nowrap;
    transition: background 0.15s;
  }
  .src-pill:hover { background: currentColor; color: var(--paper) !important; }
  .src-pill.src-internal { color: var(--rx-deep); background: rgba(199,58,15,0.06); }
  .src-pill.src-doc { color: var(--apothecary); background: rgba(45,74,62,0.06); }
  .src-pill.src-carrier-rep { color: var(--slate); background: rgba(42,59,71,0.06); }
  .src-pill.src-community { color: #7a5a1a; background: rgba(122,90,26,0.06); }

  .src-list { display: flex; flex-direction: column; gap: 13px; }
  .src-row { display: grid; grid-template-columns: 140px 1fr; gap: 16px; padding-bottom: 13px; border-bottom: 1px solid rgba(20,17,13,0.12); }
  .src-row:last-child { border-bottom: none; padding-bottom: 0; }
  .src-row dt { display: flex; flex-direction: column; align-items: flex-start; gap: 6px; }
  .src-type { font-family: var(--f-mono); font-size: 9px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-soft); }
  .src-row dd { font-size: 14px; color: var(--ink-2); line-height: 1.5; }
  .src-note { margin-top: 6px; font-family: var(--f-display); font-style: italic; font-size: 13px; color: var(--ink-soft); }
  @media (max-width: 640px) { .src-row { grid-template-columns: 1fr; gap: 6px; } }

  /* Province grids */
  .prov-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 1.5px; background: var(--ink); border: 1px solid var(--ink); }
  .prov-cell {
    padding: 13px 16px; background: var(--paper); transition: background 0.15s;
  }
  .prov-cell a { display: block; text-decoration: none; color: var(--ink); }
  .prov-cell .name { font-family: var(--f-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-soft); margin-bottom: 4px; }
  .prov-cell .link { font-family: var(--f-display); font-size: 14px; font-style: italic; }
  .prov-cell:hover { background: var(--paper-2); }
  .prov-cell.none { color: var(--ink-soft); font-style: italic; font-size: 12px; }

  /* Audit panel */
  .audit-band { font-family: var(--f-display); font-size: 22px; margin: 36px 0 6px; font-weight: 400; padding-bottom: 6px; border-bottom: 1.5px solid currentColor; }
  .audit-band.audit-a { color: var(--apothecary); }
  .audit-band.audit-b { color: #a06a00; }
  .audit-band.audit-c { color: var(--rx-deep); }
  .audit-band.audit-d { color: var(--slate); }
  .audit-desc { font-size: 13px; color: var(--ink-2); margin-bottom: 14px; max-width: 780px; line-height: 1.5; }
  .audit-table { margin-bottom: 20px; }
  .audit-warn { margin-top: 36px; padding: 20px 24px; background: var(--paper-2); border: 1.5px solid var(--ink); border-left: 4px solid var(--rx); font-family: var(--f-display); font-size: 15px; font-style: italic; color: var(--ink-2); line-height: 1.55; }
  .audit-warn strong { color: var(--ink); font-style: normal; }
  /* Sticky disclaimer strip in footer */
  .legal-strip {
    margin-top: 32px;
    padding: 20px 24px;
    background: var(--ink);
    color: var(--paper);
    border-left: 4px solid var(--rx);
  }
  .legal-strip strong { color: var(--rx); }
  .legal-strip p { font-family: var(--f-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; line-height: 1.6; }

  /* Footer */
  footer { margin-top: 80px; padding: 40px 0; border-top: 3px solid var(--ink); }
  .foot-top { display: flex; flex-direction: column; gap: 32px; justify-content: space-between; align-items: flex-start; }
  @media (min-width: 768px) { .foot-top { flex-direction: row; } }
  .foot-mark { font-family: var(--f-display); font-size: 40px; line-height: 1; }
  .foot-mark .r { font-style: italic; color: var(--rx); }
  .foot-tag { margin-top: 12px; font-family: var(--f-display); font-style: italic; color: var(--ink-soft); max-width: 360px; }
  .foot-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; font-family: var(--f-mono); font-size: 12px; text-transform: uppercase; letter-spacing: 0.05em; }
  .foot-cols h4 { color: var(--ink-soft); margin-bottom: 12px; font-weight: 500; }
  .foot-cols ul { list-style: none; display: flex; flex-direction: column; gap: 8px; }
  .foot-cols a { color: var(--ink); text-decoration: none; }
  .foot-cols a:hover { color: var(--rx); }
  .foot-bottom { margin-top: 40px; display: flex; flex-direction: column; justify-content: space-between; gap: 8px; font-family: var(--f-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.2em; color: var(--ink-soft); }
  @media (min-width: 768px) { .foot-bottom { flex-direction: row; } }

  /* Date pills — "last verified" indicator shown on section headers */
  .date-pill {
    display: inline-block;
    font-family: var(--f-mono);
    font-size: 9px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--ink-soft);
    background: rgba(0,0,0,0.04);
    padding: 3px 8px;
    border: 1px solid rgba(0,0,0,0.1);
    border-radius: 2px;
    vertical-align: middle;
    cursor: help;
    white-space: nowrap;
  }
  .date-pill::before { content: "§ "; opacity: 0.6; }


  /* Inline editorial explainers — homepage content depth without changing the tool workflow */
  .editorial-brief {
    max-width: 980px;
    margin: 0 0 24px;
    padding: 18px 22px 20px;
    background: rgba(45,74,62,0.045);
    border: 1px solid rgba(20,17,13,0.18);
    border-left: 4px solid var(--apothecary);
    box-shadow: 0 1px 0 rgba(20,17,13,0.06);
  }
  .editorial-brief.rx { border-left-color: var(--rx); background: rgba(199,58,15,0.045); }
  .editorial-brief.slate { border-left-color: var(--slate); background: rgba(42,59,71,0.045); }
  .editorial-kicker {
    font-family: var(--f-mono);
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--ink-soft);
    margin-bottom: 7px;
  }
  .editorial-brief h3 {
    font-family: var(--f-display);
    font-size: clamp(18px, 2.2vw, 23px);
    line-height: 1.15;
    font-weight: 400;
    letter-spacing: -0.01em;
    margin-bottom: 8px;
  }
  .editorial-brief h3 em { color: var(--rx); font-style: italic; }
  .editorial-brief p {
    font-family: var(--f-display);
    font-size: 14.5px;
    line-height: 1.6;
    color: var(--ink-2);
    max-width: 880px;
    margin: 0 0 10px;
  }
  .editorial-brief ul {
    list-style: none;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 8px 18px;
    margin: 12px 0 0;
    padding: 0;
  }
  .editorial-brief li {
    position: relative;
    padding-left: 16px;
    font-size: 13px;
    line-height: 1.55;
    color: var(--ink-2);
  }
  .editorial-brief li::before {
    content: "✦";
    position: absolute;
    left: 0;
    top: 1px;
    color: var(--rx);
    font-size: 10px;
  }
  @media (max-width: 640px) {
    .editorial-brief { padding: 15px 16px 17px; margin-bottom: 18px; }
    .editorial-brief ul { grid-template-columns: 1fr; }
  }

  /* Community comments system */
  .workflows-list { display: flex; flex-direction: column; gap: 20px; margin-top: 8px; }
  .workflow-entry { padding: 16px 20px; background: rgba(45,74,62,0.04); border-left: 3px solid var(--apothecary); }
  .workflow-title { font-family: var(--f-serif); font-size: 15px; font-weight: 600; color: var(--ink); margin: 0 0 8px 0; line-height: 1.4; letter-spacing: -0.005em; }
  .workflow-text { font-family: var(--f-serif); font-size: 13.5px; line-height: 1.6; color: var(--ink-2); margin: 0; }
  .workflow-text p { margin: 0 0 10px; }
  .workflow-text p:last-child { margin-bottom: 0; }
  .workflow-text strong { color: var(--apothecary); font-weight: 600; }
  .workflow-text ul.wf-bullets { list-style: none; padding: 0; margin: 0 0 10px; }
  .workflow-text ul.wf-bullets:last-child { margin-bottom: 0; }
  .workflow-text ul.wf-bullets li { position: relative; padding: 3px 0 3px 18px; font-size: 13.5px; line-height: 1.55; }
  .workflow-text ul.wf-bullets li::before { content: "▸"; position: absolute; left: 2px; top: 3px; color: var(--apothecary); font-size: 11px; }

  .card-location, .card-notes { margin-top: 14px; padding: 12px 16px; background: rgba(45,74,62,0.05); border-left: 3px solid var(--apothecary); }
  .card-location-label, .card-notes-label { font-family: var(--f-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--apothecary); margin-bottom: 6px; font-weight: 600; }
  .card-location-body, .card-notes-body { font-family: var(--f-serif); font-size: 13px; line-height: 1.55; color: var(--ink-2); }
  .card-notes { border-left-color: var(--rx-deep); }
  .card-notes-label { color: var(--rx-deep); }

  /* Critical warning — attention-grabbing red */
  .card-warning { margin-top: 14px; padding: 14px 18px; background: rgba(180,60,40,0.08); border-left: 4px solid #b43c28; border-right: 1px solid rgba(180,60,40,0.2); border-top: 1px solid rgba(180,60,40,0.2); border-bottom: 1px solid rgba(180,60,40,0.2); position: relative; }
  .card-warning-label { font-family: var(--f-mono); font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.14em; color: #b43c28; margin-bottom: 6px; font-weight: 700; }
  .card-warning-body { font-family: var(--f-serif); font-size: 14px; line-height: 1.55; color: #7a2a1c; font-weight: 500; }

  /* Benefit card preview image */
  .card-preview { margin-bottom: 18px; }
  .card-preview img { display: block; max-width: 100%; width: auto; max-height: 260px; border: 1px solid rgba(45,74,62,0.15); background: #fff; padding: 4px; box-shadow: 0 4px 18px rgba(45,74,62,0.15), 0 1px 3px rgba(0,0,0,0.08); border-radius: 2px; }
  .card-preview-label { font-family: var(--f-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--ink-soft); margin-top: 8px; font-style: italic; }

  /* Plan-entry card preview (smaller) */
  .plan-card-preview { margin: 10px 0 6px; }
  .plan-card-preview img { display: block; max-width: 100%; width: auto; max-height: 180px; border: 1px solid rgba(45,74,62,0.15); background: #fff; padding: 3px; box-shadow: 0 3px 12px rgba(45,74,62,0.12), 0 1px 2px rgba(0,0,0,0.06); border-radius: 2px; }
  .plan-warning { margin-top: 8px; padding: 10px 14px; background: rgba(180,60,40,0.08); border-left: 3px solid #b43c28; font-family: var(--f-serif); font-size: 13px; line-height: 1.5; color: #7a2a1c; }
  .plan-warning strong { font-family: var(--f-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: 0.12em; color: #b43c28; font-weight: 700; display: inline; margin-right: 4px; }

  .card-plans { margin-top: 4px; margin-bottom: 12px; }
  .card-plans-label { font-family: var(--f-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-soft); margin-bottom: 5px; }
  .card-plans-chips { display: flex; flex-wrap: wrap; gap: 4px; }
  .plan-chip { display: inline-block; padding: 3px 8px; background: rgba(45,74,62,0.08); color: var(--ink-2); font-family: var(--f-serif); font-size: 11px; line-height: 1.3; border-radius: 2px; }

  .plans-list { display: flex; flex-direction: column; gap: 12px; }
  .plan-row { display: flex; justify-content: space-between; align-items: baseline; padding: 10px 14px; background: rgba(45,74,62,0.04); border-left: 2px solid var(--apothecary); }
  .plan-entry { padding: 14px 18px; background: rgba(45,74,62,0.04); border-left: 3px solid var(--apothecary); }
  .plan-header { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 8px; gap: 16px; }
  .plan-name { font-family: var(--f-serif); font-size: 15px; font-weight: 600; color: var(--ink); }
  .plan-carrierid { font-family: var(--f-mono); font-size: 10.5px; color: var(--apothecary); letter-spacing: 0.06em; text-transform: uppercase; white-space: nowrap; font-weight: 600; }
  .plan-ids { display: flex; flex-wrap: wrap; gap: 18px; margin: 8px 0 6px; }
  .plan-ids div { display: flex; align-items: baseline; gap: 8px; }
  .plan-ids dt { font-family: var(--f-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-soft); }
  .plan-ids dd { margin: 0; }
  .plan-ids button { font-family: var(--f-mono); font-size: 12px; color: var(--ink); background: var(--paper); border: 1px solid rgba(45,74,62,0.15); padding: 3px 8px; cursor: pointer; letter-spacing: 0.02em; }
  .plan-ids button:hover { background: rgba(45,74,62,0.08); }
  .plan-where { font-family: var(--f-serif); font-size: 12.5px; line-height: 1.55; color: var(--ink-2); margin-top: 6px; }
  .plan-where strong { font-family: var(--f-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--apothecary); font-weight: 600; display: block; margin-bottom: 2px; }
  .plan-note { font-family: var(--f-serif); font-size: 12.5px; line-height: 1.55; color: var(--ink-2); font-style: italic; margin-top: 6px; padding-top: 6px; border-top: 1px dotted rgba(45,74,62,0.15); }

  .ont-dir-list { display: flex; flex-direction: column; gap: 8px; }
  .ont-dir-row { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; background: rgba(45,74,62,0.03); border-left: 3px solid var(--apothecary); text-decoration: none; color: inherit; transition: background 0.15s ease, border-color 0.15s ease; }
  .ont-dir-row:hover { background: rgba(45,74,62,0.08); border-left-color: var(--rx-deep); }
  .ont-dir-left { flex: 1; min-width: 0; }
  .ont-dir-prof { font-family: var(--f-serif); font-size: 16px; font-weight: 600; color: var(--ink); letter-spacing: -0.005em; margin-bottom: 2px; }
  .ont-dir-college { font-family: var(--f-mono); font-size: 10.5px; color: var(--ink-soft); letter-spacing: 0.02em; text-transform: uppercase; }
  .ont-dir-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; margin-left: 24px; }
  .ont-dir-label { font-family: var(--f-display); font-style: italic; font-size: 14px; color: var(--apothecary); text-align: right; }
  .ont-dir-arrow { font-family: var(--f-display); font-size: 18px; color: var(--apothecary); }
  @media (max-width: 680px) {
    .ont-dir-row { flex-direction: column; align-items: flex-start; gap: 10px; }
    .ont-dir-right { margin-left: 0; }
    .ont-dir-label { text-align: left; }
  }

  .comments-wrap {
    margin-top: 32px;
    padding: 20px 22px 22px;
    background: rgba(0,0,0,0.02);
    border: 1px dashed rgba(0,0,0,0.15);
    border-radius: 2px;
  }
  .comments-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid rgba(0,0,0,0.08);
  }
  .comments-title {
    font-family: var(--f-display);
    font-style: italic;
    font-size: 15px;
    color: var(--ink);
  }
  .comments-count {
    display: inline-block;
    font-family: var(--f-mono);
    font-size: 10px;
    background: var(--ink);
    color: var(--paper);
    padding: 2px 7px;
    border-radius: 10px;
    margin-left: 6px;
    vertical-align: middle;
  }
  .comments-hidden-note {
    font-family: var(--f-mono);
    font-size: 10px;
    color: var(--ink-soft);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-style: italic;
  }
  .comments-compose {
    margin-bottom: 16px;
  }
  .comments-input {
    width: 100%;
    padding: 10px 12px;
    font-family: var(--f-body);
    font-size: 13px;
    line-height: 1.5;
    color: var(--ink);
    background: var(--paper);
    border: 1.5px solid rgba(0,0,0,0.15);
    border-radius: 2px;
    resize: vertical;
    min-height: 44px;
    box-sizing: border-box;
  }
  .comments-input:focus {
    outline: none;
    border-color: var(--rx);
  }
  .comments-compose-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 8px;
    flex-wrap: wrap;
  }
  .comments-legal {
    font-family: var(--f-mono);
    font-size: 9px;
    color: var(--ink-soft);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-style: italic;
    flex: 1;
    min-width: 180px;
  }
  .comments-submit {
    font-family: var(--f-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--paper);
    background: var(--ink);
    border: 1.5px solid var(--ink);
    padding: 8px 16px;
    cursor: pointer;
    transition: all 0.15s;
  }
  .comments-submit:hover { background: var(--rx); border-color: var(--rx); }
  .comments-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  .comments-empty {
    font-family: var(--f-display);
    font-style: italic;
    font-size: 13px;
    color: var(--ink-soft);
    padding: 16px 0;
    text-align: center;
  }
  .comments-backend-note {
    margin-top: 16px;
    padding: 10px 12px;
    background: rgba(199, 58, 15, 0.06);
    border-left: 3px solid var(--rx);
    font-family: var(--f-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--ink-2);
    line-height: 1.6;
  }
  .comment {
    display: flex;
    gap: 12px;
    padding: 12px 14px;
    background: var(--paper);
    border: 1px solid rgba(0,0,0,0.08);
    border-radius: 2px;
  }
  .comment-votes {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    flex-shrink: 0;
    width: 32px;
  }
  .comment-vote {
    width: 26px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    color: var(--ink-soft);
    background: transparent;
    border: 1px solid rgba(0,0,0,0.1);
    cursor: pointer;
    border-radius: 2px;
    transition: all 0.12s;
  }
  .comment-vote:hover { color: var(--ink); border-color: var(--ink); }
  .comment-vote.active { color: var(--paper); background: var(--rx); border-color: var(--rx); }
  .comment-score {
    font-family: var(--f-mono);
    font-size: 11px;
    font-weight: 600;
    color: var(--ink-soft);
    min-height: 14px;
  }
  .comment-score.pos { color: #1e5f3f; }
  .comment-score.neg { color: var(--rx); }
  .comment-body { flex: 1; min-width: 0; }
  .comment-text {
    font-size: 13px;
    line-height: 1.55;
    color: var(--ink);
    word-wrap: break-word;
    white-space: pre-wrap;
  }
  .comment-meta {
    margin-top: 6px;
    font-family: var(--f-mono);
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--ink-soft);
  }

  /* Codes panel — carrier badges */
  .code-badge {
    display: inline-block;
    font-family: var(--f-mono);
    font-size: 9px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 3px 8px;
    margin: 2px 4px 2px 0;
    border: 1.5px solid currentColor;
    white-space: nowrap;
    cursor: default;
  }
  .code-badge.odb { color: #555050; background: rgba(85, 80, 80, 0.08); }
  .code-badge.gsc { color: #1e5f3f; background: rgba(30, 95, 63, 0.08); }
  .code-badge.esi { color: var(--rx); background: rgba(199, 58, 15, 0.08); }
  .code-badge.telus { color: #a06a00; background: rgba(160, 106, 0, 0.08); }
  .code-badge.mbc { color: #1a4d80; background: rgba(26, 77, 128, 0.08); }
  .code-badge.nihb { color: #5d2e8c; }
  .code-badge.csec { color: #0e6b6d; }
  .code-badge.medav { color: #800020; }
  .code-badge.big5-filter { cursor: pointer; transition: background 0.15s; }
  .code-badge.big5-filter:hover { background: currentColor; color: var(--paper) !important; }
  .code-badge.big5-filter.active { background: currentColor; color: var(--paper) !important; }

  .code-filter-bar {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    padding: 14px 0;
    margin-bottom: 12px;
    border-top: 1px solid rgba(24,20,16,0.2);
    border-bottom: 1px solid rgba(24,20,16,0.2);
    font-family: var(--f-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--ink-soft);
  }
  .code-filter-bar .label { margin-right: 4px; }
  .code-filter-bar .clear-filter { margin-left: auto; text-decoration: underline; cursor: pointer; color: var(--rx-deep); }

  /* Allowed-codes chip grid (carrier drawer) */
  .allow-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
  .allow-chip {
    font-family: var(--f-mono);
    font-size: 12px;
    font-weight: 700;
    padding: 6px 10px;
    border: 1.5px solid currentColor;
    letter-spacing: 0.04em;
    background: rgba(0,0,0,0.02);
  }
  .allow-chip.odb { color: #555050; background: rgba(85,80,80,0.08); }
  .allow-chip.gsc { color: #1e5f3f; background: rgba(30,95,63,0.08); }
  .allow-chip.esi { color: var(--rx); background: rgba(199,58,15,0.08); }
  .allow-chip.telus { color: #a06a00; background: rgba(160,106,0,0.08); }
  .allow-chip.mbc { color: #1a4d80; background: rgba(26,77,128,0.08); }
  .allow-chip.nihb { color: #5d2e8c; background: rgba(93,46,140,0.08); }
  .allow-chip.csec { color: #0e6b6d; background: rgba(14,107,109,0.08); }
  .allow-chip.medav { color: #800020; background: rgba(128,0,32,0.08); }
  .code-badge.nihb { color: #5d2e8c; background: rgba(93,46,140,0.08); border-color: #5d2e8c; }
  .code-badge.csec { color: #0e6b6d; background: rgba(14,107,109,0.08); border-color: #0e6b6d; }
  .code-badge.medav { color: #800020; background: rgba(128,0,32,0.08); border-color: #800020; }
  .allow-chip sup { font-size: 9px; margin-left: 1px; }
  .allow-note { font-family: var(--f-display); font-style: italic; font-size: 13px; color: var(--ink-soft); margin-top: 6px; line-height: 1.4; }

  /* Vacation supply calculator */
  .vcalc-wrap {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
    max-width: 980px;
    margin: 0 auto 40px;
    padding: 28px;
    background: var(--paper-2);
    border: 2px solid var(--ink);
    box-shadow: 8px 8px 0 var(--ink);
  }
  @media (max-width: 780px) { .vcalc-wrap { grid-template-columns: 1fr; } }
  .vcalc-title { font-family: var(--f-display); font-size: 28px; line-height: 1; letter-spacing: -0.01em; margin-bottom: 4px; }
  .vcalc-title em { color: var(--rx); font-style: italic; }
  .vcalc-sub { font-family: var(--f-display); font-style: italic; font-size: 14px; color: var(--ink-soft); margin-bottom: 20px; }
  .vcalc-field { display: flex; flex-direction: column; gap: 4px; margin-bottom: 14px; }
  .vcalc-field label { font-family: var(--f-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-soft); }
  .vcalc-field input { padding: 10px 12px; border: 1.5px solid var(--ink); background: var(--paper); font-family: var(--f-mono); font-size: 14px; font-weight: 500; color: var(--ink); outline: none; }
  .vcalc-field input:focus { border-color: var(--rx); }
  .vcalc-results { margin-top: 18px; padding: 16px 18px; background: var(--paper); border: 1.5px solid var(--ink); }
  .vcalc-row { display: flex; justify-content: space-between; align-items: baseline; padding: 6px 0; border-bottom: 1px dotted rgba(24,20,16,0.2); font-family: var(--f-mono); font-size: 12px; }
  .vcalc-row:last-child { border-bottom: none; }
  .vcalc-row .k { color: var(--ink-soft); text-transform: uppercase; letter-spacing: 0.05em; font-size: 10px; }
  .vcalc-row .v { font-weight: 700; color: var(--ink); }
  .vcalc-verdict { margin-top: 14px; padding: 14px 16px; font-family: var(--f-display); font-size: 17px; line-height: 1.35; border-left: 4px solid var(--rx); background: rgba(199,58,15,0.06); }
  .vcalc-verdict.ok { border-left-color: var(--apothecary); background: rgba(45,74,62,0.06); }
  .vcalc-verdict.warn { border-left-color: #a06a00; background: rgba(160,106,0,0.08); }
  .vcalc-verdict strong { font-style: normal; color: var(--rx-deep); }
  .vcalc-verdict.ok strong { color: var(--apothecary); }
  .vcalc-verdict.warn strong { color: #8a5600; }

  /* Calendar */
  .vcal-month { margin-bottom: 16px; }
  .vcal-month h4 { font-family: var(--f-display); font-size: 16px; font-style: italic; text-align: center; margin-bottom: 8px; color: var(--ink-2); }
  .vcal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; background: rgba(24,20,16,0.15); padding: 1px; }
  .vcal-dow { background: var(--paper-2); text-align: center; padding: 4px 0; font-family: var(--f-mono); font-size: 9px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-soft); }
  .vcal-day { background: var(--paper); aspect-ratio: 1; display: flex; align-items: center; justify-content: center; font-family: var(--f-mono); font-size: 11px; color: var(--ink-2); position: relative; }
  .vcal-day.empty { background: transparent; }
  .vcal-day.today { outline: 2px solid var(--ink); outline-offset: -2px; font-weight: 700; }
  .vcal-day.trip { background: rgba(199,58,15,0.18); color: var(--rx-deep); font-weight: 700; }
  .vcal-day.trip-start, .vcal-day.trip-end { background: var(--rx); color: var(--paper); font-weight: 700; }
  .vcal-day.supply-end { background: rgba(160,106,0,0.25); color: #5c3e00; font-weight: 700; outline: 1.5px dashed #8a5600; outline-offset: -3px; }
  .vcal-legend { display: flex; gap: 14px; flex-wrap: wrap; font-family: var(--f-mono); font-size: 9px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-soft); margin-top: 10px; }
  .vcal-legend .swatch { display: inline-block; width: 10px; height: 10px; margin-right: 4px; vertical-align: middle; border: 1px solid rgba(24,20,16,0.3); }



  /* Editorial guides — original long-form content for readers and publication review */
  .guides-hero {
    max-width: 980px;
    padding: 28px 32px;
    margin: 0 0 32px;
    background: var(--paper-2);
    border: 2px solid var(--ink);
    box-shadow: 8px 8px 0 var(--apothecary);
  }
  .guides-hero p {
    font-family: var(--f-display);
    font-size: clamp(17px, 2vw, 21px);
    line-height: 1.55;
    color: var(--ink-2);
    margin-bottom: 14px;
  }
  .guides-hero p:last-child { margin-bottom: 0; }
  .guide-index {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 14px;
    margin: 0 0 38px;
  }
  .guide-index a {
    display: block;
    min-height: 120px;
    padding: 18px 20px;
    border: 1.5px solid rgba(20,17,13,0.28);
    background: var(--paper);
    color: var(--ink);
    text-decoration: none;
    transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
  }
  .guide-index a:hover {
    transform: translate(-2px, -2px);
    box-shadow: 4px 4px 0 var(--ink);
    border-color: var(--ink);
  }
  .guide-index .k {
    display: block;
    font-family: var(--f-mono);
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--rx);
    margin-bottom: 8px;
  }
  .guide-index .t {
    display: block;
    font-family: var(--f-display);
    font-size: 19px;
    line-height: 1.15;
  }
  .guide-article {
    max-width: 920px;
    padding: 34px 0 42px;
    border-top: 2px solid var(--ink);
  }
  .guide-kicker {
    font-family: var(--f-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--rx);
    margin-bottom: 10px;
  }
  .guide-article h3 {
    font-family: var(--f-display);
    font-size: clamp(1.7rem, 3.6vw, 2.6rem);
    line-height: 1.05;
    letter-spacing: -0.02em;
    font-weight: 400;
    margin-bottom: 16px;
  }
  .guide-article h4 {
    font-family: var(--f-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--apothecary);
    margin: 26px 0 10px;
  }
  .guide-article p {
    font-family: var(--f-display);
    font-size: 16px;
    line-height: 1.72;
    color: var(--ink-2);
    margin-bottom: 16px;
  }
  .guide-article strong { color: var(--ink); }
  .guide-callout {
    margin: 22px 0;
    padding: 18px 22px;
    background: rgba(45,74,62,0.07);
    border-left: 4px solid var(--apothecary);
    font-family: var(--f-display);
    font-size: 15px;
    line-height: 1.65;
    color: var(--ink-2);
  }
  .guide-warning {
    margin: 22px 0;
    padding: 18px 22px;
    background: rgba(199,58,15,0.07);
    border-left: 4px solid var(--rx);
    font-family: var(--f-display);
    font-size: 15px;
    line-height: 1.65;
    color: var(--ink-2);
  }
  .guide-list {
    display: grid;
    gap: 10px;
    margin: 16px 0 22px;
    list-style: none;
  }
  .guide-list li {
    position: relative;
    padding-left: 24px;
    font-size: 14px;
    line-height: 1.6;
    color: var(--ink-2);
  }
  .guide-list li::before {
    content: "§";
    position: absolute;
    left: 0;
    top: 0;
    font-family: var(--f-mono);
    color: var(--rx);
  }
  .guide-source-strip {
    margin-top: 20px;
    padding: 12px 14px;
    background: rgba(0,0,0,0.025);
    border: 1px solid rgba(20,17,13,0.16);
    font-family: var(--f-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--ink-soft);
  }

  /* Panels — only one visible at a time */
  .panel { display: none; }
  .panel.active { display: block; }

  /* Diabetes panel */
  .diab-head-row {
    background: #e85d1a !important;
    color: var(--paper) !important;
    font-family: var(--f-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
  }
  .diab-head-row td { color: var(--paper) !important; padding: 10px 12px !important; }
  .diab-table td:first-child { font-weight: 500; width: 240px; }
  .diab-table td.benefit { color: var(--apothecary); font-weight: 700; }
  .diab-table td.nonbenefit { color: var(--rx-deep); font-weight: 700; }
  .diab-table td.sa { color: var(--rx); font-weight: 500; }
  .diab-table td.note { font-size: 12px; color: var(--ink-soft); font-style: italic; }

  .pump-table td:first-child { width: 180px; font-weight: 500; }
  .pump-table td { vertical-align: top; font-size: 12px; line-height: 1.55; }

  /* Formularies — NP search */
  .np-table { font-size: 12px; }
  .np-table td { padding: 8px 10px; }
  .np-table td.mono { font-family: var(--f-mono); font-size: 11px; }
  .np-count { font-family: var(--f-mono); font-size: 11px; color: var(--ink-soft); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 8px; }

  /* Form panel */
  .form-preview {
    background: #fff;
    border: 2px solid var(--ink);
    padding: 40px 48px;
    font-family: "Times New Roman", Times, serif;
    color: #000;
    max-width: 780px;
    margin: 0 auto;
    box-shadow: 10px 10px 0 var(--rx-deep);
  }
  .form-preview h1 { font-family: "Times New Roman", serif; font-size: 20px; text-align: center; margin-bottom: 6px; font-weight: 700; }
  .form-preview h2 { font-family: "Times New Roman", serif; font-size: 16px; text-align: center; margin-bottom: 20px; font-weight: 400; font-style: italic; }
  .form-preview .field-row { display: flex; gap: 12px; margin-bottom: 12px; align-items: baseline; font-size: 13px; }
  .form-preview .field-row label { font-weight: 700; min-width: 140px; }
  .form-preview .field-row .line { flex: 1; border-bottom: 1px solid #000; min-height: 20px; padding: 0 4px; }
  .form-preview .cb-row { display: flex; gap: 10px; align-items: flex-start; margin: 10px 0; font-size: 13px; line-height: 1.5; }
  .form-preview .cb { width: 14px; height: 14px; border: 1.5px solid #000; flex-shrink: 0; margin-top: 2px; }
  .form-preview p { font-size: 13px; line-height: 1.5; margin: 8px 0; }
  .form-preview table.med-list { width: 100%; border-collapse: collapse; margin: 14px 0; }
  .form-preview table.med-list td { border: 1px solid #000; padding: 8px 10px; font-size: 12px; height: 22px; }
  .form-preview table.med-list td.num { width: 28px; font-weight: 700; text-align: center; background: #f0f0f0; }
  .form-preview table.med-list td.qty { width: 100px; }
  .form-preview .sig-row { display: flex; gap: 24px; margin-top: 20px; font-size: 13px; }
  .form-preview .sig-row > div { flex: 1; border-top: 1px solid #000; padding-top: 6px; font-weight: 700; }
  .form-preview .elig-box { margin-top: 24px; padding: 14px 16px; border: 1.5px solid #000; font-size: 12px; background: #f7f7f2; }
  .form-preview .elig-box h3 { font-size: 13px; margin-bottom: 8px; font-weight: 700; }
  .form-preview .pharm-banner { margin-bottom: 18px; padding-bottom: 14px; border-bottom: 2px solid #000; font-size: 13px; text-align: center; font-weight: 700; }
  .form-preview .ff-inline { border: 0; border-bottom: 1px solid #000; padding: 2px 4px; font-family: "Times New Roman", serif; font-size: 13px; min-width: 220px; background: transparent; outline: 0; }
  .form-preview .ff-inline:focus { background: #fffbe6; }
  .form-preview .ff-date { border: 0; padding: 0 4px; font-family: "Times New Roman", serif; font-size: 13px; background: transparent; outline: 0; width: 100%; }
  .form-preview .ff-date:focus { background: #fffbe6; }
  .form-preview .ff-cb { width: 14px; height: 14px; margin: 2px 0 0; accent-color: #000; flex-shrink: 0; }
  .form-preview .ff-med { border: 0; padding: 2px 4px; font-family: "Times New Roman", serif; font-size: 12px; background: transparent; outline: 0; width: 100%; box-sizing: border-box; }
  .form-preview .ff-med:focus { background: #fffbe6; }
  .form-preview .ff-qty { border: 0; padding: 2px 4px; font-family: "Times New Roman", serif; font-size: 12px; background: transparent; outline: 0; width: 100%; box-sizing: border-box; }
  .form-preview .ff-qty:focus { background: #fffbe6; }
  .form-preview .ff-qty::placeholder, .form-preview .ff-med::placeholder, .form-preview .ff-inline::placeholder { color: #aaa; font-style: italic; }
  @media print {
    .form-preview .ff-inline, .form-preview .ff-date, .form-preview .ff-med, .form-preview .ff-qty { background: transparent !important; }
    .form-preview .ff-inline::placeholder, .form-preview .ff-date::placeholder, .form-preview .ff-med::placeholder, .form-preview .ff-qty::placeholder { color: transparent !important; }
  }
  .form-actions { display: flex; gap: 12px; justify-content: center; margin: 32px 0 16px; }
  .form-actions button {
    padding: 14px 26px;
    font-family: var(--f-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    border: 2px solid var(--ink);
    transition: background 0.15s, color 0.15s;
  }
  .form-actions button:hover { background: var(--ink); color: var(--paper); }
  .form-actions button.primary { background: var(--rx); color: var(--paper); border-color: var(--rx); }
  .form-actions button.primary:hover { background: var(--rx-deep); border-color: var(--rx-deep); }
  .form-pharm-input { width: 100%; padding: 10px 14px; font-family: var(--f-display); font-style: italic; font-size: 16px; border: 1.5px solid var(--ink); background: var(--paper); margin-bottom: 16px; }

  @media print {
    body { background: #fff !important; }
    body::before { display: none; }
    #app, .marquee, .section-nav, .section-header, .form-actions, .form-pharm-input, footer, #drawer, #drawer-backdrop, #global-search-wrap, #gs-overlay { display: none !important; }
    .form-preview { box-shadow: none !important; border: none !important; padding: 0 !important; max-width: 100% !important; }
    #print-root { display: block !important; }
  }



  /* Static guide links — visible normal anchors for readers */
  .guide-link-strip {
    margin: 20px 0 18px;
    padding: 14px 18px;
    background: var(--paper-2);
    border: 1px solid rgba(20,17,13,0.24);
    border-left: 4px solid var(--apothecary);
    font-size: 14px;
    line-height: 1.55;
  }
  .guide-link-strip .label {
    display: inline-block;
    margin-right: 10px;
    font-family: var(--f-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--apothecary);
    font-weight: 700;
  }
  .guide-link-strip a {
    display: inline-block;
    margin: 2px 12px 2px 0;
    color: var(--rx-deep);
    text-decoration: underline;
  }

  /* --- Global search --- */
  #global-search-wrap {
    position: sticky;
    top: 0;
    z-index: 80;
    max-width: none;
    margin: 0;
    padding: 14px 0 12px;
    background: var(--paper);
    border-bottom: 1px solid rgba(0,0,0,0.08);
    box-shadow: 0 4px 18px rgba(20,17,13,0.06);
    isolation: isolate;
  }
  #global-search-wrap::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    background: var(--paper);
    border-bottom: 1px solid rgba(0,0,0,0.08);
    z-index: -1;
  }
  #global-search-wrap .gs-bar,
  #global-search-wrap .gs-toolbar {
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
  }
  .gs-bar {
    display: flex; align-items: center; gap: 12px;
    background: var(--paper-2);
    border: 2.5px solid var(--apothecary);
    border-radius: 8px;
    padding: 15px 20px;
    box-shadow: 0 2px 0 var(--apothecary), 0 8px 24px rgba(45,74,62,0.12);
    transition: box-shadow 0.15s;
  }
  .gs-bar:focus-within {
    box-shadow: 0 2px 0 var(--apothecary), 0 0 0 4px rgba(45,74,62,0.18), 0 8px 24px rgba(45,74,62,0.15);
  }
  .gs-icon { flex-shrink: 0; color: var(--apothecary); }
  #gs-input { flex: 1; border: 0; background: transparent; outline: 0; font-family: var(--f-display); font-size: 17px; color: var(--ink); min-width: 0; }
  #gs-input::placeholder { color: var(--ink-soft); font-style: italic; font-size: 15px; }
  .gs-hint { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; color: var(--ink-soft); text-transform: uppercase; flex-shrink: 0; }
  .gs-hint kbd { border: 1px solid var(--ink-soft); padding: 2px 6px; border-radius: 2px; margin: 0 2px; }
  #gs-clear { background: 0; border: 0; cursor: pointer; color: var(--ink-soft); font-size: 22px; display: none; padding: 0 6px; }
  #gs-clear:hover { color: var(--ink); }

  #gs-overlay { position: fixed; inset: 0; background: rgba(10,8,4,0.55); z-index: 200; display: flex; align-items: flex-start; justify-content: center; padding: 60px 20px 20px; }
  #gs-overlay.hidden { display: none; }
  .gs-panel { background: var(--paper); border-radius: 4px; max-width: 920px; width: 100%; max-height: 86vh; display: flex; flex-direction: column; box-shadow: 0 30px 80px rgba(0,0,0,0.4); overflow: hidden; }
  .gs-header { display: flex; justify-content: space-between; align-items: center; padding: 16px 22px; border-bottom: 1px solid rgba(0,0,0,0.12); }
  .gs-scope-label { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-soft); }
  .gs-scope-label span { color: var(--ink); font-style: italic; font-family: var(--f-display); text-transform: none; font-size: 13px; margin-left: 6px; }
  #gs-close { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; background: 0; border: 1px solid var(--ink-soft); padding: 6px 12px; cursor: pointer; color: var(--ink); text-transform: uppercase; border-radius: 2px; }
  #gs-close:hover { background: var(--paper-2); }
  .gs-overlay-input-wrap {
    display: flex; align-items: center; gap: 10px;
    padding: 14px 22px;
    border-bottom: 1px solid rgba(0,0,0,0.08);
    background: var(--paper);
  }
  .gs-overlay-input-wrap svg { flex-shrink: 0; color: var(--apothecary); }
  #gs-overlay-input {
    flex: 1; border: 0; outline: 0; background: transparent;
    font-family: var(--f-display); font-size: 17px; color: var(--ink);
    min-width: 0;
  }
  #gs-overlay-input::placeholder { color: var(--ink-soft); font-style: italic; }
  #gs-overlay-clear {
    background: 0; border: 0; cursor: pointer; color: var(--ink-soft);
    font-size: 22px; padding: 0 6px; display: none;
  }
  #gs-overlay-clear:hover { color: var(--ink); }
  .gs-filters { padding: 14px 22px; border-bottom: 1px solid rgba(0,0,0,0.08); background: var(--paper-2); }
  .gs-filter-row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-bottom: 10px; }
  .gs-filter-row:last-child { margin-bottom: 0; }
  .gs-filter-label { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-soft); margin-right: 4px; min-width: 56px; }
  .gs-type-chip { font-family: var(--f-display); font-size: 12px; padding: 5px 12px; border: 1px solid var(--ink-soft); background: var(--paper); cursor: pointer; border-radius: 2px; color: var(--ink-2); }
  .gs-type-chip:hover { background: var(--paper-2); }
  .gs-type-chip.active { background: var(--ink); color: var(--paper); border-color: var(--ink); }
  #gs-carrier-sel { font-family: var(--f-display); font-size: 12px; padding: 5px 10px; border: 1px solid var(--ink-soft); background: var(--paper); color: var(--ink); border-radius: 2px; }
  .gs-results { flex: 1; overflow-y: auto; }
  .gs-count { padding: 12px 22px 4px; font-family: var(--f-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-soft); }
  .gs-result { padding: 14px 22px; border-bottom: 1px solid rgba(0,0,0,0.06); cursor: pointer; display: flex; gap: 14px; align-items: flex-start; transition: background 0.1s; }
  .gs-result:hover { background: var(--paper-2); }
  .gs-result-badge { font-family: var(--f-mono); font-size: 9px; text-transform: uppercase; letter-spacing: 0.1em; padding: 3px 8px; background: var(--apothecary); color: var(--paper); white-space: nowrap; flex-shrink: 0; border-radius: 2px; min-width: 62px; text-align: center; }
  .gs-result-badge.badge-code { background: #b43c28; }
  .gs-result-badge.badge-quick { background: #c89030; }
  .gs-result-badge.badge-pac { background: #3a5a8c; }
  .gs-result-badge.badge-meter { background: #5a3c7c; }
  .gs-result-badge.badge-clinical { background: #2d6a52; }
  .gs-result-badge.badge-college { background: #7a5a2a; }
  .gs-result-body { flex: 1; min-width: 0; }
  .gs-result-title { font-family: var(--f-display); font-size: 15px; color: var(--ink); margin-bottom: 3px; font-weight: 500; }
  .gs-result-carrier { font-family: var(--f-mono); font-size: 10px; color: var(--ink-soft); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 5px; }
  .gs-result-snippet { font-size: 12.5px; color: var(--ink-2); line-height: 1.5; }
  .gs-result mark { background: rgba(255, 220, 100, 0.55); color: var(--ink); padding: 0 2px; font-weight: 500; }
  .gs-empty { padding: 60px 24px; text-align: center; color: var(--ink-soft); font-style: italic; font-family: var(--f-display); }
  @media (max-width: 640px) {
    #global-search-wrap { padding: 10px 14px 8px; }
    .gs-bar { padding: 12px 14px; border-width: 2px; }
    #gs-input { font-size: 16px; }
    #gs-input::placeholder { font-size: 14px; }
    .gs-hint { display: none; }
    #gs-overlay { padding: 20px 10px; }
    .gs-filter-label { min-width: auto; }
  }

  /* --- Concise toggle --- */
  .gs-toolbar { display: flex; align-items: center; justify-content: flex-end; margin-top: 10px; padding: 0 4px; }
  .concise-toggle { display: inline-flex; align-items: center; gap: 10px; cursor: pointer; user-select: none; position: relative; }
  .concise-toggle input { position: absolute; opacity: 0; pointer-events: none; width: 0; height: 0; }
  .concise-track { position: relative; width: 38px; height: 22px; background: var(--ink-soft); border-radius: 999px; transition: background 0.2s; flex-shrink: 0; display: inline-block; }
  .concise-thumb { position: absolute; top: 2px; left: 2px; width: 18px; height: 18px; background: var(--paper); border-radius: 50%; transition: transform 0.2s; box-shadow: 0 1px 3px rgba(0,0,0,0.25); }
  .concise-toggle input:checked ~ .concise-track { background: var(--apothecary); }
  .concise-toggle input:checked ~ .concise-track .concise-thumb { transform: translateX(16px); }
  .concise-label { font-family: var(--f-display); font-size: 13px; color: var(--ink); font-weight: 500; letter-spacing: 0.01em; }
  .concise-hint { font-family: var(--f-display); font-style: italic; font-size: 12px; color: var(--ink-soft); }
  @media (max-width: 640px) { .concise-hint { display: none; } }

  /* --- Concise mode rules --- */
  body.concise-mode .concise-hide { display: none !important; }
  body:not(.concise-mode) .concise-only { display: none !important; }
  body.concise-mode .vac-badge {
    display: inline-block; padding: 8px 16px;
    font-family: var(--f-mono); font-size: 13px;
    text-transform: uppercase; letter-spacing: 0.08em;
    font-weight: 700; border-radius: 3px;
    margin-bottom: 14px; color: var(--paper);
  }
  body.concise-mode .vac-badge.covered { background: var(--apothecary); }
  body.concise-mode .vac-badge.call { background: #b43c28; }
  body.concise-mode .vac-badge.not-covered { background: #2a2a2a; }
  body.concise-mode .vac-concise-detail {
    display: block; font-family: var(--f-display); font-size: 13.5px;
    color: var(--ink-2); line-height: 1.55; margin-bottom: 8px;
  }
  body.concise-mode .actions-strip {
    margin: 10px 0 18px; padding: 14px 18px;
    background: rgba(45,74,62,0.08);
    border-left: 3px solid var(--apothecary);
    border-radius: 2px;
    font-family: var(--f-display); font-size: 13.5px;
    line-height: 1.6; color: var(--ink);
  }
  body.concise-mode .actions-strip-label {
    display: block; font-family: var(--f-mono); font-size: 10px;
    text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--apothecary); margin-bottom: 6px; font-weight: 600;
  }
  body.concise-mode .actions-strip code {
    font-family: var(--f-mono); font-size: 12px;
    background: var(--paper); padding: 1px 6px;
    border: 1px solid var(--ink-soft); border-radius: 2px;
    color: var(--rx-deep); font-weight: 600;
  }
  body.concise-mode .workflow-entry {
    padding: 8px 0 8px 14px;
    background: transparent;
    border-left: 2px solid rgba(45,74,62,0.25);
    margin-bottom: 2px;
  }
  body.concise-mode .workflow-title {
    font-size: 13.5px;
    margin-bottom: 0;
    font-weight: 500;
    color: var(--ink-2);
  }

/* FRx cookie / GDPR-style consent banner */
.frx-cookie-banner {
  position: fixed;
  left: 18px;
  right: 18px;
  bottom: 18px;
  z-index: 2147483000;
  max-width: 980px;
  margin: 0 auto;
  background: #fffdf7;
  color: var(--ink, #17130f);
  border: 2px solid var(--line, #2d251d);
  box-shadow: 8px 8px 0 rgba(20,17,13,.28);
  padding: 18px 20px;
  font-family: var(--f-sans, var(--sans, system-ui, sans-serif));
}
.frx-cookie-banner[hidden] { display: none !important; }
.frx-cookie-title {
  font-family: var(--f-mono, var(--mono, ui-monospace, monospace));
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--rx, #c73a0f);
  font-weight: 700;
  margin-bottom: 6px;
}
.frx-cookie-copy { font-size: 13.5px; line-height: 1.5; color: var(--ink-2, #2d2823); margin: 0; }
.frx-cookie-copy a { color: var(--rx-deep, var(--rx, #c73a0f)); font-weight: 700; }
.frx-cookie-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 14px; }
.frx-cookie-actions button,
.frx-cookie-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 9px 12px;
  border: 1.5px solid var(--line, #2d251d);
  background: var(--paper, #faf7ef);
  color: var(--ink, #17130f);
  font-family: var(--f-mono, var(--mono, ui-monospace, monospace));
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .08em;
  text-decoration: none;
  cursor: pointer;
}
.frx-cookie-actions button.primary { background: var(--ink, #17130f); color: var(--paper, #faf7ef); }
.frx-cookie-actions button:hover,
.frx-cookie-actions a:hover { background: var(--rx, #c73a0f); border-color: var(--rx, #c73a0f); color: #fff; }
@media (max-width: 680px) {
  .frx-cookie-banner { left: 10px; right: 10px; bottom: 10px; padding: 15px; box-shadow: 4px 4px 0 rgba(20,17,13,.25); }
  .frx-cookie-actions { flex-direction: column; }
  .frx-cookie-actions button, .frx-cookie-actions a { width: 100%; }
}
