/* =========================================================
   NexusScholar.co — Shared stylesheet
   Palette: research-blue (navy / azure / gold / crimson)
   ========================================================= */

:root {
  --ink:       #06122b;
  --navy:      #0b2447;
  --royal:     #154273;
  --azure:     #1d72d2;
  --sky:       #e8f0fb;
  --paper:     #f7f9fc;
  --cloud:     #dde5f0;
  --gold:      #c8a046;
  --crimson:   #b1372a;
  --teal:      #0f7a7a;
  --line:      rgba(11, 36, 71, 0.14);
  --line-dk:   rgba(255, 255, 255, 0.12);

  --font-serif: Arial, system-ui, -apple-system, sans-serif;
  --font-sans:  Arial, system-ui, -apple-system, sans-serif;
  --font-mono:  Arial, system-ui, -apple-system, sans-serif;
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.5;
  color: var(--ink);
  background-color: var(--paper);
  background-image:
    radial-gradient(ellipse 70% 40% at 50% -10%, rgba(29, 114, 210, 0.10), transparent 60%),
    radial-gradient(ellipse 50% 30% at 100% 100%, rgba(200, 160, 70, 0.06), transparent 60%);
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
input, select { font: inherit; }
ul { list-style: none; padding: 0; margin: 0; }
h1, h2, h3, h4 { margin: 0; font-weight: 500; }

::selection { background: var(--azure); color: #fff; }

/* ---------- Layout helpers ---------- */
.container { max-width: 1480px; margin: 0 auto; padding: 0 24px; }
.grid { display: grid; gap: 24px; }
.cols-12 { grid-template-columns: repeat(12, minmax(0, 1fr)); }
.col-2  { grid-column: span 2; }
.col-3  { grid-column: span 3; }
.col-4  { grid-column: span 4; }
.col-5  { grid-column: span 5; }
.col-7  { grid-column: span 7; }
.col-8  { grid-column: span 8; }
.col-12 { grid-column: span 12; }
.stack > * + * { margin-top: 16px; }

@media (max-width: 1024px) {
  .col-2, .col-3, .col-4, .col-5, .col-7, .col-8 { grid-column: span 12; }
}

/* ---------- Typography helpers ---------- */
.serif    { font-family: var(--font-serif); }
.mono     { font-family: var(--font-mono); }
.eyebrow  { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--azure); }
.eyebrow-gold { color: var(--gold); }
.muted    { color: var(--royal); opacity: 0.75; }
.rule     { border: 0; border-top: 1px solid var(--line); margin: 16px 0; }

/* ---------- Engraved navy surfaces (banner + footer) ---------- */
.navy-engrave {
  background-color: var(--navy);
  background-image:
    linear-gradient(180deg, rgba(255,255,255,0.05), transparent 40%),
    linear-gradient(rgba(255,255,255,0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.045) 1px, transparent 1px),
    radial-gradient(ellipse 60% 50% at 50% 0%, rgba(29,114,210,0.35), transparent 60%);
  background-size: auto, 32px 32px, 32px 32px, auto;
  color: var(--paper);
}
.ink-engrave {
  background-color: var(--ink);
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px),
    radial-gradient(ellipse 70% 60% at 80% 100%, rgba(29,114,210,0.25), transparent 60%);
  background-size: 28px 28px, 28px 28px, auto;
  color: var(--paper);
}

/* ---------- Top utility strip ---------- */
.utility-strip { font-family: Arial, sans-serif; font-size: 11px; font-weight: 700; }
.utility-strip .container { display: flex; justify-content: space-between; align-items: center; padding-top: 6px; padding-bottom: 6px; }
.utility-strip .left, .utility-strip .right { display: flex; gap: 20px; align-items: center; color: #fff; }
.utility-strip a:hover { color: #fff; }
.live-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); display: inline-block; margin-right: 6px; animation: pulse-dot 2s ease-in-out infinite; }

@keyframes pulse-dot { 0%,100% { opacity:.5; transform: scale(1);} 50% { opacity:1; transform: scale(1.4);} }

/* ---------- Masthead ---------- */
.masthead { border-bottom: 1px solid rgba(29,114,210,0.2); }
.masthead .container { padding-top: 24px; padding-bottom: 24px; }
.masthead-row { display: flex; justify-content: space-between; align-items: flex-start; gap: 40px; }
.brand { display: flex; align-items: center; gap: 20px; }
.seal { position: relative; width: 64px; height: 64px; flex-shrink: 0; }
.seal::before, .seal::after { content: ""; position: absolute; border-radius: 50%; }
.seal::before { inset: 0; border: 1px solid rgba(200,160,70,0.7); }
.seal::after { inset: 6px; border: 1px solid rgba(200,160,70,0.4); }
.seal span { position: absolute; inset: 6px; display: flex; align-items: center; justify-content: center; font-family: var(--font-serif); font-style: italic; color: var(--gold); font-size: 26px; }
.brand h1 { font-family: var(--font-serif); font-size: 48px; line-height: 1; letter-spacing: -0.01em; color: var(--gold); font-weight: 500; }
.brand .tag { font-family: var(--font-serif); font-style: italic; color: #fff; font-size: 18px; font-weight: 700; margin-top: 4px; }
.brand .meta { margin-top: 12px; font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase; color: #fff; display: flex; flex-wrap: wrap; gap: 4px 20px; }

.search-block { display: flex; flex-direction: column; gap: 12px; min-width: 360px; }
.search-bar { display: flex; align-items: center; background: rgba(255,255,255,0.10); border: 1px solid rgba(255,255,255,0.15); padding: 8px 12px; gap: 8px; }
.search-bar input { flex: 1; background: transparent; border: 0; outline: none; color: #fff; font-size: 13px; }
.search-bar input::placeholder { color: rgba(221,229,240,0.55); }
.search-bar .kbd { font-family: var(--font-mono); font-size: 9px; color: rgba(221,229,240,0.6); border: 1px solid rgba(255,255,255,0.2); padding: 2px 6px; }

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; padding: 9px 16px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase; transition: background .15s ease, color .15s ease; }
.btn-gold      { background: var(--gold); color: var(--ink); }
.btn-gold:hover{ background: #fff; }
.btn-ghost     { border: 1px solid rgba(255,255,255,0.25); color: #fff; }
.btn-ghost:hover { background: rgba(255,255,255,0.10); }
.btn-navy      { background: var(--navy); color: #fff; }
.btn-navy:hover{ background: var(--royal); }
.btn-outline   { border: 1px solid var(--line); color: var(--navy); }
.btn-outline:hover { background: var(--sky); }

/* Top nav */
.topnav { display: flex; gap: 10px; overflow-x: auto; border-top: 1px solid rgba(255,255,255,0.10); padding-top: 16px; margin-top: 24px; }
.topnav a { padding: 12px 22px; font-family: Arial, sans-serif; font-size: 12px; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; color: #fff; white-space: nowrap; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.15); transition: all 0.2s ease; }
.topnav a:hover { color: #fff; background: rgba(255,255,255,0.12); border-color: rgba(255,255,255,0.25); transform: translateY(-1px); }
.topnav a.active { color: var(--ink); background: var(--gold); border-color: var(--gold); font-weight: 600; }

/* ---------- Live marquee ---------- */
.marquee-bar { background: var(--sky); border-bottom: 1px solid var(--cloud); }
.marquee-bar .container { display: flex; align-items: center; gap: 16px; padding: 8px 24px; overflow: hidden; }
.marquee-label { flex-shrink: 0; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--crimson); display: flex; align-items: center; gap: 6px; }
.marquee-label .live-dot { background: var(--crimson); }
.marquee-track { flex: 1; overflow: hidden; }
.marquee-track > div { display: flex; gap: 40px; white-space: nowrap; font-family: var(--font-mono); font-size: 13px; font-weight: 600; color: rgba(11,36,71,1); animation: marquee 60s linear infinite; }
@keyframes marquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* ---------- Cards ---------- */
.card { background: #fff; border: 1px solid var(--line); }
.card-padded { padding: 16px; }
.card-head   { padding: 12px 16px; border-bottom: 1px solid var(--line); display: flex; justify-content: space-between; align-items: center; }
.card-head h2, .card-head h3 { font-family: var(--font-serif); }
.card-head h2 { font-size: 20px; color: var(--ink); }
.card-head h3 { font-size: 15px; color: var(--ink); }

/* Sub-section rule */
.section-rule { display: flex; justify-content: space-between; align-items: flex-end; border-bottom: 1px solid rgba(11,36,71,0.15); padding-bottom: 8px; margin-bottom: 16px; }
.section-rule h2 { font-family: var(--font-serif); font-size: 20px; color: var(--ink); }
.section-rule .count { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase; color: rgba(21,66,115,0.7); }

/* Pills */
.pill { display: inline-flex; align-items: center; gap: 4px; border: 1px solid; padding: 2px 8px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; }
.pill-navy    { background: rgba(11,36,71,0.08); color: var(--navy); border-color: rgba(11,36,71,0.2); }
.pill-gold    { background: rgba(200,160,70,0.12); color: var(--gold); border-color: rgba(200,160,70,0.3); }
.pill-crimson { background: rgba(177,55,42,0.10); color: var(--crimson); border-color: rgba(177,55,42,0.25); }
.pill-teal    { background: rgba(15,122,122,0.10); color: var(--teal); border-color: rgba(15,122,122,0.25); }
.pill-sky     { background: var(--sky); color: var(--royal); border-color: var(--cloud); }

/* ---------- Sidebar: profile ---------- */
.avatar { width: 48px; height: 48px; border-radius: 50%; background: linear-gradient(135deg, var(--navy), var(--azure)); color: #fff; display: flex; align-items: center; justify-content: center; font-family: var(--font-serif); font-size: 18px; }
.profile-stats { display: grid; grid-template-columns: repeat(3, 1fr); text-align: center; border-top: 1px solid var(--line); padding-top: 12px; margin-top: 16px; }
.profile-stats .val { font-family: var(--font-serif); font-size: 20px; color: var(--navy); }
.profile-stats .lab { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(21,66,115,0.6); }
.profile-meta { margin-top: 12px; font-size: 13px; color: rgba(11,36,71,0.85); }
.profile-meta .row { display: flex; justify-content: space-between; padding: 2px 0; }
.profile-meta .gold { color: var(--gold); }

.nav-list { font-size: 14px; }
.nav-list li { display: flex; justify-content: space-between; padding: 6px 4px; cursor: pointer; color: rgba(6,18,43,0.8); }
.nav-list li:hover { background: var(--sky); color: var(--navy); }
.nav-list li .count { font-family: var(--font-mono); font-size: 13px; color: rgba(21,66,115,0.6); }

.tier-card { background: var(--navy); color: #fff; border-color: var(--navy); padding: 12px; }
.tier-card .bar { height: 6px; background: rgba(255,255,255,0.10); margin-top: 8px; position: relative; }
.tier-card .bar > span { position: absolute; top: 0; left: 0; height: 100%; background: var(--gold); }
.tier-card .row { display: flex; justify-content: space-between; margin-top: 8px; font-family: var(--font-mono); font-size: 10px; }
.tier-card .row .right { color: var(--gold); }

/* ---------- Hero stats block ---------- */
.hero { padding: 16px; position: relative; overflow: hidden; }
.hero h2 { font-family: var(--font-serif); font-size: 22px; font-weight: 700; line-height: 1.3; letter-spacing: -0.01em; color: var(--gold); margin: 0; }
.hero h2 em { font-style: italic; color: var(--gold); }
.hero p  { color: #fff; font-size: 14px; max-width: 560px; margin-top: 8px; }
.hero-stats { display: grid; grid-template-columns: repeat(6, 1fr); gap: 1px; background: rgba(255,255,255,0.10); border: 1px solid rgba(255,255,255,0.15); }
.hero-stats > div { background: rgba(11,36,71,0.85); padding: 10px 12px; text-align: center; }
.hero-stats .val { font-family: var(--font-serif); font-size: 24px; color: #fff; }
.hero-stats .lab { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; color: #fff; }

/* ---------- Forum threads ---------- */
.forum-tabs { display: flex; align-items: center; gap: 8px; padding: 12px 16px; border-bottom: 1px solid var(--line); justify-content: space-between; background: linear-gradient(to bottom, rgba(232,240,251,0.3), transparent); }
.forum-tabs .tabs { display: flex; gap: 6px; }
.forum-tabs .tabs button { 
  padding: 10px 18px; 
  font-family: Arial, sans-serif; 
  font-size: 13px; 
  font-weight: 600;
  letter-spacing: 0.02em; 
  text-transform: capitalize; 
  color: var(--navy);
  background: #fff;
  border: 2px solid var(--line);
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.2s ease;
  box-shadow: 0 1px 3px rgba(11,36,71,0.08);
}
.forum-tabs .tabs button:hover { 
  background: var(--sky); 
  border-color: var(--azure);
  color: var(--azure);
  transform: translateY(-1px);
  box-shadow: 0 2px 6px rgba(29,114,210,0.15);
}
.forum-tabs .tabs button.active { 
  background: var(--navy); 
  color: #fff; 
  border-color: var(--navy);
  box-shadow: 0 2px 8px rgba(11,36,71,0.25);
}
.forum-tabs .filters { display: flex; gap: 8px; align-items: center; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(21,66,115,0.7); }
.forum-tabs .filters select { background: transparent; border: 1px solid var(--line); padding: 4px 8px; outline: none; }

.thread { display: grid; grid-template-columns: 60px 1fr; gap: 12px; padding: 16px; border-top: 1px solid var(--line); cursor: pointer; }
.thread:first-child { border-top: 0; }
.thread:hover { background: rgba(232,240,251,0.5); }
.thread .votes { text-align: center; color: var(--royal); }
.thread .votes .v { font-family: var(--font-mono); font-size: 13px; font-weight: 600; color: var(--navy); }
.thread .votes .l { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(21,66,115,0.6); }
.thread h3 { font-family: var(--font-serif); font-size: 17px; line-height: 1.35; color: var(--ink); margin: 4px 0; }
.thread:hover h3 { color: var(--azure); }
.thread .meta { display: flex; flex-wrap: wrap; gap: 4px 16px; font-family: var(--font-mono); font-size: 11px; color: rgba(21,66,115,0.85); }
.thread .badges { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.thread .badges .time { font-family: var(--font-mono); font-size: 10px; color: rgba(21,66,115,0.6); }

.load-more { padding: 10px; text-align: center; border-top: 1px solid var(--line); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--azure); cursor: pointer; }
.load-more:hover { color: var(--navy); }

/* ---------- Tiers grid ---------- */
.tier-head { padding: 16px 20px; display: flex; justify-content: space-between; align-items: flex-end; }
.tier-head h2 { font-family: var(--font-serif); font-size: 24px; color: #fff; letter-spacing: -0.01em; }
.tier-head .note { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase; color: #fff; }
.tier-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.tier-grid > div { padding: 20px; border-left: 1px solid var(--line); }
.tier-grid > div:first-child { border-left: 0; }
.tier-grid > div:hover { background: rgba(232,240,251,0.6); }
.tier-grid .current { background: rgba(200,160,70,0.05); }
.tier-icon { width: 36px; height: 36px; border-radius: 50%; background: #fff; display: flex; align-items: center; justify-content: center; font-size: 18px; }
.tier-icon.t1 { box-shadow: inset 0 0 0 2px var(--cloud); color: var(--royal); }
.tier-icon.t2 { box-shadow: inset 0 0 0 2px rgba(29,114,210,0.4); color: var(--azure); }
.tier-icon.t3 { box-shadow: inset 0 0 0 2px rgba(11,36,71,0.4); color: var(--navy); }
.tier-icon.t4 { box-shadow: inset 0 0 0 2px rgba(200,160,70,0.4); color: var(--gold); }
.tier-icon.t5 { box-shadow: inset 0 0 0 2px rgba(177,55,42,0.4); color: var(--crimson); }
.tier-grid .top { display: flex; justify-content: space-between; align-items: flex-start; }
.tier-grid .greek { font-family: var(--font-serif); font-style: italic; font-size: 24px; color: rgba(21,66,115,0.4); }
.tier-grid .name { font-family: var(--font-serif); font-size: 22px; margin-top: 12px; color: var(--ink); }
.tier-grid .req  { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(21,66,115,0.65); margin-top: 4px; }
.tier-grid .foot { padding-top: 12px; margin-top: 16px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 12px; }
.tier-grid .foot .right { color: var(--navy); font-weight: 600; }
.tier-grid .youhere { font-family: var(--font-mono); font-size: 9px; color: var(--gold); letter-spacing: 0.25em; text-transform: uppercase; margin-top: 8px; }

/* ---------- Featured fellows grid ---------- */
.fellows { display: grid; grid-template-columns: repeat(4, 1fr); }
.fellows > div { padding: 16px; border-left: 1px solid var(--line); border-top: 1px solid var(--line); cursor: pointer; }
.fellows > div:nth-child(4n+1) { border-left: 0; }
.fellows > div:hover { background: rgba(232,240,251,0.4); }
.fellows .a { width: 48px; height: 48px; border-radius: 50%; color: #fff; display: flex; align-items: center; justify-content: center; font-family: var(--font-serif); font-size: 18px; }
.fellows .n  { font-family: var(--font-serif); font-size: 15px; color: var(--ink); margin-top: 12px; }
.fellows .f  { font-size: 11px; color: rgba(21,66,115,0.75); }
.fellows .row { display: flex; justify-content: space-between; align-items: center; margin-top: 8px; }
.fellows .row .inst { font-family: var(--font-mono); font-size: 10px; color: rgba(21,66,115,0.6); }

/* ---------- Leaderboard ---------- */
.lb li { display: flex; justify-content: space-between; align-items: center; padding: 8px 16px; border-top: 1px solid var(--line); }
.lb li:first-child { border-top: 0; }
.lb li:hover { background: rgba(232,240,251,0.5); }
.lb .r { font-family: var(--font-serif); font-size: 18px; width: 20px; color: rgba(11,36,71,0.6); }
.lb .r1 { color: var(--gold); }
.lb .r2 { color: var(--royal); }
.lb .name { font-size: 14px; font-weight: 500; color: var(--ink); }
.lb .inst { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(21,66,115,0.6); }
.lb .pts { font-family: var(--font-mono); font-size: 13px; color: var(--navy); }

/* ---------- Pulse tags ---------- */
.tags { display: flex; flex-wrap: wrap; gap: 6px; }
.tags span {
  display: inline-flex; gap: 4px; align-items: center;
  border: 1px solid var(--line); background: rgba(232,240,251,0.6);
  padding: 5px 10px; font-size: 12px; color: var(--navy);
  cursor: pointer; transition: background .15s ease, color .15s ease;
}
.tags span:hover { background: var(--navy); color: #fff; }
.tags span small { font-family: var(--font-mono); font-size: 10px; opacity: 0.6; }

/* ---------- Peer review queue ---------- */
.queue-head { background: rgba(177,55,42,0.08); }
.queue-head .right { font-family: var(--font-mono); font-size: 10px; color: var(--crimson); }
.queue li { padding: 12px 16px; border-top: 1px solid var(--line); }
.queue li:first-child { border-top: 0; }
.queue .when { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; }
.queue .when .lbl { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; }
.queue .when.urgent .lbl { color: var(--crimson); }
.queue .when.normal .lbl { color: rgba(21,66,115,0.7); }
.queue .t { font-family: var(--font-serif); font-size: 13px; color: var(--ink); line-height: 1.4; }
.queue .actions { margin-top: 8px; display: flex; gap: 8px; }
.queue .actions button { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase; padding: 4px 8px; }
.queue .actions .accept { background: var(--navy); color: #fff; }
.queue .actions .decline { border: 1px solid var(--line); color: var(--navy); background: #fff; }

/* ---------- Symposia list ---------- */
.sym li { display: flex; gap: 12px; align-items: flex-start; padding: 12px 16px; border-top: 1px solid var(--line); }
.sym li:first-child { border-top: 0; }
.sym li:hover { background: rgba(232,240,251,0.5); }
.sym .date { text-align: center; flex-shrink: 0; border-right: 1px solid var(--line); padding-right: 12px; }
.sym .date .d { font-family: var(--font-serif); font-size: 24px; color: var(--navy); line-height: 1; }
.sym .date .m { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: rgba(21,66,115,0.7); }
.sym .body { flex: 1; }
.sym .body .t { font-family: var(--font-serif); font-size: 13px; color: var(--ink); line-height: 1.4; }
.sym .body .loc { margin-top: 4px; font-family: var(--font-mono); font-size: 11px; color: rgba(21,66,115,0.7); }

/* ---------- By discipline ---------- */
.disc { display: grid; grid-template-columns: 1fr; gap: 8px; font-size: 14px; color: var(--navy); }
.disc li { display: flex; justify-content: space-between; cursor: pointer; }
.disc li:hover { color: var(--azure); }
.disc li .count { font-family: var(--font-mono); font-size: 13px; color: rgba(21,66,115,0.65); }

/* ---------- Partners wall ---------- */
.partners { background: #fff; border-top: 1px solid var(--line); }
.partners .container { padding-top: 32px; padding-bottom: 32px; }
.partners-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 20px; }
.partners-head h2 { font-family: var(--font-serif); font-size: 22px; color: var(--ink); margin-top: 4px; }
.partners-head .note { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase; color: rgba(21,66,115,0.7); }
.partner-grid {
  display: grid; grid-template-columns: repeat(7, 1fr);
  gap: 1px; background: var(--line); border: 1px solid var(--line);
}
.partner-grid > div {
  background: #fff; aspect-ratio: 3 / 1;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-serif); font-style: italic;
  color: rgba(11,36,71,0.7); font-size: 14px; transition: all .15s ease;
}
.partner-grid > div:hover { color: var(--navy); background: var(--sky); }
@media (max-width: 768px) { .partner-grid { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Footer ---------- */
.footer { margin-top: 8px; }
.footer .container { padding-top: 48px; padding-bottom: 48px; }
.footer .top { display: grid; grid-template-columns: repeat(12, 1fr); gap: 32px; }
.footer .brand-col { grid-column: span 4; }
.footer .nav-col   { grid-column: span 2; }
@media (max-width: 1024px) { .footer .brand-col, .footer .nav-col { grid-column: span 12; } }
.footer .seal-row  { display: flex; gap: 12px; align-items: center; }
.footer .seal-mini { width: 44px; height: 44px; border-radius: 50%; border: 1px solid rgba(200,160,70,0.7); display: flex; align-items: center; justify-content: center; font-family: var(--font-serif); font-style: italic; color: var(--gold); font-size: 20px; }
.footer .brand-col h3 { font-family: var(--font-serif); font-size: 22px; color: #fff; }
.footer .brand-col .sub { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase; color: #fff; }
.footer .blurb { margin-top: 16px; font-size: 13px; color: #fff; line-height: 1.6; max-width: 360px; }
.subscribe { display: flex; margin-top: 8px; }
.subscribe input { flex: 1; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.15); padding: 8px 12px; color: #fff; font-size: 12px; outline: none; }
.subscribe input::placeholder { color: rgba(221,229,240,0.45); }
.subscribe button { padding: 0 16px; background: var(--gold); color: var(--ink); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase; }
.subscribe button:hover { background: #fff; }
.footer .nav-col h4 { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--gold); margin-bottom: 12px; }
.footer .nav-col li { padding: 4px 0; font-size: 12px; color: #fff; cursor: pointer; }
.footer .nav-col li:hover { color: #fff; }
.footer .bottom { border-top: 1px solid rgba(255,255,255,0.10); }
.footer .bottom .container { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; padding: 16px 24px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: #fff; }
.footer .bottom .right { display: flex; gap: 16px; align-items: center; }
.footer .bottom .right .gold { color: var(--gold); }

/* =========================================================
   INNER PAGE — Membership / Fellowship detail page
   ========================================================= */
.page-hero { padding: 56px 0 40px; }
.crumbs { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: #fff; margin-bottom: 16px; }
.crumbs a:hover { color: var(--gold); }
.page-hero h1 { font-family: var(--font-serif); font-size: 52px; line-height: 1.05; color: #fff; letter-spacing: -0.015em; max-width: 880px; }
.page-hero .lede { margin-top: 16px; font-size: 16px; max-width: 720px; color: #fff; line-height: 1.6; }
.page-hero .actions { margin-top: 24px; display: flex; gap: 12px; flex-wrap: wrap; }

.kpi-strip { background: #fff; border-bottom: 1px solid var(--line); }
.kpi-strip .container { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; padding: 0; background: var(--line); }
.kpi-strip > .container > div { background: #fff; padding: 20px 24px; }
.kpi-strip .val { font-family: var(--font-serif); font-size: 28px; color: var(--navy); }
.kpi-strip .lab { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: rgba(21,66,115,0.7); margin-top: 4px; }
@media (max-width: 768px) { .kpi-strip .container { grid-template-columns: repeat(2, 1fr); } }

.content-block { padding: 56px 0; }
.content-block h2 { font-family: var(--font-serif); font-size: 28px; color: var(--ink); letter-spacing: -0.01em; }
.content-block .sub { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--azure); margin-bottom: 8px; }

/* Tier deep cards (inner page) */
.tier-deep { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; margin-top: 32px; }
@media (max-width: 1024px) { .tier-deep { grid-template-columns: repeat(2, 1fr); } }
.tier-deep .t { background: #fff; border: 1px solid var(--line); padding: 20px; display: flex; flex-direction: column; gap: 8px; }
.tier-deep .t .head { display: flex; justify-content: space-between; align-items: flex-start; padding-bottom: 12px; border-bottom: 1px solid var(--line); }
.tier-deep .t .name { font-family: var(--font-serif); font-size: 22px; color: var(--ink); }
.tier-deep .t .greek { font-family: var(--font-serif); font-style: italic; font-size: 26px; color: rgba(21,66,115,0.4); }
.tier-deep .t ul { font-size: 12px; color: rgba(11,36,71,0.85); }
.tier-deep .t ul li { padding: 6px 0; border-bottom: 1px dashed var(--line); display: flex; gap: 8px; }
.tier-deep .t ul li::before { content: "▸"; color: var(--azure); flex-shrink: 0; }
.tier-deep .t .foot { margin-top: auto; padding-top: 12px; display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 10px; color: rgba(21,66,115,0.7); }
.tier-deep .t.highlight { background: rgba(200,160,70,0.06); border-color: rgba(200,160,70,0.4); }

/* Compare table */
.compare { width: 100%; border-collapse: collapse; margin-top: 24px; background: #fff; border: 1px solid var(--line); font-size: 13px; }
.compare th, .compare td { padding: 12px 16px; text-align: left; border-bottom: 1px solid var(--line); }
.compare thead th { background: var(--navy); color: #fff; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase; font-weight: 500; }
.compare tbody th { font-weight: 500; color: var(--ink); width: 32%; }
.compare tbody tr:nth-child(odd) td, .compare tbody tr:nth-child(odd) th { background: rgba(232,240,251,0.35); }
.compare .yes  { color: var(--teal); font-weight: 600; }
.compare .star { color: var(--gold); font-weight: 600; }
.compare .no   { color: rgba(11,36,71,0.35); }

/* Process timeline */
.timeline { margin-top: 32px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
@media (max-width: 1024px) { .timeline { grid-template-columns: 1fr 1fr; } }
.timeline .step { background: #fff; border: 1px solid var(--line); padding: 20px; position: relative; }
.timeline .step::before { content: counter(step, decimal-leading-zero); counter-increment: step; position: absolute; top: -14px; left: 16px; background: var(--navy); color: #fff; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.25em; padding: 4px 10px; }
.timeline { counter-reset: step; }
.timeline .step h3 { font-family: var(--font-serif); font-size: 17px; color: var(--ink); margin-top: 8px; }
.timeline .step p  { font-size: 13px; color: rgba(11,36,71,0.7); margin-top: 8px; line-height: 1.55; }

/* FAQ */
.faq { margin-top: 24px; }
.faq details { background: #fff; border: 1px solid var(--line); padding: 16px 20px; margin-bottom: 8px; cursor: pointer; }
.faq details[open] { background: var(--sky); }
.faq summary { list-style: none; font-family: var(--font-serif); font-size: 17px; color: var(--ink); display: flex; justify-content: space-between; align-items: center; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-family: var(--font-mono); color: var(--azure); font-size: 18px; }
.faq details[open] summary::after { content: "−"; }
.faq p { margin-top: 12px; font-size: 13px; color: rgba(11,36,71,0.8); line-height: 1.6; }

/* CTA strip */
.cta { padding: 56px 0; }
.cta-card { background: var(--navy); color: #fff; padding: 40px; display: flex; justify-content: space-between; align-items: center; gap: 32px; }
.cta-card h2 { font-family: var(--font-serif); font-size: 32px; line-height: 1.1; max-width: 640px; }
.cta-card h2 em { color: var(--gold); font-style: italic; }
.cta-card .actions { display: flex; gap: 12px; flex-wrap: wrap; flex-shrink: 0; }
@media (max-width: 768px) { .cta-card { flex-direction: column; align-items: flex-start; } }

/* Misc inline */
.flex { display: flex; }
.between { justify-content: space-between; }
.center { align-items: center; }
.gap-2 { gap: 8px; }
.gap-3 { gap: 12px; }
.mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 12px; }
.mt-4 { margin-top: 16px; }
.mt-6 { margin-top: 24px; }
