/* ============================================
   KAPIBARAN Brand Design System v2 (Beige / Premium D2C)
   Reference: KAPIBARAN_design_package PC_01_TOP.png
   --------------------------------------------
   - Background   : #F4F1EC (Ivory White)
   - Background2  : #FAF7F2 (off section alt)
   - Accent       : #E8DDC8 (Warm Beige)
   - Accent dark  : #C9B896
   - CTA          : #8B7355 (Camel)
   - Text         : #2B2218 (Dark Brown)
   - Text sub     : #6B5D4F (Mid Brown)
   - Border       : #E5DDD0
   ============================================ */

:root {
    --color-bg:           #F4F1EC;
    --color-bg-alt:       #FAF7F2;
    --color-accent:       #E8DDC8;
    --color-accent-dark:  #C9B896;
    --color-cta:          #8B7355;
    --color-cta-hover:    #6F5C44;
    --color-text:         #2B2218;
    --color-text-sub:     #6B5D4F;
    --color-border:       #E5DDD0;
    --color-white:        #FFFFFF;

    --font-serif-jp:   'Shippori Mincho', 'Noto Serif JP', 'Yu Mincho', 'YuMincho', 'Hiragino Mincho ProN', serif;
    --font-sans-jp:    'Noto Sans JP', 'Yu Gothic', 'Hiragino Sans', sans-serif;
    --font-serif-en:   'Cormorant Garamond', 'Yu Mincho', serif;
    --font-sans-en:    'Inter', 'Helvetica Neue', Arial, sans-serif;

    --container-max:   1200px;
    --section-pad-pc:  120px;
    --section-pad-sp:  64px;
}

/* ---------- 全体トーン（D-26: サイト全体 Shippori Mincho 統一） ---------- */
html, body, .l-container, .l-content, .l-mainContent,
.entry-content, .post_content, p, span, div, li {
    color: var(--color-text);
    font-family: var(--font-serif-jp) !important;
    font-feature-settings: "palt";
    letter-spacing: 0.02em;
    line-height: 1.85;
}
html, body, .l-container, .l-content, .l-mainContent {
    background-color: var(--color-bg) !important;
}
body { color: var(--color-text) !important; }

/* ボタン・メニュー・フォーム類も明朝に */
.kbv2-btn, .kbv2-btn--primary, .kbv2-btn--ghost,
.kbv2-pill, .kbv2-form input, .kbv2-form select, .kbv2-form textarea,
.c-gnav__item a, .l-header a, .l-footer a,
.kbv2-cat-card__sub, .kbv2-prod-card__name, .kbv2-plist__name,
.kbv2-journal__title, .kbv2-journal__date,
.kbv2-faq__q, .kbv2-faq__a, .kbv2-eyebrow {
    font-family: var(--font-serif-jp) !important;
}

a { color: var(--color-text); text-decoration: none; transition: color .25s ease, opacity .25s ease; }
a:hover { color: var(--color-cta); opacity: 0.85; }

/* SWELL 既定の見出し背景バーを子テーマ範囲内では全て除去 */
.entry-content h1, .entry-content h2, .entry-content h3, .entry-content h4 {
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin-left: 0 !important;
}
.entry-content h1::before, .entry-content h1::after,
.entry-content h2::before, .entry-content h2::after,
.entry-content h3::before, .entry-content h3::after,
.entry-content h4::before, .entry-content h4::after { content: none !important; background: transparent !important; }

/* ---------- 共通ユーティリティ ---------- */
.kbr-container { max-width: var(--container-max); margin: 0 auto; padding: 0 24px; }
.kbr-eyebrow {
    font-family: var(--font-sans-en);
    font-size: 0.74rem;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: var(--color-text-sub);
    margin-bottom: 1rem;
    display: inline-block;
}
.kbr-h1-en, .kbr-h2-en {
    font-family: var(--font-serif-en);
    font-weight: 400;
    letter-spacing: 0.12em;
    color: var(--color-text);
}
.kbr-h1-en { font-size: clamp(2.6rem, 5vw, 4rem); }
.kbr-h2-en { font-size: clamp(1.8rem, 3.6vw, 2.6rem); }
.kbr-h1-jp, .kbr-h2-jp {
    font-family: var(--font-serif-jp);
    font-weight: 500;
    color: var(--color-text);
    letter-spacing: 0.06em;
}
.kbr-h1-jp { font-size: clamp(1.6rem, 4.4vw, 2.6rem); line-height: 1.5; }
.kbr-h2-jp { font-size: clamp(1.4rem, 3.2vw, 2.0rem); line-height: 1.55; }
.kbr-body { font-size: 1rem; line-height: 1.95; color: var(--color-text); }
.kbr-sub  { color: var(--color-text-sub); }

/* ---------- ボタン ---------- */
.kbr-btn-primary {
    display: inline-block;
    background: var(--color-cta);
    color: var(--color-white) !important;
    padding: 16px 44px;
    border-radius: 2px;
    font-family: var(--font-sans-jp);
    font-weight: 500;
    letter-spacing: 0.18em;
    font-size: 0.88rem;
    transition: all .3s ease;
    border: 1px solid var(--color-cta);
}
.kbr-btn-primary:hover { background: var(--color-cta-hover); transform: translateY(-1px); color:#fff !important; opacity:1; }

.kbr-btn-secondary {
    display: inline-block;
    background: transparent;
    color: var(--color-text) !important;
    border: 1px solid var(--color-text);
    padding: 15px 43px;
    border-radius: 2px;
    font-family: var(--font-sans-jp);
    font-weight: 500;
    letter-spacing: 0.18em;
    font-size: 0.88rem;
    transition: all .3s ease;
}
.kbr-btn-secondary:hover { background: var(--color-text); color: #fff !important; opacity:1; }

/* ---------- セクション ---------- */
.kbr-section {
    width: 100vw !important;
    position: relative !important;
    left: 50% !important;
    right: 50% !important;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
    max-width: none !important;
    padding: clamp(var(--section-pad-sp), 9vw, var(--section-pad-pc)) 24px;
    background: var(--color-bg);
}
.kbr-section--alt { background: var(--color-bg-alt); }
.kbr-section--dark { background: #1B1612; color: #fff; }
.kbr-section__inner { max-width: var(--container-max); margin: 0 auto; }
.kbr-section__head { text-align: center; margin: 0 auto 3.5rem; }

/* ---------- HERO (PC_01 風) ---------- */
.kbr-hero {
    width: 100vw !important;
    position: relative !important;
    left: 50% !important;
    right: 50% !important;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
    max-width: none !important;
    min-height: 78vh;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: var(--color-text);
    overflow: hidden;
    padding: 0;
    background-color: var(--color-accent);
}
.kbr-hero__bg {
    position: absolute; inset: 0;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    z-index: 0;
}
.kbr-hero__bg::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(244,241,236,0.18) 0%, rgba(244,241,236,0.55) 100%);
}
.kbr-hero__inner {
    position: relative; z-index: 2;
    max-width: 720px; padding: 4rem 1.5rem;
    animation: kbr-fade-up 1.1s ease-out both;
}
.kbr-hero__en {
    font-family: var(--font-serif-en);
    font-size: clamp(2.2rem, 5.4vw, 3.8rem);
    font-weight: 400;
    letter-spacing: 0.08em;
    margin: 0 0 1.2rem;
    color: var(--color-text);
}
.kbr-hero__jp {
    font-family: var(--font-serif-jp);
    font-size: clamp(1.1rem, 2vw, 1.4rem);
    font-weight: 500;
    letter-spacing: 0.12em;
    margin: 0 0 2.4rem;
    color: var(--color-text);
}
.kbr-hero__cta { margin-top: 0.6rem; }

/* ---------- ヘッダー（白） ---------- */
.l-header { background: var(--color-white) !important; box-shadow: 0 1px 0 var(--color-border); }
.l-header__inner { background: transparent !important; }
.l-header.is-transparent { background: transparent !important; box-shadow: none; }
.l-header__logo img { max-height: 34px !important; width: auto !important; }
.c-gnav__item a, .c-iconList__link, .l-header a {
    font-family: var(--font-sans-jp);
    color: var(--color-text) !important;
    font-size: 0.84rem;
    letter-spacing: 0.12em;
}
.c-gnav__item a:hover { color: var(--color-cta) !important; }

/* ===== D-34: フッター背景ベージュ × 文字ダークブラウン ===== */
html body .l-footer,
html body .l-footer .l-footer__inner,
html body .l-footer__widgetArea,
html body .l-footer__foot,
html body .l-footer__head {
    background: var(--color-accent) !important;
    color: var(--color-text) !important;
}
html body .l-footer a,
html body .l-footer__nav a,
html body .l-footer .menu-item a {
    color: var(--color-text) !important;
    font-family: var(--font-serif-jp) !important;
    letter-spacing: 0.06em;
}
html body .l-footer a:hover {
    color: var(--color-cta) !important;
    opacity: 0.85;
}
html body .c-copyright,
html body .l-footer__copyright,
html body .copyright {
    background: var(--color-accent-dark) !important;
    color: var(--color-text) !important;
    font-family: var(--font-serif-jp) !important;
    font-size: 0.78rem !important;
    letter-spacing: 0.10em;
    padding: 0.8rem 1rem;
}
html body .l-footer__nav li,
html body .l-footer__foot li {
    border-color: rgba(43, 34, 24, 0.18) !important;
}
.kbr-footer-operator {
    color: rgba(255,255,255,0.32) !important;
    font-size: 0.66rem !important;
    letter-spacing: 0.12em;
    margin-top: 0.6rem;
    text-align: center;
}

/* ---------- サイドバー一切非表示・固定ページ＆フロント＆Productsは全幅 ---------- */
body.page .l-sidebar,
body.home .l-sidebar,
body.archive .l-sidebar,
body.single .l-sidebar { display: none !important; }
body.page .l-mainContent,
body.home .l-mainContent,
body.archive .l-mainContent,
body.single .l-mainContent {
    width: 100% !important; max-width: 100% !important; flex-basis: 100% !important;
}
body.page .l-content,
body.home .l-content {
    max-width: 100% !important; padding-left: 0 !important; padding-right: 0 !important;
}
body.page article.post,
body.home article.post {
    padding: 0 !important; margin: 0 !important; background: transparent !important;
}
body.page .entry-content, body.home .entry-content {
    padding: 0 !important; margin: 0 !important; max-width: 100% !important;
}
body.page .p-mainContent, body.home .p-mainContent {
    padding-top: 0 !important;
}
.page .c-pageTitle, .home .c-pageTitle,
.page .entry-header, .home .entry-header,
.page-title, .article-header { display: none !important; }

/* ---------- SWELL p-mainVisual を全面で非表示 (Hero に置き換わるため) ---------- */
.p-mainVisual, .p-mainVisual__inner, #mainvisual, .l-mainVisualArea {
    display: none !important; height: 0 !important; min-height: 0 !important;
}

/* ---------- フッター検索バー消す ---------- */
.l-footer .widget_search, .l-footer .search-form,
.l-bottomFixedMenu .widget_search { display: none !important; }

/* ---------- 共通アニメーション ---------- */
@keyframes kbr-fade-up {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}
.kbr-reveal { opacity: 0; transform: translateY(28px); transition: opacity .9s ease, transform .9s ease; }
.kbr-reveal.is-in { opacity: 1; transform: translateY(0); }

/* ---------- レスポンシブ ---------- */
@media (max-width: 768px) {
    .kbr-section { padding: var(--section-pad-sp) 18px; }
    .kbr-section__head { margin-bottom: 2.4rem; }
    .kbr-hero { min-height: 64vh; }
}

/* ============================================
   旧 kbr-* クラス対応（既存ページHTMLの上書き）
   - kbr-hero__inner / kbr-hero__logo / kbr-hero__headline / kbr-hero__sub / kbr-hero__cta
   - kbr-pillars / kbr-pillar / kbr-pillar__no / kbr-pillar__title / kbr-pillar__body
   - kbr-h1 / kbr-h2 / kbr-lead
   - kbr-products / kbr-products__label / kbr-products__title / kbr-products__sub / kbr-products__body
   - kbr-story / kbr-story__body
   - kbr-cta / kbr-cta__body
   - kbr-btn / kbr-btn--accent / kbr-btn--solid-accent
   - kbr-section--dark
   - kbr-scroll-hint
   - kbr-about-section / kbr-about-section__heading / kbr-about-section__body
   - kbr-footer-operator
   ============================================ */

/* HERO 用 (旧 navy → 新 beige) */
.kbr-hero { background: linear-gradient(135deg, #E8DDC8 0%, #F4F1EC 100%) !important; color: var(--color-text) !important; }
.kbr-hero__inner { position: relative; z-index: 2; max-width: 720px; padding: 4rem 1.5rem; animation: kbr-fade-up 1.1s ease-out both; text-align: center; }
.kbr-hero__logo { max-width: clamp(220px, 44vw, 420px); margin: 0 auto 2rem; display: block; }
.kbr-hero__logo img { width: 100%; height: auto; display: block; filter: brightness(0); }
.kbr-hero__headline { font-family: var(--font-serif-jp); font-weight: 500; font-size: clamp(1.4rem, 3.6vw, 2.1rem); letter-spacing: 0.12em; color: var(--color-text) !important; margin: 0 0 1.2rem; line-height: 1.55; }
.kbr-hero__sub { font-size: clamp(0.92rem, 1.3vw, 1rem); color: var(--color-text-sub) !important; line-height: 2; max-width: 540px; margin: 0 auto 2.4rem; }
.kbr-hero__cta {
    display: inline-block; padding: 16px 44px;
    background: var(--color-cta); color: #fff !important;
    border-radius: 2px; font-family: var(--font-sans-jp);
    font-weight: 500; letter-spacing: 0.18em; font-size: 0.88rem;
    text-decoration: none; transition: all .3s ease; border: 1px solid var(--color-cta);
}
.kbr-hero__cta:hover { background: var(--color-cta-hover); transform: translateY(-1px); }
.kbr-scroll-hint { position: absolute !important; bottom: 1.6rem !important; left: 50% !important; transform: translateX(-50%) !important; z-index: 3; color: var(--color-text-sub); font-size: 0.7rem; letter-spacing: 0.3em; text-transform: uppercase; }

/* 共通見出し */
.kbr-eyebrow { display: inline-block; font-family: var(--font-sans-en); font-size: 0.74rem; letter-spacing: 0.32em; color: var(--color-text-sub); text-transform: uppercase; margin-bottom: 1rem; }
.kbr-h1, .kbr-h2 {
    background: transparent !important; background-color: transparent !important;
    border: none !important; padding: 0 !important; box-shadow: none !important;
    margin-left: 0 !important;
}
.kbr-h1, .kbr-h1::before, .kbr-h1::after { content: none; }
.kbr-h1 { font-family: var(--font-serif-jp); font-weight: 500; font-size: clamp(1.6rem, 4vw, 2.4rem); line-height: 1.4; color: var(--color-text); margin: 0 0 1.2rem; }
.kbr-h2 { font-family: var(--font-serif-jp); font-weight: 500; font-size: clamp(1.4rem, 3vw, 1.9rem); line-height: 1.5; color: var(--color-text); margin: 0 0 1rem; letter-spacing: 0.04em; }
.kbr-h2::before, .kbr-h2::after { content: none !important; background: transparent !important; }
.kbr-lead { font-size: clamp(0.95rem, 1.3vw, 1.05rem); line-height: 1.95; color: var(--color-text-sub); max-width: 640px; }

/* dark セクション内では白色に */
.kbr-section--dark .kbr-h2, .kbr-section--dark .kbr-h1,
.kbr-story .kbr-h2, .kbr-story .kbr-h1 { color: #fff !important; }
.kbr-section--dark { background: #1B1612 !important; color: rgba(255,255,255,0.88); }

/* CONCEPT pillars */
.kbr-pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(20px, 3vw, 32px); margin-top: 1.5rem; max-width: 1100px; margin-left: auto; margin-right: auto; }
@media (max-width: 768px) { .kbr-pillars { grid-template-columns: 1fr; } }
.kbr-pillar { background: var(--color-white); padding: 2.4rem 1.8rem; border-radius: 4px; text-align: left; box-shadow: 0 8px 24px rgba(43,34,24,0.04); border: 1px solid var(--color-border); transition: transform .3s ease, box-shadow .3s ease; }
.kbr-pillar:hover { transform: translateY(-4px); box-shadow: 0 16px 36px rgba(43,34,24,0.08); }
.kbr-pillar__no { display: block; font-family: var(--font-sans-en); font-size: 0.78rem; letter-spacing: 0.32em; color: var(--color-cta); margin-bottom: 1.2rem; }
.kbr-pillar__title { background: transparent !important; border: none !important; padding: 0 !important; font-family: var(--font-serif-jp); font-size: 1.18rem; font-weight: 500; color: var(--color-text) !important; margin: 0 0 0.8rem; line-height: 1.5; }
.kbr-pillar__title::before, .kbr-pillar__title::after { content: none !important; background: transparent !important; }
.kbr-pillar__body { font-size: 0.92rem; line-height: 1.95; color: var(--color-text-sub); }

/* Products section */
.kbr-products { background: var(--color-bg-alt); text-align: center; }
.kbr-products__label { display: block; font-family: var(--font-sans-en); color: var(--color-cta); letter-spacing: 0.4em; font-size: 0.74rem; text-transform: uppercase; margin-bottom: 1.2rem; }
.kbr-products__title {
    background: transparent !important; border: none !important; padding: 0 !important;
    font-family: var(--font-serif-en); font-size: clamp(2.4rem, 6vw, 4.4rem); font-weight: 400;
    color: var(--color-text) !important; margin: 0 0 0.6rem; letter-spacing: 0.06em; line-height: 1;
}
.kbr-products__title::before, .kbr-products__title::after { content: none !important; background: transparent !important; }
.kbr-products__sub { font-size: 1rem; color: var(--color-text-sub); margin-bottom: 1.6rem; letter-spacing: 0.18em; font-family: var(--font-serif-jp); }
.kbr-products__body { max-width: 520px; margin: 0 auto 2rem; line-height: 2; color: var(--color-text); font-size: 0.96rem; }

/* Story section */
.kbr-story { background: #1B1612 !important; color: #fff; text-align: center; }
.kbr-story .kbr-h2 { color: #fff !important; }
.kbr-story__body { color: rgba(255,255,255,0.85); max-width: 620px; margin: 0 auto 2rem; line-height: 2.1; white-space: pre-line; font-family: var(--font-serif-jp); font-size: 0.98rem; }
.kbr-story .kbr-btn { border-color: rgba(255,255,255,0.7); color: #fff !important; }
.kbr-story .kbr-btn:hover { background: #fff; color: #1B1612 !important; }

/* Contact CTA section */
.kbr-cta { background: var(--color-bg); text-align: center; padding-top: clamp(60px, 9vh, 110px); padding-bottom: clamp(60px, 9vh, 110px); }
.kbr-cta__body { color: var(--color-text-sub); max-width: 520px; margin: 0 auto 2rem; line-height: 2; }

/* Buttons (旧 navy デザインの kbr-btn 系を beige に置き換え) */
.kbr-btn {
    display: inline-block;
    padding: 14px 36px;
    border: 1px solid var(--color-text);
    color: var(--color-text) !important;
    background: transparent;
    border-radius: 2px;
    font-family: var(--font-sans-jp);
    font-weight: 500;
    letter-spacing: 0.16em;
    font-size: 0.86rem;
    text-decoration: none;
    transition: all .25s ease;
}
.kbr-btn:hover { background: var(--color-text); color: #fff !important; }
.kbr-btn--accent { border-color: var(--color-cta); color: var(--color-cta) !important; }
.kbr-btn--accent:hover { background: var(--color-cta); color: #fff !important; }
.kbr-btn--solid-accent { background: var(--color-cta); border-color: var(--color-cta); color: #fff !important; }
.kbr-btn--solid-accent:hover { background: var(--color-cta-hover); color: #fff !important; }

/* About page sections */
.kbr-about-section { max-width: 720px; margin: 0 auto; padding: 2.6rem 0; border-top: 1px solid var(--color-border); }
.kbr-about-section:first-child { border-top: none; }
.kbr-about-section__heading {
    background: transparent !important; border: none !important; padding: 0 !important;
    font-family: var(--font-serif-jp);
    font-size: 1.2rem; font-weight: 500; color: var(--color-text) !important;
    margin: 0 0 1.2rem; letter-spacing: 0.04em;
}
.kbr-about-section__heading::before, .kbr-about-section__heading::after { content: none !important; background: transparent !important; }
.kbr-about-section__body { font-size: 0.98rem; line-height: 2.1; color: var(--color-text); white-space: pre-line; }

/* Footer operator label */
.kbr-footer-operator { text-align: right; font-size: 0.72rem; color: rgba(255,255,255,0.45) !important; letter-spacing: 0.06em; margin-top: 1rem; }
.kbr-footer-operator a { color: rgba(255,255,255,0.6) !important; text-decoration: underline; }

/* ===== SIDEBAR & WIDGET 完全非表示 (高 specificity) ===== */
body .l-sidebar,
body aside#sidebar,
body #sidebar,
html body .l-sidebar { display: none !important; visibility: hidden !important; width: 0 !important; }
body .l-content { display: block !important; }
body .l-mainContent, body article.post {
    width: 100% !important; max-width: 100% !important; flex: 1 1 100% !important; flex-basis: 100% !important;
}
body.home .l-content, body.page .l-content {
    padding-top: 0 !important; padding-bottom: 0 !important;
    padding-left: 0 !important; padding-right: 0 !important;
    max-width: 100% !important;
}
body.home .l-mainContent__inner, body.page .l-mainContent__inner {
    padding: 0 !important; max-width: 100% !important;
}
body.home article.post, body.page article.post,
body.home .post_content, body.page .post_content {
    padding: 0 !important; margin: 0 !important; background: transparent !important; max-width: 100% !important;
}
body.home .post_content > p:empty, body.page .post_content > p:empty {
    display: none !important;
}

/* wpautop で生成された空 `<p>` を消す */
body.home .entry-content > p:empty, body.page .entry-content > p:empty { display: none !important; }

/* p-mainVisual 強制 OFF（再発防止） */
.p-mainVisual, .p-mainVisual__inner, #mainvisual, .l-mainVisualArea, .l-topImage {
    display: none !important; height: 0 !important; min-height: 0 !important; visibility: hidden !important;
}

/* SWELL 投稿スライダー（pickup banner / postSlider）も TOP上部から完全除去 — 5/18 user 指示 */
.p-postSlider,
.p-postSlider__inner,
.p-postSlider__swiper,
.p-pickupBanners,
.l-pickupBanners,
.p-pickupSlider {
    display: none !important;
    height: 0 !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    visibility: hidden !important;
}

/* スライダー fade up animation for hero */
@keyframes kbr-fade-up {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ===== 高 specificity Heading 上書き (SWELL h2 デフォルト完全粉砕) ===== */
html body .kbr-hero h1, html body .kbr-hero h2,
html body .kbr-hero h3,
html body .kbr-section h1, html body .kbr-section h2,
html body .kbr-section h3, html body .kbr-section h4,
html body .entry-content .kbr-h1,
html body .entry-content .kbr-h2,
html body .post_content .kbr-h1,
html body .post_content .kbr-h2,
html body h1.kbr-h1, html body h2.kbr-h2,
html body h3.kbr-pillar__title,
html body h2.kbr-products__title,
html body h2.kbr-about-section__heading {
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}
html body .kbr-hero h2, html body .kbr-hero h1,
html body .kbr-section:not(.kbr-section--dark):not(.kbr-story) h2,
html body .kbr-section:not(.kbr-section--dark):not(.kbr-story) h1,
html body .kbr-h2, html body .kbr-h1,
html body h3.kbr-pillar__title,
html body h2.kbr-products__title,
html body h2.kbr-about-section__heading {
    color: var(--color-text) !important;
}
html body .kbr-section--dark h1, html body .kbr-section--dark h2,
html body .kbr-section--dark h3, html body .kbr-section--dark h4,
html body .kbr-story h1, html body .kbr-story h2 {
    color: #ffffff !important;
}
/* ::before / ::after の SWELL装飾を完全に消す */
html body .kbr-section h1::before, html body .kbr-section h1::after,
html body .kbr-section h2::before, html body .kbr-section h2::after,
html body .kbr-section h3::before, html body .kbr-section h3::after,
html body .kbr-hero h1::before, html body .kbr-hero h1::after,
html body .kbr-hero h2::before, html body .kbr-hero h2::after,
html body .kbr-pillar h3::before, html body .kbr-pillar h3::after,
html body .kbr-products__title::before, html body .kbr-products__title::after,
html body .kbr-about-section__heading::before, html body .kbr-about-section__heading::after {
    content: none !important;
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    display: none !important;
}

/* ===== コンテンツ section の左右 padding（中央寄せ） ===== */
.kbr-section { padding-left: 4vw !important; padding-right: 4vw !important; }
.kbr-section__inner { max-width: 1100px; margin: 0 auto; }

/* WP 自動段落で発生する空 <p> の隙間を抑止 */
.entry-content > p:empty, .post_content > p:empty { display: none !important; }
.entry-content br, .post_content br { line-height: 0; }

/* ヘッダーロゴ表示位置と高さ（より大きく） */
.l-header__logo img { max-height: 36px !important; width: auto !important; }
.l-header { padding-top: 0; padding-bottom: 0; }
.l-header__inner { padding-top: 14px; padding-bottom: 14px; }

/* ヘッダー上部の小さい白いストリップ（free area）を隠す */
.l-header__top, .l-header__topRow,
.c-headBanner, .p-headBanner { display: none !important; }

/* 検索ボックスをヘッダーから消す（ブランド世界観優先） */
.l-header .c-iconBtn--search, .l-header .c-searchForm { display: none !important; }

/* ===== B1: ヘッダー上部の茶色帯（キャッチフレーズ + RSS + 検索）非表示 ===== */
.l-header__bar,
.l-header__barInner,
.c-catchphrase,
.c-iconList,
.l-header .c-iconList__item.-rss,
.l-header .c-iconList__item.-search {
    display: none !important;
    height: 0 !important;
    min-height: 0 !important;
    visibility: hidden !important;
}

/* ===== C5: PRODUCT CATEGORIES 2カードを中央寄せ ===== */
.kbv2-cat-grid {
    display: flex !important;
    justify-content: center;
    gap: clamp(20px, 3vw, 40px);
    flex-wrap: wrap;
    max-width: 980px;
    margin: 0 auto;
}
.kbv2-cat-grid > .kbv2-cat-card {
    flex: 0 1 360px;
    max-width: 400px;
    min-width: 260px;
}
@media (max-width: 768px) {
    .kbv2-cat-grid { gap: 16px; }
    .kbv2-cat-grid > .kbv2-cat-card { flex: 0 1 calc(50% - 8px); min-width: 0; }
}

/* ===== C1: BRAND 2カラム section（kbv2-brand） ===== */
.kbv2-brand { padding: clamp(80px, 11vw, 140px) 24px; }
.kbv2-brand__grid {
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: clamp(40px, 6vw, 90px);
    align-items: center;
    max-width: 1280px;
    margin: 0 auto;
}
@media (max-width: 840px) {
    .kbv2-brand__grid { grid-template-columns: 1fr; gap: 2.4rem; }
}
.kbv2-brand__media { position: relative; width: 100%; }
.kbv2-brand__img {
    width: 100%;
    aspect-ratio: 4 / 5;
    background-size: cover;
    background-position: center;
    border-radius: 2px;
    box-shadow: 0 22px 50px rgba(43, 34, 24, 0.10);
}
@media (max-width: 840px) {
    .kbv2-brand__img { aspect-ratio: 4 / 3; }
}
.kbv2-brand__body { padding: 1rem 0; }
.kbv2-brand__lead {
    font-size: clamp(1.0rem, 1.5vw, 1.18rem);
    color: var(--color-text);
    margin: 0 0 1.2rem;
    letter-spacing: 0.08em;
    line-height: 1.7;
}
.kbv2-brand__name {
    font-family: var(--font-serif-jp);
    font-weight: 500;
    font-size: clamp(2.6rem, 5.4vw, 4rem);
    letter-spacing: 0.16em;
    color: var(--color-text);
    margin: 0 0 2.4rem;
    line-height: 1;
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
}
.kbv2-brand__name::before, .kbv2-brand__name::after { content: none !important; }
/* ブランドロゴ画像差し替え (2026-05-21) — 半分サイズ・上下に余白
   SWELL の lazyload (width="1763" + .lazyaspectratio 100%) を抑える */
html body .kbv2-brand__body .kbv2-brand__name {
    line-height: 1 !important;
    margin: 1.4rem 0 1.6rem !important;
    font-size: 0 !important;
    max-width: 240px !important;
}
html body .kbv2-brand__body .kbv2-brand__name img.kbv2-brand__logo,
html body .kbv2-brand__body .kbv2-brand__name img.kbv2-brand__logo.lazyload,
html body .kbv2-brand__body .kbv2-brand__name img.kbv2-brand__logo.lazyaspectratio,
html body .kbv2-brand__body .kbv2-brand__name img.kbv2-brand__logo.lazyloaded {
    display: block !important;
    width: 100% !important;
    max-width: 240px !important;
    height: auto !important;
    margin: 0 !important;
    aspect-ratio: 1763 / 258;
}
@media (max-width: 768px) {
    html body .kbv2-brand__body .kbv2-brand__name {
        text-align: center !important;
        margin: 1.2rem auto 1.4rem !important;
        max-width: 165px !important;
    }
    html body .kbv2-brand__body .kbv2-brand__name img.kbv2-brand__logo {
        max-width: 165px !important;
        margin: 0 auto !important;
    }
}
.kbv2-brand__text { margin: 0 0 2.4rem; }
.kbv2-brand__text p {
    font-size: clamp(0.94rem, 1.2vw, 1.02rem);
    color: var(--color-text);
    margin: 0 0 0.4rem;
    letter-spacing: 0.06em;
    line-height: 2.0;
}
.kbv2-brand__text .kbv2-brand__final {
    margin-top: 1.6rem;
    color: var(--color-text);
    line-height: 2.0;
}
.kbv2-brand__btn {
    display: inline-block;
    padding: 12px 36px 12px 28px;
    border: 1px solid var(--color-text);
    color: var(--color-text) !important;
    background: transparent;
    border-radius: 999px;
    font-size: 0.86rem;
    letter-spacing: 0.16em;
    text-decoration: none;
    transition: all .25s ease;
}
.kbv2-brand__btn:hover { background: var(--color-text); color: #fff !important; }

/* ===== C4: PRODUCT サブメニュー サムネ画像 + 軽微な装飾 ===== */
/* dropdown 全体のソフトな影と幅 */
.c-gnav .sub-menu {
    box-shadow: 0 10px 24px rgba(43, 34, 24, 0.08) !important;
    min-width: 280px !important;
    border-radius: 3px;
}
.c-gnav .sub-menu .menu-item-244 > a,
.c-gnav .sub-menu .menu-item-245 > a {
    display: flex !important;
    align-items: center;
    padding: 0.7rem 1.2rem !important;
    min-height: 64px;
    transition: background-color .2s ease;
}
.c-gnav .sub-menu .menu-item-244 > a:hover,
.c-gnav .sub-menu .menu-item-245 > a:hover {
    background-color: rgba(232, 221, 200, 0.35);
}
/* 文字と画像の重なり解消: padding shorthand を高 specificity で上書き */
html body header.l-header .c-gnav .sub-menu .menu-item-244 > a,
html body header.l-header .c-gnav .sub-menu .menu-item-245 > a {
    padding: 0.7rem 1.2rem 0.7rem 88px !important;
    position: relative !important;
}
/* SWELL parent CSS が ::before を position:absolute にしているため
   left/top を明示してテキスト領域 (padding-left:88px の外) に固定する */
html body header.l-header .c-gnav .sub-menu .menu-item-244 > a::before,
html body header.l-header .c-gnav .sub-menu .menu-item-245 > a::before {
    content: "" !important;
    position: absolute !important;
    left: 1.2rem !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 50px !important;
    height: 50px !important;
    margin: 0 !important;
    background-size: cover !important;
    background-position: center !important;
    background-color: var(--color-accent);
    border-radius: 4px;
    border: 1px solid var(--color-border);
    flex-shrink: 0;
}
html body header.l-header .c-gnav .sub-menu .menu-item-244 > a::before {
    background-image: url('https://www.kapibaran.com/wp-content/uploads/2026/05/KB-FC01-BE_beige.jpg') !important;
}
html body header.l-header .c-gnav .sub-menu .menu-item-245 > a::before {
    background-image: url('https://www.kapibaran.com/wp-content/uploads/2026/05/KB-TM01-WH_white.jpg') !important;
}
/* SP では画像 ::before を隠して通常テキストリンクとして表示（タップしやすく） */
@media (max-width: 959px) {
    html body header.l-header .c-gnav .sub-menu .menu-item-244 > a,
    html body header.l-header .c-gnav .sub-menu .menu-item-245 > a {
        padding: 0.9rem 1.2rem !important;
        min-height: auto !important;
    }
    html body header.l-header .c-gnav .sub-menu .menu-item-244 > a::before,
    html body header.l-header .c-gnav .sub-menu .menu-item-245 > a::before {
        display: none !important;
    }
}

/* C-20 撤回完了 — ドロップダウンは SWELL デフォルトスタイルに戻す */

/* C-8 / C-9 / Hero __lead 上書きを撤回（CEO 設計に委ねる） — 2026-05-20 user 指示 */

/* 見出し統一 override 撤回（本日朝の CEO 設計に戻す） */

/* 商品カードの価格金額のみ font-size 半分に */
html body .kbv2-prod-card__price {
    font-size: 0.65rem !important;
}

/* ============================================================
   v2 デザインシステム (kbv2-*)  カンプ PC_01〜PC_10 準拠
   ============================================================ */

/* 共通レイアウト */
.kbv2-container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.kbv2-narrow { max-width: 760px; margin: 0 auto; }
.kbv2-text-center { text-align: center; }
.kbv2-sub { color: var(--color-text-sub); font-size: 0.86rem; }

/* セクション */
.kbv2-section {
    width: 100vw !important;
    position: relative; left: 50%; right: 50%;
    margin-left: -50vw !important; margin-right: -50vw !important;
    max-width: none !important;
    padding: clamp(64px, 9vw, 120px) 24px;
    background: var(--color-bg);
}
.kbv2-section--white { background: #FFFFFF; }
.kbv2-section--bg { background: var(--color-bg-alt); }
.kbv2-section--dark { background: #1B1612; color: #fff; }
.kbv2-section__head { text-align: center; margin: 0 auto 3rem; max-width: 760px; }

/* タイポグラフィ */
.kbv2-eyebrow {
    display: inline-block;
    font-family: var(--font-sans-en);
    font-size: 0.72rem; letter-spacing: 0.32em;
    color: var(--color-cta);
    text-transform: uppercase;
    margin-bottom: 1rem;
}
.kbv2-h1 {
    background: transparent !important; border: none !important; padding: 0 !important;
    font-family: var(--font-serif-jp);
    font-weight: 500;
    font-size: clamp(1.8rem, 4.6vw, 2.8rem);
    line-height: 1.4; letter-spacing: 0.06em;
    color: var(--color-text);
    margin: 0 0 1rem;
}
.kbv2-h1::before, .kbv2-h1::after { content: none !important; background: transparent !important; }
.kbv2-h1-en {
    background: transparent !important; border: none !important; padding: 0 !important;
    font-family: var(--font-serif-en);
    font-weight: 400; font-size: clamp(2.4rem, 5vw, 3.6rem);
    letter-spacing: 0.12em;
    color: var(--color-text);
    margin: 0 0 1rem;
}
.kbv2-h2 {
    background: transparent !important; border: none !important; padding: 0 !important;
    font-family: var(--font-serif-jp); font-weight: 500;
    font-size: clamp(1.4rem, 3.2vw, 2.0rem);
    line-height: 1.5; letter-spacing: 0.04em;
    color: var(--color-text);
    margin: 0 0 1rem;
}
.kbv2-h2::before, .kbv2-h2::after { content: none !important; background: transparent !important; }
.kbv2-h2-en {
    background: transparent !important; border: none !important; padding: 0 !important;
    font-family: var(--font-serif-en);
    font-weight: 400; font-size: clamp(1.8rem, 3.8vw, 2.6rem);
    letter-spacing: 0.10em;
    color: var(--color-text);
    margin: 0 0 1rem;
}
.kbv2-section--dark h2, .kbv2-section--dark h1, .kbv2-section--dark p { color: #fff; }
.kbv2-lead {
    font-size: clamp(0.94rem, 1.3vw, 1.05rem);
    line-height: 2;
    color: var(--color-text);
    max-width: 720px;
}
.kbv2-lead.kbv2-text-center { margin-left: auto; margin-right: auto; }

/* ===== CONCEPT セクション本文（About / 可読性チューニング 2026-05-21） ===== */
.kbv2-concept {
    max-width: 800px;
    margin: 56px auto 0;
    text-align: center;
    color: var(--color-text);
    font-family: var(--font-serif-jp);
    font-size: clamp(0.95rem, 1.25vw, 1.05rem);
    line-height: 2.0;
    letter-spacing: 0.04em;
}
.kbv2-concept__p {
    margin: 0 0 2.2em;
}
.kbv2-concept__p:last-child {
    margin-bottom: 0;
}
@media (max-width: 768px) {
    .kbv2-concept {
        max-width: 92%;
        margin-top: 36px;
        font-size: 0.95rem;
        line-height: 1.95;
        letter-spacing: 0.02em;
    }
    .kbv2-concept__p {
        margin-bottom: 1.8em;
    }
    /* SP では <br> を活かして読みやすく */
    .kbv2-concept__p br { display: inline; }
}

/* ===== Hero (PC_01) ===== */
.kbv2-hero {
    width: 100vw !important;
    position: relative; left: 50%; right: 50%;
    margin-left: -50vw !important; margin-right: -50vw !important;
    max-width: none !important;
    min-height: 78vh;
    display: flex; align-items: center; justify-content: center;
    background-size: cover; background-position: center;
    color: var(--color-text);
    overflow: hidden;
}
.kbv2-hero__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(255,255,255,0.0) 0%, rgba(244,241,236,0.25) 100%);
    z-index: 1;
}
.kbv2-hero--gradient {
    background-image: linear-gradient(135deg, #FAF7F2 0%, #E8DDC8 100%) !important;
}
.kbv2-hero__lead {
    color: var(--color-text-sub);
    font-size: clamp(0.92rem, 1.3vw, 1.04rem);
    line-height: 2;
    max-width: 540px;
    margin: 0 auto 2.4rem;
}
.kbv2-hero__inner {
    position: relative; z-index: 2;
    text-align: center;
    padding: 4rem 1.5rem;
    max-width: 880px;
    animation: kbr-fade-up 1.1s ease-out both;
}
.kbv2-hero__en {
    font-family: var(--font-serif-en);
    font-size: clamp(2.4rem, 6vw, 4.2rem);
    font-weight: 400; letter-spacing: 0.06em;
    color: var(--color-text);
    margin: 0 0 1rem;
}
.kbv2-hero__jp {
    font-family: var(--font-serif-jp);
    font-size: clamp(1.1rem, 2vw, 1.4rem);
    font-weight: 500; letter-spacing: 0.16em;
    color: var(--color-text);
    margin: 0 0 2.4rem;
}

/* ===== Buttons (kbv2) ===== */
.kbv2-btn {
    display: inline-block;
    padding: 16px 44px;
    border-radius: 2px;
    font-family: var(--font-sans-jp);
    font-weight: 500;
    letter-spacing: 0.18em;
    font-size: 0.88rem;
    text-decoration: none;
    transition: all .3s ease;
    cursor: pointer;
    border: 1px solid transparent;
}
.kbv2-btn--primary { background: var(--color-cta); color: #fff !important; border-color: var(--color-cta); }
.kbv2-btn--primary:hover { background: var(--color-cta-hover); transform: translateY(-1px); color: #fff !important; }
.kbv2-btn--ghost { background: transparent; color: var(--color-text) !important; border: 1px solid var(--color-text); }
.kbv2-btn--ghost:hover { background: var(--color-text); color: #fff !important; }

/* ===== Concept icon (svg) ===== */
.kbv2-concept__icon { margin: 0 auto 1.4rem; line-height: 0; }
.kbv2-concept .kbv2-h2 { margin-top: 0; }

/* ===== Product Categories grid ===== */
.kbv2-pcat__grid {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: clamp(16px, 2vw, 28px);
}
@media (max-width: 768px) { .kbv2-pcat__grid { grid-template-columns: repeat(2, 1fr); } }

/* .kbv2-cat-grid 中央寄せ override 撤回 — CEO のオリジナル grid 4列に戻す */
.kbv2-cat-card {
    display: block; background: #fff; border: 1px solid var(--color-border);
    border-radius: 4px; text-align: left;
    color: var(--color-text) !important; text-decoration: none;
    overflow: hidden;
    transition: transform .3s ease, box-shadow .3s ease;
}
.kbv2-cat-card:hover { transform: translateY(-4px); box-shadow: 0 18px 36px rgba(43,34,24,0.08); color: var(--color-text) !important; }
.kbv2-cat-card__img { padding-top: 100%; background-size: cover; background-position: center; background-color: var(--color-accent); }
.kbv2-cat-card__en  { font-family: var(--font-serif-en); font-size: 0.82rem; letter-spacing: 0.24em; color: var(--color-cta); margin: 1rem 1.2rem 0.2rem; }
.kbv2-cat-card__jp  { font-family: var(--font-serif-jp); font-size: 1.04rem; font-weight: 500; margin: 0 1.2rem 0.4rem; color: var(--color-text); }
.kbv2-cat-card__sub { font-size: 0.84rem; color: var(--color-text-sub); margin: 0 1.2rem 1.2rem; }

/* ===== New Arrivals grid ===== */
.kbv2-arrivals__grid {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: clamp(20px, 3vw, 36px);
}
@media (max-width: 768px) { .kbv2-arrivals__grid { grid-template-columns: 1fr; } }
.kbv2-prod-card {
    display: block; text-decoration: none; color: var(--color-text) !important;
    text-align: center;
    transition: transform .3s ease;
}
.kbv2-prod-card:hover { transform: translateY(-4px); color: var(--color-text) !important; }
.kbv2-prod-card__img { padding-top: 100%; background-size: cover; background-position: center; background-color: var(--color-accent); border-radius: 4px; margin-bottom: 1rem; }
.kbv2-prod-card__name { font-family: var(--font-serif-jp); font-size: 0.98rem; font-weight: 500; margin: 0 0 0.4rem; }
.kbv2-prod-card__price { font-family: var(--font-sans-en); font-size: 0.92rem; color: var(--color-text); margin: 0; letter-spacing: 0.04em; }

/* ===== Journal cards ===== */
.kbv2-journal__grid {
    display: grid; grid-template-columns: repeat(2, 1fr);
    gap: clamp(20px, 3vw, 36px);
}
.kbv2-journal__grid--3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 768px) {
    .kbv2-journal__grid, .kbv2-journal__grid--3 { grid-template-columns: 1fr; }
}
.kbv2-journal__card { display: block; text-decoration: none; color: var(--color-text) !important; background: #fff; border-radius: 4px; overflow: hidden; transition: transform .3s ease, box-shadow .3s ease; }
.kbv2-journal__card:hover { transform: translateY(-4px); box-shadow: 0 18px 36px rgba(43,34,24,0.08); color: var(--color-text) !important; }
.kbv2-journal__img { padding-top: 56.25%; background-size: cover; background-position: center; background-color: var(--color-accent); position: relative; }
.kbv2-journal__cat { position: absolute; top: 0.8rem; left: 0.8rem; background: rgba(255,255,255,0.9); padding: 0.25rem 0.7rem; font-size: 0.72rem; letter-spacing: 0.12em; color: var(--color-cta); border-radius: 2px; }
.kbv2-journal__body { padding: 1.2rem 1.4rem 1.6rem; }
.kbv2-journal__title { font-family: var(--font-serif-jp); font-size: 1rem; font-weight: 500; color: var(--color-text); margin: 0.4rem 0 0.4rem; line-height: 1.6; }
.kbv2-journal__date { font-family: var(--font-sans-en); font-size: 0.78rem; color: var(--color-text-sub); margin: 0; letter-spacing: 0.04em; }
.kbv2-journal__feature { display: grid; grid-template-columns: 1.1fr 1fr; gap: 0; align-items: center; background: #fff; border-radius: 4px; overflow: hidden; box-shadow: 0 12px 30px rgba(43,34,24,0.06); margin-bottom: 2rem; text-decoration: none; color: var(--color-text) !important; }
@media (max-width: 768px) { .kbv2-journal__feature { grid-template-columns: 1fr; } }
.kbv2-journal__feature-img { padding-top: 56.25%; background-size: cover; background-position: center; }
.kbv2-journal__feature-body { padding: 2.4rem 2.6rem; }
.kbv2-journal__hero { width: 100%; padding-top: 50%; background-size: cover; background-position: center; border-radius: 4px; margin-bottom: 2rem; }

/* ===== Page hero (sub pages) ===== */
.kbv2-page-hero {
    width: 100vw !important;
    position: relative; left: 50%; right: 50%;
    margin-left: -50vw !important; margin-right: -50vw !important;
    max-width: none !important;
    min-height: 36vh;
    display: flex; align-items: center; justify-content: center;
    background-size: cover; background-position: center;
    background-color: var(--color-accent);
    color: var(--color-text);
    text-align: center;
    overflow: hidden;
}
.kbv2-page-hero--small { min-height: 28vh; background-color: var(--color-bg-alt); }
.kbv2-page-hero__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(255,255,255,0.3), rgba(244,241,236,0.55)); z-index: 1; }
.kbv2-page-hero__inner { position: relative; z-index: 2; padding: 3rem 1.5rem; }
.kbv2-page-hero__title { margin: 0 0 0.6rem; }
.kbv2-page-hero__sub { font-family: var(--font-serif-jp); color: var(--color-text-sub); font-size: 0.96rem; letter-spacing: 0.16em; margin: 0; }

/* ===== About page ===== */
.kbv2-timeline { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.4rem; padding: 1rem 0; }
@media (max-width: 768px) { .kbv2-timeline { grid-template-columns: 1fr; } }
.kbv2-timeline__item { background: #fff; border: 1px solid var(--color-border); padding: 1.4rem 1.2rem; border-radius: 4px; text-align: center; }
.kbv2-timeline__year { display: block; font-family: var(--font-serif-en); color: var(--color-cta); letter-spacing: 0.2em; font-size: 0.92rem; }
.kbv2-timeline__txt { display: block; font-family: var(--font-serif-jp); margin-top: 0.4rem; }

/* ===== CRAFT — ものづくりのこと (2026-05-21) ===== */
.kbv2-craft .kbv2-h2 { margin-bottom: 1.1rem; }
.kbv2-craft__rule {
    display: block;
    width: 32px;
    height: 1px;
    background: var(--color-cta);
    opacity: 0.85;
    margin: 1.4rem auto 1.6rem;
}
.kbv2-craft__sub {
    font-family: var(--font-serif-jp);
    font-size: clamp(1.2rem, 2.2vw, 1.6rem);
    color: var(--color-text);
    letter-spacing: 0.08em;
    line-height: 1.7;
    margin: 0 0 1.4rem;
}
.kbv2-craft .kbv2-container.kbv2-narrow { max-width: 880px; }
.kbv2-craft__body {
    font-family: var(--font-serif-jp);
    font-size: clamp(0.92rem, 1.2vw, 1.0rem);
    color: var(--color-text);
    letter-spacing: 0.03em;
    line-height: 2.05;
    margin: 0 auto;
    max-width: 820px;
}
.kbv2-craft__close {
    font-family: var(--font-serif-jp);
    font-size: clamp(1.1rem, 1.9vw, 1.35rem);
    color: var(--color-text);
    letter-spacing: 0.08em;
    line-height: 1.7;
    margin: 2.4rem 0 0;
}
/* PC は <br> のみ改行 / SP は <br> + <br class="br-sp"> 両方改行 */
.kbv2-craft br.br-sp, .kbv2-br-sp { display: none; }
@media (max-width: 768px) {
    .kbv2-craft__rule { margin: 1.1rem auto 1.3rem; }
    .kbv2-craft__sub { letter-spacing: 0.04em; font-size: 1.18rem; }
    .kbv2-craft__body { letter-spacing: 0.02em; line-height: 1.95; font-size: 0.9rem; max-width: 100%; padding: 0 0.4rem; }
    .kbv2-craft__close { font-size: 1.05rem; letter-spacing: 0.04em; margin-top: 1.8rem; }
    .kbv2-craft br.br-sp, .kbv2-br-sp { display: inline; }
}

/* ===== HISTORY / ROADMAP — 8カード横並びタイムライン (2026-05-21) ===== */
/* この section だけ container 制約を外して横幅を広く取る */
.kbv2-history .kbv2-container { max-width: 1680px; }
.kbv2-history .kbv2-section__head { margin-bottom: 3.5rem; }
.kbv2-th-headrule {
    display: block;
    width: 42px;
    height: 1px;
    background: var(--color-cta);
    margin: 1.2rem auto 0;
}
.kbv2-th {
    position: relative;
    margin: 0 auto;
    max-width: 1680px;
    padding: 0 24px;
    box-sizing: border-box;
}
/* 矢印付き横レール (両端は dot 中心から少しはみ出す) */
.kbv2-th__rail {
    position: absolute;
    top: 7px;
    left: calc(24px + (100% - 48px) / 16 - 18px);   /* 1セル幅/2 - 18px (はみ出し分) */
    right: calc(24px + (100% - 48px) / 16 - 18px);
    height: 1px;
    z-index: 1;
}
.kbv2-th__line {
    position: absolute;
    inset: 0;
    background: var(--color-cta);
    opacity: 0.7;
}
.kbv2-th__arrow {
    position: absolute;
    top: 50%;
    width: 0; height: 0;
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    transform: translateY(-50%);
}
.kbv2-th__arrow--l { left: -1px; border-right: 10px solid var(--color-cta); }
.kbv2-th__arrow--r { right: -1px; border-left: 10px solid var(--color-cta); }

.kbv2-th__row {
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    gap: 0.7rem;
    position: relative;
}
.kbv2-th__cell {
    position: relative;
    padding-top: 50px;   /* dot + stem 分 */
}
.kbv2-th__dot {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 14px;
    height: 14px;
    border: 1.5px solid var(--color-cta);
    background: var(--color-bg);
    border-radius: 50%;
    z-index: 3;
    box-sizing: border-box;
}
/* ドットからカードへ降りる縦の細線 */
.kbv2-th__stem {
    position: absolute;
    top: 14px;
    left: 50%;
    transform: translateX(-50%);
    width: 1px;
    height: 36px;
    background: var(--color-cta);
    opacity: 0.55;
    z-index: 1;
}
.kbv2-th__card {
    background: #FAF7F2;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 1.4rem 0.7rem 1.4rem;
    text-align: center;
    min-height: 280px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
}
.kbv2-th__year {
    font-family: var(--font-serif-en);
    font-size: 1.7rem;
    font-weight: 400;
    color: var(--color-cta);
    letter-spacing: 0.04em;
    margin: 0 0 0.7rem;
    line-height: 1;
    display: flex;
    align-items: baseline;
    gap: 0.25em;
}
.kbv2-th__season {
    font-family: var(--font-serif-jp);
    font-size: 0.78rem;
    letter-spacing: 0.05em;
    color: var(--color-cta);
}
.kbv2-th__txt {
    font-family: var(--font-serif-jp);
    font-size: 0.86rem;
    line-height: 1.75;
    color: var(--color-text);
    margin: 0;
    letter-spacing: 0.02em;
}
.kbv2-th__sub {
    font-family: var(--font-serif-jp);
    font-size: 0.74rem;
    line-height: 1.7;
    color: var(--color-text-sub);
    margin: 0.5rem 0 0;
    letter-spacing: 0.02em;
}
.kbv2-th__rule {
    display: block;
    width: 22px;
    height: 1px;
    background: var(--color-cta);
    margin: 0.9rem auto 1rem;
    opacity: 0.7;
}
.kbv2-th__icon {
    color: var(--color-cta);
    width: 40px;
    height: 40px;
    margin-top: auto;
}
.kbv2-th__icon svg {
    width: 100%;
    height: 100%;
    display: block;
}

@media (max-width: 1200px) {
    .kbv2-th__row { grid-template-columns: repeat(4, 1fr); }
    .kbv2-th__rail { display: none; }
    .kbv2-th__cell { padding-top: 28px; }
    .kbv2-th__stem { display: none; }
}
@media (max-width: 768px) {
    .kbv2-history .kbv2-section__head { margin-bottom: 2.2rem; }
    .kbv2-th__row { grid-template-columns: 1fr; gap: 1rem; max-width: 360px; margin: 0 auto; }
    .kbv2-th__cell { padding-top: 24px; }
    .kbv2-th__card { min-height: auto; padding: 1.3rem 1rem 1.3rem; }
    .kbv2-th__year { font-size: 1.5rem; }
}
.kbv2-values { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.4rem; margin-top: 1rem; }
@media (max-width: 768px) { .kbv2-values { grid-template-columns: 1fr; gap: 1.2rem; } }
.kbv2-value {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    padding: 2.8rem 1.6rem 2.4rem;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.kbv2-value__symbol {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: var(--color-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 0 1.5rem;
}
.kbv2-value__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-cta);
    width: 32px;
    height: 32px;
}
.kbv2-value__icon svg {
    width: 100%;
    height: 100%;
    display: block;
}
.kbv2-value__no {
    font-family: var(--font-serif-en);
    font-size: 1.3rem;
    color: var(--color-text-sub);
    letter-spacing: 0.08em;
    margin: 0 0 0.6rem;
    line-height: 1;
}
.kbv2-value__title {
    font-family: var(--font-serif-jp);
    font-size: 1.18rem;
    color: var(--color-text);
    margin: 0 0 0.9rem;
    letter-spacing: 0.04em;
    line-height: 1.4;
    text-decoration: none !important;
    border: none !important;
    background: transparent !important;
    padding: 0 !important;
}
.kbv2-value__title::before, .kbv2-value__title::after { content: none !important; background: none !important; }
.kbv2-value__rule {
    display: block;
    width: 28px;
    height: 1px;
    background: var(--color-cta);
    margin: 0 auto 1.1rem;
    opacity: 0.7;
}
.kbv2-value__body {
    font-size: 0.9rem;
    color: var(--color-text-sub);
    line-height: 1.95;
    margin: 0;
    letter-spacing: 0.02em;
}
.kbv2-cta { background: var(--color-accent); padding: clamp(56px, 9vw, 90px) 24px; }

/* ===== Brand statement 2-column (MYTREX 風) ===== */
/* .kbv2-brand 2カラム section CSS 撤回（本日朝の状態に戻す） */

/* ===== Products list ===== */
.kbv2-plist__filters { display: flex; flex-wrap: wrap; gap: 0.6rem; justify-content: center; margin-bottom: 2.4rem; }
.kbv2-pill { background: transparent; border: 1px solid var(--color-border); color: var(--color-text); padding: 0.5rem 1.2rem; border-radius: 999px; cursor: pointer; font-size: 0.84rem; letter-spacing: 0.06em; }
.kbv2-pill:hover { border-color: var(--color-cta); color: var(--color-cta); }
.kbv2-pill--active { background: var(--color-accent); border-color: var(--color-accent); color: var(--color-cta); }
.kbv2-plist__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(16px, 2vw, 30px); }
@media (max-width: 768px) { .kbv2-plist__grid { grid-template-columns: repeat(2, 1fr); } }
.kbv2-plist__card { display: block; text-decoration: none; color: var(--color-text) !important; transition: transform .3s ease; }
.kbv2-plist__card:hover { transform: translateY(-3px); color: var(--color-text) !important; }
.kbv2-plist__img { padding-top: 100%; background-size: cover; background-position: center; background-color: var(--color-accent); position: relative; border-radius: 4px; margin-bottom: 0.7rem; }
.kbv2-plist__cat { position: absolute; top: 0.6rem; left: 0.6rem; background: rgba(255,255,255,0.92); padding: 0.2rem 0.6rem; font-size: 0.66rem; color: var(--color-cta); letter-spacing: 0.16em; border-radius: 2px; }
.kbv2-plist__name { font-family: var(--font-serif-jp); font-size: 0.92rem; margin: 0 0 0.2rem; }
.kbv2-plist__price { font-family: var(--font-sans-en); font-size: 0.88rem; color: var(--color-text); margin: 0; }

/* ===== Product detail ===== */
.kbv2-breadcrumb { font-size: 0.78rem; color: var(--color-text-sub); margin: 0 0 1.6rem; letter-spacing: 0.06em; }
.kbv2-pd__top { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; }
@media (max-width: 880px) { .kbv2-pd__top { grid-template-columns: 1fr; } }
.kbv2-pd__main { width: 100%; height: auto; border-radius: 4px; }
.kbv2-pd__cat { font-family: var(--font-serif-en); font-size: 0.78rem; letter-spacing: 0.24em; color: var(--color-cta); margin: 0 0 0.6rem; }
.kbv2-pd__model { font-size: 0.86rem; color: var(--color-text-sub); margin: 0.4rem 0 1.2rem; }
/* 価格 / メーカー希望小売価格 関連 override 撤回 — CEO設計に戻す */
.kbv2-pd__color-label { font-size: 0.82rem; color: var(--color-text-sub); margin: 0 0 0.4rem; }
.kbv2-pd__colors { display: flex; gap: 0.6rem; margin: 0 0 1.4rem; }
.kbv2-color-chip { display: inline-block; width: 22px; height: 22px; border-radius: 999px; border: 1px solid var(--color-border); }
.kbv2-pd__qty { display: flex; align-items: center; gap: 1rem; margin: 0 0 1.4rem; font-size: 0.86rem; }
.kbv2-qty-input { border: 1px solid var(--color-border); padding: 0.35rem 0.9rem; border-radius: 2px; }
.kbv2-pd__cart { width: 100%; display: block; text-align: center; }
html body .kbv2-pd__ec-btns { display: grid !important; grid-template-columns: repeat(3, 1fr) !important; gap: 0.8rem !important; margin: 1.2rem 0 !important; }
@media (max-width: 600px) { html body .kbv2-pd__ec-btns { grid-template-columns: 1fr !important; } }
/* EC buttons — logo card style */
html body .kbv2-ec-btn,
html body .kbv2-ec-btn--amazon,
html body .kbv2-ec-btn--rakuten,
html body .kbv2-ec-btn--yahoo {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 0.5rem !important;
    padding: 1.4rem 0.8rem 1.1rem !important;
    background: #fff !important;
    border: 1px solid var(--color-border) !important;
    border-radius: 10px !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05) !important;
    color: var(--color-text) !important;
    text-decoration: none !important;
    cursor: not-allowed !important;
    opacity: 0.82 !important;
    transition: box-shadow 0.2s !important;
}
/* EC logo area */
html body .kbv2-ec-btn .kbv3-ec-logo {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 38px !important;
    margin-bottom: 0.1rem !important;
}
/* "で見る" label */
html body .kbv2-ec-btn .kbv3-ec-label {
    font-family: var(--font-serif-jp) !important;
    font-size: 0.78rem !important;
    color: var(--color-text) !important;
    text-align: center !important;
    line-height: 1.4 !important;
}
/* circular arrow */
html body .kbv2-ec-btn .kbv3-ec-arrow {
    width: 28px !important;
    height: 28px !important;
    border-radius: 50% !important;
    background: var(--color-accent) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: var(--color-cta) !important;
    font-size: 0.9rem !important;
    margin-top: 0.3rem !important;
    flex-shrink: 0 !important;
}
.kbv2-pd__benefits { list-style: none; padding: 0; margin: 1.4rem 0 0; display: flex; gap: 1.5rem; flex-wrap: wrap; font-size: 0.8rem; color: var(--color-text-sub); }
.kbv2-feats { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1.5rem; margin: 2rem 0 0; }
@media (max-width: 768px) { .kbv2-feats { grid-template-columns: repeat(2, 1fr); } }
.kbv2-feat { text-align: center; padding: 1.2rem 0.6rem; background: #fff; border-radius: 4px; }
.kbv2-feat__icon { font-size: 1.8rem; color: var(--color-cta); margin-bottom: 0.6rem; }
.kbv2-feat__title { font-family: var(--font-serif-jp); font-size: 0.92rem; margin: 0 0 0.3rem; }
.kbv2-feat__sub { font-size: 0.76rem; color: var(--color-text-sub); margin: 0; }
.kbv2-spec { width: 100%; max-width: 720px; margin: 1.6rem auto 0; border-collapse: collapse; font-size: 0.9rem; }
.kbv2-spec th, .kbv2-spec td { padding: 0.8rem 1rem; border-bottom: 1px solid var(--color-border); text-align: left; }
.kbv2-spec th { font-family: var(--font-serif-jp); color: var(--color-text-sub); font-weight: 500; width: 30%; background: var(--color-bg-alt); }
.kbv2-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; margin-top: 1.6rem; }
@media (max-width: 768px) { .kbv2-steps { grid-template-columns: 1fr; } }
.kbv2-step { background: #fff; border-radius: 4px; padding: 1.6rem; text-align: center; }
.kbv2-step__no { display: inline-block; width: 28px; height: 28px; border-radius: 999px; background: var(--color-cta); color: #fff; line-height: 28px; font-family: var(--font-sans-en); margin-bottom: 0.6rem; }
.kbv2-step__title { font-family: var(--font-serif-jp); font-size: 1rem; margin: 0.4rem 0; }
.kbv2-step__body { font-size: 0.86rem; color: var(--color-text-sub); }
.kbv2-reviews { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; margin-top: 1.6rem; }
@media (max-width: 768px) { .kbv2-reviews { grid-template-columns: 1fr; } }
.kbv2-review { background: #fff; border: 1px solid var(--color-border); padding: 1.6rem; border-radius: 4px; }
.kbv2-review__stars { color: var(--color-cta); margin: 0 0 0.6rem; font-family: var(--font-sans-en); font-size: 0.86rem; }

/* kbv3 product gallery — img tag (object-fit:cover / full-bleed) */
.kbv3-pd__main-img { position: relative !important; width: 100% !important; aspect-ratio: 1 / 1 !important; border-radius: 16px !important; background-color: #f0ece6 !important; margin-bottom: 0.8rem !important; overflow: hidden !important; }
@media (max-width: 880px) { .kbv3-pd__main-img { aspect-ratio: 1 / 1 !important; border-radius: 12px !important; } }
.kbv3-pd__main-imgel { width: 100% !important; height: 100% !important; object-fit: cover !important; object-position: center !important; display: block !important; padding: 0 !important; border-radius: 0 !important; }
.kbv3-pd__thumbs { display: flex; gap: 0.6rem; }
.kbv3-pd__thumb { width: 80px; height: 80px; background-size: cover; background-position: center top; border-radius: 8px; border: 2px solid transparent; cursor: pointer; transition: border-color 0.18s; }
.kbv3-pd__thumb:hover, .kbv3-pd__thumb.kbv3-active { border-color: var(--color-cta); }
/* Color chip — large pill variant */
.kbv2-color-chip--lg { width: auto !important; height: auto !important; padding: 0.45rem 1.1rem; cursor: pointer; display: inline-flex !important; align-items: center; }
.kbv2-color-chip--lg::before { background: #fff !important; }
.kbv2-color-chip--lg .kbv2-color-chip__label { font-size: 0.82rem; font-weight: 500; color: #fff !important; background: transparent !important; }
.kbv2-color-chip--lg[title="アイボリー"] .kbv2-color-chip__label { color: var(--color-text) !important; background: transparent !important; }
.kbv2-color-chip.kbv3-active { outline: 2px solid var(--color-cta); outline-offset: 3px; }

/* ===== Contact / FAQ ===== */
.kbv2-contact__cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.4rem; max-width: 1000px; margin: 0 auto; }
@media (max-width: 768px) { .kbv2-contact__cards { grid-template-columns: 1fr; } }
.kbv2-contact__card { background: var(--color-accent); padding: 2rem 1.6rem; text-align: center; border-radius: 4px; }
.kbv2-contact__icon { font-family: var(--font-serif-en); font-size: 1.8rem; color: var(--color-cta); margin-bottom: 0.6rem; }
.kbv2-contact__title { font-family: var(--font-serif-jp); font-size: 1rem; margin: 0 0 0.6rem; }
.kbv2-contact__body { font-size: 0.86rem; color: var(--color-text); line-height: 1.8; margin: 0; }
.kbv2-link { color: var(--color-cta) !important; text-decoration: underline; }
.kbv2-faq { max-width: 820px; margin: 0 auto; }
.kbv2-faq__item { background: #fff; border: 1px solid var(--color-border); border-radius: 4px; margin: 0 0 0.8rem; padding: 1.2rem 1.4rem; }
.kbv2-faq__q { font-family: var(--font-serif-jp); cursor: pointer; list-style: none; outline: none; position: relative; padding-right: 2rem; color: var(--color-text); font-weight: 500; }
.kbv2-faq__q::-webkit-details-marker { display: none; }
.kbv2-faq__q::after { content: "+"; position: absolute; right: 0; top: 0; color: var(--color-cta); font-size: 1.4rem; }
.kbv2-faq__item[open] .kbv2-faq__q::after { content: "−"; }
.kbv2-faq__a { color: var(--color-text-sub); line-height: 1.95; margin: 0.8rem 0 0; }

.kbv2-form { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; max-width: 720px; margin: 0 auto; }
.kbv2-form__row { display: flex; flex-direction: column; }
.kbv2-form__row--full { grid-column: 1 / -1; }
.kbv2-form label { font-size: 0.82rem; color: var(--color-text-sub); margin-bottom: 0.4rem; letter-spacing: 0.06em; }
.kbv2-form label span { color: var(--color-cta); font-size: 0.74rem; margin-left: 0.4rem; }
.kbv2-form input, .kbv2-form select, .kbv2-form textarea {
    width: 100%; border: 1px solid var(--color-border); padding: 0.7rem 0.9rem; border-radius: 2px;
    font-family: var(--font-sans-jp); font-size: 0.94rem; background: #fff; color: var(--color-text);
}
.kbv2-form__notice { grid-column: 1 / -1; font-size: 0.84rem; color: var(--color-text-sub); margin: 0.6rem 0 0; }

/* ===== Legal pages ===== */
.kbv2-legal { width: 100%; border-collapse: collapse; }
.kbv2-legal th, .kbv2-legal td { padding: 1rem; border-bottom: 1px solid var(--color-border); text-align: left; vertical-align: top; font-size: 0.94rem; }
.kbv2-legal th { width: 32%; background: var(--color-bg-alt); font-family: var(--font-serif-jp); font-weight: 500; color: var(--color-text-sub); }
.kbv2-legal__h { font-family: var(--font-serif-jp); font-size: 1rem; color: var(--color-text); margin: 2rem 0 0.6rem; padding: 0; background: transparent !important; border: none !important; }
.kbv2-legal__p { line-height: 2; color: var(--color-text); margin: 0; }

/* ===== Article (Journal detail) ===== */
.kbv2-article { line-height: 2; color: var(--color-text); font-size: 1rem; }
.kbv2-article h2, .kbv2-article h3 { font-family: var(--font-serif-jp); color: var(--color-text); background: transparent !important; border: none !important; padding: 0 !important; }
.kbv2-article h2 { font-size: 1.4rem; margin: 2rem 0 0.8rem; }
.kbv2-article h3 { font-size: 1.15rem; margin: 1.5rem 0 0.6rem; }
.kbv2-article p { margin: 0 0 1.2rem; }

/* ===== フッターに SOLARWORKS 控えめ表示 (Day 7 で functions.php からも追加) ===== */
.l-footer .kbv2-operator-line {
    display: block; text-align: right; padding: 0.4rem 1.2rem 1rem;
    font-size: 0.7rem; color: rgba(255,255,255,0.4) !important;
    letter-spacing: 0.06em;
}
.l-footer .kbv2-operator-line a { color: rgba(255,255,255,0.55) !important; text-decoration: underline; }
