@charset "utf-8";
/* sp */
@font-face { font-family: "Yu Gothic M"; src: local("Yu Gothic Medium"); }
@font-face { font-family: "Yu Gothic M"; src: local("Yu Gothic Bold"); font-weight: bold; }
body {
	font-family:
	-apple-system, BlinkMacSystemFont,
	"游ゴシック体", YuGothic,
	"Yu Gothic M",
	"游ゴシック Medium", "Yu Gothic Medium",
	"ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN W3", HiraKakuProN-W3,
	"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN",
	"ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro",
	"メイリオ", Meiryo,
	Osaka,
	"ＭＳ Ｐゴシック", "MS PGothic",
	"Helvetica Neue", HelveticaNeue,
	Helvetica,
	Arial,
	"Segoe UI",
	sans-serif,
	"Apple Color Emoji",
	"Segoe UI Emoji",
	"Segoe UI Symbol",
	"Noto Color Emoji";

 	font-size: 16px;
 	font-size: 0.875rem;

	margin: 0;
	padding: 0;
	
	background-color: #fff;
}

a {
	color: #00f;
	text-decoration: none;
}

*, *:before, *:after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}
.pc {
	display: none;
}
.contents-wrapper {
	position: relative;
	width: 100%;
	margin: 0 auto;
	padding: 0;
	background: #fff;
	box-sizing: border-box;
}

header {
	position: relative;
	left: 0;
	top: 0;
	max-width: 100%;
	width: 100%;
 	font-size: 0.875rem;
}
.header_menu {
	display: flex;
	align-items: center;
	/* justify-content: space-between; */
	/* height: 40px; */
	padding: 6px 10px 10px;
	box-sizing: border-box;
}
.cart-box {
	display: flex;
	align-items: center;
	width: 20%;
}
.cart-box span {
	color: #CC0000;
	font-size: 0.75rem;
	font-weight: bold;	
}
.logo {
	width: 20%;
	margin-left: 0px;
}
.cart {
	width: 30px;
	margin: 0 5px 0 auto;
}
.cart img,
.logo img {
	width: 100%;
}
.cvp {
	display: inline-block;
	width: 60%;
	font-size: 0.6875rem;
	font-weight: bold;
	color: #444;
	text-align: center;
	padding-left: 0.5rem;
	/* border-bottom: 1px solid;
	border-image: linear-gradient(to right,rgba(23,127,151,0.3) 1%,rgba(23,127,151,0.8) 50%,rgba(23,127,151,0.8) 51%,rgba(23,127,151,0.3) 100%);
	border-image-slice: 1; */
}
/* ////////////////////////////////////////////////////////////// */
.swiper-container {
	line-height: 0.5;
}
.information-container {
	width: 100%;
	margin: 0 auto 4%;
	padding: 2% 4%;
	color: #000;
	background-color: #EFFBFB;
}
.information-container p {
	font-size: 0.875rem;
	line-height: 1.3;
}
.information-container p.catch {
	font-weight: bold;
}
h2.title {
	width: 100%;
	padding: 0.5rem 0;
	font-size: 1.0rem;
	font-weight: bold;
	background-color: #20859C;
	color: #fff;
	text-align: center;
	margin-bottom: 5%;
}
@media screen and (max-width: 359px) {
	h2.title {
		font-size: 0.875rem;
	}
}

/* btn */
.btn_main {
	position: relative;
	display: flex;
	align-items: center;
	font-size: 1.0rem;
	font-weight: bold;
	
	/* width: 335px; */
	width: 90%;
	height: 44px;
	margin: 0 auto 20px;
	padding: 0 20px;
	line-height: 0.5;
	
	background: linear-gradient(180deg, #FFFFFF 0%, rgba(255, 255, 255, 0) 100%), #E7E7E7;
	/* border */
	border: 1px solid #BDBDBD;
	box-sizing: border-box;
	border-radius: 5px;
}
.btn_main a {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	color: #000;
	
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	padding: 0 15px;
}
.btn_main span {
	margin-right: 10px;
}
.btn_main .arrow {
	margin-left: auto;
}
.active {
	transform: rotateZ(90deg);	
	transition: 0.3s;
}

.menu_groups {
	display: none;
}
.submenu_groups {
	display: flex;
	flex-wrap: wrap;
	justify-content: start;
	
	width: 90%;
	margin: 0 auto 50px;
	padding: 0 0;
	
	/* border: 1px solid #ccc;
	border-top: none;
	border-radius: 0 0 5px 5px; */
}
.btn_submenu {
	position: relative;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
		
	display: flex;
	align-items: center;
	width: 46%;
	height: 38px;
	padding: 0 5px;
	margin: 0 2% 2%;
	
	background: linear-gradient(180deg, #FFFFFF 0%, rgba(255, 255, 255, 0) 100%), #D2F4F4;
	border: 1px solid #BDBDBD;
	border-radius: 5px;

	font-size: 0.75rem;;
	font-weight: bold;
	line-height: 100%;
	color: #13A5AE;
	box-sizing: border-box;
}
.btn_submenu:hover {
	opacity: 0.7;
	border: 1px solid #999;
}
.btn_submenu:active {
	opacity: 1.0;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%), #FFFFFF 100%, #D2F4F4;
	border: 1px solid #D2F4F4;
}
.btn_submenu::before{
	font-size: 0.75rem;
	content: "＞";
	padding-right: 5px;
}
.btn_submenu a {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.menu_groups p {
	width: 100%;
	text-align: right;
	margin: 10px 20px 0 0;
}
.menu_groups p a {
	color: #13A5AE;
	text-decoration: underline;
}
.menu_groups p a:before {
	content: "▶ ";
}
.menu_groups p a:hover {
	opacity: 0.7;
}
.menu_groups p a:active {
	opacity: 1.0;
}

/* 星占いのバナー */
.banner_uranai {
	width: 90%;
	margin: 0 auto 30px;
	border: 1px solid #ccc;
	border-radius: 8px;
	padding: 20px;
}
.banner_uranai:hover {
	border: 1px solid #177F97;
	opacity: 0.8;
}
.notice-box {
	width: 84%;
	margin: 10% auto 15%;
	font-size: 0.6875rem;
	line-height: 1.5;
}
.notice-box h4 {
	font-size: 0.75rem;
	font-weight: normal;
	text-decoration: underline;
}

.note-box {
	width: 92%;
	margin: 0 auto;
	padding: 1% 4%;
	font-size: 0.875rem;
	line-height: 1.3;
}

/*	バナー */
.banner-container {
	position: relative;
	width: 90%;
	margin: 20px auto;
	padding: 20px;
	border: 1px solid #e1e1e1;
	border-radius: 8px;
}
.banner-container::after {
	/* content: "PR"; */
	position: absolute;
	top: 5px;
	right: 20px;
	font-size: 0.625rem;
	color: #aaa;
}
.banner-container p.caption {
	font-size: 0.6875rem;
	line-height: 1.1;
	padding: 0 4px;
	color: #444;
}

.year-banner {
	width: 85%;
	margin: 10% auto;
	line-height: 0.8;
}
.year-banner img {
	border: 5px solid #177F97;
	border-radius: 1rem;
}

/* ////////////////////////////////////////////////////////////// */
section {
	width: 100%;
	padding-bottom: 20px;
}
section img {
	width: 100%;
}
.pagemenu-box {
	background-color: #EFFBFB;
}
.pagemenu {
	width: 90%;
	margin: 0 auto 7%;
	padding: 0 0 5%;
}
.pagemenu li {
	width: 100%;
	font-size: 0.8125rem;
	font-weight: bold;
	color: #13A5AE;
	line-height: 2;
}
.pagemenu li::before {
	font-size: 0.8125rem;
	content: "＞";
	padding-right: 8px;
}
.pagemenu li a {
	color: #13A5AE;
}
.pagemenu li a:hover {
	text-decoration: underline;
}
.contents-box {
	width: 94%;
	margin: 0 auto 10%;
	font-size: 0.9375rem;
	line-height: 1.5;
}
.contents-box h2.sub_title {
	font-size: 1.125rem;
	font-weight: bold;
	line-height: 1.3;
	border-left: 6px solid #177F97;
	padding-left: 10px;
	margin-bottom: 1rem;
}
.contents-box h3 {
	/* padding: 10px 0; */
	font-size: 1.125rem;
	font-weight: bold;
	line-height: 1.3;
	border-left: 6px solid #177F97;
	padding-left: 10px;
	margin-bottom: 30px;
}
.contents-box h4 {
	font-size: 0.9375rem;
	font-weight: bold;
	line-height: 1.3;
	border-left: 3px solid #177F97;
	padding-left: 7px;
	margin-bottom: 0.5rem;
}
.contents-box h5 {
	display: inline;
	font-size: 0.9375rem;
	font-weight: bold;
	line-height: 2;
	/* border-left: 3px solid #177F97; */
	padding: 0 7px;
	background: linear-gradient(transparent 60%, rgba(23, 128, 151, 0.3) 60%);
	margin-bottom: 0.5rem;
}
.text-box p {
	margin-bottom: 1rem;
}

.contents-box .photo-container {
	display: flex;
	justify-content: center;
	width: 96%;
	margin: 8% auto;
}
.contents-box .photo-container .photo-box {
	width: 50%;	
	margin: 0 1.5%;
}
.contents-box .photo-container .photo-box div {
	line-height: 0.8;
}
.photo-container .photo-box .caption {
	font-size: 0.75rem;
}

/* ////////////////////////////////////////////////////////////////////////////// */
/* 物販のappeal部分 */
/* ////////////////////////////////////////////////////////////////////////////// */
.shop-container {
	margin-bottom: 6%;
	background: #efefef;
}
.shop-container h2.title {
	background: #cc0000;
	margin-bottom: 4%;
}
.shop-container .item-container {
	width: 96%;
	margin: 0 auto;
	padding-bottom: 30px;
	/* display: flex;
	justify-self: flex-start;
	flex-wrap: wrap; */
	/* margin: 20px; */
}
.shop-container .item-container .more {
	position: absolute;
	right: 2px;
	bottom: 10px;
	font-size: 0.6875rem;
	color: #00f;
	z-index: 10010;
}
.shop-container .item-container .more a {
	color: #00f;
}
.shop-container .item-container .item-box {
	min-height: 170px;
	max-height: 190px;
	/* margin: 0 1% 20px; */
	padding: 8px 5px 0;
	background: #f9f9f9;
	border-radius: 5px;
}
/* .shop-container .item-container .item-box:last-child {
	height: 300px;
} */
.shop-container .item-container .item-box div {
	line-height: 0.8;
}
.shop-container .item-container .item-box .caption {
	font-size: 0.75rem;
	line-height: 1.4;
	padding: 5px 0;
}
.shop-container .item-container .item-box div img {
	object-fit: cover;
	width: 100%;
	height: 100px;
}
.swiper-button-white {
	transform: scale(0.6);
}
.swiper-button-green {
	transform: scale(0.6);
	color: rgba(32, 134, 156, 0.6);
}
.swiper-pagination-bullet-active { background-color: rgba(32, 134, 156, 0.8); }

.twitter-container {
	width: 90%;
	margin: 0 auto 6%;
	border: 1px solid #ccc;
	border-radius: 8px;
	padding: 4px 8px 8px;
}

div img {
	width: 100%;
}

footer {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
/* 	margin-top: 30px; */
	padding: 0 0 20px;
	width: 100%;
	/* height: 40px; */
	font-size: 0.6875rem;
	line-height: 1.2;
	/* border-top: 4px solid rgba(32, 134, 156, 0.5); */
	/* background-color: #20859C;
	color: #fff; */
}
footer p {
	width: 100%;
	text-align: center;
}
/* フッタ固定メニュー */
/*========================
　smartphone　bottom menu
　========================*/
.mini-text {
	font-size: 0.75rem;
}
ul.bottom-menu {
	display: flex;
	align-items: center;
	position: fixed;
	bottom: 0;
	left: 0;
	/* transform: translate(-50%, 0); */
	width: 100%;
	height: calc(40px + env(safe-area-inset-bottom));
	margin: 0;
	padding: 0;
	background-color: rgba(32, 134, 156,0.9);
/* 	border-top: 2px solid #808080; */
	color: #fff;
	z-index: 1000;
	padding-bottom: env(safe-area-inset-bottom);
}
ul.bottom-menu li {
	display: table;
	width: 25%;
	height: 100%;
	/* padding: 10px 0; */
	text-align: center;
	font-size: 0.6875rem;
	border-left: 1px solid #d7eaee;
}
ul.bottom-menu li:first-child {
	border-left: none;
}
.bottom-menu li a {
	display: table-cell;
	vertical-align: middle;
	color: #fff;
	text-decoration: none;
}
.bottom-menu li a:hover {
	color: #0941c4;	/*マウスオーバー時の色*/
}
.bottom-menu li a:active {
	color: #fff;
}
.bottom-menu li a:visited {
	color: #fff;
}
.menu_icon {
	display: inline-block;
	width: 24px;
}
.menu_icon img {
	width: 100%;
}

/* === 展開メニュー === */
ul.menu-second-level {
	visibility: hidden;
	opacity: 0;
	z-index: 1;
}
ul.menu-second-level li a {
	border-top: 1px dashed #a9a9a9;	/*展開の枠点線*/
	font-size: 15px;	/*展開メニューの文字サイズ*/
	line-height: 30px;	/*文字の縦幅*/
}
.menu-second-level li a:hover {
	height: 100%;
	background: #cc0000;	/*マウスオーバーの色*/
}
li.menu-width-max ul.menu-second-level {
	position: absolute;
	bottom: 47px;	/*高さ*/
	left: 0;
	box-sizing: border-box;
	width: 100%;
	padding: 0;
}
li.menu-width-max:hover ul.menu-second-level {
	bottom: 47px;	/*高さ*/
	visibility: visible;
	opacity: 1;
}
li.menu-width-max ul.menu-second-level li {
	float: left;
	width: 100%;
	border: none;
}
/* ---------------------------------------------------------- */
.pagetop {
	position: fixed;
	bottom: -50px;
	right: 20px;
}
.pagetop a {
	display: table-cell;
	width: 46px;
	height: 46px;
	padding: 4px;
	background-color: rgba(0, 153, 153, 1);
	opacity: 0.7;
	/* border-radius: 5px 5px 0px 0px; */
	border-radius: 4rem;
	
	vertical-align: middle;
	text-align: center;
	color: #fff;
	font-size: 0.5rem;
	text-decoration: none;
	line-height: 1;
}
.pagetop a:hover {
	opacity: 1;
}

/* ---------------------------------------------------------- */
/* ハンバーガーメニュー */
/* ---------------------------------------------------------- */
#nav-drawer {
	position: relative;
	position: absolute;
	right: 10px;
	top: 14px; 
}

/*チェックボックス等は非表示に*/
.nav-unshown {
	display:none;
}

/*アイコンのスペース*/
#nav-open {
	display: inline-block;
	width: 30px;
	height: 22px;
	vertical-align: middle;
}

/* ---------------------------------------------------------- */
/* ハンバーガーメニュー */
/* ---------------------------------------------------------- */
/*ハンバーガーアイコンをCSSだけで表現*/
#nav-open span, #nav-open span:before, #nav-open span:after {
	position: absolute;
	height: 3px;/*線の太さ*/
	width: 25px;/*長さ*/
	border-radius: 3px;
	display: block;
	content: '';
	cursor: pointer;
	/* background: rgba(255, 72, 16, 1); */
	background: #20859C;
}
#nav-open span:before {
	bottom: -8px;
}
#nav-open span:after {
	bottom: -16px;
}

/*閉じる用の薄黒カバー*/
#nav-close {
	display: none;/*はじめは隠しておく*/
	position: fixed;
	z-index: 10000;
	top: 0;/*全体に広がるように*/
	right: 0;
	width: 100%;
	height: 100%;
	background: black;
	opacity: 0;
	transition: .3s ease-in-out;
}

/*中身*/
#nav-content {
	overflow: auto;
	position: fixed;
	top: 0;
	right: 0;
	z-index: 10001;
	width: 80%;
	max-width: 100%;
	height: 100%;
	transition: .3s ease-in-out;
	-webkit-transform: translateX(105%);
	transform: translateX(105%);/*左に隠しておく*/
	padding: 10px;

	background: rgba(230, 230, 230, 1);
	color: #000;
}
/*チェックが入ったらもろもろ表示*/
#nav-input:checked ~ #nav-close {
	display: block;
	opacity: .5;
}

#nav-input:checked ~ #nav-content {
	-webkit-transform: translateX(0%);
	transform: translateX(0%);
	box-shadow: 6px 0 25px rgba(0,0,0,.15);
}
#nav-content p {
	border-radius: 8px;
	padding: 6px 8px;
	text-align: center;
	color: #ffffdd;
	background: rgba(68, 0, 204, 1);	
}
#nav-content ul {
	margin-top: 10px;
	padding: 0 8px;
}
#nav-content ul li {
	list-style-type: none;
	line-height: 1.5;
	padding: 6px 4px;
	border-bottom: 1px dotted #1aa010;
}

/* .ocnk_cart iframe {
	height: 455px!important;
} */


/* ---------------------------------------------------------- */
/* フローティングバナー */
/* ---------------------------------------------------------- */
.floating-banner {
	position: fixed; /* 追従 */
	z-index: 99999;
	left: 0 ; /* 左右の隙間が空かないように */
	bottom: 40px; /* 画面の最下部にぴったりくっつくように指定 */	
	width: 100vw;
	background-color: rgba(0,0,0,0.8);
	border-radius: 8px; 
	padding: 10% 5vw 6%;
	box-sizing: border-box;
}
.floating-banner .sp {
	display: inline-block; /* 消していたスマホ用のバナーを表示させる */
	width: 100%;
	border: 2px solid #fff;
	border-radius: 8px;
}
.css-cancel {
	display: inline-block;
	position: absolute;
	top: 4%;
	right: 6%;
	margin: 0;
	padding: 0;
	width: 4px;
	height: 20px;
	background: #fff;
	transform: rotate(45deg);
	z-index: 10000;
}
.css-cancel:before {
	display: block;
	content: "";
	position: absolute;
	top: 50%;
	right: -8px;
	width: 20px;
	height: 4px;
	margin-top: -2px;
	background: #fff;
}
.floating-banner {
	top: unset; /* PCで指定していた上下の位置指定をクリア */
}
.fade {
	animation: 1s fadeIn;
}
@keyframes fadeIn {
 0% { opacity: 0; }
 100% { opacity: 1 ;}
}
/* ---------------------------------------------------------- */
/* パンくず */
/* ---------------------------------------------------------- */
.breadcrumb-area {
	display: flex;
	align-items: center;
	width: 94%;
	margin: 0 auto;
	padding: 0 0 5%;
	list-style: none;
}

.breadcrumb-area span {
  position: relative;
/*   display: inline-block; */
  list-style: none;
  margin-right: 1rem;
  color: #13A5AE;
  font-size: 0.6875rem;
}
.breadcrumb-area span.home:after,
.breadcrumb-area span.nav2:after {/*三角の部分*/
  content: "";
  position: absolute;
  top: 0;
  left: 100%;
  border-style: solid;
  border-color: transparent;
  border-left-color: #D2F4F4;/*背景色*/
  border-width: 10px 10px;
  width: 0;
  height: 0;
}

.breadcrumb-area span a {
  display: inline-block;
  padding: 0 2px 0 5px;
/*   height: 28px; */
  line-height: 20px;
  text-decoration: none;
  color: #13A5AE;
  background: #D2F4F4;/*背景色*/
}

.breadcrumb-area span a:hover {
	color: #333;
}

.bookmark {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 40px;
}
.bookmark li {
	width: 40px;
	margin: 0 10px;
}
.bookmark li img{
	width: 100%;
}

.helms {
	color: #000;
	text-decoration: none;
}

.menusmall {
	font-size: 0.5625rem;
}

.error-wrapper {
	width: 90%;
	/* height: 600px; */
	margin: 30px auto 0;
	padding-bottom: 60px;
}
.error-wrapper p:first-child {
	font-size: 1.0rem;
	font-weight: bold;
	margin-bottom: 1rem;
}
.error-wrapper p:nth-child(2) {
	line-height: 1.5;
	margin-bottom: 2rem;
}
.error-wrapper nav {
	display: block;
	margin-bottom: 1rem;
}

.mini-banner-container {
	width: 90%;
	margin: 2% auto;
}
.mini-banner-container li:first-child {
	margin-bottom: 2%;
}
.mini-banner-container img {
	width: 100%;
}