/* 자동 생성 — make-fonts.js. self-hosted 서브셋 폰트 (기사 글자만) */
@font-face{font-family:"Noto Serif KR";font-style:normal;font-weight:400;font-display:swap;src:url("fonts/noto-serif-kr-400.woff2") format("woff2");}
@font-face{font-family:"Nanum Myeongjo";font-style:normal;font-weight:400;font-display:swap;src:url("fonts/nanum-myeongjo-400.woff2") format("woff2");}
@font-face{font-family:"Nanum Myeongjo";font-style:normal;font-weight:700;font-display:swap;src:url("fonts/nanum-myeongjo-700.woff2") format("woff2");}
@font-face{font-family:"Nanum Myeongjo";font-style:normal;font-weight:800;font-display:swap;src:url("fonts/nanum-myeongjo-800.woff2") format("woff2");}
@font-face{font-family:"EB Garamond";font-style:normal;font-weight:400 500;font-display:swap;src:url("fonts/eb-garamond.woff2") format("woff2");}

/* ───────────────────────────────────────────────
   은혜의 윤리 — LRB 문예지 스타일
   크림 종이 · 명조 본문 · 절제된 와인레드
   ─────────────────────────────────────────────── */

:root {
  --paper:      #f7f3ea;   /* 크림 종이 */
  --paper-warm: #f1ebdc;   /* 살짝 짙은 종이 (인용 등) */
  --ink:        #211f1b;   /* 본문 잉크 */
  --ink-soft:   #4a463e;   /* 보조 텍스트 */
  --ink-faint:  #8a8475;   /* 흐린 메타 */
  --accent:     #7a2230;   /* 와인레드 */
  --accent-dim: #9a4b56;
  --rule:       #d8cfba;   /* 가는 괘선 */

  --serif-ko:   "Noto Serif KR", "Nanum Myeongjo", serif;
  --serif-disp: "Nanum Myeongjo", "Noto Serif KR", serif;
  --serif-lat:  "EB Garamond";   /* 끝에 serif 금지 — 뒤의 한글 폰트로 폴백돼야 함 */

  --measure:    40rem;     /* 본문 단 폭 */
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }
/* 스크롤은 기기 네이티브 속도 그대로(터치 1:1). '맨 위로'만 JS로 부드럽게 처리. */

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--serif-lat), var(--serif-ko);
  font-weight: 400;
  line-height: 1.85;
  letter-spacing: 0.01em;
  word-break: keep-all;       /* 한글 단어 보존 */
  overflow-wrap: break-word;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "kern" 1;
}

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-dim); }

/* 라틴 글자(영문·숫자)는 개러몬드, 한글은 명조로 자연 폴백 */
.title, .subtitle, h2, h3, .body-text, .standfirst, .byline,
.masthead-title, .masthead-sub, .toc-title, .toc-sub {
  font-family: var(--serif-lat), var(--serif-ko);
}

/* ═══════════════ 기사 페이지 ═══════════════ */

.skip-home {
  position: fixed;
  top: 1.4rem; left: 1.6rem;
  z-index: 3;
  font-family: var(--serif-lat), var(--serif-ko);
  font-size: 0.82rem;
  letter-spacing: 0.06em;
  color: var(--ink-faint);
}
.skip-home:hover { color: var(--accent); }

.article {
  position: relative;
  z-index: 1;
  max-width: var(--measure);
  margin: 0 auto;
  padding: 7rem 1.6rem 6rem;
}

.article-head { text-align: center; margin-bottom: 1.6rem; }

.kicker {
  font-family: var(--serif-lat), var(--serif-ko);
  font-size: 0.74rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent);
  margin: 0 0 1.8rem;
}

.title {
  font-family: var(--serif-disp);
  font-weight: 800;
  font-size: clamp(2.1rem, 6vw, 3.1rem);
  line-height: 1.22;
  letter-spacing: -0.01em;
  margin: 0;
  color: var(--ink);
}

.subtitle {
  font-family: var(--serif-disp);
  font-weight: 400;
  font-size: clamp(1.15rem, 3vw, 1.4rem);
  line-height: 1.45;
  color: var(--ink-soft);
  margin: 1rem auto 0;
  max-width: 30rem;
}

.byline {
  font-family: var(--serif-lat), var(--serif-ko);
  font-size: 1.02rem;
  color: var(--ink);
  margin: 1.9rem 0 0;
}

.meta-line {
  font-family: var(--serif-lat), var(--serif-ko);
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  color: var(--ink-faint);
  margin: 0.5rem 0 0;
}

/* 머리글 — 도입부(standfirst) */
.standfirst {
  font-family: var(--serif-lat), var(--serif-ko);
  font-size: 1.08rem;
  line-height: 1.78;
  color: var(--ink-soft);
  margin: 2.4rem auto 0;
  max-width: 34rem;
  padding: 0 0.5rem;
  text-align: justify;
}

/* 괘선 */
.head-rule, .foot-rule, .sec-rule {
  border: 0;
  height: 1px;
  background: var(--rule);
}
.head-rule {
  width: 4rem;
  margin: 2.6rem auto 2.8rem;
  height: 2px;
  background: var(--accent);
}
.sec-rule {
  width: 100%;
  margin: 2.6rem 0;
  background: transparent;
  position: relative;
  text-align: center;
}
.sec-rule::after {
  content: "❧";              /* 잎사귀 구분 장식 */
  position: relative;
  top: -0.85rem;
  display: inline-block;
  background: var(--paper);
  padding: 0 1rem;
  color: var(--accent-dim);
  font-size: 1.1rem;
}

/* 본문 */
.body-text {
  font-size: 1.16rem;
  line-height: 1.95;
}
.body-text p {
  margin: 0;
  text-align: justify;
  text-justify: inter-character;
}
.body-text p + p {
  margin-top: 1.35em;        /* 문단 사이 숨 쉴 공간 */
  text-indent: 0.9em;        /* + 문예지식 들여쓰기 */
}

/* 첫 문단: 들여쓰기 없이, 첫 글자 살짝 강조 느낌 없이 깔끔히 */
.body-text > p:first-of-type { text-indent: 0; }
.body-text > p:first-of-type::first-line { letter-spacing: 0.02em; }

/* 섹션 제목 */
.body-text h2 {
  font-family: var(--serif-disp);
  font-weight: 700;
  font-size: 1.6rem;
  line-height: 1.4;
  letter-spacing: -0.005em;
  text-align: center;
  margin: 3.4rem 0 1.6rem;
  color: var(--ink);
}
.body-text h2::after {
  content: "";
  display: block;
  width: 2rem; height: 1px;
  background: var(--rule);
  margin: 0.9rem auto 0;
}

.body-text h3 {
  font-family: var(--serif-disp);
  font-weight: 700;
  font-size: 1.18rem;
  letter-spacing: 0.01em;
  margin: 2.6rem 0 0.9rem;
  color: var(--accent);
}

/* 인용(성경·강조) */
.body-text blockquote {
  margin: 2rem 0;
  padding: 0.2rem 0 0.2rem 1.4rem;
  border-left: 2px solid var(--accent);
  font-size: 1.12rem;
  line-height: 1.8;
  color: var(--ink-soft);
  text-align: left;
}

/* 푸터 */
.article-foot { text-align: center; margin-top: 4rem; }
.foot-rule { width: 6rem; margin: 0 auto 1.6rem; }
.article-foot a {
  font-size: 0.9rem;
  letter-spacing: 0.04em;
  color: var(--ink-faint);
}
.article-foot a:hover { color: var(--accent); }

/* ═══════════════ 목차 페이지 ═══════════════ */

.index {
  position: relative;
  z-index: 1;
  max-width: 44rem;
  margin: 0 auto;
  padding: 6rem 1.6rem 6rem;
}

.masthead { text-align: center; }
.masthead-kicker {
  font-size: 0.74rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent);
  margin: 0 0 2rem;
}
.masthead-title {
  font-family: var(--serif-disp);
  font-weight: 800;
  font-size: clamp(2.8rem, 9vw, 4.6rem);
  line-height: 1.05;
  letter-spacing: -0.015em;
  margin: 0;
}
.masthead-sub {
  font-family: var(--serif-disp);
  font-weight: 400;
  font-size: clamp(1.1rem, 3vw, 1.35rem);
  line-height: 1.5;
  color: var(--ink-soft);
  margin: 1.4rem auto 0;
  max-width: 30rem;
}
.masthead-meta {
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  color: var(--ink-faint);
  margin: 1.4rem 0 0;
}
.masthead-rule {
  width: 100%;
  height: 1px;
  background: var(--rule);
  margin: 3.4rem 0;
}

.toc-day { margin-bottom: 3rem; }
.toc-day-head { margin-bottom: 1.4rem; }
.toc-day-title {
  font-family: var(--serif-disp);
  font-weight: 700;
  font-size: 1.05rem;
  letter-spacing: 0.16em;
  color: var(--accent);
  margin: 0;
  display: inline-block;
}
.toc-day-sub {
  font-size: 0.84rem;
  color: var(--ink-faint);
  letter-spacing: 0.03em;
  margin: 0.35rem 0 0;
}

.toc-list { list-style: none; margin: 0; padding: 0; }
.toc-entry { border-top: 1px solid var(--rule); }
.toc-entry:last-child { border-bottom: 1px solid var(--rule); }
.toc-entry a {
  display: flex;
  align-items: baseline;
  gap: 1.4rem;
  padding: 1.5rem 0.4rem;
  color: var(--ink);
  transition: background 0.18s ease, padding 0.18s ease;
}
.toc-entry a:hover {
  background: var(--paper-warm);
  padding-left: 1rem; padding-right: 1rem;
}
.toc-num {
  font-family: var(--serif-lat), serif;
  font-size: 1.5rem;
  font-weight: 400;
  color: var(--accent-dim);
  min-width: 2.2rem;
  line-height: 1;
}
.toc-text { display: flex; flex-direction: column; gap: 0.3rem; }
.toc-title {
  font-family: var(--serif-disp);
  font-weight: 700;
  font-size: 1.32rem;
  line-height: 1.3;
  color: var(--ink);
}
.toc-entry a:hover .toc-title { color: var(--accent); }
.toc-sub {
  font-size: 0.96rem;
  color: var(--ink-soft);
  line-height: 1.45;
}
.toc-byline {
  font-size: 0.8rem;
  letter-spacing: 0.04em;
  color: var(--ink-faint);
  margin-top: 0.15rem;
}

.index-foot {
  margin-top: 3.5rem;
  padding-top: 2rem;
  border-top: 1px solid var(--rule);
  text-align: center;
}
.index-foot p {
  font-size: 0.86rem;
  color: var(--ink-faint);
  line-height: 1.7;
  margin: 0;
}

/* ═══════════════ 반응형 ═══════════════ */
@media (max-width: 640px) {
  body { line-height: 1.8; }
  .article { padding: 5rem 1.3rem 4rem; }
  .body-text { font-size: 1.1rem; line-height: 1.9; }
  .body-text p + p { text-indent: 1.1em; }
  /* 좁은 화면에선 양끝맞춤 해제 — 단어 사이 과도한 간격 방지 */
  .body-text p, .standfirst { text-align: left; }
  .skip-home { top: 1rem; left: 1.1rem; }
  .toc-entry a { gap: 1rem; }
  .toc-num { font-size: 1.25rem; min-width: 1.8rem; }
  .toc-title { font-size: 1.18rem; }
}

/* ═══════════════ 다크 모드 ═══════════════
   수동 토글(data-theme) + 시스템 설정 자동 적용.
   사용자가 light를 고르면 시스템 dark도 무시. */
:root[data-theme="dark"] {
  --paper:      #17150f;
  --paper-warm: #201d16;
  --ink:        #ece6d8;
  --ink-soft:   #bcb5a3;
  --ink-faint:  #888073;
  --accent:     #d59aa2;
  --accent-dim: #c1828b;
  --rule:       #3a352c;
}
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --paper:      #17150f;
    --paper-warm: #201d16;
    --ink:        #ece6d8;
    --ink-soft:   #bcb5a3;
    --ink-faint:  #888073;
    --accent:     #d59aa2;
    --accent-dim: #c1828b;
    --rule:       #3a352c;
  }
}

/* ═══════════════ 컨트롤 버튼 (테마·맨위로) ═══════════════ */
.ctrl-btn {
  position: fixed;
  z-index: 4;
  width: 2.7rem;
  height: 2.7rem;
  border-radius: 50%;
  border: 1px solid var(--rule);
  background: var(--paper-warm);
  color: var(--ink-soft);
  font-family: var(--serif-lat), serif;
  font-size: 1.1rem;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 1px 6px rgba(60, 50, 30, 0.08);
  transition: color 0.18s ease, border-color 0.18s ease,
              background 0.18s ease, opacity 0.25s ease,
              transform 0.25s ease, visibility 0.25s;
}
.ctrl-btn:hover {
  color: var(--accent);
  border-color: var(--accent-dim);
}

#theme-toggle { top: 1.3rem; right: 1.4rem; }

#to-top {
  bottom: 1.4rem;
  right: 1.4rem;
  font-size: 1.25rem;
  opacity: 0;
  visibility: hidden;
  transform: translateY(0.6rem);
}
#to-top.show { opacity: 1; visibility: visible; transform: translateY(0); }

/* 토글 아이콘: 라이트→달, 다크→해 */
.icon-sun { display: none; }
.icon-moon { display: inline; }
:root[data-theme="dark"] .icon-sun { display: inline; }
:root[data-theme="dark"] .icon-moon { display: none; }
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .icon-sun { display: inline; }
  :root:not([data-theme="light"]) .icon-moon { display: none; }
}

/* ═══════════════ 기사 하단 이전/다음 네비 ═══════════════ */
.article-nav {
  display: flex;
  gap: 1.4rem;
  margin: 0 0 2.4rem;
}
.nav-link {
  flex: 1 1 0;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding: 1.2rem 1.3rem;
  border: 1px solid var(--rule);
  border-radius: 2px;
  transition: background 0.18s ease, border-color 0.18s ease;
}
a.nav-link:hover { background: var(--paper-warm); border-color: var(--accent-dim); }
.nav-prev { text-align: left; }
.nav-next { text-align: right; }
.nav-empty { border: none; background: none; }
.nav-label {
  font-family: var(--serif-lat), var(--serif-ko);
  font-size: 0.74rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
}
.nav-title {
  font-family: var(--serif-disp);
  font-weight: 700;
  font-size: 1.1rem;
  line-height: 1.35;
  color: var(--ink);
}
a.nav-link:hover .nav-title { color: var(--accent); }

.back-toc {
  display: block;
  text-align: center;
  font-size: 0.9rem;
  letter-spacing: 0.04em;
  color: var(--ink-faint);
}
.back-toc:hover { color: var(--accent); }

@media (max-width: 640px) {
  .article-nav { flex-direction: column; gap: 0.9rem; }
  .nav-next, .nav-prev { text-align: left; }
  .nav-empty { display: none; }
  .ctrl-btn { width: 2.5rem; height: 2.5rem; }
  #theme-toggle { top: 0.9rem; right: 1rem; }
  #to-top { bottom: 1rem; right: 1rem; }
}

/* ═══════════════ 인쇄 ═══════════════ */
@media print {
  body { background: #fff; color: #000; }
  .skip-home, .article-foot, .ctrl-btn { display: none; }
  .article { max-width: none; padding: 0; }
}
