/* Get Tirzepatide — Baroque cabinet aesthetic
   Pitch-black ground, oxblood crimson, gold-leaf, ivory text, indigo accent.
   Cormorant Garamond (display italic) + Playfair Display (heading) + Cinzel (inscription caps) + EB Garamond (body) + JetBrains Mono.
*/

:root {
  --primary:      #8B0000;
  --primary-50:   #FBEAEA;
  --primary-300:  #C24747;
  --primary-700:  #5E0000;
  --primary-900:  #3A0000;
  --secondary:    #0D0D0D;
  --accent:       #DAA520;
  --accent-50:    #FBF3DA;
  --accent-300:   #E6C45E;
  --accent-700:   #9C7616;
  --accent-900:   #5C440B;
  --indigo:       #4B0082;
  --indigo-300:   #6A2EB0;
  --forest:       #046307;
  --burnt:        #E97451;
  --cream:        #F7E7CE;
  --ivory:        #FFFFF0;

  --bg:           #0D0D0D;
  --surface:      #14100D;
  --surface-elev: #1C1611;
  --surface-panel:#221A14;
  --surface-panel-warm: #2D241D;

  --text:         #FFFFF0;
  --text-muted:   #C9B584;
  --text-dim:     #8B7B5E;

  --rule:         #3A2E22;
  --rule-gold:    #DAA520;
  --rule-crimson: #8B0000;

  --max-width:    74rem;
  --container-px: clamp(1rem, 3vw, 2.5rem);

  --font-display: 'Cormorant Garamond', 'Garamond', 'EB Garamond', 'Times New Roman', serif;
  --font-heading: 'Playfair Display', 'Cormorant Garamond', 'Bodoni 72', 'Didot', serif;
  --font-inscription: 'Cinzel', 'Trajan Pro', 'Cormorant SC', Georgia, serif;
  --font-body:    'EB Garamond', 'Garamond', 'Adobe Garamond', 'Times New Roman', serif;
  --font-mono:    'JetBrains Mono', 'IBM Plex Mono', 'Courier New', monospace;

  --radius:       0;

  --radial-glow:  radial-gradient(ellipse at 35% 30%, rgba(218,165,32,0.18) 0%, rgba(139,0,0,0.10) 40%, rgba(13,13,13,0) 78%);
  --shadow-card:  0 8px 32px rgba(0,0,0,0.45);
}

/* ===== Reset / base ===== */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background-color: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 1.0625rem;
  line-height: 1.65;
  font-feature-settings: "onum" 1, "kern" 1, "liga" 1;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img { max-width: 100%; height: auto; display: block; }
hr { border: 0; border-top: 1px solid var(--rule); margin: 2rem 0; }
button { font-family: inherit; }

a {
  color: var(--accent);
  text-decoration: none;
  transition: color 300ms ease-out, text-decoration-color 300ms ease-out;
}
a:hover {
  color: var(--accent-300);
  text-decoration: underline;
  text-decoration-color: var(--accent);
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
a:visited { color: var(--accent-700); }
a:focus-visible {
  outline: 3px solid var(--accent);
  outline-offset: 2px;
  box-shadow: 0 0 12px rgba(218,165,32,0.5);
}

::selection { background: rgba(218,165,32,0.35); color: var(--ivory); }

/* ===== Typography ===== */
h1, h2, h3, h4 {
  font-family: var(--font-heading);
  color: var(--ivory);
  line-height: 1.12;
  margin: 0 0 1rem;
  font-weight: 700;
  letter-spacing: -0.01em;
}
h1 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(3rem, 7vw, 5.75rem);
  line-height: 1.04;
  letter-spacing: -0.005em;
  margin: 0 0 1.25rem;
}
h2 { font-size: clamp(2rem, 4.25vw, 3.25rem); margin: 0 0 1rem; }
h3 { font-size: 1.625rem; margin: 0 0 0.75rem; }
h4 { font-size: 1.25rem; margin: 0 0 0.5rem; }

p { margin: 0 0 1.15rem; }
p.lede {
  font-size: 1.3125rem;
  line-height: 1.5;
  color: var(--ivory);
  font-style: italic;
  max-width: 64ch;
  margin-left: auto;
  margin-right: auto;
}

.eyebrow {
  font-family: var(--font-inscription);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.8125rem;
  color: var(--accent);
  margin: 0 0 0.85rem;
}

ul, ol { padding-left: 1.4rem; margin: 0 0 1.15rem; }
li { margin-bottom: 0.4rem; }

ol.roman-list {
  list-style: none;
  padding-left: 0;
  counter-reset: roman;
}
ol.roman-list > li {
  counter-increment: roman;
  position: relative;
  padding-left: 3rem;
  margin-bottom: 1.5rem;
}
ol.roman-list > li::before {
  content: counter(roman, upper-roman) ".";
  position: absolute;
  left: 0;
  top: 0;
  width: 2.2rem;
  font-family: var(--font-inscription);
  font-weight: 600;
  color: var(--accent);
  letter-spacing: 0.08em;
}

blockquote {
  margin: 1.75rem 0;
  padding: 1.25rem 2rem;
  border-left: 2px solid var(--indigo);
  border-right: 2px solid var(--indigo);
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.5rem;
  line-height: 1.4;
  color: var(--ivory);
  text-align: center;
  background: rgba(75,0,130,0.04);
}

code, pre, .mono {
  font-family: var(--font-mono);
  font-size: 0.9em;
  letter-spacing: 0.02em;
}
code {
  background: var(--surface-panel);
  color: var(--accent-300);
  border: 1px solid var(--accent);
  padding: 0.05rem 0.4rem;
  border-radius: 0;
}

sup { font-size: 0.7em; line-height: 1; vertical-align: super; }
sup a.cite {
  font-family: var(--font-inscription);
  color: var(--accent);
  text-decoration: none;
  font-weight: 600;
  letter-spacing: 0.05em;
  padding: 0 0.05em;
}
sup a.cite:hover { color: var(--accent-300); }

/* Drop cap */
.drop-cap::first-letter {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 700;
  color: var(--accent);
  float: left;
  font-size: 5.25em;
  line-height: 0.85;
  padding: 0.05em 0.15em 0 0;
  margin-top: 0.05em;
}

/* ===== Layout / container ===== */
.container {
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
  padding-left: var(--container-px);
  padding-right: var(--container-px);
}
main { display: block; }

/* ===== Header / nav ===== */
.site-header {
  position: relative;
  padding: 0 0 0.75rem;
  background: linear-gradient(180deg, rgba(13,13,13,1) 0%, rgba(13,13,13,0.96) 100%);
  border-top: 6px solid;
  border-image: linear-gradient(90deg, #B8860B, #DAA520, #B8860B) 1;
}
.mast {
  text-align: center;
  padding: 1.5rem 0 0.5rem;
}
.mast-cartouche {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.25rem 1.25rem;
  border: 1px solid var(--accent);
  position: relative;
}
.mast-cartouche::before,
.mast-cartouche::after {
  content: "";
  display: inline-block;
  width: 36px; height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
.site-brand {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 600;
  font-size: 1.5rem;
  color: var(--ivory);
  letter-spacing: 0.01em;
}
.site-brand:hover { color: var(--accent); text-decoration: none; }
.mast-inscription {
  display: block;
  font-family: var(--font-inscription);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--accent);
  font-size: 0.7rem;
  margin-top: 0.6rem;
}
.mast-rule {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  margin: 0.85rem auto 0;
  max-width: 480px;
}

.site-nav {
  padding-top: 0.75rem;
}
.site-nav ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0;
}
.site-nav li {
  margin: 0;
  display: inline-flex;
  align-items: center;
}
.site-nav li:not(:last-child)::after {
  content: "\2766";
  color: var(--accent);
  margin: 0 0.85rem;
  font-size: 0.8rem;
  opacity: 0.7;
}
.site-nav a {
  font-family: var(--font-inscription);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.78rem;
  color: var(--ivory);
  padding: 0.5rem 0.1rem;
}
.site-nav a:hover { color: var(--accent); text-decoration: none; }
.site-nav a[aria-current="page"] {
  color: var(--accent);
  border-bottom: 3px double var(--accent);
  padding-bottom: 0.2rem;
}

/* ===== Hero ===== */
.hero {
  position: relative;
  padding: 4rem 0 3rem;
  text-align: center;
  background-color: var(--bg);
  background-image: var(--radial-glow);
  overflow: hidden;
}
.hero .hero-frame {
  max-width: 56rem;
  margin: 0 auto;
  padding: 2.5rem 2rem;
  border: 1.5px solid var(--accent);
  position: relative;
  background: rgba(28,22,17,0.55);
}
.hero .hero-frame::before,
.hero .hero-frame::after {
  content: "";
  position: absolute;
  width: 16px; height: 16px;
  border: 1.5px solid var(--accent);
  border-right: 0; border-bottom: 0;
}
.hero .hero-frame::before { top: -1.5px; left: -1.5px; }
.hero .hero-frame::after  { top: -1.5px; right: -1.5px; border-left: 0; border-right: 1.5px solid var(--accent); }
.hero .corner-tr,
.hero .corner-bl,
.hero .corner-br {
  position: absolute;
  width: 16px; height: 16px;
  border: 1.5px solid var(--accent);
}
.hero .corner-bl { bottom: -1.5px; left: -1.5px; border-top: 0; border-right: 0; }
.hero .corner-br { bottom: -1.5px; right: -1.5px; border-top: 0; border-left: 0; }
.hero h1 { color: var(--ivory); }
.hero .subheadline {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 1.25rem;
  line-height: 1.5;
  color: var(--text-muted);
  max-width: 56ch;
  margin: 1.25rem auto 0;
}
.hero .filigree {
  text-align: center;
  margin: 1.5rem auto 1rem;
  color: var(--accent);
  font-size: 1.2rem;
  letter-spacing: 1.5em;
  opacity: 0.9;
}

.cta-row {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 1.5rem;
}

/* Inscription tablets */
.tablets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 0;
  max-width: 60rem;
  margin: 2rem auto 0;
  border: 1.5px solid var(--accent);
  background: rgba(13,13,13,0.6);
}
.tablet {
  padding: 0.85rem 0.75rem;
  text-align: center;
  border-right: 1px solid rgba(218,165,32,0.4);
}
.tablet:last-child { border-right: 0; }
.tablet .t-label {
  display: block;
  font-family: var(--font-inscription);
  letter-spacing: 0.18em;
  font-size: 0.66rem;
  color: var(--text-muted);
  text-transform: uppercase;
  margin-bottom: 0.35rem;
}
.tablet .t-value {
  display: block;
  font-family: var(--font-inscription);
  font-weight: 600;
  font-size: 1.05rem;
  color: var(--accent);
  letter-spacing: 0.08em;
}
@media (max-width: 720px) {
  .tablet { border-right: 0; border-bottom: 1px solid rgba(218,165,32,0.4); }
  .tablet:last-child { border-bottom: 0; }
}

/* ===== Buttons ===== */
.btn {
  display: inline-block;
  font-family: var(--font-inscription);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-size: 0.82rem;
  padding: 0.875rem 1.875rem;
  border-radius: 0;
  cursor: pointer;
  transition: background-color 300ms ease-out, color 300ms ease-out, box-shadow 300ms ease-out, border-color 300ms ease-out;
  text-decoration: none;
  text-align: center;
  line-height: 1.2;
}
.btn:hover { text-decoration: none; }
.btn-primary {
  background-color: var(--primary);
  color: var(--ivory);
  border: 1.5px solid var(--accent);
  box-shadow: inset 0 0 0 0 rgba(218,165,32,0);
}
.btn-primary:hover {
  background-color: var(--primary-900);
  color: var(--ivory);
  box-shadow: inset 0 0 0 1px rgba(218,165,32,0.6);
}
.btn-secondary {
  background-color: transparent;
  color: var(--accent);
  border: 1.5px solid var(--accent);
}
.btn-secondary:hover {
  background-color: rgba(218,165,32,0.12);
  color: var(--accent-300);
  border-color: var(--accent-300);
}
.btn-ghost {
  background-color: transparent;
  color: var(--accent);
  border: 0;
}
.btn-ghost:hover {
  background-color: rgba(218,165,32,0.08);
  color: var(--accent-300);
}

/* ===== Section / cabinet structure ===== */
section.cabinet {
  padding: 3.25rem 0 2.5rem;
  position: relative;
}
section.cabinet > .container > .cabinet-head {
  text-align: center;
  margin-bottom: 1.75rem;
}
.cabinet-head .eyebrow { color: var(--accent); margin-bottom: 0.5rem; }
.cabinet-head h2 { color: var(--ivory); }
.cabinet-head .fleuron {
  color: var(--accent);
  font-size: 1.5rem;
  margin: 0.5rem auto 0.75rem;
  letter-spacing: 0.4em;
  line-height: 1;
}
.cabinet-head .rule-gold {
  width: 60%;
  margin: 0.5rem auto 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
}

.inscription-band {
  text-align: center;
  font-family: var(--font-inscription);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--accent);
  font-size: 0.78rem;
  padding: 0.6rem 0;
  border-top: 1px solid var(--accent);
  border-bottom: 1px solid var(--accent);
  margin: 1.25rem auto 2rem;
  max-width: 38rem;
}

.engraved-divider {
  text-align: center;
  margin: 3rem auto;
  color: var(--accent);
  font-size: 1.4rem;
  letter-spacing: 2em;
  line-height: 1;
  opacity: 0.85;
}
.engraved-divider img {
  max-width: 100%;
  margin: 0 auto;
  display: block;
  opacity: 0.85;
  height: auto;
}

.prose {
  max-width: 64ch;
  margin: 0 auto;
}
.prose p, .prose ul, .prose ol { color: var(--ivory); }

/* ===== Cards / plates ===== */
.plate {
  border: 1.5px solid var(--accent);
  background: var(--surface-elev);
  box-shadow: var(--shadow-card), inset 0 0 0 1px rgba(218,165,32,0.18);
  padding: 1.75rem 2rem;
  position: relative;
  margin: 1.5rem 0;
}
.plate::before, .plate::after,
.plate > .corner-bl, .plate > .corner-br {
  content: "";
  position: absolute;
  width: 14px; height: 14px;
  border: 1.5px solid var(--accent);
  pointer-events: none;
}
.plate::before { top: -1.5px; left: -1.5px; border-right: 0; border-bottom: 0; }
.plate::after  { top: -1.5px; right: -1.5px; border-left: 0; border-bottom: 0; }
.plate > .corner-bl { bottom: -1.5px; left: -1.5px; border-right: 0; border-top: 0; }
.plate > .corner-br { bottom: -1.5px; right: -1.5px; border-left: 0; border-top: 0; }

.plate .plate-head { margin-bottom: 0.75rem; }
.plate .plate-head .eyebrow { color: var(--accent); }
.plate .plate-head h3 { color: var(--ivory); }

.plate.caveat { border-color: var(--primary); background: rgba(139,0,0,0.06); }
.plate.caveat::before, .plate.caveat::after,
.plate.caveat > .corner-bl, .plate.caveat > .corner-br { border-color: var(--primary); }
.plate.caveat .plate-head .eyebrow { color: var(--primary-300); }
.plate.caveat .plate-head h3 { color: var(--ivory); }

.plate.cartouche {
  text-align: center;
}
.plate.cartouche::after { display: block; }

/* Callouts */
.callout {
  margin: 1.75rem 0;
  padding: 1.25rem 1.5rem;
  border-left: 2px solid var(--indigo);
  background: rgba(75,0,130,0.04);
}
.callout .eyebrow {
  color: var(--indigo-300);
  margin-bottom: 0.5rem;
}
.callout.regulatory {
  border: 1.5px solid var(--accent);
  background: rgba(218,165,32,0.04);
  padding: 1.25rem 1.5rem;
}
.callout.regulatory .eyebrow { color: var(--accent); }

/* ===== Tables ===== */
table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.5rem 0 2rem;
  border: 1.5px solid var(--accent);
  background: var(--surface-elev);
  font-size: 0.96rem;
}
thead th {
  background: var(--accent);
  color: var(--bg);
  font-family: var(--font-inscription);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.78rem;
  text-align: left;
  padding: 0.6rem 0.85rem;
  border-bottom: 1.5px solid var(--primary);
}
tbody td {
  padding: 0.65rem 0.85rem;
  border-bottom: 1px solid rgba(184,134,11,0.45);
  color: var(--ivory);
  vertical-align: top;
}
tbody tr:nth-child(even) td { background: var(--surface-panel); }
tbody tr:last-child td { border-bottom: 0; }
td .mono, td.mono { color: var(--accent-300); font-family: var(--font-mono); letter-spacing: 0.02em; }

/* ===== Chips ===== */
.chip-row { display: flex; flex-wrap: wrap; gap: 0.45rem; margin: 0.5rem 0 1rem; }
.chip {
  display: inline-block;
  padding: 0.18rem 0.55rem;
  border: 1px solid var(--accent);
  background: rgba(218,165,32,0.10);
  color: var(--accent);
  font-family: var(--font-inscription);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.72rem;
  border-radius: 0;
}
.chip.crimson { border-color: var(--primary); color: var(--primary-300); background: transparent; }
.chip.indigo  { background: var(--indigo); color: var(--ivory); border-color: var(--indigo); }
.chip.fill    { background: var(--accent); color: var(--bg); }

/* ===== Hero figure ===== */
.hero-figure {
  margin: 2rem auto 0;
  max-width: 60rem;
  border: 1.5px solid var(--accent);
  position: relative;
  background: var(--surface);
}
.hero-figure img { width: 100%; display: block; height: auto; }

figure { margin: 1.75rem 0; }
figure img {
  border: 1.5px solid var(--accent);
  background: var(--surface);
}
figcaption {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.95rem;
  color: var(--text-muted);
  margin-top: 0.5rem;
  text-align: center;
}

/* ===== References list ===== */
ol.references-list {
  list-style: none;
  padding: 0;
  counter-reset: refs;
}
ol.references-list > li {
  counter-increment: refs;
  position: relative;
  padding: 0.85rem 1rem 0.85rem 4rem;
  border-bottom: 1px solid var(--rule);
  font-family: var(--font-body);
  color: var(--ivory);
  font-size: 1rem;
  line-height: 1.55;
}
ol.references-list > li::before {
  content: "[" counter(refs, decimal-leading-zero) "]";
  position: absolute;
  left: 0.5rem;
  top: 0.85rem;
  width: 3rem;
  font-family: var(--font-mono);
  color: var(--accent);
  font-size: 0.9rem;
  letter-spacing: 0.02em;
}
ol.references-list .ref-doi {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.84rem;
  color: var(--text-muted);
  margin-top: 0.25rem;
  letter-spacing: 0.02em;
}
ol.references-list a { color: var(--accent); }
ol.references-list a:hover { color: var(--accent-300); }

/* ===== Charts ===== */
.chart-wrap {
  border: 1.5px solid var(--accent);
  background: var(--surface-elev);
  padding: 1.25rem 1.25rem 1.5rem;
  margin: 1.75rem 0;
  position: relative;
}
.chart-wrap .chart-title {
  font-family: var(--font-inscription);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--accent);
  font-size: 0.82rem;
  margin-bottom: 0.6rem;
  text-align: center;
}
.chart-wrap canvas {
  width: 100% !important;
  height: 280px !important;
  max-height: 320px;
}
.chart-caption {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.9rem;
  color: var(--text-muted);
  margin-top: 0.5rem;
  text-align: center;
}

/* ===== Form (contact) ===== */
.contact-form {
  border: 1.5px solid var(--accent);
  background: var(--surface-elev);
  padding: 1.75rem;
  max-width: 38rem;
  margin: 1.5rem auto;
}
.field { margin-bottom: 1.1rem; }
.field label {
  display: block;
  font-family: var(--font-inscription);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.78rem;
  color: var(--accent);
  margin-bottom: 0.35rem;
}
.field input, .field textarea {
  width: 100%;
  background: var(--bg);
  border: 1px solid var(--accent);
  color: var(--ivory);
  padding: 0.65rem 0.75rem;
  font-family: var(--font-body);
  font-size: 1rem;
  border-radius: 0;
}
.field input:focus, .field textarea:focus {
  outline: 3px solid var(--accent);
  outline-offset: 2px;
}
.field textarea { min-height: 7rem; resize: vertical; }
.form-note {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.9rem;
  color: var(--text-muted);
  margin-top: 0.5rem;
}

/* ===== Footer ===== */
.site-footer {
  background-color: var(--bg);
  border-top: 6px solid;
  border-image: linear-gradient(90deg, #B8860B, #DAA520, #B8860B) 1;
  margin-top: 4rem;
  padding: 2.5rem 0 1.75rem;
  color: var(--text-muted);
}
.footer-cartouche {
  text-align: center;
  margin-bottom: 1.5rem;
}
.footer-cartouche .site-brand {
  font-size: 1.35rem;
}
.footer-cartouche .finis {
  display: block;
  margin-top: 0.4rem;
  font-family: var(--font-inscription);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-size: 0.7rem;
  color: var(--accent);
}
.footer-cols {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  margin: 1.5rem auto 1.25rem;
  max-width: 56rem;
}
@media (min-width: 720px) {
  .footer-cols { grid-template-columns: repeat(3, 1fr); }
}
.footer-cols h4 {
  font-family: var(--font-inscription);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.78rem;
  color: var(--accent);
  margin: 0 0 0.5rem;
  font-weight: 600;
}
.footer-cols ul { list-style: none; padding: 0; margin: 0; }
.footer-cols li { margin: 0.25rem 0; }
.footer-cols a {
  color: var(--ivory);
  font-family: var(--font-body);
  font-size: 0.95rem;
}
.footer-cols a:hover { color: var(--accent); }
.colophon {
  text-align: center;
  font-family: var(--font-inscription);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.7rem;
  color: var(--text-muted);
  margin: 1.5rem auto 0.75rem;
  max-width: 60rem;
  border-top: 1px solid var(--rule);
  padding-top: 1rem;
}
.disclaimer, .copyright {
  text-align: center;
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.9rem;
  color: var(--text-muted);
  margin: 0.35rem auto;
  max-width: 50rem;
}

/* ===== Marginalia (catalog rail) ===== */
.layout-with-rail {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}
@media (min-width: 1024px) {
  .layout-with-rail {
    grid-template-columns: 13rem 1fr;
    gap: 3rem;
  }
}
.catalog-rail {
  font-family: var(--font-inscription);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.76rem;
  color: var(--accent);
}
.catalog-rail h4 {
  font-family: var(--font-inscription);
  font-size: 0.78rem;
  color: var(--accent);
  margin: 0 0 0.85rem;
  font-weight: 600;
}
.catalog-rail ul { list-style: none; padding: 0; margin: 0; }
.catalog-rail li {
  margin: 0.45rem 0;
  padding-left: 0;
}
.catalog-rail a {
  color: var(--ivory);
  display: inline-block;
  border-bottom: 1px dotted var(--rule);
  padding: 0.15rem 0;
}
.catalog-rail a:hover { color: var(--accent); border-bottom-color: var(--accent); }
.catalog-rail .year {
  display: inline-block;
  font-family: var(--font-mono);
  color: var(--accent-300);
  font-size: 0.72rem;
  margin-left: 0.4rem;
  text-transform: none;
  letter-spacing: 0;
}

/* ===== Tippy customization ===== */
.tippy-box[data-theme~='baroque'] {
  background: var(--surface-elev);
  color: var(--ivory);
  border: 1.5px solid var(--accent);
  border-radius: 0;
  font-family: var(--font-body);
  font-size: 0.95rem;
  line-height: 1.45;
  padding: 0.5rem 0.7rem;
  max-width: 360px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.6);
}
.tippy-box[data-theme~='baroque'] .tippy-arrow { color: var(--accent); }
.tippy-box[data-theme~='baroque'] .tippy-content { padding: 0.25rem; }

/* ===== Misc ===== */
.text-center { text-align: center; }
.text-muted { color: var(--text-muted); }
.faq-q {
  font-family: var(--font-heading);
  font-weight: 700;
  color: var(--ivory);
}

/* 404 */
.error-hero {
  text-align: center;
  padding: 6rem 0;
}
.error-hero h1 { font-size: clamp(4rem, 12vw, 9rem); }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    transition-duration: 0ms !important;
    animation-duration: 0ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
  }
}

/* Print */
@media print {
  body { background: #fff; color: #000; }
  .site-header, .site-footer, .cta-row, .catalog-rail { display: none; }
  a { color: inherit; text-decoration: underline; }
}
