/* --- 全体の設定とCSS変数 --- */

.after{width: 90%;padding: 2% 2% 2% 2%; margin: 0% auto 0;background-color: #fff}
.afterbg{width: 100%;padding: 0% 0% 0% 0%; margin: 0% auto 0;background:#d4ecea;}

.afont1 {font-size: clamp(0.9rem, 0.9vw, 1.0rem); color:#8d8661;line-height: 150%;padding: 2% 0% 0% 0%;text-align: center;font-family: 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;}

.afont2 {font-size: clamp(0.75rem, 0.93vw, 0.93rem); color:#000;line-height: 150%;padding: 1% 0% 1% 0%;text-align: left}
.afont3 {font-size: clamp(0.8rem, 1.3vw, 1.3rem); color:#000;line-height: 150%;padding: 0% 0% 2% 0%;text-align: left}

:root {

    --title-bg-color: #8d8661; /* 右カラムのタイトル背景色 */
    --text-color: #8d8661;
    --gap-large: 1%; /* 要素間の大きな隙間 */
    --gap-medium: 1%; /* 要素間の中くらいの隙間 */
    --gap-small: 1%;  /* 要素間の小さな隙間 */
}

/* --- 基本スタイルとリセット --- */
body {
    margin: 0;

    color: var(--text-color);
    line-height: 1.7;
}

* {
    box-sizing: border-box;
}



/* --- 全体レイアウト --- */
.container7 {
    width: var(--content-width);
    max-width: var(--content-max-width);
    margin: 5% auto 0%;width: 90%;padding: 4% 2% 5% 2%; background-color: #fff
}

.main-content {
    display: flex;
    flex-direction: column; /* スマホでは縦1列がデフォルト */
}

/* --- 左カラム --- */
.left-column {
    padding: 0 var(--gap-large); /* 両脇の空間 */
    text-align: center;
    margin-bottom: 2rem;
}

.left-column .main-title2 {
    font-size: clamp(1.0rem, 1.0vw, 1.0rem);font-weight: 700;color: #8d8661;
    margin-bottom: 0.5rem;font-family: 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}

.left-column .description {
    text-align: left; /* 説明文は読みやすさのため左揃え */
    font-size: clamp(0.9rem, 1.5vw, 1rem);
    margin-bottom: 2rem;
}

/* --- 右カラム --- */
.right-column {
    display: flex;
    flex-direction: column;
    gap: var(--gap-large); /* 各info-blockの下に3%の隙間 */
}

.info-block {
    background-color: #fff;
}

.block-title {
    background-color: var(--title-bg-color);
    color: white;
    text-align: center;
    margin: 0;
    padding: 0.5rem;
    font-size: clamp(1.0rem, 1.2vw, 1.2rem);
    font-weight: bold;font-family: 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}

.block-content {
    display: flex;
    flex-direction: column; /* スマホでは縦1列 */
    padding: 1.5rem 0; /* スマホ用のパディング */
    gap: 1rem;
}

.block-image {
    flex: 1; /* スマホでは幅いっぱいに */padding: 0.5rem 0;margin: auto
}

.block-text {
    flex: 1;
}

.block-text h3 {
    margin-top: 0;
    margin-bottom: var(--gap-medium); /* タイトル下に2%の隙間 */
    font-size: clamp(1rem, 1.8vw, 1.2rem);
}

.block-text p {
    margin: 0;
    font-size: clamp(0.85rem, 1.4vw, 0.95rem);
}

.footer-note {
    font-size: clamp(0.8rem, 1.3vw, 0.9rem);margin-top: 3%;
    padding: 1rem;
    border-top: 2px solid var(--title-bg-color);
    border-bottom: 2px solid var(--title-bg-color);
}




/* --- PC表示用のスタイル (768px以上) --- */
@media (min-width: 1000px) {
	
	.left-column .main-title2 {
    font-size: clamp(1.5rem, 1.7vw, 1.7em);font-weight: 700;color: #8d8661;
    margin-bottom: 1.5rem;font-family: 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}
	.container7 {
    width: var(--content-width);
    max-width: var(--content-max-width);
    margin: 3% auto;width: 80%;padding: 2% 2% 2% 2%; background-color: #fff
}
	
	.after{width: 80%;padding: 2% 2% 2% 2%; margin: 0% auto 0%;background-color: #fff}
.afterbg{width: 100%;padding: 0% 0% 0% 0%; margin: 0% auto 0;background:#d4ecea;}
	
    .main-content {
        flex-direction: row; /* PCでは横並び2列 */
        gap: var(--gap-large);
        align-items: stretch; /* カラムの高さを揃える */
    }

    .left-column,
    .right-column {
        flex: 1 1 50%; /* 両カラムを50%幅に */
        margin-bottom: 0;
    }

    .block-content {
        flex-direction: row; /* PCでは画像とテキストを横並び */
        align-items: center; /* 中央揃え */
        padding: var(--gap-small); /* 全体に1%の隙間 */
        gap: 1.5rem;
    }

    .block-image {
        flex: 0 0 35%; /* 画像を35%で固定 */
    }

    .block-text {
        flex: 1 1 65%; /* テキストを65%に */
        padding: var(--gap-small); /* 上下左右に1%の隙間 */
    }
}