/* České Křídlovice — Moravian wine-cellar editorial.
   Distinct from a centred-magazine layout: asymmetric hero, brass corner
   marks, an interstitial roman-numeral year, hand-drawn flourishes, and
   diegetic SVG ornaments inside the prose. */

:root {
  --paper:    #f4ead0;
  --paper-2:  #ede0bb;
  --paper-3:  #e3d2a0;
  --ink:      #20191a;
  --ink-soft: #5a4a3c;
  --wine:     #5a181f;
  --wine-2:   #7a2026;
  --brass:    #a07a32;
  --brass-2:  #c9a86b;
  --olive:    #5d6e44;
  --rule:     #b89249;
  --display:  "Marcellus", "Cormorant Garamond", Georgia, serif;
  --smcaps:   "Marcellus SC", "Marcellus", Georgia, serif;
  --serif:    "Vollkorn", Georgia, "Times New Roman", serif;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--serif);
  font-size: 19px;
  line-height: 1.62;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  background-image:
    radial-gradient(ellipse at 8% 0%,    rgba(176,125,46,.08), transparent 55%),
    radial-gradient(ellipse at 92% 18%,  rgba(90,24,31,.05),   transparent 55%),
    radial-gradient(ellipse at 50% 100%, rgba(93,110,68,.06),  transparent 60%);
}

::selection { background: var(--wine); color: var(--paper); }

a {
  color: var(--wine);
  text-decoration-color: rgba(90,24,31,.4);
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  transition: color .15s, text-decoration-color .15s;
}
a:hover { color: var(--wine-2); text-decoration-color: var(--wine); }

img { max-width: 100%; height: auto; display: block; }

/* ── Hero ─────────────────────────────────────────────────────────────── */

.hero {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  align-items: end;
  padding: clamp(2.5rem, 5vw, 4rem) clamp(1.5rem, 4vw, 3rem) clamp(2rem, 4vw, 3rem);
  max-width: 1200px;
  margin: 0 auto;
  background:
    linear-gradient(180deg, var(--paper-2) 0%, var(--paper) 80%);
  border-bottom: 1px solid var(--rule);
}

@media (min-width: 960px) {
  .hero {
    grid-template-columns: minmax(0, 1fr) minmax(0, 360px);
    gap: 3rem;
    align-items: start;
  }
  .hero-text { padding-top: .8rem; }
}

/* Brass corner-mark frame */
.hero-frame {
  position: absolute;
  inset: clamp(1rem, 2.5vw, 1.8rem);
  pointer-events: none;
}
.hero-frame::before,
.hero-frame::after {
  content: "";
  position: absolute;
  width: 36px; height: 36px;
  border: 1px solid var(--brass);
}
.hero-frame::before {
  top: 0; left: 0;
  border-right: none; border-bottom: none;
}
.hero-frame::after {
  bottom: 0; right: 0;
  border-left: none; border-top: none;
}

.hero-text {
  min-width: 0;
}

.hero-text .kicker {
  font-family: var(--smcaps);
  font-size: .82rem;
  letter-spacing: .22em;
  color: var(--wine);
  margin: 0 0 1.2rem;
}

.hero-text .title {
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(2.4rem, 5.4vw, 4.4rem);
  line-height: 1;
  margin: 0 0 1.4rem;
  letter-spacing: -.005em;
  color: var(--ink);
}

.hero-text .lede {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(1.1rem, 1.7vw, 1.32rem);
  line-height: 1.5;
  max-width: 28em;
  margin: 0 0 2rem;
  color: var(--ink);
}

.meta-grid {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem 1.6rem;
  border-top: 1px solid var(--rule);
  padding-top: 1.2rem;
}
.meta-grid li {
  display: flex;
  flex-direction: column;
  gap: .15rem;
}
.meta-label {
  font-family: var(--smcaps);
  font-size: .72rem;
  letter-spacing: .18em;
  color: var(--ink-soft);
}
.meta-value {
  font-family: var(--display);
  font-size: 1.02rem;
  color: var(--ink);
  letter-spacing: .005em;
}

.hero-figure {
  margin: 0 auto;
  position: relative;
  max-width: 440px;
}
@media (min-width: 960px) {
  .hero-figure {
    max-width: none;
    margin: 0;
  }
}
.hero-figure img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  border: 1px solid var(--rule);
  box-shadow:
    0 1px 0 rgba(255,255,255,.4) inset,
    0 14px 28px -16px rgba(32,25,26,.55);
}
.hero-figure figcaption {
  font-family: var(--smcaps);
  font-size: .72rem;
  letter-spacing: .18em;
  color: var(--ink-soft);
  margin-top: .8rem;
  text-align: right;
}

@media (max-width: 820px) {
  .hero-frame { inset: .8rem; }
  .hero-frame::before, .hero-frame::after { width: 24px; height: 24px; }
  .hero-figure figcaption { text-align: left; }
}

/* ── Annus Domini band ────────────────────────────────────────────────── */

.annus-band {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: clamp(2rem, 5vw, 3.5rem) 1rem;
  border-bottom: 1px solid var(--rule);
  background:
    radial-gradient(ellipse at 50% 50%, rgba(176,125,46,.10), transparent 70%);
  user-select: none;
}
.annus {
  font-family: var(--display);
  font-size: clamp(3.6rem, 9vw, 6.5rem);
  letter-spacing: .12em;
  color: var(--brass);
  line-height: 1;
  text-shadow: 0 1px 0 rgba(255,255,255,.5);
}
.annus-sub {
  font-family: var(--smcaps);
  font-size: .82rem;
  letter-spacing: .26em;
  color: var(--wine);
  margin-top: 1rem;
}

/* ── Sections ─────────────────────────────────────────────────────────── */

main { padding-bottom: 4rem; }

.prose {
  max-width: 700px;
  margin: 0 auto;
  padding: clamp(2.5rem, 5vw, 4rem) 1.5rem 1.5rem;
}

.prose h2 {
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(1.8rem, 3.4vw, 2.5rem);
  line-height: 1.15;
  margin: 0 0 1.4rem;
  color: var(--wine);
  letter-spacing: -.005em;
}

.prose h2 .numeral {
  display: block;
  font-family: var(--smcaps);
  font-size: .42em;
  letter-spacing: .26em;
  color: var(--brass);
  font-weight: 400;
  margin-bottom: .5em;
}

.prose p {
  margin: 0 0 1.05rem;
}

/* Drop cap */
.prose p.dropcap::first-letter {
  font-family: var(--display);
  font-weight: 400;
  font-size: 4.2em;
  line-height: .82;
  float: left;
  padding: .12em .14em 0 0;
  color: var(--wine);
}

/* Aside */
.aside-block {
  font-style: italic;
  color: var(--ink-soft);
  border-left: 2px solid var(--brass);
  padding: .25rem 0 .25rem 1.1rem;
  margin: 1.5rem 0 0;
  font-size: .98em;
  background: linear-gradient(90deg, rgba(201,168,107,.08), transparent 60%);
}

/* ── Names rail (II) ──────────────────────────────────────────────────── */

.names-rail {
  list-style: none;
  padding: 0;
  margin: 1.6rem 0 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border-top: 1px solid var(--rule);
}
.names-rail li {
  display: grid;
  grid-template-columns: minmax(140px, .35fr) 1fr;
  gap: 1.5rem;
  padding: 1rem 0;
  border-bottom: 1px solid var(--rule);
}
.names-label {
  font-family: var(--smcaps);
  font-size: .76rem;
  letter-spacing: .18em;
  color: var(--wine);
  align-self: start;
  padding-top: .15rem;
}
.names-value {
  font-family: var(--serif);
  font-size: 1.02rem;
  line-height: 1.45;
}
.names-value .aside,
.aside {
  font-style: italic;
  font-size: .9rem;
  color: var(--ink-soft);
}

@media (max-width: 540px) {
  .names-rail li {
    grid-template-columns: 1fr;
    gap: .25rem;
  }
}

/* ── Flourish dividers ────────────────────────────────────────────────── */

.flourish {
  display: flex;
  justify-content: center;
  margin: clamp(2rem, 4vw, 3rem) auto 0;
  color: var(--brass);
  opacity: .85;
}
.flourish svg {
  width: clamp(120px, 22%, 180px);
  height: auto;
}

/* ── Plate (full-width photograph) ────────────────────────────────────── */

.plate {
  margin: clamp(3rem, 6vw, 4.5rem) auto 0;
  max-width: 780px;
  padding: 0 1.5rem;
}
.plate img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border: 1px solid var(--rule);
  box-shadow:
    0 1px 0 rgba(255,255,255,.4) inset,
    0 14px 28px -18px rgba(32,25,26,.55);
}
.plate figcaption {
  font-family: var(--serif);
  font-style: italic;
  font-size: .92rem;
  color: var(--ink-soft);
  margin-top: .9rem;
  text-align: center;
  max-width: 56em;
  margin-left: auto;
  margin-right: auto;
}

/* ── Memorial list (V) ────────────────────────────────────────────────── */

.memorial-list {
  list-style: none;
  padding: 0;
  margin: 1.5rem 0 0;
}

.memorial-list li {
  border-top: 1px solid var(--rule);
  padding: 1.4rem 0 0;
  margin: 1.4rem 0 0;
  position: relative;
}
.memorial-list li:first-child {
  border-top: none;
  padding-top: 0;
  margin-top: 0;
}

.memorial-list li.with-aside { padding-right: 60px; }
.ill-column {
  position: absolute;
  right: 0;
  top: 1.4rem;
  width: 44px;
  height: auto;
  color: var(--brass);
  opacity: .85;
}

.mem-name {
  font-family: var(--display);
  font-weight: 400;
  font-size: 1.22rem;
  margin: 0 0 .15rem;
  color: var(--ink);
  letter-spacing: .005em;
}
.mem-meta {
  font-family: var(--smcaps);
  font-size: .76rem;
  letter-spacing: .18em;
  color: var(--brass);
  margin: 0 0 .6rem;
}
.memorial-list li > p:not(.mem-name):not(.mem-meta) {
  font-size: .98em;
  color: var(--ink);
  margin: 0 0 .6rem;
}

@media (max-width: 540px) {
  .memorial-list li.with-aside { padding-right: 0; }
  .ill-column {
    position: static;
    margin: .4rem 0 .8rem;
    width: 40px;
  }
}

/* ── Inline ornaments inside Krajina ──────────────────────────────────── */

.ill-grapes,
.ill-rose {
  float: right;
  width: 60px;
  height: auto;
  margin: .2rem 0 .8rem 1.2rem;
  shape-outside: ellipse(50% 60%);
}
.ill-grapes { color: var(--wine); }
.ill-rose   { color: var(--olive); }

@media (max-width: 540px) {
  .ill-grapes, .ill-rose { width: 48px; margin: .2rem 0 .6rem .9rem; }
}

/* ── Plain & link lists ───────────────────────────────────────────────── */

.plain-list, .link-list {
  list-style: none;
  padding: 0;
  margin: 1rem 0 0;
}
.plain-list li, .link-list li {
  padding: .6rem 0;
  border-bottom: 1px dotted var(--rule);
}
.plain-list li:last-child, .link-list li:last-child { border-bottom: none; }
.link-list li::before {
  content: "❦";
  color: var(--brass);
  margin-right: .7rem;
  font-size: 1.05em;
}

/* ── Endmark ──────────────────────────────────────────────────────────── */

.endmark {
  text-align: center;
  font-size: 1.6rem;
  color: var(--brass);
  margin: 2.5rem 0 0;
  letter-spacing: .3em;
}

/* ── Footer ──────────────────────────────────────────────────────────── */

.footer {
  max-width: 700px;
  margin: 3rem auto 0;
  padding: 2.4rem 1.5rem 3rem;
  border-top: 1px solid var(--rule);
  font-size: .92rem;
  color: var(--ink-soft);
  text-align: center;
}
.footer p { margin: 0 0 .8rem; }
.footer-meta {
  font-family: var(--smcaps);
  font-size: .76rem;
  letter-spacing: .26em;
  color: var(--wine);
  margin-top: 1.4rem !important;
}

/* ── Mobile tightening ────────────────────────────────────────────────── */

@media (max-width: 640px) {
  body { font-size: 17.5px; }
  .prose { padding-left: 1.1rem; padding-right: 1.1rem; }
  .prose p.dropcap::first-letter { font-size: 3.4em; }
}
