/* ═══════════════════════════════════════════════════════════
   HALLWAYS OF THE MIND — YEARBOOK CSS
   St. Anselm Memorial High School, Class of '84
   Aesthetic: aged paper, typewriter, marginalia, amber warmth
   ═══════════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --paper:        #f5edd6;
  --paper-dark:   #e8d9b4;
  --paper-aged:   #dbc898;
  --ink:          #2a1f0e;
  --ink-light:    #5a3e1b;
  --ink-faded:    #7a5c2e;
  --red-ink:      #9b1c1c;
  --blue-ink:     #1a3a6b;
  --green-ink:    #1a4a2e;
  --pencil:       #666;
  --amber:        #c97c1a;
  --amber-light:  #e8a84a;
  --spine-bg:     #2a1a0a;
  --spine-text:   #c8a46a;
  --border-thin:  1px solid #b8a070;
  --border-mid:   2px solid #8a6030;
  --shadow:       0 4px 24px rgba(42,31,14,0.18);
  --font-body:    'IM Fell English', Georgia, serif;
  --font-display: 'Playfair Display', Georgia, serif;
  --font-type:    'Special Elite', 'Courier Prime', monospace;
  --font-mono:    'Courier Prime', monospace;
}

html, body {
  height: 100%;
  background: #1a1008;
  font-family: var(--font-body);
  color: var(--ink);
  overflow-x: hidden;
}

/* ─── SPINE NAVIGATION ─── */
#spine-nav {
  position: fixed;
  left: 0;
  top: 0;
  height: 100vh;
  width: 3.6rem;
  background: var(--spine-bg);
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 100;
  border-right: 2px solid #6a4a1a;
  box-shadow: 2px 0 12px rgba(0,0,0,0.5);
}

.spine-label {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-family: var(--font-type);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  color: var(--spine-text);
  padding: 1rem 0.2rem;
  text-transform: uppercase;
  opacity: 0.8;
}

#spine-nav ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  flex: 1;
  width: 100%;
  padding: 0.5rem 0;
  overflow-y: auto;
}

#spine-nav ul::-webkit-scrollbar { width: 3px; }
#spine-nav ul::-webkit-scrollbar-track { background: transparent; }
#spine-nav ul::-webkit-scrollbar-thumb { background: #6a4a1a; }

.spine-btn {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  width: 100%;
  padding: 0.6rem 0.4rem;
  background: none;
  border: none;
  color: #a0784a;
  font-family: var(--font-type);
  font-size: 0.58rem;
  letter-spacing: 0.12em;
  cursor: pointer;
  transition: color 0.2s, background 0.2s;
  text-align: center;
}

.spine-btn:hover {
  color: var(--spine-text);
  background: rgba(200,164,106,0.12);
}

.spine-btn.active {
  color: var(--amber-light);
  background: rgba(200,164,106,0.2);
  border-left: 2px solid var(--amber);
}

/* ─── BOOK WRAPPER ─── */
#book-wrapper {
  margin-left: 3.6rem;
  min-height: 100vh;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding: 2rem 1rem 4rem;
}

/* ─── PAGE ARROWS ─── */
.page-arrow {
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(42,26,10,0.85);
  border: var(--border-thin);
  border-color: #8a6030;
  color: var(--spine-text);
  font-size: 1.8rem;
  width: 3rem;
  height: 3rem;
  cursor: pointer;
  z-index: 90;
  border-radius: 50%;
  transition: background 0.2s, color 0.2s, opacity 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.75;
}

.page-arrow:hover { background: #6a4010; color: var(--amber-light); opacity: 1; }

#prev-btn { left: 4.2rem; }
#next-btn { right: 1rem; }

/* ─── SECTION BASE ─── */
.yearbook-section {
  display: none;
  width: 100%;
  max-width: 1200px;
  animation: fadeIn 0.5s ease;
}

.yearbook-section.active { display: block; }

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ─── SPREAD LAYOUT ─── */
.spread-page {
  background: var(--paper);
  border: var(--border-thin);
  border-color: #c0a060;
  box-shadow: var(--shadow);
  padding: 2.5rem 2.8rem;
  position: relative;
  min-height: 700px;
  overflow: hidden;
}

.spread-page::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(ellipse at 20% 30%, rgba(180,140,60,0.06) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 70%, rgba(180,140,60,0.04) 0%, transparent 50%);
  pointer-events: none;
}

/* Two-column spread */
#section-opening .spread-page,
#section-faculty .spread-page,
#section-clubs .spread-page,
#section-superlatives .spread-page,
#section-marginalia .spread-page {
  display: inline-block;
  vertical-align: top;
  width: calc(50% - 0.5rem);
}

#section-opening .spread-page:first-child,
#section-faculty .spread-page:first-child,
#section-clubs .spread-page:first-child,
#section-superlatives .spread-page:first-child,
#section-marginalia .spread-page:first-child {
  border-right: none;
  margin-right: 0;
}

/* ─── SIGNATURES SECTION SPECIAL LAYOUT ─── */
#section-signatures {
  display: none;
}
#section-signatures.active {
  display: flex;
  gap: 0;
}

#section-signatures .spread-page {
  flex: 1;
  min-width: 0;
}

#section-signatures .left-page {
  border-right: none;
}

/* ─── PAGE HEADER RULE ─── */
.page-header-rule {
  border-top: var(--border-mid);
  border-color: var(--ink-faded);
  margin-bottom: 1.5rem;
}

.page-header-rule::before {
  content: '';
  display: block;
  border-top: 1px solid var(--paper-aged);
  margin-top: 3px;
}

.section-label {
  font-family: var(--font-type);
  font-size: 0.7rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--ink-faded);
  margin-bottom: 1.2rem;
}

/* ═══════════════════════════════════════
   COVER PAGE
   ═══════════════════════════════════════ */
#section-cover .cover-page {
  background: linear-gradient(160deg, #2a1a08 0%, #1a0e04 40%, #0e0802 100%);
  border: 4px solid #6a4a1a;
  box-shadow: 0 0 40px rgba(180,120,30,0.3), inset 0 0 60px rgba(0,0,0,0.4);
  min-height: 80vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 4rem 3rem;
  position: relative;
  overflow: hidden;
}

#section-cover .cover-page::before {
  content: '';
  position: absolute;
  inset: 12px;
  border: 1px solid rgba(180,140,60,0.3);
  pointer-events: none;
}

.cover-school-badge {
  font-family: var(--font-type);
  font-size: 0.65rem;
  letter-spacing: 0.4em;
  color: #a07040;
  text-transform: uppercase;
  margin-bottom: 2rem;
}

.cover-seal {
  margin-bottom: 1.5rem;
}

.seal-ring {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  border: 3px solid #8a6020;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 20px rgba(180,120,30,0.4);
}

.seal-inner {
  width: 68px;
  height: 68px;
  border-radius: 50%;
  border: 1px solid #6a4a10;
  background: radial-gradient(circle, #2a1a08 60%, #1a0e04);
  display: flex;
  align-items: center;
  justify-content: center;
}

.seal-year {
  font-family: var(--font-display);
  font-size: 1.1rem;
  color: #c8a046;
  font-weight: 700;
}

.cover-title {
  font-family: var(--font-display);
  font-size: clamp(2.8rem, 6vw, 5rem);
  color: #e8c870;
  text-align: center;
  line-height: 1.1;
  margin-bottom: 1rem;
  text-shadow: 0 2px 8px rgba(0,0,0,0.5);
}

.cover-title em {
  font-size: 0.6em;
  color: #a08040;
  display: block;
}

.cover-subtitle {
  font-family: var(--font-type);
  font-size: 0.9rem;
  letter-spacing: 0.2em;
  color: #a07840;
  margin-bottom: 2rem;
  text-transform: uppercase;
}

.cover-tagline {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.9rem;
  color: #786040;
  text-align: center;
  max-width: 400px;
  line-height: 1.6;
  margin-bottom: 2rem;
  padding: 1rem 1.5rem;
  border-top: 1px solid #4a3010;
  border-bottom: 1px solid #4a3010;
}

.cover-deco-line {
  width: 120px;
  height: 1px;
  background: linear-gradient(to right, transparent, #8a6020, transparent);
  margin-bottom: 1.5rem;
}

.cover-bottom-label {
  font-family: var(--font-type);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  color: #5a3a14;
  text-transform: uppercase;
}

.cover-coffee-ring {
  position: absolute;
  bottom: 3rem;
  right: 3rem;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  border: 8px solid transparent;
  border-top-color: rgba(180,120,40,0.15);
  border-right-color: rgba(180,120,40,0.12);
  border-bottom-color: rgba(180,120,40,0.08);
  transform: rotate(25deg);
}

/* ═══════════════════════════════════════
   OPENING SPREAD
   ═══════════════════════════════════════ */
.spread-title {
  font-family: var(--font-display);
  font-size: 1.6rem;
  color: var(--ink);
  margin-bottom: 1.5rem;
  font-style: italic;
}

.body-text {
  font-family: var(--font-body);
  font-size: 0.95rem;
  line-height: 1.75;
  color: var(--ink-light);
}

.body-text p { margin-bottom: 1rem; }

.body-text.dropcap p:first-child::first-letter {
  font-family: var(--font-display);
  font-size: 3.5rem;
  font-weight: 700;
  float: left;
  line-height: 0.8;
  margin: 0.1em 0.1em 0 0;
  color: var(--ink);
}

.read-accordingly {
  font-size: 1rem !important;
  color: var(--ink) !important;
  text-align: right;
  margin-top: 1.5rem !important;
}

.tape-note {
  position: absolute;
  bottom: 2rem;
  left: 2rem;
  background: #fffde8;
  border: var(--border-thin);
  padding: 0.6rem 0.8rem;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: var(--ink-faded);
  max-width: 160px;
  line-height: 1.4;
  box-shadow: 1px 2px 6px rgba(0,0,0,0.15);
}

.tape-note::before {
  content: '';
  display: block;
  width: 40px;
  height: 14px;
  background: rgba(255,240,150,0.6);
  position: absolute;
  top: -7px;
  left: 50%;
  transform: translateX(-50%);
  border: 1px solid rgba(200,180,80,0.4);
}

.group-photo-spread {
  position: relative;
}

.group-photo {
  width: 100%;
  display: block;
  border: var(--border-thin);
  box-shadow: 2px 2px 10px rgba(0,0,0,0.2);
  filter: sepia(0.15) contrast(0.95);
}

.photo-caption {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: var(--ink-faded);
  margin-top: 0.5rem;
  text-align: center;
  font-style: italic;
}

/* ═══════════════════════════════════════
   FACULTY PAGE
   ═══════════════════════════════════════ */
.faculty-photo-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 1.5rem;
}

.faculty-photo {
  width: 100%;
  max-width: 280px;
  border: 3px solid var(--paper-dark);
  box-shadow: 2px 4px 14px rgba(0,0,0,0.25);
  filter: sepia(0.2) contrast(0.95);
  display: block;
}

.faculty-nameplate {
  margin-top: 1rem;
  text-align: center;
  border-top: var(--border-thin);
  border-bottom: var(--border-thin);
  padding: 0.5rem 1rem;
}

.faculty-name {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--ink);
}

.faculty-title {
  font-family: var(--font-type);
  font-size: 0.65rem;
  color: var(--ink-faded);
  letter-spacing: 0.15em;
  margin-top: 0.2rem;
}

.door-plaque {
  background: linear-gradient(135deg, #c8a446, #a07820, #c8a446);
  border: 2px solid #6a4010;
  padding: 0.8rem 1.2rem;
  text-align: center;
  box-shadow: inset 0 0 8px rgba(0,0,0,0.2), 2px 2px 8px rgba(0,0,0,0.3);
}

.plaque-text {
  font-family: var(--font-type);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  color: #2a1a06;
  text-transform: uppercase;
}

.plaque-sub {
  font-family: var(--font-type);
  font-size: 0.6rem;
  color: #4a2e0a;
  letter-spacing: 0.1em;
  margin-top: 0.2rem;
}

.plaque-quote {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.75rem;
  color: #2a1a06;
  margin-top: 0.4rem;
}

.superlative-box {
  border: var(--border-thin);
  padding: 0.8rem 1rem;
  margin-bottom: 1rem;
  background: rgba(180,140,60,0.06);
}

.sup-label {
  font-family: var(--font-type);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-faded);
  margin-bottom: 0.3rem;
}

.sup-text {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.9rem;
  color: var(--ink-light);
}

.faculty-comments-block {
  margin-top: 1.2rem;
}

.comment-header {
  font-family: var(--font-type);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-faded);
  margin-bottom: 0.7rem;
  border-bottom: var(--border-thin);
  padding-bottom: 0.4rem;
}

.comment-list {
  list-style: none;
  font-size: 0.85rem;
  line-height: 1.6;
}

.comment-list li {
  margin-bottom: 0.5rem;
  padding-left: 0.8rem;
  border-left: 2px solid var(--paper-aged);
  font-family: var(--font-body);
  font-style: italic;
  color: var(--ink-light);
}

.commenter {
  font-style: normal;
  font-weight: bold;
  color: var(--ink);
}

/* ═══════════════════════════════════════
   SENIOR PROFILES
   ═══════════════════════════════════════ */
#section-seniors {
  display: none;
}

#section-seniors.active {
  display: block;
}

.seniors-header-spread {
  background: var(--paper-dark);
  border: var(--border-mid);
  padding: 2rem 3rem;
  text-align: center;
  margin-bottom: 0;
  position: relative;
}

.seniors-year-banner {
  font-family: var(--font-type);
  font-size: 0.7rem;
  letter-spacing: 0.3em;
  color: var(--ink-faded);
  text-transform: uppercase;
  margin-bottom: 0.5rem;
}

.seniors-title-large {
  font-family: var(--font-display);
  font-size: 2.2rem;
  color: var(--ink);
  font-style: italic;
}

.seniors-subtitle {
  font-family: var(--font-type);
  font-size: 0.65rem;
  color: var(--ink-faded);
  letter-spacing: 0.2em;
  margin-top: 0.5rem;
}

/* Senior Sub-Navigation */
.senior-subnav {
  display: flex;
  background: var(--paper-dark);
  border: var(--border-thin);
  border-top: none;
  overflow-x: auto;
}

.senior-btn {
  flex: 1;
  padding: 0.7rem 0.5rem;
  background: none;
  border: none;
  border-right: var(--border-thin);
  font-family: var(--font-type);
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  color: var(--ink-faded);
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
  white-space: nowrap;
}

.senior-btn:last-child { border-right: none; }
.senior-btn:hover { background: rgba(180,140,60,0.1); color: var(--ink); }
.senior-btn.active { background: var(--paper); color: var(--ink); font-weight: bold; border-bottom: 2px solid var(--amber); }

/* Senior Profile Spread */
.senior-profile {
  display: none;
}

.senior-profile.active {
  display: flex;
}

.profile-left, .profile-right {
  flex: 1;
  min-width: 0;
}

.profile-left {
  display: flex;
  flex-direction: column;
  align-items: center;
  border-right: none;
  background: var(--paper-dark);
  padding: 2.5rem 2rem;
}

.senior-emoji {
  font-size: 2rem;
  margin-bottom: 1rem;
}

.senior-photo-frame {
  border: 3px solid var(--paper-aged);
  box-shadow: 2px 4px 14px rgba(0,0,0,0.25), inset 0 0 8px rgba(0,0,0,0.05);
  overflow: hidden;
  width: 100%;
  max-width: 240px;
  aspect-ratio: 3/4;
}

.senior-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: sepia(0.15) contrast(0.95);
  display: block;
}

.group-crop .senior-photo {
  object-position: center 20%;
}

.dubois-photo { object-position: 40% 30%; }
.emerson-photo { object-position: 20% 10%; }

.senior-superlative-badge {
  margin-top: 1rem;
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.8rem;
  color: var(--ink-faded);
  text-align: center;
  border-top: var(--border-thin);
  padding-top: 0.7rem;
  max-width: 220px;
}

.senior-name-block {
  margin-bottom: 0.8rem;
}

.senior-name {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--ink);
  border-bottom: var(--border-mid);
  padding-bottom: 0.4rem;
}

.senior-photo-caption {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.8rem;
  color: var(--ink-faded);
  margin-bottom: 1.2rem;
}

.senior-details-grid {
  display: grid;
  gap: 0.7rem;
  margin-bottom: 1.2rem;
}

.detail-item {
  display: grid;
  grid-template-columns: 70px 1fr;
  gap: 0.5rem;
  align-items: start;
  font-size: 0.85rem;
  line-height: 1.5;
}

.detail-label {
  font-family: var(--font-type);
  font-size: 0.6rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ink-faded);
  padding-top: 0.1rem;
}

.detail-val {
  color: var(--ink-light);
  font-family: var(--font-body);
}

.quote-val {
  font-style: italic;
  font-size: 0.95rem;
  color: var(--ink);
  font-weight: bold;
}

.senior-message-block {
  background: rgba(180,140,60,0.06);
  border-left: 3px solid var(--paper-aged);
  padding: 1rem 1.2rem;
  margin-top: auto;
}

.message-label {
  font-family: var(--font-type);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-faded);
  margin-bottom: 0.5rem;
}

.message-text {
  font-family: var(--font-body);
  font-size: 0.9rem;
  line-height: 1.65;
  color: var(--ink-light);
  margin-bottom: 0.8rem;
}

.senior-signature {
  font-family: var(--font-display);
  font-size: 1.1rem;
  color: var(--ink);
  margin-bottom: 0.2rem;
}

.sig-note {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.7rem;
  color: var(--ink-faded);
}

/* Signature style variations */
.james-sig { font-size: 1.2rem; transform: rotate(-1.5deg); display: inline-block; }
.peirce-sig { letter-spacing: 0.05em; }
.addams-sig { font-size: 1.3rem; }
.dubois-sig { letter-spacing: 0.03em; }
.emerson-sig { font-size: 1.4rem; font-weight: 700; }
.thoreau-sig { font-size: 0.95rem; }

/* Marginalia in profiles */
.marginalia-corner {
  position: absolute;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  line-height: 1.4;
  pointer-events: none;
  max-width: 140px;
}

.thank-you-cluster {
  position: absolute;
  right: 1.5rem;
  bottom: 8rem;
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.ty-note {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--ink-faded);
  display: inline-block;
}

.detention-stamp {
  margin-top: 1rem;
  border: 2px solid var(--red-ink);
  color: var(--red-ink);
  font-family: var(--font-type);
  font-size: 0.7rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  padding: 0.4rem 0.8rem;
  text-align: center;
  transform: rotate(-4deg);
  display: inline-block;
}

.stamp-sub {
  font-size: 0.55rem;
  display: block;
}

.torn-scrap {
  position: absolute;
  bottom: 1.5rem;
  left: 1.5rem;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: var(--ink-faded);
  background: #fffde0;
  padding: 0.4rem 0.6rem;
  border: 1px dashed #c0a040;
  transform: rotate(1.5deg);
  box-shadow: 1px 1px 4px rgba(0,0,0,0.1);
}

/* ═══════════════════════════════════════
   CLUBS
   ═══════════════════════════════════════ */
.clubs-intro {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.1rem;
  color: var(--ink-faded);
  margin-bottom: 1.5rem;
}

.club-card {
  border: var(--border-thin);
  padding: 0.9rem 1rem;
  margin-bottom: 1rem;
  background: rgba(245,237,214,0.5);
  position: relative;
}

.club-card::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--paper-aged);
}

.club-name {
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 0.3rem;
}

.club-desc {
  font-family: var(--font-body);
  font-size: 0.82rem;
  color: var(--ink-light);
  margin-bottom: 0.4rem;
  font-style: italic;
}

.club-members {
  font-family: var(--font-type);
  font-size: 0.7rem;
  color: var(--ink-faded);
  letter-spacing: 0.05em;
  margin-bottom: 0.3rem;
}

.cm-label {
  font-weight: bold;
}

.club-highlight {
  font-family: var(--font-body);
  font-size: 0.8rem;
  color: var(--ink-light);
  padding: 0.4rem 0.6rem;
  border-top: var(--border-thin);
  margin-top: 0.4rem;
}

.outdoor-club .club-name::after {
  content: ' 🌿';
}

/* ═══════════════════════════════════════
   SUPERLATIVES
   ═══════════════════════════════════════ */
.sup-official-header, .sup-unofficial-header {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 1rem;
  border-bottom: var(--border-thin);
  padding-bottom: 0.4rem;
}

.unofficial-sub {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.8rem;
  font-weight: 400;
  display: block;
  color: var(--ink-faded);
}

.superlatives-grid {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
  margin-bottom: 1.5rem;
}

.sup-entry {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.5rem;
  align-items: start;
  border-bottom: 1px dotted var(--paper-aged);
  padding-bottom: 0.5rem;
  font-size: 0.85rem;
}

.sup-title {
  font-family: var(--font-body);
  font-style: italic;
  color: var(--ink-light);
}

.sup-winner {
  font-family: var(--font-type);
  font-size: 0.7rem;
  color: var(--ink);
  white-space: nowrap;
  text-align: right;
}

.faculty-sup .sup-title { color: var(--ink-faded); }

.sup-pair-header {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 0.7rem;
  border-bottom: 1px dotted var(--paper-aged);
  padding-bottom: 0.3rem;
}

.superlatives-pairs { display: flex; flex-direction: column; gap: 0.6rem; }

.pair-entry {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.5rem;
  font-size: 0.82rem;
  border-bottom: 1px dotted var(--paper-aged);
  padding-bottom: 0.4rem;
}

.pair-title { font-family: var(--font-body); font-style: italic; color: var(--ink-light); }
.pair-who { font-family: var(--font-type); font-size: 0.7rem; color: var(--ink); white-space: nowrap; text-align: right; }

.superlatives-unofficial-grid { display: flex; flex-direction: column; gap: 0.55rem; }

.usup-entry {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.5rem;
  font-size: 0.8rem;
  border-bottom: 1px dotted var(--paper-aged);
  padding-bottom: 0.35rem;
  align-items: start;
}

.usup-title { font-family: var(--font-body); font-style: italic; color: var(--ink-light); line-height: 1.3; }
.usup-winner { font-family: var(--font-type); font-size: 0.68rem; color: var(--ink); white-space: nowrap; text-align: right; }

/* ═══════════════════════════════════════
   DEWEY'S HOMEROOM NOTE
   ═══════════════════════════════════════ */
.homeroom-full-spread {
  background: var(--paper);
  border: var(--border-mid);
  box-shadow: var(--shadow);
  padding: 3rem;
  position: relative;
  overflow: hidden;
  min-height: 80vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.homeroom-paper {
  background: #fffef5;
  border: 1px solid #d4b88a;
  max-width: 680px;
  width: 100%;
  padding: 3rem 3.5rem;
  position: relative;
  box-shadow: 0 2px 18px rgba(0,0,0,0.1);
  /* Lined paper effect */
  background-image: repeating-linear-gradient(
    to bottom,
    transparent,
    transparent 27px,
    rgba(180,140,60,0.12) 27px,
    rgba(180,140,60,0.12) 28px
  );
  line-height: 28px;
}

.homeroom-paper::before {
  content: '';
  position: absolute;
  left: 70px;
  top: 0;
  bottom: 0;
  width: 1px;
  background: rgba(200,100,100,0.2);
}

.memo-header {
  font-family: var(--font-type);
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  color: var(--ink-faded);
  margin-bottom: 1.5rem;
  border-bottom: 1px solid var(--paper-aged);
  padding-bottom: 0.7rem;
}

.memo-from, .memo-to, .memo-from-line, .memo-date {
  display: block;
  margin-bottom: 0.2rem;
}

.homeroom-body {
  font-family: var(--font-body);
  font-size: 0.92rem;
  line-height: 1.8;
  color: var(--ink-light);
}

.homeroom-body p {
  margin-bottom: 1rem;
}

.homeroom-body em {
  color: var(--ink);
}

.closing-line {
  font-size: 1rem;
  color: var(--ink);
  font-style: italic;
  margin-top: 1.5rem !important;
}

.dewey-sign {
  font-family: var(--font-display);
  font-size: 1.4rem;
  color: var(--ink);
  margin-top: 1rem;
  font-style: italic;
}

.memo-marginalia {
  position: absolute;
  right: -10px;
  bottom: 3rem;
  background: #fffde0;
  border: 1px solid #d4b050;
  padding: 0.6rem 0.8rem;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: var(--ink-faded);
  max-width: 140px;
  line-height: 1.5;
  box-shadow: 1px 2px 6px rgba(0,0,0,0.1);
}

.memo-marginalia::before {
  content: '';
  display: block;
  width: 40px;
  height: 14px;
  background: rgba(255,240,150,0.7);
  position: absolute;
  top: -7px;
  left: 50%;
  transform: translateX(-50%);
}

.memo-coffee-ring {
  position: absolute;
  bottom: 2rem;
  right: 2.5rem;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  border: 6px solid transparent;
  border-top-color: rgba(180,120,40,0.12);
  border-right-color: rgba(180,120,40,0.1);
  transform: rotate(15deg);
}

/* ═══════════════════════════════════════
   SIGNATURES
   ═══════════════════════════════════════ */
.sig-intro-text {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.85rem;
  color: var(--ink-faded);
  margin-bottom: 1.2rem;
  line-height: 1.5;
}

.sig-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  margin-bottom: 1.2rem;
}

.sig-btn {
  padding: 0.3rem 0.7rem;
  background: transparent;
  border: var(--border-thin);
  font-family: var(--font-type);
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  color: var(--ink-faded);
  cursor: pointer;
  transition: all 0.2s;
}

.sig-btn:hover { background: rgba(180,140,60,0.1); color: var(--ink); }
.sig-btn.active { background: var(--paper-dark); color: var(--ink); border-color: var(--amber); }

.sig-page { display: none; }
.sig-page.active { display: block; }

.right-sig-page { display: block; }

.sig-page-header {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--ink);
  border-bottom: var(--border-thin);
  padding-bottom: 0.4rem;
  margin-bottom: 1rem;
  font-style: italic;
}

.sig-entry {
  margin-bottom: 0.9rem;
  padding-bottom: 0.6rem;
  border-bottom: 1px dotted var(--paper-aged);
}

.sig-author {
  font-family: var(--font-type);
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 0.2rem;
}

.sig-text {
  font-family: var(--font-body);
  font-size: 0.83rem;
  line-height: 1.55;
  color: var(--ink-light);
}

/* Author color variations — simulate different handwriting */
.james-hand  { color: #3a6ba8; }
.peirce-hand { color: var(--red-ink); }
.addams-hand { color: #3a6020; }
.dubois-hand { color: #2a1f0e; }
.emerson-hand{ color: #7a4010; }
.thoreau-hand{ color: #4a5a30; }
.dewey-hand  { color: var(--ink-faded); }

.sig-margin-note {
  position: absolute;
  font-family: var(--font-mono);
  font-size: 0.68rem;
  color: var(--red-ink);
  max-width: 140px;
  line-height: 1.4;
}

.gutter-note {
  bottom: 5%;
  right: 1.5rem;
  color: var(--ink-faded);
  font-size: 0.62rem;
}

.vertical-note {
  writing-mode: vertical-rl;
  right: 0.8rem;
  top: 40%;
  max-width: none;
  font-size: 0.65rem;
  color: var(--ink-faded);
}

.emerson-margin {
  bottom: 10%;
  right: 1rem;
  color: #7a4010;
  font-style: italic;
}

.addams-thanks-cluster {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-top: 0.8rem;
  padding-top: 0.5rem;
  border-top: 1px dotted var(--paper-aged);
}

.addams-thanks-cluster span {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: var(--ink-faded);
}

.thoreau-reply {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.85rem;
  color: var(--ink);
  margin-top: 1rem;
  padding: 0.5rem 1rem;
  border-left: 3px solid var(--paper-aged);
}

.dewey-margin-reply {
  position: absolute;
  bottom: 2rem;
  right: 1.5rem;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: var(--ink-faded);
  font-style: italic;
  max-width: 180px;
  text-align: right;
}

/* ═══════════════════════════════════════
   MARGINALIA PAGE
   ═══════════════════════════════════════ */
.marginalia-desc {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.82rem;
  color: var(--ink-faded);
  margin-bottom: 1.5rem;
}

.margin-object {
  margin-bottom: 1.4rem;
  position: relative;
}

.cassette-doodle {
  border: var(--border-thin);
  padding: 0.8rem 1rem;
  background: #fffef5;
  font-family: var(--font-mono);
  font-size: 0.7rem;
}

.cassette-label {
  color: var(--ink-faded);
  margin-bottom: 0.2rem;
}

.cassette-note {
  font-size: 0.6rem;
  color: #a08040;
  margin-top: 0.3rem;
  font-style: italic;
}

.peirce-red .margin-text {
  font-family: var(--font-type);
  font-size: 0.85rem;
  letter-spacing: 0.1em;
  color: var(--red-ink);
}

.margin-attr {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.65rem;
  color: #a08040;
  margin-top: 0.3rem;
}

.tape-ephemera {
  border: 1px dashed var(--paper-aged);
  padding: 0.8rem 1rem;
  background: rgba(255,253,230,0.6);
}

.tape-item {
  font-family: var(--font-type);
  font-size: 0.68rem;
  color: var(--ink-faded);
  margin-bottom: 0.3rem;
  letter-spacing: 0.05em;
}

.tape-note-attach {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  font-style: italic;
  color: var(--ink-light);
  margin-top: 0.4rem;
  padding-top: 0.3rem;
  border-top: 1px dotted var(--paper-aged);
}

.dubois-arrow .arrow-target {
  font-family: var(--font-type);
  font-size: 0.8rem;
  text-decoration: line-through;
  color: var(--ink-faded);
  display: inline;
}

.dubois-arrow .arrow-annotation {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--ink);
  font-style: italic;
  margin-left: 0.5rem;
  display: inline;
}

.dubois-arrow .arrow-annotation::before { content: '→ '; color: var(--red-ink); }

.loose-note {
  background: #fffef0;
  border: 1px solid #d4b050;
  padding: 0.6rem 0.8rem;
  font-family: var(--font-body);
  font-size: 0.8rem;
  line-height: 1.5;
  color: var(--ink-light);
  position: relative;
}

.loose-note::before {
  content: '';
  display: block;
  width: 36px;
  height: 12px;
  background: rgba(255,240,150,0.7);
  position: absolute;
  top: -6px;
  left: 50%;
  transform: translateX(-50%);
}

.loose-note em {
  font-size: 0.7rem;
  color: var(--ink-faded);
  display: block;
  margin-bottom: 0.3rem;
}

.thoreau-scrap {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  background: #fffde8;
  border: 1px dashed #c0a040;
  padding: 0.5rem 0.8rem;
}

.dewey-memo { font-style: normal !important; }

.crossed-out-text {
  font-family: var(--font-type);
  font-size: 0.85rem;
  color: var(--ink-faded);
  margin-bottom: 0.3rem;
}

.replaced-text {
  font-family: var(--font-mono);
  font-size: 0.82rem;
  color: var(--blue-ink);
  font-style: italic;
}

.thoreau-detention {
  border: 2px solid var(--red-ink);
  padding: 0.6rem 0.8rem;
  position: relative;
  overflow: hidden;
}

.pressed-leaf-bg {
  position: absolute;
  right: 0.5rem;
  top: 0.3rem;
  font-size: 1.4rem;
  opacity: 0.6;
}

.detention-note {
  font-family: var(--font-type);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  color: var(--red-ink);
  text-transform: uppercase;
}

.detention-reason {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: var(--ink-faded);
  margin-top: 0.2rem;
}

.group-photo-note {
  margin-top: 1.5rem;
  border-top: var(--border-thin);
  padding-top: 0.8rem;
}

.group-caption-margin {
  font-family: var(--font-type);
  font-size: 0.75rem;
  color: var(--ink-faded);
  font-style: italic;
  letter-spacing: 0.05em;
}

/* ═══════════════════════════════════════
   CLOSING
   ═══════════════════════════════════════ */
#section-closing {
  display: none;
}

#section-closing.active {
  display: flex;
}

.closing-left, .closing-right {
  flex: 1;
  min-width: 0;
}

.closing-left { border-right: none; }

.closing-scene {
  font-family: var(--font-body);
  font-size: 0.9rem;
  line-height: 1.8;
  color: var(--ink-light);
  margin-bottom: 1.5rem;
}

.closing-scene p { margin-bottom: 0.8rem; }

.closing-scene strong {
  color: var(--ink);
  font-style: italic;
}

.closing-reflection {
  border-top: var(--border-thin);
  padding-top: 1rem;
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.95rem;
  color: var(--ink);
  line-height: 1.7;
}

.hidden-payload-box {
  background: linear-gradient(135deg, rgba(180,140,60,0.08), rgba(180,140,60,0.03));
  border: var(--border-mid);
  border-color: var(--paper-aged);
  padding: 1.5rem;
  margin-bottom: 2rem;
}

.payload-label {
  font-family: var(--font-type);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--amber);
  margin-bottom: 1rem;
}

.payload-grid { display: flex; flex-direction: column; gap: 0.6rem; }

.payload-row {
  display: grid;
  grid-template-columns: 70px 20px 1fr;
  gap: 0.3rem;
  align-items: start;
  font-size: 0.82rem;
}

.payload-name {
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--ink);
}

.payload-arrow {
  color: var(--amber);
  text-align: center;
}

.payload-idea {
  font-family: var(--font-body);
  font-style: italic;
  color: var(--ink-light);
  line-height: 1.4;
}

.payload-footer {
  border-top: var(--border-thin);
  padding-top: 0.8rem;
  margin-top: 0.8rem;
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.88rem;
  color: var(--ink);
}

.back-cover-taglines {
  border-top: var(--border-mid);
  padding-top: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.bc-tagline-main {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1rem;
  color: var(--ink);
  line-height: 1.5;
}

.bc-tagline-alt {
  font-family: var(--font-body);
  font-size: 0.88rem;
  color: var(--ink-light);
  line-height: 1.5;
}

.bc-tagline-kill {
  font-family: var(--font-type);
  font-size: 0.85rem;
  letter-spacing: 0.08em;
  color: var(--ink-faded);
  border-top: 1px dotted var(--paper-aged);
  padding-top: 0.8rem;
}

.bc-tagline-kill em {
  color: var(--amber);
}

.closing-school-line {
  position: absolute;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-type);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  color: var(--ink-faded);
  text-transform: uppercase;
  white-space: nowrap;
}

/* ═══════════════════════════════════════
   GENERIC MARGINALIA HELPERS
   ═══════════════════════════════════════ */
.handwritten-note {
  position: absolute;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  line-height: 1.45;
  pointer-events: none;
  max-width: 170px;
}

.blue-ink  { color: var(--blue-ink); }
.red-ink   { color: var(--red-ink); }
.pencil-ink{ color: var(--pencil); }
.fountain-ink { color: var(--ink); font-family: 'IM Fell English', serif; }

.marginalia-right {
  position: absolute;
  right: 1.5rem;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  line-height: 1.45;
  color: var(--pencil);
  pointer-events: none;
  max-width: 160px;
}

/* ═══════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════ */
@media (max-width: 900px) {
  #spine-nav {
    width: 2.8rem;
  }

  .spine-label { display: none; }
  .spine-btn { font-size: 0.48rem; }

  #book-wrapper {
    margin-left: 2.8rem;
    padding: 1rem 0.5rem 3rem;
  }

  #prev-btn { left: 3.2rem; width: 2.4rem; height: 2.4rem; font-size: 1.4rem; }
  #next-btn { right: 0.5rem; width: 2.4rem; height: 2.4rem; font-size: 1.4rem; }

  /* Stack spreads on mobile */
  #section-opening .spread-page,
  #section-faculty .spread-page,
  #section-clubs .spread-page,
  #section-superlatives .spread-page,
  #section-marginalia .spread-page {
    display: block;
    width: 100%;
  }

  #section-seniors .senior-profile.active,
  #section-closing.active,
  #section-signatures.active {
    flex-direction: column;
  }

  .senior-photo-frame { max-width: 180px; }

  .homeroom-paper {
    padding: 1.5rem 1.5rem;
  }

  .spread-page {
    padding: 1.5rem 1.5rem;
    min-height: unset;
  }
}

@media (max-width: 600px) {
  #spine-nav { display: none; }
  #book-wrapper { margin-left: 0; }
  #prev-btn { left: 0.3rem; }
  #next-btn { right: 0.3rem; }
  .cover-title { font-size: 2.2rem; }
}
