   TWEAK VARIATIONS
   ========================================================================== */

/* ---- Font combinations ---- */
[data-fonts="serif-sans"] { --font-display: var(--font-serif); --font-heading: var(--font-serif); --font-body: var(--font-sans); }
[data-fonts="all-serif"]  { --font-display: var(--font-serif); --font-heading: var(--font-serif); --font-body: var(--font-serif); }
[data-fonts="all-serif"] body { font-size: var(--text-base); line-height: 1.66; }
[data-fonts="sans-serif"] { --font-display: var(--font-sans); --font-heading: var(--font-sans); --font-body: var(--font-serif); }
[data-fonts="sans-serif"] .hero__title,
[data-fonts="sans-serif"] .section-head__title,
[data-fonts="sans-serif"] .feat__title { letter-spacing: -0.035em; font-weight: var(--fw-semibold); }
[data-fonts="sans-serif"] .hero__title em,
[data-fonts="sans-serif"] .about__manifesto em { font-style: normal; }
[data-fonts="all-sans"]   { --font-display: var(--font-sans); --font-heading: var(--font-sans); --font-body: var(--font-sans); }
[data-fonts="all-sans"] .hero__title,
[data-fonts="all-sans"] .section-head__title { letter-spacing: -0.035em; font-weight: var(--fw-semibold); }
[data-fonts="all-sans"] .hero__title em,
[data-fonts="all-sans"] .about__manifesto em,
[data-fonts="all-sans"] .membership__title em,
[data-fonts="all-sans"] .topic__name em { font-style: normal; }

/* ---- Collection / section accent (topic + hero index + arrows) ---- */
[data-accent="olive"]    { --collection-accent: var(--olive-600);     --collection-accent-soft: var(--olive-100); }
[data-accent="burgundy"] { --collection-accent: var(--burgundy-muted); --collection-accent-soft: var(--burgundy-soft); }
[data-accent="ochre"]    { --collection-accent: var(--ochre-soft);     --collection-accent-soft: var(--ochre-tint); }
[data-accent="navy"]     { --collection-accent: var(--navy-deep);      --collection-accent-soft: var(--navy-soft); }
[data-accent="clay"]     { --collection-accent: var(--clay-soft);      --collection-accent-soft: var(--clay-tint); }
/* apply collection accent to the topic + featured zones (not global olive nav/buttons) */
[data-accent] #featured, [data-accent] #topics, [data-accent] #latest {
  --section-accent: var(--collection-accent); --section-accent-soft: var(--collection-accent-soft);
}
/* "mixed" = leave per-topic colors as authored; non-mixed unifies topic tiles */
[data-accent]:not([data-accent="mixed"]) .topic {
  --t-accent: var(--collection-accent); --t-soft: var(--collection-accent-soft);
}

/* ---- Background tone (light theme only) ---- */
[data-bg="warm"]:not([data-theme="dark"]) { --color-bg-page: #f3ece0; --color-bg-page-alt: #efe7d8; --color-bg-surface: #faf5ec; }
[data-bg="ivory"]:not([data-theme="dark"]) { --color-bg-page: var(--warm-050); --color-bg-page-alt: var(--warm-100); }

/* ---- Tone: calm (default) vs bold ---- */
[data-tone="bold"] {
  --text-hero: clamp(3rem, 1.7rem + 5.6vw, 6.2rem);
  --tracking-tight: -0.035em;
}
[data-tone="bold"] .hero__title { font-weight: var(--fw-semibold); line-height: 1.12; font-size: clamp(1.7rem, 0.7rem + 4.6vw, 3.5rem); }
[data-tone="bold"] .hero { padding-top: clamp(4rem, 7vw, 8rem); }
[data-tone="bold"] .section-head__title { font-weight: var(--fw-semibold); }
[data-tone="bold"] .hero__eyebrow .eyebrow,
[data-tone="bold"] .section-head .eyebrow { letter-spacing: var(--tracking-widest); }
[data-tone="bold"] .cover__glyph { color: color-mix(in srgb, var(--cv-fg, var(--olive-700)) 20%, transparent); }
[data-tone="bold"] .feat__title,
[data-tone="bold"] .row__title { font-weight: var(--fw-medium); }
[data-tone="bold"] .block { padding-block: clamp(4.5rem, 9vw, 8.5rem); }

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 1000px) {
  .hero__grid { grid-template-columns: 1fr; gap: var(--space-12); align-items: stretch; }
  .featured-grid { grid-template-columns: repeat(2, 1fr); }
  .topics { grid-template-columns: repeat(2, 1fr); }
  .about { grid-template-columns: 1fr; gap: var(--space-10); }
  .membership__grid { grid-template-columns: 1fr; gap: var(--space-10); }
  .footer__top { grid-template-columns: 1fr 1fr; gap: var(--space-10); }
}
@media (max-width: 720px) {
  /* header nav → mobile dropdown is owned by aw-base.css (.site-menu / .nav-toggle) */
  .brand__tag { display: none; }
  .hero__stats { flex-wrap: wrap; gap: var(--space-6); }
  .featured-grid { grid-template-columns: 1fr; }
  .topics { grid-template-columns: 1fr; }
  .row { grid-template-columns: 1fr; gap: var(--space-2); }
  .row__no { display: none; }
  .row__aside { flex-direction: row; align-items: center; }
  .news__inner { grid-template-columns: 1fr; }
  .footer__top { grid-template-columns: 1fr 1fr; }
  .section-head { flex-direction: column; align-items: flex-start; gap: var(--space-4); }
}
@media (max-width: 480px) {
  .footer__top { grid-template-columns: 1fr; }
  .news__form { width: 100%; }
  .field { min-width: 0; flex: 1; }
}

/* ==========================================================================
   Membership auth (mock) — header controls, modal, member menu, scraps
   ========================================================================== */
.btn--sm { min-height: 2.4rem; padding: 0 1rem; font-size: var(--text-sm); }
.auth-slot { display: flex; align-items: center; gap: var(--space-3); }

.auth-link {
  background: none; border: 0; cursor: pointer; padding: 0.4rem 0.2rem; white-space: nowrap;
  font-family: var(--font-meta); font-size: var(--text-sm); color: var(--color-text-secondary);
  position: relative; transition: color var(--dur-fast) var(--ease);
}
.auth-link::after { content: ""; position: absolute; left: 0; right: 100%; bottom: 0.1rem; height: 1px;
  background: var(--color-text-primary); transition: right var(--dur-normal) var(--ease); }
.auth-link:hover { color: var(--color-text-primary); }
.auth-link:hover::after { right: 0; }

/* scrap quick-link (logged in) */
.scrap-link {
  display: inline-flex; align-items: center; gap: 0.4rem; cursor: pointer; white-space: nowrap;
  background: none; border: 0; padding: 0.4rem 0.3rem;
  font-family: var(--font-meta); font-size: var(--text-sm); color: var(--color-text-secondary);
  transition: color var(--dur-fast) var(--ease);
}
.scrap-link:hover { color: var(--color-text-primary); }
.scrap-link__n {
  display: inline-grid; place-items: center; min-width: 1.25rem; height: 1.25rem; padding: 0 0.3rem;
  border-radius: var(--radius-pill); background: var(--color-accent); color: var(--color-text-on-accent);
  font-size: var(--text-2xs); font-weight: var(--fw-semibold); line-height: 1;
}

/* member chip + dropdown */
.member { position: relative; }
.member__btn {
  display: inline-flex; align-items: center; gap: 0.5rem; cursor: pointer; white-space: nowrap;
  background: var(--color-bg-surface); border: 1px solid var(--color-border-default);
  border-radius: var(--radius-pill); padding: 0.3rem 0.7rem 0.3rem 0.35rem;
  color: var(--color-text-primary); transition: border-color var(--dur-fast) var(--ease);
}
.member__btn:hover { border-color: var(--color-border-strong); }
.member__avatar {
  display: inline-grid; place-items: center; width: 1.7rem; height: 1.7rem; border-radius: 50%;
  background: var(--color-accent); color: var(--color-text-on-accent);
  font-family: var(--font-display); font-size: var(--text-sm); line-height: 1;
}
.member__name { font-family: var(--font-meta); font-size: var(--text-sm); max-width: 8rem;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.member__chev { color: var(--color-text-muted); }
.member__menu {
  position: absolute; right: 0; top: calc(100% + 0.5rem); z-index: 60; min-width: 12rem;
  background: var(--color-bg-surface); border: 1px solid var(--color-border-default);
  border-radius: var(--radius-md); box-shadow: var(--shadow-lg, 0 20px 50px rgba(0,0,0,0.25));
  padding: 0.4rem; display: flex; flex-direction: column;
}
.member__menu button {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem; cursor: pointer;
  background: none; border: 0; text-align: left; padding: 0.6rem 0.7rem; border-radius: var(--radius-sm);
  font-family: var(--font-meta); font-size: var(--text-sm); color: var(--color-text-secondary);
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.member__menu button:hover { background: var(--color-bg-surface-soft); color: var(--color-text-primary); }

/* ---- modal shell (auth + scraps) ---- */
.modal { position: fixed; inset: 0; z-index: 200; display: none; }
.modal.is-open { display: block; }
html.modal-lock, html.modal-lock body { overflow: hidden; }
.modal__overlay { position: absolute; inset: 0; background: rgba(12,11,7,0.62);
  backdrop-filter: blur(3px); opacity: 0; animation: modalFade var(--dur-normal) var(--ease) forwards; }
.modal__card {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -46%);
  width: min(94vw, 25rem); max-height: 88vh; overflow: auto;
  background: var(--color-bg-page); border: 1px solid var(--color-border-default);
  border-radius: var(--radius-lg); padding: clamp(1.6rem, 3vw, 2.4rem);
  box-shadow: 0 40px 110px rgba(0,0,0,0.5);
  opacity: 0; animation: modalRise var(--dur-slow, 0.4s) var(--ease) forwards;
}
.modal__card--wide { width: min(94vw, 34rem); }
@keyframes modalFade { to { opacity: 1; } }
@keyframes modalRise { to { opacity: 1; transform: translate(-50%, -50%); } }
@media (prefers-reduced-motion: reduce) {
  .modal__overlay, .modal__card { animation: none; opacity: 1; }
  .modal__card { transform: translate(-50%, -50%); }
}
.modal__x {
  position: absolute; right: 0.9rem; top: 0.9rem; cursor: pointer;
  display: inline-grid; place-items: center; width: 2rem; height: 2rem; border-radius: 50%;
  background: none; border: 0; color: var(--color-text-muted);
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.modal__x:hover { background: var(--color-bg-surface-soft); color: var(--color-text-primary); }
.modal__eyebrow { display: block; margin-bottom: var(--space-3); }
.modal__title { font-family: var(--font-display); font-size: var(--text-2xl);
  letter-spacing: var(--tracking-tight); color: var(--color-text-primary); margin: 0 0 var(--space-5); }
.modal__tabs { display: flex; gap: 0.4rem; padding: 0.3rem; margin-bottom: var(--space-5);
  background: var(--color-bg-surface-soft); border-radius: var(--radius-pill); }
.modal__tab {
  flex: 1; cursor: pointer; background: none; border: 0; padding: 0.55rem 0.5rem; border-radius: var(--radius-pill);
  font-family: var(--font-meta); font-size: var(--text-sm); color: var(--color-text-muted);
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.modal__tab.is-active { background: var(--color-bg-page); color: var(--color-text-primary);
  box-shadow: 0 1px 3px rgba(0,0,0,0.12); }
.modal__note { font-size: var(--text-sm); color: var(--color-text-secondary); line-height: var(--leading-normal);
  background: var(--color-bg-surface-soft); border-left: 2px solid var(--color-accent);
  padding: 0.7rem 0.9rem; border-radius: var(--radius-sm); margin: 0 0 var(--space-4); }
.modal__form { display: flex; flex-direction: column; gap: var(--space-4); }
.modal__field { display: flex; flex-direction: column; gap: 0.4rem; }
.modal__field > span { font-family: var(--font-meta); font-size: var(--text-xs);
  letter-spacing: var(--tracking-wide); color: var(--color-text-muted); }
.modal__field .field { width: 100%; }
.modal__submit { width: 100%; margin-top: var(--space-2); }
.modal__fine { display: block; margin-top: var(--space-4); text-align: center; }

/* ---- scrap list ---- */
.scrap-list { display: flex; flex-direction: column; }
.scrap-empty { font-size: var(--text-base); color: var(--color-text-secondary); line-height: var(--leading-normal);
  padding: var(--space-6) 0; text-align: center; }
.scrap-empty strong { color: var(--color-accent); font-weight: var(--fw-semibold); }
.scrap-row { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: var(--space-4);
  padding: var(--space-4) 0; border-top: 1px solid var(--color-border-soft); }
.scrap-row:first-child { border-top: 0; }
.scrap-row__no { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--color-text-muted); }
.scrap-row__open { text-align: left; background: none; border: 0; cursor: pointer; display: flex;
  flex-direction: column; gap: 0.2rem; min-width: 0; }
.scrap-row__kicker { font-family: var(--font-meta); font-size: var(--text-2xs);
  letter-spacing: var(--tracking-wide); color: var(--color-text-muted); text-transform: uppercase; }
.scrap-row__title { font-family: var(--font-display); font-size: var(--text-lg); line-height: var(--leading-snug);
  color: var(--color-text-primary); transition: color var(--dur-fast) var(--ease); }
.scrap-row__open:hover .scrap-row__title { color: var(--color-accent); }
.scrap-row__del { cursor: pointer; background: none; border: 0; color: var(--color-text-muted);
  display: inline-grid; place-items: center; width: 1.9rem; height: 1.9rem; border-radius: 50%;
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease); }
.scrap-row__del:hover { background: var(--color-bg-surface-soft); color: var(--burgundy-muted); }

/* ---- reader scrap button ---- */
.reader__actions { display: flex; align-items: center; gap: 0.6rem; }
.reader__scrap {
  display: inline-flex; align-items: center; gap: 0.45rem; cursor: pointer; white-space: nowrap;
  background: rgba(245,247,238,0.06); border: 1px solid rgba(245,247,238,0.18);
  border-radius: var(--radius-pill); padding: 0.5rem 0.95rem;
  font-family: var(--font-meta); font-size: var(--text-sm); color: #e9e3d4;
  transition: background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.reader__scrap:hover { background: rgba(245,247,238,0.12); border-color: rgba(245,247,238,0.36); }
.reader__scrap .ic-on { display: none; }
.reader__scrap.is-on { color: #cbd6a3; border-color: rgba(203,214,163,0.5); background: rgba(203,214,163,0.12); }
.reader__scrap.is-on .ic-off { display: none; }
.reader__scrap.is-on .ic-on { display: inline; }

/* ==========================================================================
   Hover micro-interactions (restrained, premium — not chaotic)
   ========================================================================== */
.row { transition: background var(--dur-normal) var(--ease); }
.row__title { transition: color var(--dur-fast) var(--ease); }
.row:hover .row__title { color: var(--section-accent); }
.row__no { transition: color var(--dur-fast) var(--ease), letter-spacing var(--dur-normal) var(--ease); }
.row:hover .row__no { color: var(--section-accent); letter-spacing: 0.04em; }
.feat .cover { transition: transform var(--dur-slow, 0.4s) var(--ease), box-shadow var(--dur-slow, 0.4s) var(--ease); }
.feat:hover .cover { transform: translateY(-4px); }
.feat__title { transition: color var(--dur-fast) var(--ease); }
.feat:hover .feat__title { color: var(--section-accent); }
.topic { transition: background var(--dur-normal) var(--ease), transform var(--dur-normal) var(--ease); }
.topic:hover { transform: translateY(-2px); }
.index__item .index__entry-title { transition: color var(--dur-fast) var(--ease); }
.index__item:hover .index__entry-title { color: var(--section-accent); }

/* ── 인증·회원 페이지(다크) ───────────────────────────── */
.aw-auth-wrap { padding: 64px 0; }
.aw-auth { max-width: 460px; margin: 0 auto; padding: 36px; border: 1px solid var(--color-border-soft); border-radius: var(--radius-lg, 20px); background: var(--color-bg-surface); }
.aw-auth--wide { max-width: 760px; }
.aw-auth h1 { font-family: var(--font-display); font-size: var(--text-3xl, 1.9rem); margin: 10px 0 6px; letter-spacing: var(--tracking-tight); color: var(--color-text-primary); }
.aw-auth .lead { color: var(--color-text-secondary); margin: 0 0 20px; line-height: 1.6; }
.aw-auth .f { display: block; margin-bottom: 14px; }
.aw-auth .f > span { display: block; font-size: var(--text-sm, .85rem); font-weight: var(--fw-semibold, 600); color: var(--color-text-secondary); margin-bottom: 6px; }
.aw-auth .f .field { width: 100%; }
.aw-auth .err { margin: 0 0 16px; padding: 12px 14px; border-radius: var(--radius-md, 14px); background: var(--color-access-members-bg); border: 1px solid var(--burgundy-muted); color: var(--color-text-primary); font-size: 14px; }
.aw-auth .err li { margin: 2px 0; }
.aw-auth .foot { margin-top: 16px; color: var(--color-text-secondary); font-size: 14px; }
.aw-auth .foot a { color: var(--color-link); font-weight: 600; }
.btn--block { width: 100%; justify-content: center; }
.aw-panel { border: 1px solid var(--color-border-soft); border-radius: var(--radius-md, 14px); background: var(--color-bg-surface-soft); padding: 18px; margin-bottom: 14px; }
.aw-panel h3 { margin: 0 0 6px; font-size: var(--text-md, 1.05rem); color: var(--color-text-primary); }
.aw-panel p { margin: 0; color: var(--color-text-secondary); font-size: 14px; }

/* ── 콘텐츠 목록/상세(다크) ───────────────────────────── */
.aw-list-wrap, .aw-article-wrap { padding: 56px 0; }
/* ── 잡지형 읽기(v3): 글 영역만 라이트 크림 종이로 재스코프 ───────────── */
.aw-article {
  max-width: var(--max-reading, 720px); margin: 0 auto;
  /* 페이지는 다크지만, 글은 크림 종이 위에서 읽히도록 토큰 재스코프 */
  --color-bg-surface: #faf6ee;
  --color-text-primary: #1f1f1a; --color-text-body: #454338;
  --color-text-secondary: #666457; --color-text-muted: #8a8678;
  --color-text-reading: #454338;
  --color-accent: #5c6940; --color-link: #4e5a34;
  --color-border-soft: #e3dccd; --color-border-default: #d9d3c4;
  --color-bg-surface-soft: #ece4d3;

  position: relative;
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(255,252,245,.5), rgba(255,252,245,0) 60%),
    #faf6ee;
  border-radius: 8px;
  padding: clamp(2rem, 5vw, 3.6rem) clamp(1.4rem, 5vw, 3.2rem) clamp(2.6rem, 6vw, 4rem);
  box-shadow: 0 40px 110px rgba(0,0,0,.45), 0 0 0 1px rgba(120,96,52,.07);
  color: var(--color-text-body);
}
/* 종이결 텍스처(기존 reader 기법 재사용) */
.aw-article::before {
  content: ""; position: absolute; inset: 0; border-radius: inherit;
  pointer-events: none; mix-blend-mode: multiply; opacity: .5;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");
  background-size: 200px 200px;
}
.aw-article > * { position: relative; z-index: 1; }

/* ── 본문 복사 방지(드래그 선택 차단) ─────────────────────────────────
   글 본문에만 적용 — 폼/로그인/네비게이션 등 다른 영역은 정상 동작.
   ※ 화면에 보이는 글의 '캐주얼 복사'를 막는 억지(deterrence)일 뿐,
     완전한 보호는 아님(개발자도구·소스보기·캡처로는 우회 가능). */
.aw-article-body,
#reader .reader__content {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-touch-callout: none; /* iOS 길게 눌러 복사 메뉴 차단 */
}
/* 본문 안에서도 링크는 클릭 가능해야 하므로 선택만 막고 동작은 유지 */
.aw-article-body a,
#reader .reader__content a { -webkit-user-drag: none; user-drag: none; }

.aw-article .back { display: inline-block; color: var(--color-text-secondary); font-size: 14px; }
.aw-article .back:hover { color: var(--color-accent); }
.art-topbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.scrap-form { margin: 0; }
.scrap-btn { display: inline-flex; align-items: center; gap: 6px; cursor: pointer;
  background: var(--color-bg-surface-soft); border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-pill, 999px); padding: 6px 13px;
  font-family: var(--font-meta); font-size: 13px; color: var(--color-text-secondary);
  transition: color .15s ease, border-color .15s ease, background .15s ease; }
.scrap-btn:hover { color: var(--color-text-primary); border-color: var(--color-border-default); }
.scrap-btn.is-on { color: var(--color-accent); border-color: var(--color-accent);
  background: var(--color-accent-soft, rgba(174,183,140,0.16)); }
.scrap-btn.is-on svg { fill: currentColor; }
.scrap-btn[disabled] { opacity: .5; cursor: default; }
.aw-article-head .art-tags { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
.aw-article .art-kicker {
  font-family: var(--font-sans); font-size: var(--text-2xs);
  font-weight: var(--fw-semibold); letter-spacing: var(--tracking-wider);
  text-transform: uppercase; color: var(--color-accent);
}
.aw-article h1 {
  font-family: var(--font-serif); font-weight: var(--fw-medium);
  font-size: clamp(2rem, 1.4rem + 2.4vw, 2.9rem); line-height: 1.14;
  letter-spacing: var(--tracking-tight); margin: 10px 0 0;
  color: var(--color-text-primary); text-wrap: balance;
}
.aw-article .art-dek {
  font-family: var(--font-serif); font-weight: var(--fw-regular);
  font-size: 1.22rem; line-height: 1.55; color: var(--color-text-secondary);
  margin: 14px 0 0; text-wrap: pretty;
}
.aw-article .art-meta {
  font-family: var(--font-sans); color: var(--color-text-muted);
  font-size: var(--text-xs); letter-spacing: .02em; margin-top: 14px;
}
.aw-article-figure { margin: clamp(1.6rem, 3vw, 2.4rem) 0; }
.aw-article-cover {
  width: 100%; aspect-ratio: 16 / 9; object-fit: cover;
  display: block;
  /* 삽화의 흰 배경을 종이색에 녹여 '둥둥 뜨는' 느낌 제거 */
  mix-blend-mode: multiply;
}
.aw-article-figure figcaption {
  font-family: var(--font-sans); font-size: var(--text-xs);
  color: var(--color-text-muted); margin-top: .55rem;
}
/* 잡지형 읽기 — 모바일·동작축소 마감 */
@media (max-width: 640px) {
  .aw-article { padding: 1.6rem 1.2rem 2.2rem; }
  .aw-article-body { font-size: 1.08rem; line-height: 1.8; }
}
@media (prefers-reduced-motion: reduce) {
  .aw-article { box-shadow: 0 10px 30px rgba(0,0,0,.35); }
}
/* 잡지형 본문(v3): 명조 한 목소리 */
.aw-article-body {
  margin-top: 28px; font-family: var(--font-serif);
  font-size: 1.18rem; line-height: 1.84; color: var(--color-text-body);
}
.aw-article-body > .lead { font-size: 1.3rem; line-height: 1.6; color: var(--color-text-primary); }
.aw-article-body strong, .aw-article-body b { color: var(--color-text-primary); font-weight: var(--fw-semibold); }
.aw-article-body p { margin: 0 0 1.35rem; text-wrap: pretty; }
.aw-article-body h2 {
  font-family: var(--font-serif); font-weight: var(--fw-medium);
  font-size: 1.6rem; line-height: 1.3; letter-spacing: var(--tracking-tight);
  color: var(--color-text-primary); margin: 2.6rem 0 1rem;
}
.aw-article-body h3 {
  font-family: var(--font-serif); font-weight: var(--fw-medium);
  font-size: 1.3rem; color: var(--color-text-primary); margin: 1.8rem 0 .7rem;
}
.aw-article-body ul, .aw-article-body ol { margin: 0 0 1.35rem; padding-left: 1.4rem; }
.aw-article-body li { margin: .35rem 0; }
/* 조용한 풀쿼트: 이탤릭 명조 + 올리브 좌측 선, 배경/박스 없음 */
.aw-article-body blockquote {
  margin: 2rem 0; padding: 0 0 0 1.3rem;
  border-left: 2px solid var(--color-accent); background: none; border-radius: 0;
  font-family: var(--font-serif); font-style: italic; font-weight: var(--fw-regular);
  font-size: clamp(1.35rem, 1rem + 1.1vw, 1.6rem); line-height: 1.5;
  color: var(--color-accent);
}
.aw-article-body blockquote p { margin: 0; }
.aw-article-body a { color: var(--color-link); text-decoration: underline; text-underline-offset: 3px; }
.aw-article-body img { max-width: 100%; border-radius: 12px; border: 1px solid var(--color-border-soft); }
.aw-article-body code { background: var(--color-bg-surface-soft); padding: .15em .4em; border-radius: 6px; font-family: var(--font-mono); font-size: .92em; }
.aw-article-body pre { background: var(--color-bg-surface-soft); padding: 16px; border-radius: 12px; overflow: auto; border: 1px solid var(--color-border-soft); }
.aw-fade { height: 80px; margin-top: -28px; background: linear-gradient(180deg, transparent, var(--color-bg-page)); }
.aw-paywall { margin-top: 16px; padding: 32px; text-align: center; border: 1px solid var(--color-border-soft); border-radius: var(--radius-lg, 20px); background: var(--color-bg-surface); }
.aw-paywall h3 { margin: 0 0 10px; color: var(--color-text-primary); }
.aw-paywall p { margin: 0 0 16px; color: var(--color-text-secondary); }


/* ── 24시간 무료 공개(카운트다운) ───────────────────────── */
.free-window { display: flex; align-items: center; gap: 8px; margin: 14px 0 22px; padding: 10px 14px;
  border: 1px solid color-mix(in srgb, var(--color-accent) 55%, transparent); border-radius: 10px;
  background: var(--color-accent-soft, rgba(174,183,140,0.14)); color: var(--color-text-primary);
  font-size: 14px; line-height: 1.4; }
.free-window svg { color: var(--color-accent); flex: 0 0 auto; }
.free-window strong { color: var(--color-accent); font-weight: var(--fw-semibold, 600); }
.free-window.is-expired { opacity: .6; }
.badge.free-pill { background: var(--color-accent-soft, rgba(174,183,140,0.16)); color: var(--color-accent);
  border: 1px solid color-mix(in srgb, var(--color-accent) 38%, transparent); white-space: nowrap; }

/* ── 내 서재(스크랩 진열대) ─────────────────────────────── */
.shelf__head { margin-bottom: 14px; }
.shelf__sub { color: var(--color-text-secondary); font-size: 14px; margin-top: 4px; }
.shelf__filters { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 18px; }
.shelf__chip { cursor: pointer; border: 1px solid var(--color-border-soft); background: var(--color-bg-surface);
  color: var(--color-text-secondary); border-radius: var(--radius-pill, 999px); padding: 6px 12px;
  font-family: var(--font-meta); font-size: 13px; display: inline-flex; align-items: center; gap: 6px;
  transition: color .15s, border-color .15s, background .15s; }
.shelf__chip:hover { color: var(--color-text-primary); border-color: var(--color-border-default); }
.shelf__chip.is-active { color: var(--color-text-on-accent, #15140f); background: var(--color-accent); border-color: var(--color-accent); }
.shelf__n { font-size: 11px; opacity: .85; }
.shelf__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: clamp(14px, 2vw, 22px); }
.shelf__item { display: flex; flex-direction: column; }
.shelf__card { display: block; transition: transform .18s ease; }
.shelf__card .cover { box-shadow: var(--shadow-sm, 0 6px 18px rgba(0,0,0,.35)); }
.shelf__card:hover { transform: translateY(-4px); }
.shelf__foot { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-top: 8px; }
.shelf__label { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.shelf__del { cursor: pointer; background: none; border: 0; color: var(--color-text-muted); padding: 4px; line-height: 0;
  border-radius: 6px; transition: color .15s, background .15s; }
.shelf__del:hover { color: var(--burgundy-muted, #d99a8b); background: var(--color-bg-surface-soft); }
@media (max-width: 480px) { .shelf__grid { grid-template-columns: repeat(2, 1fr); } }

/* ── 서비스(shop-in-shop) 갤러리 카드 ───────────────────── */
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.2rem, 2.5vw, 2rem); margin-top: 8px; }
.svc-card { display: flex; flex-direction: column; gap: 10px; padding: 22px;
  background: var(--color-bg-surface); border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg); transition: border-color var(--dur-normal) var(--ease), transform var(--dur-normal) var(--ease); }
.svc-card:hover { border-color: var(--color-border-default); transform: translateY(-3px); }
.svc-card.is-locked { opacity: 0.82; }
.svc-card__top { display: flex; align-items: center; justify-content: space-between; }
.svc-card__icon { display: inline-grid; place-items: center; width: 2.6rem; height: 2.6rem; border-radius: 12px;
  background: var(--color-accent-soft); color: var(--color-accent); font-family: var(--font-display); font-size: 1.3rem; }
.svc-card__title { font-family: var(--font-display); font-size: var(--text-lg); color: var(--color-text-primary); letter-spacing: var(--tracking-tight); margin: 2px 0 0; }
.svc-card__desc { font-size: var(--text-sm); color: var(--color-text-secondary); line-height: var(--leading-normal); flex: 1; }
.svc-card__foot { margin-top: 6px; }
@media (max-width: 1000px) { .svc-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .svc-grid { grid-template-columns: 1fr; } }
