/* ページ全体の背景と余白 */
.contact-page-wrapper {
    background-color: #fdfaf5 !important;
    /* 優しいアイボリー */
    padding: 60px 20px !important;
}

/* タイトルと説明文のエリア */
.contact-text-area {
    max-width: 700px;
    /* カードと同じ幅にする */
    margin: 0 auto 30px;
    /* 中央に寄せて、下に余白を作る */
    padding: 0 10px;
    /* スマホ時に端にピタッとつかないように微調整 */
}

/* 必須項目の注意書き */
.required-notice {
    margin-top: 20px !important;
    color: #b33e3e !important;
    /* 少し落ち着いた赤色 */
    font-weight: bold;
    font-size: 0.9rem;
    border-top: 1px solid #e0e4dc;
    /* 上に薄い線を入れて区切る */
    padding-top: 15px;
}

/* 「お問い合わせフォーム」の文字 */
.contact-title {
    color: #5B744C;
    font-weight: bold;
    font-size: 1.8rem;
    margin-bottom: 20px;
    text-align: left;
    /* 左揃えを維持しつつ中央エリア内に配置 */
}

/* 説明文（黒文字） */
.contact-description p {
    color: #333;
    line-height: 1.8;
    margin-bottom: 10px;
    font-size: 0.95rem;
    text-align: left;
}

/* フォームを包むカード：ここがオシャレのポイント */
.contact-card {
    background: #fff;
    padding: 60px 50px;
    border-radius: 40px;
    /* 角を大きく丸く */
    box-shadow: 0 20px 60px rgba(91, 116, 76, 0.08);
    /* ロゴの緑を混ぜた薄い影 */
    max-width: 700px;
    /* 横幅を絞って中央に */
    margin: 0 auto;
    /* 中央寄せ */
}

/* 入力項目のまとまり */
.form-item {
    margin-bottom: 30px;
    text-align: left;
}

/* ラベル：ロゴの濃い緑を使う */
.form-item label {
    display: block;
    font-weight: bold;
    color: #5B744C;
    margin-bottom: 10px;
    font-size: 0.95rem;
    padding-left: 5px;
}

/* ついでにラベルの横に「必須」チップを入れるとより親切です（お好みで） */
.form-item label::after {
    content: "必須";
    background-color: #b33e3e;
    color: #fff;
    font-size: 0.7rem;
    padding: 2px 8px;
    border-radius: 4px;
    margin-left: 10px;
    vertical-align: middle;
}

/* 入力欄：枠線を消して背景色をつけるのが最新のトレンド */
.form-item input,
.form-item select,
.form-item textarea {
    width: 100%;
    border: 2px solid transparent;
    background-color: #f8f9f6;
    /* ほんのり緑がかったグレー */
    padding: 16px 20px;
    border-radius: 15px;
    font-size: 1rem;
    transition: all 0.3s ease;
    box-sizing: border-box;
    /* はみ出し防止 */
}

/* クリックした時にロゴの緑がふわっと出る */
.form-item input:focus,
.form-item textarea:focus {
    outline: none;
    background-color: #fff;
    border-color: #B2C2A2;
    /* ロゴの若葉色 */
    box-shadow: 0 0 0 5px rgba(178, 194, 162, 0.15);
}

/* セレクトボックスが「未選択（値が空）」の時の文字色 */
.form-item select:has(option[value=""]:checked) {
    color: #767575 !important;
}
/* プレースホルダ（お名前などの例）と同じグレーに合わせる */
.form-item select {
    color: #333;
    /* 選択後の色 */
}

/* 選択肢（中身）の文字色はしっかり黒（濃い緑）にする */
.form-item select option {
    color: #999;
    /* またはロゴの濃い緑 #5B744C */
}



/* 送信ボタン（丸みのある大きなボタン） */
.form-action {
    text-align: center;
    margin-top: 40px;
}

.btn-submit-main {
    background-color: #5B744C;
    /* ロゴの濃い緑 */
    color: #fff;
    border: none;
    padding: 18px 80px;
    border-radius: 100px;
    font-weight: bold;
    font-size: 1.1rem;
    cursor: pointer;
    transition: all 0.3s;
    box-shadow: 0 8px 25px rgba(91, 116, 76, 0.2);
}

.btn-submit-main:hover {
    background-color: #B2C2A2;
    /* ホバーで明るい緑に */
    transform: translateY(-3px);
    box-shadow: 0 12px 30px rgba(91, 116, 76, 0.15);
}

/* スマホ表示の調整 */
@media (max-width: 768px) {
    .contact-card {
        padding: 40px 20px;
        border-radius: 30px;
    }

    .btn-submit-main {
        width: 100%;
        padding: 18px 0;
    }
}

.error-msg {
    color: #e3342f;
    /* 警告の赤 */
    font-size: 0.85rem;
    margin-top: 5px;
    display: block;
}

/* エラーがある入力欄の枠線を赤くする */
input:invalid,
textarea:invalid {
    border-color: #e3342f;
}