@charset "utf-8";

/* -------------------------------------------- */
/* ▼タブレット用デザインとして付け足すデザイン */
/* -------------------------------------------- */

@media screen and (min-width:480px){}

@media (max-width: 768px) {

	.hidden-phone{
		display: none!important;
	}
	.visible-phone{
		display: block!important;
	}

	body {
		-webkit-text-size-adjust: 100%;
		margin: 0;
	}
	.page_body{
		padding-top: 70px;
	}
	.content{
		width: 100%;
	}
	.inner{
		padding:0 10px;
	}
	header{
		/* position: relative; */
		height: 70px;
		padding-top: 0;
	}
	header .nav{
		/* display: none; */
		position: fixed;
    top: 0;
    right: -500px;
    width: 100%;
    height: 100%;
    padding-top: 70px;
    background:#000;
    font-size: 16px;
    box-sizing: border-box;
		z-index: 2;
		opacity: 0.95;
	}
	header li+ li{
		border-left: none;
	}
	header .logo{
		float: none;
		position: absolute;
		left: 10px;
		top: 8px;
		z-index: 9;
		width: auto;
	}
	/* header .logo h1{
		padding: 0;
	} */
	header .logo h1 img{
		width: 35px;
	}
	header .menuBtn{
		/* float: right; */
		position: absolute;
		right: 10px;
		top: 20%;
		z-index: 9;
		font-size: 0;
	}
	header .menuBtn.open{
		top: 15px;
	}
	header .menuBtn.open img{
		width: 25px;
	}
	header .telBtn{
		/* float: right; */
		position: absolute;
		right: 50px;
		top: 5px;
		z-index: 9;
	}
	header .menuBtn img{
		width: 40px;
	}
	header ul{
		margin: 0 10px;
		/* border-top: 1px solid #ccc; */
	}
	header li{
		display: block;
		border-bottom: 1px solid #ccc;
	}
	header li a {
    font-size: 1.6rem;
    padding: 10px 0;
	}
	header li a span{
		font-size: 1.2rem;
	}




	/* footer */

	footer .footBox{
		width: 100%;
	}
	footer .boxInner{
		flex-direction: row-reverse;
		position: relative;
		margin-bottom: 20px;
	}

	footer .copy{
		padding: 5px;
	}
	footer .copy p{
		font-size: 1rem;
	}
	footer .footNav ul{
		display: block;
		text-align: left;
	}
	footer .footNav li{
		display: block;
		line-height: 1.2em;
	}
	footer .footNav li a{
		border: none;
		padding: 0;
		font-size: 1.2rem;
	}
	footer .footNav li.sns{
		position: absolute;
    right: 0;
    bottom: -5px;
	}
	footer .add,
	footer .tel{
		font-size: 1.2rem;
	}
	#page-top a{
		padding: 5px;
		font-size: 0;
	}
	#page-top img{
		width: 25px;
	}
	/* mainvisual */

	.mainVisual{
		margin-bottom: 10px;
	}
	.mainVisual p{
		z-index: 9;
		font-size: 12px;
		padding: 5px;
		width: 90%;
	}
	.mainVisual p span{
		font-size: 1.9rem;
		padding: 0;
	}
	.flexslider .slides{
		height: 70vh;
	}
	/* .flexslider .slides > li,
	.flexslider .slides img{
		object-fit: contain;
    height: auto;
	} */

	.s1, .s2 {
    margin-bottom: 30px;
	}
	.s2{
		padding: 30px 0;
	}
	.s4{
		padding: 10px 0 30px;
	}
	.s1 li, .s2 li{
		display: block;
	}
	.s2 li.reverse{
		margin-bottom: 0;
	}
	.s1 .is_txt, .s2 .is_txt{
		padding-left: 0;
		width: 100%;
	}
	.s1 .is_txt p, .s2 .is_txt p{
		font-size: 1.4rem;
		letter-spacing: 1px;
	}
	.s1 .is_img, .s2 .is_img{
		width: 100%;
	}
	.s1 .is_img img, .s2 .is_img img{
		height: 150px;
    width: 100%;
    object-fit: cover;
	}
	.s1 h3, .s2 h3{
		font-size: 1.6rem;
	}
	.s1 .flex.reverse .is_txt, .s2 .flex.reverse .is_txt{
		padding:5px 0 0 0;
	}
	.s2 .is_txt p.title{
		font-size: 2.4rem;
	}
	.titleB{
		font-size: 2.4rem;
		text-align: left;
		margin-bottom: 15px;
	}
	.titleB span{
		font-size: 1.6rem;
	}

	.cardGroup{
		width: 100%;
		display: block;
	}
	.card{
		width: 100%;
	}
	.cardGroup > :nth-child(2n){
		margin-left: 0;
		margin-top: 10px;
	}
	.cardGroup > :nth-child(n+3){
		margin-top: 10px;
	}
	.card .txtArea{
		padding: 15px 10px 10px;
		text-align: left;
	}
	.card .tit{
		font-size: 1.6rem;
		text-align: center;
	}
	.card figure{
		padding:15px 0 0;
	}
	.card figure img{
		height: 90px;
	}
	.card p{
		letter-spacing: 1px;
    text-align: justify;
	}

	.s4 .titleB span{
		display: inline-block;
		font-size: 1.4rem;
    padding-left: 15px;
	}
	.s4 .faqBox{
		display: block;
	}
	.s4 dl{
		width: 100%;
	}
	.s4 dl:nth-child(2n){
		margin-left: 0;
	}
	.s4 dt{
		font-size: 1.4rem;
	}
	.s4 dd{
		margin-left: 1em;
		margin-bottom: 1em;
		font-size: 1.4rem;
    letter-spacing: 0.5px;
    text-align: justify;
	}

	/* entry */
	.is_entry .content{
		padding: 0 0 30px;
	}
	.is_entry .titBox{
		margin: 10px 10px 15px;
    padding: 20px 0;
		width: 100%;
	}
	.is_entry .titBox p{
		font-size: 2.6rem;
	}
	.is_entry .entry_table th, .is_entry .entry_table td{
		padding-top: 15px;
		padding-bottom: 15px;
		font-size: 1.4rem;
    letter-spacing: 1.2px;
		line-height: 1.4em;
		border-bottom: 1px solid #bbb;
	}
	.is_entry .s1{
		padding: 10px;
	}
	.is_entry .entry_table th{
		width: 30%;
	}
	.is_entry .form{
		margin-bottom: 0;
	}

}
