@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@200..700&family=Shippori+Mincho+B1:wght@400;500;600;700;800&display=swap');

html {
	font-size: 62.5%;
}
body {
	color: #1C1B1A;
	font-size: 1.6rem;
	line-height: 1.8;
	font-weight: normal;
	font-family: ryo-gothic-plusn, sans-serif;
	background: #fafafa;
}
p:not(:last-child) {
	margin-bottom: 12px;
}

@keyframes fogloop {
  from {
      background-position: 0 0;
  }
  to {
      background-position: 280vw 0; /*-1000px部分は画像の横幅と同じ数値*/
  }
}
*, *:before, *:after {
	-webkit-box-sizing: border-box;
	box-sizing: border-box
}
img {
	max-width: 100%;
	height: auto;
	box-sizing: border-box;
	vertical-align: middle;
}
svg {
	display: block;
	margin: -0.2px 0;
	position: relative;
	z-index: 1;
}
p.img img {
	border-radius: 12px;
}

@media screen and (max-width: 1194px) {
	body:before {
		animation: none;
	}
}
@media screen and (max-width: 834px) {
	body {
		font-size: 1.5rem;
		line-height: 2;
	}
}
@media screen and (max-width: 560px) {
}
@media screen and (max-width: 320px) {
	body {
		font-size: 1.4rem;
		line-height: 1.8;
	}
}


/* ***************************************
 * リンク
 * **************************************/

a {
	display: inline-block;
	color: #E60013;
	text-decoration: none;
	transition: all .3s ease;
	word-break: break-all;
	cursor: pointer;
}
a:hover {
	opacity: .7;
}
a.noopacity,
a.noopacity img {
	opacity: 1 !important;
}
a img {
	transition: all .3s;
	-webkit-transition: all .3s;
}
a img:hover {
	opacity: .7;
}



/* 別ウィンドウリンク
 * ************************************/

a.tab,
span.tab {
	display: inline-block !important;
	position: relative;
	padding-right: 18px;
	margin-right: 6px;
	line-height: 1;
}
a.tab:after,
span.tab:after {
	content: "";
	display: inline-block;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	background: url(../images/icon/tab.webp) no-repeat;
	background-size: 100%;
	width: 12px;
	height: 12px;
}
a.tab.white:after,
span.tab.white:after {
	background: url(../images/icon/tab.webp) no-repeat;
	background-size: 100%;
}


/* メインボタン */
.btnPage {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto;
	max-width: 350px;
	width: 100%;
	height: 74px;
	border: 1px solid rgba(5, 103, 64, .3);
    border-radius: 4px;
	text-decoration: none;
	position: relative;
	z-index: 0;
}
.btnPage:hover {
	opacity: 1;
	background: #056740;
	color: #FFF;
}



/* ボタンリスト */
ul.btn_list a {
	display: block;
}
ul.btn_list li {
	border-radius: 12px;
    box-shadow: 0 0 14px rgba(102, 102, 102, 0.2);
    transition: all .3s ease;
}
ul.btn_list li:hover {
	transform: translateY(-3px);
}
ul.btn_list a:hover,
ul.btn_list li img:hover {
	opacity: 1;
}



/* テキストリンク */
a.linkText {
	display: inline-block !important;
	padding-bottom: 3px !important;
	border-bottom: 1px solid !important;
}



@media screen and (max-width: 834px) {
	
}
@media screen and (max-width: 560px) {
	/* ボタンリスト */
	ul.btn_list li {
		box-shadow: 0 0 18px rgba(102, 102, 102, 0.2);
	}
}
@media screen and (max-width: 430px) {
}
@media screen and (max-width: 320px) {
}


/* ******************************************************
 * レスポンシブ
 * *************************************************** */

@media screen and (min-width: 769px) {
	.pc {
		display: block !important;
	}
	.sp {
		display: none !important;
	}
}

@media screen and (max-width: 768px) {
	.pc {
		display: none !important;
	}
	.sp {
		display: block !important;
	}
}


/* ***************************************
 * レイアウト
 * **************************************/

#header {
	
}
#header .header-logo {
	text-align: center;
	padding: 30px 0;
}

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









main {
	margin: 60px 0;
}
.inner {
	max-width: 1240px;
	padding: 0 30px;
	margin: 0 auto;
}
.inside {
	width: 834px;
	margin: 0 auto;
}
.inner_wide {
	max-width: 1920px;
    width: calc(100% - 120px);
	margin: 0 auto;
}


article {
	width: 100%;
}
section {
	padding: 120px 0;
}
.contents {
	margin: 0 auto 0;
	padding: 0 0 90px;
}
.content {
	margin: 0 auto 0;
	padding: 60px;
	background: #FFF;
	border-radius: 18px;
}

.title_box {
	position: relative;
	z-index: 1;
}
.title_box.title_box_contact {
	padding-top: 60px;
}
.title_box:before {
	position: absolute;
	top: calc(50% - 15%);
	left: 50%;
	width: 100%;
	text-align: center;
	transform: translate(-50%, -50%);
	font-size: 12rem;
	font-weight: bold;
	color: #F2F2F2;
	line-height: 1;
	z-index:-1;
}
.title_box.title_box_contact:before {
	content: "CONTACT";
	color: #CCE5FE;
}


/* 固定ページ */
.page_contents {
	
}
.page_items {
	margin-top: 90px;
}
.page_item {
	margin-top: 90px;
}


@media screen and (max-width: 1194px) {
	.inner {
		padding: 0 60px;
	}
	.title_box:before {
		font-size: 10rem;
	}
}
@media screen and (max-width: 1024px) {
	.inner {
		width: 100%;
	}
	.inner__nr {
		width: 100%;
	}
	.inner_wide {
		padding: 0 60px;
	}
	
	.title_box:before {
		font-size: 7rem;
	}
}
@media screen and (max-width: 768px) {
	section {
		padding: 75px 0;
	}
	.inner,
	.inner_wide {
		width: 100%;
		padding: 0 45px;
	}
	.inside {
		width: 100%;
	}
	
	.content {
		padding: 45px 0 75px;
	}
	
	
	.contents_flex {
		flex-direction: column;
	}
	.contents_flex .contents_flex___main {
		width: 100%;
	}
	.contents_flex .contents_flex___side {
		width: 100%;
		margin: 60px 0 0;
	}
	
	.title_box:before {
		font-size: 6rem;
	}
}
@media screen and (max-width: 559px) {
	section {
		padding: 60px 0;
	}
	.contents {
		padding: 0 0 60px;
	}
	.content {
		padding: 30px 0 60px;
	}
	
	.title_box:before {
		font-size: 5rem;
	}
	.title_box.title_box_contact {
		padding-top: 45px;
	}
}
@media screen and (max-width: 430px) {
	.inner,
	.inner__nr,
	.inner_wide {
		padding: 0 30px;
	}
	
	.title_box:before {
		font-size: 4rem;
	}
}
@media screen and (max-width: 380px) {
	.inner,
	.inner__nr,
	.inner_wide {
		padding: 0 20px;
	}
	
	.title_box:before {
		font-size: 3rem;
	}
}
@media screen and (max-width: 320px) {
	section {
		padding: 45px 0;
	}
}


/* YouTube 埋め込み
 * ***************************************/

.youtube {
	width: 100%;
	aspect-ratio: 16 / 9;
}
.youtube.middle {
	width: 60%;
	margin: 0 auto;
}
.youtube iframe {
	width: 100%;
	height: 100%;
	border: 4px solid #FFF;
	border-radius: 12px;
    box-shadow: 0 0 14px rgba(102, 102, 102, .3);
	position: relative;
	z-index: 1;
}

.youtube_effect {
	position: relative;
}
.youtube_effect:before {
	content: "";
    display: inline-block;
    position: absolute;
    bottom: -120px;
    left: 0;
    background: url(../images/common/effectLine_gold.webp) no-repeat;
    background-size: cover;
    width: 420px;
    height: 420px;
}
.youtube_effect:after {
	content: "";
	display: inline-block;
	position: absolute;
	top: -120px;
    right: 0;
    background: url(../images/common/effectLine_gold.webp) no-repeat;
    background-size: cover;
    width: 420px;
    height: 420px;
}


@media screen and (max-width: 1194px) {
}
@media screen and (max-width: 960px) {
}
@media screen and (max-width: 834px) {
	.youtube.middle {
		width: 75%;
	}
	.youtube_effect:before {
		left: -30px;
		width: 330px;
		height: 330px;
	}
	.youtube_effect:after {
		right: -30px;
		width: 330px;
		height: 330px;
	}
}
@media screen and (max-width: 560px) {
	.youtube.middle {
		width: 100%;
	}
	.youtube_effect:before {
		background: url(../images/common/effectLine_gold_sp.webp) no-repeat;
		background-size: cover;
		background-position: center;
		left: -60px;
		bottom: -90px;
		width: 220px;
		height: 220px;
	}
	.youtube_effect:after {
		background: url(../images/common/effectLine_gold_sp.webp) no-repeat;
		background-size: cover;
		background-position: center;
		top: -90px;
		right: -60px;
		width: 220px;
		height: 220px;
	}
}
@media screen and (max-width: 430px) {
}
@media screen and (max-width: 320px) {
}



/* common
 * ***************************************/

#common .header_flex .header_flex___logo {
	width: calc(100% / 2);
	text-align: center;
}
#common .header_flex .header_flex___logo a {
	display: inline-block !important;
}


@media screen and (max-width: 834px) {
	#common .header_flex {
		flex-direction: row;
	}
	#common .header_flex .header_flex___logo {
		
	}
}


/* ***************************************
 * ヘッダー
 * ***************************************/

header {
	text-align: center;
}
header .header-flex {
	display: flex;
}
header #navigation {
}

@media screen and (max-width: 1441px) {
}
@media screen and (max-width: 768px) {
	
}
@media screen and (max-width: 559px) {
	
}
@media screen and (max-width:430px) {
	
}
@media screen and (max-width: 320px) {
	
}


/****************************************
 * グローバルナビ
 * **************************************/

nav.general {
    max-width: 700px;
    width: 45%;
    margin-left: auto;
	z-index: 2;
}
nav.general .gnav_front {
	margin-right: 120px;
}
nav.general ul.gnav_front_list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	justify-content: flex-end;
}
nav.general ul.gnav_front_list li {
	min-width: 150px;
	line-height: 2.3;
}
nav.general ul.gnav_front_list li a {
	display: block;
	text-align: center;
	font-family: ryo-display-plusn, serif;
	color: #FFF;
	padding: 18px;
}
nav.general ul.gnav_front_list li a span {
	display: block;
	font-family: "bodoni-moda-variable", sans-serif;
	font-size: 9px;
	font-weight: bold;
	text-align: center;
	margin-top: -6px;
}
nav.general ul.gnav li a:hover {
	opacity: 1;
	background: #D60079;
}

nav.general .gnav_back {}
nav.general .gnav_back .gnav_back_box {
	display: block;
	position: fixed;
	top: 0;
	right: -300px;
	bottom: 0;
	width: 300px;
	background: #ffffff;
	overflow-x: hidden;
	overflow-y: auto;
	padding: 45px;
	-webkit-overflow-scrolling: touch;
	transition: .5s;
	z-index: 3;
}

nav.general .open .gnav_back_box {
	right: 0;
}
nav.general ul.gnav_back_list {
	list-style: none;
	margin: 0;
	padding: 0;
	border-bottom: 1px solid #ededed;
}
nav.general ul.gnav_back_list li {
	text-align: center;
	border-top: 1px solid #ededed;
}
nav.general ul.gnav_back_list li span {
	display: block;
    font-family: ryo-gothic-plusn, sans-serif;
    font-size: 9px;
    font-weight: bold;
    text-align: center;
}
nav.general ul.gnav_back_list li a {
	display: block;
	padding: 18px 0;
	color: #E4007F;
	font-family: ryo-display-plusn, serif;
	font-size: 1.6rem;
}
nav.general ul.gnav_back_list li a span {
	font-family: "bodoni-moda-variable", sans-serif;
	font-size: 1rem;
}
.gnav_back_box .inner ul li a:hover {
	background: #e4e4e4;
}


@media screen and (max-width: 1194px) {
	nav.general .gnav_front {
		margin-right: 75px;
	}
	nav.general ul.gnav_front_list li {
		min-width: 105px;
	}
	nav.general ul.gnav_front_list li a {
		padding: 12px 18px;
	}
}
@media screen and (max-width: 960px) {
}
@media screen and (max-width: 834px) {
	.gnav_back_box {
		right: -240px;
		width: 240px;
	}
}
@media screen and (max-width: 768px) {
	nav.general .gnav_front {
		display: none;
	}
}
@media screen and (max-width: 430px) {
	nav.general .gnav_back .gnav_back_box {
		width: 280px;
	}
	nav.general ul.gnav_back_list li a {
		font-size: 1.5rem;
	}
}
@media screen and (max-width: 380px) {
	nav.general .gnav_back .gnav_back_box {
		width: 260px;
		padding: 30px;
	}
	nav.general ul.gnav_back_list li a {
		font-size: 1.4rem;
	}
}
@media screen and (max-width: 380px) {
	nav.general .gnav_back .gnav_back_box {
		width: 240px;
	}
	nav.general ul.gnav_back_list li a {
		padding: 12px 0;
	}
}


/* ハンバーガー 
 * **************************************/

nav.general .toggle_btn {
	display: block;
	position: fixed;
	top: 60px;
	right: 60px;
	width: 60px;
	height: 30px;
	transform: translate(0, 0);
	transition: all .5s;
	cursor: pointer;
	z-index: 3;
}
nav.general .open .toggle_btn {
	right: 330px;
}
nav.general .toggle_btn span {
	display: block;
	position: absolute;
	right: 0;
	width: 30px;
	height: 2px;
	background-color: #FFF;
	transition: all .5s;
}
nav.general .toggle_btn span:nth-child(1) {
	top: 5px;
	width: 60px;
	animation: equalizer01 7000ms infinite;
}
nav.general .toggle_btn span:nth-child(2) {
	top: 15px;
	width: 30px;
	animation: equalizer02 5000ms infinite;
	animation-delay: 0.33s;
}
nav.general .toggle_btn span:nth-child(3) {
	top: 25px;
	width: 20px;
	animation: equalizer02 5000ms infinite;
}
nav.general .open .toggle_btn span {
	background-color: #fff;
	width: 30px;
}
nav.general .open .toggle_btn span:nth-child(1) {
	transform: translate(0, 10px) rotate(-45deg);
	animation: unset;
}
nav.general .open .toggle_btn span:nth-child(2) {
	opacity: 0;
	animation: unset;
}
nav.general .open .toggle_btn span:nth-child(3) {
	transform: translate(0, -10px) rotate(45deg);
	animation: unset;
}

@keyframes equalizer01 {
	0% { width: 70%; }
	10% { width: 50%; }
	20% { width: 100%; }
	30% { width: 10%; }
	40% { width: 50%; }
	50% { width: 70%; }
	60% { width: 50%; }
	70% { width: 10%; }
	80% { width: 100%; }
	90% { width: 10%; }
	100% { width: 70%; }
}
@keyframes equalizer02 {
	0% { width: 30%; }
	10% { width: 20%; }
	20% { width: 40%; }
	30% { width: 10%; }
	40% { width: 20%; }
	50% { width: 30%; }
	60% { width: 20%; }
	70% { width: 10%; }
	80% { width: 40%; }
	90% { width: 10%; }
	100% { width: 30%; }
}

@media screen and (max-width: 1194px) {
	nav.general .toggle_btn {
		top: 42px;
		right: 30px;
	}
}
@media screen and (max-width: 768px) {
	.open .toggle_btn {
		right: 260px;
	}
	nav.general .toggle_btn span {
		background: #E4007F;
	}
}
@media screen and (max-width: 560px) {
	nav.general .toggle_btn {
		top: 30px;
		right: 30px;
	}
	nav.general .toggle_btn span {
		background: #E4007F;
	}
}
@media screen and (max-width: 430px) {
	nav.general .toggle_btn {
		top: 24px;
	}
	nav.general .open .toggle_btn {
		right: 290px;
	}
}
@media screen and (max-width: 380px) {
	nav.general .open .toggle_btn {
		right: 275px;
	}
}
@media screen and (max-width: 380px) {
	nav.general .open .toggle_btn {
		right: 260px;
	}
}
@media screen and (max-width: 320px) {
	nav.general .open .toggle_btn {
		right: 250px;
	}
}



/* マスク 
 * **************************************/

nav.general #mask {
	visibility: hidden;
	opacity: 0;
	transition: all .3s ease;
}
nav.general .open #mask {
	visibility: visible;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #000;
	opacity: .7;
	z-index: 2;
	transition: all .3s ease;
	cursor: pointer;
}


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



/* ***************************************
 * H要素
 * **************************************/

h1, h2, h3, h4, h5, h6 {
	font-family: ryo-gothic-plusn, sans-serif;
	font-weight: 400;
	line-height: 1.4;
	margin: 0;
	text-align: center;
	color: #056740;
}

h1 {
	font-size: 100%;
}
h2 {
	font-size: 5.8rem;
	margin-bottom: 30px;
}
h3 {
	text-align: left;
	font-size: 3.2rem;
	margin-bottom: 30px;
}
h4 {
	text-align: left;
	font-size: 3rem;
	margin-bottom: 30px;
}


.sec_title {
	padding-top: 45px;
	position: relative;
	z-index: 1;
}
.sec_title.ver {
	display: flex;
    justify-content: center;
}
.sec_title.ver span.verSpan {
	white-space: pre;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	text-align: left;
}
.sec_title:before {
	content: "";
	position: absolute;
	left: 50%;
	top: 0;
	transform: translateX(-50%);
	background: url(../images/common/wing.webp) no-repeat;
	background-size: 100%;
	width: 58px;
	height: 28px;
}
.sec_title span {
	display: block;
	font-size: 3rem;
}

.sec_subtitle {
	text-align: center;
	padding-bottom: 30px;
	position: relative;
}
.sec_subtitle span {
	display: block;
	font-size: 2.6rem;
	margin-top: 6px;
}
.sec_subtitle:after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
	background: #093A69;
	width: 90px;
	height: 1px;
}


@media screen and (max-width: 1280px) {
	h2 {
		font-size: 4.8rem;
	}
}
@media screen and (max-width: 768px) {
	h2 {
		font-size: 4.2rem;
	}
	h3 {
		font-size: 3rem;
	}

	.sec_title.ver {
		-ms-writing-mode: lr-tb;
		writing-mode: horizontal-tb;
		text-align: center;
	}
	.sec_title.ver span.verSpan {
		-ms-writing-mode: lr-tb;
		writing-mode: horizontal-tb;
		text-align: center;
	}
}
@media screen and (max-width: 559px) {
	h2 {
		font-size: 3.2rem;
	}
	h3 {
		font-size: 2.6rem;
	}
	h4 {
		font-size: 1.4rem;
	}

	.sec_title span {
		font-size: 2.2rem;
	}
	.sec_title span.albumTitle {
		margin-bottom: -30px;
	}
	.sec_subtitle span {
		font-size: 2rem;
	}
	
	.sec_title.ver {
		
	}
}
@media screen and (max-width: 430px) {
	h2 {
		
	}
	h3 {
		font-size: 2.2rem;
	}
	h4 {
		font-size: 1.3rem;
	}

	.sec_title span {
		font-size: 2rem;
	}
	.sec_subtitle span {
		font-size: 1.8rem;
	}
}
@media screen and (max-width: 380px) {
	h2 {
		font-size: 2.2rem;
	}
	h3 {
		font-size: 2rem;
	}
	h4 {
		font-size: 1.3rem;
	}

	.sec_title span {
		font-size: 2rem;
	}
	.sec_subtitle span {
		font-size: 1.6rem;
	}
}
@media screen and (max-width: 320px) {
	h2 {
		
	}
	h3 {
		font-size: 1.8rem;
	}
	h4 {
		font-size: 1.2rem;
	}

	.sec_title span {
		font-size: 1.6rem;
		margin-top: 3px;
	}
	.sec_subtitle span {
		font-size: 1.4rem;
	}
}





/****************************************
 * パンくず
 * **************************************/

.breadcrumbs_area {
	padding: 18px 0;
}
.breadcrumbs {
	font-size: .8em;
}
.breadcrumbs a {
	color: #06140C;
}
.breadcrumbs span.hyphen {
	padding: 0 12px;
}
.breadcrumbs span.current-item {
	font-weight: bold;
	color: #133D24;
}

@media screen and (max-width: 560px) {
	.breadcrumbs {
		overflow-x: auto;
		white-space: nowrap;
	}
}
@media screen and (max-width: 560px) {
	
}



/****************************************
 * 共通
 * ****************************************/

/*スライドイン
 * ****************************************/

.slideinSlow {
	animation: SlideInSlow 2s;
}
@keyframes SlideInSlow {
	0% {
		opacity: 0;
		transform: translateX(64px);
	}
	100% {
		opacity: 1;
		transform: translateX(0);
	}
}
.slideinSlow2 {
	animation: SlideInSlow2 2.8s;
}
@keyframes SlideInSlow2 {
	0% {
		opacity: 0;
		transform: translateX(128px);
	}
	100% {
		opacity: 1;
		transform: translateX(0);
	}
}




/*見出し
*****************************************/
.page_topimage h2.topimage_title {
	text-align: center;
	font-size: 2.6em;
	color: #FFF;
	position: absolute;
	left: 0;
	right: 0;
	top: 50%;
	margin: auto;
	transform: translateY(-50%) translateX(0);
}
.page_topimage h2.topimage_title span {
	display: block;
	text-transform: uppercase;
	font-size: .5em;
	font-weight: bold;
}

@media screen and (max-width: 560px) {
	.page_topimage h2.topimage_title {
		font-size: 2em;
	}
	.pagecontents_title {
		font-size: 1.3rem;
		padding-left: 30px;
	}
}
@media screen and (max-width: 430px) {
	.page_topimage h2.topimage_title {
		font-size: 1.8em;
	}
	.pagecontents_title {
		padding-left: 0;
	}
}
@media screen and (max-width: 320px) {
	.page_topimage h2.topimage_title {
		font-size: 1.6em;
	}
}


/* ボタンボックス
 * ***************************************/

.btnBox {
	text-align: center;
	margin-top: 60px;
	position: relative;
	z-index: 0;
}
.btnBox.m0 {
	margin-top: 0;
}
.btnBox.m30 {
	margin-top: 30px;
}
.button_box.left {
	text-align: left;
}
.button_box.right {
	text-align: right;
}
.button_box a {
	text-decoration: none !important;
}



@media screen and (max-width: 430px) {
	.button_box {
		margin-top: 30px;
	}
}


/* 上付き
 * ***************************************/

.sup {
	display: inline !important;
	vertical-align: top !important;
	font-size: .8em !important;
}


/* 小さい字
 * ***************************************/

.small {
	font-size: .8em;
}



/* ページ内ジャンプ
 * ***************************************/

ul.jump_list {
	list-style: none;
	margin: -45px auto 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
}
ul.jump_list li {
	width: calc(100% / 4 - 18px);
    margin: 30px 24px 0 0;
	padding-left: 18px;
	border-bottom: 1px solid #285063;
	position: relative;
}
ul.jump_list li:nth-child(4n) {
	margin-right: 0;
}
ul.jump_list li:before {
	content: "";
	display: inline-block;
	position: absolute;
	top: 50%;
	left: 1em;
	transform: translateY(-50%);
	background: url(../images/common/icon_arrowMain.webp) no-repeat;
	background-size: 100%;
	background-position: center;
	width: 16px;
	height: 16px;
}
ul.jump_list li a {
	overflow: hidden;
	display: block;
	height: 100%;
	padding: 12px 18px 12px 26px;
}
ul.jump_list li a:hover {
	opacity: 1;
	font-weight: bold;
}
ul.jump_list li .jump_flex {
	
}
ul.jump_list li .jump_flex .jump_flex___img {
	
}
ul.jump_list li .jump_flex .jump_flex___txt {
	padding: 30px;
}
ul.jump_list li .jump_flex .jump_flex___txt p.jump_flex___txt_title {
	text-align: center;
	font-size: 1.3rem;
	font-weight: bold;
	margin-bottom: 18px;
	color: #568A35;
}


@media screen and (max-width: 768px) {
	ul.jump_list {
		width: 100%;
		margin: -26px auto 0;
	}
	ul.jump_list li {
		width: calc(100% / 2 - 12px);
		margin: 26px 24px 0 0;
	}
}
@media screen and (max-width: 560px) {
	ul.jump_list {
		margin: -18px 0 0 0;
	}
	ul.jump_list li {
		width: 100%;
		margin: 18px 0 0 0;
	}
	ul.jump_list li .jump_flex {
		display: flex;
		align-items: center;
	}
	ul.jump_list li .jump_flex .jump_flex___img {
		width: 150px;
	}
	ul.jump_list li .jump_flex .jump_flex___txt {
		width: calc(100% - 150px);
		padding: 0 0 0 30px;
	}
	ul.jump_list li .jump_flex .jump_flex___txt p.jump_flex___txt_title {
		text-align: left;
		margin: 0;
		font-size: 1.1rem;
	}
}
@media screen and (max-width: 430px) {
	ul.jump_list li .jump_flex .jump_flex___img {
		width: 105px;
	}
	ul.jump_list li .jump_flex .jump_flex___txt {
		width: calc(100% - 105px);
		padding: 0 0 0 18px;
	}
	ul.jump_list li .jump_flex .jump_flex___txt p.jump_flex___txt_title {
		text-align: left;
		margin: 0;
		font-size: .9rem;
	}
}


p.ready {
	text-align: center;
	font-family: 'ShipporiMinchoB1', serif;
	font-size: 1.12rem;
}



/****************************************
 * テキスト
 * *************************************/

span.price {
	font-size: 4rem;
	margin-left: 12px;
	display: inline-block !important;
}
span.yen {
	font-size: 3rem;
	margin-left: 6px;
	display: inline-block !important;
}

span.moya {
	display: inline-block;
	position: relative;
}
span.moya:before {
	content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: linear-gradient(275deg, #FFE5F3 0%, #FFE5F3 50%, #FFE5F3 100%);
    filter: blur(30px);
	z-index: -1;
}

@media screen and (max-width: 834px) {
	span.price {
		font-size: 3rem;
	}
	span.yen {
		font-size: 2rem;
	}
}
@media screen and (max-width: 560px) {
	span.price {
		font-size: 2.6rem;
	}
	span.yen {
		font-size: 1.8rem;
	}
}
@media screen and (max-width: 430px) {
}
@media screen and (max-width: 320px) {
}



/* キャラクターの案内 */

b.magenta {
	color: #E4007F;
}
b.or {
	color: #fe5f14;
}
b.blue {
	color: #093A69;
}



/***************************************
 * ページナビゲーション
 * *************************************/

nav.navigation {
	overflow: hidden;
	float: none;
	max-width: 100%;
	text-align: center;
	padding: 0;
	margin: 60px 0 0;
}
nav.navigation h2.screen-reader-text {
	display: none;
}
nav.navigation .nav-links {
	width: 100%;
	display: flex;
    justify-content: center;
}
nav.navigation .page-numbers {
	display: inline-block;
	margin: 0 18px;
	padding: 0 1em;
	border-radius: 4px;
	width: auto;
	height: 48px;
	line-height: 48px;
}
nav.navigation .nav-links span.current {
	background: #056740;
	color: #FFF;
}
nav.navigation a {
	display: inline-block !important;
	color: #FFF;
}
nav.navigation .nav-links a.page-numbers {
	background: #ededed;
	color: #056740;
}
nav.navigation .nav-links a.prev,
nav.navigation .nav-links a.next {
	width: auto;
}

@media screen and (max-width: 768px) {
	nav.navigation {
		display: block;
	}
}
@media screen and (max-width: 560px) {
	nav.navigation .page-numbers {
		margin: 0 6px;
		padding: 0 12px;
	}
}




/****************************************
 * フォーム
*****************************************/

/* iOSリセット */
input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}
select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    outline: none;
    background: transparent;
}
button,
input[type="submit"] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding: 0;
    border: none;
    outline: none;
    background: transparent;
}

/*フォーム*/
textarea {
	overflow: auto;
	resize: vertical;
}
input[type="text"],
input[type="tel"],
input[type="email"],
input[type="search"],
textarea {
	font-size: 1em;
	margin: 0;
	padding: 18px;
	width: 100%;
	max-width: 100%;
	outline: none;
	color: #000;
	vertical-align: bottom;
	transition: .3s;
	letter-spacing: 1px;
	border-radius: 6px;
	border: 1px solid #ededed;
	background: #FFF;
}
input[type="text"]:focus,
input[type="tel"]:focus,
input[type="password"]:focus,
input[type="email"]:focus,
input[type="search"]:focus,
textarea:focus {
	background: #FFF;
	border: 1px solid #E4007F;
	outline: none;
}
select {
	position: relative;
	width: 100%;
	min-width: 75px;
	padding: 18px 22px 18px 12px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: 1px solid #ededed;
	background: #fff url(../images/common/select.webp) no-repeat;
	background-position: right 1em center;
    background-size: 12px, 100%;
	font-size: 1em;
	color: #000;
	border-radius: 6px;
}

/*ボタン*/
.button,
button,
input[type="submit"],
input[type="reset"],
input[type="button"],
.button:before,
button:before,
input[type="submit"]:before,
input[type="reset"]:before,
input[type="button"]:before,
.button:after,
button:after,
input[type="submit"]:after,
input[type="reset"]:after,
input[type="button"]:after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .3s;
	transition: all .3s;
}
.button,
button,
input[type="submit"],
input[type="reset"],
input[type="button"] {
	display: inline-block;
	padding: 10px 20px;
	font-size: 1.6rem;
	font-weight: bold;
	color: #fff;
	background-color: #E4007F;
	border: none;
	border-radius: 4px;
	cursor: pointer;
	text-align: center;
	transition: background-color 0.3s ease;
}
.button:hover,
button:hover,
input[type="submit"]:hover,
input[type="reset"]:hover,
input[type="button"]:hover {
	background-color: #023521;
}
.button:before,
button:before,
input[type="submit"]:before,
input[type="reset"]:before,
input[type="button"]:before,
.button:after,
button:after,
input[type="submit"]:after,
input[type="reset"]:after,
input[type="button"]:after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}

@media screen and (max-width: 559px) {
	.button,
	button,
	input[type="submit"],
	input[type="reset"],
	input[type="button"] {
		display: block;
		margin: 0 auto;
		padding: 0 3.5em;
		line-height: 60px;
		border-radius: 60px;
	}
}
@media screen and (max-width: 380px) {
	input[type="text"],
	input[type="tel"],
	input[type="email"],
	input[type="search"],
	textarea {
		padding: 15px;
	}
	select {
		padding: 15px 22px 15px 12px;
	}
}
@media screen and (max-width: 320px) {
	input[type="text"],
	input[type="tel"],
	input[type="email"],
	input[type="search"],
	textarea {
		padding: 12px;
	}
	select {
		padding: 12px 22px 12px 9px;
	}
}


input[type="radio"],
input[type="checkbox"] {
	width: 18px;
	height: 18px;
	padding: 0 !important;
	margin: 0 6px 0 0;
}

@media screen and (max-width: 1194px) {
	input[type="radio"],
	input[type="checkbox"] {
		
	}
}
@media screen and (max-width: 960px) {
}
@media screen and (max-width: 834px) {
}
@media screen and (max-width: 560px) {
}
@media screen and (max-width: 430px) {
}
@media screen and (max-width: 320px) {
}



/****************************************
 * フォーム送信後の完了ページ
 * **************************************/

#completed .completedMessage {
	    text-align: center;
}







/****************************************
 * WPネイティブCSS
 * **************************************/

.alignleft {
	float: left;
}
.alignright {
	float: right;
}
.wp-block-image {
	margin: 30px 0;
}
.wp-block-image figcaption {}
img[class*="wp-image-"],
img[class*="attachment-"] {
	max-width: 100%;
	height: auto;
}
img.alignright {
	display: block;
	margin: 0 0 0 auto;
}
img.alignleft {
	display: block;
	margin: 0 auto 0 0;
}
img.aligncenter {
	display: block;
	margin: 0 auto;
}
blockquote {
	display: block;
	-webkit-margin-before: 1em;
	-webkit-margin-after: 1em;
	-webkit-margin-start: 40px;
	-webkit-margin-end: 40px;
	margin: 50px;
	border-left: 1px solid #ededed;
	padding-left: 30px;
}
cite {
	font-size: .8em;
}
cite a {
	display: inline-block;
	color: #005CB5;
	border-bottom: 1px solid #005CB5;
}

/* clearfix */
.clearfix {
	overflow: hidden;
	zoom: 1;
}
.clearfix:after {
	content: "";
	display: block;
	clear: both;
}

@media screen and (max-width: 560px) {
	blockquote {
		margin: 30px;
	}
	.wp-block-image {
		margin: 0;
	}
}

/****************************************
 * 画像キャプション
 * **************************************/

.wp-caption {
	text-align: right;
}
.wp-caption-text,
.gallery-caption　{
	font-size: 12px;
	margin: 0;
	color: #333;
}
.wp-caption img {
	margin: 0;
	padding: 0;
	border: 0 none;
	vertical-align: bottom;
}
.wp-caption-dd {
	margin: 0;
	padding: 0 4px 5px;
	font-size: 11px;
	line-height: 17px;
}



/*****************************************
 * フッター
 * ***************************************/

footer {
	
}
footer .footer-top {
	padding: 60px 0;
	background: #E60013;
}
footer .footer-bottom {
	background: #fafafa;
	padding: 18px 0;
	font-size: .8em;
}

footer a {
	color: #FFF;
}
@media screen and (max-width: 1194px) {
	
}

/* 上へ戻る */
footer .totop {
	position: fixed;
	bottom: 30px;
	right: 30px;
	z-index: 3;
}


footer .navigation-fnav {
	display: flex;
	flex-direction: column;
}
footer .navigation-fnav ul.fnav {
	margin-right: 60px;
}
footer .navigation-fnav ul.fnav li {
	display: inline-block;
	margin-top: 12px;
}
footer .navigation-fnav ul.fnav li:not(:last-child) {
	margin-right: 18px;
}
footer .navigation-fnav ul.fnav.home-fnav {
	margin-top: -18px;
}
footer .navigation-fnav ul.fnav.pages-fnav {
	margin-top: 0;
}
footer .footer-top .footer-topLogo {
	text-align: right;
	margin-top: 30px;
}



.footer-bottom-flex {
	display: flex;
    justify-content: space-between;
    align-items: center;
}
.footer-bottom-flex .footer-bottom-flex___copy {
	color: #666;
}
.footer-bottom-flex .footer-bottom-flex___must {
	display: flex;
    align-items: center;
}
.footer-bottom-flex .footer-bottom-flex___must a {
	display: block;
	color: #000;
}
.footer-bottom-flex .footer-bottom-flex___must a:nth-child(n+2) {
	margin-left: 2em;
}

@media screen and (max-width: 1194px) {
	
}
@media screen and (max-width: 1024px) {
	
}
@media screen and (max-width: 768px) {
	
	footer .navigation-fnav ul.fnav {
		width: 480px;
		        margin-right: 0;
	}
	
	
	.footer-bottom-flex {	
        flex-direction: column-reverse;
	}
	.footer-bottom-flex .footer-bottom-flex___copy {
		margin-top: 30px;
	}
}
@media screen and (max-width: 559px) {
	footer .navigation-fnav ul.fnav {
		width: 100%;
	}
	
	footer .footer-top .footer-topLogo {
		margin-top: 60px;
	}
	footer .footer-topLogo img.footer-logo {
		width: 150px;
	}
	
	
	
	
}
@media screen and (max-width: 430px) {
	footer .footer-topLogo img.footer-logo {
		width: 120px;
	}
}
@media screen and (max-width: 320px) {
	footer .footer-topLogo img.footer-logo {
		width: 105px;
	}
}












/* コピーライト 
 * ***************************************/

footer #copyright {
	text-align: center;
	margin-top: 30px;
	padding: 60px 0;
	border-top: 1px solid #FF008C;
	position: relative;
}
footer #copyright:before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	background: #CC0070;
	width: 100%;
	height: 1px;
}

footer #copyright .inner {
	padding: 0 30px;
}
footer #copyright p.copyright {
	font-size: 1.2rem;
	color: #FFE5F3;
}
footer #copyright p.copyright a {
	color: #FFE5F3;
}

@media screen and (max-width: 559px) {
	
	footer #copyright {
		margin-top: 0;
	}
}
@media screen and (max-width: 430px) {
	
}
@media screen and (max-width: 320px) {
	
}



/* ***************************************
 * developer
 * **************************************/

p.dev {
	text-align: center;
	color: red;
	font-weight: bold;
	font-family: sans-serif;
}


/****************************************
 * ログインユーザー 編集
 * **************************************/

.edit {
	margin-top: 30px;
	text-align: right;
}
.edit .edit_user {
	font-size: 1rem;
	margin: 0;
}
.edit a.editURL {
	font-size: 1.2rem;
	border-bottom: 1px solid;
}



