@charset "utf-8";

/*
Theme Name: Theme Name: 浅草観音うら振興会 公式サイト
Version: 1.0
*/




/*==========================================
 General
===========================================*/

:root {
	--key-color: #0064e7;
	--font: "Zen Kaku Gothic New", sans-serif;
	--text-color: #646464;
}

#loading {
	width: 100vw;
	height: 100vh;
	background: #fff;
	z-index: 9999;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	transition: all 1s ease-out;
}

#loading span {
	position: absolute;
	left: 50%;
	top: 50%;
	margin-left: -25px;
	margin-top: -25px;
	width: 50px;
	height: 50px;
	border: 1px solid #0064e7;
	border-right: 1px solid transparent;
	border-radius: 30px;
	animation: loading 1s linear infinite;

}


@keyframes loading {
	to {}

	from {
		transform: rotate(360deg);
		transform-origin: 50% 50%;
	}

}





html {
	font-size: 62.5%;
	-webkit-overflow-scrolling: touch;
	height: 100%
}

body {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 500;
	font-style: normal;
	margin: 0;
	padding: 0;
	width: 100%;
	-webkit-font-smoothing: antialiased;
	-webkit-text-size-adjust: 100%;
	-webkit-overflow-scrolling: touch;
	color: #646464;
	font-size: 1.6rem;
	background: #f8f8f4;
}


@media only screen and (max-width: 768px) {
	body {
		min-width: inherit;
	}
}

a {
	color: #2D2920;
	text-decoration: none;
}

a:link {
	color: #2D2920
}

a:visited {
	color: #2D2920
}

a:hover {
	color: #2D2920;
	text-decoration: underline;
}

a:active {
	color: #2D2920
}

a.btn {
	padding: 10px 20px;
	font-size: 2rem;
	font-weight: 600;
	color: #8bc5d8;
	text-align: center;
	cursor: pointer;
	width: 100%;
	max-width: 300px;
	display: block;
	margin: 0 auto;
	border: 4px solid #8bc5d8;
	transition: all 0.2s linear;
	box-sizing: border-box;
}

a.btn:hover {
	background: #8bc5d8;
	text-decoration: none;
	color: #FFF;
}

p {
	font-size: 1.6rem;
	text-align: left;
	color: #646464;
	line-height: 2;
	margin-bottom: 40px;
	font-weight: 500;
}

p.small {
	font-size: 1.5rem;
	text-align: left;
	line-height: 2;
	margin-bottom: 30px;
}

p.center {
	text-align: center !important;
}

p.last-sentence {
	margin-bottom: 60px;
}

.x-small {
	font-size: 1.3rem;
	line-height: 1.3;
}

p.last-sentence {
	margin-bottom: 60px !important;
}

p.center {
	text-align: center;
}

p.underline {
	text-decoration: underline;
}

.align-left {
	text-align: left !important;
}

.align-right {
	text-align: right !important;
}

.center {
	text-align: center;
}

br.sp-none {
	display: block;
}

br.pc-none {
	display: none;
}

@media only screen and (max-width: 768px) {
	p {
		font-size: 1.5rem;
		line-height: 1.8;
		text-align: left;
	}

	p.last-sentence {
		margin-bottom: 40px !important;
	}

	p.center {
		text-align: left !important;
	}

	br.sp-none {
		display: none;
	}

	br.pc-none {
		display: block;
	}
}



/*==========================================
text
===========================================*/
h1,
h2,
h3,
h4 {
	font-family: var(--font);
}

h1 {
	width: 100%;
	letter-spacing: 0em;
	font-size: 3.4rem;
	color: var(--key-color);
	font-weight: 600;
	display: inline-block;
	text-align: center;
	line-height: 1;
	height: 1.6em;
	background-image: url("images/h1_bg.png");
	background-repeat: repeat-x;
	margin-top: 120px;
	color: #fff;
	padding-top: 16px;
	margin-bottom: 48px;
}



h2 {
	color: var(--key-color);
	display: block;
	text-align: center;
	margin: 0 auto 0;
	margin-bottom: 36px;
	font-weight: 600;
	position: relative;
	font-size: 3.4rem;
	line-height: 1;
}


h2.animation-box {
	opacity: 0;
	transform: translateY(30px);
	transition: all 1s ease;
}

h2.animation-box.active {
	opacity: 1;
	transform: translateY(0);
}

.home h2 {
	margin-bottom: 60px;
}



h3 {

	font-size: 2.8rem;
	letter-spacing: 0.05em;
	font-weight: normal;
	color: #2D2920;
	text-align: left;
	margin: 0 auto 40px;
	display: block;
	font-weight: 600;
}

h4 {

	font-size: 1.8rem;
	letter-spacing: 0.05em;
	font-weight: normal;
	color: #2D2920;
	text-align: left;
	margin: 0 auto 20px;
	display: block;
	font-weight: 600;
}

@media only screen and (max-width: 1200px) {
	html[lang="en"] h1 {
		font-size: 3rem;
	}
}

@media only screen and (max-width: 768px) {
	h1 {
		height: 40px;
		margin-bottom: 30px;
		font-size: 2.2rem;
		margin-top: 100px;
	}

	html[lang="en"] h1 {
		font-size: 2rem;
	}


	h2 {
		font-size: 2.4rem;
		line-height: 1.4;
	}

	.home h2 {
	margin-bottom: 30px;
}

	h3 {
		margin: 0 auto 30px;
		font-size: 2rem;
	}

	h4 {
		font-size: 1.8rem;
		font-weight: 500;
	}

	h1::after {
		top: 40px;
		height: 3px;
	}
}

.animation-box {
	opacity: 0;
	transform: translateY(30px);
	transition: all 1s ease;
}

.animation-box.active {
	opacity: 1;
	transform: translateY(0);
}


/*==========================================
 header
===========================================*/
.header-top {
	width: 100%;
	top: 0;
	left: 0;
	z-index: 700;
	position: absolute;
}



.header-top #head-inner {
	margin: 0 auto;

}

.header-top .socialLink {
	top: 4vw;
	right: 148px;
	text-align: right;
	display: flex;
	justify-content: right;
	position: absolute;
}

.header-top .socialLink div {
	margin-left: 25px;

}






@media only screen and (max-width: 768px) {
	.header-top {
		padding-top: 0;
		padding-bottom: 0;
		top: 0;
		left: 0;
		width: 100%;

	}

	.header-top #head-inner {
		padding: 20px 0 10px;
		min-width: auto;
	}

	.header-top .socialLink {
		top: 48px;
		right: 75px;
	}

	.header-top .socialLink div {
		margin-left: 12px;

	}

	.header-top .socialLink div.youtube {
		width: 35px;
		height: auto;
		margin-top: 2px;
	}

	.header-top .socialLink div.fb {
		width: 30px;
		height: auto;
	}

	.header-top .socialLink div img {
		width: 100%;
		height: auto;
	}

}

.header-common {
	width: 100%;
	top: 0;
	left: 0;
	z-index: 700;
	position: absolute;
	height: 124px;
	background-image: url("images/partition.png");
	background-repeat: repeat-x;
}

.header-common #head-inner {
	margin: 0 auto;

}

.header-common .logo {
	margin: 48px 0 22px 60px;

}

.header-common .socialLink {
	top: 57px;
	right: 148px;
	text-align: right;
	display: flex;
	justify-content: right;
	position: absolute;
}

.header-common .socialLink div {
	margin-left: 25px;

}

@media only screen and (max-width: 768px) {
	.header-common {
		height: 100px;
	}

	.header-common .logo {
		margin: 46px 0 22px 20px;
		width: 240px;
	}

	.header-common .logo img {
		width: 100%;
		height: auto;
	}

	.header-common .socialLink {
		top: 48px;
		right: 75px;
	}

	.header-common .socialLink div {
		margin-left: 12px;

	}

	.header-common .socialLink div.youtube {
		width: 35px;
		height: auto;
		margin-top: 2px;
	}

	.header-common .socialLink div.fb {
		width: 30px;
		height: auto;
	}

	.header-common .socialLink div img {
		width: 100%;
		height: auto;
	}

}

@media only screen and (max-width: 480px) {

	.header-common .logo {
		margin: 50px 0 22px 20px;
		width: 180px;
	}
}



.gtranslate_wrapper {
	top: 4vw;
	left: 60px;
	position: absolute;
}

.header-common .gtranslate_wrapper {
	top: 10px;
	right: 50px;
	left: unset;
	position: absolute;
}

.gtranslate_wrapper a {
	position: relative;
	padding-right: 0.4em;
	margin-right: 0.2em;
	color: #0064e7;
}

.gtranslate_wrapper a:not(:last-of-type)::after {
	content: "|";
	position: absolute;
	right: 0;
	color: #0064e7;
}

.gtranslate_wrapper a:last-child::after {
	display: none;
}

.gtranslate_wrapper.is-select-mode a {
	display: none;
}

.gtranslate_wrapper .gtr-select {
	font-size: 16px;
	/* iOS拡大対策 */
	padding: .2em .5em;
	margin-top: 10px;
}



html &[lang="en"] .gtranslate_wrapper.en .vertical-box p {
	writing-mode: unset;
	-ms-writing-mode: unset;
}


@media only screen and (max-width: 768px) {
	.gtranslate_wrapper {
		top: 10px;
		right: 12px;
		left: unset;
		position: absolute;
	}

	.header-common .gtranslate_wrapper {

		right: 12px;

	}

	.gtranslate_wrapper a {
		font-size: 1.3rem;
	}

	.gtranslate_wrapper a:not(:last-of-type)::after {
		top: 3px;
	}
}



.is-ios-safari .ios-safari-translate-note {
	text-align:left;
	padding:0 30px;
	line-height:1.4;
	font-size:1.4rem;
	color:#646464;
  display: block;
  box-sizing:border-box;
  margin-bottom:30px;
}

.ios-safari-translate-note {
  display: none;
}





/*==========================================
 ナビゲーション
===========================================*/




.menu {
	position: fixed;
	right: 60px;
	top: 3vw;
	padding: 0;
	width: 60px;
	height: 60px;
	cursor: pointer;
	z-index: 900;
	opacity: 1;
}

.menu img {
	width: 100%;
	height: auto;
}

.header-common .menu {
	top: 43px;
}


@media only screen and (max-width: 980px) {
	.menu {
		top: 2.7vw;
	}
}

@media only screen and (max-width: 768px) {
	.menu {
		right: 20px;
		top: 43px;
		width: 40px;
		height: 40px;
	}
}



nav#nav {
	position: fixed;
	top: 0;
	left: 0;
	opacity: 0;
	transition: all 0.8s;
	width: 100%;
	height: 100%;
	text-align: center;
	padding: 40px;
	z-index: 999;
	display: block;
	box-sizing: border-box;
	background-image: url("images/menu_bg.png");
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
}



nav#nav.active {
	opacity: 1;
	visibility: visible !important;
}




#nav ul#g-navi {
	width: 100%;
	margin-top: 15vh;
	display: flex;
	flex-flow: column;
	z-index: 2;

	justify-content: center;
}

#nav ul#g-navi li {
	color: #fff;
	font-size: 3.2rem;
	font-size: 2.2vw;
	margin-bottom: 50px;
	display: block;
	font-weight: 600;
	text-align: center;

}

#nav ul#g-navi li:last-child {
	margin-left: 0 !important;
}


#nav ul#g-navi li a {
	text-decoration: none;
	transition: .15s ease-in-out;
	color: #fff;
}

#nav ul#g-navi li a:hover {
	opacity: 0.5;
}



@media only screen and (max-width: 768px) {



	#nav #nav-wrap {
		width: 100%;
		padding: 100px 5%;
	}

	#nav .nav-logo {
		display: none;

	}

	#nav ul#g-navi {
		width: 100%;
		top: inherit;
		left: inherit;
		margin-left: 0;
		text-align: center;
		display: block;
		position: relative;
		margin: 100px auto;
	}

	#nav ul#g-navi li {
		font-size: 2.2rem;
		margin-bottom: 40px;
	}

	#nav ul#g-navi li .menu-close {
		width: 30px;
		height: 30px;
	}

}

@media only screen and (max-width: 375px) {
	#nav ul li {}
}




/* Go Page Top
================================================== */
#page-top {
	border-radius: 50%;
	height: 40px;
	width: 40px;

	background: #0064e7;
	position: fixed;
	bottom: 30px;
	right: 20px;
	text-align: center;
	cursor: pointer;
	z-index: 500;
}

#page-top::after {
	position: absolute;
	content: '';
	width: 9px;
	height: 9px;

	border-top: solid 2px #fff;
	border-right: solid 2px #fff;
	top: 17px;
	left: 15px;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
	cursor: pointer;
}

@media only screen and (max-width: 768px) {
	#page-top {
		display: none;
	}
}




/*footer
================================================== */

footer {
	width: 100%;
	box-sizing: border-box;
	padding: 22px 30px 60px;
	margin: 0 auto;
	text-align: center;
	background: #001d5c
}

footer .foot-title {
	width: 100%;
	max-width: 1100px;
	margin: 0 auto;
	margin-bottom: 50px;
}

footer .foot-title img {
	width: 100%;
	height: auto;
}

footer .foot-logo {
	width: 100%;
	max-width: 105px;
	margin: 0 auto 25px;
}

footer .foot-logo img {
	width: 100%;
	height: auto;
}

footer .foot-navi {
	margin: 0 auto 35px;
	display: flex;
	justify-content: center;
}

footer .foot-navi li {
	padding: 0 19px;
	font-size:1.8rem;
}

footer .foot-navi li a {
	color: #fff;
}

footer .copyright {
	color: #fff;
}


@media only screen and (max-width: 768px) {

	footer .foot-title {
		margin-bottom: 30px;
	}

	footer .foot-navi {
		flex-flow: column;
		margin: 0 auto 30px;
	}

	footer .foot-navi li {
		font-size: 1.3rem;
		margin-bottom: 20px;
	}

	footer .foot-logo {
		max-width: 80px;
		margin: 0 auto 30px;
	}

	footer .copyright {
		font-size: 1.4rem;
	}


}

/*  top main image
================================================== */
.topVisualWrapper {
	width: 100%;
	position: relative;
	height: 100%;
	margin: 0 auto;
	opacity:0;
	transition: all 2s ease;
}

.topVisualWrapper.active {
	opacity:1;
	
}


.topVisualWrapper .title-en {
	position: absolute;
	bottom: 3%;
	left: 50vw;
	margin-left: -40vw;
	width: 80vw;
	height: auto;
}

.topVisualWrapper .title-en img {
	width: 100%;
	height: auto;
}


.topVisualWrapper img.bg {
	width: 100%;
	height: auto;
	vertical-align: bottom;
}

.topVisualWrapper.fixed {
	padding-top: 60px;
}




@media only screen and (max-width: 768px) {
	.topVisualWrapper .title-en {
	margin-left: -27vw;
	width: 54vw;
	height: auto;
		bottom:20%;

	}
}




/*Fixed bg
================================================== */


.fixed-bg {
	width: 100vw;
	height: 90vh;
	background-size: cover;
	background-attachment: fixed;
	background-repeat: no-repeat;
	background-position: center center;
}

.fixed-bg-1 {
	background-image: url("images/bg_section1.jpg");
}

.fixed-bg-2 {
	background-image: url("images/bg_section2.jpg");
}




@media only screen and (min-width: 1360px) {
	.fixed-bg {

		background-size: cover;

	}
}

@media only screen and (max-width: 768px) {
	.fixed-bg {

		background-attachment: scroll;

	}
}




/*==========================================
 Contents
===========================================*/


/*Layout
================================================== */
#contentsArea {
	width: 100%;
	padding-top: 0;
}

#contentsArea section {
	position: relative;
	padding: 0 30px 0;
	box-sizing: border-box;
	width: 100%;
	max-width: 1100px;
	margin: 0 auto;
}

.single-post #contentsArea section,
.single-members #contentsArea section {
	padding: 0 30px 120px;
}

.home #contentsArea section {
	padding: 60px 30px 65px;
}

#contentsArea .wfull {
	width: 100%;
	box-sizing: border-box;
}


#contentsArea .w980 {
	width: 100%;
	max-width: 1020px;
	margin: 0 auto;
}

#contentsArea .w900 {
	width: 100%;
	max-width: 900px;
	margin: 0 auto;
}

#contentsArea .w800 {
	width: 100%;
	max-width: 840px;
	margin: 0 auto;
}


.partition {
	width: 100%;
	height: 120px;
	margin: 0 auto;
	background-image: url("images/partition.png");
	background-repeat: repeat-x;
}

.partition-end {
	width: 100%;
	height: 120px;
	margin: 0 auto;
	background-image: url("images/partition_bottom.png");
	background-repeat: repeat-x;
}

















@media screen and (max-width: 768px) {

	#contentsArea section {
		padding: 0 20px 30px 20px;
	}

	.home #contentsArea section {
	padding: 30px 30px 60px;
}

	.single-post #contentsArea section,
	.single-members #contentsArea section {
		padding: 20px 20px 75px;
	}

	#contentsArea .w900 {
		width: inherit;
	}

	#contentsArea .w800 {
		width: inherit;
	}

	.fl-box .fl-box-left {
		float: none;
		width: 100%;
		margin-right: 0;
	}

	.fl-box .fl-box-right {
		width: 100%;
		text-align: center;

	}

	.fl-box-half {
		width: 100%;
	}

	.fl-box-half-left {
		width: 100%;
		float: none;
	}



}

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

	.fullImg {
		margin-bottom: 80px;
	}

	.fullImg div {
		width: 100%;
		float: none;
		margin-bottom: 30px;
		text-align: center;
	}

	.fullImg div img {
		width: 96%;
		margin: 0 auto;
	}



}


ul.column3 {
	width: 100%;
	margin-bottom: 50px;
	font-size: 0;
	flex-wrap: wrap;
	display: flex;
	justify-content: space-between;
}

ul.column3 li {
	width: 31%;
	text-align: left;
	vertical-align: top;
	color: #222;
	position: relative;
	display: inline-block;
	font-size: 1.8rem;
	margin-bottom: 60px;
	list-style-type: none;
	padding: 0;
}

.home ul.column3 li {
	margin-bottom: 20px;
}

ul.column3::after {
	width: 28%;
	content: "";
	display: block;
	height: 0;
}

ul.column3 li::before {
	display: none;
}


ul.column3 li img {
	width: 100%;
	height: auto;
	margin-bottom: 15px;
}

ul.column3 li a {
	text-decoration: none;
}

ul.column3 li a img {
	text-decoration: none;
	transition: all 0.5s linear;
	opacity: 1;
}

ul.column3 li a:hover img {
	opacity: 0.8;
}

ul.column3 .infoWrapper .type {
	font-size: 1.6rem;
	color: #646464;
	margin-bottom: 5px;
	display: block;
}

.page-template-archive-members ul.column3 .infoWrapper .title {
	font-size: 2.4rem;
	color: #323232
}





ul.column3 .infoWrapper .date {
	color: #646464;
	display: block;
	margin-bottom: 10px;
	font-size: 1.6rem;
}


ul.column3 .infoWrapper .title {
	font-size: 1.6rem;
	line-height: 2;
	color: #646464;
	font-weight: 500;
	margin-bottom: 10px;
}




@media only screen and (max-width: 480px) {
	ul.column3 {
		flex-direction: column;
		text-align: center;
		margin-bottom: 0;
	}

	ul.column3 li {
		width: 100%;
		max-width: inherit;
		text-align: center;
		padding: 0;
		margin: 0 auto 30px;

	}

	ul.column3 li:last-child {
		margin-bottom: 0;

	}

	ul.column3 li .infoWrapper {
		margin: 0 auto;
		text-align: left;
		margin-bottom: 30px;
	}

	ul.column3 .infoWrapper .date {

		font-size: 1.5rem;
	}

	ul.column3 .infoWrapper .title {
		line-height: 1.6;
		font-size: 1.5rem;
	}



}


.top-img-column {
	width: 100%;
	display: flex;
	justify-content: space-between;
	margin-bottom: 70px;
	flex-shrink: 1;
}


.top-img-column div img {
	width: 100%;
	height: auto;
	vertical-align: bottom;
}



@media only screen and (max-width: 480px) {
	.top-img-column {
		flex-flow: column;
		margin-bottom: 50px;
		flex-shrink: unset;
	}

	.top-img-column-4 {
		flex-flow: wrap;
		flex-shrink: 1;
	}

	.top-img-column-4 div {
		width: 50%;
	}
}

/*index news
================================================== */

/*single news
================================================== */
.single-news img:first-child {
	margin-bottom: 35px;
}

.single-news .news-head-img img {
	width: 100% !important;
	height: auto !important;
}

.single-news .date {
	margin-bottom: 40px;
	display: block;
}

.single-news h2 {
	text-align: left;
	font-size: 2.4rem;
	line-height: 1.4;
	margin-bottom: 40px;
}

/* 追加（）editor style css Images */

.post {
	clear: left;
	margin-bottom: 80px !important;

	display: flow-root;
}

.post img.size-medium {
	height: auto;
	width: 100%;
	max-width: 360px;
}

.post img.wp-smiley {
	border: none;
	margin-bottom: 0;
	margin-top: 0;
	padding: 0;
}

.post .alignleft {
	float: left;
	margin: 0.375em 1.75em 1.75em 0;
}

.post .alignright {
	float: right;
	margin: 0.375em 0 1.75em 1.75em;
}

.post .aligncenter {
	clear: both;
	display: block;
	margin: 0 auto 1.75em;
}


@media screen and (max-width:480px) {
	#contentsArea .w800 .post img {
		width: 100%;
		height: auto;
	}
}

@media only screen and (max-width: 768px) {
	.single-news .date {
		margin-bottom: 20px;
		display: block;
	}

	.single-news img:first-child {
		margin-bottom: 20px;
	}

	.single-news h2 {
		font-size: 2rem;
		line-height: 1.4;
		margin-bottom: 20px;
	}

	.post {
		margin-bottom: 50px;
	}
}

/*加盟店個別
================================================== */

.single-members .type {
	margin-bottom: 20px;
	display: block;
}

.single-members h2 {
	text-align: left;
	
}

.single-members .column2-wrap{
	display: flex;
	justify-content: space-between;
	
}

.single-members .column2-wrap:last-child {
	margin-bottom:80px;
}

.single-members .column2-wrap img {
	width: 100%;
	height: auto;
}




.single-members .column2-wrap div {
	width: 48%;
}

.single-members .column2-wrap div a {
	color: #646464;
}

@media only screen and (max-width: 480px) {
	.single-members .column2-wrap {
		flex-direction: column;
		
	}

	.single-members .column2-wrap:last-child {
		margin-bottom: 40px;
	}

	.single-members .column2-wrap div {
		width: 100%;
		margin-bottom: 10px;
	}

	.single-members .column2-wrap div p {
		margin-bottom: 20px;
	}

	.single-members .column2-wrap div img {
		margin-bottom: 20px;
	}

}




/*pegination
================================================== */
ul.pegination {
	list-style-type: none;
	width: 100%;

	display: flex;
	margin: 0 auto;
}

ul.pegination li {
	width: 50%;
	position: relative;
	font-size: 2rem;
	font-family: var(--font-sans-en);


}






ul.pegination li.pegination-left {
	text-align: left;
	position: relative;
	padding-left: 50px;
}



ul.pegination li.pegination-right {
	text-align: right !important;
	position: relative;
	padding-right: 65px;

}

ul.pegination li.pegination-left a,
ul.pegination li.pegination-right a {
	text-decoration: none;
	color: #323232;
}

ul.pegination li.pegination-left a::before {
	position: absolute;
	content: '';
	background: url(images/arrow_left.png) no-repeat !important;
	background-size: 10px 20px !important;
	top: 1px;
	left: 0;
	height: 20px;
	width: 30px;
	display: block;
}



ul.pegination li.pegination-right a::after {
	position: absolute;
	content: '';
	background: url(images/arrow_right.png) no-repeat !important;
	background-size: 10px 20px !important;
	right: -5px;
	top: 1px;
	height: 20px;
	width: 30px;
	display: block;

}

@media only screen and (max-width: 768px) {

	ul.pegination li {
		font-size: 1.6rem;
	}

	ul.pegination li.pegination-left {
		padding-left: 30px;
	}

	ul.pegination li.pegination-right {
		padding-right: 30px;
	}

	ul.pegination li.pegination-left a::before {
		top: -1px;
		left: 0;
	}

	ul.pegination li.pegination-right a::after {

		right: -20px;
		top: -1px;

	}
}







/*WP-pagenavi
--------------------------------------------------- */

.wp-pagenavi {
	color: #fff;
	margin: 0 0 72px;
	text-align: center;
	overflow: hidden;
}

.wp-pagenavi a,
.wp-pagenavi span {
	text-decoration: none !important;
	padding: 6px 14px 8px;
	margin-right: 8px;
	line-height: 1;
	color: #afafaf !important;
	font-size: 2.4rem;
	display: inline-block;
	border: 1px solid #ddd;
}

.wp-pagenavi span.current {

	color: #000 !important;
	padding: 6px 14px 8px;
}

.wp-pagenavi span.pages {
	border: none;
	color: #333 !important;
	font-size: 1.8rem;
}

.wp-pagenavi a.nextpostslink {
	border: none;
}

.wp-pagenavi span.extend {
	color: #333;
	border: none;
	padding: 0;
	background: #fff;
}

.wp-pagenavi a:hover {
	text-decoration: none !important;
	text-decoration: underline;
	background: #ddd;
	color: #000;
	margin-right: 8px;
}

@media only screen and (max-width: 768px) {
	.wp-pagenavi {
		margin-bottom: 40px;
	}

	.wp-pagenavi a,
	.wp-pagenavi span {
		font-size: 1.6rem;
		margin-right: 8px;
		padding: 6px 12px 8px;
	}

	.wp-pagenavi span.current {
		padding: 6px 12px 8px;
	}

	.wp-pagenavi a:hover {
		margin-right: 8px;
	}

	.wp-pagenavi span.pages {

		font-size: 1.6rem;
	}
}

/*==========================================
 植木市、三社祭
===========================================*/


.vertical-txt-column {
	display: flex;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
}

#contentsArea .vertical-txt-column section {
	margin-bottom: 30px;
}

.vertical-box {
	width: 20%;
	display: flex;
	justify-content: flex-end;
}

.vertical-box.vertical-box-right {
	margin-top: 400px;
	justify-content: flex-start;
	align-items: flex-end;
	margin-bottom: 37.2%;
}

.page-template-page-about .vertical-box.vertical-box-right {
	margin-top: 0;
	justify-content: flex-start;
	align-items: flex-start;

}

.vertical-contents {
	width: 80%;

}

.vertical-contents .header-img {
	margin-bottom: 32px;
}


.vertical-contents p.ex-large {
	font-size: 3.4rem;
	color: #0064e7;
	font-weight: 600;
	margin: 35px auto;
	text-align: center;
	line-height: 1;
}


.vertical-contents img {
	width: 100%;
	height: auto;
}



.vertical-box span.vertical-copy {
	writing-mode: vertical-rl;
	font-weight: 500;
	font-style: normal;
	font-size: 3.6vw;
	display: block;
	color: #8bc5d8;
	line-height: 1.3;
	max-height: 100rem;
}

.lang-only {
	writing-mode: horizontal-tb;
	font-weight: 500;
	font-style: normal;
	font-size: 3.6vw;
	display: block;
	color: #8bc5d8;
	line-height: 1.3;
	text-align: center;
	padding: 0 30px;
	box-sizing: border-box;
	margin: 60px 0;
}

html[lang="ja"] .lang-only {
	display: none;
}

.page-template-page-about .vertical-box.vertical-box-right span.vertical-copy {}


html[lang="en"] .vertical-txt-column,
html[lang="ko"] .vertical-txt-column,
html[lang="zh-CN"] .vertical-txt-column,
html[lang="zh-TW"] .vertical-txt-column {
	flex-direction: column !important;
}

html[lang="en"] .vertical-box,
html[lang="ko"] .vertical-box,
html[lang="zh-CN"] .vertical-box,
html[lang="zh-TW"] .vertical-box {
	width: 100%;
	padding-left: 0;
	justify-content: flex-start;
	margin-top: -88px;
}

html[lang="en"] .page-template-page-sanja .vertical-box,
html[lang="ko"] .page-template-page-sanja .vertical-box,
html[lang="zh-CN"] .page-template-page-sanja .vertical-box,
html[lang="zh-TW"] .page-template-page-sanja .vertical-box {
	margin-top: -16px;
}

html[lang="en"] .vertical-box span.vertical-copy,
html[lang="ko"] .vertical-box span.vertical-copy,
html[lang="zh-CN"] .vertical-box span.vertical-copy,
html[lang="zh-TW"] .vertical-box span.vertical-copy {
	writing-mode: horizontal-tb;
	margin-bottom: 30px;
	text-align: center !important;
	padding: 0 30px;
	box-sizing: border-box;
	width: 100%;
}

html[lang="en"] .vertical-box-right,
html[lang="ko"] .vertical-box-right,
html[lang="zh-CN"] .vertical-box-right,
html[lang="zh-TW"] .vertical-box-right {
	margin-bottom:40px;
}

html[lang="en"] .vertical-box.dammy,
html[lang="ko"] .vertical-box .dammy,
html[lang="zh-CN"] .vertical-box.dammy,
html[lang="zh-TW"] .vertical-box.dammy {
	display: none;
}



.vertical-contents .topic-column2 {
	display: flex;
	justify-content: space-between;
	margin-bottom:50px;
}

.vertical-contents .topic-column2 div {
	width: 46%;
}

.vertical-contents .topic-column2 div img {
	margin-bottom: 15px;
}

.vertical-contents .topic-column2 h2 {
	font-size: 2.6rem;
	color: var(--key-color);
	line-height: 1.4;
	margin-bottom: 20px;
}

html[lang="en"] .item2,
	html[lang="ko"] .item2,
	html[lang="zh-CN"] .item2,
	html[lang="zh-TW"] .item2 {
		order: 1;
	}

	html[lang="en"] .item3,
	html[lang="ko"] .item3,
	html[lang="zh-CN"] .item3,
	html[lang="zh-TW"] .item3 {
		order: 3;
	}

	html[lang="en"] .item4,
	html[lang="ko"] .item4,
	html[lang="zh-CN"] .item4,
	html[lang="zh-TW"] .item4 {
		order: 2;
	}

@media screen and (min-width: 1280px) {
	.vertical-box span.vertical-copy {
		font-size:3.8rem;
	}
}

@media screen and (max-width: 1080px) {
	.vertical-contents p.ex-large {
		font-size: 3rem;
	}
}

@media screen and (max-width: 768px) {
	#contentsArea .vertical-txt-column section {
		margin-bottom: 0;
	}

	.vertical-contents p.ex-large {
		margin:20px auto;
	}

	.vertical-txt-column .item1 {
		order: 0;
	}

	.vertical-txt-column .item2 {
		order: 2;
	}

	.vertical-txt-column .item3 {
		order: 1;
	}



	

	.vertical-box {
		margin-top: 0;
		width: 30px;
		justify-content: flex-start;
		box-sizing: border-box;
		padding-left: 10px;

	}


	.vertical-box.vertical-box-right {
		margin-top: 200vh;
		justify-content: flex-end;
		align-items: flex-start;
		margin-bottom: 30vh;
		padding-left: 30px;
		height:400px;
	}

	.page-template-page-about .vertical-box {
		padding-left: 10px;
		width: 70px;
		justify-content: flex-start;

	}

	.page-template-page-about .vertical-box.dammy,
	.page-template-page-sanja .vertical-box.dammy
	 {
		display: none;

	}

	.page-template-page-about .vertical-box.vertical-box-right {
		margin-top: 0;
		padding-left: 10px;
		width: 70px;
		justify-content: flex-start;
		align-items: flex-start;
		margin-bottom: 0;

	}

	.page-template-page-sanja .vertical-box {
		width: 60px;
	}



	.vertical-box span.vertical-copy {
		font-size: 1.8rem;
		display: block;
		text-align: left;
	}

	html[lang="en"] .vertical-box,
	html[lang="ko"] .vertical-box,
	html[lang="zh-CN"] .vertical-box,
	html[lang="zh-TW"] .vertical-box {
		width: 100% !important;
		
		justify-content: flex-start;
		margin-top: -30px;
	}

	html[lang="en"] .vertical-box-right,
	html[lang="ko"] .vertical-box-right,
	html[lang="zh-CN"] .vertical-box-right,
	html[lang="zh-TW"] .vertical-box-right {
		width: 100%;
		padding-right: 10px;
		justify-content: flex-end;
	}

	html[lang="en"] .vertical-box span.vertical-copy {
		font-size: 1.8rem;
		max-height: 50rem;
	}

	.vertical-box p span {
		margin-left: 15px;
	}

	.vertical-contents p.ex-large {
		font-size: 1.7rem;
	}

	.vertical-contents .topic-column2 {
		flex-flow: column;
		margin-bottom: 50px;
	}

	.vertical-contents .topic-column2 div {
		width: 100%;
	}

	.vertical-contents .topic-column2 div img {
		margin-bottom: 15px;
	}

	.vertical-contents .topic-column2 h2 {
		font-size: 2rem;
		margin-bottom: 15px;
	}
}

/* 浅草観音裏振興会について
================================================== */

.page-template-page-about .topic {
	margin-bottom: 100px;
}

.page-template-page-about .topic-last {
	margin-bottom:30px;
}


/* 年譜
================================================== */
dl.chronology {
	width: 100%;
	display: block;
	padding: 0 0;
}

.chronology dt,
.chronology dd {
	font-size: 1.6rem;
	line-height: 2;

	position: relative;
	padding: 0;

	border-top: 1px solid #8bc5d8;
	padding: 15px 0 20px;
}

.chronology dt {
	float: left;
	width: 210px;
}

.chronology dd {
	margin-left: 210px;
}

html[lang="en"] .chronology dt {
	width: 250px;
}

html[lang="en"] .chronology dd {
	margin-left: 250px;
}



@media only screen and (max-width: 768px) {

	.chronology dt,
	.chronology dd {
		font-size: 1.5rem;
		width: 100%;
		margin-bottom: 0;
		line-height: 1.8;
	}


	.chronology dt {
		float: none;
		padding-bottom: 0;
		font-weight: 600;
	}

	.chronology dd {
		padding-top: 10px;
		margin-left: 0;
		border-top: none;
	}

	.chronology dd:last-child {
		margin: 0;
	}
}


/* 役員一覧
============================================= */

ul.yakuin {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

ul.yakuin li {
	width: 30%;
	line-height: 2;
}

@media screen and (max-width: 768px) {
	ul.yakuin {
		flex-direction: column;
	}

	ul.yakuin li {
		width: 100%;
		line-height: 2.2;
	}

}

/* SLIDER
=========================================== */


.slider {
	width: 100%;
	z-index: 500;
	margin-bottom: 80px;
}

.slider.slick-initialized {
	display: block;

}



.slick-slide {
	margin: 0 10px;
	height: auto !important;
	overflow: hidden;
}


.slick-slide img {
	width: 100%;
	height: auto;
	object-fit: cover;
}

.slick-prev {
	left: 20px !important;
	z-index: 999;
	top: 45% !important;

}

.slick-next {
	right: 30px !important;
	z-index: 999;
	top: 45% !important;

}

.slick-prev:before,
.slick-next:before {
	font-size: 30px !important;
}

.slide-arrow {
	width: 3.5vw;
	height: auto;
	position: absolute;
	z-index: 999;
	top: 50% !important;
	margin-top: -20px;
	cursor: pointer;
	transition: all 0.3s linear
}

.slide-arrow:hover {
	opacity: 0.8;
}

.prev-arrow {

	left: 20px !important;


}

.next-arrow {

	right: 20px !important;
	z-index: 999;
	top: 50% !important;
	margin-top: -20px;
	cursor: pointer;
}


@media only screen and (max-width: 768px) {


	.slideWrap {
		padding: 60px 0 30px;
	}



	.slider {
		padding-bottom: 30px;
	}


	.slick-slide {
		margin: 0 5px;
		height: auto !important;
		overflow: hidden;
	}
}

@media only screen and (max-width: 480px) {
	.slide-arrow {
		width: 8vw;
		margin-top: -30px;
	}



}

.event-info-wrap {
	background: #a5d067;
	width: 100%;
	padding: 150px 40px;
	box-sizing: border-box;
}

#contentsArea section.event-info {
	width: 100%;
	max-width: 1100px;
	background: #f8f8f4;
	box-sizing: border-box;
	padding: 47px 72px !important;
	text-align: center;
}

.event-info .year {
	font-size: 4rem;
	font-weight: 600;
	color: #666666;
	letter-spacing: 0.3em;
	margin-bottom: 20px;
}

.event-info h2 {
	width: 100%;
	
	margin: 0 auto;
	text-align: center;
	margin-bottom: 64px;
}

.event-info h2 img {
	width: 100%;
	height: auto;
}

.event-info h3 {
	font-size: 2.8rem;
	text-align: center;
	font-weight: 600;
	color: #467b39;
}

.event-info p {
	text-align: center;
	margin-bottom: 60px;
}

.event-info p.afterdate {
	margin-bottom: 110px;
}

.event-info .date-heading {
	font-size: 3.8rem;
	text-align: center;
	font-weight: 600;
	color: #000;
	line-height: 1.6;
}

.event-info .info {
	margin-bottom: 30px;
}

.event-info .info span {
	display: inline-block;
	text-align: center;
	font-size: 3.2rem;
	line-height: 1.8;
	color: #000;
}

.event-info .info span.title {
	color: #467b39;
	font-weight: 600;
	line-height: 1.4;
}

.event-info .info span.time {
	font-size: 2.4rem;
	color: #646464;
	line-height: 1.8;
}

.event-info .profile {
	display: flex;
	justify-content: space-between;
	margin-bottom: 70px;
}

.event-info .profile .img {
	width: 46%
}

.event-info .profile .img img {
	width: 100%;
	height: auto;
}

.event-info .profile .text {
	text-align: left;
	width: 47%
}

.event-info .profile .text .name {
	font-size: 2.8rem;
	color: #467b39;
	font-weight: 600;
	margin-bottom: 30px;
}

.event-info .profile .text p {
	text-align: left;

}



@media only screen and (max-width: 768px) {

	.event-info-wrap {
		background: #a5d067;
		width: 100%;
		padding: 30px 30px;
		box-sizing: border-box;
	}

	#contentsArea section.event-info {
		padding: 20px 20px !important;
	}

	.event-info .year {
		font-size: 6.25vw;
	}

	.event-info h2 {
		margin-bottom: 20px;
	}

	.event-info h3 {
		font-size: 1.8rem;
		margin-bottom: 20px;
	}

	.event-info .date-heading {
		font-size: 6.25vw;
		margin-bottom: 20px;
	}

	.event-info p.afterdate {
		margin-bottom: 50px;
		text-align: left;
	}

	.event-info .info {
		text-align: left;
	}

	.event-info .info span {
		font-size: 1.8rem;
	}

	.event-info .info span.title {
		font-size: 2rem;
		text-align: left;
		line-height: 1.4;
		margin-bottom: 5px;
	}

	.event-info .info span.date {
		font-size: 2rem;
		text-align: left;
		margin-bottom: 5px;
	}

	.event-info .info span.time {
		font-size: 1.6rem;
		text-align: left;
		line-height: 1.4;
	}

	.event-info p {
		text-align: left;
		margin-bottom: 30px;
	}

	.event-info .profile .img {
		width: 30%
	}

	.event-info .profile .text {
		text-align: left;
		width: 66%
	}

	.event-info .profile .text .name {
		font-size: 2rem;
		margin-bottom: 20px;
	}

	.event-info .profile .text p {
		text-align: left;

	}




}

@media only screen and (max-width: 480px) {
	.event-info .profile {
		flex-flow: column;
		margin-bottom: 30px;
	}

	.event-info .profile .img {
		width: 100%;
		margin-bottom: 20px;
	}

	.event-info .profile .text {
		width: 100%
	}

	.event-info .profile .text .name {
		margin-bottom: 15px;
	}
}

/*access
================================================== */
iframe[src*="www.google.com/maps/embed"] {
	aspect-ratio: 16 / 9;
	width: 100%;
	height: auto;
}

@media only screen and (max-width: 480px) {
iframe[src*="www.google.com/maps/embed"] {
	aspect-ratio: 3 / 2;
	width: 100%;
	height: auto;
}
}




.map-wrap {
	width: 100%;
	text-align: center;
	padding: 0;
	margin-bottom: 30px
}



/*contact
================================================== */

.form-layout {
	justify-content: space-between;
	width: 100%;
	max-width: 800px;
	margin: 0 auto 50px;
	border-bottom: none;
	display: flex;
	flex-wrap: wrap;
}

.form-layout dt,
.form-layout dd {
	padding: 20px 0;
	font-size: 1.6rem;
}

.form-layout dt {
	width: 26%;
	vertical-align: middle;
	text-align: left;
	font-weight: 500;
	line-height: 1.4;
}

.form-layout dd {
	width: 71%;
	text-align: left;
	line-height: 1.4;
}

@media screen and (max-width:768px) {
	.form-layout {
		margin: 0 auto 20px;

		box-sizing: border-box;
		text-align: left;
	}

	.form-layout dt {
		width: 100%;
		padding: 0;
	}

	.form-layout dd {
		padding: 0 0 20px;
		width: 100%;
		line-height: 1.4;
	}
}

.form-layout dt p,
.form-layout dd p {
	margin-bottom: 10px !important;
	;
}

.form-layout input,
.form-layout textarea {
	box-sizing: border-box;
	border: 1px solid #ccc;
	padding: 5px;

	background: #f8f8f4;
	font-size: 1.6rem;
}

.form-layout input:focus {
	border: 1px solid #999;
	outline: 0;
	background: #fff;
}

.form-layout textarea:focus {
	border: 1px solid #999;
	outline: 0;
	background: #fff;
}

.form-layout textarea {
	width: 100%;
	height: 200px;

}

.form-layout input {
	width: 100%;
	height: 40px;
}


.form-layout .required {
	display: inline-block;
	padding-left: 5px;
}

.form-layout sup {
	font-size: 1rem;
	color: #646464;
	vertical-align: super;
}

.form-submit {
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
	text-align: center;
}

.form-submit p {
	text-align: center;
}

input[type="submit"],
input[type="reset"],
input[type="button"] {

	padding: 10px 20px;
	font-size: 2rem;
	font-weight: 600;
	color: #8bc5d8;
	text-align: center;
	cursor: pointer;
	width: 100%;
	max-width: 300px;
	display: block;
	margin: 0 auto;
	border: 4px solid #8bc5d8;
	transition: all 0.2s linear;
	box-sizing: border-box;
	background: #f8f8f4;
}


input[type="submit"]:hover,
input[type="reset"]:hover,
input[type="button"]:hover {
	background: #8bc5d8;
	text-decoration: none;
	color: #FFF;

}

.wpcf7-spinner {
	display: block !important;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output,
.wpcf7 form.sent {
	border: unset !important;
	text-align: center !important;

}

.wpcf7 form.sent .wpcf7-response-output {
	border: unset !important;
}

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

	input[type="submit"],
	input[type="reset"],
	input[type="button"] {
		width: 100%
	}
}


/* 追加（）Funcybox */
.fancybox__content {
	max-width: 90% !important;
	max-height: 90% !important;
}

.f-thumbs {
	display: none !important;
}

.fancybox__infobar {
	display: none !important;
}