
/* .contact-top {
	margin-top: 80px;
}
.contact-top .contact-top-box {
	display: flex;
	align-items: center;
	flex-direction: column;
	justify-content: center;
	padding: 60px 0;
	background-color: #f4f2f0;
}
.contact-top .contact-top-box .top-line {
	color: #35353c;
	font-size: 16px;
	font-weight: 500;
	text-align: center;
}
.contact-top .contact-top-box .btm-line {
	color: var(--oc-primary-color);
	font-size: 14px;
	font-weight: 500;
	text-align: center;
	margin: 0;
}
.contact-top .contact-top-box .phone-number {
	font-size: 48px;
	font-weight: 500;
	text-align: center;
	line-height: 1em;
}
.contact-top .contact-top-box .phone-number .icon {
	font-size: 36px;
	margin-right: 0.33em;
	vertical-align: baseline;
	transform: rotate(105deg);
}
.contact-form-container {
	padding: 40px 0 80px 0;
}

.contact-form-container .contact-result {
	color: #35353c;
	text-align: center;
	font-size: 20px;
	padding: 1em;
	margin-bottom: 30px;
}
.contact-form-container .contact-result.failed {
	background-color: #fcefef;
}
.contact-result.success {
}
.contact-form-container .contact-result p {
	font-size: 20px;
	line-height: 1.4em;
	margin: 0;
}

.contact-form .field-group {
	height: 70px;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	margin-bottom: 30px;
}
.contact-form .field-group .label-wrap {
	flex: 0 0 25%;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.contact-form .field-group .label-wrap .group-label {
	flex: 1 0 10px;
	color: #35353c;
	font-size: 20px;
	font-weight: 500;
}
.contact-form .field-group .req {
	flex: 0 0 auto;
	color: #fff;
	font-size: 16px;
	font-weight: 500;
	line-height: 1em;
	padding: 0.5em 1em;
	background-color: #e8460b;
}
.contact-form .field-group .input-wrap {
	flex: 0 0 75%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-left: 20px;
}
.contact-form .field-group .text-input {
	width: 100%;
	height: 100%;
	font-size: 20px;
	font-weight: 500;
	padding: 5px 10px;
	border: none;
	outline: none;
	background-color: #f4f2f0;
}
.contact-form .field-group .contact-radio {
	flex: 0 0 32%;
	margin-right: 2%;
	display: flex;
	align-items: center;
}
.contact-form .field-group .contact-radio:last-child {
	margin-right: 0;
}
.contact-form .field-group .contact-radio input[type="radio"] {
	display: none;
}
.contact-form .field-group .contact-radio input[type="radio"] ~ label {
	width: 100%;
	height: 70px;
	display: flex;
	align-items: center;
	color: var(--oc-primary-color);
	font-size: 20px;
	font-weight: 500;
	margin-right: 2%;
	padding: 0 0 0 0.2em;
	background-color: #f4f2f0;
}
.contact-form .field-group .contact-radio input[type="radio"]:checked ~ label {
	color: #fff;
	background-color: var(--oc-primary-color);
}

.contact-form .confirm-group {
	text-align: center;
	margin: 60px 0 30px 0;
}
.contact-form .confirm-group .agree-text {
	color: #35353c;
	font-size: 16px;
	font-weight: 500;
	margin-bottom: 1em;
}
.contact-form .confirm-group .agree-btn {
	
}
.contact-form .confirm-group .agree-chk {
	display: none;
}
.contact-form .confirm-group .agree-chk ~ .agree-label {
	color: var(--oc-primary-color);
	font-size: 16px;
	font-weight: 500;
	margin-bottom: 1em;
	user-select: none;
}
.contact-form .confirm-group .agree-chk ~ .agree-label .chk-box {
	display: inline-block;
	width: 10px;
	height: 10px;
	margin-right: 7px;
	border: 1px solid var(--oc-primary-color);
}
.contact-form .confirm-group .agree-chk:checked ~ .agree-label .chk-box {
	background-color: var(--oc-primary-color);
}

.contact-form .g-recaptcha {
	display: flex;
	justify-content: center;
	margin-bottom: 30px;
}

.contact-form .submit-group {
	display: flex;
	justify-content: center;
}
.contact-form .site-btn.grey-txt.lined:after{
	content: '';
	display: block;
	position: absolute;
	right: 0;
	top: 50%;
	width: 25%;
	transform: translateY(-50%);
	border-top: 1px solid var(--oc-primary-color);
} */
/*
* END CONTACT PAGE
*/

/* @media (max-width: 575.98px) {
    .contact-section {
        padding: 80px 0;
    }
    .contact-top .contact-top-box {
        padding: 40px 0;
    }
    .contact-top .contact-top-box .top-line {
        padding: 0 20px;
    }
    .contact-top .contact-top-box .btm-line {
    }
    .contact-top .contact-top-box .phone-number {
        font-size: 42px;
    }
    .contact-top .contact-top-box .phone-number .icon {
        font-size: 27px;
        margin-right: 0.2em;
    }
    .contact-phone{
        font-size: 12px;
    }
    .contact-phone > span{
        font-size: 2.5em;
    }
    .footer-address{
        font-size: 14px;
    }
    .go-top{
        position: absolute;
        top: 1%;
        right: 1%;
    }

    .footer-bottom p{
        font-size: 12px;
    }
    .footer-btn{
        justify-content: center;
        align-items: center;
    }
    .copyright{
        font-size: 10px;
    }
    .contact-form .field-group {
        height: unset;
        flex-direction: column;
    }
    .contact-form .field-group .label-wrap {
        width: 100%;
        flex: 0 0 auto;
        margin-bottom: 5px;
    }
    .contact-form .field-group .input-wrap {
        width: 100%;
        height: 70px;
        flex: 0 0 70px;
        padding-left: 0;
    }
    .contact-form .field-group .input-wrap.radio {
        height: auto;
        flex-direction: column;
    }
    .contact-form .field-group .input-wrap.radio .contact-radio {
        width: 80%;
        flex: 1 0 auto;
        margin: 0 auto 10px auto;
    }
    .contact-form .confirm-group .agree-text {
        font-size: 14px;
    }
    .contact-form .confirm-group .agree-chk ~ .agree-label {
        font-size: 14px;
    }
    .contact-result p {
        font-size: 16px;
    }
} */
  

.contact-container {
	margin-top: 127px;
	margin-bottom: 127px;
}

.contact-direction {
	padding-bottom: 37px;
	border-bottom: 1px solid #2F3C5B;;
}

.contact-form-wrap {
	margin-top: 20px;
}


.contact-form .field-group {
	display: flex;
	align-items: center;
	padding: 30px 0;
	background-size: 10px 1px;
	background-image: linear-gradient(to right, #2F3C5B 3px, transparent 3px);
	background-repeat: repeat-x;
	background-position: left bottom;  
}

.contact-form .input-wrap {
	/* max-width: 640px; */
	flex: 1;
    min-width: 0;
    width: 100%;
}

.contact-form .input-wrap.radio{
	display: flex;
	align-items: center;
	gap: 10px 40px;
	flex-wrap: wrap;
}

.contact-form .label-wrap {
  width: 30%;
  padding: 10px 0;
}

.contact-form label {
    /* display: block; */
	font-weight: 500;
}

.contact-form .required {
	background-color: #C95F5F;
    color: #fff;
    font-size: 12px;
	padding: 0.333em 0.417em;
    margin-left: 5px;
	border-radius: 5px;
}

.contact-form .any {
	background-color: #6CA1F3;
    color: #fff;
    font-size: 12px;
	padding: 0.333em 0.417em;
    margin-left: 5px;
	border-radius: 5px;
}

.zipcode-wrap {
	display: flex;
	align-items: center;
	gap: 12px;
}

.zipcode-wrap input {
	max-width: 176px;
}

input[type="text"], input[type="tel"], input[type="email"],select, textarea {
    width: 100%; /* 親要素の幅に合わせる */
    padding: 10px; /* 内側の余白 */
    border: none; /* 枠線 */
    border-radius: 5px; /* 角丸 */
    font-size: 16px; /* 文字サイズ */
    outline: none; /* フォーカス時の青枠を削除 */
    transition: border-color 0.3s, box-shadow 0.3s; /* なめらかな変化 */
	flex: 1;
	min-width: 0;
	height: 50px;
	background-color: #E9ECF1;
}

input::placeholder,
textarea::placeholder {
    color: #8F96A8; /* プレースホルダーの色 */
    opacity: 1;  /* 透明度を調整 */
}

.select_wrapper {
    position: relative;
}

.select_wrapper::after {
    content: "";
    position: absolute;
    top: 18px;
    right: 16px;
    width: 8px;
    height: 8px;
    border-right: 2px solid #2F3C5B;
    border-bottom: 2px solid #2F3C5B;
    transform: rotate(45deg);
}

/* select のプレースホルダー風の色変更 */
select {
    color: #2F3C5B; /* 選択前のテキストの色 */
	-webkit-appearance: none;
    appearance: none;
}

/* select で未選択時のスタイル */
select option[value=""][disabled] {
    color: #2F3C5B; /* 未選択状態のテキスト色 */
}

textarea {
	height: 12em;
	resize: none;
}

.submit-group {
	display: flex;
	justify-content: center;
	margin-top: 43px;
}

.contact-submit {
	background: linear-gradient(to top, #F64A4A, #FF9737);
    color: white;
    border: none;
    padding: 10px;
    width: 100%;
    border-radius: 10px;
    font-size: 25px;
	max-width: 400px;
	height: 3.6em;
}

.contact-submit:hover {
	opacity: 0.6;
}

input[type="radio"] {
	appearance: none;
	width: 16px;
	height: 16px;
	border: 1px solid #2F3C5B;
	border-radius: 50%;
	display: inline-block;
	position: relative;
	vertical-align: middle
	;
  }
  
  input[type="radio"]:checked {
	background-color: #FFF;
	/* border-color: #007bff; */
  }
  
  input[type="radio"]::before {	
	content: "";
	width: 10px;
	height: 10px;
	background-color: #69A0BF;
	border-radius: 50%;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	display: none;
  }
  
  input[type="radio"]:checked::before {
	display: block;
  }
  
  .contact-privacy-wrap {
    margin-top: 30px;
    display: flex;
    flex-direction: column;
    gap: 20px;
    align-items: center  }

	.contact-form .confirm-group {
		text-align: center;
		margin: 60px 0 30px 0;
	}

@media (max-width: 769px) {
	.contact-container {
		margin-top: 37px;
		margin-bottom: 37px;
	}

	.contact-form .field-group {
		flex-direction: column;
		align-items: flex-start;
	}

	.contact-form .label-wrap {
		width: 100%;
		padding-top: 0;
	}	

	.contact-form .input-wrap.radio{
		gap: 10px 20px;
	}


    .contact-submit {
		max-width: 325px;
	    height: 2.8em;
    }
	
	
}
