/* torc.art — shared stylesheet for periodic / gather / offerings /
   colophon / quire. The "galley proof" design: type set in the chase —
   ruled, numbered, unfussy. Letterpress-minimal, no scripts, no
   frameworks. Per-subbin variation hangs off body.bin-<name>. */

@font-face {
  font-family: "EB Garamond";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/static/fonts/eb-garamond-400-normal.woff2") format("woff2");
}
@font-face {
  font-family: "EB Garamond";
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("/static/fonts/eb-garamond-400-italic.woff2") format("woff2");
}
@font-face {
  font-family: "EB Garamond";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/static/fonts/eb-garamond-600-normal.woff2") format("woff2");
}
/* DM Sans faces stay declared for members-continuity pages; the galley
   layer itself sets meta in Inconsolata. Unused faces don't download. */
@font-face {
  font-family: "DM Sans";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/static/fonts/dm-sans-400-normal.woff2") format("woff2");
}
@font-face {
  font-family: "DM Sans";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/static/fonts/dm-sans-500-normal.woff2") format("woff2");
}
@font-face {
  font-family: "Inconsolata";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/static/fonts/inconsolata-400-normal.woff2") format("woff2");
}

:root {
  --step--2: clamp(0.78rem, calc(0.74rem + 0.22vw), 0.9rem);
  --step--1: clamp(0.88rem, calc(0.84rem + 0.26vw), 1rem);
  --step-0:  clamp(1rem,    calc(0.94rem + 0.34vw), 1.2rem);
  --step-1:  clamp(1.25rem, calc(1.12rem + 0.62vw), 1.6rem);
  --step-2:  clamp(1.55rem, calc(1.32rem + 1.1vw),  2.2rem);
  --step-3:  clamp(2rem,    calc(1.6rem + 1.8vw),   3rem);

  --space-3xs: clamp(0.25rem, calc(0.2rem + 0.2vw),   0.4rem);
  --space-2xs: clamp(0.4rem,  calc(0.3rem + 0.35vw),  0.6rem);
  --space-xs:  clamp(0.6rem,  calc(0.5rem + 0.45vw),  0.9rem);
  --space-s:   clamp(0.9rem,  calc(0.75rem + 0.6vw),  1.2rem);
  --space-m:   clamp(1.2rem,  calc(1rem + 0.8vw),     1.8rem);
  --space-l:   clamp(1.8rem,  calc(1.4rem + 1.2vw),   2.6rem);
  --space-xl:  clamp(2.6rem,  calc(2rem + 1.6vw),     3.6rem);

  --bg: #f7f4ef;
  --bg-accent: #efe9e1;
  --bg-card: #fffdf9;
  --ink: #221d18;
  --muted: #6a6257;
  --accent: #7d4060;
  --accent-ink: #ffffff;
  --line: #d4ccbe;     /* hairline */
  --rule: #221d18;     /* full-weight rule, same as ink */
  --error: #8a2b2b;
  --error-bg: #f6eaea;
  --notice: #2c5e1f;
  --notice-bg: #e9f3e7;
  --max: 70ch;
  --mono: "Inconsolata", ui-monospace, SFMono-Regular, Menlo, monospace;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg); /* flat paper; the press prints one tone */
  color: var(--ink);
  font-family: "EB Garamond", ui-serif, Georgia, "Times New Roman", serif;
  font-size: var(--step-0);
  line-height: 1.55;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  font-kerning: normal;
}

/* ---- the mono meta voice: slug lines, labels, nav ---- */

.mono,
.eyebrow,
.fineprint,
figcaption,
.embed-link,
.nav-list a,
.footer-nav a,
.badge {
  font-family: var(--mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* ---- layout ---- */

.site-header,
main,
.site-footer {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 var(--space-m);
}
.site-header { padding-top: var(--space-l); }
main          { padding-top: var(--space-xs); padding-bottom: var(--space-l); }
.site-footer {
  margin-top: var(--space-xl);
  padding-bottom: var(--space-xl);
  color: var(--muted);
}

main.wide { max-width: 92ch; }

/* ---- nav: the job ticket ---- */

nav.site-nav {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-s);
  line-height: 1.2;
  border-top: 2px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  padding: 0.55rem 0;
}

.site-title a {
  font-family: var(--mono);
  font-size: var(--step--1);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink);
  text-decoration: none;
}
.site-title a:hover,
.site-title a:focus-visible { color: var(--accent); }
.site-title .binary-name {
  font-family: var(--mono);
  font-size: var(--step--1);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  margin-left: var(--space-3xs);
}
.site-title .binary-name::before { content: "/ "; color: var(--muted); }

.nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2xs) var(--space-s);
  margin-left: auto;
  justify-content: flex-end;
}
.nav-list a {
  font-size: var(--step--1);
  color: var(--ink);
  text-decoration: none;
}
.nav-list a:hover,
.nav-list a:focus-visible { color: var(--accent); }

/* ---- footer: the imprint ---- */

.footer-nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2xs) var(--space-s);
  padding: 0.6rem 0;
  border-bottom: 2px solid var(--rule);
}
.footer-nav a {
  color: var(--muted);
  text-decoration: none;
  font-size: var(--step--2);
}
.footer-nav a:hover,
.footer-nav a:focus-visible { color: var(--accent); }
.site-footer .fineprint {
  font-family: "EB Garamond", serif;
  font-style: italic;
  letter-spacing: normal;
  text-transform: none;
  padding-top: var(--space-xs);
}

/* ---- prose ---- */

h1, h2, h3, h4 {
  font-family: "EB Garamond", serif;
  letter-spacing: 0.01em;
  margin: var(--space-l) 0 var(--space-s);
  line-height: 1.15;
}
h1 { font-size: var(--step-3); font-weight: 400; line-height: 1.1; margin-top: var(--space-l); }
h2 { font-size: var(--step-2); font-weight: 400; }
h3 { font-size: var(--step-1); font-weight: 600; }
h4 { font-weight: 600; }

p { margin: 0 0 var(--space-s); }

.lede,
.home-deck {
  color: var(--muted);
  font-style: italic;
  font-size: var(--step-1);
  max-width: 52ch;
  margin: 0 0 var(--space-m);
}
.lede strong { font-style: normal; font-weight: 600; }

.eyebrow {
  font-size: var(--step--2);
  letter-spacing: 0.18em;
  color: var(--muted);
  margin: 0 0 var(--space-2xs);
}

.fineprint {
  color: var(--muted);
  font-size: var(--step--2);
}

a {
  color: var(--ink);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.18em;
}
a:hover,
a:focus-visible { color: var(--accent); }

ul, ol { padding-left: 1.2rem; margin: 0 0 var(--space-s); }
li { margin: 0.2rem 0; }

blockquote {
  margin: var(--space-m) 0;
  padding-left: var(--space-s);
  border-left: 2px solid var(--line);
  color: var(--muted);
}

hr { border: 0; border-top: 1px solid var(--line); margin: var(--space-l) 0; }

code, pre, kbd, samp {
  font-family: var(--mono);
  background: var(--bg-accent);
  padding: 0.1rem 0.35rem;
  font-size: 0.95em;
}
pre { padding: var(--space-s); overflow-x: auto; line-height: 1.5; }
pre code { background: transparent; padding: 0; }

img, video, iframe { max-width: 100%; height: auto; }

figure { margin: var(--space-m) 0; }
figcaption {
  font-size: var(--step--2);
  color: var(--muted);
  margin-top: var(--space-2xs);
}

table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--space-m) 0;
  font-size: var(--step--1);
}
th {
  font-family: var(--mono);
  font-size: var(--step--2);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}
th, td {
  text-align: left;
  padding: 0.5rem 0.6rem;
  border-bottom: 1px solid var(--line);
}

/* ---- forms ---- */

form {
  display: grid;
  gap: var(--space-s);
  margin: var(--space-s) 0 var(--space-m);
}
form.inline { display: inline; margin: 0; gap: 0; }

label {
  display: grid;
  gap: var(--space-3xs);
  font-family: var(--mono);
  font-size: var(--step--2);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

input[type=text],
input[type=email],
input[type=password],
input[type=number],
input[type=url],
input[type=search],
textarea,
select {
  font: inherit;
  font-family: "EB Garamond", serif;
  letter-spacing: normal;
  text-transform: none;
  padding: 0.55rem 0.7rem;
  border: 1px solid var(--line);
  background: var(--bg-card);
  color: var(--ink);
  border-radius: 0;
  width: 100%;
}
textarea { resize: vertical; min-height: 8rem; line-height: 1.5; }
input:focus, textarea:focus, select:focus {
  outline: 2px solid var(--accent);
  outline-offset: 1px;
}
input[type=file] {
  width: 100%;
  font: inherit;
  font-family: var(--mono);
  padding: 0.4rem 0;
}

/* Buttons are set like the rest of the meta voice: mono, a single
   hairline of ink, and they invert on press — type meeting paper. */
button, .button {
  font-family: var(--mono);
  font-style: normal; /* don't inherit italic from .lede etc. */
  font-size: var(--step--2);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: transparent;
  color: var(--ink);
  padding: 0.5rem 1rem;
  border: 1px solid var(--ink);
  border-radius: 0;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
  line-height: 1.2;
}
button:hover, .button:hover,
button:focus-visible, .button:focus-visible {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--bg);
}

button.secondary, .button.secondary { border-color: var(--line); color: var(--muted); }
button.secondary:hover, .button.secondary:hover {
  background: transparent;
  border-color: var(--ink);
  color: var(--ink);
}

button.danger, .button.danger {
  background: transparent;
  color: var(--error);
  border-color: var(--error);
}
button.danger:hover, .button.danger:hover { background: var(--error); color: #fff; }
button.danger.small { padding: 0.2rem 0.6rem; font-size: var(--step--2); }

.error {
  border-left: 3px solid var(--error);
  padding: 0.6rem 0.9rem;
  background: var(--error-bg);
  color: var(--error);
  font-size: var(--step--1);
}
.notice {
  border-left: 3px solid var(--notice);
  padding: 0.6rem 0.9rem;
  background: var(--notice-bg);
  color: var(--notice);
  font-size: var(--step--1);
}

.badge {
  display: inline-block;
  background: transparent;
  border: 1px solid var(--line);
  color: var(--muted);
  padding: 0.1rem 0.55rem;
  font-size: var(--step--2);
}
.badge-on { border-color: var(--accent); color: var(--accent); }

/* ---- the galley entry: shared numbered-row pattern ----
   Any list that opts in (.posts, .replies ol) numbers its entries in
   the margin with CSS counters — no template logic. */

.posts,
.replies ol {
  counter-reset: entry;
}
.post-card,
.reply {
  counter-increment: entry;
  position: relative;
  padding-left: 3.4rem;
}
.post-card::before,
.reply::before {
  content: counter(entry, decimal-leading-zero);
  position: absolute;
  left: 0;
  top: calc(var(--space-m) + 0.3rem);
  width: 2.3rem;
  text-align: right;
  font-family: var(--mono);
  font-size: var(--step--2);
  letter-spacing: 0.08em;
  color: var(--muted);
}
.reply::before { top: calc(var(--space-s) + 0.25rem); }

/* ---- gathering feed ---- */

.feed-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-xs);
}
.posts { list-style: none; padding: 0; margin: var(--space-m) 0 0; border-top: 1px solid var(--rule); }
.post-card {
  padding-top: var(--space-m);
  padding-bottom: var(--space-m);
  border-bottom: 1px solid var(--line);
}
.post-card:last-child { border-bottom: 1px solid var(--rule); }
.post-card header { margin-bottom: var(--space-2xs); }
.post-link {
  color: var(--ink);
  text-decoration: none;
  font-variant: small-caps;
  letter-spacing: 0.1em;
  font-size: 1.05em;
}
.post-link:hover { color: var(--accent); }
.post-body { margin: var(--space-2xs) 0; white-space: pre-wrap; }

/* ---- offering embeds: a hairline of the second ink ---- */

.embed {
  margin: var(--space-s) 0 0;
  padding: 0.2rem 0 0.2rem var(--space-s);
  border-left: 2px solid var(--accent);
  background: transparent;
  border-top: 0; border-right: 0; border-bottom: 0;
  color: var(--ink);
}
.embed-title {
  margin: 0;
  color: var(--ink);
  font-weight: 600;
}
.embed-text-body {
  margin: 0.3rem 0 0;
  white-space: pre-wrap;
  font-style: italic;
  color: var(--muted);
}
.embed-image img, .embed-video video {
  display: block;
  max-width: 100%;
  height: auto;
  border: 1px solid var(--ink);
  padding: 0.4rem;
  background: var(--bg-card);
}
.embed-image figcaption,
.embed-audio figcaption,
.embed-video figcaption {
  color: var(--muted);
  font-size: var(--step--2);
  margin: 0.45rem 0 0;
}
.embed-audio audio { width: 100%; margin-top: 0.4rem; }
.embed-link {
  margin: 0.4rem 0 0;
  font-size: var(--step--2);
}
.embed-link a { color: var(--accent); text-decoration: none; }
.embed-link a:hover { text-decoration: underline; }

.post-detail > header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-s);
  flex-wrap: wrap;
  margin-bottom: var(--space-s);
}
.post-detail > header .lede { margin: 0; }
.post-detail .post-body { font-size: var(--step-0); }
.replies { margin-top: var(--space-l); }
.replies ol { list-style: none; padding: 0; margin: 0; border-top: 1px solid var(--rule); }
.reply {
  padding-top: var(--space-s);
  padding-bottom: var(--space-s);
  border-bottom: 1px solid var(--line);
}
.reply:last-of-type { border-bottom: 1px solid var(--rule); }
.reply-author {
  margin: 0;
  color: var(--ink);
}
.reply-author strong {
  font-variant: small-caps;
  letter-spacing: 0.1em;
  font-weight: 400;
  font-size: 1.05em;
}
.reply-body { margin: 0.25rem 0; white-space: pre-wrap; }
.reply-form { margin-top: var(--space-m); }

/* ---- offerings ---- */

.offerings { list-style: none; padding: 0; margin: var(--space-s) 0; border-top: 1px solid var(--rule); }
.offerings li {
  padding: var(--space-s) 0;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: baseline;
  gap: var(--space-s);
  flex-wrap: wrap;
}
.offerings li:last-child { border-bottom: 1px solid var(--rule); }
.offerings .meta {
  color: var(--muted);
  font-family: var(--mono);
  font-size: var(--step--2);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.offering-detail .text-body {
  background: var(--bg-card);
  border: 1px solid var(--line);
  padding: var(--space-m);
  white-space: pre-wrap;
  margin: var(--space-m) 0;
}
.offering-meta {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 0.25rem var(--space-m);
  font-size: var(--step--1);
}
.offering-meta dt {
  color: var(--muted);
  font-family: var(--mono);
  font-size: var(--step--2);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.offering-meta dd { margin: 0; }

.media-type {
  border: 1px solid var(--line);
  padding: var(--space-xs) var(--space-s);
  margin: var(--space-s) 0 var(--space-3xs);
}
.media-type legend {
  padding: 0 0.4rem;
  color: var(--muted);
  font-family: var(--mono);
  font-size: var(--step--2);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.radio {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-right: var(--space-s);
  font-weight: normal;
}
.radio input { margin: 0; }

.media-frame { margin: var(--space-m) 0; }
.media-frame img, .media-frame video {
  display: block;
  max-width: 100%;
  height: auto;
  border: 1px solid var(--ink);
  padding: 0.4rem;
  background: var(--bg-card);
}
.media-frame audio { width: 100%; }

/* ---- quire ---- */

.editions { list-style: none; padding: 0; margin: var(--space-m) 0 0; border-top: 1px solid var(--rule); }
.edition-row {
  padding: var(--space-xs) 0;
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: var(--space-s);
  align-items: baseline;
  flex-wrap: wrap;
}
.edition-row:last-child { border-bottom: 1px solid var(--rule); }
.edition-row .meta {
  color: var(--muted);
  font-family: var(--mono);
  font-size: var(--step--2);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.slot-grid {
  list-style: none;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(8.5rem, 1fr));
  gap: var(--space-2xs);
  margin: var(--space-m) 0;
}
.slot-tile { margin: 0; }
.slot-tile a {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: var(--space-xs);
  min-height: 5rem;
  border: 1px solid var(--line);
  background: transparent;
  color: var(--ink);
  text-decoration: none;
}
.slot-tile a:hover { border-color: var(--accent); color: var(--accent); }
.slot-tile.has-winner a { border-color: var(--accent); }
.slot-tile .slot-num {
  font-family: var(--mono);
  font-size: var(--step--2);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}
.slot-tile .slot-prompt { font-style: italic; font-size: var(--step--1); line-height: 1.25; }
.slot-tile .slot-count {
  font-family: var(--mono);
  font-size: var(--step--2);
  color: var(--muted);
  margin-top: auto;
}

.slot-entries { list-style: none; padding: 0; margin: var(--space-s) 0; border-top: 1px solid var(--rule); }
.slot-entry { padding: var(--space-s) 0; border-bottom: 1px solid var(--line); }
.slot-entry:last-child { border-bottom: 1px solid var(--rule); }
.slot-entry .entry-meta {
  display: flex;
  align-items: baseline;
  gap: var(--space-xs);
  flex-wrap: wrap;
  margin: 0 0 var(--space-2xs);
}
.vote-form { margin-top: var(--space-2xs); }
.suggest-form select {
  width: 100%;
  padding: 0.4rem;
  font: inherit;
  background: var(--bg-card);
  border: 1px solid var(--line);
}

/* ---- admin ---- */

.admin-block {
  margin-top: var(--space-l);
  padding-top: var(--space-m);
  border-top: 1px solid var(--rule);
}
.admin-form.inline { display: inline; }
.admin-form.inline button { margin-top: 0; }

/* Owner affordances: delete buttons on posts/replies/offerings */
.delete-form { display: inline; margin: 0 0 0 var(--space-2xs); }
.delete-form button { margin-top: 0; }

/* ---- mobile ---- */

@media (max-width: 720px) {
  .site-nav { flex-direction: column; align-items: flex-start; }
  .nav-list { gap: var(--space-2xs) var(--space-xs); margin-left: 0; justify-content: flex-start; }

  .post-card, .reply { padding-left: 0; }
  .post-card::before, .reply::before {
    position: static;
    display: block;
    text-align: left;
    width: auto;
    margin-bottom: var(--space-3xs);
  }
}

/* ---- works (The 200): gallery grid + admin table ---- */

.works-grid {
  list-style: none;
  padding: 0;
  margin: var(--space-m) 0 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(12rem, 1fr));
  gap: var(--space-m);
}
.work-cell { margin: 0; }
.work-cell > a {
  display: block;
  text-decoration: none;
  color: var(--ink);
}
.work-cell > a:hover .work-title { color: var(--accent); }
.work-plate {
  margin: 0 0 var(--space-2xs);
  border: 1px solid var(--ink);
  background: var(--bg-card);
  padding: 0.4rem;
}
.work-plate img { display: block; width: 100%; height: auto; }
.work-title { margin: 0; font-style: italic; }
.work-meta {
  margin: var(--space-3xs) 0 0;
  display: flex;
  gap: var(--space-xs);
  font-family: var(--mono);
  font-size: var(--step--2);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}
.work-meta .work-price { color: var(--ink); }
.work-cell.is-sold .work-meta .work-state { color: var(--accent); }
.work-cell.is-sold .work-title { text-decoration: line-through; text-decoration-thickness: 1px; }

.work-plate-large { max-width: 32rem; margin: var(--space-m) 0; }
.work-detail .work-body { margin: var(--space-s) 0; white-space: pre-wrap; }

/* Admin works table reuses the base table styling; just the action cell. */
.work-actions { display: flex; gap: var(--space-2xs); flex-wrap: wrap; }
.work-actions form { margin: 0; }
