/* ============================================================
   Günlük Rapor — Quiet Modern
   Warm cream paper · soft mesh atmosphere · Fraunces + Inter
   Strong typography, single ink color, restraint, breathing room.
   ============================================================ */

:root {
  /* Surfaces — soft linen, more neutral than warm cream.
     Less yellow, slightly cooler, holds slate ink with quiet contrast. */
  --paper:        #f3efe7;
  --paper-deep:   #ebe6d9;
  --paper-edge:   #d4ccb8;

  /* Atmospheric tints — barely visible mesh.
     Warm peach lift in one corner, slate-blue hint in the other. */
  --wash-warm:    oklch(91% 0.03 60);
  --wash-cool:    oklch(89% 0.035 230);

  /* Ink — deep slate blue. Not pure black, not navy.
     Has a quiet maritime weight while remaining bookish. */
  --ink:        #1c2330;
  --ink-soft:   #4e5562;
  --ink-faint:  #8b919a;
  --ink-mute:   #bdc0c6;
  --rule:       #cdc5b3;
  --rule-soft:  #ddd6c3;

  /* Single accent — deep oxidised teal.
     Cooler than oxblood, refined, uncommon in news design. */
  --accent:       #1e6b66;
  --accent-hi:    #2a8c87;
  --accent-soft:  #cfe1df;

  /* Forecast direction colors — independent of accent now.
     Forest for up, russet for down, slate-faint for flat. */
  --dir-up:        #2f5e3e;
  --dir-up-soft:   #d2dfca;
  --dir-down:      #a8493a;
  --dir-down-soft: #f1d8d2;
  --dir-flat:      #8b919a;
  --dir-flat-soft: #dee0e4;

  /* Type system
     --display : huge italic editorial type (date, headings)
     --read    : long-form reading body (prose, leads) — variable serif
     --body    : tight UI labels (meta, chip numbers, archive count) */
  --display: "Fraunces", "EB Garamond", "Source Serif Pro", Georgia, serif;
  --read:    "Newsreader", "Source Serif Pro", "EB Garamond", Georgia, serif;
  --body:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

  /* Geometry */
  --max: 1180px;
  --gutter: clamp(1.25rem, 1rem + 2vw, 3rem);
  --reading: 64ch;
  --ease: cubic-bezier(0.2, 0.7, 0.2, 1);
}

html { scroll-behavior: smooth; }

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
::selection { background: var(--accent); color: var(--paper); }

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--body);
  font-size: clamp(15px, 0.92rem + 0.2vw, 17px);
  line-height: 1.55;
  font-feature-settings: "ss01", "cv11", "kern";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  position: relative;
  overflow-x: hidden;
  min-height: 100vh;
}

a {
  color: var(--ink);
  text-decoration: none;
  transition: color 200ms var(--ease);
}
a:hover { color: var(--accent); }
a:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 4px;
  border-radius: 2px;
}

/* =========================================================
   ATMOSPHERIC BACKGROUND
   Two soft radial washes + organic grain → never reads as flat.
   ========================================================= */
.bg {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}
body > *:not(.bg):not(.to-top) { position: relative; z-index: 1; }

.bg__wash {
  position: absolute;
  width: 70vmax;
  height: 70vmax;
  border-radius: 50%;
  filter: blur(140px);
  opacity: 0.35;
  mix-blend-mode: multiply;
}
.bg__wash--warm {
  background: var(--wash-warm);
  top: -30vmax;
  right: -25vmax;
}
.bg__wash--cool {
  background: var(--wash-cool);
  bottom: -30vmax;
  left: -25vmax;
}
.bg__grain {
  position: absolute;
  inset: -50%;
  /* Subtler grain — feels like a paper stock rather than print noise */
  opacity: 0.028;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml;utf8,<svg viewBox='0 0 280 280' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.05' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.85 0'/></filter><rect width='280' height='280' filter='url(%23n)'/></svg>");
  background-size: 260px 260px;
}

/* =========================================================
   MASTHEAD
   ========================================================= */
.masthead {
  max-width: var(--max);
  margin: 0 auto;
  padding: clamp(1.75rem, 1rem + 2vw, 3rem) var(--gutter) clamp(1rem, 1vw + 0.5rem, 1.5rem);
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.75rem 2rem;
}

.masthead__brand {
  display: inline-flex;
  align-items: baseline;
  gap: 0.45rem;
  color: var(--ink);
  transition: opacity 220ms var(--ease);
}
.masthead__brand:hover {
  color: var(--ink);
  opacity: 0.78;
}
.masthead__brand:hover .masthead__dot {
  background: var(--accent);
}
.masthead__wordmark {
  font-family: var(--display);
  font-weight: 600;
  font-variation-settings: "SOFT" 30, "WONK" 0;
  font-size: clamp(1.55rem, 1.1rem + 1.05vw, 2.35rem);
  letter-spacing: -0.028em;
  line-height: 1;
}
.masthead__dot {
  display: inline-block;
  width: 0.32em;
  height: 0.32em;
  background: var(--accent);
  border-radius: 50%;
  transform: translateY(-0.05em);
  transition: background 240ms var(--ease);
}
.masthead__sub {
  font-family: var(--display);
  font-weight: 400;
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1, "opsz" 96;
  font-size: clamp(1.3rem, 1rem + 0.95vw, 2rem);
  color: var(--ink-faint);
  letter-spacing: -0.018em;
  line-height: 1;
}
.masthead__meta {
  margin: 0;
  font-family: var(--body);
  font-size: 0.78rem;
  color: var(--ink-faint);
  letter-spacing: 0.02em;
  display: inline-flex;
  align-items: baseline;
  gap: 0.5rem;
}
.masthead__meta strong {
  color: var(--ink);
  font-weight: 600;
  font-feature-settings: "tnum";
}
.masthead__meta-sep { color: var(--ink-mute); }

/* =========================================================
   CANVAS
   ========================================================= */
.canvas {
  max-width: var(--max);
  margin: 0 auto;
  padding: clamp(1.5rem, 2vw, 3rem) var(--gutter) clamp(3rem, 4vw, 5rem);
}

/* =========================================================
   HERO — compact landing header
   Two-row composition: kicker + date on top, lead + CTA in body row,
   section chips as a single dense strip. Keeps everything above the
   fold on common viewports.
   ========================================================= */
.hero {
  padding: clamp(1rem, 2vw, 2rem) 0 clamp(1.25rem, 2vw, 2rem);
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(0.75rem, 1vw, 1.25rem);
  border-bottom: 1px solid var(--rule);
}

/* Staggered entrance — content reveals line-by-line on first paint */
.hero > * {
  opacity: 0;
  transform: translateY(8px);
  animation: heroReveal 700ms var(--ease) forwards;
}
.hero > .hero__top { animation-delay:  50ms; }
.hero > .hero__body { animation-delay: 220ms; }
.hero > .hero__chips { animation-delay: 360ms; }

@keyframes heroReveal {
  to { opacity: 1; transform: translateY(0); }
}

.hero__top {
  display: grid;
  gap: 0.4rem;
}
.hero__kicker {
  margin: 0;
  font-family: var(--body);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 600;
}

.hero__date {
  margin: 0;
  font-family: var(--display);
  font-weight: 400;
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1, "opsz" 144;
  font-size: clamp(2.4rem, 1.6rem + 3vw, 4.2rem);
  line-height: 0.95;
  letter-spacing: -0.035em;
  color: var(--ink);
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.2em 0.4em;
}
.hero__day {
  color: var(--ink);
  font-feature-settings: "lnum";
}
.hero__month {
  color: var(--accent);
  font-size: 0.92em;
}
.hero__year {
  font-family: var(--body);
  font-style: normal;
  font-variation-settings: normal;
  font-size: 0.85rem;
  letter-spacing: 0.16em;
  color: var(--ink-faint);
  font-weight: 500;
  font-feature-settings: "tnum";
  align-self: baseline;
}

.hero__body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 1rem clamp(1.5rem, 3vw, 3rem);
}
.hero__lead {
  margin: 0;
  font-family: var(--display);
  font-style: italic;
  font-variation-settings: "SOFT" 50, "opsz" 16;
  font-weight: 400;
  font-size: clamp(1rem, 0.85rem + 0.5vw, 1.25rem);
  line-height: 1.45;
  color: var(--ink-soft);
  max-width: 56ch;
  text-wrap: balance;
}

.hero__chips {
  list-style: none;
  margin: 0;
  padding: 0.75rem 0 0;
  border-top: 1px dashed var(--rule);
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem 1.5rem;
}
.hero__chips li {
  display: inline-flex;
  align-items: baseline;
  gap: 0.45rem;
  padding: 0.1rem 0;
  font-family: var(--body);
  font-size: 0.82rem;
  color: var(--ink-soft);
  font-weight: 500;
}
.hero__chip-no {
  font-family: var(--display);
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1;
  font-size: 1em;
  color: var(--accent);
  min-width: 1.2em;
}
.hero__chip-name { color: var(--ink); }

.hero__cta {
  display: inline-flex;
  align-items: baseline;
  gap: 0.7rem;
  width: max-content;
  font-family: var(--display);
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1;
  font-size: clamp(1.05rem, 0.9rem + 0.4vw, 1.4rem);
  color: var(--ink);
  padding: 0.25rem 0 0.5rem;
  /* Two-layer underline: 1px ink rule resting, 2px terracotta grows in on hover */
  background-image:
    linear-gradient(var(--accent), var(--accent)),
    linear-gradient(var(--ink), var(--ink));
  background-size: 0 2px, 100% 1px;
  background-repeat: no-repeat;
  background-position: 0 100%, 0 100%;
  transition:
    color 220ms var(--ease),
    background-size 320ms var(--ease),
    gap 250ms var(--ease);
  white-space: nowrap;
}
.hero__cta:hover {
  color: var(--accent);
  background-size: 100% 2px, 100% 1px;
  gap: 1rem;
}
.hero__cta-arrow {
  font-family: var(--body);
  font-style: normal;
  color: var(--accent);
  transition: transform 250ms var(--ease);
  display: inline-block;
}
.hero__cta:hover .hero__cta-arrow { transform: translateX(4px); }

.hero--empty .hero__date { font-size: 2.5rem; color: var(--ink-faint); }

/* =========================================================
   ARCHIVE — compact list with single-line rows
   Body lead sits inline with the date; cue stays right-aligned.
   ========================================================= */
.archive {
  padding-top: clamp(1.25rem, 2vw, 2rem);
}
.archive__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 0.75rem;
  gap: 1rem;
}
.archive__title {
  margin: 0;
  font-family: var(--display);
  font-style: italic;
  font-weight: 400;
  font-variation-settings: "SOFT" 100, "WONK" 1;
  font-size: clamp(1.25rem, 1rem + 0.6vw, 1.6rem);
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--ink);
}
.archive__count {
  font-family: var(--body);
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  color: var(--ink-faint);
}
.archive__list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.archive__item {
  border-top: 1px solid var(--rule);
}
.archive__item:last-child { border-bottom: 1px solid var(--rule); }

.archive__link {
  display: grid;
  grid-template-columns: 3.5rem minmax(0, 1fr) auto;
  gap: clamp(0.75rem, 2vw, 1.5rem);
  align-items: baseline;
  padding: 0.7rem 0.25rem;
  color: var(--ink);
  position: relative;
  transition: padding 250ms var(--ease), background 250ms var(--ease);
}
.archive__link:hover {
  padding-left: 0.85rem;
  background: linear-gradient(90deg, rgba(140, 53, 32, 0.05) 0%, transparent 55%);
}
.archive__link:hover .archive__num { color: var(--accent); }
.archive__link:hover .archive__cue { color: var(--accent); }
.archive__link:hover .archive__cue-arrow { transform: translateX(3px); }

.archive__date {
  display: inline-flex;
  align-items: baseline;
  gap: 0.4rem;
  font-family: var(--body);
  font-feature-settings: "tnum";
}
.archive__num {
  font-family: var(--display);
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1, "opsz" 96;
  font-weight: 400;
  font-size: clamp(1.4rem, 1.1rem + 0.6vw, 1.85rem);
  line-height: 1;
  color: var(--ink);
  letter-spacing: -0.03em;
  transition: color 250ms var(--ease);
}
.archive__mon {
  font-family: var(--body);
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  color: var(--ink-faint);
  line-height: 1.15;
  text-transform: capitalize;
  display: inline-block;
}
.archive__yr {
  color: var(--ink-mute);
  font-size: 0.66rem;
}

.archive__body { min-width: 0; }
.archive__lead {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  font-family: var(--read);
  font-size: clamp(0.92rem, 0.88rem + 0.12vw, 1rem);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 62ch;
  font-feature-settings: "onum";
}
.archive__cue {
  font-family: var(--display);
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1;
  font-size: 0.85rem;
  color: var(--ink-faint);
  width: max-content;
  transition: color 250ms var(--ease);
  align-self: center;
}
.archive__cue-arrow {
  display: inline-block;
  transition: transform 250ms var(--ease);
}
.archive__empty {
  font-family: var(--body);
  font-size: 0.88rem;
  color: var(--ink-faint);
  padding: 1.5rem 0;
  text-align: center;
}

/* =========================================================
   ISSUE PAGE
   ========================================================= */
.issue {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(2rem, 4vw, 3.5rem);
}

.issue__head {
  padding: clamp(2rem, 4vw, 4rem) 0 clamp(1rem, 2vw, 1.5rem);
  display: grid;
  gap: 1rem;
  border-bottom: 1px solid var(--rule);
}
.issue__kicker {
  margin: 0;
  font-family: var(--body);
  font-size: 0.78rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 600;
}
.issue__date {
  margin: 0;
  font-family: var(--display);
  font-weight: 400;
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1, "opsz" 144;
  font-size: clamp(3.5rem, 2.5rem + 6vw, 9rem);
  line-height: 0.88;
  letter-spacing: -0.045em;
  color: var(--ink);
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.15em 0.35em;
}
.issue__day {
  font-feature-settings: "lnum";
  color: var(--ink);
}
.issue__month {
  color: var(--accent);
  font-size: 0.85em;
}
.issue__year {
  margin: 0;
  font-family: var(--body);
  font-size: 0.82rem;
  letter-spacing: 0.16em;
  color: var(--ink-faint);
  font-weight: 500;
  font-feature-settings: "tnum";
}

/* Nav */
.issue__nav {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 1rem;
  align-items: center;
  padding: 0.5rem 0;
}
.issue__nav-link {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  font-family: var(--body);
  font-size: 0.85rem;
  color: var(--ink-soft);
  font-weight: 500;
  padding: 0.3rem 0;
  transition: color 200ms var(--ease), transform 250ms var(--ease);
  text-decoration: none;
}
.issue__nav-link--prev { justify-self: start; }
.issue__nav-link--next { justify-self: end; }
.issue__nav-link--index {
  position: relative;
  font-family: var(--body);
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--ink);
  border: 1px solid var(--ink);
  padding: 0.7rem 1.4rem;
  background: transparent;
  transition: color 200ms var(--ease), background 200ms var(--ease), border-color 200ms var(--ease);
  isolation: isolate;
}
.issue__nav-link--index::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--ink);
  transform: scaleY(0);
  transform-origin: bottom center;
  transition: transform 320ms var(--ease);
  z-index: -1;
}
.issue__nav-link--index:hover {
  color: var(--paper);
  border-color: var(--ink);
}
.issue__nav-link--index:hover::before { transform: scaleY(1); }
.issue__nav-link:hover { color: var(--accent); }
.issue__nav-link--prev:hover { transform: translateX(-3px); }
.issue__nav-link--next:hover { transform: translateX(3px); }
.issue__nav-link--disabled { opacity: 0.35; pointer-events: none; }
.issue__nav-cue { color: var(--accent); font-size: 1rem; }
.issue__nav-text {
  display: inline-flex;
  flex-direction: column;
  line-height: 1.15;
}
.issue__nav-label {
  font-size: 0.7rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.issue__nav-date {
  font-family: var(--display);
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1;
  font-size: 1rem;
  color: var(--ink);
}

/* ─────────────────────────────────────────────────────────
   IN-PAGE SECTION CHIP NAV — editorial brutalist
   Square hairline rectangles. On hover a 2px terracotta rule
   slides under the chip; no pill, no fill, no rounded corners.
   ───────────────────────────────────────────────────────── */
.issue__chips {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.7rem 1.5rem;
  align-items: baseline;
  padding: 0.5rem 0 0.25rem;
  position: relative;
}
.issue__chips::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -0.75rem;
  height: 1px;
  background: var(--rule);
}
.issue__chips-label {
  font-family: var(--body);
  font-size: 0.68rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
  font-weight: 600;
  white-space: nowrap;
  padding-top: 0.55rem;
}
.issue__chips-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem 0.5rem;
}
.issue__chip {
  position: relative;
  display: inline-flex;
  align-items: baseline;
  gap: 0.7rem;
  padding: 0.55rem 1rem 0.6rem;
  border: 1px solid var(--rule);
  background: transparent;
  font-family: var(--read);
  font-size: 0.92rem;
  line-height: 1;
  color: var(--ink);
  white-space: nowrap;
  isolation: isolate;
  transition:
    color 320ms var(--ease),
    border-color 320ms var(--ease),
    background 320ms var(--ease);
}
.issue__chip::before {
  /* hairline that draws under the chip on hover — slower, more poised */
  content: "";
  position: absolute;
  left: -1px;
  right: -1px;
  bottom: -1px;
  height: 1px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 380ms var(--ease);
  z-index: 1;
}
.issue__chip:hover {
  border-color: var(--ink-soft);
  color: var(--accent);
  background: transparent;
}
.issue__chip:hover::before { transform: scaleX(1); }
.issue__chip:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.issue__chip-no {
  font-family: var(--display);
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1, "opsz" 96;
  font-size: 1.1em;
  color: var(--accent);
  letter-spacing: -0.02em;
  font-feature-settings: "lnum";
}
.issue__chip-name {
  font-feature-settings: "onum";
  font-style: italic;
}

/* =========================================================
   PROSE — analytical long-form
   ========================================================= */
.prose {
  /* min() ensures the column never exceeds its container even when 64ch
     would otherwise be wider than a narrow viewport */
  max-width: min(var(--reading), 100%);
  width: 100%;
  margin: 0 auto;
  font-family: var(--read);
  font-optical-sizing: auto;
  font-feature-settings: "ss01", "ss02", "onum", "liga", "kern";
  font-size: clamp(1.05rem, 0.97rem + 0.28vw, 1.22rem);
  line-height: 1.68;
  color: var(--ink);
  counter-reset: section;
  letter-spacing: -0.003em;
  /* Safeguards: long URLs and table-like content shouldn't blow out mobile */
  overflow-wrap: break-word;
  word-wrap: break-word;
  min-width: 0;
}
/* Anchor jump offset so the heading isn't flush with the viewport top
   when a chip is clicked. */
.prose > h2 { scroll-margin-top: 1.5rem; }

.prose > h1 {
  font-family: var(--display);
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1, "opsz" 144;
  font-weight: 400;
  font-size: clamp(2.2rem, 1.5rem + 2vw, 3.5rem);
  line-height: 1.05;
  letter-spacing: -0.025em;
  margin: 0 0 2.5rem;
  text-align: left;
  color: var(--ink);
  text-wrap: balance;
}

.prose > h2 {
  font-family: var(--display);
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1, "opsz" 144;
  font-weight: 400;
  font-size: clamp(1.7rem, 1.25rem + 1.4vw, 2.4rem);
  line-height: 1.1;
  letter-spacing: -0.025em;
  margin: 4rem 0 1.4rem;
  padding-top: 2.75rem;
  border-top: 1px solid var(--rule);
  color: var(--ink);
  position: relative;
  text-wrap: balance;
}
.prose > h2::before {
  counter-increment: section;
  content: counter(section, decimal-leading-zero);
  display: block;
  font-family: var(--body);
  font-style: normal;
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  color: var(--accent);
  margin-bottom: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  font-feature-settings: "tnum";
}

.prose > h3 {
  position: relative;
  font-family: var(--display);
  font-weight: 400;
  font-style: italic;
  font-variation-settings: "SOFT" 80, "WONK" 1, "opsz" 72;
  font-size: clamp(1.22rem, 1rem + 0.55vw, 1.6rem);
  line-height: 1.2;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: 2.75rem 0 0.85rem;
  padding-top: 1.25rem;
  text-wrap: balance;
}
.prose > h3::before {
  /* Editorial separator — short accent rule above the title */
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 2.5rem;
  height: 2px;
  background: var(--accent);
}
.prose > h3::after {
  /* Faint continuation hairline trailing off to the right of the accent
     rule, so each subhead reads as a deliberate ledger entry */
  content: "";
  position: absolute;
  top: 1px;
  left: 2.7rem;
  right: 0;
  height: 1px;
  background: var(--rule-soft);
}

.prose p {
  margin: 0 0 1.1rem;
  hyphens: auto;
  text-wrap: pretty;
}

/* Drop cap on first paragraph after each H2 — slightly smaller and tighter
   so it doesn't bully the body copy. */
.prose > h2 + p::first-letter {
  font-family: var(--display);
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1, "opsz" 144;
  font-weight: 400;
  font-size: 3.8em;
  float: left;
  line-height: 0.84;
  padding: 0.18em 0.12em 0 0;
  color: var(--accent);
  letter-spacing: -0.025em;
}

.prose strong { color: var(--ink); font-weight: 600; }
.prose em {
  color: var(--ink);
  font-style: italic;
  font-family: var(--read);
}

.prose blockquote {
  margin: 1.8rem 0 1.8rem 0;
  padding: 0.2rem 0 0.2rem 1.5rem;
  border-left: 2px solid var(--accent);
  font-family: var(--display);
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1;
  font-size: 1.15em;
  line-height: 1.5;
  color: var(--ink-soft);
}

.prose ul, .prose ol {
  margin: 0 0 1.2rem;
  padding-left: 1.4rem;
}
.prose ul li::marker { color: var(--accent); }
.prose ol li::marker { color: var(--accent); font-weight: 600; }
.prose li { margin-bottom: 0.45rem; }

.prose a {
  color: var(--accent);
  border-bottom: 1px solid var(--accent-soft);
  transition: border-color 200ms var(--ease), color 200ms var(--ease);
}
.prose a:hover {
  color: var(--accent-hi);
  border-bottom-color: var(--accent);
}

/* ─────────────────────────────────────────────────────────
   BUGÜNÜN TEZİ — the editor's opening statement
   Targets the first paragraph after the "Bugünün Tezi" H3 and lifts
   it into a pull-quote with a left-side accent rule + italic display.
   ───────────────────────────────────────────────────────── */
.prose h3#bugnn-tezi + p,
.prose h3[id*="bugun"] + p,
.prose h3[id*="tezi"] + p {
  position: relative;
  margin: 0.5rem 0 2rem;
  padding: 0.25rem 0 0.25rem 1.3rem;
  font-family: var(--display);
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1, "opsz" 32;
  font-weight: 400;
  font-size: clamp(1.15rem, 0.95rem + 0.65vw, 1.5rem);
  line-height: 1.4;
  color: var(--ink);
  letter-spacing: -0.005em;
  border-left: 2px solid var(--accent);
}
.prose h3#bugnn-tezi + p::first-letter,
.prose h3[id*="bugun"] + p::first-letter,
.prose h3[id*="tezi"] + p::first-letter {
  /* override the prose drop-cap behaviour for this paragraph */
  font-size: inherit;
  float: none;
  padding: 0;
  color: inherit;
  line-height: inherit;
}

/* ─────────────────────────────────────────────────────────
   FORECAST — investment direction cards
   Replaces the 'Yön Beklentileri' markdown block. Each card is
   a tight rectangle with a leading direction glyph (↑ ↓ →),
   asset name in italic serif, optional reasoning underneath.
   ───────────────────────────────────────────────────────── */
.prose .forecast {
  margin: 1.5rem 0 2rem;
}
.prose .forecast__heading {
  font-family: var(--display);
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1, "opsz" 96;
  font-weight: 400;
  font-size: clamp(1.2rem, 1rem + 0.6vw, 1.6rem);
  letter-spacing: -0.018em;
  margin: 1.75rem 0 0.4rem;
  color: var(--ink);
}
.prose .forecast__heading::before { content: none; }
.prose .forecast__heading::after { content: none; }

.prose .forecast__caption {
  margin: 0 0 1.4rem;
  font-family: var(--body);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-faint);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
}
.prose .forecast__caption::before {
  content: "";
  display: inline-block;
  width: 1rem;
  height: 1px;
  background: var(--accent);
}

.prose .forecast-group {
  margin: 0 0 1.5rem;
}
.prose .forecast-group:last-child { margin-bottom: 0; }

.prose .forecast-group__heading {
  font-family: var(--body);
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
  font-weight: 600;
  margin: 0 0 0.7rem;
  padding: 0 0 0.45rem;
  border-bottom: 1px solid var(--rule-soft);
}

.prose .forecast-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(13rem, 1fr));
  gap: 0.55rem;
}

.prose .forecast-card {
  display: grid;
  grid-template-rows: auto auto 1fr;
  gap: 0.35rem;
  padding: 0.85rem 1rem 1rem;
  border: 1px solid var(--rule);
  background:
    linear-gradient(
      135deg,
      color-mix(in oklch, var(--dir-color) 6%, transparent) 0%,
      transparent 60%
    ),
    rgba(255, 255, 255, 0.32);
  position: relative;
  isolation: isolate;
  overflow: hidden;
  transition: border-color 320ms var(--ease), background 320ms var(--ease);
}
.prose .forecast-card:hover {
  border-color: var(--dir-color);
}
.prose .forecast-card::before {
  /* Direction-colored hairline along the left edge */
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 2px;
  background: var(--dir-color, var(--rule));
}
.prose .forecast-card::after {
  /* Magnitude bar at the bottom — fills for up, anchors right for down,
     dashed line for flat. Gives each card a tiny chart-like signal. */
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2px;
  background: var(--dir-color);
  transform-origin: left center;
  opacity: 0.55;
}
.prose .forecast-card--up::after    { transform: scaleX(0.85); transform-origin: left center; }
.prose .forecast-card--down::after  { transform: scaleX(0.85); transform-origin: right center; }
.prose .forecast-card--flat::after  {
  background: repeating-linear-gradient(
    to right,
    var(--dir-color) 0 6px,
    transparent 6px 12px
  );
  transform: scaleX(0.65);
  opacity: 0.4;
}
.prose .forecast-card:hover::after { transform: scaleX(1); opacity: 0.8; }
.prose .forecast-card--flat:hover::after { opacity: 0.6; }
.prose .forecast-card--up   { --dir-color: var(--dir-up);   }
.prose .forecast-card--down { --dir-color: var(--dir-down); }
.prose .forecast-card--flat { --dir-color: var(--dir-flat); }

.prose .forecast-card__label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--body);
  font-size: 0.66rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--dir-color);
  font-weight: 700;
  padding-bottom: 0.4rem;
  margin-bottom: 0.1rem;
  position: relative;
}
.prose .forecast-card__label::before {
  /* short rule before the label — feels like an editorial tag */
  content: "";
  display: inline-block;
  width: 0.9rem;
  height: 1px;
  background: var(--dir-color);
}

.prose .forecast-card__name {
  display: block;
  font-family: var(--read);
  font-style: italic;
  font-weight: 500;
  font-feature-settings: "ss01", "kern";
  font-size: 1.05rem;
  line-height: 1.22;
  color: var(--ink);
  letter-spacing: -0.008em;
}

.prose .forecast-card__reason {
  display: block;
  font-family: var(--body);
  font-size: 0.8rem;
  line-height: 1.5;
  color: var(--ink-faint);
  margin-top: 0.15rem;
}

@media (max-width: 540px) {
  .prose .forecast-grid {
    grid-template-columns: 1fr;
  }
}

/* ─────────────────────────────────────────────────────────
   LINK CARDS — 'Günün Bağlantıları' as a sharp grid
   Built by scripts/build_site.py post-processing the markdown.
   ───────────────────────────────────────────────────────── */
.prose .prose__links-heading {
  /* The "Günün Bağlantıları" H2 keeps its prose chrome but tightens spacing */
  margin-bottom: 1.2rem;
}
.prose .link-group {
  margin: 0 0 2.25rem;
}
.prose .link-group:last-child { margin-bottom: 0; }
.prose .link-group__heading {
  font-family: var(--display);
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1, "opsz" 96;
  font-weight: 400;
  font-size: clamp(1.15rem, 0.95rem + 0.5vw, 1.45rem);
  letter-spacing: -0.015em;
  margin: 0 0 0.8rem;
  padding-bottom: 0.55rem;
  border-bottom: 1px solid var(--rule);
  color: var(--ink);
}
.prose .link-group__heading::before { content: none; }
.prose .link-group__grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.55rem;
}
.prose .link-card-wrap {
  margin: 0;
  padding: 0;
  list-style: none;
}
.prose .link-card-wrap::marker { content: ""; }
.prose .link-card {
  position: relative;
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 0.7rem;
  padding: 1rem 1.05rem 1.1rem;
  border: 1px solid var(--rule);
  background: rgba(255, 255, 255, 0.25);
  color: var(--ink);
  text-decoration: none;
  height: 100%;
  isolation: isolate;
  overflow: hidden;
  transition:
    border-color 320ms var(--ease),
    background 320ms var(--ease),
    color 320ms var(--ease);
}
.prose .link-card::before {
  /* corner-bracket accent that grows on hover — kept to a hairline */
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  height: 1px;
  background: var(--accent);
  transition: width 380ms var(--ease);
  z-index: 1;
}
.prose .link-card {
  /* Add scale transition + subtle drop shadow buildup */
  transition:
    border-color 320ms var(--ease),
    background 320ms var(--ease),
    color 320ms var(--ease),
    transform 320ms var(--ease),
    box-shadow 320ms var(--ease);
  will-change: transform;
}
.prose .link-card:hover {
  border-color: var(--ink);
  background: rgba(255, 255, 255, 0.65);
  color: var(--ink);
  transform: translateY(-1px);
  box-shadow: 0 6px 24px -12px rgba(30, 26, 22, 0.35);
}
.prose .link-card:hover::before { width: 100%; }
.prose .link-card:hover .link-card__arrow {
  color: var(--accent);
  transform: translate(3px, -3px);
}
.prose .link-card:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}
.prose .link-card__top {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
}
.prose .link-card__source {
  font-family: var(--body);
  font-size: 0.66rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-faint);
  font-weight: 700;
}
.prose .link-card__arrow {
  font-family: var(--body);
  font-style: normal;
  font-size: 1rem;
  line-height: 1;
  color: var(--ink-mute);
  transition: color 220ms var(--ease), transform 260ms var(--ease);
}
.prose .link-card__title {
  font-family: var(--read);
  font-style: italic;
  font-variation-settings: "opsz" 16;
  font-size: clamp(0.98rem, 0.92rem + 0.2vw, 1.12rem);
  line-height: 1.4;
  color: var(--ink);
  letter-spacing: -0.003em;
  text-wrap: balance;
  /* drop the default browser link underline (inherited from .prose a) */
  border-bottom: 0;
}
.prose .link-card:hover .link-card__title { color: var(--ink); }

@media (max-width: 720px) {
  .prose .link-group__grid {
    grid-template-columns: 1fr;
  }
}

.prose hr {
  border: 0;
  margin: 2.5rem auto;
  width: 5rem;
  border-top: 1px solid var(--rule);
  position: relative;
}
.prose hr::after {
  content: "✦";
  position: absolute;
  top: -0.8em;
  left: 50%;
  transform: translateX(-50%);
  background: var(--paper);
  padding: 0 0.6rem;
  color: var(--accent);
  font-size: 0.95rem;
}

.prose code {
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  font-size: 0.88em;
  padding: 0.08em 0.32em;
  background: var(--paper-deep);
  border-radius: 2px;
  color: var(--accent);
}

/* =========================================================
   COLOPHON
   ========================================================= */
.colophon {
  max-width: var(--max);
  margin: 3rem auto 0;
  padding: 2.5rem var(--gutter) 4rem;
  border-top: 1px solid var(--rule);
  display: grid;
  gap: 0.85rem;
}
.colophon__line {
  margin: 0;
  font-family: var(--read);
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--ink-soft);
  max-width: 60ch;
  font-feature-settings: "onum";
}
.colophon__line--meta {
  font-size: 0.78rem;
  color: var(--ink-faint);
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem 1rem;
  align-items: center;
}
.colophon__line--meta a {
  color: var(--ink-soft);
  border-bottom: 1px solid var(--rule);
}
.colophon__line--meta a:hover {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 720px) {
  .masthead { gap: 0.5rem; }
  .masthead__meta { width: 100%; }

  .hero__body {
    grid-template-columns: minmax(0, 1fr);
    align-items: start;
  }
  .hero__lead {
    /* Trim very long leads on mobile so the chips and CTA stay visible */
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .hero__chips { gap: 0.25rem 1rem; }

  .archive__link {
    grid-template-columns: 3rem minmax(0, 1fr);
    gap: 0.75rem;
    padding: 0.65rem 0.25rem;
  }
  .archive__num { font-size: 1.35rem; }
  .archive__cue { display: none; }
  .archive__lead { -webkit-line-clamp: 2; }

  .issue__date {
    font-size: clamp(2.4rem, 8vw + 1rem, 3.5rem);
    gap: 0.1em 0.3em;
  }
  .issue__head { padding-top: clamp(1.5rem, 4vw, 2.5rem); }

  .issue__nav {
    grid-template-columns: 1fr;
    gap: 0.5rem;
    padding: 1rem 0;
  }
  .issue__nav-link--prev,
  .issue__nav-link--next { justify-self: start; }
  .issue__nav-link--index { justify-self: start; }

  .prose > h2 { font-size: clamp(1.4rem, 1.1rem + 1vw, 1.8rem); }
  .prose > h2 + p::first-letter { font-size: 3.5em; }
}

/* ─────────────────────────────────────────────────────────
   READ PROGRESS — thin teal bar fixed to the top of the page
   that fills left-to-right as the user scrolls the article.
   ───────────────────────────────────────────────────────── */
.read-progress {
  position: fixed;
  inset: 0 0 auto 0;
  height: 2px;
  z-index: 70;
  pointer-events: none;
  background: transparent;
}
.read-progress__bar {
  display: block;
  height: 100%;
  width: 100%;
  background: var(--accent);
  transform-origin: left center;
  transform: scaleX(0);
  /* No transition — track follows scroll one-to-one for tactile feel */
  will-change: transform;
  opacity: 0.92;
}

/* ─────────────────────────────────────────────────────────
   BACK-TO-TOP — compact square icon button, fixed bottom-right
   Hidden until the user scrolls past the hero / issue head.
   No text — just an upward arrow. Accessible via aria-label.
   ───────────────────────────────────────────────────────── */
.to-top {
  position: fixed;
  right: clamp(1rem, 1.5vw, 1.75rem);
  bottom: clamp(1rem, 1.5vw, 1.75rem);
  z-index: 50;

  width: 2.75rem;
  height: 2.75rem;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  background: var(--ink);
  color: var(--paper);
  border: 1px solid var(--ink);
  /* No radius. Square. */

  cursor: pointer;

  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
  transition:
    opacity 260ms var(--ease),
    transform 260ms var(--ease),
    background 220ms var(--ease),
    border-color 220ms var(--ease);
}
.to-top.is-visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.to-top:hover {
  background: var(--accent);
  border-color: var(--accent);
}
.to-top:hover .to-top__arrow { transform: translateY(-3px); }
.to-top:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}
.to-top__arrow {
  display: block;
  font-size: 1.25rem;
  line-height: 1;
  color: var(--paper);
  font-family: var(--display);
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1;
  transition: transform 240ms var(--ease);
}

@media (max-width: 720px) {
  .to-top {
    right: 0.85rem;
    bottom: 0.85rem;
    width: 2.5rem;
    height: 2.5rem;
  }
  .to-top__arrow { font-size: 1.15rem; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    transition-duration: 0.001ms !important;
  }
  .to-top { transform: none; }
}
