
/* The Proposition · library.css — tiny additions on top of styles.css. */

.lib-meta { font-family: var(--font-mono); font-size: 0.92rem; letter-spacing: 0.06em; color: var(--muted); margin-top: 12px; }
.lib-meta strong { color: var(--ink); font-weight: 600; }
.lib-meta span + span:before { content: "·"; margin: 0 10px; color: var(--hairline-strong); }

/* Gate form: reuses .form-grid look from contact.html */
.gate-block { background: var(--paper-2); border: 1px solid var(--hairline); border-radius: var(--radius-lg); padding: clamp(32px, 4vw, 56px); position: relative; }
.gate-block::before { content: ""; position: absolute; top: 0; left: clamp(32px, 4vw, 56px); width: 80px; height: 4px; background: var(--teal); }
.gate-block .eyebrow { padding-top: 18px; border-top: 0; }
.gate-block h2 { font-size: clamp(1.8rem, 2.6vw, 2.4rem); margin: 6px 0 10px; letter-spacing: -0.02em; }
.gate-block p { color: var(--ink-soft); }
.gate-block .form-grid { margin-top: 24px; }
.gate-block .btn { margin-top: 4px; }
.gate-block .form-grid { max-width: 520px; }
.gate-msg { margin: 0; min-height: 1.4em; font-family: var(--font-mono); font-size: 0.95rem; color: var(--muted); }
.gate-msg--ok { color: var(--teal-deep); }
.gate-msg--err { color: #B5341A; }
.hp { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; }

/* Resource hero portrait — borrows from bio-portrait but smaller */
.lib-hero { display: grid; grid-template-columns: minmax(0,1fr) minmax(320px, 420px); gap: clamp(32px, 5vw, 80px); align-items: center; }
.lib-hero__copy h1 { margin: 6px 0 12px; }
.lib-hero__photo { aspect-ratio: 3/4; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-portrait); background: var(--paper-2); position: relative; }
.lib-hero__photo picture, .lib-hero__photo img { display: block; width: 100%; height: 100%; }
.lib-hero__photo img { object-fit: cover; }
@media (max-width: 760px) { .lib-hero { grid-template-columns: 1fr; } .lib-hero__photo { max-width: 320px; } }

/* Body prose: tighter rhythm and matching list style */
.lib-body { max-width: 64ch; }
.lib-body h2 { font-size: clamp(1.6rem, 2.2vw, 2rem); margin: clamp(28px, 4vw, 48px) 0 12px; letter-spacing: -0.015em; }
.lib-body h3 { font-size: clamp(1.2rem, 1.5vw, 1.4rem); margin: clamp(20px, 3vw, 32px) 0 8px; letter-spacing: -0.01em; }
.lib-body p, .lib-body ul { margin: 0 0 1.2em; }
.lib-body blockquote { border-left: 3px solid var(--teal); margin: 1.4em 0; padding: 4px 18px; color: var(--ink-soft); font-style: italic; font-family: var(--font-display); font-size: 1.1rem; }

/* Index page: reuse the existing .resources-* classes; just give the grid a sensible columns rule */
.library-index .resources-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--ink); border-left: 1px solid var(--ink); }
@media (max-width: 980px) { .library-index .resources-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .library-index .resources-grid { grid-template-columns: 1fr; } }

.library-index .resource-card { min-height: 280px; gap: 14px; }
.library-index .resource-card .resource-cat { font-family: var(--font-mono); font-size: 0.78rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); }
.library-index .resource-card h3 { font-family: var(--font-display); font-size: clamp(1.4rem, 1.9vw, 1.7rem); margin: 0; letter-spacing: -0.015em; }
.library-index .resource-card p { margin: 0; color: var(--ink-soft); font-size: 1rem; }
.library-index .resource-card .resource-format { font-family: var(--font-mono); font-size: 0.85rem; letter-spacing: 0.06em; color: var(--muted); }
.library-index .resource-card .resource-cta { margin-top: auto; font-family: var(--font-display); font-weight: 600; color: var(--teal); }
.library-index .resource-card:hover .resource-cta { color: var(--teal-deep); }

.library-index .resource-card { display: flex; flex-direction: column; padding: clamp(24px, 2.8vw, 36px); border-right: 1px solid var(--ink); border-bottom: 1px solid var(--ink); text-decoration: none; color: var(--ink); background: var(--paper); transition: background var(--transition), color var(--transition); }
.library-index .resource-card:hover { background: var(--ink); color: var(--paper); }
.library-index .resource-card:hover .resource-cat, .library-index .resource-card:hover .resource-format { color: rgba(255,255,255,0.7); }

/* Related band at the bottom of each resource page */
.lib-related { background: var(--paper-2); }
