@charset "utf-8";
/*-----------------------------------------------------------------------------------------

    search

-------------------------------------------------------------------------------------------*/
#search_form .inner {
	padding: 0 10px;
}
#search_form .inner::after{
    background: url(../images/icon/line.svg) no-repeat center;
    content: "";
    display: block;
    width: 100%;
    height: 4px;
    margin: 120px 0 0;
}
#search_form form {
	background: #fff;
    margin: -100px auto 0;
    padding: 40px;
    z-index: 1;
    position: relative;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}
#search_form form::before{
	content: "";
	position: absolute;
	left: 4px;
	right: 4px;
	top: 4px;
	bottom: 4px;
	border: solid 1px #EAF3F8;
}
.search_box{
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-bottom: 25px;
    position: relative;
    z-index: 1;
}
.search_item{
	width: 100%;
	border: solid 1px #000;
	box-sizing: border-box;
	margin-right: 10px;
}
.search_item:last-child{
	margin-right: 0;
}
.search_box select{
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    width: 100%;
    padding: 15px 15px 15px;
    letter-spacing: .2em;
	outline: none;
	cursor: pointer;
}
.search_box select.search01{
	background: url(../images/icon/arrow01.svg) no-repeat 95% center;
	background-size: 15px;
}
.search_box select.search02{
	background: url(../images/icon/arrow01.svg) no-repeat 95% center;
	background-size: 15px;
}
.search_box input#s{
	background: url(../images/icon/pencil.svg) no-repeat 20px center;
	background-size: 15px;
	display: block;
	border: none;
	outline: none;
	width: 100%;
	padding: 15px 15px 15px 43px;
	box-sizing: border-box;
    color: #000;
}
.submit button {
	font-size: 14px;
	background: #BFE8FF;
	color: #fff;
	letter-spacing: 7px;
	display: block;
	width: 100%;
	border: none;
	padding: 25px 0;
	cursor: pointer;
	outline: none;
	transition: .5s;
	border-radius: 100px;
    position: relative;
    z-index: 1;
}
.submit button:hover {
	background: #BFE8FF;
	color: #000;
}
.submit button span {
	font-family: 'Roboto',sans-serif;
	font-weight: 600;
	position: relative;
	display: inline-block;
}
.submit button span::before {
	font-family: 'Material Icons';
	content: "search";
	font-size: 20px;
    vertical-align: middle;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	-moz-osx-font-smoothing: grayscale;
	font-feature-settings: 'liga';
	padding: 0 5px 0 0;
}
@media screen and (max-width: 767px) {
	#search_form form {
		margin: 0 auto;
		box-shadow: 0 0 0 rgba(0,0,0,0);
	}
    #search_form .inner::after {
        background: url(../images/icon/line.svg) no-repeat center;
        content: "";
        display: block;
        width: auto;
        height: 6px;
        margin: 50px 14px 30px;
    }
	.search_box {
		display: block;
		padding-bottom: 0;
	}
	.search_item {
		margin-bottom: 20px;
	}
	.submit button {
		font-size: 2.5vw;
		letter-spacing: 3px;
		padding: 25px 0;
	}
	.submit button span {
		padding-right: 60px;
	}
	.submit button span::after {
		width: 5vw;
		margin-right: 20px;
	}
	.submit button span::before {
		font-size: 3vw;
		padding-right: 10px;
	}
}
@media screen and (max-width: 480px) {
	#search_form form {
		padding: 10px;
	}
	.submit button {
		font-size: 13px;
		padding: 10px 0;
	}
	.submit button span {
		padding-right: 0;
		display: block;
		margin-bottom: 5px;
	}
	.submit button span::after {
		display: none;
	}
}
/*-----------------------------------------------------------------------------------------

    archive

-------------------------------------------------------------------------------------------*/
#archive{
    padding: 120px 20px 0;
}
.list_item{
    background: #FFF;
    margin: 0 0 80px;
    padding: 5px;
    position: relative;
    box-shadow: 0 2px 4px rgba(0,0,0,0.3);
}
.list_item::before{
    content: "";
    left: 0;
    right: 0;
    top: -60px;
    margin: 0 auto;
    position: absolute;
    width: 20px;
    height: 4px;
    background: url(../images/dotte.png) no-repeat;
}
.list_head{
    position: relative;
}
.list_head h2{
    background: #EAF3F8;
    padding: 40px 120px 40px 40px;
    font-size: 1.5rem;
    letter-spacing: 0.08em;
}
.list_head span {
    position: absolute;
    right: 40px;
    top: 50%;
	background: #fff;
    padding: 5px 10px;
    font-size: 1.2rem;
    letter-spacing: 0.1em;
    border: solid 1px #807d7d;
}
.item_box {
    padding: 40px;
    display: flex;
    justify-content: space-between;
}
.left,
.right{
    width: 49%;
}
.left img{
	width: 100%;
    margin: 0 0 0;
}
.left ul{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
    margin: 20px 0 0;
}
.left ul li{
    border: solid 1px #CAE6F8;
    padding: 15px 0;
    margin: 0 0 20px;
    width: 30.33333%;
    text-align: center;
    box-sizing: border-box;
}
.left p{
    font-size: 1.4rem;
    line-height: 1.6;
    letter-spacing: 0.08em;
}
.right dl{
    display: table;
    width: 100%;
    border: solid 1px #CAE6F8;
	margin-bottom: 20px;
    padding: 8px;
    box-sizing: border-box;
}
.right dt{
    display: table-cell;
    vertical-align: middle;
    width: 160px;
    text-align: center;
    border: solid 1px #CAE6F8;
    padding: 10px 0;
    letter-spacing: .6em;
}
.right dt b{
    display: block;
    text-indent: .6em;
    font-weight: normal;
}
.right dt img{
    display: block;
    margin: 0 auto 10px;
}
.right dd{
    display: table-cell;
    vertical-align: middle;
    padding: 10px 20px;
    font-size: 1.3rem;
    line-height: 1.6;
}
.right dd span{
    display: block;
	padding-top: 10px;
}
.right dd span a {
    display: inline-block;
    vertical-align: middle;
    color: #000;
    border: solid 1px #000;
    padding: 1px 20px;
}
.more{
    margin: 0 40px 40px;
    position: relative;
}
.more a{
	background: #FFF;
	font-family: '游明朝', 'YuMincho', "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", 'HG明朝E', "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-weight: 300;
    display: block;
    text-align: center;
    color: #3E3E3E;
    padding: 25px 20px;
    border-radius: 100px;
    border: solid 1px #3E3E3E;
}
.more a:hover{
    display: block;
    text-align: center;
    color: #FFF;
    padding: 25px 20px;
    background: #3E3E3E;
}
.more a span{}
.more a:hover span{
    color: #fff;
}
.more a span::before{
    font-family: 'Material Icons';
    content: "search";
    vertical-align: bottom;
    margin: 0 6px 0 0;
}
@media screen and (min-width:320px) and ( max-width: 767px) {
	#archive{
		padding: 20px 20px 0;
	}
    .list_item{
        margin: 0 0 40px;
    }
	.list_item::before{
		display: none;
	}
	.list_head h2 {
		padding: 40px 10px 10px;
		font-size: 13px;
		line-height: 1.5;
	}
	.list_head span {
		border: solid 1px #000;
		top: 10px;
		left: 10px;
		right: inherit;
	}
	.item_box{
		padding: 20px 10px 0;
		display: block;
	}
	.left {
		width: 100%;
		margin: 0 0 20px;
	}
	.left img{
		height: auto;
	}
	.left ul li {
		font-size: 1rem;
		line-height: 1.2;
	}
	.left p {
		margin: 0 0 20px;
	}
	.right {
		width: 100%;
	}
	.right dl {
		display: block;
		min-height: 0;
		margin-bottom: 10px;
	}
	.right dt{
		display: block;
		width: auto;
		padding: 10px 0;
	}
	.right dd{
		display: block;
		padding: 20px 5px;
	}
	.more {
		margin: 0 20px 20px;
	}
	.more a{
		padding: 20px;
	}
	.more a:hover{
		padding: 20px;
	}
}
/*-----------------------------------------------------------------------------------------

    page main

-------------------------------------------------------------------------------------------*/
#main.page_main h1{
    font-size: 4.8rem;
    letter-spacing: 0.1em;
}
@media screen and (min-width:320px) and ( max-width: 767px) {
	#page_main {
		padding: 100px 15px 40px 15px;
		display: inline-block;
		width: 100%;
	}
	#page_main img {
		width: 100%;
		height: 100%;
		opacity: 0.6;
	}
    #main.page_main h1{
        font-size: 8vw;
        letter-spacing: 0.1em;
    }
	#page_main h1 {
		font-size: 8vw;
		margin: 0 0 30px;
		line-height: 1.3;
	}
	#page_main h2 {
		font-size: 4.2vw;
		margin: 0 0 30px;
		letter-spacing: 0;
	}
	#page_main p {
		font-size: 1.3rem;
	}
}
/*-----------------------------------------------------------------------------------------

    single

-------------------------------------------------------------------------------------------*/
#single{
    padding: 60px 20px 120px;
}
#single .single_list_item .list_item{
    margin: 0 0 60px;
    padding: 0 0 0;
    border: solid 1px #000;
    position: relative;
}
#single .single_list_item .list_head{
    position: relative;
    padding: 10px 0 0;
}
#single .single_list_item .list_head h2{
    background: #EAF3F8;
    background-size: 15px;
    padding: 40px 120px 40px 30px;
    margin: 0 10px;
    font-size: 1.5rem;
    letter-spacing: 0.08em;
}
#single .single_list_item .list_head span{
    position: absolute;
    right: 40px;
    top: 50%;
    padding: 5px 10px;
    font-size: 1.2rem;
    letter-spacing: 0.1em;
    margin: -12px 0 0;
    border: solid 1px #807d7d;
}
#single .single_list_item{
    margin: 0 0 60px;
    padding: 0 0 1px;
    position: relative;
    box-shadow: 1px 3px 6px rgba(0,0,0,0.2);
}
#single .single_list_item .txt{
    padding: 0 40px;
    font-size: 1.3rem;
    line-height: 2;
}
#single .single_list_item .more{
    margin: 40px;
    position: relative;
}
#single .more a {
    background: linear-gradient(-135deg, #BFE8FF, #A3E9E9);
    display: block;
    border: solid 2px #BFE8FF;
    text-align: center;
    color: #fff;
    padding: 25px 20px;
    font-size: 1.6rem;
}
#single .more a:hover{
    letter-spacing: 0.2em;
}
#single .single_list_item .left img{
    margin: 0;
}
#single .single_list_item .right dl {
    display: table;
    width: 100%;
    min-height: 25%;
    border: solid 1px #cae6f8;
    border-bottom: none;
    padding: 8px;
    box-sizing: border-box;
}
#single .single_list_item .right dl:last-child{
    border-bottom: solid 1px #cae6f8;
}
@media screen and (min-width:320px) and ( max-width: 767px) {
	#single{
		padding: 40px 10px;
	}
	#single .single_list_item .left img{
		width: 100%;
	}
	#single .single_list_item .list_head h2{
		background: #cae6f8;
		padding: 20px 89px 20px 20px;
		font-size: 13px;
		line-height: 1.3;
	}
	#single .single_list_item{
        background: #FFF;
		margin: 0 0 80px;
	}
	#single .single_list_item .txt{
		padding: 0 20px;
	}
	#single .single_list_item .more{
		margin: 20px;
	}
	#single .more a {
		padding: 20px 20px;
	}
	#single .more a:hover{
		padding: 20px 20px;
	}
}
/*-----------------------------------------------------------------------------------------

    single section

-------------------------------------------------------------------------------------------*/
.single_sec01{
    padding: 0;
    box-sizing: border-box;
    border: solid 1px #000;
}
.sec01_box01{
    padding: 40px;
	display: flex;
}
.sec01_box01 p span img{
 height: 250px;
 object-fit: cover;
 width: 33%;
}
.sec01_box02{
    padding: 40px;
    margin: 0 40px;
    border: solid 1px #ddd;
}
.sec01_box02 dl dt span{
    display: inline-block;
    vertical-align: middle;
    padding: 15px 20px;
    border: solid 1px #000;
    min-width: 170px;
	box-sizing: border-box;
	line-height: 1.5;
}
.sec01_box02 dl dd{
    padding: 25px 0;
    font-size: 1.3rem;
    line-height: 2;
}
.sec01_box03 {
    margin: 40px 40px 0;
    padding: 0 40px;
    font-size: 1.4rem;
    line-height: 2;
}
.single_sec02{
    box-shadow: 1px 3px 6px rgba(0,0,0,0.2);
    margin: 120px 0 180px;
    padding: 0 0 1px;
    position: relative;
}
.single_sec02::before{
    background: url(../images/icon/line.svg) no-repeat center;
    content: "";
    display: block;
    width: calc(100% - 40px);
    height: 6px;
    margin: 0 20px;
    position: absolute;
    top: -40px;
}
.single_sec02::after {
    background: url(../images/icon/line.svg) no-repeat center;
    content: "";
    display: block;
    width: calc(100% - 40px);
    height: 6px;
    margin: 0 20px;
    position: absolute;
    bottom: -90px;
}
.sec02_box01{
    padding: 40px;
}
.sec02_box01 dl {
    display: table;
    width: 100%;
    min-height: 100px;
    border-bottom: solid 1px #CAE6F8;
    padding: 0 0 20px;
    box-sizing: border-box;
    margin: 0 0 20px;
}
.sec02_box01 dl:last-child{
    margin: 0;
}
.sec02_box01 dl dt{
    background: #EAF3F8;
    display: table-cell;
    vertical-align: middle;
    padding: 15px 0px 15px 0;
    width: 250px;
    position: relative;
    font-size: 1.5rem;
    line-height: 1.5;
    letter-spacing: .4em;
    text-align: center;
    font-weight: normal;
}
.sec02_box01 dl dt img {
    position: absolute;
    left: 40px;
/*    top: 50%;
    transform: translateY(-50%);*/
}
.sec02_box01 dl dd{
    line-height: 2;
    display: table-cell;
    vertical-align: middle;
    padding: 25px 40px;
    font-size: 1.3rem;
}
.sec02_box01 dl dd span{
    display: block;
    margin: 15px 0 0;
}
.sec02_box01 dl dd span a {
    display: inline-block;
    vertical-align: middle;
    color: #000;
    border: solid 1px #000;
    padding: 1px 20px;
}
.sec02_box01 dl dd ul{
    flex-wrap: wrap;
    justify-content: space-between;
}
.sec02_box01 dl dd ul li{
    width: 49%;
    vertical-align: middle;
}
#related ul {
	display: flex;
}
#related ul li:hover {
	opacity: 0.7;
	transition: .5s;
}
@media screen and (max-width: 767px) {
	.sec01_box01{
		padding: 20px;
		display: block;
	}
	.sec01_box01 p span img{	
		width: 100%;
		height: auto;
	}
	.sec01_box02 {
		padding: 15px;
		margin: 0 15px;
	}
	.sec01_box02 dl dt span{
		display: block;
		padding: 10px;
	}
	.sec01_box02 dl dd{
		padding: 15px 0 25px;
	}
	.sec01_box03 {
		margin: 20px;
		padding: 0;
		font-size: 1.3rem;
	}
	.single_sec02{
        background: #FFF;
		margin: 40px 0 0;
	}
    .single_sec02::before{
        background: url(../images/icon/line.svg) no-repeat center;
        content: "";
        display: block;
        width: calc(100% - 20px);
        height: 6px;
        margin: 0 10px;
        position: absolute;
        top: -40px;
    }
    .single_sec02::after {
        background: url(../images/icon/line.svg) no-repeat center;
        content: "";
        display: block;
        width: calc(100% - 20px);
        height: 6px;
        margin: 0 10px;
        position: absolute;
        bottom: -90px;
    }
	.sec02_box01{
		padding: 15px;
	}
	.sec02_box01 dl {
		display: block;
		padding: 0;
	}
	.sec02_box01 dl dt{
		display: block;
		width: auto;
		padding: 10px 10px 10px 10px;
	}
	.sec02_box01 dl dd{
		display: block;
		padding: 20px 10px;
	}
	.sec02_box01 dl dd ul{
		display: block;
	}
	.sec02_box01 dl dd ul li{
		width: 100%;
	}
	.sec02_box01 dl dt img {
		left: 25px;
	}
	#related ul {
		display: block;
	}
}
@media screen and (max-width: 400px) {
	.sec01_box02 dl dd{
		padding: 15px 0 25px;
		font-size: 3.7vw;
	}
}
/*-----------------------------------------------------------------------------------------

    page

-------------------------------------------------------------------------------------------*/
#pager .wp-pagenavi{
    margin: 0 0 120px;
    text-align: center;
}
#pager .wp-pagenavi a, #pager .wp-pagenavi span{
    text-decoration: none;
    padding: 0 12px;
    height: 30px;
    margin: 0 5px;
    line-height: 30px;
    text-align: center;
    vertical-align: middle;
    display: inline-block;
    border: solid 1px #777777;
    color: #777777;
}
#pager .wp-pagenavi a:hover,#pager .wp-pagenavi span.current {
    background: #777777;
    color: #fff;
    display: inline-block;
    vertical-align: middle;
}
.related {
    margin: 80px 0 0;
}
.related h3{
	font-family: '游明朝', 'YuMincho', "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", 'HG明朝E', "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-weight: 300;
    font-size: 2.4rem;
    margin: 0 0 30px;
    text-align: center;
    color: #777;
}
.related ul::after{
    content: "";
    clear: both;
    display: block;
}
.related ul li img{
    height: auto;
}
.related ul li{
    width: 100%;
    margin: 0 10px;
    background: #FFF;
    box-sizing: border-box;
    padding: 10px;
}
.related ul li:nth-of-type(2){
	margin: 0;
    padding: 10px;
    border-left: solid 1px #ddd;
    border-right: solid 1px #ddd;
}
.related ul li p{
	font-family: '游明朝', 'YuMincho', "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", 'HG明朝E', "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-weight: 300;
    color: #000;
    font-size: 1.6rem;
    margin: 15px 0 0;
    padding: 0 0 0;
}
.related ul li span{
    background: linear-gradient(-135deg, #BFE8FF, #A3E9E9);
    display: block;
    text-align: center;
    margin: 15px 0 0;
    padding: 10px 0;
    border-radius: 100px;
    color: #FFF;
    font-size: 1.5rem;
    letter-spacing: 0.1em;
}

@media screen and (min-width:320px) and ( max-width: 767px) {
	#pager .wp-pagenavi a, #pager .wp-pagenavi span{
		margin: 5px;
	}
	.related ul li img{
		width: 100%;
	}
	.related ul li{
		max-width: 90%;
		width: 100%;
		margin: 20px auto 0;
		float: none;
	}
	.related ul li:nth-of-type(2){
		width: 100%;
		max-width: 90%;
		float: none;
		margin: 20px auto 0;
		padding: 10px;
		border-left: none;
		border-right: none;
	}
}

/*-----------------------------------------------------------------------------------------

    Contact

-------------------------------------------------------------------------------------------*/
.contact_box{
    background: #FFF;
    margin: 120px 0;
    padding: 40px;
    box-shadow: 2px 4px 6px rgba(0,0,0,0.2);
    text-align: center;
}
.contact_box dl{
    display: table;
    width: 100%;
    box-sizing: border-box;
    margin: 0 0 10px;
    padding: 0 10px 10px;
    border-bottom: solid 1px #EAF3F8;
}
.contact_box dt {
    display: table-cell;
    background: #EAF3F8;
    text-align: center;
    width: 210px;
    padding: 20px 0;
    vertical-align: middle;
}
.contact_box dd {
    display: table-cell;
    padding: 10px 0 10px 20px;
    vertical-align: middle;
    text-align: left;
}
.contact_box dd input.ipt01{
    display: block;
    box-sizing: border-box;
    width: 100%;
    padding: 10px;
    font-size: 1.5rem;
    letter-spacing: 0.08em;
    border: solid 1px #ddd;
    border-radius: 4px;
}
.contact_box dd input.adnum01{
    display: inline-block;
    box-sizing: border-box;
    width: 90px;
    padding: 10px;
    font-size: 1.5rem;
    letter-spacing: 0.08em;
    border: solid 1px #ddd;
    border-radius: 4px;
}
.contact_box dd input.adnum02{
    display: inline-block;
    box-sizing: border-box;
    width: 110px;
    padding: 10px;
    font-size: 1.5rem;
    letter-spacing: 0.08em;
    border: solid 1px #ddd;
    border-radius: 4px;
}
.contact_box dd .select_box{
    display: inline-block;
    margin: 0 10px 0 0;
    position: relative;
}
.contact_box dd .select_box::after{
    content: "▼";
    display: block;
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    color: #777;
}
.mw_wp_form_confirm .select_box::after{
    display: none!important;
}
.contact_box dd .select01{
    background: #FFF;
    display: block;
    box-sizing: border-box;
    width: 100%;
    padding: 10px 40px 10px 10px;
    font-size: 1.5rem;
    letter-spacing: 0.08em;
    border: solid 1px #ddd;
    border-radius: 4px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}
.contact_box dd .select02{
    background: #FFF;
    display: block;
    box-sizing: border-box;
    width: 100%;
    padding: 10px 30px 10px 10px;
    font-size: 1.5rem;
    letter-spacing: 0.08em;
    border: solid 1px #ddd;
    border-radius: 4px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}
.contact_box dd textarea{
    display: block;
    box-sizing: border-box;
    width: 100%;
    min-height: 100px;
    padding: 10px;
    font-size: 1.5rem;
    letter-spacing: 0.08em;
    border: solid 1px #ddd;
    border-radius: 4px;
}
.contact_box dd .line{
    display: inline-block;
    vertical-align: top;
    letter-spacing: 0;
    text-align: center;
    margin: 13px 10px 0 10px;
}
.contact_box dd .add_box{
    display: inline-block;
    vertical-align: middle;
    position: relative;
}
.contact_box .error {
    margin: 10px 0 0;
}
.contact_box .check_box{
    text-align: center;
    margin: 25px 0 0;
    display: inline-block;
    position: relative;
}
.contact_box .check_box .error{
    position: absolute;
    left: 18px;
    top: 10px;
}
.contact_box .check{
    margin: 0 3px 0 0;
    vertical-align: baseline;
}
.contact_box .check_link a{
    font-size: 1.2rem;
    color: #777;
    text-decoration: underline;
    margin: 0 0 0 40px;
}
.contact_box .submit{
    box-sizing: border-box;
    background: linear-gradient(-135deg, #BFE8FF, #A3E9E9);
    display: block;
    padding: 20px;
    color: #FFF;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    display: block;
    width: 100%;
    border: none;
    outline: none;
    border-radius: 100px;
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    margin: 30px 0 0;
}
.thanks_box{
    background: #FFF;
    position: relative;
    box-shadow: 1px 3px 6px rgba(0,0,0,0.2);
    text-align: center;
    margin: 120px 0;
    padding: 60px 20px;
    color: #3E3E3E;
}
.thanks_box h5{
    font-size: 2.4rem;
    letter-spacing: 0.01em;
    margin: 0 0 40px;
}
.thanks_box p{
    margin: 0 0 40px;
    font-size: 1.6rem;
    line-height: 1.8;
    letter-spacing: 0.01em;
}
.thanks_box a{
    display: block;
    width: 100%;
    box-sizing: border-box;
    border: solid 1px #3E3E3E;
    border-radius: 100px;
    padding: 20px;
    text-align: center;
    font-size: 1.6rem;
    color: #3E3E3E;
}
@media screen and (min-width:320px) and ( max-width: 767px) {
    .thanks_box{
        background: #FFF;
        position: relative;
        box-shadow: 1px 3px 6px rgba(0,0,0,0.2);
        text-align: center;
        margin: 40px 10px;
        padding: 40px 20px;
        color: #3E3E3E;
    }
    .thanks_box a{
        display: block;
        width: 100%;
        box-sizing: border-box;
        border: solid 1px #3E3E3E;
        border-radius: 100px;
        padding: 20px;
        text-align: center;
        font-size: 1.4rem;
        color: #3E3E3E;
    }
}

@media screen and (min-width:320px) and ( max-width: 767px) {
    .contact_box{
        background: #FFF;
        margin: 40px 10px;
        padding: 10px;
        box-shadow: 2px 4px 6px rgba(0,0,0,0.2);
    }
    .contact_box dl{
        display: block;
        width: 100%;
        box-sizing: border-box;
        margin: 0 0 10px;
        padding: 0;
        border-bottom: solid 1px #EAF3F8;
    }
    .contact_box dt {
        display: block;
        background: #EAF3F8;
        text-align: center;
        width: 100%;
        padding: 20px 0;
        vertical-align: middle;
    }
    .contact_box dd {
        display: block;
        padding: 10px 0;
        vertical-align: middle;
    }
    .mw_wp_form_confirm dd{
        padding: 20px 10px;
    }
    .contact_box dd input.ipt01{
        display: block;
        box-sizing: border-box;
        width: 100%;
        padding: 10px;
        font-size: 1.5rem;
        letter-spacing: 0.08em;
        border: solid 1px #ddd;
        border-radius: 4px;
    }
    .contact_box dd input.adnum01{
        display: inline-block;
        box-sizing: border-box;
        width: 90px;
        padding: 10px;
        font-size: 1.5rem;
        letter-spacing: 0.08em;
        border: solid 1px #ddd;
        border-radius: 4px;
    }
    .contact_box dd input.adnum02{
        display: inline-block;
        box-sizing: border-box;
        width: 110px;
        padding: 10px;
        font-size: 1.5rem;
        letter-spacing: 0.08em;
        border: solid 1px #ddd;
        border-radius: 4px;
    }
    .contact_box dd .select_box{
        display: inline-block;
        margin: 0 10px 0 0;
        position: relative;
    }
    .contact_box dd .select_box::after{
        content: "▼";
        display: block;
        position: absolute;
        right: 10px;
        top: 50%;
        transform: translateY(-50%);
        color: #777;
    }
    .mw_wp_form_confirm .select_box::after{
        display: none!important;
    }
    .contact_box dd .select01{
        background: #FFF;
        display: block;
        box-sizing: border-box;
        width: 100%;
        padding: 10px 35px 10px 10px;
        font-size: 1.5rem;
        letter-spacing: 0.08em;
        border: solid 1px #ddd;
        border-radius: 4px;
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
    }
    .contact_box dd .select02{
        background: #FFF;
        display: block;
        box-sizing: border-box;
        width: 100%;
        padding: 10px 25px 10px 10px;
        font-size: 1.5rem;
        letter-spacing: 0.08em;
        border: solid 1px #ddd;
        border-radius: 4px;
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
    }
    .contact_box dd textarea{
        display: block;
        box-sizing: border-box;
        width: 100%;
        min-height: 100px;
        padding: 10px;
        font-size: 1.5rem;
        letter-spacing: 0.08em;
        border: solid 1px #ddd;
        border-radius: 4px;
    }
    .contact_box dd .line{
        display: inline-block;
        vertical-align: top;
        letter-spacing: 0;
        text-align: center;
        margin: 13px 10px 0 10px;
    }
    .contact_box dd .add_box{
        display: inline-block;
        vertical-align: middle;
        position: relative;
    }
    .contact_box .error {
        margin: 10px 0 0;
    }
    .contact_box .check_box{
        text-align: center;
        margin: 25px 0 0;
    }
    .contact_box .check{
        margin: 0 3px 0 0;
        vertical-align: baseline;
    }
    .contact_box .check_link{
        display: block;
    }
    .contact_box .check_link a{
        font-size: 1.2rem;
        color: #777;
        text-decoration: underline;
        margin: 10px 0 0;
        display: inline-block;
    }
    .contact_box .submit{
        box-sizing: border-box;
        background: linear-gradient(-135deg, #BFE8FF, #A3E9E9);
        display: block;
        padding: 20px;
        color: #FFF;
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
        display: block;
        width: 100%;
        border: none;
        outline: none;
        border-radius: 100px;
        font-size: 1.6rem;
        letter-spacing: 0.1em;
        margin: 30px 0 0;
    }
    .contact_box .check_box .error {
        position: static;
        left: 18px;
        top: 10px;
    }
}

