/* =========================================================
  顔採用.net 共通カテゴリーページ
  /wp-content/themes/swell_child/assets/css/kao-category.css
========================================================= */

.kao-cat-page {
  --navy: #073763;
  --blue: #0b4f9f;
  --light: #f3f8ff;
  --border: #d8e7f6;
  --orange: #ff6b2c;
  --orange2: #f04f12;
  --text: #10233f;
  --muted: #5b6b80;
  --yellow: #f6b21a;

  max-width: 1180px;
  margin: 0 auto;
  padding: 0 18px 48px;
  color: var(--text);
}

.kao-cat-page *,
.kao-cat-page *::before,
.kao-cat-page *::after {
  box-sizing: border-box;
}

.kao-cat-page a {
  color: inherit;
  text-decoration: none;
}

.kao-cat-page img {
  max-width: 100%;
  height: auto;
}

/* =========================================================
  SWELL見出し装飾の干渉防止
========================================================= */

.kao-cat-page h1,
.kao-cat-page h2,
.kao-cat-page h3 {
  background: transparent !important;
  background-image: none !important;
  border: none !important;
  box-shadow: none !important;
}

.kao-cat-page h1::before,
.kao-cat-page h1::after,
.kao-cat-page h2::before,
.kao-cat-page h2::after,
.kao-cat-page h3::before,
.kao-cat-page h3::after {
  content: none !important;
  display: none !important;
}

/* =========================================================
  HERO
========================================================= */

.kao-cat-hero {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid var(--border);
  min-height: 390px;
  background:
    linear-gradient(
      90deg,
      #fff 0%,
      #fff 36%,
      rgba(255,255,255,.94) 51%,
      rgba(255,255,255,.58) 68%,
      rgba(255,255,255,.08) 100%
    ),
    var(--hero-image) center right / cover no-repeat;
  box-shadow: 0 18px 42px rgba(7,55,99,.10);
}

.kao-cat-hero__inner {
  position: relative;
  min-height: 390px;
  padding: 34px 32px;
}

.kao-cat-hero__content {
  width: 58%;
  max-width: 620px;
  position: relative;
  z-index: 2;
}

.kao-cat-breadcrumb {
  font-size: 12px;
  color: #607086;
  margin-bottom: 16px;
}

.kao-cat-breadcrumb a {
  color: #607086;
}

.kao-cat-label {
  display: inline-flex;
  padding: 6px 14px;
  border-radius: 999px;
  background: var(--navy);
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  margin-bottom: 10px;
}

.kao-cat-title {
  margin: 0 0 10px !important;
  padding: 0 !important;
  color: var(--navy) !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1.15;
  font-weight: 800;
  letter-spacing: .04em;
}

.kao-cat-catch {
  margin: 0 0 12px;
  color: var(--blue);
  font-size: 20px;
  font-weight: 900;
  line-height: 1.6;
}

.kao-cat-lead {
  margin: 0;
  color: #263b55;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.9;
}

.kao-cat-chip-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 22px;
}

.kao-cat-chip {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 9px;
  align-items: center;
  padding: 12px;
  background: rgba(255,255,255,.94);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 8px 18px rgba(7,55,99,.06);
}

.kao-cat-chip span {
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: #edf5ff;
  border: 1px solid #cfe3f9;
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
}

.kao-cat-chip strong {
  font-size: 12px;
  line-height: 1.45;
  color: var(--navy);
}

/* HERO右側サマリー */

.kao-cat-summary {
  position: absolute;
  right: 28px;
  top: 64px;
  width: 250px;
  z-index: 3;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 14px 30px rgba(7,55,99,.16);
}

.kao-cat-summary__title {
  padding: 12px 15px;
  background: var(--navy);
  color: #fff;
  font-size: 14px;
  font-weight: 900;
}

.kao-cat-summary ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 10px 15px !important;
}

.kao-cat-summary li {
  position: relative;
  padding: 9px 0 9px 22px;
  border-bottom: 1px solid #e7eff8;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.55;
}

.kao-cat-summary li:last-child {
  border-bottom: none;
}

.kao-cat-summary li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 9px;
  color: var(--blue);
  font-weight: 900;
}

/* =========================================================
  編集方針
========================================================= */

.kao-cat-policy {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  margin-top: 22px;
  padding: 20px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: 0 12px 26px rgba(11,57,104,.06);
}

.kao-cat-policy__icon {
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: #edf5ff;
  border: 1px solid #cfe3f9;
  color: var(--blue);
  font-weight: 900;
}

.kao-cat-policy__title {
  color: var(--navy);
  font-size: 18px;
  font-weight: 900;
  margin-bottom: 6px;
}

.kao-cat-policy p {
  margin: 0;
  color: #334862;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.8;
}

/* =========================================================
  共通セクション見出し
========================================================= */

.kao-cat-section {
  margin-top: 34px;
}

.kao-cat-heading {
  position: relative !important;
  margin: 0 0 18px !important;
  padding: 0 0 0 18px !important;
  color: var(--navy) !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  font-size: 22px !important;
  font-weight: 900 !important;
  line-height: 1.45 !important;
}

.kao-cat-heading::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 6px !important;
  height: 30px !important;
  background: var(--navy) !important;
  border-radius: 2px !important;
}

.kao-cat-heading::after {
  content: none !important;
  display: none !important;
}

/* =========================================================
  注目記事
========================================================= */

.kao-cat-feature-layout {
  display: grid;
  grid-template-columns: 1.05fr 1.6fr;
  gap: 16px;
}

.kao-cat-feature-large {
  position: relative;
  min-height: 420px;
  border-radius: 18px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.72)),
    var(--thumb) center / cover no-repeat;
  box-shadow: 0 14px 30px rgba(11,57,104,.12);
}

.kao-cat-feature-large > span {
  position: absolute;
  top: 12px;
  left: 12px;
  background: var(--blue);
  color: #fff;
  padding: 5px 10px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 900;
}

.kao-cat-feature-large > div {
  position: absolute;
  left: 20px;
  right: 20px;
  bottom: 20px;
  color: #fff;
}

.kao-cat-feature-large h2 {
  margin: 0 0 10px !important;
  padding: 0 !important;
  color: #fff !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  font-size: 24px !important;
  line-height: 1.45 !important;
  font-weight: 900 !important;
}

.kao-cat-feature-large p {
  margin: 0;
  color: #e8f2ff;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.8;
}

.kao-cat-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.kao-cat-card {
  display: block;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 10px 22px rgba(11,57,104,.06);
  transition: transform .18s ease, box-shadow .18s ease;
}

.kao-cat-card:hover,
.kao-cat-feature-large:hover,
.kao-cat-archive-card:hover,
.kao-cat-cluster-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 34px rgba(11,57,104,.12);
}

.kao-cat-card__thumb {
  height: 112px;
  background: #edf5ff center / cover no-repeat;
}

.kao-cat-card__body {
  padding: 12px;
}

.kao-cat-card span {
  display: inline-flex;
  padding: 4px 9px;
  border-radius: 6px;
  background: var(--blue);
  color: #fff;
  font-size: 11px;
  font-weight: 900;
  margin-bottom: 8px;
}

.kao-cat-card h3 {
  margin: 0 0 8px !important;
  padding: 0 !important;
  color: var(--navy) !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
  font-weight: 900 !important;
}

.kao-cat-card p {
  margin: 0;
  color: #607086;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.7;
}

/* =========================================================
  メイン＋サイドレイアウト
========================================================= */

.kao-cat-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 24px;
  margin-top: 34px;
}

.kao-cat-main {
  min-width: 0;
}

/* =========================================================
  記事一覧
========================================================= */

.kao-cat-archive-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.kao-cat-archive-card {
  display: grid;
  grid-template-columns: 150px minmax(0, 1fr);
  gap: 14px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 10px 22px rgba(11,57,104,.06);
  transition: transform .18s ease, box-shadow .18s ease;
}

.kao-cat-archive-card__thumb {
  min-height: 120px;
  background: #edf5ff;
}

.kao-cat-archive-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.kao-cat-archive-card__body {
  padding: 12px 12px 12px 0;
}

.kao-cat-archive-card__body span {
  color: #7d8ca0;
  font-size: 11px;
  font-weight: 700;
}

.kao-cat-archive-card h3 {
  margin: 4px 0 8px !important;
  padding: 0 !important;
  color: var(--navy) !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  font-size: 15px !important;
  line-height: 1.5 !important;
  font-weight: 900 !important;
}

.kao-cat-archive-card p {
  margin: 0;
  color: #607086;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.7;
}

/* =========================================================
  サイドバー
========================================================= */

.kao-cat-side {
  display: grid;
  gap: 18px;
  align-content: start;
}

.kao-cat-side-box {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 16px;
  box-shadow: 0 12px 26px rgba(11,57,104,.06);
}

.kao-cat-side-title {
  color: var(--navy);
  font-size: 17px;
  font-weight: 900;
  margin-bottom: 12px;
}

.kao-cat-ranking {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.kao-cat-ranking li {
  border-bottom: 1px solid #e7eff8;
}

.kao-cat-ranking li:last-child {
  border-bottom: none;
}

.kao-cat-ranking a {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 9px;
  padding: 10px 0;
  font-size: 12px;
  font-weight: 800;
  color: var(--text);
  line-height: 1.55;
}

.kao-cat-ranking span {
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--navy);
  color: #fff;
  font-size: 12px;
  font-weight: 900;
}

.kao-cat-ranking li:first-child span {
  background: var(--yellow);
}

.kao-cat-worry ul {
  list-style: none !important;
  margin: 0 0 12px !important;
  padding: 0 !important;
}

.kao-cat-worry li {
  position: relative;
  padding-left: 22px;
  margin: 8px 0;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.65;
}

.kao-cat-worry li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--blue);
}

.kao-cat-worry a {
  color: var(--blue);
  font-size: 13px;
  font-weight: 900;
}

.kao-cat-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.kao-cat-tags a {
  display: inline-flex;
  padding: 6px 10px;
  border-radius: 999px;
  background: #f3f8ff;
  border: 1px solid #d6e8f8;
  color: var(--blue);
  font-size: 12px;
  font-weight: 800;
}

/* =========================================================
  関連テーマ
========================================================= */

.kao-cat-cluster-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.kao-cat-cluster-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 10px 22px rgba(11,57,104,.06);
  transition: transform .18s ease, box-shadow .18s ease;
}

.kao-cat-cluster-card > div {
  height: 100px;
  background: #edf5ff center / cover no-repeat;
}

.kao-cat-cluster-card h3 {
  margin: 12px 12px 6px !important;
  padding: 0 !important;
  color: var(--navy) !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  line-height: 1.5 !important;
}

.kao-cat-cluster-card p {
  margin: 0 12px 14px;
  color: #607086;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.7;
}

/* =========================================================
  ページネーション
========================================================= */

.kao-cat-pagination {
  margin-top: 28px;
  text-align: center;
}

.kao-cat-pagination .nav-links {
  display: flex;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
}

.kao-cat-pagination .page-numbers {
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--navy);
  font-size: 13px;
  font-weight: 800;
  background: #fff;
}

.kao-cat-pagination .page-numbers.current {
  background: var(--navy);
  color: #fff;
  border-color: var(--navy);
}

/* =========================================================
  下部CTA
========================================================= */

.kao-cat-cta {
  margin-top: 38px;
  min-height: 120px;
  border-radius: 18px;
  background:
    linear-gradient(90deg, rgba(7,55,99,.98), rgba(7,55,99,.88), rgba(7,55,99,.34)),
    var(--cta-image) center right / cover no-repeat;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 20px;
  align-items: center;
  padding: 28px 34px;
  box-shadow: 0 14px 30px rgba(7,55,99,.18);
}

.kao-cat-cta strong {
  display: block;
  color: #fff;
  font-size: 22px;
  font-weight: 900;
  line-height: 1.55;
}

.kao-cat-cta p {
  margin: 4px 0 0;
  color: #dbeaff;
  font-size: 13px;
  font-weight: 700;
}

.kao-cat-cta a {
  display: inline-flex;
  min-height: 44px;
  align-items: center;
  justify-content: center;
  padding: 0 28px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--orange), var(--orange2));
  color: #fff;
  font-weight: 900;
  box-shadow: 0 10px 22px rgba(255,107,44,.28);
}

/* =========================================================
  Responsive
========================================================= */

@media (max-width: 1024px) {
  .kao-cat-summary {
    display: none;
  }

  .kao-cat-hero__content {
    width: 68%;
  }

  .kao-cat-layout {
    grid-template-columns: 1fr;
  }

  .kao-cat-side {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .kao-cat-cluster-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .kao-cat-page {
    padding: 0 12px 36px;
  }

  .kao-cat-hero {
    background:
      linear-gradient(
        180deg,
        rgba(255,255,255,.98),
        rgba(255,255,255,.94) 48%,
        rgba(255,255,255,.52) 75%,
        rgba(255,255,255,.12)
      ),
      var(--hero-image) center bottom / cover no-repeat;
  }

  .kao-cat-hero__inner {
    min-height: 560px;
    padding: 26px 20px;
  }

  .kao-cat-hero__content {
    width: 100%;
  }

  .kao-cat-title {
    font-size: 38px;
  }

  .kao-cat-catch {
    font-size: 18px;
  }

  .kao-cat-chip-grid,
  .kao-cat-feature-layout,
  .kao-cat-card-grid,
  .kao-cat-archive-grid,
  .kao-cat-side,
  .kao-cat-cluster-grid {
    grid-template-columns: 1fr;
  }

  .kao-cat-policy {
    grid-template-columns: 1fr;
  }

  .kao-cat-feature-large {
    min-height: 360px;
  }

  .kao-cat-archive-card {
    grid-template-columns: 1fr;
  }

  .kao-cat-archive-card__body {
    padding: 14px;
  }

  .kao-cat-heading {
    font-size: 19px !important;
    padding-left: 16px !important;
  }

  .kao-cat-heading::before {
    width: 5px !important;
    height: 26px !important;
  }

  .kao-cat-cta {
    grid-template-columns: 1fr;
    text-align: center;
    padding: 24px 18px;
  }

  .kao-cat-cta a {
    width: 100%;
  }
}

@media (max-width: 520px) {
  .kao-cat-title {
    font-size: 34px;
  }

  .kao-cat-hero__inner {
    min-height: 620px;
  }

  .kao-cat-feature-large h2 {
    font-size: 20px !important;
  }

  .kao-cat-cta strong {
    font-size: 19px;
  }
}
/* =========================================================
  緊急修正：注目記事カード崩れ対応
  横長アイキャッチをPC 3列×2段で表示
========================================================= */

.kao-cat-page .kao-cat-feature-grid-v2 {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
  align-items: stretch !important;
}

.kao-cat-page .kao-cat-feature-card-v2 {
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  border: 1px solid #d8e7f6 !important;
  border-radius: 18px !important;
  background: #fff !important;
  box-shadow: 0 12px 26px rgba(11, 57, 104, .07) !important;
  text-decoration: none !important;
  color: #10233f !important;
}

.kao-cat-page .kao-cat-feature-card-v2__thumb {
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  overflow: hidden !important;
  background: #f4f9ff !important;
  border-bottom: 1px solid #e2edf8 !important;
}

.kao-cat-page .kao-cat-feature-card-v2__thumb img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: contain !important;
  object-position: center center !important;
  background: #f4f9ff !important;
}

.kao-cat-page .kao-cat-feature-card-v2__body {
  padding: 14px 15px 16px !important;
}

.kao-cat-page .kao-cat-feature-card-v2__body span {
  display: inline-flex !important;
  width: fit-content !important;
  margin-bottom: 8px !important;
  padding: 4px 9px !important;
  border-radius: 999px !important;
  background: #0b4f9f !important;
  color: #fff !important;
  font-size: 11px !important;
  font-weight: 900 !important;
}

.kao-cat-page .kao-cat-feature-card-v2__body h3 {
  margin: 0 0 8px !important;
  padding: 0 !important;
  color: #073763 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  line-height: 1.55 !important;
}

.kao-cat-page .kao-cat-feature-card-v2__body p {
  margin: 0 !important;
  color: #52687f !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1.7 !important;
}

/* 古い注目記事レイアウトが残っている場合の無効化 */
.kao-cat-page .kao-cat-feature-layout {
  display: block !important;
}

.kao-cat-page .kao-cat-feature-large,
.kao-cat-page .kao-cat-card-grid,
.kao-cat-page .kao-cat-card {
  display: none !important;
}

/* 記事一覧側の横長画像対応 */
.kao-cat-page .kao-cat-archive-card {
  display: grid !important;
  grid-template-columns: 180px minmax(0, 1fr) !important;
  overflow: hidden !important;
}

.kao-cat-page .kao-cat-archive-card__thumb {
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  min-height: auto !important;
  background: #f4f9ff !important;
}

.kao-cat-page .kao-cat-archive-card__thumb img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  background: #f4f9ff !important;
}

/* スマホ・タブレット */
@media (max-width: 1024px) {
  .kao-cat-page .kao-cat-feature-grid-v2 {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .kao-cat-page .kao-cat-archive-card {
    grid-template-columns: 160px minmax(0, 1fr) !important;
  }
}

@media (max-width: 768px) {
  .kao-cat-page .kao-cat-feature-grid-v2 {
    grid-template-columns: 1fr !important;
  }

  .kao-cat-page .kao-cat-archive-card {
    grid-template-columns: 1fr !important;
  }

  .kao-cat-page .kao-cat-archive-card__body {
    padding: 14px !important;
  }
}