/* ═══════════════════════════════════════════════════════════════════════════
   Anıl Öztürk — Specimen Catalogue
   Personal site, Lund-aligned palette per LU Grafisk Manual v2.0.1 (2024).
   ═══════════════════════════════════════════════════════════════════════════ */

:root {
  /* Lund primary */
  --lu-blue:        #000080;   /* Logo text colour, headings */
  --lu-bronze:      #9c6114;   /* Logo seal, accents, ornament */
  --lu-bronze-tint: #c89556;   /* 50% bronze for hairlines */

  /* Lund pastels (warm, distinctive) */
  --pastel-pink:  #e9c4c7;     /* "Pastel green" in manual; warm rose tone */
  --pastel-blue:  #b9d3dc;
  --pastel-sage:  #adcab8;
  --pastel-warm:  #d6d2c4;
  --pastel-grey:  #bfb8af;

  /* Surfaces */
  --bone:        #fdfaf3;
  --bone-warm:   #f6f0e3;
  --paper:       #fbf8f0;
  --ink:         #14141c;
  --ink-soft:    #4d4c44;
  --ink-mute:    #7a7770;
  --rule-soft:   rgba(20, 20, 28, 0.10);
  --rule-bronze: rgba(156, 97, 20, 0.30);

  /* Type scale */
  --serif-display: 'EB Garamond', 'Adobe Garamond Pro', Garamond, 'Times New Roman', serif;
  --serif-body:    'EB Garamond', 'Adobe Garamond Pro', Garamond, serif;
  --sans:          'Inter', 'Frutiger LT Std', 'Helvetica Neue', Arial, sans-serif;
  --mono:          'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
}

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

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  background: var(--bone);
}

body {
  font-family: var(--serif-body);
  font-size: 18px;
  line-height: 1.55;
  color: var(--ink);
  background: var(--bone);
  text-align: justify;
  text-justify: inter-word;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "kern", "liga", "onum";
  font-variant-numeric: oldstyle-nums;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  hyphens: auto;
}

p, .entry-body, .cc-body { text-align: justify; hyphens: auto; }

@media (max-width: 720px) { body { font-size: 17px; } }

::selection {
  background: var(--pastel-pink);
  color: var(--lu-blue);
}

a {
  color: var(--lu-blue);
  text-decoration: none;
  background-image: linear-gradient(currentColor, currentColor);
  background-size: 0 1px;
  background-repeat: no-repeat;
  background-position: 0 100%;
  transition: background-size .25s ease;
}

a:hover { background-size: 100% 1px; }

a.bronze { color: var(--ink-mute); }

p { margin-bottom: 0.9em; }
p:last-child { margin-bottom: 0; }

em, i { font-style: italic; }
strong, b { font-weight: 600; }

h1, h2, h3, h4, h5 {
  font-family: var(--serif-display);
  font-weight: 500;
  line-height: 1.12;
  color: var(--ink);
  letter-spacing: -0.01em;
}

/* ═══ Layout ═══ */

.container {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 32px;
}
@media (max-width: 720px) { .container { padding: 0 20px; } }

main { flex: 1; }

/* ═══ Top masthead ═══ */

.masthead {
  border-bottom: 1px solid var(--rule-soft);
  background: var(--bone);
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(10px);
  background: rgba(253, 250, 243, 0.92);
}

.masthead-inner {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 24px;
  padding: 18px 0 14px;
}

.brand {
  white-space: nowrap;
}
.brand a {
  color: inherit;
  background: none;
  text-decoration: none;
  display: inline-flex;
  align-items: baseline;
  gap: 14px;
  transition: opacity 0.18s ease;
}
.brand a:hover { opacity: 0.78; }

/* Bespoke AÖ monogram — display italic, tight kerning, bronze accent.
   The two letters compose the visual mark; the full name follows in ink. */
.brand-mark {
  font-family: var(--serif-display);
  font-style: italic;
  font-weight: 500;
  font-size: 1.55rem;
  letter-spacing: -0.07em;
  color: var(--lu-bronze);
  line-height: 1;
  font-feature-settings: "kern" 1, "dlig" 1;
}
.brand-name {
  font-family: var(--serif-display);
  font-style: italic;
  font-weight: 400;
  font-size: 1.05rem;
  color: var(--ink);
  letter-spacing: -0.005em;
  line-height: 1;
}
@media (max-width: 540px) {
  .brand-name { display: none; }
}

nav.primary {
  display: flex;
  gap: 22px;
  align-items: baseline;
  flex-wrap: wrap;
  justify-content: flex-end;
}

nav.primary a {
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-soft);
  background: none;
  padding-bottom: 2px;
  position: relative;
}

nav.primary a:hover {
  color: var(--lu-blue);
}

nav.primary a.active {
  color: var(--lu-blue);
}
nav.primary a.active::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -3px;
  height: 2px;
  background: var(--lu-bronze);
}

.nav-num {
  font-family: var(--mono);
  font-size: 0.62rem;
  color: var(--ink-mute);
  margin-right: 4px;
  letter-spacing: 0;
  text-transform: none;
  vertical-align: super;
}

@media (max-width: 880px) {
  .masthead-inner { flex-direction: column; align-items: flex-start; gap: 12px; padding-bottom: 18px; }
  nav.primary { justify-content: flex-start; gap: 16px; }
}

/* ═══ Page header ═══ */

.page-header {
  padding: 110px 0 56px;
  position: relative;
}

/* .marker class retained as a no-op for legacy templates */
.page-header .marker { display: none; }

.page-header h1 {
  font-family: var(--serif-display);
  font-size: clamp(2.6rem, 6.4vw, 4.8rem);
  font-weight: 500;
  letter-spacing: -0.022em;
  line-height: 1.02;
  margin-bottom: 20px;
  color: var(--ink);
}
.page-header h1 em {
  color: var(--lu-bronze);
  font-style: italic;
  font-weight: 400;
}

.page-header .lede {
  font-family: var(--serif-body);
  font-size: 1.18rem;
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 720px;
  font-style: italic;
  margin-top: 4px;
}

.page-header .meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 18px 32px;
  margin-top: 26px;
  font-family: var(--mono);
  font-size: 0.72rem;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.page-header .meta-row span b {
  color: var(--ink);
  font-weight: 500;
  margin-left: 6px;
}

/* ═══ Diadem — site signature ornament ═══
   A small centered hairline interrupted by a bronze diamond, placed once
   per page between the page-header and the body. Classical book-typography
   move; the site's visual signature. */

.diadem-row {
  padding: 8px 0 32px;
}
.diadem {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin: 0 auto;
  max-width: 140px;
  height: 8px;
}
.diadem::before, .diadem::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--rule-bronze);
}
.diadem-mark {
  width: 5px;
  height: 5px;
  background: var(--lu-bronze);
  transform: rotate(45deg);
  flex-shrink: 0;
}

/* ═══ Section ═══ */

section.body {
  padding: 64px 0;
  border-bottom: 1px solid var(--rule-soft);
}
section.body:last-of-type { border-bottom: none; }

.section-head {
  display: flex;
  align-items: baseline;
  gap: 20px;
  margin-bottom: 32px;
  border-bottom: 1px solid var(--ink);
  padding-bottom: 12px;
}

.section-head .roman {
  font-family: var(--serif-display);
  font-style: italic;
  color: var(--ink-mute);
  font-size: 1.05rem;
  font-weight: 400;
  letter-spacing: 0.04em;
  flex-shrink: 0;
  min-width: 36px;
}

.section-head h2 {
  font-size: 1.7rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  flex: 1;
}

.section-head .count {
  font-family: var(--mono);
  font-size: 0.72rem;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
}

/* ═══ Specimen card ═══ */

.specimen {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 24px;
  padding: 22px 0;
  border-bottom: 1px solid var(--rule-soft);
  position: relative;
}
.specimen:last-child { border-bottom: none; }

.specimen .ref {
  font-family: var(--mono);
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  color: var(--ink-mute);
  padding-top: 4px;
}
.specimen .ref .num {
  display: block;
  font-size: 0.78rem;
  color: var(--ink-mute);
  font-weight: 500;
  margin-bottom: 4px;
}
.specimen .ref .coord { display: block; }

.specimen .title {
  font-family: var(--serif-display);
  font-size: 1.25rem;
  font-weight: 500;
  margin-bottom: 4px;
  letter-spacing: -0.005em;
  line-height: 1.25;
}
.specimen .title em { color: var(--ink); font-style: italic; }

.specimen .meta {
  font-family: var(--sans);
  font-size: 0.78rem;
  color: var(--ink-mute);
  letter-spacing: 0.02em;
  margin-bottom: 10px;
}
.specimen .meta b { color: var(--ink-soft); font-weight: 500; }

.specimen .body-text {
  font-size: 0.98rem;
  color: var(--ink-soft);
  line-height: 1.55;
}

.specimen .links {
  display: flex;
  gap: 14px;
  margin-top: 10px;
  flex-wrap: wrap;
  align-items: center;
}
.specimen .links a, .specimen .links button {
  font-family: var(--sans);
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink);
  font-weight: 500;
  border: 1px solid var(--ink);
  padding: 5px 11px;
  background: transparent;
  cursor: pointer;
  transition: background .2s, color .2s, border-color .2s;
  background-image: none;
}
.specimen .links a:hover, .specimen .links button:hover {
  background: var(--ink);
  color: var(--bone);
  border-color: var(--ink);
}

.tags {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}
.tag {
  font-family: var(--mono);
  font-size: 0.62rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--pastel-pink);
  color: var(--lu-blue);
  padding: 2px 8px;
  border-radius: 0;
}
.tag.sage  { background: var(--pastel-sage); }
.tag.blue  { background: var(--pastel-blue); }
.tag.warm  { background: var(--pastel-warm); color: var(--ink-soft); }
.tag.bronze{ background: transparent; color: var(--ink-mute); border: 1px solid var(--rule-bronze); }

@media (max-width: 720px) {
  .specimen { grid-template-columns: 1fr; gap: 8px; }
  .specimen .ref { display: flex; gap: 14px; padding-top: 0; }
  .specimen .ref .num, .specimen .ref .coord { display: inline; margin-bottom: 0; }
}

/* ═══ Hero (home page) ═══ */

.hero {
  padding: 132px 0 80px;
}

/* Legacy .hero-marker hidden — page identification comes from masthead + H1 */
.hero-marker { display: none; }

.hero h1 {
  font-family: var(--serif-display);
  font-size: clamp(3.2rem, 9.5vw, 7rem);
  font-weight: 500;
  letter-spacing: -0.028em;
  line-height: 0.96;
  margin-bottom: 24px;
  color: var(--ink);
}

.hero .epigraph {
  font-family: var(--serif-display);
  font-style: italic;
  font-size: 1.5rem;
  color: var(--ink-soft);
  max-width: 760px;
  line-height: 1.42;
  margin-top: 18px;
}

.hero .meta {
  display: flex;
  flex-wrap: wrap;
  gap: 18px 36px;
  margin-top: 42px;
  font-family: var(--mono);
  font-size: 0.74rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.hero .meta b {
  color: var(--ink);
  font-weight: 500;
  margin-left: 8px;
}

/* ═══ Footer ═══ */

footer.site {
  border-top: 1px solid var(--ink);
  padding: 56px 0 40px;
  background: var(--bone);
  margin-top: 64px;
}

footer.site .grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px 48px;
}
@media (max-width: 540px) {
  footer.site .grid { grid-template-columns: 1fr; }
}

footer.site h6 {
  font-family: var(--mono);
  font-size: 0.66rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 14px;
  font-weight: 500;
}

footer.site p, footer.site li, footer.site a {
  font-family: var(--sans);
  font-size: 0.84rem;
  color: var(--ink-soft);
  line-height: 1.6;
}

footer.site ul { list-style: none; }

footer.site .colophon {
  margin-top: 36px;
  padding-top: 22px;
  border-top: 1px solid var(--rule-soft);
  font-family: var(--mono);
  font-size: 0.66rem;
  letter-spacing: 0.06em;
  color: var(--ink-mute);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}

footer.site .lu-attribution {
  display: flex;
  align-items: center;
  gap: 14px;
}
footer.site .lu-attribution img {
  height: 38px;
  width: auto;
  filter: none;
}

/* ═══ Misc utilities ═══ */

.divider-bronze {
  height: 1px;
  background: var(--lu-bronze);
  width: 56px;
  margin: 32px 0;
}

.callout {
  background: var(--pastel-pink);
  border-left: 3px solid var(--lu-bronze);
  padding: 18px 22px;
  margin: 24px 0;
  font-family: var(--serif-display);
  font-style: italic;
  color: var(--lu-blue);
  font-size: 1.05rem;
  line-height: 1.5;
}

.field-list {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 14px 28px;
  margin: 24px 0;
}
.field-list dt {
  font-family: var(--mono);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  color: var(--ink-mute);
  text-transform: uppercase;
  padding-top: 6px;
}
.field-list dd {
  font-family: var(--serif-body);
  color: var(--ink);
  font-size: 1.02rem;
}
@media (max-width: 720px) {
  .field-list { grid-template-columns: 1fr; gap: 4px; }
  .field-list dt { padding-top: 12px; }
}

/* ═══ CV page ═══════════════════════════════════════════════════════════════
   Refined academic-CV typography: hairline rules, OpenType figures,
   serif-italic Roman section markers, restrained bronze accents.
   ═════════════════════════════════════════════════════════════════════════ */

/* All numerals across the CV use lining + tabular figures so dates, GPAs
   and codes align cleanly down the column. */
.cv-section-head, .cv-list, .cv-download, .cv-note {
  font-feature-settings: "lnum" 1, "tnum" 1, "kern" 1, "liga" 1;
}

/* ── Download row ──────────────────────────────────────────────────────── */
.cv-download {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 22px;
  align-items: baseline;
  margin: 0 0 48px;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--rule-soft);
}
.cv-action {
  font-family: var(--mono);
  font-size: 0.64rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 10px 20px;
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--ink);
  text-decoration: none;
  font-weight: 500;
  line-height: 1.3;
  transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
.cv-action:hover {
  background: var(--ink);
  color: var(--bone);
}
.cv-meta {
  font-family: var(--mono);
  font-size: 0.66rem;
  letter-spacing: 0.08em;
  color: var(--ink-mute);
}

/* ── Section heads ─────────────────────────────────────────────────────── */
/* No Roman markers, no vertical divider. Just a confident display title
   over a single hairline ink rule. */
.cv-section-head {
  margin: 72px 0 24px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--ink);
  line-height: 1.15;
}
.cv-section-head:first-of-type { margin-top: 0; }
.cv-section-head .cv-section-title {
  font-family: var(--serif-display);
  font-size: 1.95rem;
  font-weight: 400;
  letter-spacing: -0.018em;
  color: var(--ink);
}

/* ── Entry grid ────────────────────────────────────────────────────────── */
.cv-list { margin: 0; }
.cv-entry {
  display: grid;
  grid-template-columns: 168px 1fr;
  gap: 14px 36px;
  padding: 26px 0 28px;
  border-bottom: 1px solid var(--rule-soft);
}
.cv-entry:first-child { padding-top: 8px; }
.cv-entry:last-child { border-bottom: none; padding-bottom: 4px; }

.cv-date {
  font-family: var(--mono);
  font-size: 0.66rem;
  letter-spacing: 0.06em;
  color: var(--ink-mute);
  text-transform: uppercase;
  padding-top: 11px;
  font-weight: 500;
  font-feature-settings: "tnum" 1, "lnum" 1;
}
.cv-body {
  font-family: var(--serif-body);
  color: var(--ink);
  font-size: 1rem;
  line-height: 1.55;
}
.cv-position {
  font-family: var(--serif-display);
  font-size: 1.24rem;
  font-weight: 500;
  line-height: 1.22;
  color: var(--ink);
  letter-spacing: -0.012em;
}
.cv-institution {
  font-family: var(--serif-body);
  font-style: italic;
  font-size: 0.98rem;
  color: var(--ink-soft);
  margin-top: 3px;
  line-height: 1.4;
}
.cv-detail {
  margin-top: 10px;
  font-family: var(--serif-body);
  font-size: 0.95rem;
  line-height: 1.65;
  color: var(--ink-soft);
  max-width: 70ch;
}
.cv-detail em { font-style: italic; }
.cv-detail strong { font-weight: 600; color: var(--ink); }

/* ── Top-level bullets — refined hairline em-dash markers ─────────────── */
.cv-bullets {
  list-style: none;
  margin: 14px 0 0;
  padding: 0;
}
.cv-bullets li {
  font-family: var(--serif-body);
  font-size: 0.97rem;
  line-height: 1.6;
  color: var(--ink);
  padding-left: 24px;
  position: relative;
  margin-bottom: 10px;
}
.cv-bullets li:last-child { margin-bottom: 0; }
.cv-bullets li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.74em;
  width: 14px;
  height: 1px;
  background: var(--lu-bronze);
}
.cv-bullets li strong {
  font-family: var(--serif-body);
  font-weight: 600;
  color: var(--ink);
  letter-spacing: 0;
}
.cv-bullets li em { font-style: italic; }
.cv-bullets li sub { font-size: 0.78em; vertical-align: -0.18em; }

/* ── Sub-bullets — interpunct markers, lighter ink ────────────────────── */
.cv-sub {
  list-style: none;
  margin: 8px 0 4px;
  padding: 0;
}
.cv-sub li {
  font-family: var(--serif-body);
  font-size: 0.93rem;
  line-height: 1.58;
  color: var(--ink-soft);
  padding-left: 18px;
  position: relative;
  margin-bottom: 5px;
}
.cv-sub li:last-child { margin-bottom: 0; }
.cv-sub li::before {
  content: "·";
  position: absolute;
  left: 4px;
  top: -0.05em;
  color: var(--ink-mute);
  font-weight: 700;
  font-size: 1.2em;
  line-height: 1.6;
}
.cv-sub li strong {
  font-family: var(--serif-body);
  font-weight: 600;
  color: var(--ink);
}
.cv-sub li em { font-style: italic; }
.cv-sub li code {
  font-family: var(--mono);
  font-size: 0.78em;
  letter-spacing: 0.04em;
  color: var(--lu-bronze);
  background: transparent;
  padding: 1px 6px;
  border: 1px solid var(--rule-bronze);
  border-radius: 0;
  font-feature-settings: "tnum" 1;
  white-space: nowrap;
  vertical-align: 0.04em;
}

/* Code chips that appear inline in top-level bullets (e.g. co-taught) */
.cv-bullets li code {
  font-family: var(--mono);
  font-size: 0.8em;
  letter-spacing: 0.04em;
  color: var(--lu-bronze);
  background: transparent;
  padding: 1px 6px;
  border: 1px solid var(--rule-bronze);
  font-feature-settings: "tnum" 1;
  white-space: nowrap;
  vertical-align: 0.04em;
}

/* ── References note ─────────────────────────────────────────────────── */
.cv-note {
  max-width: 70ch;
  margin-top: 28px;
  font-family: var(--serif-body);
  font-size: 0.96rem;
  line-height: 1.65;
  color: var(--ink-soft);
}
.cv-note a {
  color: var(--ink);
  text-decoration: underline;
  text-decoration-color: var(--rule-soft);
  text-underline-offset: 3px;
  transition: text-decoration-color 0.18s ease;
}
.cv-note a:hover { text-decoration-color: var(--ink); }

/* ── Mobile collapse ──────────────────────────────────────────────────── */
@media (max-width: 720px) {
  .cv-section-head .cv-section-title { font-size: 1.5rem; }
  .cv-entry { grid-template-columns: 1fr; gap: 6px 0; padding: 22px 0; }
  .cv-date { padding-top: 0; }
}

/* ═══ Atlas key (themes) ═══ */

.atlas-key {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 8px;
  margin: 12px 0 0;
}
.atlas-key span {
  font-family: var(--mono);
  font-size: 0.66rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 3px 9px;
  border: 1px solid var(--rule-bronze);
  color: var(--ink-mute);
}

/* ═══ Forms ═══ */

form.contact {
  display: grid;
  gap: 18px;
  max-width: 640px;
  margin-top: 32px;
}
form.contact label {
  font-family: var(--mono);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mute);
  display: block;
  margin-bottom: 4px;
}
form.contact input, form.contact textarea {
  width: 100%;
  background: var(--paper);
  border: 1px solid var(--rule-soft);
  border-bottom: 1.5px solid var(--lu-bronze);
  padding: 12px 14px;
  font-family: var(--serif-body);
  font-size: 1.02rem;
  color: var(--ink);
  border-radius: 0;
  transition: border-color .2s, background .2s;
}
form.contact textarea { min-height: 160px; resize: vertical; }
form.contact input:focus, form.contact textarea:focus {
  outline: none;
  border-bottom-color: var(--lu-blue);
  background: var(--bone);
}
form.contact button {
  font-family: var(--sans);
  font-size: 0.82rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  background: var(--lu-blue);
  color: var(--bone);
  border: none;
  padding: 14px 30px;
  cursor: pointer;
  transition: background .2s;
  font-weight: 500;
  justify-self: start;
}
form.contact button:hover { background: var(--lu-bronze); }

/* ═══ Index of works (home grid) ═══ */

.index-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin: 56px 0 0;
}
@media (max-width: 880px) { .index-strip { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .index-strip { grid-template-columns: 1fr; } }

.idx-card {
  border-top: 1px solid var(--lu-bronze);
  padding-top: 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.idx-card .num {
  font-family: var(--mono);
  font-size: 0.7rem;
  color: var(--ink-mute);
  letter-spacing: 0.16em;
}
.idx-card .ttl {
  font-family: var(--serif-display);
  font-size: 1.1rem;
  font-weight: 500;
  line-height: 1.2;
  color: var(--ink);
}
.idx-card .sub {
  font-family: var(--sans);
  font-size: 0.78rem;
  color: var(--ink-mute);
  line-height: 1.5;
}
.idx-card a { color: var(--ink); background: none; }
.idx-card a:hover .ttl { color: var(--lu-blue); }

/* ═══ Print ═══ */

@media print {
  .masthead, footer.site, nav.primary, .specimen .links { display: none; }
  body { background: white; color: black; }
}

/* ═══ Institutional grouping (Teaching page: Courses by university) ═════════ */

:root {
  --lund-accent:    #9c6114; /* Lund bronze */
  --nui-accent:     #1f3a8a; /* Maynooth deep blue */
  --baskent-accent: #8b1a1a; /* Başkent burgundy */
}

.uni-block {
  margin-top: 56px;
  padding-top: 32px;
  border-top: 1px solid var(--rule-soft);
}
.uni-block:first-of-type {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}

.uni-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 28px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--lund-accent);
}
.uni-head.nui     { border-color: var(--nui-accent); }
.uni-head.baskent { border-color: var(--baskent-accent); }

.uni-name {
  font-family: var(--serif-display);
  font-size: 1.7rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  color: var(--ink);
}
.uni-name em { font-style: italic; color: var(--lund-accent); }
.uni-head.nui .uni-name em     { color: var(--nui-accent); }
.uni-head.baskent .uni-name em { color: var(--baskent-accent); }

.uni-meta {
  font-family: var(--mono);
  font-size: 0.72rem;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--ink-mute);
  text-align: right;
  white-space: nowrap;
  flex-shrink: 0;
}

.entry.uni-lund    { border-left: 3px solid var(--lund-accent);    padding-left: 22px; }
.entry.uni-nui     { border-left: 3px solid var(--nui-accent);     padding-left: 22px; }
.entry.uni-baskent { border-left: 3px solid var(--baskent-accent); padding-left: 22px; }

.entry.uni-lund .entry-title strong,
.entry.uni-nui .entry-title strong,
.entry.uni-baskent .entry-title strong {
  font-family: var(--mono);
  font-weight: 500;
  font-size: 0.86em;
  letter-spacing: 0.02em;
  margin-right: 4px;
}
.entry.uni-lund .entry-title strong    { color: var(--lund-accent); }
.entry.uni-nui .entry-title strong     { color: var(--nui-accent); }
.entry.uni-baskent .entry-title strong { color: var(--baskent-accent); }

/* ═══ Publication cards (Publications page) ════════════════════════════════ */

.pub-list {
  display: flex;
  flex-direction: column;
  margin-top: 8px;
}
details.pub-card {
  position: relative;
  padding: 22px 0;
  margin: 0;
  border-top: 1px solid var(--rule-soft);
}
details.pub-card:last-child { border-bottom: 1px solid var(--rule-soft); }
details.pub-card[open] { padding-bottom: 26px; }
details.pub-card > summary.pc-summary {
  cursor: pointer;
  list-style: none;
  outline: none;
  position: relative;
  padding-right: 32px;
}
details.pub-card > summary.pc-summary::-webkit-details-marker { display: none; }
details.pub-card > summary.pc-summary::marker { content: ''; }
details.pub-card > summary.pc-summary::after {
  content: '+';
  position: absolute;
  top: 0;
  right: 0;
  font-family: var(--mono);
  color: var(--ink-mute);
  font-size: 1rem;
  font-weight: 500;
  line-height: 1;
}
details.pub-card[open] > summary.pc-summary::after { content: '−'; color: var(--ink); }
details.pub-card > summary.pc-summary:hover .pc-title { color: var(--lu-bronze); }

.pub-card .pc-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px 24px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}
.pub-card .pc-title {
  font-family: var(--serif-display);
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.3;
  color: var(--ink);
  letter-spacing: -0.003em;
  margin: 0;
  flex: 1 1 60%;
  min-width: 280px;
  max-width: 820px;
}
.pub-card .pc-title em { font-style: italic; }
.pub-card .pc-title small {
  display: block;
  margin-top: 4px;
  font-family: var(--serif-display);
  font-style: italic;
  font-size: 0.92rem;
  color: var(--ink-soft);
  font-weight: 400;
}
.pub-card .pc-pills {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}

.pub-card .pc-cite-line {
  font-family: var(--serif-body);
  font-size: 0.94rem;
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0;
  max-width: 820px;
}
.pub-card .pc-cite-line b,
.pub-card .pc-cite-line strong { color: var(--ink); font-weight: 500; }
.pub-card .pc-cite-line em { font-style: italic; }
.pub-card .pc-cite-note {
  font-family: var(--serif-body);
  font-size: 0.84rem;
  line-height: 1.5;
  color: var(--ink-mute);
  margin: 4px 0 0;
  max-width: 820px;
  font-style: italic;
}
.pub-card .pc-cite-note em { font-style: normal; }
.pub-card .pc-asterisk {
  color: var(--ink-mute);
  font-weight: 500;
  font-style: normal;
  margin-right: 2px;
}

.pub-card .pc-body {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--rule-soft);
}
.pub-card .pc-abstract {
  font-size: 1rem;
  line-height: 1.65;
  color: var(--ink);
  margin: 0 0 18px;
  max-width: 760px;
}
.pub-card .pc-abstract p { margin: 0 0 0.9em; }
.pub-card .pc-abstract p:last-child { margin-bottom: 0; }

.pub-card .pc-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0;
}
.pub-card .pc-action {
  font-family: var(--mono);
  font-size: 0.66rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 6px 12px;
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--ink);
  text-decoration: none;
  cursor: pointer;
  font-weight: 500;
  line-height: 1.3;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.pub-card .pc-action:hover {
  background: var(--ink);
  color: var(--bone);
  border-color: var(--ink);
}
.pub-card .pc-cite-btn { font-family: var(--mono); }

.pub-card .pc-bibtex { display: none; }

.pill.pub-status-forthcoming { background: var(--lu-bronze); color: var(--bone); }
.pill.pub-status-open-access { background: var(--pastel-sage); color: var(--lu-blue); }
.pill.pub-status-turkish     { background: var(--pastel-sage); color: var(--lu-blue); }

/* ═══ Course cards (Teaching page) ═════════════════════════════════════════ */

.course-list {
  display: flex;
  flex-direction: column;
  gap: 28px;
  margin-top: 12px;
}

.course-card {
  position: relative;
  padding: 30px 32px;
  background: var(--bone);
  border: 1px solid var(--rule-soft);
  border-left-width: 4px;
}
.course-card.status-current {
  border-left-color: var(--ink-mute);
  background: linear-gradient(to right, rgba(156, 97, 20, 0.05), transparent 30%);
}
.course-card.status-past {
  border-left-color: var(--rule-soft);
  background: var(--paper);
}

.course-card .cc-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 20px 28px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.course-card .cc-id { flex: 1 1 60%; min-width: 280px; }

.course-card .cc-code {
  font-family: var(--mono);
  font-size: 0.86rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--ink-mute);
  display: block;
  margin-bottom: 8px;
}
.course-card.status-past .cc-code { color: var(--ink-mute); }

.course-card .cc-title {
  font-family: var(--serif-display);
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.25;
  color: var(--ink);
  letter-spacing: -0.003em;
  margin: 0;
}
.course-card .cc-title em { font-style: italic; }

.course-card .pills {
  display: flex;
  flex-direction: column;
  gap: 5px;
  flex-shrink: 0;
  align-items: flex-end;
}
.course-card .pills-row {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.pill {
  font-family: var(--mono);
  font-size: 0.6rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 4px 10px;
  font-weight: 500;
  white-space: nowrap;
  line-height: 1.3;
}
.pill.status-current  { background: var(--lu-bronze); color: var(--bone); }
.pill.status-past     { background: rgba(156, 97, 20, 0.14); color: var(--ink-mute); }
.pill.role-convenor   { background: var(--lu-blue); color: var(--bone); }
.pill.role-co-convenor{ background: var(--pastel-pink); color: var(--lu-blue); }
.pill.role-lecturer   { background: rgba(0, 0, 128, 0.10); color: var(--lu-blue); }
.pill.language-turkish{ background: var(--pastel-sage); color: var(--lu-blue); }

.course-card .cc-meta {
  font-family: var(--mono);
  font-size: 0.7rem;
  letter-spacing: 0.06em;
  color: var(--ink-mute);
  text-transform: uppercase;
  margin-bottom: 16px;
  line-height: 1.55;
}
.course-card .cc-meta b { color: var(--ink-soft); font-weight: 500; }

.course-card .cc-body {
  font-size: 1rem;
  line-height: 1.62;
  color: var(--ink);
  max-width: 820px;
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--rule-soft);
}
.course-card.status-past .cc-body { color: var(--ink-soft); }
.course-card .cc-body p { margin-bottom: 0.8em; }
.course-card .cc-body p:last-child { margin-bottom: 0; }

/* MOOC panels — collapsible, each MOOC its own panel with nested lectures */
.mooc-list {
  display: flex;
  flex-direction: column;
  gap: 32px;
  margin-top: 8px;
}
details.mooc-card {
  position: relative;
  padding: 22px 0;
  margin: 0;
  border-top: 1px solid var(--rule-soft);
  border-bottom: 1px solid var(--rule-soft);
}
details.mooc-card[open] { padding-bottom: 28px; }
details.mooc-card > summary.mc-summary {
  cursor: pointer;
  list-style: none;
  outline: none;
  position: relative;
  padding-right: 32px;
}
details.mooc-card > summary.mc-summary::-webkit-details-marker { display: none; }
details.mooc-card > summary.mc-summary::marker { content: ''; }
details.mooc-card > summary.mc-summary::after {
  content: '−';
  position: absolute;
  top: 0;
  right: 0;
  font-family: var(--mono);
  color: var(--ink);
  font-size: 1rem;
  font-weight: 500;
  line-height: 1;
}
details.mooc-card:not([open]) > summary.mc-summary::after { content: '+'; color: var(--ink-mute); }
details.mooc-card > summary.mc-summary:hover .mc-title { color: var(--lu-bronze); }

.mooc-card .mc-title {
  font-family: var(--serif-display);
  font-size: 1.35rem;
  font-weight: 500;
  line-height: 1.3;
  color: var(--ink);
  letter-spacing: -0.005em;
  margin: 0 0 12px;
  max-width: 820px;
}
.mooc-card .mc-meta {
  display: grid;
  grid-template-columns: 96px 1fr;
  column-gap: 18px;
  row-gap: 4px;
  font-family: var(--mono);
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1.55;
  margin: 0;
  max-width: 820px;
}
.mooc-card .mc-meta dt {
  color: var(--ink-mute);
  font-weight: 500;
  letter-spacing: 0.12em;
}
.mooc-card .mc-meta dd {
  color: var(--ink-mute);
  margin: 0;
}
.mooc-card .mc-meta dd strong { color: var(--ink); font-weight: 500; }

.mooc-card .mc-body {
  margin-top: 22px;
  padding-top: 22px;
  border-top: 1px solid var(--rule-soft);
}
.mooc-card .mc-intro {
  font-size: 1rem;
  line-height: 1.65;
  color: var(--ink);
  max-width: 760px;
  margin: 0 0 28px;
}

.mooc-lectures {
  display: flex;
  flex-direction: column;
  gap: 20px;
  border-left: 2px solid var(--rule-bronze);
  padding-left: 22px;
  max-width: 800px;
}
.mooc-lecture { margin: 0; }
.mooc-lecture .ml-title {
  font-family: var(--serif-display);
  font-size: 1.05rem;
  font-weight: 500;
  line-height: 1.3;
  color: var(--ink);
  margin: 0 0 6px;
  letter-spacing: -0.003em;
}
.mooc-lecture .ml-title em { font-style: italic; }
.mooc-lecture .ml-body {
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--ink-soft);
  margin: 0;
  max-width: 720px;
}
@media (max-width: 600px) {
  .mooc-card .mc-meta { grid-template-columns: 80px 1fr; column-gap: 12px; }
  .mooc-lectures { padding-left: 16px; }
}

/* Talk cards — collapsible if body present, static otherwise; auto-numbered.
   The counter starts at total+1 (set inline by data_talks.py) and decrements
   per card, so the oldest entry at the bottom of the list shows 01 and the
   most recent at the top shows the highest number. The number sits in a
   fixed left gutter (absolutely positioned) so the title and the meta
   labels both start at the same x position. */
.talk-list {
  display: flex;
  flex-direction: column;
  margin-top: 8px;
}
.talk-card { counter-increment: tk-counter -1; }
.talk-card .tk-idx::before {
  content: counter(tk-counter, decimal-leading-zero);
}
.talk-card .tk-idx {
  position: absolute;
  top: 0;
  left: -44px;
  font-family: var(--mono);
  font-size: 0.66rem;
  letter-spacing: 0.14em;
  font-weight: 500;
  color: var(--ink-mute);
  width: 32px;
  text-align: left;
  pointer-events: none;
  padding-top: 6px;
}
details.talk-card,
article.talk-card {
  position: relative;
  padding: 22px 0 22px 44px;
  margin: 0;
  border-top: 1px solid var(--rule-soft);
}
details.talk-card:last-child,
article.talk-card:last-child { border-bottom: 1px solid var(--rule-soft); }
details.talk-card[open] { padding-bottom: 26px; }
details.talk-card > summary.tk-summary {
  cursor: pointer;
  list-style: none;
  outline: none;
  position: relative;
  padding-right: 32px;
}
details.talk-card > summary.tk-summary::-webkit-details-marker { display: none; }
details.talk-card > summary.tk-summary::marker { content: ''; }
details.talk-card > summary.tk-summary::after {
  content: '+';
  position: absolute;
  top: 0;
  right: 0;
  font-family: var(--mono);
  color: var(--ink-mute);
  font-size: 1rem;
  font-weight: 500;
  line-height: 1;
}
details.talk-card[open] > summary.tk-summary::after { content: '−'; color: var(--ink); }
details.talk-card > summary.tk-summary:hover .tk-title { color: var(--lu-bronze); }

.talk-card .tk-head {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px 24px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.talk-card .tk-title {
  font-family: var(--serif-display);
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.3;
  color: var(--ink);
  letter-spacing: -0.003em;
  margin: 0;
  flex: 1 1 60%;
  min-width: 280px;
  max-width: 820px;
  hyphens: manual;
  -webkit-hyphens: manual;
  text-align: left;
}
.talk-card .tk-meta dd {
  hyphens: manual;
  -webkit-hyphens: manual;
}
.talk-card .tk-title em { font-style: italic; }
.talk-card .tk-title strong { font-weight: 600; color: var(--ink); }
.talk-card .tk-pills {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}

.talk-card .tk-meta {
  display: grid;
  grid-template-columns: 96px 1fr;
  column-gap: 18px;
  row-gap: 4px;
  font-family: var(--mono);
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1.55;
  margin: 0;
  max-width: 820px;
}
.talk-card .tk-meta dt {
  color: var(--ink-mute);
  font-weight: 500;
  letter-spacing: 0.12em;
}
.talk-card .tk-meta dd {
  color: var(--ink-mute);
  margin: 0;
}
.talk-card .tk-meta dd strong { color: var(--ink); font-weight: 500; }
.talk-card .tk-meta dd em { font-style: italic; }
@media (max-width: 600px) {
  .talk-card .tk-meta { grid-template-columns: 80px 1fr; column-gap: 12px; }
}

.talk-card .tk-body {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--rule-soft);
}
.talk-card .tk-abstract {
  font-size: 1rem;
  line-height: 1.65;
  color: var(--ink);
  max-width: 760px;
}
.talk-card .tk-abstract p { margin: 0 0 0.9em; }
.talk-card .tk-abstract p:last-child { margin-bottom: 0; }
.talk-card .tk-abstract p.acknowledgement {
  margin-top: 18px;
  font-family: var(--mono);
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  color: var(--ink-mute);
  font-style: normal;
}

.talk-card .tk-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}
.talk-card .tk-action {
  font-family: var(--mono);
  font-size: 0.66rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 6px 12px;
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--ink);
  text-decoration: none;
  font-weight: 500;
  line-height: 1.3;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.talk-card .tk-action:hover {
  background: var(--ink);
  color: var(--bone);
  border-color: var(--ink);
}

.pill.talk-status-forthcoming { background: var(--lu-bronze); color: var(--bone); }
.pill.talk-status-turkish     { background: var(--pastel-sage); color: var(--lu-blue); }

/* Invited lecture cards — collapsible, distinct from course cards: top bronze rule, no pills */
.lecture-list {
  display: flex;
  flex-direction: column;
  margin-top: 8px;
}
details.lecture-card {
  position: relative;
  padding: 22px 0 22px;
  margin: 0;
  border-top: 1px solid var(--rule-soft);
}
details.lecture-card:last-child { border-bottom: 1px solid var(--rule-soft); }
details.lecture-card[open] { padding-bottom: 26px; }
details.lecture-card > summary.lc-summary {
  cursor: pointer;
  list-style: none;
  outline: none;
  position: relative;
  padding-right: 32px;
}
details.lecture-card > summary.lc-summary::-webkit-details-marker { display: none; }
details.lecture-card > summary.lc-summary::marker { content: ''; }
details.lecture-card > summary.lc-summary::after {
  content: '+';
  position: absolute;
  top: 0;
  right: 0;
  font-family: var(--mono);
  color: var(--ink-mute);
  font-size: 1rem;
  font-weight: 500;
  line-height: 1;
}
details.lecture-card[open] > summary.lc-summary::after { content: '−'; color: var(--ink); }
details.lecture-card > summary.lc-summary:hover .lc-title { color: var(--lu-bronze); }

.lecture-card .lc-title {
  font-family: var(--serif-display);
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 1.3;
  color: var(--ink);
  letter-spacing: -0.003em;
  margin: 0 0 10px;
  max-width: 820px;
}
.lecture-card .lc-title em { font-style: italic; }

.lecture-card .lc-meta {
  display: grid;
  grid-template-columns: 96px 1fr;
  column-gap: 18px;
  row-gap: 4px;
  font-family: var(--mono);
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1.55;
  margin: 0;
  max-width: 820px;
}
.lecture-card .lc-meta dt {
  color: var(--ink-mute);
  font-weight: 500;
  letter-spacing: 0.12em;
}
.lecture-card .lc-meta dd {
  color: var(--ink-mute);
  margin: 0;
  word-break: normal;
  overflow-wrap: break-word;
}
.lecture-card .lc-meta dd strong {
  color: var(--ink);
  font-weight: 500;
}
@media (max-width: 600px) {
  .lecture-card .lc-meta { grid-template-columns: 80px 1fr; column-gap: 12px; }
}

.lecture-card .lc-body {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--rule-soft);
  font-size: 1rem;
  line-height: 1.65;
  color: var(--ink);
  max-width: 760px;
}
.lecture-card .lc-body p { margin: 0; }

/* Collapsible course-card: each course expands to reveal its description */
details.course-card { margin: 0; }
details.course-card > summary.cc-summary {
  cursor: pointer;
  list-style: none;
  outline: none;
  position: relative;
}
details.course-card > summary.cc-summary::-webkit-details-marker { display: none; }
details.course-card > summary.cc-summary::marker { content: ''; }
details.course-card > summary.cc-summary::after {
  content: '+';
  position: absolute;
  right: 0;
  bottom: 0;
  font-family: var(--mono);
  color: var(--ink-mute);
  font-size: 0.95rem;
  font-weight: 500;
  line-height: 1;
  pointer-events: none;
}
details.course-card[open] > summary.cc-summary::after { content: '−'; color: var(--ink); }
details.course-card > summary.cc-summary .cc-meta { margin-bottom: 0; padding-right: 24px; }
details.course-card > summary.cc-summary:hover .cc-title { color: var(--lu-bronze); }

/* Collapsible section folds — entire section can be collapsed by clicking the heading */
.section-fold { margin: 0; }
.section-fold > summary.section-head {
  cursor: pointer;
  list-style: none;
  outline: none;
}
.section-fold > summary.section-head::-webkit-details-marker { display: none; }
.section-fold > summary.section-head::marker { content: ''; }
.section-fold > summary.section-head::after {
  content: '−';
  margin-left: auto;
  padding-left: 14px;
  font-family: var(--mono);
  color: var(--ink-mute);
  font-size: 1.1rem;
  font-weight: 500;
  align-self: center;
  flex-shrink: 0;
}
.section-fold:not([open]) > summary.section-head::after { content: '+'; }
.section-fold > summary.section-head:hover::after { color: var(--ink); }

/* Outcomes — HORIZONTAL three-column row, compact */
.outcomes-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin: 30px 0 44px;
  padding: 0;
  list-style: none;
  max-width: 720px;
}
.outcomes-list li {
  border-top: 2px solid var(--lu-bronze);
  padding-top: 16px;
  font-family: var(--serif-body);
  font-size: 0.96rem;
  line-height: 1.55;
  color: var(--ink-soft);
  text-align: left;
  hyphens: manual;
  -webkit-hyphens: manual;
}
.outcomes-list li .o-name {
  display: block;
  font-family: var(--serif-display);
  font-style: italic;
  font-weight: 500;
  font-size: 1.25rem;
  color: var(--ink);
  margin-bottom: 8px;
  letter-spacing: -0.005em;
}
@media (max-width: 800px) {
  .outcomes-list { grid-template-columns: 1fr; gap: 22px; }
}

/* Philosophy — classical typographic treatment */
.philosophy-text {
  max-width: 720px;
  font-family: var(--serif-body);
  font-size: 1.05rem;
  line-height: 1.72;
  color: var(--ink);
  hyphens: manual;
  -webkit-hyphens: manual;
}
.philosophy-text p { margin-bottom: 1.1em; }
.philosophy-text p:last-child { margin-bottom: 0; }

.philosophy-lede {
  margin-top: 8px;
  font-size: 1.1rem;
  line-height: 1.65;
}

.dropcap {
  float: left;
  font-family: var(--serif-display);
  font-size: 4.4rem;
  line-height: 0.88;
  font-weight: 500;
  color: var(--ink-mute);
  padding: 4px 14px 0 0;
  margin-top: 6px;
}

.fn-ref {
  font-family: var(--mono);
  font-size: 0.6em;
  vertical-align: super;
  line-height: 0;
  margin-left: 1px;
}
.fn-ref a {
  color: var(--ink-mute);
  text-decoration: none;
  border: none;
  padding: 0 1px;
  font-weight: 500;
}
.fn-ref a:hover { color: var(--lu-blue); }

.philosophy-sources {
  max-width: 720px;
  margin-top: 40px;
  padding-top: 22px;
  border-top: 1px solid var(--rule-soft);
}
.philosophy-sources h6 {
  font-family: var(--mono);
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 16px;
  font-weight: 500;
}
.philosophy-sources ol {
  list-style: none;
  counter-reset: src;
  padding-left: 0;
  margin: 0;
  font-family: var(--serif-body);
  font-size: 0.85rem;
  line-height: 1.55;
  color: var(--ink-soft);
}
.philosophy-sources ol li {
  counter-increment: src;
  position: relative;
  padding-left: 28px;
  margin-bottom: 10px;
}
.philosophy-sources ol li:last-child { margin-bottom: 0; }
.philosophy-sources ol li::before {
  content: counter(src);
  position: absolute;
  left: 0;
  top: 0;
  font-family: var(--mono);
  font-size: 0.7rem;
  color: var(--ink-mute);
  font-weight: 500;
  padding-top: 2px;
}
.philosophy-sources ol li em { font-style: italic; color: var(--ink); }

/* Smooth scroll-and-highlight when a footnote anchor is clicked */
.philosophy-sources ol li:target { background: rgba(156, 97, 20, 0.08); padding-top: 4px; padding-bottom: 4px; padding-right: 8px; }

/* Pillars — VERTICAL stack, each pillar collapsible */
.pillars {
  display: flex;
  flex-direction: column;
  margin: 24px 0 4px;
  max-width: 720px;
  border-top: 1px solid var(--rule-soft);
}
.pillar {
  border-bottom: 1px solid var(--rule-soft);
}
.pillar > summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: baseline;
  gap: 14px;
  padding: 12px 0;
  outline: none;
}
.pillar > summary::-webkit-details-marker { display: none; }
.pillar > summary::marker { content: ''; }
.pillar > summary::after {
  content: '+';
  margin-left: auto;
  font-family: var(--mono);
  color: var(--ink-mute);
  font-size: 0.9rem;
  font-weight: 500;
  width: 12px;
  text-align: right;
}
.pillar[open] > summary::after { content: '−'; color: var(--ink); }

.pillar .p-num {
  font-family: var(--serif-display);
  font-style: italic;
  color: var(--ink-mute);
  font-size: 1.05rem;
  font-weight: 500;
  flex-shrink: 0;
  width: 28px;
  letter-spacing: 0.04em;
}
.pillar .p-name {
  font-family: var(--serif-display);
  font-size: 1.08rem;
  font-weight: 500;
  letter-spacing: -0.003em;
  line-height: 1.25;
  color: var(--ink);
}
.pillar .p-body {
  margin: 2px 0 16px 42px;
  max-width: 680px;
  font-size: 0.92rem;
  line-height: 1.6;
  color: var(--ink-soft);
}
@media (max-width: 720px) {
  .pillar .p-body { margin-left: 0; }
  .pillar > summary { gap: 10px; }
}

/* Collapsible entries (used for past courses) */
.entry-collapsible {
  padding: 14px 0;
  border-bottom: 1px solid var(--rule-soft);
  border-left: none !important;
  padding-left: 0 !important;
}
.entry-collapsible[open] { padding-bottom: 22px; }
.entry-collapsible:last-of-type { border-bottom: none; }

.entry-collapsible summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: baseline;
  gap: 14px 22px;
  flex-wrap: wrap;
  padding: 4px 0;
  outline: none;
}
.entry-collapsible summary::-webkit-details-marker { display: none; }
.entry-collapsible summary::marker { content: ''; }

.entry-collapsible summary::before {
  content: '+';
  font-family: var(--mono);
  font-size: 0.95rem;
  color: var(--ink-mute);
  width: 14px;
  flex-shrink: 0;
  font-weight: 500;
  transition: color .2s;
}
.entry-collapsible[open] summary::before { content: '−'; color: var(--ink); }
.entry-collapsible summary:hover::before { color: var(--ink); }

.entry-collapsible .ec-title {
  font-family: var(--serif-display);
  font-size: 1.06rem;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.005em;
  flex: 1;
  min-width: 240px;
}
.entry-collapsible .ec-title strong {
  font-family: var(--mono);
  font-weight: 500;
  font-size: 0.86em;
  letter-spacing: 0.02em;
  color: var(--ink-mute);
  margin-right: 6px;
}
.entry-collapsible .ec-meta {
  font-family: var(--mono);
  font-size: 0.66rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-mute);
  white-space: nowrap;
}
.entry-collapsible .entry-body {
  margin-top: 14px;
  padding-left: 30px;
  border-left: 1px solid var(--rule-soft);
  color: var(--ink-soft);
  font-size: 0.96rem;
}

/* Past-courses container — muted */
.past-courses {
  margin-top: 16px;
  padding-top: 8px;
}
.past-courses .ec-title strong { color: var(--ink-mute); }

/* Past-courses sub-grouping (university label inside the collapsible block) */
.past-uni-label {
  font-family: var(--mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 22px 0 6px;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--rule-soft);
}
.past-uni-label:first-of-type { margin-top: 4px; }
.past-uni-label em { font-style: italic; color: var(--ink-soft); letter-spacing: 0; text-transform: none; font-size: 1em; }

/* Course index grid (top of Courses section: visual key of all codes) */
.course-index {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 8px;
  margin: 0 0 40px;
  padding: 18px;
  background: var(--paper);
  border: 1px solid var(--rule-soft);
}
.course-index .ci-item {
  font-family: var(--mono);
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
  padding: 6px 8px;
  border-left: 2px solid var(--lund-accent);
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.course-index .ci-item.nui     { border-left-color: var(--nui-accent); }
.course-index .ci-item.baskent { border-left-color: var(--baskent-accent); }
.course-index .ci-item .ci-code {
  font-weight: 500;
  text-transform: uppercase;
  color: var(--ink);
}
.course-index .ci-item .ci-yr {
  font-size: 0.62rem;
  color: var(--ink-mute);
  letter-spacing: 0.08em;
}

/* ═══ Entry card (no number column, no coordinates) ════════════════════════ */

.entry {
  padding: 26px 0;
  border-bottom: 1px solid var(--rule-soft);
}
.entry:last-child { border-bottom: none; }
.entry:first-child { padding-top: 4px; }

.entry-title {
  font-family: var(--serif-display);
  font-size: 1.32rem;
  font-weight: 500;
  margin: 0 0 6px;
  letter-spacing: -0.005em;
  line-height: 1.28;
  color: var(--ink);
}
.entry-title em { color: var(--ink-mute); font-style: italic; }
.entry-title strong { font-weight: 600; }

.entry-meta {
  font-family: var(--mono);
  font-size: 0.7rem;
  letter-spacing: 0.05em;
  color: var(--ink-mute);
  text-transform: uppercase;
  margin: 0 0 12px;
  font-style: normal;
  line-height: 1.6;
}
.entry-meta b { color: var(--ink-soft); font-weight: 500; }
.entry-meta em { font-style: italic; text-transform: none; letter-spacing: 0; }

.entry-body {
  font-size: 1rem;
  line-height: 1.62;
  color: var(--ink);
  max-width: 760px;
  margin: 0 0 12px;
}
.entry-body p { margin-bottom: 0.7em; }
.entry-body p:last-child { margin-bottom: 0; }

.entry-links {
  display: flex;
  gap: 12px;
  margin: 8px 0 12px;
  flex-wrap: wrap;
  align-items: center;
}
.entry-links a, .entry-links button {
  font-family: var(--sans);
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 500;
  border: 1px solid var(--rule-bronze);
  padding: 5px 11px;
  background: transparent;
  cursor: pointer;
  transition: background .2s, color .2s, border-color .2s;
  background-image: none;
}
.entry-links a:hover, .entry-links button:hover {
  background: var(--pastel-pink);
  color: var(--lu-blue);
  border-color: var(--lu-blue);
}

/* ═══ Subsection head (used inside a section.body for grouping items) ═══════ */

.subsection-head {
  font-family: var(--serif-display);
  font-size: 1.18rem;
  font-style: italic;
  font-weight: 500;
  color: var(--ink-mute);
  margin: 36px 0 16px;
  letter-spacing: 0.005em;
  border-bottom: 1px solid var(--rule-soft);
  padding-bottom: 6px;
}
.subsection-head:first-child { margin-top: 0; }

.subsection-head .count {
  font-family: var(--mono);
  font-size: 0.66rem;
  letter-spacing: 0.10em;
  color: var(--ink-mute);
  text-transform: uppercase;
  font-style: normal;
  margin-left: 12px;
  vertical-align: 2px;
}

/* ═══ Prose list (used on Home, Service, Research) ═══════════════════════════ */

.prose-list {
  max-width: 760px;
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.prose-list > p {
  font-size: 1.04rem;
  line-height: 1.6;
  color: var(--ink);
  margin: 0;
  position: relative;
  padding-left: 28px;
  border-left: 1px solid transparent;
  transition: border-color .25s, padding-left .25s;
}

.prose-list > p::before {
  content: '—';
  position: absolute;
  left: 0;
  top: 0;
  color: var(--ink-mute);
  font-family: var(--serif-display);
  font-style: italic;
}

.prose-list > p:hover {
  border-left-color: var(--rule-bronze);
}

.prose-list > p strong {
  font-weight: 600;
  color: var(--ink);
}

.prose-list > p em {
  font-style: italic;
}

.prose-list > p a {
  color: var(--lu-blue);
}

.prose-list .more {
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

p.more-link {
  margin-top: 28px;
  font-family: var(--sans);
  font-size: 0.82rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

p.more-link a {
  color: var(--ink-mute);
  font-weight: 500;
}

.affiliation-note {
  font-family: var(--mono);
  font-size: 0.74rem;
  letter-spacing: 0.06em;
  color: var(--ink-mute);
  margin-top: 22px;
  text-transform: uppercase;
}

.affiliation-note a {
  color: var(--ink-mute);
  background-image: linear-gradient(currentColor, currentColor);
  background-size: 0 1px;
}
.affiliation-note a:hover { background-size: 100% 1px; }

/* ═══ Reduced motion already default ═══ */
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}
