* {
    padding: 0;
    margin: 0;
    font-family: 'Noto Sans JP',sans-serif;
}

img {
    width: 100%;
    vertical-align: top;
}

a {
    display: inline-block;
    text-decoration: none;
}

p, h2, h3, h4 {
    text-align: center;
    letter-spacing: 0.02em;
    line-height: 1.5;
}

.inner {
    width: 640px;
    margin: 0 auto;
}

.col_2 {
    display: flex;
    justify-content: space-between;
}

/* sec01 */
#page_after {
    padding: 60px 0;
}

h2 {
    font-size: 36px;
    margin-bottom: 40px;
}

#page_after img {
    margin-top: 40px;
	margin-bottom: 25px;
}

.form-items {
    /* display: flex; */
    text-align: left;
    padding-bottom: 20px;
    border-bottom: 1px solid #e4e4e4;
    margin-bottom: 20px;
}

p.form-flex {
    text-align: left;
    font-weight: bold;
    display: flex;
    align-items: center;
    margin-bottom: 10px;
}

span.req {
    background-color: #f28185;
    color: #fff;
    font-size: 11px;
    font-weight: 100;
    padding: 1px 10px 0px;
    border-radius: 2px;
    display: inline-block;
    margin-left: 15px;
}

input.wpcf7-form-control.wpcf7-text.wpcf7-validates-as-required {
    width: 100%;
    border: 1px solid #dedede;
    border-radius: 2px;
    background-color: #f8f8f8;
    padding: 10px 15px;
    box-sizing: border-box;
}

span.wpcf7-spinner {
    display: none;
}

input.wpcf7-form-control.wpcf7-submit.has-spinner {
    font-size: 22px;
    font-weight: bold;
    color: #fff;
    background-color: #4dc1f3;
    padding: 20px;
    width: 360px;
    border: 2px solid #368cb0;
    border-radius: 8px;
    box-shadow: 0 8px 0 #368cb0;
}

textarea.wpcf7-form-control.wpcf7-textarea.wpcf7-validates-as-required {
    width: 100%;
    background-color: #f8f8f8;
    border-radius: 2px;
    border: 1px solid #e4e4e4;
    padding: 10px 20px;
    box-sizing: border-box;
}

/* footer */
.footer_logo {
    text-align: left;
    font-size: 32px;
    font-weight: bold;
	margin-bottom: 25px;
}

.company .col_2 {
    justify-content: flex-start;
}

/* 表示/非表示切り替え */
.sp {
	display: none;
}


/* フッター */
footer {
    background: #000;
    color: #fff;
    padding: 40px 0 20px;
}

.company-ttl {
    width: 80px;
    text-align: left;
}

.footer_detail {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding-bottom: 30px;
    border-bottom: 1px solid #fff;
    margin-bottom: 20px;
}

footer img {
    max-width: 350px;
}

@media screen and (max-width:840px) {
    .inner {
        width: 90%;
    }
}

@media screen and (max-width:480px) {
	.pc{
		display: none;
	}
	.sp {
		display: block;
	}
	.inner {
        width: 100%;
        padding: 0 25px;
        box-sizing: border-box;
    }
    h2 {
        font-size: 30px;
        margin-bottom: 30px;
    }
    p {
        font-size: 13px;
        line-height: 1.5;
		text-align: left;
    }
	.col_2 {
		flex-direction: column;
	}
	.service_r {
		width: 100%;
	}
	#fv a {
		width: calc(100% - 50px);
	}
	#sec01 .col_2 {
		gap: 25px;
		margin-top: 25px;
	}
	.detail .col_2 {
		flex-direction: row;
		gap: 5px!important;
	}

	.footer_logo {
		text-align: center;
		font-size: 22px;
	}

	.footer_detail {
		flex-direction: column-reverse;
		align-items: center;
		padding-bottom: 0;
		border-bottom: none;
	}

	footer img {
		width: 80%;
	}

	.company {
		margin-top: 45px;
		border-top: 1px solid #fff;
		width: 100%;
	}

	.company .col_2 {
		flex-direction: row;
		justify-content: flex-start;
		padding: 20px;
		border-bottom: 1px solid #fff;
	}

	.company-ttl {
		width: 65px;
	}

	.company .col_2 p {
		text-align: left;
	}

	footer p {
		font-size: 12px;
	}

	.c_right {
		font-size: 10px;
	}

	footer {
		padding: 20px 0 20px;
	}
	input.wpcf7-form-control.wpcf7-submit.has-spinner {
		font-size: 18px;
		padding: 20px;
		width: 100%;
		border: 2px solid #368cb0;
		border-radius: 4px;
	}
}