/* ===========================================================
   base.css — токени, типографіка, ресет, утиліти
   Архетип: РЕДАКЦІЙНИЙ / журнальний
   =========================================================== */

:root {
  /* Палітра: глибокий нічний індиго + мідно-латунний акцент */
  --ink:        #14172E;   /* основний фон-чорнило */
  --ink-2:      #1B1F3B;   /* блок темніший */
  --paper:      #F4F1EA;   /* паперовий світлий */
  --paper-2:    #ECE7DB;   /* теплий пісок */
  --brass:      #C68A4B;   /* мідно-латунний акцент */
  --brass-deep: #A66E33;
  --line:       #2B2F4E;   /* лінія на темному */
  --line-light: #D6CFC0;   /* лінія на світлому */
  --muted:      #8C8FA8;   /* приглушений текст на темному */
  --muted-2:    #6E6A5E;   /* приглушений на світлому */

  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans:  "Manrope", system-ui, -apple-system, "Segoe UI", sans-serif;

  --maxw: 1280px;
  --gut: clamp(20px, 5vw, 84px);

  --step--1: clamp(.78rem, .76rem + .1vw, .85rem);
  --step-0:  clamp(1rem, .96rem + .2vw, 1.12rem);
  --step-1:  clamp(1.2rem, 1.1rem + .5vw, 1.5rem);
  --step-2:  clamp(1.5rem, 1.2rem + 1.4vw, 2.4rem);
  --step-3:  clamp(2.1rem, 1.5rem + 3vw, 4rem);
  --step-4:  clamp(2.8rem, 1.6rem + 6vw, 6.8rem);
}

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--sans);
  font-size: var(--step-0);
  line-height: 1.65;
  color: var(--ink);
  background: var(--paper);
  font-feature-settings: "ss01";
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 {
  font-family: var(--serif);
  font-weight: 470;
  line-height: 1.02;
  letter-spacing: -.01em;
  margin: 0;
  font-optical-sizing: auto;
}

p { margin: 0 0 1.1em; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; height: auto; }
ul { margin: 0; padding: 0; list-style: none; }

/* ---------- Layout ---------- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding-inline: var(--gut); }

.section { padding-block: clamp(56px, 9vw, 132px); }
.section--tight { padding-block: clamp(40px, 6vw, 84px); }

/* нумерований заголовок розділу */
.rubric {
  display: flex;
  align-items: baseline;
  gap: 18px;
  border-top: 1px solid var(--line-light);
  padding-top: 22px;
  margin-bottom: clamp(28px, 4vw, 56px);
}
.rubric__num {
  font-family: var(--sans);
  font-size: var(--step--1);
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--brass-deep);
  font-weight: 700;
  flex: none;
  padding-top: .4em;
}
.rubric__title { font-size: var(--step-2); max-width: 18ch; }
.rubric__lead {
  margin-left: auto;
  max-width: 38ch;
  color: var(--muted-2);
  font-size: var(--step-0);
  align-self: flex-end;
}

/* двоколонковий текст */
.cols2 {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(28px, 4vw, 64px);
}
@media (min-width: 768px) { .cols2 { grid-template-columns: 1fr 1fr; } }

.lede { font-size: var(--step-1); line-height: 1.4; color: var(--ink); }

/* широка фото-смуга */
.bleed {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 7;
  overflow: hidden;
  background: var(--ink-2);
}
.bleed--tall { aspect-ratio: 4 / 3; }
.bleed img, .bleed > img { width: 100%; height: 100%; object-fit: cover; }
.bleed { /* alias safety */ }

.figwide { position: relative; width: 100%; overflow: hidden; background: var(--ink-2); }
.figwide img { width: 100%; height: 100%; object-fit: cover; display: block; aspect-ratio: 16/7; }
.figwide__cap {
  position: absolute; left: 0; bottom: 0;
  background: var(--ink); color: var(--paper);
  font-size: var(--step--1); letter-spacing: .14em; text-transform: uppercase;
  padding: 10px 18px;
}

/* кнопки — без скруглень, типографічні */
.btn {
  display: inline-flex; align-items: center; gap: .6em;
  font-family: var(--sans); font-weight: 700;
  font-size: var(--step--1); letter-spacing: .12em; text-transform: uppercase;
  padding: 16px 26px; border: 1px solid currentColor;
  background: var(--brass); color: var(--ink); border-color: var(--brass);
  transition: background .2s, color .2s, transform .15s;
}
.btn:hover { background: var(--brass-deep); border-color: var(--brass-deep); color: var(--paper); }
.btn--ghost { background: transparent; color: var(--ink); border-color: var(--ink); }
.btn--ghost:hover { background: var(--ink); color: var(--paper); }
.btn--onink { color: var(--ink); }

.linkarrow {
  display: inline-flex; align-items: center; gap: .5em;
  font-weight: 700; font-size: var(--step--1); letter-spacing: .12em; text-transform: uppercase;
  color: var(--brass-deep); border-bottom: 1px solid currentColor; padding-bottom: 3px;
}
.linkarrow:hover { color: var(--ink); }

.tag {
  font-size: var(--step--1); letter-spacing: .26em; text-transform: uppercase;
  color: var(--brass-deep); font-weight: 700;
}

/* приховування для доступності */
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.on-ink { background: var(--ink); color: var(--paper); }
.on-ink .rubric { border-color: var(--line); }
.on-ink .rubric__lead { color: var(--muted); }
.on-ink .lede { color: var(--paper); }
.on-ink .tag { color: var(--brass); }
.on-ink a.linkarrow { color: var(--brass); }
.on-ink a.linkarrow:hover { color: var(--paper); }
