/* ============================================================================
 *  THEME: RECEIPT
 *  Thermal-printer paper. Narrow column. Public-record receipt of one
 *  citizen-journalist's running tab against the State. Perforated edges,
 *  dot-matrix print, "TOTAL DUE: ACCOUNTABILITY".
 * ========================================================================= */
:root {
  --bg:      #2A2723;
  --paper:   #F4EFE0;
  --ink:     #1a1a1a;
  --fade:    rgba(26,26,26,0.55);
  --barcode: #1a1a1a;
  --hi:      #B22222;

  --print:   "VT323", "IBM Plex Mono", monospace;
  --mono:    "IBM Plex Mono", ui-monospace, monospace;
}
* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  background:
    radial-gradient(circle at 20% 30%, rgba(0,0,0,0.25), transparent 60%),
    radial-gradient(circle at 80% 70%, rgba(0,0,0,0.20), transparent 60%),
    var(--bg);
  color: var(--paper);
  font-family: var(--mono);
  font-size: 16px;
  line-height: 1.5;
  min-height: 100vh;
}
::selection { background: var(--hi); color: var(--paper); }
.preview-back {
  position: fixed; top: 1rem; left: 1rem; z-index: 5;
  font-family: var(--mono);
  font-size: 0.78rem; letter-spacing: 0.18em; text-transform: uppercase;
  background: var(--paper); color: var(--ink);
  padding: 6px 10px; text-decoration: none;
  border: 1px solid var(--ink);
}
.preview-back:hover { background: var(--ink); color: var(--paper); }

/* the receipt */
.tape {
  max-width: 480px;
  margin: 1.6rem auto 3rem;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--print);
  font-size: 22px;
  line-height: 1.18;
  padding: 1.6rem 1.4rem 2rem;
  position: relative;
  box-shadow:
    0 2px 0 rgba(0,0,0,0.18),
    0 30px 60px rgba(0,0,0,0.5);
}
/* perforation top + bottom */
.tape::before, .tape::after {
  content: "";
  position: absolute; left: 0; right: 0; height: 14px;
  background:
    radial-gradient(circle at 7px 50%, var(--bg) 5px, transparent 6px) 0 0/14px 14px;
}
.tape::before { top: -7px; }
.tape::after  { bottom: -7px; }
/* faint thermal print fade */
.tape > *:not(.hr) { letter-spacing: 0.01em; }
.tape p, .tape h1, .tape h2, .tape h3, .tape h4, .tape ul { margin: 0; }

.hr {
  border: 0; border-top: 1.5px dashed var(--ink);
  margin: 0.7rem 0;
}
.hr.solid { border-top: 1.5px solid var(--ink); }
.hr.thick { border-top: 4px solid var(--ink); }

.center { text-align: center; }
.muted  { color: var(--fade); }
.right  { text-align: right; }

.row {
  display: flex; justify-content: space-between; gap: 1rem;
  font-family: var(--mono); font-size: 13px;
  letter-spacing: 0.04em;
}
.row.print {
  font-family: var(--print); font-size: 19px;
  letter-spacing: 0.02em;
}

.head .store {
  font-family: var(--print);
  font-size: 38px;
  line-height: 0.95;
  letter-spacing: 0.02em;
  text-align: center;
  text-transform: uppercase;
}
.head .sub {
  text-align: center;
  font-family: var(--mono); font-size: 12px;
  letter-spacing: 0.18em; text-transform: uppercase;
  margin-top: 0.4rem;
  color: var(--fade);
}
.head .meta {
  font-family: var(--mono); font-size: 12px;
  letter-spacing: 0.1em;
  margin-top: 0.7rem;
  display: grid; grid-template-columns: auto 1fr; gap: 2px 14px;
}
.head .meta b { font-weight: 500; color: var(--ink); }

.banner {
  font-family: var(--print);
  font-size: 30px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
  margin: 0.4rem 0;
}
.banner em { font-style: normal; color: var(--hi); }

.lede {
  font-family: var(--mono);
  font-size: 13px;
  line-height: 1.55;
  margin: 0.4rem 0;
}

/* line items */
.items {
  font-family: var(--print);
  font-size: 19px;
}
.items .item {
  display: flex; justify-content: space-between; gap: 1rem;
  border-bottom: 1px dotted rgba(26,26,26,0.4);
  padding: 0.25rem 0;
}
.items .item .desc small {
  display: block;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--fade);
  margin-top: 2px;
}
.items .item .qty {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--fade);
  white-space: nowrap;
}

.totals {
  font-family: var(--print);
  font-size: 22px;
  margin-top: 0.4rem;
}
.totals .grand {
  font-size: 30px;
  text-transform: uppercase;
}
.totals .grand b { color: var(--hi); }

.cta {
  text-align: center;
  font-family: var(--print);
  font-size: 24px;
  text-transform: uppercase;
  margin: 0.6rem 0 0.2rem;
}
.btnrow { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 6px; margin-top: 0.4rem; }
.btn {
  text-align: center;
  text-decoration: none;
  font-family: var(--mono);
  font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 8px 4px;
  background: var(--paper); color: var(--ink);
  border: 1.5px solid var(--ink);
}
.btn:hover { background: var(--ink); color: var(--paper); }
.btn.fl { background: var(--hi); border-color: var(--hi); color: var(--paper); }
.btn.fl:hover { background: var(--ink); border-color: var(--ink); }

.channels {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  display: grid; grid-template-columns: auto 1fr; gap: 3px 10px;
  margin: 0.3rem 0;
}
.channels dt { color: var(--fade); text-transform: uppercase; letter-spacing: 0.18em; }
.channels dd { margin: 0; }

/* barcode */
.barcode {
  margin: 0.6rem auto 0.3rem;
  height: 56px;
  width: 70%;
  background: repeating-linear-gradient(
    90deg,
    var(--barcode) 0 2px, transparent 2px 4px,
    var(--barcode) 4px 5px, transparent 5px 9px,
    var(--barcode) 9px 12px, transparent 12px 14px,
    var(--barcode) 14px 15px, transparent 15px 19px
  );
}
.barno {
  text-align: center;
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.32em;
}
.thanks {
  text-align: center;
  font-family: var(--print);
  font-size: 22px;
  margin-top: 0.5rem;
  text-transform: uppercase;
}
.fineprint {
  text-align: center;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fade);
  margin-top: 0.4rem;
}


/* ──────────────── ADA / WCAG 2.2 AA ────────────────
   Shared accessibility primitives mirrored from site.css. */
.skip-link {
  position: absolute; left: -9999px; top: auto;
  width: 1px; height: 1px; overflow: hidden; z-index: 10000;
}
.skip-link:focus, .skip-link:focus-visible {
  position: fixed; left: 1rem; top: 1rem;
  width: auto; height: auto; padding: 0.75rem 1rem;
  background: #ffd400; color: #0d0d0d; font-weight: 700;
  text-decoration: none; outline: 3px solid #0d0d0d;
  outline-offset: 2px; border-radius: 4px;
  box-shadow: 0 4px 12px rgba(0,0,0,.4);
  font-family: system-ui, -apple-system, sans-serif;
}
a:focus-visible, button:focus-visible, input:focus-visible,
select:focus-visible, textarea:focus-visible, summary:focus-visible,
[tabindex]:focus-visible {
  outline: 3px solid #ffd400; outline-offset: 2px; border-radius: 2px;
}
main:focus-visible, [role="main"]:focus-visible { outline: none; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}
.sr-only {
  position: absolute !important; width: 1px !important; height: 1px !important;
  padding: 0 !important; margin: -1px !important; overflow: hidden !important;
  clip: rect(0,0,0,0) !important; white-space: nowrap !important; border: 0 !important;
}
