/* ====================================
   ヘッダーとナビゲーション
   ==================================== */
#header {
    background-color: #fff;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    padding: 15px 0;
    position: sticky; /* スクロールしても追従 */
    top: 0;
    z-index: 1000; /* 他の要素より手前に表示 */
}

.header-inner {
    display: flex;
    justify-content: flex-start;
    align-items: center;
}

/* ロゴ */
.site-logo {
    margin: 0;
    /* ロゴ画像のサイズを調整 */
    height: 30px;
}

.site-logo img {
    height: 100%;
    width: auto;
}

/* PC用グローバルナビゲーション */
.g-nav {
    margin-left: auto;
    margin-right: 50px;
}

.g-nav-list {
    display: flex;
    gap: 30px; /* メニュー間のスペース */
}

.g-nav-list a {
    color: #333;
    font-size: 16px;
    font-weight: 600;
    padding: 5px 0;
    position: relative;
    transition: color 0.3s ease;
}

.g-nav-list a::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0; /* 左端から開始 */
    width: 0; /* 初期状態では幅ゼロ */
    height: 2px; /* アンダーラインの太さ */
    background-color: #1a2a6c; /* アンダーラインの色 */
    transition: width 0.3s ease; /* 幅の変化をアニメーションさせる */
}

.g-nav-list a:hover::after {
    width: 100%; /* ホバー時に幅を100%にして左から右へ伸びる */
}

/* お問い合わせボタン (汎用ボタンクラスを使用) */
.btn {
    display: inline-block;
    margin: 0 10px;
    padding: 10px 30px; /* 横長にするため左右のパディングを増やす */
    border-radius: 50px; /* 完全に角を丸くする */
    text-align: center;
    text-decoration: none;
    font-weight: 700;
    /* ふわっとした変化のため、全ての変化にアニメーションを設定 */
    transition: all 0.3s ease;
    white-space: nowrap;
}

/* ホバー前 */
.btn--contact {
    background-color: #1a2a6c; /* 指定色 */
    color: #fff; /* テキストカラーは白 */
    border: 2px solid #1a2a6c; /* 枠線も同色にして、ホバー時の準備をする */
}

/* ホバー後 */
.btn--contact:hover {
    background-color: #fff; /* 背景を白に反転 */
    color: #1a2a6c; /* テキストカラーも反転色に */
    border: 2px solid #1a2a6c; /* 枠線は維持 */
}

/* ホバー前 */
.btn--consult {
    background-color: #b22222; /* 指定色 */
    color: #fff; /* テキストカラーは白 */
    border: 2px solid #b22222; /* 枠線も同色にして、ホバー時の準備をする */
}

/* ホバー後 */
.btn--consult:hover {
    background-color: #fff; /* 背景を白に反転 */
    color: #b22222; /* テキストカラーも反転色に */
    border: 2px solid #b22222; /* 枠線は維持 */
}

/* ハンバーガーボタンとスマホメニューは最初は非表示 */
.hamburger-btn,
.sp-nav {
    display: none;
}


/* ====================================
   レスポンシブデザイン (スマートフォン対応)
   ==================================== */
@media (max-width: 999px) {
    /* PC用メニューとボタンを非表示 */
    .g-nav,
    .contact-btn-wrapper {
        display: none;
    }

    /* ヘッダー内側の配置を修正: ロゴとハンバーガーボタンを両端に配置 */
    .header-inner {
        justify-content: space-between;
    }

    /* ロゴの右マージンを解除（両端配置のため不要に） */
    .site-logo {
        margin-right: 0;
    }

    /* ハンバーガーボタンを表示 */
    .hamburger-btn {
        display: block;
        width: 40px;
        height: 40px;
        background: none;
        border: none;
        cursor: pointer;
        position: relative;
        padding: 0;
        z-index: 1010;
        /* 右寄せのためマージンは調整不要 */
    }

    /* ハンバーガーボタンの線 (修正箇所) */
    .hamburger-btn span {
        display: block;
        height: 2px;
        background-color: #333;
        position: absolute;
        left: 0;
        width: 100%;
        transition: transform 0.3s ease, opacity 0.3s ease;
        /* 全ての線を縦軸中央に配置するための共通設定 */
        top: 50%;
        transform: translateY(-50%);
    }

    /* 修正: 線の初期位置を調整し、3本が均等に並ぶようにする */
    .hamburger-btn span:nth-child(1) {
        transform: translateY(-10px); /* 中央から上に10px移動 */
    }
    .hamburger-btn span:nth-child(2) {
        opacity: 1; /* 中央の線（通常時） */
    }
    .hamburger-btn span:nth-child(3) {
        transform: translateY(10px); /* 中央から下に10px移動 */
    }

    /* 「バツ」の形状 (is-active時の修正) */
    .hamburger-btn.is-active span:nth-child(1) {
        /* 中央に寄せた後、45度回転 */
        transform: translateY(0) rotate(45deg);
    }
    .hamburger-btn.is-active span:nth-child(2) {
        opacity: 0; /* 中央の線は非表示 */
    }
    .hamburger-btn.is-active span:nth-child(3) {
        /* 中央に寄せた後、-45度回転 */
        transform: translateY(0) rotate(-45deg);
    }

    /* スマホ用ドロワーメニュー */
    .sp-nav {
        display: block;
        position: fixed;
        top: 72px;
        right: 0;
        width: 80%;
        max-width: 350px;
        height: calc(100vh - 72px); /* 画面全体からヘッダー高さを引く */

        background-color: rgba(255, 255, 255, 0.95);
        box-shadow: -4px 0 8px rgba(0, 0, 0, 0.1);

        transform: translateX(100%);
        transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        z-index: 999;
        padding-top: 20px;
        overflow-y: auto;
    }

/* メニューオープン時のスタイル */
    .sp-nav.is-open {
        transform: translateX(0);
    }

    .sp-nav-list {
        padding: 0;
        margin: 0;
    }

    .sp-nav-list li {
        border-bottom: 1px solid #f0f0f0; /* 薄いグレーの区切り線 */
    }

    .sp-nav-list a {
        display: block;
        padding: 18px 30px;
        color: #333;
        font-size: 16px;
        font-weight: 600;
        text-align: left; /* 左寄せ */
        transition: background-color 0.2s ease;
    }

    .sp-nav-list a:hover:not(.btn--contact),
    .sp-nav-list a:focus:not(.btn--contact),
    .sp-nav-list a:hover:not(.btn--consult),
    .sp-nav-list a:focus:not(.btn--consult){
        background-color: #e6f0ff;
        color: #111;
    }

    .sp-nav-list a.btn--contact {
        display: block;
        width: 85%;
        margin: 0 auto 20px;
        padding: 10px 30px;
        text-align: center;
        color: #FFF;
    }
    .sp-nav-list a:hover.btn--contact {
        background: #FFF;
        color: #1a2a6c;
    }

    .sp-nav-list a.btn--consult {
        display: block;
        width: 85%;
        margin: 0 auto 20px;
        padding: 10px 30px;
        text-align: center;
        color: #FFF;
    }
    .sp-nav-list a:hover.btn--consult {
        background: #FFF;
        color: #b22222;
    }


    /* ボタン要素の親リストアイテムの境界線などを非表示 */
    .sp-nav-list li:has(> .btn--contact) { /* :has()が未対応の場合はli:last-childを使用 */
        border-bottom: none;
    }
}

.no-scroll {
    overflow: hidden;
}


/* ====================================
   キービジュアルセクション
   ==================================== */
.hero-kv {
    position: relative;
    width: 100%;
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    /* すべて左揃えに統一 */
    text-align: left;

    /* PC用背景画像 */
    background-image: url('img/kv_pc.jpg');
    background-size: cover;
    background-position: center;
    overflow: hidden;
}

/* 背景画像のオーバーレイ */
.hero-kv::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.2);
    z-index: 1;
}

.hero-kv__inner {
    position: relative;
    z-index: 2;
    padding: 20px;
    max-width: 1200px;
    width: 100%; /* 親要素の幅を使うことを保証 */
    margin-left: auto;
    margin-right: auto;
}

.hero-kv__main-catch {
    text-align: left;
    font-size: 72px; /* インパクト重視のサイズ */
    font-weight: bold;
    margin-bottom: 25px;
    line-height: 1.3;
    text-shadow: 2px 2px 6px rgba(0, 0, 0, 0.6);
}

.hero-kv__sub-text {
    text-align: left;
    font-size: 24px;
    margin-bottom: 50px;
    text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.5);
}

.hero-kv__buttons {
    display: flex;
    justify-content: flex-start; /* 左揃え */
    gap: 30px;
    flex-wrap: wrap;
    margin-left: 0;
    margin-right: auto;
    max-width: 700px;
}

/* プライマリボタン */
.btn--primary {
    background-color: #b22222; /* 修正: 指定された色 */
    color: #fff;
    border: 2px solid #b22222; /* 修正: 枠線も同色に */
    padding: 15px 40px;
    border-radius: 50px;
    font-size: 17px;
}

.btn--primary:hover {
    background-color: #8b0000;
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

/* セカンダリボタン */
.btn--secondary {
    background-color: #1a2a6c; /* 修正: 背景色を指定色にする */
    color: #fff;
    border: 2px solid #1a2a6c; /* 修正: 枠線を背景色と同じにする (ホバー時の反転用) */
    padding: 15px 40px;
    border-radius: 50px;
    font-size: 17px;
}

.btn--secondary:hover {
    background-color: #0f1840; /* 背景を濃い青に変化 */
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

/* ====================================
   アニメーションスタイル
   ==================================== */

/* フェードインアップアニメーションの定義 */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px); /* 下から30px移動してくる */
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* アニメーションを適用するクラス */
.animate-fade-in-up {
    opacity: 0; /* 初期状態は非表示 */
    animation: fadeInUp 0.8s ease-out forwards; /* 0.8秒でアニメーション */
}

/* アニメーションの遅延 */
.animate-fade-in-up.delay-1 {
    animation-delay: 0.3s; /* 0.3秒遅れて開始 */
}
.animate-fade-in-up.delay-2 {
    animation-delay: 0.6s; /* 0.6秒遅れて開始 */
}

/* ====================================
   レスポンシブデザイン (KV部分)
   ==================================== */

@media (max-width: 767px) {
    .hero-kv {
        height: 100vh;
        background-image: url('img/kv_sp.jpg');
        background-attachment: scroll;
    }

    .hero-kv__main-catch {
        font-size: 48px;
        margin-bottom: 20px;
        line-height: 1.4;
    }

    .hero-kv__sub-text {
        font-size: 18px;
        margin-bottom: 40px;
        padding: 0 15px;
    }

    .hero-kv__buttons {
        flex-direction: column;
        gap: 15px;
        width: 85%;
        margin: 0 auto;
        /* スマホではボタンを中央寄せにするのが一般的 */
        justify-content: center;
    }

    .btn--primary,
    .btn--secondary {
        width: 100%;
        box-sizing: border-box;
        padding: 14px 20px;
        font-size: 16px;
    }
}

@media (min-width: 768px) and (max-width: 1024px) {
    .hero-kv {
        height: 100vh;
    }
    .hero-kv__main-catch {
        font-size: 56px;
    }
    .hero-kv__sub-text {
        font-size: 20px;
    }
}

/* ====================================
   共通セクションスタイル
   ==================================== */
.section {
    padding: 100px 0; /* 上下に大きな余白 */
}

/* 左右分割グリッド */
.content-grid {
    display: grid;
    /* PCでは2カラム (40%と60%の比率) で配置 */
    grid-template-columns: 1fr 1fr;
    gap: 80px; /* 左右の隙間 */
    align-items: center; /* 縦方向の中央揃え */
}

.section-title {
    font-size: 38px;
    font-weight: 700;
    line-height: 1.4;
    color: #1a2a6c; /* メインカラーを適用 */
    margin-bottom: 30px;
    padding-bottom: 15px;
    position: relative;
}

.section-title::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 60px;
    height: 3px;
    background-color: #b22222; /* アクセントカラーを適用 */
}

.section-text {
    font-size: 17px;
    line-height: 1.8;
    color: #333;
    text-align: justify; /* 両端揃えにして体裁を整える */
}

.section-image-left {
    width: 100%;
    height: auto;
    display: block;
    transform: rotateZ(-3deg);
    clip-path: polygon(15% 0%, 100% 0%, 100% 90%, 0% 100%);
}
.section-image-right {
    width: 100%;
    height: auto;
    display: block;
    transform: rotateZ(3deg);
    clip-path: polygon(0% 10%, 100% 0%, 85% 100%, 0% 90%);
}

/* セクション2用の背景色 */
.bg-gray {
    background-color: #f8f8f8;
}

/* ====================================
   レイアウトの反転
   ==================================== */
/* セクション2 (右側テキスト) のレイアウトを反転させる */
.section--right-text .content-grid {
    /* 左右の順序を逆にする */
    grid-template-areas: "image text";
    grid-template-columns: 1fr 1fr; /* 左右の幅も反転 */
}

.section--right-text .content-image-area {
    grid-area: image;
}

.section--right-text .content-text-area {
    grid-area: text;
}

/* ====================================
   レスポンシブデザイン (セクション)
   ==================================== */
@media (max-width: 999px) { /* タブレットサイズからレイアウトを変更 */
    .section {
        padding: 60px 0;
    }

    .content-grid {
        /* 縦並びの1カラムに変更 */
        grid-template-columns: 1fr;
        gap: 40px;
        width: 90%;
        margin: 0 auto;
    }

    .section-title {
        font-size: 36px;
        text-align: left
    }

    .section-text {
        font-size: 16px;
        text-align: left;
    }

    .section-image {
        width: 80%;
        margin: 0 auto;
    }

    .content-image-area {
        width: 90%;
        margin: 0 auto;
    }

}


@media (max-width: 767px) {
    .section-title {
        font-size: 28px;
        text-align: left
    }

    .section-text {
        font-size: 14px;
        text-align: left;
    }

    .section-image {
        width: 80%;
        margin: 0 auto;
    }

    .content-image-area {
        width: 100%;
        margin: 0 auto;
    }
}

/* ====================================
   サービスセクション共通スタイル
   ==================================== */

.section-heading {
    font-size: 32px;
    font-weight: 700;
    color: #1a2a6c;
    text-align: center;
    margin-bottom: 15px;
}

.section-description {
    font-size: 18px;
    color: #555;
    text-align: center;
    margin-bottom: 40px;
}

@media (max-width: 999px) {
  .section-description {
    text-align: left;
  }
}

/* ====================================
   横スクロールコンテナ
   ==================================== */

/* スクロールを可能にする外側のラッパー */
.service-scroll-wrapper {
    /* 中央寄せのため、左右のネガティブマージンを削除 */
    /* margin-left: -20px; */
    /* margin-right: -20px; */

    /* 修正: コンテナの幅を100%にし、左右のパディングを削除 */
    padding-left: 0;
    padding-right: 0;

    /* 横スクロールを有効にする */
    overflow-x: auto;
    overflow-y: hidden;

    /* スクロールバーのデザインを非表示 (変更なし) */
    -ms-overflow-style: none;
    scrollbar-width: none;
    padding-bottom: 15px;
}

/* Chrome, Safari, Opera のスクロールバー非表示 */
.service-scroll-wrapper::-webkit-scrollbar {
    display: none;
}

/* サービス一覧（横並びコンテナ） */
.service-list {
    display: flex;
    width: max-content;

    /* 修正: サービスリスト全体を親要素内で中央に配置 */
    /* padding-left: 40px; <-- 削除 */
    /* padding-right: 20px; <-- 削除 */

    /* 中央揃えのためのスタイル */
    margin-left: auto;
    margin-right: auto;

    /* アイテム間の隙間を保つためのパディングを調整 */
    padding-left: 20px;
    padding-right: 20px;
}

/* 各サービスアイテム */
.service-item {
    display: block;
    width: 420px; /* 修正: アイテムの固定幅を420pxに拡大 */
    min-width: 420px; /* 修正: 縮小されないようにする */
    background-color: #fff;
    border-radius: 8px;
    overflow: hidden;
    margin-right: 30px; /* アイテム間の隙間は維持 */
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.08);
    transition: transform 0.3s ease;
    text-decoration: none;
}

.service-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
}

.service-banner-img {
    width: 100%;
    height: 200px; /* 修正: バナー画像の固定高さを増やす */
    object-fit: cover;
    display: block;
}

/* ダミーアイテムのスタイルも高さに合わせて調整 */
.service-item.dummy .dummy-img {
    background-color: #eee;
    color: #666;
    height: 200px; /* 修正: ダミーアイテムの高さを合わせる */
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 20px; /* 修正: 文字サイズも少し大きく */
    font-weight: 700;
}

.service-item-title {
    font-size: 18px; /* 修正: タイトル文字を大きく */
    font-weight: 700;
    color: #1a2a6c;
    padding: 20px 20px 5px 20px; /* 修正: パディングを調整 */
}

.service-item-description {
    font-size: 14px; /* 修正: 説明文を大きく */
    color: #555;
    padding: 0 20px 20px 20px; /* 修正: パディングを調整 */
}

/* ====================================
   選ばれる理由セクション
   ==================================== */

/* 3カラムレイアウト */
.feature-list {
    display: flex;
    justify-content: space-between; /* 均等に配置 */
    gap: 30px; /* アイテム間の隙間 */
    margin-top: 50px;
}

.feature-item {
    flex: 1; /* 均等な幅を占める */
    text-align: center; /* アイテム内の要素を中央に寄せる */
    padding: 30px 20px;
    background: #FFF;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    transition: box-shadow 0.3s ease;
}

.feature-item:hover {
    box-shadow: 0 8px 15px rgba(0, 0, 0, 0.1); /* ホバーで影をつける */
}

/* アイコンデザイン */
.feature-icon {
    width: auto; /* 幅をアイコンのコンテンツに合わせる */
    height: auto;
    margin: 0 auto 20px auto; /* 上下に余白と中央寄せは維持 */

    /* 修正: 背景色、円形、リング、シャドウを全て削除 */
    background-color: transparent;
    border-radius: 0;
    box-shadow: none;

    /* 中央揃えとサイズ調整のための設定 */
    display: block; /* ブロック要素に変更 */
    text-align: center;
}

.feature-icon img {
    /* サイズを大きくし、視認性を高める */
    width: 150px;
    height: 150px;
    object-fit: contain;
}

.feature-title {
    font-size: 20px;
    font-weight: 700;
    color: #1a2a6c;
    line-height: 1.5;
    margin-bottom: 15px;
    text-align: left; /* テキストは読みやすいように左揃え */
}

.feature-text {
    font-size: 15px;
    color: #555;
    line-height: 1.7;
    text-align: left; /* テキストは読みやすいように左揃え */
}

/* ====================================
   レスポンシブデザイン (スマートフォン対応)
   ==================================== */
@media (max-width: 767px) {
    .feature-list {
        flex-direction: column; /* 縦並びに変更 */
        gap: 30px;
    }

    .feature-item {
        padding: 20px;
        text-align: left; /* スマホでは全体を左揃えに戻す */
    }

    .feature-icon {
        float: none; /* スマホでも左寄せではなく、中央寄せを維持 */
        margin: 0 auto 15px auto; /* 中央寄せに戻す */
        width: 150px; /* サイズ固定 */
        height: 150px;
        display: block;
    }

    .feature-title {
        /* アイコンが中央寄せになったため、タイトルも中央寄せに戻す */
        text-align: center;
    }

    .feature-text {
        text-align: left; /* 本文は左揃えを維持 */
        clear: both; /* アイコンの回り込みを解除 */
    }
}

/* ====================================
   比較表セクション
   ==================================== */
.table-scroll-wrapper {
    /* テーブルも横スクロール可能にする */
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 20px; /* スクロールバーのための余白 */

    /* スクロールバーを非表示にする設定は service-scroll-wrapper で共通化されています */
}

.comparison-table {
    width: 100%; /* 親要素の幅いっぱい */
    border-collapse: collapse; /* ボーダーを重ねる */
    max-width: 1080px;
    min-width: 900px; /* テーブルが縮小しすぎない最低幅 */
    font-size: 15px;
    background-color: #fff;
    margin: 0 auto; /* 中央寄せ */
}

.comparison-table th,
.comparison-table td {
    padding: 15px 20px;
    border: 1px solid #ddd;
    text-align: center;
    line-height: 1.6;
}

/* ヘッダー行 */
.comparison-table thead th {
    background-color: #1a2a6c; /* メインカラー */
    color: #fff;
    font-weight: 700;
    text-align: center;
}

.comparison-table thead th:nth-child(3) {
  border-right: 3px solid #b22222; /* 左側に太い枠線 */
}

.comparison-table thead th:last-child {
  border-top: 3px solid #b22222; /* 左側に太い枠線 */
  border-left: 3px solid #b22222; /* 左側に太い枠線 */
  border-right: 3px solid #b22222; /* 左側に太い枠線 */
}

/* 1列目の見出し (ラベル) */
.comparison-table .table-label {
    width: 150px; /* 幅を固定して見やすくする */
    background-color: #f8f8f8;
    color: #1a2a6c;
    font-weight: 700;
    text-align: center;
}

/* 自社サービスを強調するスタイル */
.comparison-table .highlight {
    background-color: #fff8f8; /* 薄い赤系の背景 */
    color: #b22222; /* アクセントカラーの文字 */
    font-weight: 700;
    text-align: center; /* 項目に合わせて中央寄せ */
    border-left: 3px solid #b22222; /* 左側に太い枠線 */
    border-right: 3px solid #b22222; /* 左側に太い枠線 */
}

.comparison-table .highlight-end {
    border-bottom: 3px solid #b22222; /* 左側に太い枠線 */
}

.comparison-table thead th.highlight {
    background-color: #b22222; /* ヘッダーは濃い赤 */
    color: #fff;
    border-left: none;
    text-align: center;
}

/* ====================================
   レスポンシブデザイン (比較表)
   ==================================== */
@media (max-width: 900px) {
    /* 900px以下では横スクロールが発生 */
}

@media (max-width: 767px) {
    /* スマホで表内のパディングを調整し、さらに見やすく */
    .comparison-table th,
    .comparison-table td {
        padding: 12px 10px;
        font-size: 14px;
    }

    .comparison-table .table-label {
        width: 120px; /* ラベルの幅を調整 */
    }
}

/* ====================================
   導入の流れセクション (形状・角度修正版)
   ==================================== */
#flow {
    background-color: #f4f7fc;
}

/* フローチャート全体のコンテナ */
.flow-chart {
    display: flex;
    justify-content: space-between;
    gap: 10px; /* 隙間を少し広げて形状を見やすく */
    margin-top: 50px;
    width: 100%;
}

/* 各ステップのアイテム */
.flow-item {
    flex: 1;
    display: flex;
    flex-direction: column;
}

/* 強調したいステップ（謎解き研修実施） */
.flow-item--highlight {
    flex: 1.5; /* 幅を広く */
}

/* 矢印型のボックス (修正箇所) */
.flow-box {
    background-color: #1a2a6c;
    color: #fff;
    padding: 20px 10px;
    height: 160px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    position: relative;

    clip-path: polygon(
        0% 0%,                      /* 左上 */
        calc(100% - 20px) 0%,       /* 右上（矢印の付け根） */
        100% 50%,                   /* 右端（矢印の先端） */
        calc(100% - 20px) 100%,     /* 右下（矢印の付け根） */
        0% 100%,                    /* 左下 */
        20px 50%                    /* 左端（矢印のくぼみ） */
    );
}

/* STEP1 (最初) と STEP6 (最後) の個別形状指定は削除し、統一形状にします */

/* 強調ステップのデザイン */
.flow-item--highlight .flow-box {
    background-color: #b22222;
}

/* ステップ番号 */
.flow-step-num {
    font-size: 14px;
    font-weight: 700;
    opacity: 0.8;
    margin-bottom: 5px;
    display: block;
    letter-spacing: 0.05em;
    /* 形状に合わせて少し右に寄せるとバランスが良い場合がありますが、中央揃えで配置します */
}

/* タイトル */
.flow-title {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.4;
    margin: 0;
}

.flow-title .small {
    font-size: 13px;
    font-weight: normal;
}

/* 強調ステップ内のサブフロー */
.flow-sub-flow {
    font-size: 13px;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid rgba(255, 255, 255, 0.3);
    font-weight: bold;
}

/* 下の説明テキスト */
.flow-text {
    margin-top: 15px;
    font-size: 14px;
    color: #333;
    line-height: 1.6;
    padding: 0 5px;
    text-align: left;
}


/* ====================================
   レスポンシブデザイン (フローチャート)
   ==================================== */
@media (max-width: 999px) {
    .flow-chart {
        flex-direction: column;
        gap: 20px;
        max-width: 500px;
        margin-left: auto;
        margin-right: auto;
    }

    .flow-item,
    .flow-item--highlight {
        flex: auto;
        width: 100%;
    }

    .flow-box {
        height: auto;
        padding: 20px;
        /* スマホ用: 下向きの矢印（角度統一） */
        clip-path: polygon(
            0% 0%,
            100% 0%,
            100% calc(100% - 30px),
            50% 100%,
            0% calc(100% - 30px)
        );
        margin-bottom: 0;
    }

    /* スマホでも全ての形状を統一するため、first-child / last-child の指定はしません */

    .flow-text {
        text-align: left;
        margin-bottom: 20px;
    }
}

/* ====================================
   会社概要セクション
   ==================================== */
#company {
    background-color: #fff;
}

.company-wrapper {
    max-width: 900px;
    margin: 50px auto 0;
}

/* 会社情報リスト (定義リスト) */
.company-list {
    width: 100%;
    border-top: 1px solid #ddd;
    margin-bottom: 60px;
}

.company-row {
    display: flex;
    border-bottom: 1px solid #ddd;
}

.company-row dt {
    width: 25%; /* 項目名の幅 */
    background-color: #f4f7fc; /* 薄い青背景 */
    padding: 20px;
    font-weight: 700;
    color: #1a2a6c;
    display: flex;
    align-items: center; /* 縦方向中央揃え */
}

.company-row dd {
    width: 75%; /* 内容の幅 */
    padding: 20px;
    color: #333;
    line-height: 1.8;
}

/* 事業内容のリスト */
.business-list {
    list-style: disc;
    padding-left: 20px;
    margin: 0;
}

.business-list li {
    margin-bottom: 5px;
}

/* アクセスマップ */
.company-map {
    width: 100%;
    height: 400px;
    background-color: #eee;
    border-radius: 8px;
    overflow: hidden; /* iframeの角丸用 */
}

/* ====================================
   レスポンシブデザイン (会社概要)
   ==================================== */
@media (max-width: 767px) {
    .company-row {
        flex-direction: column; /* スマホでは縦並び */
    }

    .company-row dt {
        width: 100%;
        border-bottom: 1px solid #eee; /* スマホ時の区切り線 */
        padding: 15px;
    }

    .company-row dd {
        width: 100%;
        padding: 15px;
    }

    .company-map {
        height: 300px; /* スマホでは少し高さを抑える */
    }
}

/* ====================================
   CTAセクション (CVR向上施策)
   ==================================== */
.cta-section {
    position: relative;
    padding: 100px 0;
    color: #fff;
    text-align: center;

    background-image: url('img/cta_pc.jpg'); /* KVと同じ画像または別のオフィス画像 */
    background-size: cover;
    background-position: center;
    background-attachment: fixed; /* パララックス効果で高級感を出す */
}

.cta-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.85); /* #1a2a6c の透過率85% */
}

/* コンテンツを前面に出す */
.cta-content {
    position: relative;
    z-index: 1;
    max-width: 800px;
    margin: 0 auto; /* 中央寄せ */
}

.cta-heading {
    font-size: 42px;
    font-weight: 700;
    line-height: 1.4;
    margin-bottom: 30px;
    letter-spacing: 0.05em;
    text-shadow: 0 4px 10px rgba(0,0,0,0.3);
}

.cta-description {
    font-size: 18px;
    line-height: 1.8;
    margin-bottom: 60px;
    opacity: 0.9;
}

.cta-buttons {
    display: flex;
    justify-content: center;
    gap: 40px;
    align-items: center; /* 中央揃えに統一 */
}

.cta-btn-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.cta-btn-label {
    font-size: 18px;
    font-weight: 700;
    color: #ffd700; /* ゴールドで目を引く */
    margin-bottom: 10px;
    display: block;
}

.btn--cta-large {
    background-color: #b22222;
    color: #fff;
    border: 2px solid #b22222;
    padding: 20px 60px; /* 大きく */
    font-size: 20px;
    min-width: 320px;
    border-radius: 50px;
    text-decoration: none;
    display: inline-block;
    transition: all 0.3s ease;
    box-shadow: 0 10px 25px rgba(0,0,0,0.3);
}

.btn--cta-large:hover {
    background-color: #8b0000; /* 濃い赤 */
    border: 2px solid #8b0000;
    transform: translateY(-2px);
}

.btn--cta-secondary {
    background-color: #1a2a6c; /* KVと同じ濃い青 */
    color: #fff;
    border: 2px solid #1a2a6c;
    padding: 20px 60px;
    font-size: 20px;
    min-width: 320px;
    border-radius: 50px;
    text-decoration: none;
    display: inline-block;
    transition: all 0.3s ease;
    box-shadow: 0 10px 25px rgba(0,0,0,0.3);
}

.btn--cta-secondary:hover {
    background-color: #0f1840; /* KVと同じホバー色（さらに濃い青） */
    border: 2px solid #0f1840;
    transform: translateY(-2px);
}

/* ====================================
   レスポンシブデザイン (CTA)
   ==================================== */
@media (max-width: 767px) {
    .cta-section {
        padding: 60px 0;
        background-attachment: scroll; /* スマホではパララックス解除 */
    }

    .cta-heading {
        font-size: 28px;
        margin-bottom: 20px;
    }

    .cta-description {
        font-size: 15px;
        text-align: left; /* スマホでは左揃えの方が読みやすい場合あり */
        display: inline-block; /* 中央寄せしつつ左揃えにするテクニック */
    }
    .cta-content {
        text-align: center; /* 親要素は中央寄せ */
    }

    .cta-buttons {
        flex-direction: column; /* 縦並び */
        gap: 20px; /* 隙間調整 */

        /* 修正: KVと同じく幅を85%にして中央寄せ */
        width: 85%;
        margin: 0 auto;
    }

    /* 修正: ボタンを囲むラッパーも幅100%にする */
    .cta-btn-wrapper {
        width: 100%;
    }

    /* 修正: ボタンを親要素いっぱい(横長)に広げる */
    .btn--cta-large,
    .btn--cta-secondary {
        width: 100%;
        min-width: auto; /* 固定の最小幅を解除 */
        padding: 15px 0; /* 上下パディングのみ指定し、左右は幅に依存 */
        box-sizing: border-box; /* パディングを含めて幅計算 */

        text-align: center;
        display: block; /* ブロック要素として幅を効かせる */
    }

    /* ラベルのマージン微調整 */
    .cta-btn-label {
        margin-bottom: 8px;
    }
}

/* ====================================
   フッター
   ==================================== */
#footer {
    background-color: #000; /* CTAセクションと同じ黒 */
    color: #fff;
    padding: 20px 0; /* 上下の余白 */
    text-align: center;

    /* CTAセクションとの境界を少し明確にするための細い線 (任意) */
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.copyright {
    margin: 0;
    font-size: 12px;
    color: #888; /* 真っ白ではなくグレーにして控えめに */
    font-family: Arial, sans-serif; /* 英語表記なのでシステムフォントで綺麗に見せる */
}
