@charset "UTF-8";
/* =========================================================
   KAPUTELI / Column (Category archive)
   - Scope: .kap-column
   - Family: kap- 系統
   - Editorial 系(ヒーロー画像なし、白背景+大型タイポ)
   ========================================================= */

.kap-column {
  --kap-bg: #ffffff;
  --kap-bg-tint: #f4f3ef;
  --kap-bg-tint-2: #ebeae6;
  --kap-ink: #111111;
  --kap-ink-2: #555555;
  --kap-ink-3: #888888;
  --kap-rule: #d8d6d2;

  --kap-maxw: 1280px;
  --kap-gutter: clamp(20px, 4vw, 48px);

  --kap-sans: "Schibsted Grotesk", "Helvetica Neue", "Arial", sans-serif;
  --kap-jp: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;

  background: var(--kap-bg);
  color: var(--kap-ink);
  font-family: var(--kap-sans);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.5;
}

/* JP 共通 */
.kap-column .kap-jp,
.kap-column .kap-jp * {
  font-family: var(--kap-jp);
}

/* リセット(.kap-column 配下のみ) */
.kap-column h1,
.kap-column h2,
.kap-column h3,
.kap-column h4,
.kap-column p,
.kap-column ul,
.kap-column ol {
  margin: 0;
  padding: 0;
}
.kap-column ul,
.kap-column ol {
  list-style: none;
}
.kap-column a {
  color: inherit;
  text-decoration: none;
}
.kap-column img {
  max-width: 100%;
  display: block;
}

/* =========================================================
   Reveal animation
   ========================================================= */
.kap-column .kap-reveal {
  opacity: 0;
  transform: translateY(18px);
  transition:
    opacity 0.9s cubic-bezier(0.2, 0.7, 0.2, 1),
    transform 0.9s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.kap-column .kap-reveal.is-in {
  opacity: 1;
  transform: none;
}
@media (prefers-reduced-motion: reduce) {
  .kap-column .kap-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* =========================================================
   Wrap
   ========================================================= */
.kap-column__wrap {
  width: 100%;
  max-width: var(--kap-maxw);
  margin-inline: auto;
  padding-inline: var(--kap-gutter);
}

/* =========================================================
   HERO (Editorial)
   ========================================================= */
.kap-column__hero {
  position: relative;
  background: var(--kap-bg);
  /* header-kpt のスペースを上に確保 */
  padding-top: clamp(140px, 22vh, 220px);
  padding-bottom: clamp(60px, 10vw, 120px);
}
.kap-column__hero > .kpt-header,
.kap-column__hero > header.kpt-header {
  position: absolute;
  inset: 0 0 auto 0;
  z-index: 3;
}

.kap-column__hero-label {
  font-family: var(--kap-sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.3em;
  color: var(--kap-ink-2);
  text-transform: uppercase;
  margin-bottom: 32px;
}

.kap-column__hero-title {
  font-family: var(--kap-sans);
  font-weight: 500;
  font-size: clamp(56px, 10vw, 140px);
  line-height: 0.96;
  letter-spacing: -0.02em;
  margin: 0 0 32px;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--kap-ink);
  /* カテゴリ名の英字とJPが混在しても先頭から揃うように */
  text-transform: capitalize;
}

.kap-column__hero-foot {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: end;
}
.kap-column__hero-lead {
  font-size: 16px;
  line-height: 2;
  max-width: 560px;
  margin: 0;
}
.kap-column__hero-meta {
  text-align: right;
  font-family: var(--kap-sans);
  font-size: 11px;
  letter-spacing: 0.3em;
  color: var(--kap-ink-2);
  text-transform: uppercase;
  line-height: 2.4;
}

/* admin-bar調整 */
.admin-bar .kap-column__hero {
  padding-top: clamp(160px, 22vh, 240px);
}

/* =========================================================
   FEATURED
   ========================================================= */
.kap-column__featured-sec {
  padding: 32px var(--kap-gutter) 64px;
  background: var(--kap-bg);
}

.kap-column__featured {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 48px;
  align-items: center;
  border-block: 1px solid var(--kap-rule);
  padding: 48px 0;
  /* anchor をホバー枠にしないため */
  outline: none;
}
.kap-column__featured-media {
  aspect-ratio: 16 / 10;
  background-size: cover;
  background-position: center;
  background-color: var(--kap-bg-tint);
  filter: grayscale(15%);
  transition: transform 0.6s cubic-bezier(0.2, 0.6, 0.2, 1);
}
.kap-column__featured:hover .kap-column__featured-media {
  transform: scale(1.02);
}
.kap-column__featured-body {
  min-width: 0; /* grid item の text overflow 対策 */
}
.kap-column__featured-meta {
  font-family: var(--kap-sans);
  font-size: 11px;
  letter-spacing: 0.3em;
  color: var(--kap-ink-2);
  text-transform: uppercase;
  margin-bottom: 16px;
}
.kap-column__featured-title {
  font-weight: 500;
  font-size: clamp(24px, 3vw, 36px);
  line-height: 1.4;
  margin: 0 0 16px;
  letter-spacing: -0.005em;
}
.kap-column__featured-excerpt {
  font-size: 15px;
  color: var(--kap-ink-2);
  line-height: 1.95;
  margin: 0 0 24px;
}

/* CTA(Featured / Subscribeの "Read the article" 等の共通) */
.kap-column__cta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--kap-sans);
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--kap-ink);
  border-bottom: 1px solid var(--kap-ink);
  padding-bottom: 4px;
}
.kap-column__arrow {
  display: inline-block;
  transition: transform 0.3s ease;
}
.kap-column__featured:hover .kap-column__arrow,
.kap-column__cta:hover .kap-column__arrow {
  transform: translateX(4px);
}

/* =========================================================
   ARTICLE GRID
   ========================================================= */
.kap-column__grid-sec {
  padding: 32px var(--kap-gutter) clamp(80px, 12vw, 140px);
  background: var(--kap-bg);
}
.kap-column__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 48px 32px;
}

.kap-column__article {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.kap-column__article-media {
  aspect-ratio: 16 / 10;
  background-size: cover;
  background-position: center;
  background-color: var(--kap-bg-tint);
  transition: transform 0.6s cubic-bezier(0.2, 0.6, 0.2, 1);
  overflow: hidden;
}
.kap-column__article:hover .kap-column__article-media {
  transform: scale(1.02);
}

.kap-column__article-meta {
  font-family: var(--kap-sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--kap-ink-2);
  text-transform: uppercase;
  margin: 18px 0 8px;
  display: flex;
  gap: 14px;
  align-items: center;
}
.kap-column__chip {
  padding: 3px 10px;
  border: 1px solid var(--kap-rule);
  border-radius: 999px;
  font-size: 10px;
  letter-spacing: 0.16em;
  font-family: var(--kap-jp);
  text-transform: none;
  color: var(--kap-ink-2);
}
.kap-column__article-title {
  font-weight: 500;
  font-size: 16px;
  line-height: 1.65;
  margin: 0 0 12px;
  letter-spacing: 0;
}
.kap-column__article-excerpt {
  font-size: 13px;
  line-height: 1.85;
  color: var(--kap-ink-2);
  margin: 0 0 16px;
}
.kap-column__article-cta {
  font-family: var(--kap-sans);
  font-size: 11px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--kap-ink);
  margin-top: auto;
}

.kap-column__empty {
  font-size: 15px;
  color: var(--kap-ink-2);
  text-align: center;
  padding: 80px 0;
}

/* =========================================================
   PAGINATION (paginate_links 'list')
   ========================================================= */
.kap-column__pagination {
  margin-top: 80px;
  display: flex;
  justify-content: center;
}
.kap-column__pagination .page-numbers {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.kap-column__pagination .page-numbers li {
  list-style: none;
}
.kap-column__pagination a,
.kap-column__pagination span.page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  height: 44px;
  padding: 0 14px;
  border: 1px solid var(--kap-rule);
  border-radius: 999px;
  font-family: var(--kap-sans);
  font-size: 12px;
  letter-spacing: 0.16em;
  color: var(--kap-ink-2);
  background: #fff;
  transition: color 0.3s ease, border-color 0.3s ease, background 0.3s ease;
  text-decoration: none;
}
.kap-column__pagination a:hover {
  color: var(--kap-ink);
  border-color: var(--kap-ink);
}
.kap-column__pagination .current {
  color: #fff;
  background: var(--kap-ink);
  border-color: var(--kap-ink);
}
.kap-column__pagination .dots {
  border-color: transparent;
  background: transparent;
}

/* =========================================================
   CLOSING / Subscribe
   ========================================================= */
.kap-column__closing {
  background: var(--kap-ink);
  color: #fff;
  padding: clamp(96px, 14vw, 176px) var(--kap-gutter);
  text-align: center;
}
.kap-column__closing-eyebrow {
  font-family: var(--kap-sans);
  font-size: 11px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 28px;
}
.kap-column__closing-title {
  font-family: var(--kap-jp);
  font-weight: 500;
  font-size: clamp(32px, 5vw, 64px);
  line-height: 1.3;
  margin: 0 0 28px;
}
.kap-column__closing-lead {
  font-size: 15px;
  line-height: 2;
  color: rgba(255, 255, 255, 0.78);
  margin: 0 auto 48px;
}

.kap-column__subscribe {
  max-width: 520px;
  margin: 0 auto;
  display: flex;
  gap: 0;
  border-bottom: 1px solid #fff;
}
.kap-column__subscribe-input {
  flex: 1;
  min-width: 0;
  border: 0;
  background: transparent;
  padding: 16px 0;
  font-family: var(--kap-sans);
  font-size: 14px;
  outline: none;
  letter-spacing: 0.06em;
  color: #fff;
}
.kap-column__subscribe-input::placeholder {
  color: rgba(255, 255, 255, 0.45);
}
.kap-column__subscribe-btn {
  background: none;
  border: 0;
  padding: 16px 0 16px 24px;
  cursor: pointer;
  font-family: var(--kap-sans);
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #fff;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  transition: opacity 0.3s ease;
}
.kap-column__subscribe-btn:hover {
  opacity: 0.7;
}
.kap-column__subscribe-btn:hover .kap-column__arrow {
  transform: translateX(4px);
}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 1024px) {
  .kap-column__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 880px) {
  .kap-column__hero-foot {
    grid-template-columns: 1fr;
    gap: 32px;
    align-items: start;
  }
  .kap-column__hero-meta {
    text-align: left;
  }
  .kap-column__featured {
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 40px 0;
  }
}
@media (max-width: 540px) {
  .kap-column__grid {
    grid-template-columns: 1fr;
    gap: 56px;
  }
  .kap-column__hero-title {
    font-size: clamp(48px, 16vw, 80px);
  }
}

/* =========================================================
   header-kpt を白背景の上で読めるようにする(Columnのみ)
   - header-kpt.php は一切触らない
   - .kap-column 配下にスコープして他ページに影響を与えない
   - 構造: .kpt-header > .kpt-logo / .kpt-nav > ul + .kpt-burger (3本span)
   ========================================================= */

/* ---- ロゴ / ナビ文字色を黒系に ---- */
.kap-column .kpt-header,
.kap-column .kpt-header .kpt-logo,
.kap-column .kpt-header .kpt-logo-mark,
.kap-column .kpt-header .kpt-nav-list a,
.kap-column .kpt-header .kpt-has-sub {
  color: var(--kap-ink) !important;
}

/* サブメニュー内のリンクも黒に */
.kap-column .kpt-header .kpt-submenu a {
  color: var(--kap-ink) !important;
}

/* ---- リンクのホバー(白下地でも見えるアクセント) ---- */
.kap-column .kpt-header .kpt-nav-list a,
.kap-column .kpt-header .kpt-has-sub {
  transition: opacity 0.25s ease;
}
.kap-column .kpt-header .kpt-nav-list a:hover,
.kap-column .kpt-header .kpt-has-sub:hover {
  opacity: 0.55;
}

/* ---- ハンバーガー(3本線)の白指定を黒に上書き ---- */
.kap-column .kpt-header .kpt-burger {
  color: var(--kap-ink) !important;
  background: transparent !important;
  border-color: var(--kap-ink) !important;
}
.kap-column .kpt-header .kpt-burger > span {
  background-color: var(--kap-ink) !important;
}

/* ---- 現在ページのアクセント ---- */
/* Columnは /category/pers/ なので "Column" リンクに下線 */
.kap-column .kpt-header .kpt-nav-list a[href*="/category/"],
.kap-column .kpt-header .kpt-nav-list a[href$="/column/"] {
  text-decoration: underline;
  text-underline-offset: 6px;
  text-decoration-thickness: 1px;
}

/* ---- モバイルドロワー(開いた時にも文字色が見えるよう保険) ---- */
/* ドロワー自体の背景色は header-kpt 側CSSの値を尊重し、
   テキスト色だけ黒系へ寄せておく(白下地のままなら整合、暗下地でも害はない) */
.kap-column .kpt-drawer a,
.kap-column .kpt-drawer .kpt-drawer-jp,
.kap-column .kpt-drawer .kpt-drawer-sub a {
  color: inherit;
}
