@charset "UTF-8";


/**header--------------------------------------------------------------*/
.header-brand-container:before,.header-brand-container:after {
	content:"";
	clear:both;
	display:block;
}
.lb {
    float: left;
    width: 25%;
	padding-top:15px;
}
.rb {
    float: right;
	text-align:right;
    width: 73%;
}
#headerwrap ul {
	margin:0;
	list-style:none;
}
.box01-hd li,.box02-hd li {
	display:inline-block;
	vertical-align:middle;
	margin-left:7px;
	margin-bottom:10px;
	color: #bebab1;
    font-size: 11px;
	line-height:2;
}
.box01-hd,.box02-hd {
	margin-bottom:0px;
}
#headerwrap #header {
    background: url("../../uploads/header-bg_02.png") no-repeat top left 230px;
	padding-top:0px;
}
.header-brand-container {
	padding-bottom:9px;
}
.header-brand-container {
    display: flex;
    align-items: center;
	justify-content: space-between;
}
.rb .box01-hd{
	padding-top: 20px;
}
/**menu--------------------------------------------------------------*/
#headerwrap #main-menu-container ul {
	list-style:none;
	max-width:1000px;
	margin:0 auto;
	display:flex;
	flex-wrap:wrap;
}
#headerwrap #main-menu-container li {
	float:left;
	margin:0;
	position: relative;
	width:auto;
}
#headerwrap #main-menu-container li:before,#headerwrap #main-menu-container li:last-child:after {
    content: "";
    height: 25px;
    border-left: 1px solid #b4b4b4;
    display: block;
    position: absolute;
    top: 15px;
    left: 0;
}
#headerwrap #main-menu-container li:last-child:after {
	left:auto;
	right:0;
}
#headerwrap #main-menu-container li a {
    font-size: 10px;
    color: #28b579;
    text-decoration: none;
    text-align: center;
    display: block;
    padding: 10px 23px 9px;
    font-weight: 700;
    letter-spacing: 0.2em;
	font-family: "Hiragino Mincho ProN","ヒラギノ明朝 ProN","Hiragino Mincho Pro","ヒラギノ明朝 Pro","Yu Mincho","游明朝","MS PMincho","ＭＳ Ｐ明朝",serif;
}
#headerwrap #main-menu-container li a:before {
    content: attr(title);
    color: #4d4d4d;
    display: block;
    font-size: 16px;
    letter-spacing: 0.15em;
    margin-bottom: 5px;
    font-family: 'Lato', sans-serif;
}
#headerwrap #main-menu-container li:hover a {
	opacity:1;
	text-decoration:none;
	color:#fff36e;
	background:url("../../uploads/ar.png")no-repeat right 2px bottom 2px,#27b578;
}
#headerwrap #main-menu-container li:hover a:before {
	color:#fff;
}
#main-menu-container {
	margin-bottom:22px;
}
#headerwrap #main-menu-container li.nav00 {
	display:none;
}
#headerwrap #main-menu-container li ul {
	display:none;
}
#headerwrap #main-menu-container li:hover ul {
	display:block;
}
#headerwrap #main-menu-container li ul {
    position: absolute;
    float: none;
    top: 60px;
    left: 0;
    z-index: 99;
}

/*sub-menu*/
#headerwrap #main-menu-container li .sub-menu {
  width:100%;
  padding:0;
  border:none;
	
}
#headerwrap #main-menu-container li .sub-menu li {
  	clear:both;
	float:none;
	display:block;
	width:100%;
}
#headerwrap #main-menu-container li .sub-menu li a {
  display:block;
  text-indent:0;
  white-space: unset;
  background: none;
  text-align: center;
	font-size:13px;
    border-bottom: dotted 1px #a8a8a8;
    color: #542d0a;
	padding: 9px 5px 8px;
  text-decoration: none;
  height:auto;
	background-color: rgba(255, 255, 255, 0.9);	
}
#headerwrap #main-menu-container li .sub-menu li a:hover {
	opacity:0.7;
	font-weight:bold;
}


/**footer--------------------------------------------------------------*/
#footerwrap {
    border-top: 1px solid #b4b4b4;
}
#pagewrap .bg-ft {
	background: url("../../uploads/footer-bg_03.png") no-repeat right bottom -20px;
}
.copyright-container {
    background-color: #28b579;
    padding: 20px 0 10px;
}
#footer-nav {
	margin:0;
}
#footer-nav li {
	margin: 0 0 10px;
    padding: 0 10px;
    border-left: 1px solid #fff;
    line-height: 1;
}
#footer-nav li:first-child {
	border:none;
	padding-left:0;
}
.lb-ft {
    float: left;
    width: 70%;
}
.rb-ft {
    float: right;
    width: 28%;
    text-align: right;
}
.box-ft {
    overflow: hidden;
    color: #fff;
}
body #pc-backtop {
    width: auto;
    height: auto;
    right: 20px;
    bottom: 400px;
}
#footerwrap .row_inner {
	max-width:94%;
	margin:0 auto;
}

/**top--------------------------------------------------------------*/
body .site {
	font-size: 13px;
    color: #343434;
    line-height: 2;
	font-family: "メイリオ","ヒラギノ角ゴ ProN W3″", "Hiragino Kaku Gothic ProN",  Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}
.site a:visited,.site a:link {
	color:inherit;
	text-decoration:underline;
	outline:none;
}
.site a:hover {
	color:inherit;
	text-decoration:none;
	opacity:0.7;
}
body .pagewidth {
  max-width: 94%;
}
.module-fancy-heading.module .sub-head:before {
  display: none;
}
.module-fancy-heading .fancy-heading {
  	margin:0;
	line-height: 1.4;
	font-size: inherit;
}
.module-fancy-heading.module .sub-head {
  padding:0;
}
.module .gallery-icon {
  cursor:default;
}
.module .module-title,.main-head,.sub-head,.image-title {
	
}
.module {
	margin-bottom:30px;
}
.module .module-title {
	margin-bottom:15px;
}
.module p:last-child {
	margin-bottom:0;
}
.module ul {
	margin:0;
	list-style:none;
}
.module li {
	line-height:1.7;
}
.module table {
	width:100%;
	border-collapse: collapse;
}
.module,ul,li,a,div,span,.image-title,tr,td,th,input {
	 box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
}
.module_row {
	overflow: hidden;
}
.on-row {
	overflow:unset;
}
/***/

#pagewrap .bg-top {
	background: url("../../uploads/top_03.png") no-repeat,url("../../uploads/top_06.png") no-repeat;
    background-position: left calc((100% - 880px) /2 ) top 50px,right calc((100% - 880px) /2 ) top 60px;
}
#pagewrap .post-top .post-title {
    font-size: 15px;
    color: #f188a7;
    border-bottom: 1px solid #c4b8a2;
    padding: 10px 0 15px;
    margin-bottom: 15px;
    line-height: 1.7;
}
#pagewrap .post-top .post {
	margin-bottom:25px;
}
.t-top .main-head {
	color: #4d4d4d;
    font-size: 18px;
    font-family: 'Lato', sans-serif;
    background: url("../../uploads/post-bg-title_03.png") no-repeat left top 2px;
    padding-bottom: 25px;
	padding-left:38px;
    border-bottom: 1px solid #b4b4b4;
}
.post1-top time {
	font-size: 13px;
    color: #4d4d4d;
	display:inline-block;
	margin-right:12px;
	margin-bottom:0;
}
#pagewrap .post1-top .post-title {
	display: inline-block;
	font-size:14px;
    color: #28b579;
	line-height:2;
	margin-bottom:0;
}
#pagewrap .post1-top .post {
	border-bottom: 1px dotted #afafaf;
	padding:20px 0;
	margin-bottom:0;
}
.img-top.module {
	max-width:600px;
	margin-left:auto;
	margin-right:auto;
}
.row-top {
/* 	max-width:640px; */
	margin:0 auto;
}
body .module-fancy-heading .main-head + .sub-head:before {
    content: "";
    border-top: none;}
/**single--------------------------------------*/
.single .post {
	padding-top:58px;
}
.single .post-image {
	text-align:center;
	margin-bottom:30px;
}
.single .post-title {
	font-size:13px;
    color: #f188a7;
	line-height:2;
}
#pagewrap .history-back-button {
	background: #27b578;
    display: block;
    text-align: center;
    color: #fff;
    text-decoration: none;
    padding: 10px 10px;
    max-width: 250px;
    margin: 0 auto;
}
.history-back-container {
	padding-bottom:80px;
}


/**concept-------p2-----------------------------*/
.img-sub.module {
	margin-bottom:0;
	padding:120px 0;
}
.row-p2 {
	padding: 15px 20px 0;
    border: 1px solid #b8b8b8;
    background: #fff;
	margin-bottom:30px;
}
.t-p2  .main-head {
    font-size: 28px;
    color: #f187a6;
    display: inline-block;
    margin-right: 7px;
}
.t-s1-p2 .main-head {
	color:#28b579;
}
#pagewrap .t-p2 .sub-head {
    font-size: 23px;
    color: #4c4c4c;
    display: inline-block;
}
.t-p2.module {
	border-bottom: 1px solid #c4b8a2;
    padding-bottom: 15px;
	margin-bottom:15px;
	font-family:"Hiragino Mincho ProN","ヒラギノ明朝 ProN","Hiragino Mincho Pro","ヒラギノ明朝 Pro","Yu Mincho","游明朝","MS PMincho","ＭＳ Ｐ明朝",serif;
}

/**p3-----------------------------------------*/
.t-p3 .main-head {
	font-family: 'Lato', sans-serif;
    color: #4d4d4d;
    font-size: 18px;
    border-top: 1px solid #28b579;
    border-bottom: 1px solid #28b579;
    border-left: 10px solid #28b579;
    padding: 11px 0 10px 20px;
}
.t-p3.module,.tab-p3.module,.te-p3.module {
	margin-bottom:15px;
}
.row-p3 {
	background: #fff;
    border: 1px solid #b8b8b8;
    padding: 20px 20px 0;
	margin-bottom:30px;
}
.tab-p3 tr td {
	vertical-align:top;
	padding:10px 5px;
	border-bottom: 1px dotted #afafaf;
}
.tab-p3 tr td:last-child {
	text-align:right;
	min-width:60px;
}
.tab-p3 tr td:first-child {
	color: #f188a7;
    font-weight: 700;
}
.tab-p3.module {
	margin-bottom:15px;
}
.tab-p3.module .module-title {
	text-align: center;
    color: #28b579;
    font-size: 13px;
    margin-bottom: 7px;
}


/**cafe---p5---------------------------*/
.t-p5 .main-head {
	font-size: 23px;
    color: #4c4c4c;
	font-family: "Hiragino Mincho ProN","ヒラギノ明朝 ProN","Hiragino Mincho Pro","ヒラギノ明朝 Pro","Yu Mincho","游明朝","MS PMincho","ＭＳ Ｐ明朝",serif;
	border-bottom: 1px solid #c4b8a2;
    background: url("../../uploads/cafe_12.png")no-repeat left top 2px;
    padding: 0 0 10px 31px;
}
.t-p5.module {
	margin-bottom:15px;
}
.tab-p5.module .module-title {
	background: url("../../uploads/cafe_24.png")no-repeat left center;
    padding-left: 38px;
    font-family: 'Lato', sans-serif;
    color: #4d4d4d;
    font-size: 18px;
}
.tab-p5.module {
	background: #fff1d6;
    padding: 20px;
}
.tab-p5 tr td {
	border-bottom: 1px dotted #afafaf;
    padding: 12px 0;
    color: #4d4d4d;
	vertical-align:middle;
}
.tab-p5 tr td:first-child {
	font-weight:700;
}
.tab-p5 tr td:last-child {
	text-align: right;
}

/**info----------------p6---------------------------*/
.tab-info tr td {
	border-bottom: 1px dotted #afafaf;
    padding: 13px 0;
	vertical-align:top;
}
.tab-info tr td:first-child {
	color: #f188a7;
    font-weight: 700;
    width: 105px;
}



/* =============================================
	mobile menu settings
=============================================　*/
/* Mobile Menu Button */
#menu-button{
	visibility:hidden;
	opacity:0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: fixed;
	z-index: 900;
	top: 10px;
	right: 10px;
	width: 48px;
	height: 48px;
	background-color: rgb(40 181 121 / 70%);
	color:#fff;
}
#menu-button.nav-on {
	visibility:visible;
	opacity:1;
}
#menu-button .ham-lines {
	position: relative;
	margin: 0 auto;
	width: 32px;
	height: 32px;
}
#menu-button .ham-lines span,
#menu-button .ham-lines::before,
#menu-button .ham-lines::after {
	position: absolute;
	display: block;
	right: 0;
	left: 0;
	margin: 0 auto;
	width: 28px;
	height: 2px;
	background-color: #fff;
	border-radius: 1px;
}
#menu-button .ham-lines span {
	bottom: 15px;
	transition: all .25s .25s;
	opacity: 1;
}
#menu-button .ham-lines::before,
#menu-button .ham-lines::after {
	content: "";
}
#menu-button .ham-lines::before{
	bottom: 24px;
	animation: menu-bar01 .75s forwards;
}
#menu-button .ham-lines::after {
	bottom: 6px;
	animation: menu-bar03 .75s forwards;
}
#menu-button .ham-text {
	font-size: 12px;
	line-height: 1;
}
#menu-button.is-active .ham-lines span {
	opacity: 0;
}
#menu-button.is-active .ham-lines::before {
	animation: active-menu-bar01 .5s forwards;
}
#menu-button.is-active .ham-lines::after {
	animation: active-menu-bar03 .5s forwards;
}
@keyframes menu-bar01 {
	0% {
		transform: translateY(9px) rotate(45deg);
	}
	50% {
		transform: translateY(9px) rotate(0);
	}
	100% {
		transform: translateY(0) rotate(0);
	}
}
@keyframes menu-bar03 {
	0% {
		transform: translateY(-9px) rotate(-45deg);
	}
	50% {
		transform: translateY(-9px) rotate(0);
	}
	100% {
		transform: translateY(0) rotate(0);
	}
}
@keyframes active-menu-bar01 {
	0% {
		transform: translateY(0) rotate(0);
	}
	50% {
		transform: translateY(9px) rotate(0);
	}
	100% {
		transform: translateY(9px) rotate(45deg);
	}
}
@keyframes active-menu-bar03 {
	0% {
		transform: translateY(0) rotate(0);
	}
	50% {
		transform: translateY(-9px) rotate(0);
	}
	100% {
		transform: translateY(-9px) rotate(-45deg);
	}
}
/* Mobile Header Menu Container */
nav.nav-off{
	display:none;
}
#main-menu-container.is-active {
    position: fixed;
    z-index: 700;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    overflow-y: auto;
    background: #28b579;
    color: #fff;
    display: block;
}
/* Header Main Menu */
#main-menu-container.is-active .main-menu,
#main-menu-container.is-active .sub-menu {
	margin: 0;
	list-style: none;
}
#main-menu-container.is-active .menu-item {
	margin: 0;
	padding: 8px 0 0 16px;
}
#main-menu-container.is-active .main-menu {
	position: static;
	width: 100%;
	max-width: 94%;
	margin: 0 auto 16px;
	padding: 0;
	border: none;
	border-radius: 0;
	background-color: transparent;
	box-shadow: none;
}
#main-menu-container.is-active .main-menu>li {
	margin: 0 16px;
	padding: 8px;
	border-bottom: dotted 1px #ccc;
}
#main-menu-container.is-active .main-menu>li:last-of-type {
	border-bottom: none;
}
#main-menu-container.is-active .main-menu li a {
	font-size: 16px;
	line-height: 2;
	color: #111;
}
.img-center{
	margin: 0 auto;
}
.post1-top .builder-posts-wrap.list-post {
    overflow-y: scroll;
}
#pagewrap .post-top .post-title a:hover {
    text-decoration: none;
}
#pagewrap .post-top .post-title a {
    text-decoration: underline;
}




@media screen and (max-width: 1024px) { /* mobile visibility changes for max-width */
	#menu-button{
		visibility:visible;
		opacity:1;
	}
	#main-menu-container:not(.is-active){
		display:none;
	}
	
	/**menu**/
	#headerwrap #main-menu-container li a {
		display: block;
		color: #fff;
		padding: 10px;
	}
	#headerwrap #main-menu-container li a:hover {
		opacity:0.7;
	}
	#headerwrap #main-menu-container li {
		float: none;
		text-align: center;
		padding: 0;
	}
	#headerwrap #main-menu-container ul {
		display:block;
		max-width: 94%;
		margin: 0 auto;
		padding: 10% 0;
	}
	#headerwrap #main-menu-container li a:hover, #headerwrap #main-menu-container li.current-menu-item a {
		color: #fff;
	}
	
	
	/**sub*/
	#headerwrap #main-menu-container li .sub-menu {
		position: static;
		display: block;
		width: 100%;
		background: rgb(255 255 255 / 50%);
		padding: 0;
		max-width: 100%;
		margin-top: 0;
	}
	#headerwrap #main-menu-container li .sub-menu li a {
		padding: 5px 0;
		text-decoration: none;
	}
	#headerwrap #main-menu-container li .sub-menu li {
		display: block;
		width: 100%;
		padding: 0;
	}
	#headerwrap #main-menu-container li a:before{
		display: none;
	}
	
	
	
}

/* === mobile menu end === */


/* =============================================

	Media Query

============================================= */


@media screen and (max-width: 1200px) {
	
	.module_row .row_inner {
		max-width: 100%;
	}
}

@media screen and (max-width: 1024px) { 
	
	/**header*/
	#pagewrap .bg-top {
		background-position: left top 5px,top right 5px;
	}
	#headerwrap #main-menu-container li:before, #headerwrap #main-menu-container li:last-child:after {
		display:none;
	}
	#main-menu-container {
		margin-bottom: 0;
	}
	
	/**footer*/
	#pagewrap .sp-footer-icons-container a {
		background:#28b579;
		color:#fff;
		text-decoration:none;
		border-color:#fff;
		min-height:50px;
	}
	.sp-footer-icons-container {
		border-top:1px solid #fff;
		background:none;
	}
	body .sp-footer-icons-container svg {
		fill:#fff;
	}
	#headerwrap #main-menu-container li a{
		font-size: 16px;
	}
	
	
}


@media screen and (max-width: 939px) {
	
}


@media screen and (max-width: 768px) {
	
	/**header*/
	.lb,.rb {
		float: none;
		width: 100%;
		text-align:center;
	}
	#site-logo img {
		max-width:80%;
		margin:0 auto 20px;
	}
	.box01-hd {
		margin-bottom: 5px;
	}
	
	/**footer*/
	.lb-ft,.rb-ft {
		float: none;
		width: 100%;
		text-align:center;
	}
	#footer-nav li:first-child {
		padding-left: 10px;
	}
	#footer-nav {
		text-align: center;
	}
	
}


@media screen and (max-width: 680px) {
	
	
	/**header*/
	#headerwrap #header {
		background-position: center top;
		padding-top: 65px;
		padding-bottom: 30px;
	}
	.box01-hd li, .box02-hd li {
		display: block;
		margin-left: 0;
	}
	#site-logo img{
		margin-bottom: 0;
	}
	
	/***/
	.module-image {
		text-align:center;
	}
	#pagewrap .module-gallery .gallery-item {
		width:49.25%;
		margin: 0 1.5% 1.5% 0;
		float:left;
	}
	#pagewrap .module-gallery .gallery-item:nth-of-type(2n) {
		margin-right:0;
	}
  	#pagewrap .gallery-columns-3 .gallery-item:nth-of-type(3n + 1) {
		clear:none;
	}
	.module .module-gallery-grid {
		display:block;
	}
	
	/*top*/
	#pagewrap .bg-top {
		background-size: 40%;
		padding-top: 20px;
	}
	.post-top .post-image {
		text-align:center;
	}
	.post1-top time {
		display: block;
		margin-right: 0;
	}
	
	/**p2*/
	.img-sub.module {
		padding: 70px 0;
	}
	.t-p2 .main-head {
/* 		display: block; */
		margin-right: 0;
	}
	/* footer */
	#footer-nav{
		display: none;
	}
	.header-brand-container{
		flex-wrap: wrap;
	}
	.module-fancy-heading .main-head + .sub-head:before{
		display: none!important;
	}
	.t-p5 .main-head{
		padding: 0 0 10px 20px;
		font-size: 22px;
	}
	.tab-info tr td:first-child,.tab-info tr td {
		display: block;
		width: auto;
	}
	body .themify_builder_content-263 .tb_6a2x522.module-text{
    text-align: left;
    }
}

.youtube {
	width: 100%;
	aspect-ratio: 16 / 9;
}

.youtube iframe {
	width: 80%;
	height: 80%;
	border-radius: 20px;
}


