/*
Theme Name:  KOUKOKU-KK
Theme URI:   https://koukoku-kk.co.jp/
Template:    swell
Author:      S-ONE
Author URI:  https://s-one.ltd/
Description: 興黒工業株式会社 様向け 専用カスタマイズテーマ
Version:     1.0.0
*/



/* ==============================================
   KOUKOKU-KK
   モノトーン調整版
=============================================== */

:root {
    --kk-bg: #ffffff;
    --kk-text: #111111;
    --kk-subtext: #555555;
    --kk-border: rgba(17, 17, 17, 0.14);
    --kk-border-strong: rgba(17, 17, 17, 0.22);
    --kk-muted: #f3f3f3;
    --kk-muted-dark: #e8e8e8;
    --color-bg: #ffffff;
    --color-text: #111111;
    --color-subtext: #333333;
    --color-border: #000000;
}

body {
    font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "Yu Gothic", "YuGothic", sans-serif;
    font-size: 1rem;
    font-weight: 500;
    color: var(--color-text);
    background-color: var(--color-bg);
    line-height: 1.9;
    letter-spacing: 0.02em;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    margin: 0;
    padding: 0;
}

/* ==============================================
   1. カテゴリーバッジ
   白黒トーン統一
=============================================== */
.p-postList__item [data-cat-id="public"],
.c-postThumb__cat[data-cat-id="public"],
.p-postList__item [data-cat-id="high-end"],
.c-postThumb__cat[data-cat-id="high-end"],
.p-postList__item [data-cat-id="renovation"],
.c-postThumb__cat[data-cat-id="renovation"],
.p-postList__item [data-cat-id="maintenance"],
.c-postThumb__cat[data-cat-id="maintenance"] {
    background-color: #111111 !important;
    color: #ffffff !important;
    border: 1px solid #111111 !important;
}

/* ==============================================
   2. ヘッダー右端アクション
   ミニマル・モノトーン調整
=============================================== */
.koukoku-header-action-unit { position: fixed; top: 72px; right: 2%; transform: translateY(-50%); display: flex; align-items: center; gap: 24px; z-index: 9999; transition: all 0.3s ease; }
body.admin-bar .koukoku-header-action-unit { margin-top: 55px; }
html[data-scrolled="true"] .koukoku-header-action-unit { top: 36px; }
.koukoku-header-action__tel-group { display: flex; flex-direction: column; align-items: flex-end; line-height: 1.2; }
.koukoku-header-action__caption { font-size: 0.72rem; color: #666666; font-weight: 500; letter-spacing: 0.12em; transition: color 0.3s ease; }
.koukoku-header-action__tel { font-size: 1.45rem !important; font-weight: 500 !important; color: #111111 !important; text-decoration: none !important; letter-spacing: 0.04em; font-family: var(--swl-font_family) !important; transition: color 0.3s ease, opacity 0.3s ease; }
.koukoku-header-action-unit.is-top-page .koukoku-header-action__caption { color: rgba(255,255,255,0.88); }
.koukoku-header-action-unit.is-top-page .koukoku-header-action__tel { color: #ffffff !important; }
html[data-scrolled="true"] .koukoku-header-action-unit.is-top-page .koukoku-header-action__caption { color: #666666; }
html[data-scrolled="true"] .koukoku-header-action-unit.is-top-page .koukoku-header-action__tel { color: #111111 !important; }
.koukoku-header-action__btn { display: inline-flex; align-items: center; justify-content: center; gap: 6px; width: 148px; height: 46px; border-radius: 0; background: rgba(17,17,17,0.78); color: #ffffff !important; border: 1px solid rgba(255,255,255,0.72); font-size: 0.8rem; font-weight: 500; letter-spacing: 0.08em; transition: background 0.3s ease, color 0.3s ease, border-color 0.3s ease, transform 0.3s ease; position: relative; overflow: hidden; z-index: 1; }
html[data-scrolled="true"] .koukoku-header-action__btn { background: #111111; border-color: #111111; }
.koukoku-header-action__btn:hover { background: #ffffff; color: #111111 !important; border-color: #ffffff; transform: translateY(-2px); }
.koukoku-header-action__btn .material-symbols-outlined { font-size: 1.1rem; vertical-align: middle; }
@media (max-width: 1100px) { .koukoku-header-action-unit { display: none !important; } }
@media (min-width: 1101px) { .c-gnav { margin-right: 340px !important; } }
@media (max-width: 782px) { body.admin-bar .koukoku-header-action-unit { margin-top: 46px; } }
.-txt .c-headLogo__link { font-family: var(--swl-font_family) !important; font-weight: 400; }


/* ==============================================
   3. フォント統一
=============================================== */
body,
button,
input,
select,
textarea,
h1, h2, h3, h4, h5, h6,
.p-top-hero__title,
.koukoku-footer__tel a {
    font-family: var(--swl-font_family) !important;
}

.koukoku-footer__tel a {
    font-weight: 700 !important;
    letter-spacing: 0.05em !important;
    text-decoration: none !important;
}

/* ==============================================
   4. メガメニュー
   ガラス調 + トップページトーン統一版
   ※PC専用前提
   ※縦長カード維持
   ※文字の見え方改善 / 2枚目以降の薄化対策統合
   ※ul.c-gnav の下端位置に接地
============================================== */

/* =========================
   親メニュー
========================= */
li.mega-menu-pc {
  position: static !important;
}

li.mega-menu-pc > ul.sub-menu {
  position: fixed !important;
  top: 130px  !important;
  left: 0 !important;
  right: 0 !important;
  width: 100vw !important;
  max-width: 100vw !important;
  margin: 0 !important;
  padding: 72px 0 !important;
  box-sizing: border-box !important;
  z-index: 9999 !important;

  background: rgba(255, 255, 255, 0.01) !important;
  backdrop-filter: blur(20px) saturate(160%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(160%) !important;
  border-top: 1px solid rgba(255, 255, 255, 0.42) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.45),
    0 24px 60px rgba(0, 0, 0, 0.10) !important;

  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transform: none !important;
  transition:
    opacity 0.45s ease,
    visibility 0.45s ease !important;
}

/* 固定ヘッダー時のみ位置変更 */
.l-fixHeader li.mega-menu-pc > ul.sub-menu,
#fix_header li.mega-menu-pc > ul.sub-menu {
  top: 78px !important;
}

li.mega-menu-pc:hover > ul.sub-menu {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: none !important;
}

/* =========================
   不要リンクの除去
========================= */
li.mega-menu-pc > ul.sub-menu > li > a,
li.mega-menu-pc .p-blogParts > a,
li.mega-menu-pc .wp-block-columns > a,
li.mega-menu-pc .wp-block-column > a,
li.mega-menu-pc .swell-block-bannerLink > a:empty,
li.mega-menu-pc .c-bannerLink__text > a:empty,
li.mega-menu-pc .c-bannerLink__title > a:empty {
  display: none !important;
}

li.mega-menu-pc .sub-menu .swell-block-bannerLink .c-bannerLink__text > a.c-bannerLink,
li.mega-menu-pc .sub-menu .swell-block-bannerLink .c-bannerLink__title > a.c-bannerLink,
li.mega-menu-pc .sub-menu .swell-block-bannerLink .c-bannerLink__description > a.c-bannerLink,
li.mega-menu-pc .sub-menu .swell-block-bannerLink .c-bannerLink__title a.c-bannerLink,
li.mega-menu-pc .sub-menu .swell-block-bannerLink .c-bannerLink__description a.c-bannerLink {
  display: none !important;
}

/* =========================
   内部レイアウト
========================= */
li.mega-menu-pc .p-blogParts {
  display: block !important;
  width: 100% !important;
  max-width: 1240px !important;
  margin: 0 auto !important;
  padding: 0 40px !important;
  box-sizing: border-box !important;
}

li.mega-menu-pc .wp-block-columns,
li.mega-menu-pc .sub-menu .wp-block-columns {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 28px !important;
  margin: 0 !important;
  align-items: stretch !important;
}

li.mega-menu-pc .wp-block-column,
li.mega-menu-pc .sub-menu .wp-block-column {
  position: relative !important;
  display: flex !important;
  align-items: stretch !important;
  min-width: 0 !important;
  margin: 0 !important;
}

li.mega-menu-pc .sub-menu .wp-block-column > .swell-block-bannerLink {
  width: 100% !important;
}

/* =========================
   カード本体
========================= */
li.mega-menu-pc .sub-menu .swell-block-bannerLink {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  aspect-ratio: 3 / 4 !important;
  min-height: 0 !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 0 !important;
  isolation: isolate !important;

  background: rgba(17, 17, 17, 0.78) !important;
  border: 1px solid rgba(255, 255, 255, 0.22) !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.10) !important;

  transition:
    transform 0.6s cubic-bezier(.16, 1, .3, 1),
    box-shadow 0.6s ease,
    border-color 0.4s ease !important;
}

li.mega-menu-pc .sub-menu .swell-block-bannerLink:hover {
  transform: translateY(-6px) !important;
  border-color: rgba(255, 255, 255, 0.34) !important;
  box-shadow: 0 24px 46px rgba(0, 0, 0, 0.16) !important;
}

/* =========================
   全面リンク
========================= */
li.mega-menu-pc .sub-menu .swell-block-bannerLink > a.c-bannerLink {
  position: absolute !important;
  inset: 0 !important;
  z-index: 5 !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  background: transparent !important;
  text-decoration: none !important;
  pointer-events: auto !important;
}

/* =========================
   画像
========================= */
li.mega-menu-pc .sub-menu .swell-block-bannerLink .c-bannerLink__figure {
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
}

li.mega-menu-pc .sub-menu .swell-block-bannerLink .c-bannerLink__img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  opacity: 0.9 !important;
  transition:
    transform 0.8s cubic-bezier(.16, 1, .3, 1),
    filter 0.8s ease,
    opacity 0.5s ease !important;
}

li.mega-menu-pc .sub-menu .swell-block-bannerLink:hover .c-bannerLink__img {
  transform: scale(1.08) !important;
  opacity: 1 !important;
  filter: grayscale(0%) brightness(1.12) contrast(1.04) !important;
}

/* =========================
   テキストレイヤー
========================= */
li.mega-menu-pc .sub-menu .swell-block-bannerLink .c-bannerLink__text {
  position: absolute !important;
  inset: 0 !important;
  z-index: 10 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  align-items: flex-start !important;
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
  padding: 0 24px 28px !important;
  box-sizing: border-box !important;
  text-align: left !important;
  pointer-events: none !important;

  background: linear-gradient(
    to top,
    rgba(17, 17, 17, 0.82) 0%,
    rgba(17, 17, 17, 0.48) 40%,
    rgba(17, 17, 17, 0.12) 70%,
    rgba(17, 17, 17, 0) 100%
  ) !important;
}

li.mega-menu-pc .sub-menu .swell-block-bannerLink .c-bannerLink__title,
li.mega-menu-pc .sub-menu .swell-block-bannerLink .c-bannerLink__description {
  position: relative !important;
  z-index: 11 !important;
  color: #ffffff !important;
  opacity: 1 !important;
  -webkit-text-fill-color: #ffffff !important;
}

/* =========================
   タイトル
========================= */
li.mega-menu-pc .sub-menu .swell-block-bannerLink .c-bannerLink__title {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  font-family: var(--swl-font_family) !important;
  font-size: 1.06rem !important;
  font-weight: 700 !important;
  line-height: 1.7 !important;
  letter-spacing: 0.04em !important;
  text-shadow: 0 4px 18px rgba(0, 0, 0, 0.34) !important;
  transform: translateY(8px) !important;
  transition: transform 0.5s ease !important;
  pointer-events: none !important;
}

li.mega-menu-pc .sub-menu .swell-block-bannerLink .c-bannerLink__title > a.c-bannerLink {
  display: none !important;
}

li.mega-menu-pc .sub-menu .swell-block-bannerLink .c-bannerLink__title br {
  display: block !important;
}

/* =========================
   サブタイトル / 説明
========================= */
li.mega-menu-pc .sub-menu .swell-block-bannerLink .c-bannerLink__description {
  display: block !important;
  margin-top: 8px !important;
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  line-height: 1.7 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: rgba(255, 255, 255, 0.92) !important;
  -webkit-text-fill-color: rgba(255, 255, 255, 0.92) !important;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.24) !important;

  opacity: 0 !important;
  visibility: hidden !important;
  transform: translate3d(0, 10px, 0) !important;
  transition:
    opacity 0.45s ease 0.08s,
    transform 0.45s cubic-bezier(.16, 1, .3, 1) 0.08s,
    visibility 0.45s ease 0.08s !important;

  pointer-events: none !important;
}

li.mega-menu-pc .sub-menu .swell-block-bannerLink .c-bannerLink__description strong {
  font-weight: 700 !important;
  color: inherit !important;
}

/* =========================
   装飾レイヤー
========================= */
li.mega-menu-pc .sub-menu .swell-block-bannerLink::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 2 !important;
  pointer-events: none !important;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.10) 0%,
    rgba(255, 255, 255, 0.03) 24%,
    rgba(255, 255, 255, 0) 46%
  ) !important;
}

li.mega-menu-pc .sub-menu .swell-block-bannerLink::after {
  content: "" !important;
  position: absolute !important;
  top: 14px !important;
  right: 14px !important;
  bottom: 14px !important;
  left: 14px !important;
  z-index: 4 !important;
  box-sizing: border-box !important;
  border: 1px solid rgba(255, 255, 255, 0.24) !important;
  opacity: 0 !important;
  transform: scale(1.02) !important;
  transition:
    opacity 0.5s ease,
    transform 0.5s cubic-bezier(.16, 1, .3, 1) !important;
  pointer-events: none !important;
}

li.mega-menu-pc .sub-menu .swell-block-bannerLink:hover::after {
  opacity: 1 !important;
  transform: scale(1) !important;
}

/* =========================
   ホバー時の文字演出
========================= */
li.mega-menu-pc .sub-menu .swell-block-bannerLink:hover .c-bannerLink__title {
  transform: translateY(0) !important;
}

li.mega-menu-pc .sub-menu .swell-block-bannerLink:hover .c-bannerLink__description {
  opacity: 1 !important;
  visibility: visible !important;
  transform: translate3d(0, 0, 0) !important;
}

/* =========================
   空要素の整理
========================= */
li.mega-menu-pc .sub-menu .p-blogParts.post_content p:empty {
  display: none !important;
  margin: 0 !important;
}


/* =========================
   コラム＆ニュース
========================= */
.blog, .post-type-archive-column { --kk-bg: #ffffff; --kk-text: #111111; --kk-line: rgba(17, 17, 17, 0.12); }
.blog #content, .blog .l-content, .blog .l-main, .post-type-archive-column #content, .post-type-archive-column .l-content, .post-type-archive-column .l-main { display: block !important; max-width: 100% !important; width: 100% !important; padding: 0 !important; margin: 0 !important; }
.blog .l-header__inner, .blog .l-fixHeader__inner, .blog .l-header .l-container, .blog .l-fixHeader .l-container, .post-type-archive-column .l-header__inner, .post-type-archive-column .l-fixHeader__inner, .post-type-archive-column .l-header .l-container, .post-type-archive-column .l-fixHeader .l-container { max-width: 100% !important; width: 100% !important; padding-left: clamp(20px, 5vw, 60px) !important; padding-right: clamp(20px, 5vw, 60px) !important; box-sizing: border-box !important; }
.blog .p-page-hero, .post-type-archive-column .p-page-hero { position: relative !important; width: 100% !important; min-height: 100vh !important; min-height: 100svh !important; display: flex !important; align-items: center !important; justify-content: center !important; background-color: #111 !important; background-size: cover !important; background-position: center center !important; background-repeat: no-repeat !important; color: #fff !important; overflow: hidden !important; isolation: isolate !important; z-index: 1 !important; filter: grayscale(20%) !important; }
.post-type-archive-column .p-page-hero { background-image: url('https://kk2026.xsrv.jp/wp-content/uploads/2026/05/Work08-1.webp') !important; }
.blog .p-page-hero { background-image: url('https://kk2026.xsrv.jp/wp-content/uploads/2026/05/Work03-3.webp') !important; }
.blog .p-page-hero::before, .post-type-archive-column .p-page-hero::before { content: '' !important; position: absolute !important; inset: 0 !important; background: radial-gradient(circle at center, rgba(0,0,0,0.22) 0%, rgba(0,0,0,0.58) 100%) !important; z-index: 2 !important; }
.blog .p-page-hero__outline, .post-type-archive-column .p-page-hero__outline { position: absolute !important; inset: 0 !important; display: flex !important; align-items: center !important; overflow: hidden !important; pointer-events: none !important; z-index: 1 !important; }
.blog .p-page-hero__outline-track, .post-type-archive-column .p-page-hero__outline-track { display: inline-flex !important; align-items: center !important; white-space: nowrap !important; will-change: transform !important; animation: kkArchiveCinematicMarquee 90s linear infinite !important; }
.blog .p-page-hero__outline-track span, .post-type-archive-column .p-page-hero__outline-track span { display: inline-block !important; padding-right: 10vw !important; font-size: clamp(5rem, 15vw, 13rem) !important; font-weight: 900 !important; font-family: 'Helvetica Neue', Arial, sans-serif !important; color: rgba(255,255,255,0.04) !important; line-height: 1 !important; }
@keyframes kkArchiveCinematicMarquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
@keyframes kkArchiveFadeUpHero { 0% { opacity: 0; transform: translateY(30px); } 100% { opacity: 1; transform: translateY(0); } }
.blog .p-page-hero__inner, .post-type-archive-column .p-page-hero__inner { position: relative !important; z-index: 10 !important; width: 100% !important; max-width: 980px !important; margin: 0 auto !important; padding: 140px 40px 100px !important; text-align: center !important; visibility: visible !important; }
.blog .p-page-hero__title, .post-type-archive-column .p-page-hero__title { margin: 0 0 44px !important; color: #fff !important; opacity: 1 !important; animation: kkArchiveFadeUpHero 1.2s cubic-bezier(0.215, 0.61, 0.355, 1) 0.2s both !important; }
.blog .p-page-hero__title .en, .post-type-archive-column .p-page-hero__title .en { display: block !important; margin-bottom: 10px !important; font-size: 1rem !important; font-weight: 700 !important; color: #fff !important; letter-spacing: 0.08em !important; }
.blog .p-page-hero__title .jp, .post-type-archive-column .p-page-hero__title .jp { display: block !important; font-size: clamp(2.2rem, 5vw, 4rem) !important; font-weight: 300 !important; line-height: 1.3 !important; color: #fff !important; }
.blog .p-page-hero__summary, .post-type-archive-column .p-page-hero__summary { position: relative !important; z-index: 10 !important; }
.blog .p-page-hero__summary .catch, .post-type-archive-column .p-page-hero__summary .catch { margin: 0 0 24px !important; font-size: clamp(1.45rem, 2.4vw, 2.2rem) !important; font-weight: 400 !important; line-height: 1.7 !important; color: #fff !important; opacity: 1 !important; animation: kkArchiveFadeUpHero 1.2s cubic-bezier(0.215, 0.61, 0.355, 1) 0.4s both !important; }
.blog .p-custom-main, .post-type-archive-column .p-custom-main { background: var(--kk-bg) !important; color: var(--kk-text) !important; padding: 0 !important; width: 100% !important; position: relative !important; z-index: 20 !important; box-shadow: 0 -20px 40px rgba(0,0,0,0.1) !important; }
.blog .p-homeContent, .post-type-archive-column .p-homeContent { max-width: 1200px !important; margin: 0 auto !important; padding: 100px 20px 80px !important; }
.blog .p-postList__thumb img, .post-type-archive-column .p-postList__thumb img { transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1) !important; }
.blog .p-postList__item:hover .p-postList__thumb img, .post-type-archive-column .p-postList__item:hover .p-postList__thumb img { transform: scale(1.08) !important; }
.blog .koukoku-archive-progress, .post-type-archive-column .koukoku-archive-progress { position: fixed !important; top: 0 !important; left: 0 !important; width: 0 !important; height: 2px !important; background: #111 !important; z-index: 10000 !important; transition: width .12s ease-out !important; }
.blog .l-mainContent__inner [class*=page-numbers], .post-type-archive-column .l-mainContent__inner [class*=page-numbers] { box-sizing: content-box !important; display: inline-block !important; font-size: 14px !important; height: 36px !important; line-height: 36px !important; margin: 6px !important; min-width: 36px !important; padding: 0 !important; text-align: center !important; text-decoration: none !important; transition: all .3s ease !important; color: #fff !important; background-color: #dedede !important; border-radius: 0 !important; box-shadow: var(--swl-box_shadow) !important; }
.blog .l-mainContent__inner [class*=page-numbers].current, .blog .l-mainContent__inner [class*=page-numbers]:hover, .post-type-archive-column .l-mainContent__inner [class*=page-numbers].current, .post-type-archive-column .l-mainContent__inner [class*=page-numbers]:hover { background-color: #111 !important; color: #fff !important; }
@media screen and (max-width: 1024px) { .blog .p-page-hero, .post-type-archive-column .p-page-hero { min-height: 100dvh !important; background-position: center center !important; } .blog .p-page-hero__inner, .post-type-archive-column .p-page-hero__inner { max-width: 100% !important; padding: 112px 24px 64px !important; } .blog .p-page-hero__title, .post-type-archive-column .p-page-hero__title { margin: 0 0 28px !important; } .blog .p-page-hero__title .jp, .post-type-archive-column .p-page-hero__title .jp { font-size: clamp(2rem, 7vw, 3.2rem) !important; line-height: 1.28 !important; } .blog .p-page-hero__summary .catch, .post-type-archive-column .p-page-hero__summary .catch { font-size: clamp(1.15rem, 3.8vw, 1.6rem) !important; line-height: 1.7 !important; margin: 0 0 20px !important; } .blog .p-page-hero__outline-track span, .post-type-archive-column .p-page-hero__outline-track span { font-size: clamp(3.5rem, 16vw, 7rem) !important; padding-right: 8vw !important; color: rgba(255,255,255,0.03) !important; } }
@media screen and (max-width: 767px) { .blog .p-page-hero, .post-type-archive-column .p-page-hero { min-height: 100dvh !important; background-position: center center !important; } .blog .p-page-hero::before, .post-type-archive-column .p-page-hero::before { background: linear-gradient(to bottom, rgba(0,0,0,0.32) 0%, rgba(0,0,0,0.58) 100%) !important; } .blog .p-page-hero__inner, .post-type-archive-column .p-page-hero__inner { max-width: 100% !important; padding: 96px 20px 56px !important; } .blog .p-page-hero__title, .post-type-archive-column .p-page-hero__title { margin: 0 0 22px !important; animation: kkArchiveFadeUpHero 1.2s cubic-bezier(0.215, 0.61, 0.355, 1) 0.2s both !important; } .blog .p-page-hero__title .en, .post-type-archive-column .p-page-hero__title .en { margin-bottom: 8px !important; font-size: 0.9rem !important; line-height: 1.4 !important; } .blog .p-page-hero__title .jp, .post-type-archive-column .p-page-hero__title .jp { font-size: clamp(1.75rem, 8.2vw, 2.5rem) !important; line-height: 1.28 !important; overflow-wrap: anywhere !important; } .blog .p-page-hero__summary .catch, .post-type-archive-column .p-page-hero__summary .catch { font-size: clamp(1rem, 4.6vw, 1.3rem) !important; line-height: 1.75 !important; margin: 0 !important; animation: kkArchiveFadeUpHero 1.2s cubic-bezier(0.215, 0.61, 0.355, 1) 0.4s both !important; } .blog .p-page-hero__outline, .post-type-archive-column .p-page-hero__outline { display: none !important; } }
@media screen and (max-width: 480px) { .blog .p-page-hero__inner, .post-type-archive-column .p-page-hero__inner { padding: 88px 16px 48px !important; } .blog .p-page-hero__title .jp, .post-type-archive-column .p-page-hero__title .jp { font-size: clamp(1.6rem, 8.8vw, 2.1rem) !important; } .blog .p-page-hero__summary .catch, .post-type-archive-column .p-page-hero__summary .catch { font-size: clamp(0.95rem, 4.8vw, 1.15rem) !important; } }
@media (prefers-reduced-motion: reduce) { .blog .p-page-hero__outline-track, .post-type-archive-column .p-page-hero__outline-track, .blog .p-page-hero__title, .post-type-archive-column .p-page-hero__title, .blog .p-page-hero__summary .catch, .post-type-archive-column .p-page-hero__summary .catch { animation: none !important; transition: none !important; } }


/* =========================
   ポインター
========================= */
@media (hover: hover) and (pointer: fine) {
  .kk-cursor {
    position: fixed;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    pointer-events: none;
    z-index: 20000;
    mix-blend-mode: normal;
  }

  .kk-cursor__dot {
    position: fixed;
    top: 0;
    left: 0;
    width: 8px;
    height: 8px;
    margin: -4px 0 0 -4px;
    border-radius: 50%;
    background: rgba(17,17,17,0.92);
    transform: translate3d(0,0,0);
    will-change: transform, opacity;
    transition: opacity .2s ease;
  }

  .kk-cursor__ring {
    position: fixed;
    top: 0;
    left: 0;
    width: 34px;
    height: 34px;
    margin: -17px 0 0 -17px;
    border-radius: 50%;
    border: 1px solid rgba(17,17,17,0.34);
    background: rgba(255,255,255,0.02);
    transform: translate3d(0,0,0);
    will-change: transform, width, height, margin, background, border-color, opacity, box-shadow;
    transition:
      width .24s ease,
      height .24s ease,
      margin .24s ease,
      background .24s ease,
      border-color .24s ease,
      opacity .24s ease,
      box-shadow .24s ease;
    backdrop-filter: none;
  }

  .kk-cursor__label {
    position: fixed;
    top: 0;
    left: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 78px;
    height: 78px;
    padding: 0 10px;
    margin: -39px 0 0 -39px;
    font-size: 0.66rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    color: #ffffff;
    opacity: 0;
    transform: translate3d(0,0,0) scale(.92);
    transition: opacity .22s ease, transform .22s ease;
    will-change: transform, opacity;
    text-align: center;
    white-space: nowrap;
  }

  .kk-cursor.is-hidden .kk-cursor__dot,
  .kk-cursor.is-hidden .kk-cursor__ring,
  .kk-cursor.is-hidden .kk-cursor__label {
    opacity: 0;
  }

  .kk-cursor.is-hover .kk-cursor__ring {
    width: 54px;
    height: 54px;
    margin: -27px 0 0 -27px;
    border-color: rgba(17,17,17,0.72);
    background: rgba(17,17,17,0.08);
  }

  .kk-cursor.is-down .kk-cursor__ring {
    width: 42px;
    height: 42px;
    margin: -21px 0 0 -21px;
  }

  .kk-cursor.has-label .kk-cursor__dot {
    opacity: 0;
  }

  .kk-cursor.has-label .kk-cursor__ring {
    width: 78px;
    height: 78px;
    margin: -39px 0 0 -39px;
    border-color: #111111;
    background: rgba(17,17,17,0.94);
    box-shadow: 0 12px 30px rgba(0,0,0,0.18);
  }

  .kk-cursor.has-label .kk-cursor__label {
    opacity: 1;
    transform: translate3d(0,0,0) scale(1);
  }
}
