@charset "UTF-8";
/*
    Template: swell
    Theme Name: 岩国ホームページ制作工房
    Theme URI: https://iwakuni-hp.com/
    Description: 岩国ホームページ制作工房の自社サイト用カスタム子テーマ。SWELL を親テーマとして拡張。
    Version: 0.2.0
    Author: 岩国ホームページ制作工房
    Author URI: https://iwakuni-hp.com/
    Text Domain: iwakuni-hp

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/

/* =========================================================
   1. カラーパレット (CSS Variables)
   feel-design.jp 系の誠実なクリーンさ + ロゴカラー (#0c3960) 統一
   ========================================================= */
:root {
    --c-bg: #ffffff;
    --c-bg-soft: #f6f8fa;
    --c-bg-accent: #e9f0f5;
    --c-primary: #0c3960;          /* ロゴ・ボタン等のアクセント用 */
    --c-primary-light: #4283ad;
    --c-text-strong: #1a1a1a;      /* 見出し用の優しい黒(真っ黒ではない) */
    --c-text: #444444;             /* 本文用(feel-design.jp 系の柔らかい黒) */
    --c-text-sub: #666666;
    --c-border: #e0e0e0;
    --c-accent-warn: #d85656;

    /* アクセントカラー (ボタン・テーブルヘッダー・CTA 背景に使用) */
    --c-accent: #5A99B8;           /* 錦川ブルー */
    --c-accent-text: #ffffff;      /* アクセント上に乗せる文字色 */

    /* フォント
       ラテン文字は Inter、日本語は Noto Sans JP で表示される
       (両方とも functions.php で Google Fonts から読み込み) */
    --font-base: "Inter", "Noto Sans JP", "Hiragino Kaku Gothic ProN",
                 "Hiragino Sans", "Yu Gothic", "YuGothic", "Meiryo",
                 system-ui, -apple-system, sans-serif;

    --shadow-card: 0 2px 8px rgba(20, 20, 20, 0.06);
    --shadow-card-hover: 0 8px 24px rgba(20, 20, 20, 0.12);

    --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
}

/* =========================================================
   SWELL のデフォルト要素を整理
   - 告知バー(山口県岩国市の小規模事業者向け...)を非表示
   - 追従ヘッダー .l-fixHeader を非表示
   - パンくず .p-breadcrumb を非表示
   - SWELL のページタイトル .c-pageTitle を非表示(自前の .page-hero を使う)
   - 各種コンテナの top padding/margin を 0 に
   ========================================================= */
.l-header__bar,
.l-fixHeader,
[class*="l-fixHeader"],
#breadcrumb,
.p-breadcrumb,
.c-pageTitle,
.l-mainContent .c-pageTitle,
.p-articleThumb,
#post_slider,
.p-postSlider,
.l-header__customBtn,
.l-header [aria-label="検索ボタン"],
.l-header .c-iconBtn[data-onclick="toggleSearch"] {
    display: none !important;
}

html,
body,
.l-page,
#wrapper,
.l-content,
#content,
.l-container,
.l-mainContent,
.l-mainContent.l-article,
.l-mainContent__inner,
#main_content,
#contents,
main,
.post_content,
.l-mainContent > article,
.l-mainContent > div {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

/* alignfull が最初のセクションの時、上に隙間が出ないように */
.l-mainContent > *:first-child,
.l-content > *:first-child,
#contents > *:first-child,
.post_content > *:first-child,
.l-mainContent__inner > *:first-child,
.l-mainContent .alignfull:first-child,
.l-mainContent .alignfull:first-of-type {
    margin-top: 0 !important;
}

/* page-hero / hero-iwakuni が真上に来るよう強制 */
.hero-iwakuni,
.page-hero {
    margin-top: 0 !important;
}

/* =========================================================
   ヘッダー: 最上部は透過、スクロール後に白くする
   ========================================================= */
.l-header {
    position: fixed !important;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    z-index: 100;
    background-color: transparent !important;
    background-image: none !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    /* 戻り(白 → 透明): 0.4 秒で素早く */
    transition: background-color 0.4s ease, backdrop-filter 0.4s ease, box-shadow 0.4s ease;
}

.l-header.is-scrolled {
    background-color: rgba(255, 255, 255, 0.97) !important;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06) !important;
    backdrop-filter: blur(10px) !important;
    -webkit-backdrop-filter: blur(10px) !important;
    /* 白化(透明 → 白): 0.8 秒でゆっくり */
    transition: background-color 0.8s ease, backdrop-filter 0.8s ease, box-shadow 0.8s ease !important;
}

/* 文字色は常時 dark (白半透明バー上で読みやすい) */
.l-header .l-header__logo a,
.l-header .l-header__logo,
.l-header .c-gnav a,
.l-header .c-gnav .menu-item a {
    color: var(--c-text-strong) !important;
    text-shadow: none !important;
}

/* ロゴテキストに薄ベージュの角丸長方形背景 + アイコン左 + 上下中央
   ホームは <h1>、他ページは <div> で出力されるため、両方を強制統一 */
.l-header .l-header__inner .l-header__logo .c-headLogo,
.l-header .c-headLogo,
.l-header h1.c-headLogo,
.l-header div.c-headLogo {
    background-color: transparent !important;
    border-radius: 0 !important;
    padding: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    align-self: center !important;
    margin: auto 0 !important;
    gap: 0.65rem;
    box-sizing: border-box;
    line-height: 1.5 !important;
    font-size: 1.25rem !important;
    font-weight: 700 !important;
    letter-spacing: 0 !important;
    font-family: inherit !important;
    font-style: normal !important;
    font-feature-settings: normal !important;
    height: auto !important;
    max-height: none !important;
}

/* アイコンを文字の左に追加(大きめ) */
.l-header .c-headLogo::before {
    content: "";
    display: block;
    width: 108px;
    height: 108px;
    background-image: url('assets/img/iwakuni-hp-icon.png');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    flex-shrink: 0;
}

/* ヘッダーの内側コンテナを画面端まで広げる(ロゴを左端に寄せるため)
   右パディングは多めにしてメニューを少し左に寄せる */
.l-header .l-header__inner.l-container,
.l-header .l-header__inner {
    max-width: none !important;
    padding-left: 1.5rem !important;
    padding-right: 5rem !important;
    width: 100% !important;
}

/* =========================================================
   モバイル(<= 768px) でロゴサイズを縮小して 1 行に収める
   ========================================================= */
@media (max-width: 768px) {
    /* ロゴアイコンを縮小: 108px → 40px */
    .l-header .c-headLogo::before {
        width: 40px !important;
        height: 40px !important;
    }

    /* ロゴ文字サイズを縮小: 1.25rem → 0.85rem */
    .l-header .l-header__inner .l-header__logo .c-headLogo,
    .l-header .c-headLogo,
    .l-header h1.c-headLogo,
    .l-header div.c-headLogo {
        font-size: 0.85rem !important;
        gap: 0.4rem;
    }

    .l-header .c-headLogo .c-headLogo__link {
        font-size: 0.85rem !important;
    }

    /* スマホでは padding-right の 5rem は不要(ハンバーガーメニューだから) */
    .l-header .l-header__inner.l-container,
    .l-header .l-header__inner {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }
}

/* 内側のリンクには bg を付けない + 文字スタイル統一 */
.l-header .c-headLogo .c-headLogo__link,
.l-header h1.c-headLogo .c-headLogo__link,
.l-header div.c-headLogo .c-headLogo__link {
    background: none !important;
    padding: 0 !important;
    border-radius: 0 !important;
    font-size: 1.25rem !important;
    font-weight: 700 !important;
    letter-spacing: 0 !important;
    font-family: inherit !important;
    line-height: 1.5 !important;
    text-decoration: none !important;
}

/* ヘッダー内側を flex + center に強制 (告知バーは display:none を維持) */
.l-header .l-header__inner,
.l-header__inner {
    display: flex !important;
    align-items: center !important;
}

.l-header .l-header__inner .l-header__logo,
.l-header__logo {
    display: flex !important;
    align-items: center !important;
    align-self: center !important;
    margin: auto 0 !important;
}

/* ナビアイテム間の縦線区切り */
.c-gnav > .menu-item + .menu-item,
.l-header__gnav .menu-item + .menu-item {
    position: relative;
}

.c-gnav > .menu-item + .menu-item::before,
.l-header__gnav .menu-item + .menu-item::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: 1em;
    background-color: currentColor;
    opacity: 0.4;
}

/* パンくずナビは非表示 */
.p-breadcrumb {
    display: none !important;
}

/* =========================================================
   アクセント色の適用 (インライン navy #0c3960 を上書き)
   ========================================================= */
.wp-block-button__link {
    background-color: var(--c-accent) !important;
    color: var(--c-accent-text) !important;
    border-color: var(--c-accent) !important;
}

.wp-block-button.is-style-outline .wp-block-button__link {
    background-color: transparent !important;
    color: var(--c-accent) !important;
    border-color: var(--c-accent) !important;
}

/* section-primary 内の通常ボタン(白背景 + accent 文字) */
.section-primary .wp-block-button:not(.is-style-outline) .wp-block-button__link {
    background-color: var(--c-accent-text) !important;
    color: var(--c-accent) !important;
    border-color: var(--c-accent-text) !important;
}

/* section-primary 内のアウトラインボタン */
.section-primary .wp-block-button.is-style-outline .wp-block-button__link {
    background-color: transparent !important;
    color: var(--c-accent-text) !important;
    border-color: var(--c-accent-text) !important;
}

/* テーブルヘッダー */
.wp-block-table th {
    background-color: var(--c-accent) !important;
    color: var(--c-accent-text) !important;
}

/* section-primary (CTA 背景) */
.section-primary {
    background-color: var(--c-accent) !important;
}

.section-primary,
.section-primary p,
.section-primary h2,
.section-primary h3,
.section-primary .section-eyebrow,
.section-primary .section-title {
    color: var(--c-accent-text) !important;
}

/* =========================================================
   2. ベースタイポグラフィ
   ========================================================= */
body,
.l-page,
.swell-block-button a,
button,
input,
select,
textarea {
    font-family: var(--font-base) !important;
}

body {
    color: var(--c-text);
    line-height: 1.8;
    /* 日本語の約物・かなを自然に詰めて上品な字面に (高級感の決め手) */
    font-feature-settings: "palt" 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

h1, h2, h3, h4 {
    letter-spacing: 0.02em;
    line-height: 1.5;
}

/* =========================================================
   日本語の改行を「文節単位」に(単語の途中での改行を防止)
   - word-break: auto-phrase … 形態素解析で文節境界に改行する。
     「ホームページを制作」が「ホームペー↵ジを制作」のように
     途中で割れず、「ホームページを↵制作」と自然に折り返す。
   - word-break は継承プロパティなので本文コンテナに当てれば全文に波及。
   - 未対応ブラウザ(現時点の Firefox 等)は normal にフォールバック=現状維持で安全。
   - テーブル(td/th)は SWELL の break-all を維持(狭いセルの溢れ防止)。
   ========================================================= */
.l-mainContent,
.hero-iwakuni,
.page-hero,
.l-footer,
.swell-block-fullWideContents {
    word-break: auto-phrase;
}

/* =========================================================
   SWELL のデフォルト見出し装飾をリセット
   (h2 の navy 帯背景、h3 の下線などを解除して子テーマで再構築)
   ========================================================= */
.l-mainContent h2,
.post_content h2,
.entry-content h2 {
    background: none !important;
    background-color: transparent !important;
    border: none !important;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    color: var(--c-text-strong);
    font-weight: 700;
}

.l-mainContent h2::before,
.l-mainContent h2::after,
.post_content h2::before,
.post_content h2::after {
    display: none !important;
    content: none !important;
}

.l-mainContent h3,
.post_content h3,
.entry-content h3 {
    background: none !important;
    background-color: transparent !important;
    border: none !important;
    padding-left: 0 !important;
    color: var(--c-text-strong);
    border-bottom: 2px solid var(--c-primary-light);
    padding-bottom: 0.6rem !important;
    display: inline-block;
}

.l-mainContent h3::before,
.l-mainContent h3::after,
.post_content h3::before,
.post_content h3::after {
    display: none !important;
    content: none !important;
}

/* カード(.wp-block-column)内の h3 は別ルールで上書き */
.wp-block-columns .wp-block-column h3 {
    border-bottom: 3px solid var(--c-primary-light);
    padding-bottom: 0.5rem !important;
    margin-bottom: 1rem;
    display: inline-block;
}

/* =========================================================
   3. リンク・ボタンの統一感
   ========================================================= */
.wp-block-button__link {
    border-radius: 6px;
    transition: transform 0.3s var(--ease-out),
                box-shadow 0.3s var(--ease-out),
                background-color 0.3s var(--ease-out);
    font-weight: 600;
}

.wp-block-button__link:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-card-hover);
}

.wp-block-button.is-style-outline .wp-block-button__link {
    border-width: 2px;
}

/* =========================================================
   SWELL の標準ページタイトル(細い小見出し+下線)を非表示
   各ページの最上部は自前の .page-hero に置き換える
   ========================================================= */
.p-articleThumb,
.l-mainContent .p-pageTitle,
.l-mainContent .c-pageTitle,
.l-mainContent .p-pageHead,
.l-mainContent .post_title,
.l-mainContent .l-pageHead,
.l-mainContent .p-pageHead__title,
.l-mainContent .l-pageHead__title,
.p-breadcrumb {
    /* パンくずは残したいので別ルール */
}

.l-mainContent .post_title:not(.hero-title),
.l-mainContent .p-pageTitle,
.l-mainContent .c-pageTitle,
.p-articleThumb,
.l-mainContent .l-pageHead {
    display: none !important;
}

/* =========================================================
   .page-hero - 各下層ページの最上部に置く大型タイトル
   (home の .hero-iwakuni より一回り小さい)
   ========================================================= */
.page-hero {
    position: relative;
    /* top padding: 固定ヘッダー(~80px)をクリアするため大きめ */
    padding: clamp(7rem, 12vw, 10rem) 0 clamp(3rem, 6vw, 5rem) !important;
    background-color: var(--c-bg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    text-align: center;
    overflow: hidden;
}

/* テキスト可読性のための白オーバーレイ */
.page-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background-color: rgba(255, 255, 255, 0.78);
    pointer-events: none;
    z-index: 0;
}

.page-hero > * {
    position: relative;
    z-index: 1;
}

/* ページタイトルテキストを包む単一カード(透明 + blur すりガラス) */
.page-hero .page-hero-card {
    background-color: transparent !important;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-radius: 18px;
    padding: 2.25rem 2.5rem !important;
    width: fit-content !important;
    max-width: 100%;
    margin: 0 auto !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

.page-hero .page-hero-card > *:last-child {
    margin-bottom: 0 !important;
}

/* ページ別の背景写真 (錦帯橋を異なるアングルで) */
.page-hero--services {
    background-image: url('assets/img/hero/kintaikyo-3.jpg');
}

.page-hero--price {
    background-image: url('assets/img/hero/kintaikyo-4.jpg');
}

.page-hero--about {
    background-image: url('assets/img/hero/kintaikyo-5.jpg');
}

.page-hero--contact {
    background-image: url('assets/img/hero/kintaikyo-6.jpg');
}

.page-hero--works {
    background-image: url('assets/img/hero/kintaikyo-2.jpg');
}

.page-hero .page-hero-eyebrow {
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.3em !important;
    color: var(--c-primary-light) !important;
    margin: 0 auto 1rem !important;
    text-align: center !important;
    text-transform: uppercase;
}

.page-hero .page-hero-title {
    font-size: clamp(2.6rem, 6vw, 4.5rem) !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
    color: var(--c-text-strong) !important;
    letter-spacing: -0.01em !important;
    margin: 0 auto 2.25rem !important;
    /* SWELL のデフォルト装飾を解除 */
    background: none !important;
    border: none !important;
    padding: 0 !important;
    text-align: center !important;
    position: relative;
}

/* ページタイトル直下の装飾線 - 「これがページ全体のタイトル」を示すアクセント */
.page-hero .page-hero-title::after {
    content: "";
    display: block;
    width: 70px;
    height: 3px;
    background: var(--c-text-strong);
    margin: 1.5rem auto 0;
    border-radius: 2px;
}

.page-hero .page-hero-lead {
    font-size: clamp(1.05rem, 1.5vw, 1.15rem) !important;
    line-height: 2 !important;
    color: var(--c-text) !important;
    max-width: 720px;
    margin: 0 auto !important;
    font-weight: 500 !important;
    text-align: center !important;
}

/* ヒーローのフェードアップ */
.page-hero .page-hero-eyebrow,
.page-hero .page-hero-title,
.page-hero .page-hero-lead {
    opacity: 0;
    transform: translateY(30px);
    animation: hero-rise 1.1s var(--ease-out) forwards;
}

.page-hero .page-hero-eyebrow { animation-delay: 0.1s; }
.page-hero .page-hero-title   { animation-delay: 0.3s; }
.page-hero .page-hero-lead    { animation-delay: 0.55s; }

/* =========================================================
   .service-detail - サービスページの画像+テキスト 2 カラム
   (カードスタイルではない、ただの 2 カラム表示)
   ========================================================= */
.service-detail.wp-block-columns {
    align-items: center !important;
    margin-bottom: 4rem !important;
}

.service-detail.wp-block-columns .wp-block-column {
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    transition: none !important;
}

.service-detail.wp-block-columns .wp-block-column:hover {
    transform: none;
    box-shadow: none;
}

.service-detail .wp-block-image {
    margin: 0 !important;
}

.service-detail .wp-block-image img {
    border-radius: 12px;
    width: 100%;
    height: auto;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    box-shadow: var(--shadow-card);
    transition: transform 0.6s var(--ease-out), box-shadow 0.6s var(--ease-out);
}

.service-detail:hover .wp-block-image img {
    transform: scale(1.02);
    box-shadow: var(--shadow-card-hover);
}

.service-detail h3 {
    font-size: 1.5rem !important;
    margin-top: 0 !important;
}

/* =========================================================
   4. ヒーローセクション (.hero-iwakuni)
   ========================================================= */
.hero-iwakuni {
    position: relative;
    /* top padding: 固定ヘッダー(~80px)をクリアするため大きめ
       bottom padding: 次セクションを画面下端から peek させるため控えめ */
    padding: clamp(7rem, 14vw, 11rem) clamp(1.25rem, 5vw, 3rem) clamp(3rem, 7vw, 4.5rem);
    background: var(--c-bg);
    overflow: hidden;
    /* peek テク: ヒーロー高さを 88vh に抑え、残り 12vh で次セクション(STRENGTH)が
       画面下端からチラ見えする。max-height で必ず収まるよう強制。 */
    min-height: 88vh;
    max-height: 92vh;
}

/* スライドショー(静的 HTML、100vw 幅で inner-container を突き破る)
   - inner-container の overflow: visible は SWELL のスタイル次第なので強制 */
.hero-iwakuni .wp-block-group__inner-container {
    position: static !important;
    overflow: visible !important;
}

.hero-iwakuni .hero-slideshow {
    position: absolute !important;
    top: 0 !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: 100vw !important;
    height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    max-width: none !important;
    z-index: 0 !important;
    overflow: hidden !important;
    pointer-events: none;
}

.hero-iwakuni .hero-slide {
    position: absolute !important;
    inset: 0 !important;
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    margin: 0 !important;
    padding: 0 !important;
    max-width: none !important;
    will-change: transform;
    opacity: 1;
    /* 単一スライド: Ken Burns 微動のみ(シネマグラフ風) */
    animation: hero-ken-burns 30s ease-in-out infinite alternate;
}

@keyframes hero-ken-burns {
    0%   { transform: scale(1) translate(0, 0); }
    100% { transform: scale(1.08) translate(-1%, -1%); }
}

/* テキスト可読性のための白オーバーレイ (同じく 100vw)
   左側を強めにグラデーション(テキスト読みやすく)、右側を弱めに(錦帯橋見せる) */
.hero-iwakuni .hero-overlay {
    position: absolute !important;
    top: 0 !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: 100vw !important;
    height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    max-width: none !important;
    background: linear-gradient(
        90deg,
        rgba(255, 255, 255, 0.78) 0%,
        rgba(255, 255, 255, 0.55) 50%,
        rgba(255, 255, 255, 0.35) 100%
    ) !important;
    z-index: 1 !important;
    pointer-events: none;
}

/* テキストコンテンツを最前面に (slideshow/overlay は除外) */
.hero-iwakuni .wp-block-group__inner-container > *:not(.hero-slideshow):not(.hero-overlay) {
    position: relative;
    z-index: 2;
}

@media (prefers-reduced-motion: reduce) {
    .hero-iwakuni .hero-slide {
        animation: none;
    }
    .hero-iwakuni .hero-slide:first-child {
        opacity: 1;
    }
}

/* eyebrow:横線装飾付きの編集スタイル */
.hero-iwakuni .hero-eyebrow {
    color: var(--c-primary);
    font-size: 0.85rem;
    font-weight: 700;
    letter-spacing: 0.3em;
    margin-bottom: 1.5rem !important;
    text-transform: uppercase;
    display: flex;
    align-items: center;
    gap: 1rem;
    text-align: left !important;
}

.hero-iwakuni .hero-eyebrow::before {
    content: "";
    display: inline-block;
    width: 48px;
    height: 2px;
    background: var(--c-accent);
    flex-shrink: 0;
}

/* タイトル:大型・左寄せ・行間タイト
   フォントサイズは「8 文字 × フォントサイズが card 幅以内」になるよう調整 */
.hero-iwakuni .hero-title {
    font-size: clamp(2.4rem, 7.5vw, 5.6rem) !important;
    line-height: 1.05 !important;
    letter-spacing: -0.03em;
    font-weight: 800;
    color: var(--c-text-strong);
    margin: 0 0 1.75rem !important;
    text-align: left !important;
    white-space: nowrap;
}

/* モバイルでは折り返し許可(画面狭いと 1 行に収まらないため) */
@media (max-width: 600px) {
    .hero-iwakuni .hero-title {
        white-space: normal;
    }
}

.hero-iwakuni .hero-subtitle {
    font-size: clamp(1.05rem, 1.6vw, 1.25rem);
    color: var(--c-text-strong);
    margin-bottom: 1.5rem !important;
    font-weight: 600;
    letter-spacing: 0.02em;
    line-height: 1.7;
    text-align: left !important;
    max-width: 600px;
}

.hero-iwakuni .hero-description {
    font-size: 0.98rem;
    line-height: 2;
    color: var(--c-text);
    margin-bottom: 2.5rem !important;
    max-width: 580px;
    text-align: left !important;
}

/* ヒーローテキスト群 - 編集スタイル(グラスカード廃止、左寄せ大型タイポ)
   2026 年トレンド:写真上に直接タイポを置く、奥行きとボリュームで語る */
.hero-iwakuni .hero-text-card {
    background-color: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    max-width: 900px;
    margin: 0 0 2.5rem 0 !important;
    box-shadow: none !important;
    text-align: left !important;
}

.hero-iwakuni .hero-text-card > * {
    text-align: left !important;
}

.hero-iwakuni .hero-text-card > *:last-child {
    margin-bottom: 0 !important;
}

.hero-iwakuni .wp-block-buttons {
    margin-top: 0;
    justify-content: flex-start !important;
    gap: 1rem;
}

.hero-iwakuni .wp-block-button__link {
    padding: 1.05rem 2.4rem;
    font-size: 1.05rem;
    font-weight: 700;
}

/* スクロール誘導 - 二重シェブロン下向き (Awwwards 系の現代ミニマル)
   2 つの v 字を縦並びで stagger フェード + 微小下降。
   STRENGTH セクション冒頭の絶対配置で、ヒーロー直下の peek 領域に飛び出す。
   STRENGTH の柔らかい白背景上に置かれるため、drop-shadow は不要。 */
.hero-scroll-cue {
    position: absolute;
    top: clamp(1rem, 3vw, 1.6rem);
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
    pointer-events: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.6rem;
    color: var(--c-primary, #1a3a5f);
}

.hero-scroll-cue__chevrons {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 3px;
}

.hero-scroll-cue__chev {
    display: block;
    opacity: 0.3;
    animation: hero-chev-pulse 1.5s cubic-bezier(0.4, 0, 0.2, 1) infinite;
}

.hero-scroll-cue__chev:nth-child(2) {
    animation-delay: 0.25s;
}

.hero-scroll-cue__text {
    font-size: 0.62rem;
    letter-spacing: 0.32em;
    font-weight: 600;
    text-indent: 0.32em; /* letter-spacing 分の右ずれを補正 */
    color: var(--c-primary, #1a3a5f);
    opacity: 0.75;
}

@keyframes hero-chev-pulse {
    0%, 100% { opacity: 0.3; transform: translateY(0); }
    50%      { opacity: 1;   transform: translateY(3px); }
}

@media (prefers-reduced-motion: reduce) {
    .hero-scroll-cue__chev {
        animation: none;
        opacity: 0.7;
    }
}

/* =========================================================
   5. セクションブロック (フルワイド + 背景色)
   feel-design 風に、セクションごとに背景色を切り替えて
   区切り感とリズムを作る。
   ========================================================= */
.l-mainContent .alignfull,
.l-mainContent .alignwide {
    margin-top: 0;
    margin-bottom: 0;
}

.section-block {
    padding: clamp(4rem, 9vw, 7rem) 0 !important;
    position: relative;
}

/* セクション内の中身を強制的に 1220px(feel-design.jp と同じ) に拡張
   (SWELL の親要素が contentSize を上書きしているため、ここで強制)
   小画面で端まで貼り付くのを防ぐため inner 側に短いパディング */
.section-block.alignfull > .wp-block-group__inner-container,
.page-hero.alignfull > .wp-block-group__inner-container,
.hero-iwakuni.alignfull > .wp-block-group__inner-container {
    max-width: 1220px !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
    box-sizing: border-box;
}

.section-soft {
    background-color: var(--c-bg-soft);
}

.section-accent {
    background-color: var(--c-bg-accent);
}

/* .section-primary の bg/text はファイル上部で --c-accent を使うルールに統合済み */

/* セクション内の英語アイブロウ (ページタイトルより小さく) */
.section-eyebrow {
    text-align: center;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.22em;
    color: var(--c-primary-light) !important;
    margin: 0 0 0.5rem 0 !important;
    text-transform: uppercase;
}

/* セクション内のメインタイトル(日本語) - ページタイトルより明確に小さく */
.section-title {
    text-align: center;
    font-size: clamp(1.3rem, 2.4vw, 1.75rem) !important;
    margin: 0 auto 3rem !important;
    font-weight: 700;
    color: var(--c-text-strong);
    /* セクションタイトルには h3 と違って下線を付けない */
    border-bottom: none !important;
    padding-bottom: 0 !important;
    display: block !important;
}

/* セパレーターは背景色のリズムで区切るので消す */
.wp-block-separator {
    display: none !important;
}

/* セクション内のテキスト系コンテンツを中央寄せ
   (カード(wp-block-columns)を持つセクションは除外、カード内テキストは左寄せのまま) */
.section-block:not(:has(> .wp-block-group__inner-container > .wp-block-columns)) > .wp-block-group__inner-container {
    text-align: center !important;
}

/* SWELL のデフォルト CSS で h2 が左寄せされるため、強制的に中央寄せ */
.section-title,
h2.section-title,
.l-mainContent h2.section-title,
.l-mainContent .section-title,
.post_content h2.section-title,
.post_content .section-title,
.section-block .section-title {
    text-align: center !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* リストは「ブロックとして中央配置」で、中身は左寄せにすると行頭が揃ってきれい */
.section-block:not(:has(> .wp-block-group__inner-container > .wp-block-columns)) > .wp-block-group__inner-container > .wp-block-list {
    display: inline-block !important;
    text-align: left !important;
    margin: 0 auto !important;
    list-style-position: outside !important;
    padding-left: 1.5em !important;
    max-width: 720px;
}

/* テーブルが中身を持つセクションでテーブル自体は中央寄せされても中の文字は左に戻す */
.section-block > .wp-block-group__inner-container > .wp-block-table,
.section-block > .wp-block-group__inner-container > .wp-block-table table {
    text-align: left;
}

/* =========================================================
   6. カード (3 つの強み、サービスなど)
   ========================================================= */
.wp-block-columns .wp-block-column {
    padding: 2.5rem 1.75rem;
    background: var(--c-bg);
    border-radius: 14px;
    border: 1px solid var(--c-border);
    box-shadow: var(--shadow-card);
    transition: transform 0.4s var(--ease-out), box-shadow 0.4s var(--ease-out);
}

.wp-block-columns .wp-block-column:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-card-hover);
}

.wp-block-columns .wp-block-column h3 {
    margin-top: 0;
    font-size: 1.35rem !important;
    margin-bottom: 1.25rem !important;
}

/* =========================================================
   6.4. 「3 つの強み」カード - 大きな装飾数字 (01/02/03)
   ========================================================= */
.wp-block-columns.strength-cards {
    gap: 1.5rem !important;
    margin-top: 2rem;
}

.strength-card.wp-block-column {
    padding: 2.5rem 1.75rem 2rem !important;
    position: relative;
    overflow: hidden;
}

/* 大きな装飾数字 (01/02/03) */
.strength-card .strength-number {
    font-size: clamp(3rem, 5.5vw, 4.5rem) !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    color: var(--c-accent) !important;
    opacity: 0.5;
    letter-spacing: -0.03em;
    margin: 0 0 1.1rem !important;
    font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
    font-feature-settings: "tnum" 1, "lnum" 1;
    transition: opacity 0.4s var(--ease-out), transform 0.4s var(--ease-out), color 0.4s var(--ease-out);
}

.strength-card:hover .strength-number {
    opacity: 0.95;
    transform: translateY(-3px);
}

/* strength-card 内の h3 は下線を外す (数字が視覚アンカーになる) */
.wp-block-columns .strength-card.wp-block-column h3,
.wp-block-columns .strength-card.wp-block-column .wp-block-heading {
    border-bottom: none !important;
    padding-bottom: 0 !important;
    display: block !important;
    margin: 0 0 0.85rem !important;
    font-size: clamp(1.15rem, 1.6vw, 1.3rem) !important;
    font-weight: 700 !important;
    line-height: 1.5;
    color: var(--c-text-strong);
}

/* 強みカード内の説明文 */
.strength-card p:not(.strength-number) {
    font-size: 0.95rem;
    line-height: 1.85;
    color: var(--c-text);
    margin: 0 !important;
}

/* 画像付きサービスカード (.service-card-with-image をクラスに指定) */
.service-card-with-image {
    padding: 0 !important;
    overflow: hidden;
}

.service-card-with-image .wp-block-image {
    margin: 0 0 1rem 0 !important;
}

.service-card-with-image .wp-block-image img {
    width: 100%;
    height: 160px;
    object-fit: cover;
    display: block;
    transition: transform 0.6s var(--ease-out);
}

.service-card-with-image:hover .wp-block-image img {
    transform: scale(1.04);
}

.service-card-with-image > *:not(.wp-block-image) {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
}

.service-card-with-image .wp-block-heading {
    padding-top: 1.25rem;
    font-size: 1.2rem !important;
    margin-top: 0 !important;
    margin-bottom: 0.6rem !important;
}

.service-card-with-image p {
    font-size: 0.95rem;
    line-height: 1.75;
    margin-bottom: 0.8rem !important;
}

.service-card-with-image .wp-block-list {
    padding-left: 1.2em;
    margin: 0;
}

.service-card-with-image .wp-block-list li {
    font-size: 0.88rem;
    line-height: 1.6;
    margin-bottom: 0.3rem;
}

.service-card-with-image > *:last-child {
    padding-bottom: 1.5rem !important;
}

/* リード段落 (各ページのイントロ) - もっと存在感を出す */
.is-style-lead {
    font-size: clamp(1.05rem, 1.6vw, 1.2rem) !important;
    line-height: 2 !important;
    color: var(--c-text) !important;
    font-weight: 500 !important;
    max-width: 720px;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* =========================================================
   6.5. お問い合わせフォーム (Contact Form 7) のスタイル
   ========================================================= */
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="url"],
.wpcf7-form input[type="number"],
.wpcf7-form input[type="date"],
.wpcf7-form textarea,
.wpcf7-form select {
    background-color: #ffffff !important;
    border: 1px solid var(--c-border) !important;
    border-radius: 6px !important;
    padding: 0.75rem 1rem !important;
    font-size: 1rem !important;
    width: 100%;
    box-sizing: border-box;
    transition: border-color 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out);
    font-family: inherit;
    color: var(--c-text);
}

.wpcf7-form input[type="text"]:focus,
.wpcf7-form input[type="email"]:focus,
.wpcf7-form input[type="tel"]:focus,
.wpcf7-form textarea:focus,
.wpcf7-form select:focus {
    outline: none !important;
    border-color: var(--c-primary) !important;
    box-shadow: 0 0 0 3px rgba(12, 57, 96, 0.12) !important;
}

.wpcf7-form textarea {
    min-height: 140px;
    resize: vertical;
}

.wpcf7-form label {
    display: block;
    margin-bottom: 1.25rem;
    font-weight: 600;
    color: var(--c-text);
    line-height: 1.6;
}

.wpcf7-form .required {
    display: inline-block;
    background: var(--c-accent-warn);
    color: #fff !important;
    font-size: 0.7rem;
    font-weight: 600;
    padding: 0.15em 0.5em;
    border-radius: 3px;
    margin-left: 0.5em;
    vertical-align: middle;
}

.wpcf7-form p {
    margin: 0 0 0.5rem 0;
    font-weight: 600;
    color: var(--c-text);
}

.wpcf7-form input[type="radio"],
.wpcf7-form input[type="checkbox"] {
    width: auto !important;
    margin-right: 0.4em;
    accent-color: var(--c-primary);
}

.wpcf7-form .wpcf7-list-item {
    display: inline-block;
    margin: 0 1em 0.5em 0;
}

.wpcf7-form .wpcf7-list-item label {
    font-weight: 400;
    margin-bottom: 0;
    cursor: pointer;
}

.wpcf7-form .privacy-consent {
    margin-top: 1.5rem;
    padding: 1rem;
    background: var(--c-bg-soft);
    border-radius: 6px;
    font-size: 0.9rem;
}

.wpcf7-form input[type="submit"],
.wpcf7-form button[type="submit"] {
    background: var(--c-primary) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 6px !important;
    padding: 0.95rem 3rem !important;
    font-size: 1.25rem !important;
    font-weight: 600 !important;
    cursor: pointer;
    transition: transform 0.3s var(--ease-out), box-shadow 0.3s var(--ease-out);
    margin-top: 1.5rem;
    display: inline-block;
    width: auto;
}

.wpcf7-form input[type="submit"]:hover,
.wpcf7-form button[type="submit"]:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-card-hover);
}

.wpcf7-form .wpcf7-spinner {
    margin-left: 1rem;
}

/* =========================================================
   7. 料金テーブル
   ========================================================= */
.wp-block-table table {
    border-collapse: separate;
    border-spacing: 0;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: var(--shadow-card);
    border: 1px solid var(--c-border);
    background: var(--c-bg);
}

.wp-block-table th {
    /* bg と color はファイル上部で --c-accent を使うルールに統合済み */
    font-weight: 600;
    padding: 1rem 1.25rem;
    border: none;
    text-align: left;
}

.wp-block-table td {
    padding: 1rem 1.25rem;
    border-top: 1px solid var(--c-border);
    border-left: none;
    border-right: none;
    border-bottom: none;
}

.wp-block-table tbody tr:nth-child(even) {
    background: var(--c-bg-soft);
}

/* =========================================================
   7.5. FAQ アコーディオン (.faq-item)
   ブログ記事内の <details class="faq-item"> 用
   ========================================================= */
.wp-block-details.faq-item,
details.faq-item {
    border: 1px solid var(--c-border);
    border-radius: 10px;
    padding: 1.1rem 1.4rem;
    margin: 0 0 0.75rem !important;
    background: var(--c-bg);
    transition: box-shadow 0.3s var(--ease-out), border-color 0.3s var(--ease-out);
}

.wp-block-details.faq-item:hover,
details.faq-item:hover {
    border-color: var(--c-accent);
}

.wp-block-details.faq-item[open],
details.faq-item[open] {
    box-shadow: var(--shadow-card);
    border-color: var(--c-accent);
}

.wp-block-details.faq-item summary,
details.faq-item summary {
    font-weight: 600 !important;
    color: var(--c-text-strong) !important;
    cursor: pointer;
    list-style: none;
    padding-right: 2rem;
    position: relative;
    line-height: 1.6;
    font-size: 1rem;
}

/* デフォルトの三角形マーカーを消す (Chrome / Safari) */
.wp-block-details.faq-item summary::-webkit-details-marker,
details.faq-item summary::-webkit-details-marker {
    display: none;
}

/* Firefox 用 */
.wp-block-details.faq-item summary::marker,
details.faq-item summary::marker {
    content: none;
    display: none;
}

/* + / − インジケーター */
.wp-block-details.faq-item summary::after,
details.faq-item summary::after {
    content: "+";
    position: absolute;
    right: 0.25rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.4rem;
    line-height: 1;
    color: var(--c-accent);
    font-weight: 400;
    transition: transform 0.25s var(--ease-out);
}

.wp-block-details.faq-item[open] summary::after,
details.faq-item[open] summary::after {
    content: "−";
}

.wp-block-details.faq-item p,
details.faq-item p {
    margin: 0.85rem 0 0 !important;
    line-height: 1.9;
    color: var(--c-text);
    font-size: 0.96rem;
}

/* =========================================================
   7.6. ブログ記事(single post)のレイアウト
   ========================================================= */

/* 投稿・カテゴリ・タグ・アーカイブ各ページのトップに
   固定ヘッダー分(~80px)の余白を確保
   (ホーム・固定ページは .hero-iwakuni / .page-hero が上部余白を担うため除外)

   重要: SWELL は <body> に class を付けず、内部の <div id="body_wrap"> に
   wp-singular / single-post / home などの WordPress クラスを付ける。
   そのため `body.single-post X` は 一切マッチしない。
   ここでは `.single-post X` (class 単体) で対応する。

   既存の override 規則は `#content` (1,0,0) で当たるので、
   こちらは `.single-post #content.l-content` で (1,2,0) → 上書き成功。 */
.single-post #content.l-content,
.archive #content.l-content,
.blog #content.l-content,
.search #content.l-content,
.error404 #content.l-content {
    padding-top: clamp(6rem, 10vw, 7.5rem) !important;
}


/* 投稿ヘッダー(タイトル・日付・カテゴリ)の見た目を整える */
.single-post .p-articleHead.c-postTitle {
    margin-bottom: 2rem;
}

.single-post .c-postTitle__ttl {
    font-size: clamp(1.5rem, 3vw, 2.1rem) !important;
    line-height: 1.5 !important;
    font-weight: 700 !important;
    color: var(--c-text-strong) !important;
    margin-bottom: 1rem !important;
    letter-spacing: -0.005em;
}

.single-post .post_content h2,
.single-post .entry-content h2 {
    margin-top: 3rem !important;
    margin-bottom: 1.25rem !important;
    padding-bottom: 0.5rem !important;
    border-bottom: 2px solid var(--c-accent) !important;
    font-size: clamp(1.3rem, 2.2vw, 1.6rem) !important;
}

.single-post .post_content h3,
.single-post .entry-content h3 {
    margin-top: 2.25rem !important;
    margin-bottom: 0.85rem !important;
    font-size: clamp(1.1rem, 1.8vw, 1.25rem) !important;
}

.single-post .post_content p,
.single-post .entry-content p {
    line-height: 1.95;
    margin-bottom: 1.25rem;
}

/* ブログ記事内のテーブルは横スクロール可 */
.single-post .post_content .wp-block-table,
.single-post .entry-content .wp-block-table {
    overflow-x: auto;
}

/* 記事冒頭の .is-style-lead を目立たせる */
.single-post .post_content p.is-style-lead,
.single-post .entry-content p.is-style-lead {
    padding: 1.5rem 1.75rem;
    background: var(--c-bg-soft);
    border-left: 4px solid var(--c-accent);
    border-radius: 0 8px 8px 0;
    margin-bottom: 2rem !important;
}

/* =========================================================
   7.7. 記事内コールアウト (.cta-callout)
   ブログ記事の本文に挟む「当工房のサービスへの導線」用
   ========================================================= */
.wp-block-group.cta-callout,
.cta-callout {
    background: var(--c-bg-accent) !important;
    border-left: 4px solid var(--c-accent) !important;
    padding: 1.5rem 1.75rem !important;
    border-radius: 0 10px 10px 0 !important;
    margin: 2rem 0 !important;
}

.cta-callout p {
    margin: 0.5rem 0 !important;
    line-height: 1.85;
    color: var(--c-text);
}

.cta-callout p:first-child {
    font-weight: 700 !important;
    color: var(--c-text-strong) !important;
    font-size: 1.05rem;
    margin-top: 0 !important;
}

.cta-callout p:last-child {
    margin-bottom: 0 !important;
}

.cta-callout a {
    color: var(--c-accent) !important;
    text-decoration: underline;
    font-weight: 600;
}

.cta-callout a:hover {
    opacity: 0.8;
}

/* =========================================================
   7.8. 料金プラン カード(GBP エントリー + HP 4 プラン)
   ========================================================= */

/* セクションラッパー */
.pricing-section {
    max-width: 1200px;
    margin: 0 auto;
}

/* エントリープラン(GBP) - バナー型カード */
.pricing-entry {
    background: var(--c-bg-soft);
    border: 2px solid var(--c-accent);
    border-radius: 14px;
    padding: 2rem 2.5rem;
    margin: 1rem auto 3rem;
    max-width: 900px;
    text-align: center;
    transition: box-shadow 0.3s var(--ease-out);
}

.pricing-entry:hover {
    box-shadow: var(--shadow-card-hover);
}

.pricing-entry__header {
    color: var(--c-accent);
    font-weight: 600;
    font-size: 0.95rem;
    margin: 0 0 0.5rem;
    letter-spacing: 0.05em;
}

.pricing-entry__plan {
    font-size: clamp(1.4rem, 2.2vw, 1.7rem) !important;
    font-weight: 800 !important;
    color: var(--c-text-strong) !important;
    margin: 0.5rem 0 0.75rem !important;
    border-bottom: none !important;
    padding-bottom: 0 !important;
    display: block !important;
    text-align: center !important;
}

.pricing-entry__price {
    font-size: clamp(1.1rem, 1.6vw, 1.3rem);
    color: var(--c-text-strong);
    font-weight: 700;
    margin: 0.5rem 0;
}

.pricing-entry__desc {
    color: var(--c-text);
    font-size: 0.95rem;
    margin: 0.5rem 0 1.5rem;
    line-height: 1.7;
}

.pricing-entry__cta {
    display: inline-block;
    background: var(--c-accent);
    color: #fff;
    padding: 0.85rem 2.5rem;
    border-radius: 8px;
    text-decoration: none;
    font-weight: 600;
    font-size: 1rem;
    transition: transform 0.3s var(--ease-out), background 0.3s var(--ease-out);
}

.pricing-entry__cta:hover {
    background: var(--c-primary);
    transform: translateY(-2px);
}

/* HP プランカード セクションタイトル */
.pricing-hp-title {
    text-align: center;
    font-size: 0.95rem;
    color: var(--c-text-sub);
    margin: 2.5rem 0 2rem;
    letter-spacing: 0.05em;
}

/* HP カード コンテナ */
.pricing-cards-hp {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    align-items: stretch;
    margin: 2rem 0;
}

@media (max-width: 1024px) {
    .pricing-cards-hp {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.25rem;
    }
}

@media (max-width: 600px) {
    .pricing-cards-hp {
        grid-template-columns: 1fr;
        gap: 1rem;
    }
}

/* 個別 HP カード */
.pricing-card-hp {
    background: var(--c-bg);
    border: 1px solid var(--c-border);
    border-radius: 14px;
    padding: 2rem 1.5rem;
    position: relative;
    display: flex;
    flex-direction: column;
    transition: transform 0.4s var(--ease-out), box-shadow 0.4s var(--ease-out);
}

.pricing-card-hp:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-card-hover);
}

/* 強調カード(ライト) */
.pricing-card-hp--highlight {
    background: linear-gradient(180deg, rgba(90, 153, 184, 0.06) 0%, var(--c-bg) 60%);
    border: 2px solid var(--c-accent);
    box-shadow: 0 8px 28px rgba(90, 153, 184, 0.15);
    transform: scale(1.04);
    z-index: 2;
}

.pricing-card-hp--highlight:hover {
    transform: scale(1.04) translateY(-4px);
}

@media (max-width: 1024px) {
    .pricing-card-hp--highlight {
        transform: none;
    }
    .pricing-card-hp--highlight:hover {
        transform: translateY(-4px);
    }
}

/* 一番人気リボン */
.pricing-card-hp__ribbon {
    position: absolute;
    top: -14px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--c-accent);
    color: #fff;
    padding: 0.35rem 1.1rem;
    border-radius: 999px;
    font-size: 0.8rem;
    font-weight: 700;
    white-space: nowrap;
    box-shadow: 0 2px 8px rgba(90, 153, 184, 0.25);
}

/* カード内タイトル */
.pricing-card-hp__title {
    font-size: clamp(1.2rem, 1.6vw, 1.4rem) !important;
    font-weight: 800 !important;
    color: var(--c-text-strong) !important;
    text-align: center !important;
    margin: 0 0 0.25rem !important;
    border-bottom: none !important;
    padding-bottom: 0 !important;
    display: block !important;
    line-height: 1.3 !important;
}

.pricing-card-hp__pages {
    text-align: center;
    font-size: 0.85rem;
    color: var(--c-text-sub);
    margin: 0 0 1.5rem;
    min-height: 2.4em;
    line-height: 1.4;
}

/* 価格表示 */
.pricing-card-hp__price-label,
.pricing-card-hp__monthly-label {
    text-align: center;
    font-size: 0.78rem;
    color: var(--c-text-sub);
    margin: 0;
    letter-spacing: 0.05em;
}

.pricing-card-hp__price {
    text-align: center;
    font-size: clamp(1.6rem, 2.2vw, 2rem);
    font-weight: 800;
    color: var(--c-text-strong);
    margin: 0 0 0.8rem;
    letter-spacing: -0.02em;
    line-height: 1.2;
}

.pricing-card-hp__monthly {
    text-align: center;
    font-size: clamp(1rem, 1.4vw, 1.2rem);
    font-weight: 700;
    color: var(--c-text-strong);
    margin: 0 0 1.5rem;
    line-height: 1.2;
}

/* 機能リスト */
.pricing-card-hp__features {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 1.5rem !important;
    flex-grow: 1;
}

.pricing-card-hp__features li {
    padding: 0.55rem 0 !important;
    font-size: 0.88rem !important;
    border-bottom: 1px dashed var(--c-border);
    line-height: 1.45;
}

.pricing-card-hp__features li:last-child {
    border-bottom: none;
}

.pricing-card-hp__features li.included {
    color: var(--c-text);
}

.pricing-card-hp__features li.included::before {
    content: "✓";
    color: var(--c-accent);
    font-weight: 700;
    margin-right: 0.4rem;
}

.pricing-card-hp__features li.not-included {
    color: var(--c-text-sub);
    opacity: 0.55;
}

.pricing-card-hp__features li.not-included::before {
    content: "×";
    color: var(--c-text-sub);
    margin-right: 0.4rem;
}

/* エンジニア対応バッジ */
.pricing-card-hp__engineer-badge {
    background: rgba(12, 57, 96, 0.06);
    border-radius: 8px;
    padding: 0.55rem 0.75rem;
    text-align: center;
    font-size: 0.8rem;
    color: var(--c-primary);
    font-weight: 600;
    margin: 0 0 1rem;
    line-height: 1.4;
}

/* CTA ボタン */
.pricing-card-hp__cta {
    display: block;
    text-align: center;
    padding: 0.85rem 1rem;
    border: 2px solid var(--c-accent);
    color: var(--c-accent);
    border-radius: 8px;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.95rem;
    background: transparent;
    transition: all 0.3s var(--ease-out);
}

.pricing-card-hp__cta:hover {
    background: var(--c-accent);
    color: #fff;
}

.pricing-card-hp--highlight .pricing-card-hp__cta {
    background: var(--c-accent);
    color: #fff;
}

.pricing-card-hp--highlight .pricing-card-hp__cta:hover {
    background: var(--c-primary);
    border-color: var(--c-primary);
}

/* 脚注 */
.pricing-footnote {
    margin: 2rem auto 0 !important;
    max-width: 900px;
    text-align: center;
    font-size: 0.88rem;
    color: var(--c-text-sub);
    line-height: 1.8;
    padding: 1rem;
    background: var(--c-bg-soft);
    border-radius: 8px;
    border-left: 3px solid var(--c-accent);
}

/* =========================================================
   7.9. 制作の流れ ステップカード(01-04 + 矢印)
   ========================================================= */

.process-cards {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2.5rem;
    margin: 2rem 0;
    position: relative;
}

@media (max-width: 1024px) {
    .process-cards {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem;
    }
}

@media (max-width: 600px) {
    .process-cards {
        grid-template-columns: 1fr;
        gap: 1.25rem;
    }
}

.process-card {
    background: var(--c-bg);
    border: 1px solid var(--c-border);
    border-radius: 14px;
    padding: 2rem 1.5rem;
    position: relative;
    transition: transform 0.4s var(--ease-out), box-shadow 0.4s var(--ease-out);
}

.process-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-card-hover);
}

/* 大きな数字(01-04) */
.process-card__number {
    font-size: clamp(2.5rem, 4vw, 3.5rem) !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    color: var(--c-accent) !important;
    opacity: 0.45;
    letter-spacing: -0.02em;
    margin: 0 0 1rem !important;
    font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
    transition: opacity 0.4s var(--ease-out), transform 0.4s var(--ease-out);
}

.process-card:hover .process-card__number {
    opacity: 0.9;
    transform: translateY(-2px);
}

.process-card__title {
    font-size: clamp(1.05rem, 1.4vw, 1.2rem) !important;
    font-weight: 700 !important;
    color: var(--c-text-strong) !important;
    margin: 0 0 0.75rem !important;
    line-height: 1.4 !important;
    border-bottom: none !important;
    padding-bottom: 0 !important;
    display: block !important;
}

.process-card__desc {
    font-size: 0.9rem;
    color: var(--c-text);
    line-height: 1.75;
    margin: 0 0 1.25rem !important;
}

.process-card__duration {
    display: inline-block;
    background: var(--c-bg-accent);
    color: var(--c-primary);
    font-size: 0.8rem;
    font-weight: 600;
    padding: 0.35rem 0.85rem;
    border-radius: 999px;
}

/* カード間の矢印(デスクトップのみ) */
.process-card:not(:last-child)::after {
    content: "→";
    position: absolute;
    right: -1.85rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.5rem;
    color: var(--c-accent);
    opacity: 0.6;
    z-index: 1;
    font-weight: 700;
}

@media (max-width: 1024px) {
    .process-card:not(:last-child)::after {
        display: none;
    }
}

/* =========================================================
   7.10. STORY セクション(錦帯橋背景 + 引用カード)
   ========================================================= */

.section-story.section-block {
    background: linear-gradient(rgba(255, 255, 255, 0.88), rgba(255, 255, 255, 0.88)),
                url('assets/img/hero/kintaikyo-5.jpg') !important;
    background-size: cover !important;
    background-position: center 30% !important;
    background-attachment: scroll !important;
    background-repeat: no-repeat !important;
}

.story-card {
    background: #fff;
    border-radius: 14px;
    padding: clamp(2rem, 4vw, 3.5rem) clamp(1.75rem, 3vw, 3rem);
    max-width: 720px;
    margin: 0 auto;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
    position: relative;
}

.story-card::before {
    content: "\201C";
    position: absolute;
    top: 0.5rem;
    left: 1.5rem;
    font-size: 5rem;
    color: var(--c-accent);
    opacity: 0.18;
    line-height: 1;
    font-family: Georgia, "Times New Roman", serif;
    font-weight: bold;
    z-index: 0;
}

.story-card::after {
    content: "\201D";
    position: absolute;
    bottom: 0.5rem;
    right: 1.5rem;
    font-size: 5rem;
    color: var(--c-accent);
    opacity: 0.18;
    line-height: 1;
    font-family: Georgia, "Times New Roman", serif;
    font-weight: bold;
    z-index: 0;
}

.story-card .story-paragraph {
    line-height: 2 !important;
    margin: 0 0 1.5rem !important;
    color: var(--c-text);
    position: relative;
    z-index: 1;
}

.story-card .story-paragraph--lead {
    font-size: clamp(1rem, 1.3vw, 1.1rem);
    font-weight: 500;
    color: var(--c-text-strong);
}

.story-signature {
    text-align: right;
    margin-top: 1.5rem !important;
    margin-bottom: 0 !important;
    font-size: 0.95rem;
    color: var(--c-text-sub);
    position: relative;
    z-index: 1;
    line-height: 1.6;
}

.story-signature__role {
    display: block;
    font-size: 0.8rem;
    margin-bottom: 0.2rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.story-signature__name {
    display: block;
    font-weight: 700;
    font-size: 1.05rem;
    color: var(--c-text-strong);
    letter-spacing: 0.02em;
}

/* =========================================================
   7.11. CONTACT セクション CTA 強化(電話 + 信頼指標)
   ========================================================= */

.cta-trust-bar {
    display: flex;
    justify-content: center;
    gap: 1.5rem 2rem;
    flex-wrap: wrap;
    margin: 1.5rem auto 2rem;
    color: rgba(255, 255, 255, 0.92);
    font-size: 0.92rem;
    font-weight: 500;
}

.cta-trust-item {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    white-space: nowrap;
}

.cta-trust-item::before {
    content: "✓";
    color: #fff;
    font-weight: 800;
    font-size: 1.05em;
}

.cta-buttons-row {
    display: flex;
    gap: 1.25rem;
    justify-content: center;
    flex-wrap: wrap;
    margin: 1.5rem 0 1rem;
}

.cta-button {
    background: #fff;
    color: var(--c-primary);
    padding: 1.1rem 2.2rem;
    border-radius: 10px;
    text-decoration: none;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    font-size: 1.05rem;
    transition: transform 0.3s var(--ease-out), box-shadow 0.3s var(--ease-out), background 0.3s var(--ease-out);
    min-width: 240px;
    justify-content: center;
    border: 2px solid #fff;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.cta-button:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.18);
}

.cta-button__icon {
    font-size: 1.2em;
}

.cta-button--phone {
    background: transparent;
    color: #fff;
}

.cta-button--phone:hover {
    background: #fff;
    color: var(--c-primary);
}

.cta-button--phone .cta-button__number {
    font-family: "Helvetica Neue", Arial, sans-serif;
    font-feature-settings: "tnum" 1;
    letter-spacing: 0.05em;
}

.cta-helper {
    text-align: center !important;
    color: rgba(255, 255, 255, 0.75);
    font-size: 0.88rem;
    margin: 1rem 0 0 !important;
    line-height: 1.6;
}

/* モバイル調整 */
@media (max-width: 600px) {
    .cta-trust-bar {
        gap: 0.5rem 1.25rem;
        font-size: 0.85rem;
    }
    .cta-buttons-row {
        flex-direction: column;
        align-items: center;
        gap: 0.85rem;
    }
    .cta-button {
        width: 100%;
        max-width: 320px;
    }
}

/* =========================================================
   7.12. ヒーロー追加演出(SVG ノイズ + マグネティック CTA + 矢印)
   ========================================================= */

/* SVG ノイズオーバーレイ - 印刷物のような温度感 */
.hero-iwakuni::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 5;
    opacity: 0.06;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
    background-size: 200px 200px;
    mix-blend-mode: overlay;
}

/* マグネティック CTA - カーソルに微妙に追従 */
.hero-iwakuni .wp-block-button__link {
    transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1),
                background-color 0.3s var(--ease-out),
                box-shadow 0.3s var(--ease-out) !important;
    transform: translate(var(--mag-x, 0), var(--mag-y, 0));
}

.hero-iwakuni .wp-block-button__link:hover {
    transform: translate(var(--mag-x, 0), calc(var(--mag-y, 0) - 2px));
    box-shadow: 0 8px 24px rgba(12, 57, 96, 0.18) !important;
}

/* メイン CTA(filled)に矢印 → を追加、hover でスライド */
.hero-iwakuni .wp-block-buttons .wp-block-button:not(.is-style-outline) .wp-block-button__link::after {
    content: " →";
    display: inline-block;
    transition: transform 0.3s var(--ease-out);
    margin-left: 0.4em;
    font-weight: 600;
}

.hero-iwakuni .wp-block-buttons .wp-block-button:not(.is-style-outline) .wp-block-button__link:hover::after {
    transform: translateX(6px);
}

/* prefers-reduced-motion 対応 */
@media (prefers-reduced-motion: reduce) {
    .hero-iwakuni .wp-block-button__link {
        transition: none !important;
        transform: none !important;
    }
}

/* =========================================================
   7.13. CSS Scroll-Driven Animations(2026 年最新技術)
   - animation-timeline: scroll() で JS なしのスクロール連動
   - Chrome 115+, Edge 115+, Safari 26+ 対応(Firefox は flag)
   - 非対応ブラウザは何も起きない(@supports で gracefully degrade)
   ========================================================= */

@supports (animation-timeline: scroll()) {

    /* ヒーローテキストカード - スクロールで奥に退いていく */
    .hero-iwakuni .hero-text-card {
        animation: hero-card-fade-scale linear both;
        animation-timeline: scroll(root);
        animation-range: 0 80vh;
    }

    @keyframes hero-card-fade-scale {
        from {
            transform: scale(1);
            opacity: 1;
        }
        to {
            transform: scale(0.92);
            opacity: 0.4;
        }
    }

    /* prefers-reduced-motion 尊重 */
    @media (prefers-reduced-motion: reduce) {
        .hero-iwakuni .hero-text-card {
            animation: none !important;
            transform: none !important;
        }
    }
}

/* =========================================================
   8. アニメーション (Intersection Observer 用)
   ========================================================= */
.fade-up {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 1s var(--ease-out), transform 1s var(--ease-out);
    will-change: opacity, transform;
}

.fade-up.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.fade-in {
    opacity: 0;
    transition: opacity 1.2s var(--ease-out);
}

.fade-in.is-visible {
    opacity: 1;
}

.stagger-parent .stagger-item {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.9s var(--ease-out), transform 0.9s var(--ease-out);
}

.stagger-parent.is-visible .stagger-item {
    opacity: 1;
    transform: translateY(0);
}

.stagger-parent.is-visible .stagger-item:nth-child(1) { transition-delay: 0.0s; }
.stagger-parent.is-visible .stagger-item:nth-child(2) { transition-delay: 0.15s; }
.stagger-parent.is-visible .stagger-item:nth-child(3) { transition-delay: 0.30s; }
.stagger-parent.is-visible .stagger-item:nth-child(4) { transition-delay: 0.45s; }
.stagger-parent.is-visible .stagger-item:nth-child(5) { transition-delay: 0.60s; }

/* ヒーローの初回ロード時のアニメ (タイトル以外) */
.hero-iwakuni .hero-eyebrow,
.hero-iwakuni .hero-subtitle,
.hero-iwakuni .hero-description,
.hero-iwakuni .wp-block-buttons {
    opacity: 0;
    transform: translateY(30px);
    animation: hero-rise 1.1s var(--ease-out) forwards;
}

.hero-iwakuni .hero-eyebrow      { animation-delay: 0.1s; }
.hero-iwakuni .hero-subtitle     { animation-delay: 0.85s; }
.hero-iwakuni .hero-description  { animation-delay: 1.05s; }
.hero-iwakuni .wp-block-buttons  { animation-delay: 1.25s; }

@keyframes hero-rise {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ヒーロータイトル専用: マスク + 1 文字ごとにせり上がる */
.hero-iwakuni .hero-title {
    visibility: hidden;
}

.hero-iwakuni .hero-title.is-split {
    visibility: visible;
}

.hero-title__mask {
    display: inline-block;
    overflow: hidden;
    vertical-align: bottom;
    line-height: 1.15;
}

.hero-title__char {
    display: inline-block;
    transform: translateY(110%);
    /* ease-out-back でバウンス感、上品な reveal */
    animation: char-rise 0.95s cubic-bezier(0.34, 1.56, 0.64, 1) both;
    animation-delay: calc(0.35s + var(--char-index, 0) * 0.07s);
    will-change: transform;
}

/* 句読点(「。」)は一拍遅らせて強調 */
.hero-title__char--punctuation {
    animation-delay: calc(0.35s + var(--char-index, 0) * 0.07s + 0.25s) !important;
}

@keyframes char-rise {
    to {
        transform: translateY(0);
    }
}

/* スクリーンリーダー用テキスト */
.sr-only {
    position: absolute !important;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

@media (prefers-reduced-motion: reduce) {
    .fade-up, .fade-in, .stagger-parent .stagger-item,
    .hero-iwakuni .hero-eyebrow,
    .hero-iwakuni .hero-title,
    .hero-iwakuni .hero-subtitle,
    .hero-iwakuni .hero-description,
    .hero-iwakuni .wp-block-buttons,
    .hero-title__char {
        opacity: 1;
        transform: none;
        animation: none;
        transition: none;
    }

    .hero-iwakuni .hero-title,
    .hero-iwakuni .hero-title.is-split {
        visibility: visible;
    }

}

/* =========================================================
   9. レスポンシブ調整
   ========================================================= */
@media (max-width: 768px) {
    .hero-iwakuni {
        padding-top: 4rem;
        padding-bottom: 3.5rem;
        /* SP では peek 強制を解除。コンテンツが入りきらないと切れるため。 */
        min-height: auto;
        max-height: none;
    }

    .hero-iwakuni::before {
        right: -30%;
        width: 100vw;
        height: 100vw;
    }

    .wp-block-columns .wp-block-column {
        padding: 1.5rem 1.25rem;
    }
}
