/*!
Theme Name: kamiya_nouen
Theme URI: http://underscores.me/
Author: Underscores.me
Author URI: http://underscores.me/
Description: Description
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: kamiya_nouen
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

kamiya_nouen is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/


/* Galleries
--------------------------------------------- */
.gallery {
	margin-bottom: 1.5em;
	display: grid;
	grid-gap: 1.5em;
}

.gallery-item {
	display: inline-block;
	text-align: center;
	width: 100%;
}

.gallery-columns-2 {
	grid-template-columns: repeat(2, 1fr);
}

.gallery-columns-3 {
	grid-template-columns: repeat(3, 1fr);
}

.gallery-columns-4 {
	grid-template-columns: repeat(4, 1fr);
}

.gallery-columns-5 {
	grid-template-columns: repeat(5, 1fr);
}

.gallery-columns-6 {
	grid-template-columns: repeat(6, 1fr);
}

.gallery-columns-7 {
	grid-template-columns: repeat(7, 1fr);
}

.gallery-columns-8 {
	grid-template-columns: repeat(8, 1fr);
}

.gallery-columns-9 {
	grid-template-columns: repeat(9, 1fr);
}

.gallery-caption {
	display: block;
}

/*--------------------------------------------------------------
# Plugins
--------------------------------------------------------------*/

/* Jetpack infinite scroll
--------------------------------------------- */

/* Hide the Posts Navigation and the Footer when Infinite Scroll is in use. */
.infinite-scroll .posts-navigation,
.infinite-scroll.neverending .site-footer {
	display: none;
}

/* Re-display the Theme Footer when Infinite Scroll has reached its end. */
.infinity-end.neverending .site-footer {
	display: block;
}

/*--------------------------------------------------------------
# Utilities
--------------------------------------------------------------*/

/* Accessibility
--------------------------------------------- */

/* Text meant only for screen readers. */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	clip-path: none;
	color: #21759b;
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}

/* Do not show the outline on the skip link target. */
#primary[tabindex="-1"]:focus {
	outline: 0;
}

/* Alignments
--------------------------------------------- */
.alignleft {
	/*rtl:ignore*/
	float: left;

	/*rtl:ignore*/
	margin-right: 1.5em;
	margin-bottom: 1.5em;
}

.alignright {
	/*rtl:ignore*/
	float: right;

	/*rtl:ignore*/
	margin-left: 1.5em;
	margin-bottom: 1.5em;
}

.aligncenter {
	clear: both;
	display: block;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 1.5em;
}













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

html{
	font-size: 10px;
	scroll-behavior: smooth;
}

html[lang]{
	margin: 0 !important;
}
#wpadminbar{
	display: none;
}

body{
	padding: 0;
	margin: 0;
	font-size: 1.6rem;
	font-weight: 300;
	line-height: 1.8;
	color: #362484;
	overflow-x: hidden;
	font-family: sans-serif;
	-webkit-font-smoothing: antialiased;
	-webkit-text-size-adjust: 100%; /* iPhoneだけ文字が大きくなる現象を防ぐ */
	/*font-feature-settings: "palt";*/ /* 文字詰め（フォントにカーニング情報が含まれる場合） */

	 /* iPhoneで上下のバーを抜いた高さ */
	height: -webkit-fill-available;
	height: -moz-available;
}

::-webkit-input-placeholder{ color: #99938f; }
:-moz-placeholder          { color: #99938f; }
:-ms-input-placeholder     { color: #99938f; }

html.pc .sp{ display: none !important; }
html.sp .pc{ display: none !important; }

iframe{
	max-width: 100%;
	vertical-align: middle;
}

img{
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}
img.cover{
	object-fit: cover;
	object-position: center;
	width: 100%;
	height: 100%;
}

p{
	text-align: justify;
}

a,
a:link,
a:visited{
	color: #3a2383;
}

a:hover img{
	opacity: 0.8;
}

#page{
	min-height: 100vh;
}


.page_width1{
	max-width: 90vw;
	width: 1000px;
	margin: 0 auto;
}
.page_width2{
	max-width: 90vw;
	width: 1100px;
	margin: 0 auto;
}

.site-header .site-branding{
	display: flex;
	justify-content: space-between;
}
.site-header .site-branding img[src*="/header/2."]{
	margin: 8px 0 0 35px;
}
.site-header .site-branding .right{
	display: flex;
	align-items: flex-start;
	font-size: 1.3rem;
	color: #3a2383;
	padding: 5px 0 0;
}
.site-header .site-branding .right .frame{
	line-height: 11px;
	border: 1px solid #3a2383;
	padding: 5px 10px;
	margin-right: 20px;
}
.site-header .site-branding .right img[src*="/header/4."]{
	margin-bottom: 10px;
}

.nav_knob{
	position: fixed;
	z-index: 2100;
	right: 10px;
	top: 10px;
	width: 10vw;
}

#site-navigation{
	position: sticky;
	top: 0;
	user-select: none;
	margin-top: 10px;
	margin-bottom: 80px;
	padding: 10px;
	background-color: rgba(255, 255, 255, 1);
	z-index: 1000;
}
#site-navigation .inner{
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 20px;
}
#site-navigation .list{
	display: flex;
	flex-wrap: wrap;
	flex-shrink: 1;
	gap: 20px 30px;
}
#site-navigation a{
	text-decoration: none;
	line-height: 1;
	white-space: nowrap;
}
#site-navigation a.page_top{
	min-width: 96px;
}
#site-navigation .img_n1{
	position: relative;
	top: -5px;
	width: 40px;
}
#site-navigation .img_n2{
	position: relative;
	top: -5px;
	width: 35px;
}
@media (max-width: 700px) {
	.min700{
		display: none;
	}
	#site-navigation{
		display: none;
		position: fixed;
		z-index: 2000;
		left: 0;
		top: 0;
		box-sizing: border-box;
		width: 100%;
		height: 100vh;
		padding: 7vw;
		margin: 0;
		background-color: #382383;
	}
	#site-navigation.open{
		display: block;
	}
	#site-navigation .inner{
		flex-direction: column;
		max-width: none;
		width: 100%;
		margin: 0;
	}
	#site-navigation .list{
		flex-direction: column;
		align-items: center;
		gap: 0;
		width: 100%;
		border-top: 1px solid #fff;
	}
	#site-navigation .list a{
		text-align: center;
		font-size: 3rem;
		color: #fff;
		box-sizing: border-box;
		width: 100%;
		padding: 5vw 0;
		border-bottom: 1px solid #fff;
	}
	#site-navigation .text1{
		font-size: 3rem;
		letter-spacing: 0.1em;
		color: #fff;
		margin: 0 0 10px;
	}
	#site-navigation .text2{
		color: #fff;
	}
}
@media (min-width: 701px) {
	.max700{
		display: none;
	}
}

.site-footer{
	position: sticky;
	top: 100vh;
	font-size: 1.5rem;
	background-image: url(img/common/footer/bg.jpg);
	background-size: cover;
	background-position: 50% 100%;
	background-repeat: no-repeat;
	padding: 1px 0 20px;
}
.site-footer .copyright{
	text-align: center;
	font-size: 1.4rem;
	color: #fff;
	margin-top: max(calc(32vw), 400px);
}
.site-footer .row1{
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}
.site-footer .row1 .left{
	display: flex;
	gap: 30px;
}
.site-footer .row1 .left .text1{
	font-size: 1.7rem;
	letter-spacing: 0.08em;
	margin: 15px 0 10px;
}
.site-footer .row1 .left .text2{
	font-size: 1.5rem;
	line-height: 1.6;
	letter-spacing: 0.07em;
	margin-left: 5px;
}
.site-footer .row1 .right{
	display: flex;
	align-items: flex-end;
	gap: 30px;
	margin-top: 20px;
}
@media (max-width: 800px) {
	.site-footer{
		background-size: 180%;
		background-position: 55% 100%;
	}
	.site-footer .row1{
		flex-direction: column;
		align-items: center;
	}
	.site-footer .row1 .left{
		flex-direction: column;
		align-items: center;
		text-align: center;
	}
	.site-footer .row1 .left .text1{
		width: 400px;
		font-size: 2.5rem;
		margin-bottom: 25px;
	}
	.site-footer .row1 .right{
		margin-top: 40px;
	}
	.site-footer .copyright{
		margin-top: 52vw;
	}
}

.ib{
	display: inline-block;
}

.anchor_target{
	position: relative;
	top: -100px;
}

.mincho{
	font-family: serif;
}

.a1mincho{
	font-family: "A1明朝 M JIS2004 AP", serif;
}

.wpcf7-submit,
button.type1,
a.button1{
	background-color: transparent;
	border: none;
	border-radius: 0;
	cursor: pointer;
	outline: none;
	padding: 0;
	-webkit-appearance: none;
	appearance: none;
	text-decoration: none;

	display: flex;
	justify-content: center;
	align-items: center;
	white-space: nowrap;
	box-sizing: border-box;
	width: 100%;
	padding: 10px;
	font-size: 2.2rem;
	letter-spacing: 0.4em;
	line-height: 1.2;
	text-align: center;
	color: #fff;
	background-color: #382383;
	margin: 25px 0;
}
.wpcf7-submit:hover,
button.type1:hover,
a.button1:hover{
	opacity: 0.8;
}
.wpcf7-submit{
	font-family: serif;
	font-size: 2rem;
	padding: 15px;
}


input[type="text"],
input[type="email"],
input[type="number"],
input[type="tel"],
input[type="url"],
input[type="password"],
input[type="datetime"],
input[type="datetime-local"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="search"],
textarea,
select{
	font-size: 1.6rem;
	font-weight: 400;
	font-family: serif !important;
	box-sizing: border-box;
	border: 0;
	/*	border: 1px solid #cdcdcd;*/
	/*	border-radius: 4px;*/
	background-color: #f9f9f8;
	outline: 0;
	padding: 17px;
	margin: 0 0 8px;
	width: 100%;
	-webkit-appearance: none; /* iPhone の入力欄へのエフェクトを消す */
}
select{
	padding: 10px 50px 10px 10px;
	width: auto;
	background: #fff url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M5%206l5%205%205-5%202%201-7%207-7-7%202-1z%22%20fill%3D%22%23555%22%2F%3E%3C%2Fsvg%3E) no-repeat right 5px top 55%;
}



/* トップ *************************************************************************** */

.page-template-top{
}

.page-template-top main{
	display: flex;
	justify-content: center;
	align-items: center;
	background-image: url(img/top/1_bg.jpg);
	background-size: cover;
	background-position: 30% 60%;
	background-repeat: no-repeat;
	height: calc(100vh - 166px);
}
.page-template-top main p{
	text-align: center;
	font-size: 1.7rem;
	font-weight: 600;
	line-height: 2.4;
	letter-spacing: 0.3em;
	margin: 0 0 calc(250px + 10vh) 0;
}

.page-template-top #news_instagram{
	position: relative;
	top: -100px;
}
.page-template-top .news_instagram{
	display: flex;
	justify-content: space-between;
	margin: 80px 0;
}
.page-template-top .news_instagram :is(.news, .instagram){
	flex-basis: 480px;
}
.page-template-top .news_instagram :is(.news, .instagram) h2{
	font-size: 2.5rem;
	font-weight: 300;
	letter-spacing: 0.15em;
	margin-top: 0;
}
.page-template-top .news_instagram .news .row{
	display: flex;
	margin: 3px 0;
}
.page-template-top .news_instagram .news .row .date{
	min-width: 130px;
	margin: 0 10px 0 0;
}
.page-template-top .news_instagram .news a{
	color: #3a2383;
	text-decoration: none;
}
.page-template-top .news_instagram .news a:hover{
	text-decoration: underline;
}
.page-template-top .news_instagram .instagram{
	text-align: center;
	border: 1px solid #3a2383;
	border-top: 0;
	border-bottom: 0;
}
.page-template-top .news_instagram .instagram .inner{
	display: inline-block;
	text-align: left;
/*	width: 350px;*/
}
.page-template-top .news_instagram .instagram .list{
	display: flex;
	justify-content: space-between;
	gap: 15px;
}
.page-template-top .news_instagram .instagram .list a{
	width: 90px;
	aspect-ratio: 1;
	background-size: cover;
	background-position: 50%;
	background-repeat: no-repeat;
}
.page-template-top .news_instagram .instagram .list a:hover{
	opacity: 0.8;
}
.page-template-top .news_instagram .img_i{
	vertical-align: -3px;
}
@media (max-width: 870px) {
	.page-template-top .news_instagram{
		flex-direction: column;
		gap: 50px;
		max-width: 500px;
		margin: 60px auto;
	}
	.page-template-top .news_instagram :is(.news, .instagram){
		flex-basis: auto;
	}
	.page-template-top .news_instagram .instagram{
		border: 0;
	}
	.page-template-top .news_instagram .instagram .inner{
		width: 100%;
	}
	.page-template-top .news_instagram .instagram .list a{
		width: 30%;
	}
}

.page-template-top .p1{
	text-align: center;
	font-size: min(3.6rem, 4.5vw);
	letter-spacing: 0.13em;
}

.page-template-top #watasitatinoomoi{
	position: relative;
	top: -100px; 
}
.page-template-top .watasitatinoomoi{
	margin: 0 0 200px;
	overflow: hidden;
}
.page-template-top .watasitatinoomoi .bg{
	background-color: #efefee;
	padding: 20px 0 60px;
}
.page-template-top .watasitatinoomoi h3{
	text-align: center;
	font-size: min(4rem, 4.9vw);
	font-weight: normal;
	letter-spacing: 0.1em;
	margin: min(70px, 12vw) 0 min(70px, 8vw);
}
.page-template-top .watasitatinoomoi h3:before,
.page-template-top .watasitatinoomoi h3:after{
	content: "";
	display: block;
	background-image: url(img/top/h3_b1.png);
	background-size: cover;
	background-position: 50%;
	background-repeat: no-repeat;
	height: 5px;
	margin: 0 0 min(20px, 2.5vw);
}
.page-template-top .watasitatinoomoi h3:after{
	background-image: url(img/top/h3_a1.png);
	margin: min(20px, 2.5vw) 0 0;
}
.page-template-top .watasitatinoomoi .row1{
	display: flex;
	justify-content: space-between;
	gap: 30px;
}
.page-template-top .watasitatinoomoi .row1 .left{
	flex-basis: 590px;
}
.page-template-top .watasitatinoomoi .row1 .left .image{
	margin: 0 0 0 min(calc(500px - 50vw), -150px) ;
	height: 525px;
}
.page-template-top .watasitatinoomoi .row1 .left .image img{
	object-position: 80% 80%;
}
.page-template-top .watasitatinoomoi .row1 .right{
	text-align: center;
	flex-basis: 260px;
	flex-grow: 1;
}
.page-template-top .watasitatinoomoi .row1 .right .image{
	margin: 0 min(calc(500px - 50vw), -130px) 0 0;
	height: 340px;
}
.page-template-top .watasitatinoomoi .row1 .right .image img{
	object-position: 80% 80%;
}
.page-template-top .watasitatinoomoi .row2{
	display: flex;
	justify-content: space-between;
}
.page-template-top .watasitatinoomoi .row2 .left{
	flex-basis: 590px;
	text-align: center;
}
.page-template-top .watasitatinoomoi .row2 .right{
	flex-basis: 590px;
}
.tate{
	display: inline-block;
	writing-mode: vertical-rl;
}
.page-template-top .watasitatinoomoi .tate{
	font-size: min(3rem, 3.8vw);
	letter-spacing: 0.1em;
	line-height: 2;
	text-align: left;
	margin-block-start: 1em;
	margin-block-end: 1em;
}
.page-template-top .watasitatinoomoi .tate.firefox{
	flex-grow: 1;
}
.page-template-top .watasitatinoomoi .image3{
	height: 585px;
	margin: 60px 0;
	margin-right: min(calc(500px - 50vw), -130px);
}
.page-template-top .watasitatinoomoi .image3 img{
	object-position: 80% 80%;
}
.page-template-top .watasitatinoomoi .image4{
	display: flex;
	gap: 10px;
	margin: 60px 0;
	margin-left: min(calc(500px - 50vw), -130px);
	height: 416px;
}
.page-template-top .watasitatinoomoi .image4 img{
	object-position: 80% 50%;
}
.page-template-top .watasitatinoomoi .row3{
	display: flex;
	justify-content: space-between;
}
.page-template-top .watasitatinoomoi .row3 .left{
	flex-basis: 610px;
}
.page-template-top .watasitatinoomoi .row3 .right{
}
.page-template-top .watasitatinoomoi .row3 .right .image{
	text-align: right;
	margin: 0 -70px 0 0;
}
.page-template-top .watasitatinoomoi .row4{
	display: flex;
	justify-content: space-between;
	margin: 30px 0;
}
.page-template-top .watasitatinoomoi .row4 .left{
	flex-grow: 1;
}
.page-template-top .watasitatinoomoi .row4 .left .image{
	margin: 0 0 0 min(calc(500px - 50vw), -130px);
	height: 548px;
}
.page-template-top .watasitatinoomoi .row5{
	display: flex;
	justify-content: space-between;
	margin: 70px 0;
}
.page-template-top .watasitatinoomoi .row5 .left{
	flex-grow: 1;
}
.page-template-top .watasitatinoomoi .row5 .left .image{
	margin: 0 0 0 min(calc(500px - 50vw), -130px);
	height: 525px;
}
.page-template-top .watasitatinoomoi .row6{
	display: flex;
	justify-content: space-between;
	gap: 70px;
}
.page-template-top .watasitatinoomoi .row6 .left{
	flex-basis: 500px;
}
.page-template-top .watasitatinoomoi .row6 .left p{
	margin-top: 0;
}
.page-template-top .watasitatinoomoi .row6 .right{
	flex-grow: 1;
}
.page-template-top .watasitatinoomoi .row6 .right .image{
	margin: 0 min(calc(500px - 50vw), -130px) 0 0;
	height: 397px;
}
.page-template-top .watasitatinoomoi .row7{
	display: flex;
	justify-content: space-between;
	gap: 50px;
	position: relative;
	z-index: 100;
}
.page-template-top .watasitatinoomoi .row7 .left{
	margin-bottom: -220px;
}
.page-template-top .watasitatinoomoi .p3{
	display: none;
	width: 80vw;
	margin: 7vw auto 3vw;
}
.page-template-top .watasitatinoomoi .row8{
	display: flex;
	justify-content: space-between;
	gap: 60px;
	margin: 80px 0;
}
.page-template-top .watasitatinoomoi .row8 .left{
	flex-grow: 1;
	flex-basis: 500px;
	text-align: center;
}
.page-template-top .watasitatinoomoi .row8 .left p{
	position: relative;
	z-index: 100;
	margin: 50px 0 0;
}
.page-template-top .watasitatinoomoi .row8 .left .image{
	margin: -140px 0 0 min(calc(500px - 50vw), -130px);
	height: 647px;
}
.page-template-top .watasitatinoomoi .row8 .left .image img{
	object-position: 20% 50%;
}
.page-template-top .watasitatinoomoi .row8 .right{
	flex-grow: 1;
	flex-basis: 420px;

	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.page-template-top .watasitatinoomoi .row8 .right p{
	margin-bottom: 0;
}
.page-template-top .watasitatinoomoi .row8 .right .image{
	margin: 0 min(calc(500px - 50vw), -130px) 0 0;
	height: 391px;
}
@media (max-width: 800px) {
	.page-template-top .watasitatinoomoi .row1{
		flex-direction: column;
		margin: 0 5vw;
	}
	.page-template-top .watasitatinoomoi .row1 .left{
		order: 2;
	}
	.page-template-top .watasitatinoomoi .row1 .left .image{
		margin: 0 0 4vw;
		aspect-ratio: 740/525;
		height: auto;
	}
	.page-template-top .watasitatinoomoi .row1 .right{
		order: 1;
	}
	.page-template-top .watasitatinoomoi .row1 .right .image{
		margin: 0 0 7vw;
		aspect-ratio: 512/343;
		height: auto;
	}
	.page-template-top .watasitatinoomoi .image3{
		height: 50vw;
		margin: 0 -5vw;
	}
	.page-template-top .watasitatinoomoi .row2{
		flex-direction: column;
		margin: 0 5vw;
	}
	.page-template-top .watasitatinoomoi .row2 .left{
		flex-basis: auto;
		padding: 9vw 0;
	}
	.page-template-top .watasitatinoomoi .row2 .right{
		flex-basis: auto;
	}
	.page-template-top .watasitatinoomoi .image4{
		margin: 8vw -5vw 5vw;
		height: 35vw;
	}
	.page-template-top .watasitatinoomoi .row3{
		flex-direction: column;
		margin: 0 5vw;
	}
	.page-template-top .watasitatinoomoi .row3 .left{
		flex-basis: auto;
		margin: 0 0 35vw;
	}
	.page-template-top .watasitatinoomoi .row3 .right .image img{
		max-width: 60%;
	}
	.page-template-top .watasitatinoomoi .row4{
		flex-direction: column;
		margin-bottom: 18vw;
	}
	.page-template-top .watasitatinoomoi .row4 .left{
		order: 2;
	}
	.page-template-top .watasitatinoomoi .row4 .left .image{
		margin: 0;
		height: 60vw;
	}
	.page-template-top .watasitatinoomoi .row4 .right{
		order: 1;
		margin: -77vw 46vw 3vw 0;
	}
	.page-template-top .watasitatinoomoi .row5{
		flex-direction: column;
		margin: 0 -5vw 17vw;
	}
	.page-template-top .watasitatinoomoi .row5 .left{
		order: 2;
	}
	.page-template-top .watasitatinoomoi .row5 .right{
		position: relative;
		z-index: 100;
		order: 1;
		display: flex;
		justify-content: center;
		align-items: center;
		margin: 0 0 -13vw;
	}
	.page-template-top .watasitatinoomoi .row5 .left .image{
		margin: 0;
		height: 55vw;
	}
	.page-template-top .watasitatinoomoi .row6{
		flex-direction: column;
		gap: 10vw;
		margin: 0 5vw;
	}
	.page-template-top .watasitatinoomoi .row6 .left{
		order: 2;
		flex-basis: auto;
	}
	.page-template-top .watasitatinoomoi .row6 .right{
		order: 1;
	}
	.page-template-top .watasitatinoomoi .row6 .right .image{
		margin: 0;
		height: 55vw;
	}
	.page-template-top .watasitatinoomoi .row7 .left{
		display: flex;
		justify-content: center;
		align-items: center;
		width: 100%;
		margin: 0 0 3vw;
	}
	.page-template-top .watasitatinoomoi .row7 .right{
		display: none;
	}
	.page-template-top .watasitatinoomoi .p3{
		display: block;
	}
	.page-template-top .watasitatinoomoi .row8{
		flex-direction: column;
		gap: 15vw;
		margin: 0 5vw;
	}
	.page-template-top .watasitatinoomoi .row8 .left{
		flex-basis: auto;
		text-align: right;
	}
	.page-template-top .watasitatinoomoi .row8 .left p{
		margin: 0px 0 0;
	}
	.page-template-top .watasitatinoomoi .row8 .left .image{
		margin: -31vw 14vw 0 -10vw;
		height: 60vw;
	}
	.page-template-top .watasitatinoomoi .row8 .right .image{
		margin: 0 0 5vw;
		height: 55vw;
	}
}

.page-template-top #fukunokami{
	overflow: hidden;
}
.page-template-top #fukunokami h3{
	font-size: 3.6rem;
	font-weight: normal;
	margin: 25px 0;
}
.page-template-top #fukunokami .bg{
	min-height: 2000px;
	background-color: #d9dbda;
	/* background-image: url(img/top/13.jpg); */
	background-size: 100% auto;
	background-position: 0 0;
	background-repeat: no-repeat;
	padding: 12.2vw 0 70px;
}
.page-template-top #fukunokami .row1{
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.page-template-top #fukunokami .row1 .left{
	flex-basis: 525px;
	margin: 0 0 0 -50px;
}
.page-template-top #fukunokami .row1 .left img{
	max-width: 130%;
}
.page-template-top #fukunokami .row1 .right{
	flex-basis: 390px;
	margin: 0 0 80px 0;
}
.page-template-top #fukunokami .img10{
	width: 100%;
	margin: 0 0 -12.2vw;
}
.page-template-top #fukunokami .takikata{
	width: 1000px;
	max-width: 100%;
	margin: 50px auto; 0;
}
.page-template-top #fukunokami .takikata .title{
	position: relative;
	z-index: 100;
	font-size: 4.1rem;
	letter-spacing: 0.1em;
	color: #fff;
	margin: 0 min(calc(500px - 50vw), -130px) 0 100px;
	box-sizing: border-box;
	height: 668px;
	padding: 50px;
	background-image: url(img/top/15.jpg);
	background-size: cover;
	background-position: 0 20%;
	background-repeat: no-repeat;
}
.page-template-top #fukunokami .takikata .list{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 50px 30px;
	padding: 400px 50px 50px;
	margin: -350px 0 0;
	background-color: #fff;
}
.page-template-top #fukunokami .takikata .list .box{
	flex-basis: 30%;
	flex-grow: 1;
}
.page-template-top #fukunokami .takikata .list .box1{
	display: flex;
	justify-content: space-between;
	flex-direction: column;
}
.page-template-top #fukunokami .takikata .list .box h4{
	font-size: 2.2rem;
	white-space: nowrap;
	margin: 0 -50px 0 0;
}
.page-template-top #fukunokami .takikata .list .box p{
	line-height: 1.6;
}
.page-template-top #fukunokami .takikata .list .box .frame{
	border: 1px solid #362484;
	border-radius: 8px;
	margin: 0 -8px;
	padding: 8px;
}
.page-template-top #fukunokami .takikata .list .box .image{
	text-align: center;
}
@media (max-width: 800px) {
	.page-template-top #fukunokami .bg{
		background-image: none;
		padding-bottom: 0;
	}
	.page-template-top #fukunokami .row1{
		flex-direction: column;
	}
	.page-template-top #fukunokami .row1 .left{
		flex-basis: auto;
		text-align: center;
		margin: -7vw 0 -12vw;
	}
	.page-template-top #fukunokami .row1 .left img{
		max-width: 90%;
	}
	.page-template-top #fukunokami .row1 .right{
		flex-basis: auto;
		margin: 0 5vw;
	}
	.page-template-top #fukunokami .takikata .title{
		background-image: url(img/top/15_sp.jpg);
		line-height: 1.3;
		padding: 4vw 5vw;
		margin: 0;
		height: 87vw;
	}
}
@media (max-width: 750px) {
	.page-template-top #fukunokami .takikata .list{
		padding: 400px 5vw 5vw;
	}
	.page-template-top #fukunokami .takikata .list .box{
		flex-basis: 40%;
	}
	.page-template-top #fukunokami .takikata .list .box h4{
		font-size: 2rem;
	}
	.page-template-top #fukunokami .takikata .list .box1{
		justify-content: flex-start;
	}
	.page-template-top #fukunokami .takikata .list .box .frame{
		margin: 0;
	}
}

.page-template-top #yasaitokinoko{
	overflow: hidden;
}
.page-template-top #yasaitokinoko .img17{
	width: 100%;
}
.page-template-top #yasaitokinoko h3{
	font-size: 3.6rem;
	font-weight: normal;
	letter-spacing: 0.07em;
	white-space: nowrap;
	margin-top: 0;
}
.page-template-top #yasaitokinoko .row1 h3{
	text-align: center;
}
.page-template-top #yasaitokinoko .row1{
	width: 840px;
	max-width: 80vw;
	margin: 60px auto 0;
}
.page-template-top #yasaitokinoko .row2{
	display: flex;
	justify-content: space-between;
	gap: 50px;
	margin: 70px 0;
}
.page-template-top #yasaitokinoko .row2 .left{
	flex-grow: 1;
}
.page-template-top #yasaitokinoko .row2 .left .image{
	margin: 0 0 0 min(calc(500px - 50vw), -130px);
	height: 477px;
}
.page-template-top #yasaitokinoko .row2 .right{
	flex-basis: 280px;
/*	margin: 0 0 0 50px;*/
}
.page-template-top #yasaitokinoko .img20{
	display: none;
}
.page-template-top #yasaitokinoko .row3{
	display: flex;
	justify-content: space-between;
	margin: 70px 0;
}
.page-template-top #yasaitokinoko .row3 .left{
	flex-basis: 300px;
	margin: 0 50px 0 0;
}
.page-template-top #yasaitokinoko .row3 .right{
	flex-grow: 1;
}
.page-template-top #yasaitokinoko .row3 .right .image{
	margin: 0 min(calc(500px - 50vw), -130px) 0 0;
	height: 559px;
}
.page-template-top #yasaitokinoko .row3 .right .buttons{
	width: 380px;
}
@media (max-width: 800px) {
	.page-template-top #yasaitokinoko h3{
		text-align: center;
		font-size: 5.5vw;
	}
	.page-template-top #yasaitokinoko .row2{
		flex-direction: column;
		gap: 6vw;
	}
	.page-template-top #yasaitokinoko .row2 .left .image{
		margin: 0;
		height: 55vw;
	}
	.page-template-top #yasaitokinoko .row2 .left .image img{
		object-position: 100% 50%;
	}
	.page-template-top #yasaitokinoko .row2 .right{
		flex-basis: auto;
		margin: 0 5vw;
	}
	.page-template-top #yasaitokinoko .img20{
		display: block;
		clip-path: inset(0px 30px);
		min-width: calc(100% + 60px);
		margin-left: -30px;
	}
	.page-template-top #yasaitokinoko .row3{
		flex-direction: column;
		margin-top: 6vw;
	}
	.page-template-top #yasaitokinoko .row3 .left{
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		margin: 0 5vw;
	}
	.page-template-top #yasaitokinoko .row3 .left p{
		order: 3;
	}
	.page-template-top #yasaitokinoko .row3 .right .image{
		display: none;
	}
	.page-template-top #yasaitokinoko .row3 .right .buttons{
		margin: 0 auto;
	}
}

.page-template-top #recipe_list{
	border: 2px solid #362484;
	box-sizing: border-box;
	width: 1100px;
	max-width: 95%;
	padding: 50px;
	margin: 50px auto;
}
.page-template-top #recipe_list .title{
	text-align: center;
	margin: 0 0 20px;
}
.page-template-top #recipe_list .title_1{
	display: flex;
	justify-content: space-between;
	padding: 0 0 0 50px;
}
.page-template-top #recipe_list .title_2{
	font-size: 2rem;
	font-weight: 600;
	letter-spacing: 0.2em;
	margin: -25px 0 10px;
}
.page-template-top #recipe_list .title_3{
	font-size: 4.4rem;
	letter-spacing: 0.1em;
}
.page-template-top #recipe_list .recipe{
	background-color: #f4f2f1;
	padding: 10px 90px 50px;
	margin: 0 0 50px;
}
.page-template-top #recipe_list .recipe:last-child{
	margin: 0;
}
.page-template-top #recipe_list .recipe h3{
	text-align: center;
	font-size: 3.7rem;
	font-weight: normal;
	letter-spacing: 0.1em;
	white-space: nowrap;
}
.page-template-top #recipe_list .recipe h3 .inner{
	display: inline-block;
	min-width: 550px;
}
.page-template-top #recipe_list .recipe h3 .h3_1{
	display: flex;
	align-items: center;
	gap: 30px;
	font-size: 2.8rem;
	letter-spacing: 0.18em;
}
.page-template-top #recipe_list .recipe h3 .h3_1:before,
.page-template-top #recipe_list .recipe h3 .h3_1:after{
	content: "";
	border-bottom: 1px dotted #362484;
	flex-grow: 1;
}
.page-template-top #recipe_list .image_zairyou{
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}
.page-template-top #recipe_list .image_zairyou .image{
	margin: 0 0 0 -130px;
}
.page-template-top #recipe_list .image_zairyou .zairyou{
	border-bottom: 1px dotted #362484;
	padding: 0 0 10px;
}
.page-template-top #recipe_list .image_zairyou .zairyou_1{
	display: flex;
	align-items: center;
	gap: 10px;
}
.page-template-top #recipe_list .image_zairyou .zairyou_1:after{
	content: "";
	border-bottom: 1px dotted #362484;
	flex-grow: 1;
}
.page-template-top #recipe_list .tejun{
	display: flex;
	justify-content: center;
	gap: 50px;
	margin: 30px 0 0;
}
.page-template-top #recipe_list .tejun .left{
	order: 2;
}
.page-template-top #recipe_list .tejun .left .image{
	border-radius: 12px;
	background-size: cover;
	background-position: 50%;
	background-repeat: no-repeat;
	box-sizing: border-box;
	width: 292px;
	aspect-ratio: 292/201;
	padding: 15px 10px;
	margin: 0 0 25px;
}
.page-template-top #recipe_list .tejun .left .text{
	display: none;
}
.page-template-top #recipe_list .tejun .image .maru,
.page-template-top #recipe_list .tejun .text .maru{
	display: inline-flex;
	justify-content: center;
	align-items: center;
	font-size: 1.8rem;
	font-weight: 600;
	font-family: sans-serif;
	line-height: 1;
	border-radius: 50px;
	background-color: #fff;
	width: 33px;
	height: 33px;
}
.page-template-top #recipe_list .tejun .text .maru{
	font-size: 2.2rem;
	color: #fff;
	background-color: #362484;
	width: 40px;
	min-width: 40px;
	height: 40px;
	margin-top: 8px;
}
.page-template-top #recipe_list .tejun .right{
	order: 1;
}
.page-template-top #recipe_list .tejun .text{
	display: flex;
	align-items: flex-start;
	gap: 20px;
	font-size: 2.6rem;
	line-height: 1.6;
	white-space: nowrap;
	font-feature-settings: "palt"; /* 文字詰め（フォントにカーニング情報が含まれる場合） */
	margin: 0 0 25px;
}
.page-template-top #recipe_list .p2{
	text-align: center;
	font-size: min(2.6rem, 4.2vw);
	font-feature-settings: "palt"; /* 文字詰め（フォントにカーニング情報が含まれる場合） */
	margin: 30px 0;
}
@media (max-width: 1050px) {
	.page-template-top #recipe_list .title_1{
/*		flex-direction: column;*/
		padding: 0;
	}
	.page-template-top #recipe_list .title_1 .left{
		text-align: left;
	}
	.page-template-top #recipe_list .title_1 .right{
		text-align: right;
		margin: 100px 0 0 -200px;
	}
	.page-template-top #recipe_list .title_2{
		margin: 0 0 10px;
	}
	.page-template-top #recipe_list .tejun{
		gap: 4.7vw;
	}
	.page-template-top #recipe_list .tejun .left .image{
		width: 27.8vw;
	}
	.page-template-top #recipe_list .tejun .text{
		font-size: 2.5vw;
	}
}
@media (max-width: 980px) {
	.page-template-top #recipe_list .title_1 .right{
		margin: 150px 0 0 -200px;
	}
}
@media (max-width: 900px) {
	.page-template-top #recipe_list .recipe{
		padding: 1px 6vw 5vw;
	}
	.page-template-top #recipe_list .recipe h3{
		font-size: 4.7vw;
	}
	.page-template-top #recipe_list .recipe h3 .inner{
		min-width: 0;
		width: 100%;
	}
	.page-template-top #recipe_list .recipe h3 .h3_1{
		font-size: 3vw;
	}
}
@media (max-width: 800px) {
	.page-template-top #recipe_list{
		padding: 3vw;
	}
	.page-template-top #recipe_list .title_1 .left img{
		width: 52vw;
	}
	.page-template-top #recipe_list .title_1 .right{
		margin: 18.7vw 0 0 -200px;
	}
	.page-template-top #recipe_list .title_1 .right img{
		width: 52vw;
	}
	.page-template-top #recipe_list .title_3{
		font-size: 5.5vw;
	}
	.page-template-top #recipe_list .image_zairyou{
		flex-direction: column;
		align-items: center;
	}
	.page-template-top #recipe_list .image_zairyou .image{
		margin: 0;
	}
	.page-template-top #recipe_list .image_zairyou .zairyou{

	}
}
@media (max-width: 770px) {
	.page-template-top #recipe_list .tejun .left{
		width: 360px;
	}
	.page-template-top #recipe_list .tejun .left .image{
		width: 100%;
	}
	.page-template-top #recipe_list .tejun .left .text{
		display: flex;
		font-size: 2.2rem;
	}
	.page-template-top #recipe_list .tejun .right{
		display: none;
	}
}

hr.type1{
	border: 0;
	width: 1100px;
	max-width: 90%;
	height: 3px;
	background-image: url(img/top/hr1.png);
	background-position: 50%;
	margin: 70px auto;
}

.page-template-top #access_contact{
	position: relative;
	top: -100px;
}
.page-template-top .access_contact{
	width: 1100px;
	max-width: 90%;
	margin: 0 auto;
}
.page-template-top .access_contact h2{
	text-align: center;
	font-size: 4.1rem;
	font-weight: normal;
	letter-spacing: 0.07em;
}
.page-template-top .access_contact .tel_fax{
	display: flex;
	align-items: center;
	white-space: nowrap;
	font-size: min(2.2rem, 1.7vw);
	margin: 30px 0;
}
.page-template-top .access_contact .tel_fax > span{
	display: flex;
	align-items: center;
}
.page-template-top .access_contact .tel_fax .big{
	font-size: min(4.2rem, 3.4vw);
	margin: 0 10px;
}
.page-template-top .access_contact .tel_fax a{
	text-decoration: none;
}
.page-template-top .access_contact .row1{
	display: flex;
	justify-content: space-between;
	gap: 50px;
}
.page-template-top .access_contact .row1 .left{
	position: relative;
	flex-basis: 500px;
	flex-grow: 1;
}
.page-template-top .access_contact .row1 :is(.left, .right) .title{
	font-size: 2.1rem;
}
.page-template-top .access_contact .row1 .left textarea{
	height: 330px;
}
.page-template-top .access_contact .row1 .right{
	flex-basis: 500px;
	flex-grow: 1;
/*	margin: 42px 0 0;*/
}
.page-template-top .access_contact .row1 .right .map iframe{
	width: 100%;
	height: 350px;
}
.page-template-top .access_contact .row1 .right .name{
	font-size: 2rem;
	letter-spacing: 0.15em;
	margin: 40px 0 0;
}
.page-template-top .access_contact .row1 .right p{
	margin: 5px 0 0;
	font-feature-settings: "palt"; /* 文字詰め（フォントにカーニング情報が含まれる場合） */
}
@media (max-width: 900px) {
	.page-template-top .access_contact .tel_fax{
		flex-direction: column;
		font-size: 1.5rem;
		padding: 0 0 0 30px;
	}
	.page-template-top .access_contact .tel_fax > span{
		width: 420px;
	}
	.page-template-top .access_contact .tel_fax .big{
		font-size: 3rem;
	}
	.page-template-top .access_contact .row1{
		flex-direction: column;
		gap: 50px;
	}
	.page-template-top .access_contact .row1 .left{
		order: 2;
	}
	.page-template-top .access_contact .row1 .right{
		width: 100%;
	}
}


/* NEWS *************************************************************************** */

body.blog .site-main{
	margin: 0 0 100px;
}

body.blog h1{
	text-align: center;
	font-weight: 300;
	margin: 100px 0 50px;
}

body.blog article{
	padding: 40px 0 30px;
	border-bottom: 1px solid #3a2383;
}
body.blog article:after{
	content: "";
	display: block;
	clear: both;
}
body.blog article .date{
	font-size: 1.4rem;
}
body.blog article .title{
	font-size: 2.5rem;
	margin: 0 0 20px 0;
}
body.blog article .content{
/*	font-size: 1.4rem;*/
	line-height: 2.1;
}
body.blog .pagination{
	text-align: center;
	margin: 50px 0 200px;
}
body.blog .pagination h2{
	display: none;
}
body.blog .pagination .nav-links > div{
	display: inline-block;
	margin: 0 50px;
}
body.blog .screen-reader-text{
	display: none;
}
body.blog .nav-links{
	display: flex;
	justify-content: center;
	gap: 20px;
}
body.blog.single .nav-links{
	justify-content: space-between;
	gap: 50px;
}
body.blog .nav-links :is(.nav-previous, .nav-next){
	max-width: 45%;
}
body.blog .nav-links :is(.nav-previous, .nav-next) a{
	display: flex;
	gap: 10px;
	text-decoration: none;
}
body.blog .nav-links :is(.nav-previous, .nav-next) a .nav-title{
	text-decoration: underline;
}
body.blog .nav-links .nav-next a .nav-title{
	text-align: right;
}



/* お問合せ *************************************************************************** */

.page-template-contact h1{
	background-image: url(img/contact/1_bg.jpg);
	background-size: cover;
	background-repeat: no-repeat;
}


div.wpcf7 .wpcf7-form .ajax-loader{
	display: none;
}

.wpcf7-spinner{
	position: absolute;
	margin-left: calc(50% - 15px);
}

.wpcf7-not-valid-tip{
	position: relative;
	top: -10px;
}

.thanks_url{
	display: none;
}



/* 404 *************************************************************************** */

.error-404{
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 100px;
}



