@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.2
*/

/************************************
** 子テーマ用のスタイルを書く
************************************/
/*必要ならばここにコードを書く*/

#container{
	display: flex;
	flex-wrap: wrap;
	overflow: hidden;
	visibility: visible;
}
.header{
	margin-bottom: 14px;
}
.header-container{
	width: 360px;
	height: 100%;
	padding-top: 30px;
	position: fixed;
}
.wrap{
	width: 100%;
}
#content {
    position: relative;
    z-index: 2;
    padding-top: 60px;
    min-height: 100vh;
    background-color: #EDEDED;
	padding-top: 0;
	margin-left: 360px !important;
	margin-top: 0;
}
.main{
	background-color: transparent;
}
.footer{
	width: 100%;
}
.navi{
	margin-bottom: 30px;
}
.consultation{
	text-align: center;
	width: 80%;
	margin: 0 auto 1em;
}
.head-tel{
	text-align: center;
	line-height: 1.4;
	margin-bottom: 56px;
}
.head-tel p{
	font-size: 24px;
	margin-top: 0;
	margin-bottom: 0.4em;
}
.head-tel span{
	font-size: 32px;
	font-weight: bold;
}
.head-tel .address{
	font-size: 18px;
}

.item-label{
	border-top: 0px;
	text-align: left;
	width: 100%;
	padding: 0 10px;
	font-size: 20px;
}
.item-label::before{
	content: " ";
	display: inline-block;
	background-image: url(image/arrow.gif);
	background-size: contain;
	vertical-align: middle;
	width: 22px;
	height: 22px;
	margin-right: 18px;
}
.navi-in > ul li{
	width: 100%;
	border-top: 1px dotted #333;
	height: auto;
	box-sizing: border-box;
	padding-left: 20px;
	line-height: 56px;
}
.navi-in > ul li:last-child{
	border-bottom: 1px dotted #333;
}

/*** フロントコンテンツ ***/
#view-home {
	position: relative;
	z-index: 1;
}
.main-image{
	height: 800px;
	overflow: hidden;
	position: relative;
	z-index: 2;
}
.main-image img{
	height: 800px;
	width: 100%;
	object-fit: cover;
}
.catchcopy{
	position: absolute;
	top: 100px;
    left: 50%;
    transform: translate(-50%, 0);
    -webkit-transform: translate(-50%, 0);
    -ms-transform: translate(-50%, 0);
	z-index: 5;
	width: 760px;
}
.catchcopy img{
	width: 100%;
}
.content-view{
	position: relative;
	z-index: 3;
	margin:-300px auto 0;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	width: 100%;
	padding: 0 20px;
	box-sizing: border-box;
	max-width: 1100px;
}
.content-view div{
	width: 32%;
	margin-bottom: 20px;
	padding: 0;
}
.content-view div img{
	width: 100%;
}

.info-title{
	font-size: 40px;
	text-align: center;
	margin-bottom: 24px;
}
.ect-3-columns{
	margin-bottom: 2rem;
}
.ect-3-columns .entry-card-wrap{
	background: #fff;
}
.ect-vertical-card.ect-tile-card .a-wrap {
	border-bottom:3px solid #eee;
}
.ect-vertical-card .entry-card-wrap .entry-card-thumb img{
	height: 200px;
	object-fit: cover;
}
.ect-vertical-card .entry-card-wrap .entry-card-thumb{
	margin-bottom: 0.2rem;
}
.post-area{
	margin-bottom: 4em;
}
.post-area .button{
	padding: 10px 10px;
	margin: 0 auto;
	text-align: center;
	background: #3D3D3D;
	border-radius: 30px;
	width: 300px;
	box-sizing: border-box;
	color: #fff;
	font-size: 1.5rem;
}
.post-area .button a{
	color: #fff;
	text-decoration: none;
}
.cat-label{
	right: 0.3em !important;
	left: inherit;
	background: #fff;
	color: #3d3d3d;
}
.e-card-info{
	justify-content: flex-start;
}
.member { width:94%; margin:0 auto 50px; background-color:#fff; }
.member table { width:100%; font-size:13px; }
.member-boshu { width:90%; margin:0 auto 70px; text-align:center; }
.member-boshu h4 { font-size:24px; }
.member-boshu img { margin: 15px auto 10px; border-radius:20px; }
.member-boshu p { font-size:15px; }

/*フッター ---------------------------------*/
.footer-contact{
	display: flex;
	background-color: #fff;
	border-radius: 8px;
	justify-content: space-between;
	width: 100%;
	padding: 20px 0;
	flex-wrap: wrap;
	margin-bottom: 1.5rem;
}
.item-tel,
.item-mail{
	width:49.8%;
	text-align: center;
	box-sizing: border-box;
	padding: 30px;
}
.item-tel a,
.item-mail a{
	text-decoration: none;
	color: #000;
	font-size: 26px;
	display: block;
	line-height: 1.6;
	text-align: center;
}
.item-tel p,
.item-mail p{
	margin: 0 auto;
}
.item-tel{
	border-right:1px solid #ccc;
}
.tel {
	font-size: 46px;
	color: #3D62AC;
	font-weight: bold;
}
.mail{
	font-size: 28px;
	color: #fff;
	background-color: #3D62AC;
	padding: 4px;
	margin-top: 8px !important;
	max-width: 348px;
	border-radius: 30px;
	display: block;
	text-align: center;
}
.footer-bottom{
	padding-left: 1.8em;
	margin-top: 0;
}
.f-info{
	font-size: 28px;
}
.f-info p{
	line-height: 1.4;
	margin: 0;
}
.add{
	font-size:18px ;
	margin-bottom: 1em;
}
.copy{
	font-size: 18px;
	line-height: 1.4;
}

/* ページコンテンツ---------------------------------------*/
.entry-content{
	background:#fff;
	padding: 4.5rem 2.5rem 2.5rem;
}
.page-header{
	position: relative;
	height: 280px;
	width: 100%;
	overflow: hidden;
	z-index: 20;
}
.breadcrumb{
	margin-bottom: 1rem;
}
.eye-catch-wrap{
	position: relative;
	left: 0;
	top: 0;
	z-index: 21;
}
.page-header h1{
	position: absolute;
    top: 46%;
    left: 50%;
	width:480px;
	text-align:center;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
	z-index: 22;
	padding: 30px 40px;
	background-color:rgba(255,255,255,0.85);
	font-size: 2.4rem;
	font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "ＭＳ 明朝", serif;
}
.article h2 {
	font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "ＭＳ 明朝", serif;
  position: relative;
  display: inline-block;
	margin: 0 auto 1em;
	left: 50%;
    transform: translate(-50%, 0%);
    -webkit-transform: translate(-50%, 0%);
    -ms-transform: translate(-50%, 0%);
	font-size: 2.6rem;
	font-weight: normal;
	background:none;
}
.article h2::before {
  content: "";
  position: absolute;
  background: #a9e1ff;
  width: 100px;
  height: 100px;
  border-radius: 50%;
  top: 50%;
  border: dashed 1px white;
  left: 50%;
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  z-index: -1;
  box-shadow: 0px 0px 0px 5px #a9e1ff;
}
.article h3 {
    color: #2d704b;
font-size: 2rem;
font-family: 'Amiri', serif;
letter-spacing: 0.15em;
margin:34px auto 30px;
padding-left: 72px;
position: relative;
	border: none;
}
.article h3::before {
    content: '';
position: absolute;
top: 50%;
left: 0;
width: 50px;
height: 1px;
background: #2d704b;
	
}
/************************************
** レスポンシブデザイン用のメディアクエリ
************************************/
/*1023px以下*/
@media screen and (max-width: 1023px){
  .header-container{
	width: 320px;
	height: 100%;
	position: fixed;
}
#content {
    position: relative;
    z-index: 2;
    padding-top: 60px;
    min-height: 100vh;
    background-color: #EDEDED;
	padding-top: 0;
	margin-left: 320px !important;
	margin-top: 0;
}
	.entry-content{
	padding: 4.5rem 2rem 2rem;
	}
	.page-header h1{
		font-size: 2.2rem;
	}
	.catchcopy{
		width: 85%;
	}
	.ect-vertical-card .entry-card-wrap .entry-card-thumb img{
	height: 140px;
	object-fit: cover;
}
}

/*834px以下*/
@media screen and (max-width: 834px){
   .ect-3-columns .entry-card-wrap{
	width: 48%;
	background: #fff;
	   margin: 0 1% 0.8em!important;
}
	.ect-3-columns{
		justify-content: space-between;
		margin: 0;
		padding: 0;
	}
	.header-container{
		width: 100%;
		position: relative;
		height: auto;
	}
	#content{
		margin-left: 0 !important;
	}
	.page-header h1{
		font-size: 1.8rem;
		padding: 24px 30px;
	}
	.article h2 {
	font-size: 1.8rem;
	font-weight: normal;
	background:none;
}
.article h2::before {
  content: "";
  position: absolute;
  background: #a9e1ff;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  top: 50%;
  border: dashed 1px white;
  left: 50%;
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  z-index: -1;
  box-shadow: 0px 0px 0px 5px #a9e1ff;
}
	.article h3 {
		font-size: 1.5rem;
	}
	.entry-content{
	padding: 4.5rem 1.7rem 1.7rem;
}
	.consultation{
		display: none;
	}
	.head-tel{
		display: none;
	}
	.main-image{
	height: 230px;
	}
	.main-image img{
	height: auto;
	width: 100%;
	object-fit: contain;
}
	.catchcopy{
		top: 24px;
		width: 75%;
	}
	.content-view{
		margin-top: -50px;
	}
	.content-view div{
	width: 48%;
	margin-bottom: 20px;
}
	.footer-contact{
	padding: 0 20px;
	flex-wrap: wrap;
	box-sizing: border-box;
}
	.item-tel{
	border-right:0px solid #666;
	border-bottom:1px solid #666;
}
	.item-tel,
	.item-mail{
		width: 100%;
	}
	.ect-vertical-card .entry-card-wrap .entry-card-thumb img{
	height: 200px;
	object-fit: cover;
}
	
}

/*480px以下*/
@media screen and (max-width: 480px){
	.page-header { height:160px; }
	.entry-content { padding-top:2rem; }
	.page-header h1 { font-size:1.6rem; }
	.content-view div { margin-bottom:5px; }
	.info-title { font-size:32px; }
	.content-view { padding: 0 12px; }
	main.main, div.sidebar { padding:12px; }
	.ect-3-columns .entry-card-wrap{
		height: 290px;
	}
	.item-tel p, .item-mail p {
		font-size:18px;
	}
	.item-tel p span, .item-mail p span {
		font-size:28px;
	}
	.add { font-size:16px; }
	.copy { font-size:16px; }

}
