/* torc.art — members
   The "galley proof" design, shared with the subbins so cross-subdomain
   navigation feels like one site: flat paper, a job-ticket header ruled
   top and bottom, metadata and controls set in Inconsolata, entries
   ruled with hairlines. Typography is EB Garamond (body + headings) and
   Inconsolata (meta/UI). Type and spacing scales are Utopia-style fluid
   clamps so the layout breathes from 320 to 1240px without breakpoints. */

@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 any straggler 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,
.nav-list a,
.footer-nav a,
.admin-nav {
  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;
}

/* 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,
form.danger button {
  background: transparent;
  color: var(--error);
  border-color: var(--error);
}
button.danger:hover, .button.danger:hover,
form.danger button: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);
}

/* Honeypot: visually hidden but not display:none (some bots skip those). */
.hp { position: absolute; left: -10000px; width: 1px; height: 1px; overflow: hidden; }

/* ---- members-specific components ---- */

ul.sessions {
  list-style: none;
  padding: 0;
  margin: var(--space-s) 0;
  border-top: 1px solid var(--rule);
  display: block;
}
ul.sessions li {
  border-bottom: 1px solid var(--line);
  padding: var(--space-s) 0;
  display: flex;
  justify-content: space-between;
  gap: var(--space-s);
  flex-wrap: wrap;
  background: transparent;
}
ul.sessions li:last-child { border-bottom: 1px solid var(--rule); }
ul.sessions .meta {
  display: grid;
  gap: 0.2rem;
  font-size: var(--step--1);
}
ul.sessions .tag {
  color: var(--accent);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-family: var(--mono);
}

dl.details {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 0.3rem var(--space-m);
  margin: var(--space-s) 0;
  font-size: var(--step--1);
}
dl.details dt {
  color: var(--muted);
  font-family: var(--mono);
  font-size: var(--step--2);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
dl.details dd { margin: 0; color: var(--ink); }

ul.tiers {
  list-style: none;
  padding: 0;
  display: grid;
  gap: var(--space-m);
  margin: var(--space-m) 0;
}
ul.tiers .tier {
  border: 1px solid var(--line);
  padding: var(--space-m);
  background: transparent;
}
ul.tiers .tier h2 { margin-top: 0; }

table.admin-users,
table.admin-audit {
  width: 100%;
  border-collapse: collapse;
  margin-top: var(--space-s);
  font-size: var(--step--1);
}
table.admin-users th,
table.admin-users td,
table.admin-audit th,
table.admin-audit td {
  text-align: left;
  padding: 0.45rem 0.7rem;
  border-bottom: 1px solid var(--line);
  vertical-align: top;
}
.audit-details {
  display: inline-block;
  max-width: 30ch;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: bottom;
  white-space: nowrap;
}

.admin-nav {
  font-size: var(--step--2);
  color: var(--muted);
  margin: var(--space-2xs) 0 var(--space-s);
}
.admin-nav a { color: var(--accent); }

.activity-counts,
.activity-list {
  list-style: none;
  padding: 0;
  margin: var(--space-xs) 0 var(--space-s);
}
.activity-counts li,
.activity-list li {
  padding: 0.35rem 0;
  border-bottom: 1px solid var(--line);
  font-size: var(--step--1);
}
.activity-counts li:last-child,
.activity-list li:last-child { border-bottom: 0; }
.activity-counts strong {
  font-family: "EB Garamond", serif;
  font-size: var(--step-0);
  margin-right: 0.4rem;
}

.admin-actions {
  display: flex;
  gap: var(--space-2xs);
  flex-wrap: wrap;
  margin: var(--space-xs) 0 var(--space-s);
}

ul.audit {
  list-style: none;
  padding: 0;
  margin: var(--space-xs) 0;
  display: grid;
  gap: var(--space-2xs);
}
ul.audit li {
  border-left: 2px solid var(--line);
  padding: 0.4rem 0.75rem;
  font-size: var(--step--1);
}
ul.audit pre {
  margin: 0.4rem 0 0;
  font-size: var(--step--2);
  white-space: pre-wrap;
  word-break: break-word;
}

/* ---- 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; }
}
