/*
Theme Name: momo to ie — Editorial Child
Theme URI: https://momotoie.com/
Description: SWELL child theme for momo to ie. Editorial redesign skin (B+).
Author: momo to ie
Version: 0.1.0
Template: swell
Text Domain: momotoie-child
*/

/* ============================================================
   Design Tokens — momo to ie Editorial
   ============================================================ */
:root {
  --m-paper:    #FDFBF7;
  --m-beige:    #F2EDE5;
  --m-beige-d:  #E8DFD0;
  --m-offwhite: #FAF7F2;
  --m-ink:      #2B2B28;
  --m-ink-soft: #4A4843;
  --m-subtle:   #7A7670;
  --m-line:     #DBD4C7;
  --m-line-soft:#ECE6D9;

  --m-sage:     #5C6F52;   /* primary accent */
  --m-sage-pale:#D8DFCF;
  --m-tan:      #C9A57B;
  --m-terracotta:#B97E5E;

  --m-font-jp-serif: "Noto Serif JP", "Hiragino Mincho ProN", "Yu Mincho", serif;
  --m-font-jp-sans:  "Noto Sans JP",  "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
  --m-font-en-serif: "Cormorant Garamond", "EB Garamond", Georgia, serif;
  --m-font-en-sans:  "Inter", "Helvetica Neue", system-ui, sans-serif;
}

/* ============================================================
   Base — body / typography overrides
   ------------------------------------------------------------
   Claude Code: 以下から先のスタイルを章ごとに追記してください。
   移行ガイド (swell-migration-guide.html) の 03〜10章を参照。
   ============================================================ */
body, .l-mainContent, .post_content {
  font-family: var(--m-font-jp-serif);
  color: var(--m-ink);
  background: var(--m-paper);
  letter-spacing: 0.02em;
}
h1, h2, h3, h4 {
  font-family: var(--m-font-jp-serif);
  font-weight: 400;
  letter-spacing: 0.04em;
}

/* ============================================================
   Issue Strip — トップバー（Customizer不要、CSS疑似要素で実装）
   ============================================================ */
body::before {
  content: "Issue No. 24\00a0\00a0\00a0\00a0/\00a0\00a0\00a0\00a0Quiet Real Living — A Journal of Home, Light & a Small Dog\00a0\00a0\00a0\00a0/\00a0\00a0\00a0\00a0Spring / 2026";
  display: block;
  width: 100%;
  padding: 10px 40px;
  background: var(--m-beige);
  border-bottom: 1px solid var(--m-line);
  font-family: var(--m-font-en-sans);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--m-subtle);
  text-align: center;
  box-sizing: border-box;
}

/* ============================================================
   04. Header — Masthead（Customizer設定の代替CSSを含む）
   ============================================================ */

/* ---- ヘッダーをセンタリング（Customizer「ロゴ中央配置」の代替） ---- */
.l-header .c-headInner {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 28px 40px 16px !important;
}
/* ロゴをセンタリング */
.l-header .c-headLogo,
.l-header .c-headLogo__wrap {
  text-align: center !important;
  width: 100% !important;
}
/* グローバルナビをセンタリング */
.l-header .c-gnav,
.l-header .c-gnav__wrap,
.l-header .c-gnav__list {
  justify-content: center !important;
  margin-top: 12px !important;
}
/* ヘッダー下ボーダー */
.l-header {
  border-bottom: 1px solid var(--m-line) !important;
}
/* ヘッダー内の検索・SNSアイコンエリアを非表示（雑誌スタイルに統一） */
.l-header .c-headSub { display: none !important; }

/* ロゴを Cormorant Garamond italic に（サイトタイトル "momo · to · ie" を使用） */
.c-headLogo__title {
  font-family: var(--m-font-en-serif);
  font-style: italic;
  font-size: clamp(36px, 5vw, 72px);
  letter-spacing: 0.01em;
  font-weight: 400;
}
.c-headLogo__title a { color: var(--m-ink); }
.c-headLogo__title a:hover { color: var(--m-sage); }

/* グローバルナビ */
.c-gnav__item > a,
.c-gnav__item > span {
  font-family: var(--m-font-jp-sans);
  font-size: 13px;
  color: var(--m-ink-soft);
  letter-spacing: 0.04em;
}

/* ヘッダー全体の下ボーダー */
.l-header {
  border-bottom: 1px solid var(--m-line);
  background: var(--m-paper);
}

/* ============================================================
   05. Home — Cover / Editor's Letter / The Index / Shop / Newsletter
   ============================================================ */

/* ---- 05-1. Cover Story (3-col: TOC | Cover image | Quote) ---- */
.m-cover {
  display: grid;
  grid-template-columns: 0.5fr 1fr 0.5fr;
  gap: 28px;
  padding: 56px 40px;
  max-width: 1200px;
  margin: 0 auto;
  box-sizing: border-box;
}

.m-cover__toc {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding-top: 16px;
}
.m-cover__toc-kicker {
  font-family: var(--m-font-en-sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--m-sage);
}
.m-cover__toc ol {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.m-cover__toc li {
  display: grid;
  grid-template-columns: 30px 1fr;
  gap: 10px;
}
.m-cover__toc-num {
  font-family: var(--m-font-en-serif);
  font-style: italic;
  font-size: 20px;
  color: var(--m-sage);
  line-height: 1;
}
.m-cover__toc-title {
  font-size: 12px;
  line-height: 1.6;
}
.m-cover__toc-cat {
  font-family: var(--m-font-en-sans);
  font-size: 9px;
  letter-spacing: 0.18em;
  color: var(--m-subtle);
  margin-top: 3px;
}
.m-cover__toc-link {
  display: block;
  text-decoration: none;
  color: inherit;
  transition: color 0.2s;
}
.m-cover__toc-link:hover .m-cover__toc-title { color: var(--m-sage); }

.m-cover__image { position: relative; }
.m-cover__image img,
.m-cover__image .wp-block-cover {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
}
.m-cover__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 28px;
  background: linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(0,0,0,0.45) 100%);
  pointer-events: none;
}
.m-cover__overlay-label {
  font-family: var(--m-font-en-sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #F2EDE5;
  margin-bottom: 10px;
}
.m-cover__overlay-title {
  font-family: var(--m-font-en-serif);
  font-style: italic;
  font-size: 42px;
  line-height: 1.05;
  color: #FAF7F2;
}
.m-cover__badge {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 84px;
  height: 84px;
  border-radius: 50%;
  background: var(--m-sage);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: white;
  text-align: center;
  line-height: 1.1;
}
.m-cover__badge-new {
  font-family: var(--m-font-en-sans);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.m-cover__badge-vol {
  font-family: var(--m-font-en-serif);
  font-style: italic;
  font-size: 20px;
  margin-top: 2px;
}

.m-cover__sidebar {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding-top: 16px;
}
.m-cover__quote {
  font-family: var(--m-font-en-serif);
  font-style: italic;
  font-size: 18px;
  line-height: 1.6;
  color: var(--m-ink-soft);
}
.m-cover__quote-attr {
  margin-top: 14px;
  font-family: var(--m-font-en-sans);
  font-size: 10px;
  letter-spacing: 0.16em;
  color: var(--m-subtle);
}
.m-cover__featured {
  margin-top: 28px;
}
.m-cover__featured-kicker {
  font-family: var(--m-font-en-sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--m-subtle);
  margin-bottom: 10px;
}

/* ---- 05-2. Editor's Letter ---- */
.m-letter {
  background: var(--m-beige);
  padding: 80px 40px;
}
.m-letter__inner {
  max-width: 1200px;
  margin: 0 auto;
}
.m-letter__grid {
  display: grid;
  grid-template-columns: 1fr 2fr 1fr;
  gap: 32px;
}
.m-letter__kicker {
  font-family: var(--m-font-en-sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--m-sage);
}
.m-letter__body {
  font-size: 17px;
  line-height: 2;
}
.m-letter__dropcap {
  float: left;
  font-family: var(--m-font-en-serif);
  font-style: italic;
  font-size: 80px;
  line-height: 0.9;
  margin-right: 12px;
  margin-top: 8px;
  color: var(--m-sage);
}
.m-letter__sig {
  font-family: var(--m-font-jp-sans);
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--m-subtle);
  text-align: right;
}

/* ---- 05-3. The Index (5-col categories) ---- */
.m-index {
  background: var(--m-beige);
  padding: 64px 0;
}
.m-index__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
}
.m-index__hd {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  border-bottom: 1px solid var(--m-line);
  padding-bottom: 14px;
  margin-bottom: 0;
}
.m-index__hd h2 {
  font-family: var(--m-font-en-serif);
  font-style: italic;
  font-size: 32px;
  font-weight: 400;
  margin: 0;
  letter-spacing: 0.02em;
}
.m-index__hd span {
  font-family: var(--m-font-en-sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--m-subtle);
}
.m-index__grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
}
.m-index__item {
  padding: 28px 18px;
  border-right: 1px solid var(--m-line);
  display: flex;
  flex-direction: column;
  gap: 10px;
  text-decoration: none;
  color: inherit;
  transition: background 0.2s;
}
.m-index__item:last-child { border-right: none; }
.m-index__item:hover { background: rgba(92, 111, 82, 0.04); }
.m-index__num {
  font-family: var(--m-font-en-serif);
  font-style: italic;
  font-size: 32px;
  color: var(--m-sage);
  line-height: 1;
}
.m-index__jp {
  font-size: 15px;
  letter-spacing: 0.06em;
  margin-top: 6px;
}
.m-index__en {
  font-family: var(--m-font-en-sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--m-subtle);
}
.m-index__desc {
  font-family: var(--m-font-jp-sans);
  font-size: 11px;
  line-height: 1.8;
  color: var(--m-subtle);
  margin: 6px 0 0;
}
.m-index__count {
  font-family: var(--m-font-en-sans);
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--m-subtle);
  margin-top: 10px;
}

/* ---- 05-4. Two Features ---- */
.m-features {
  padding: 80px 40px;
  max-width: 1200px;
  margin: 0 auto;
  box-sizing: border-box;
}
.m-features__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
}
.m-features__item {
  display: flex;
  flex-direction: column;
  gap: 16px;
  text-decoration: none;
  color: inherit;
}
.m-features__item-meta {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.m-features__item-kicker {
  font-family: var(--m-font-en-sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--m-sage);
}
.m-features__item-page {
  font-family: var(--m-font-en-serif);
  font-style: italic;
  font-size: 26px;
  color: var(--m-subtle);
}
.m-features__item-en-title {
  font-family: var(--m-font-en-serif);
  font-style: italic;
  font-size: 30px;
  font-weight: 400;
  line-height: 1.2;
  margin: 8px 0 0;
}
.m-features__item-title {
  font-size: 17px;
  font-weight: 400;
  line-height: 1.6;
  margin: 0;
}
.m-features__item-excerpt {
  font-family: var(--m-font-jp-sans);
  font-size: 13px;
  line-height: 1.9;
  color: var(--m-ink-soft);
  margin: 0;
}

/* ---- 05-5. Newsletter ---- */
.m-newsletter {
  background: var(--m-offwhite);
  padding: 72px 40px;
}
.m-newsletter__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 48px;
  align-items: center;
}
.m-newsletter__kicker {
  font-family: var(--m-font-en-sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--m-sage);
  margin-bottom: 12px;
}
.m-newsletter__title {
  font-size: 30px;
  font-weight: 400;
  line-height: 1.5;
  margin: 0 0 14px;
}
.m-newsletter__desc {
  font-family: var(--m-font-jp-sans);
  font-size: 13px;
  line-height: 2;
  color: var(--m-ink-soft);
  max-width: 380px;
  margin: 0;
}
.m-newsletter__form {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.m-newsletter__input {
  border: none;
  border-bottom: 1px solid var(--m-sage);
  padding: 12px 4px;
  background: transparent;
  font-size: 14px;
  font-family: var(--m-font-en-sans);
  color: var(--m-ink);
  outline: none;
}
.m-newsletter__btn {
  align-self: flex-start;
  padding: 12px 28px;
  border: 1px solid var(--m-sage);
  background: var(--m-sage);
  color: white;
  font-family: var(--m-font-en-sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  cursor: pointer;
}

/* ============================================================
   06. Archive — Department Header
   ============================================================ */
.m-archive-hd {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 32px;
  align-items: end;
  border-bottom: 1px solid var(--m-line);
  padding: 56px 40px 22px;
  max-width: 1200px;
  margin: 0 auto;
  box-sizing: border-box;
}
.m-archive-hd__num {
  font-family: var(--m-font-en-serif);
  font-style: italic;
  font-size: 88px;
  color: var(--m-sage);
  line-height: 1;
}
.m-archive-hd__kicker {
  font-family: var(--m-font-en-sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--m-subtle);
  margin-bottom: 6px;
}
.m-archive-hd h1 {
  font-family: var(--m-font-en-serif);
  font-style: italic;
  font-size: 56px;
  font-weight: 400;
  margin: 0;
  line-height: 1.1;
}
.m-archive-hd__desc {
  margin-top: 10px;
  font-family: var(--m-font-jp-sans);
  font-size: 14px;
  color: var(--m-ink-soft);
}
.m-archive-hd__count {
  font-family: var(--m-font-en-sans);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--m-subtle);
  white-space: nowrap;
}

/* ============================================================
   07. Article — Drop cap / Subhead / Pull quote
   ============================================================ */

/* ドロップキャップ — PR表記（.m-pr-notice）を除外 */
.post_content > p:first-of-type:not(.m-pr-notice)::first-letter,
.entry-content > p:first-of-type:not(.m-pr-notice)::first-letter,
.post_content > .m-pr-notice + p::first-letter,
.entry-content > .m-pr-notice + p::first-letter {
  font-family: var(--m-font-en-serif);
  font-style: italic;
  font-size: 4.5em;
  line-height: 0.9;
  float: left;
  margin: 0.1em 0.12em 0 -0.05em;
  color: var(--m-sage);
}
.post_content > p.m-pr-notice::first-letter,
.entry-content > p.m-pr-notice::first-letter,
.post_content p.m-pr-notice::first-letter,
.entry-content p.m-pr-notice::first-letter {
  font-family: inherit !important;
  font-style: normal !important;
  font-size: 1em !important;
  line-height: normal !important;
  float: none !important;
  margin: 0 !important;
  color: inherit !important;
}

/* 英文サブタイトル（記事冒頭に置くグループブロック） */
.m-subhead {
  font-family: var(--m-font-en-serif);
  font-style: italic;
  font-size: 22px;
  line-height: 1.5;
  color: var(--m-sage);
  margin: 0 0 32px;
  max-width: 720px;
}

/* プルクオート（引用ブロック） */
.m-pullquote,
.post_content blockquote.m-pullquote,
.wp-block-quote.m-pullquote {
  border-left: 2px solid var(--m-sage) !important;
  border-right: none;
  background: var(--m-beige);
  padding: 32px;
  margin: 40px 0;
}
.m-pullquote p,
.m-pullquote cite {
  font-family: var(--m-font-en-serif);
  font-style: italic;
}
.m-pullquote p {
  font-size: 24px;
  line-height: 1.6;
  color: var(--m-ink);
}
.m-pullquote cite {
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--m-subtle);
  font-style: normal;
}

/* アフィリエイト開示パネル */
.m-affiliate-disclosure {
  padding: 12px 16px;
  background: var(--m-beige);
  border: 1px solid var(--m-line);
  font-family: var(--m-font-jp-sans);
  font-size: 11px;
  color: var(--m-subtle);
  margin-bottom: 32px;
}

/* 記事ページ H2 スタイル */
.post_content h2,
.entry-content h2 {
  border-bottom: 1px solid var(--m-line);
  padding-bottom: 12px;
  letter-spacing: 0.02em;
}

/* 著者プロフィールボックス */
.m-author-box {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 18px;
  padding: 22px;
  background: var(--m-beige);
  margin-bottom: 48px;
}
.m-author-box__avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--m-beige-d);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--m-font-en-serif);
  font-style: italic;
  font-size: 28px;
  color: var(--m-sage);
}
.m-author-box__name { font-size: 14px; margin-bottom: 4px; }
.m-author-box__role {
  font-family: var(--m-font-en-sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--m-subtle);
  margin-bottom: 8px;
}
.m-author-box__bio {
  font-family: var(--m-font-jp-sans);
  font-size: 12px;
  line-height: 1.9;
  color: var(--m-ink-soft);
  margin: 0;
}

/* ============================================================
   08. Affiliate (Pochipp) skin
   ============================================================ */
.pchpp__box {
  border: 1px solid var(--m-sage) !important;
  border-radius: 0 !important;
  background: var(--m-paper) !important;
  box-shadow: none !important;
}
.pchpp__box .pchpp__ttl {
  font-family: var(--m-font-jp-serif) !important;
  font-size: 16px !important;
  color: var(--m-ink) !important;
}
.pchpp__box .pchpp__price {
  font-family: var(--m-font-en-serif) !important;
  font-style: italic !important;
  color: var(--m-sage) !important;
}
.pchpp__box .pchpp__btn {
  background: var(--m-sage) !important;
  border-radius: 0 !important;
  font-family: var(--m-font-en-sans) !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  font-size: 11px !important;
  border: none !important;
}
.pchpp__box .pchpp__btn--amazon {
  background: #232f3e !important;
}

/* ============================================================
   09. Footer
   ============================================================ */
.l-footer {
  background: var(--m-ink) !important;
  color: rgba(255, 255, 255, 0.7) !important;
}
.l-footer a {
  color: rgba(255, 255, 255, 0.7) !important;
}
.l-footer a:hover {
  color: rgba(255, 255, 255, 0.95) !important;
}
.l-footer .c-widgetTitle,
.l-footer .widget-title {
  font-family: var(--m-font-en-sans) !important;
  font-size: 11px !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase !important;
  color: rgba(255, 255, 255, 0.4) !important;
  border: none !important;
}
.l-footer .widget {
  font-family: var(--m-font-jp-sans);
  font-size: 11px;
  line-height: 2;
}
/* フッターのロゴエリア */
.l-footerLogo {
  font-family: var(--m-font-en-serif) !important;
  font-style: italic !important;
  font-size: 24px !important;
  color: white !important;
}
/* コピーライトバー */
.l-footer__copy {
  border-top: 1px solid rgba(255, 255, 255, 0.15);
  font-family: var(--m-font-en-sans);
  font-size: 10px;
  letter-spacing: 0.14em;
  color: rgba(255, 255, 255, 0.5);
}

/* ============================================================
   10. Mobile (max-width: 768px)
   ============================================================ */
@media (max-width: 768px) {
  /* Cover Story: 1カラムに */
  .m-cover {
    grid-template-columns: 1fr;
    padding: 32px 20px;
  }
  .m-cover__toc { display: none; } /* モバイルでは目次を非表示 */
  .m-cover__sidebar { padding-top: 16px; }

  /* Editor's Letter: 1カラムに */
  .m-letter { padding: 48px 20px; }
  .m-letter__grid { grid-template-columns: 1fr; gap: 16px; }
  .m-letter__sig { text-align: left; }
  .m-letter__dropcap { font-size: 60px; }

  /* The Index: 2カラムに */
  .m-index { padding: 48px 0; }
  .m-index__inner { padding: 0 20px; }
  .m-index__grid { grid-template-columns: repeat(2, 1fr); }
  .m-index__item:nth-child(2n) { border-right: none; }
  .m-index__num { font-size: 24px; }

  /* Two Features: 1カラムに */
  .m-features { padding: 48px 20px; }
  .m-features__grid { grid-template-columns: 1fr; gap: 32px; }

  /* Newsletter: 1カラムに */
  .m-newsletter { padding: 48px 20px; }
  .m-newsletter__inner { grid-template-columns: 1fr; gap: 28px; }

  /* Archive Department Header */
  .m-archive-hd {
    grid-template-columns: 1fr;
    padding: 32px 20px 16px;
    gap: 12px;
  }
  .m-archive-hd__num { font-size: 56px; }
  .m-archive-hd h1 { font-size: 36px; }
  .m-archive-hd__count { display: none; }

  /* Article: ドロップキャップ小さく */
  .post_content > p:first-of-type:not(.m-pr-notice)::first-letter,
  .entry-content > p:first-of-type:not(.m-pr-notice)::first-letter,
  .post_content > .m-pr-notice + p::first-letter,
  .entry-content > .m-pr-notice + p::first-letter {
    font-size: 3.5em;
  }
  .m-subhead { font-size: 17px; }
  .m-pullquote p { font-size: 18px; }

  /* Logo */
  .c-headLogo__title {
    font-size: clamp(28px, 8vw, 48px);
  }
}
