/* ========================================== */
/* base */
/* ========================================== */

body {
	font-family:"Noto Sans JP", sans-serif;
	line-height:1.8;
	color:#5F6368;
	font-size:14px;
	overflow-y: scroll;
}

.container {
    max-width: 1030px;
}



ul {
	padding:0px;
	margin:0;
	list-style:none;
}

ul.indent li {
	text-indent:-1em;
	padding-left:1em;
}

dt {
	font-weight:normal;
}

a {
	text-decoration:none;
	word-wrap:break-word;
	word-break: break-all;
	-webkit-transition: opacity 0.3s;
	-moz-transition: opacity 0.3s;
	-o-transition: opacity 0.3s;
	-ms-transition: opacity 0.3s;
	transition: opacity 0.3s;
}

a:hover {
	text-decoration:none;
}
 
a:focus {
    outline: 0;
    -webkit-box-shadow: none;
    box-shadow: none;
}

input[type="text"],input[type="password"],input[type="email"],textarea,select{ 
	font-family: inherit;
	font-size:1em !important;
	font-weight:inherit;
    -webkit-appearance: none;
}

.container {
    max-width: 1030px;
}

dl,dd,p {
	margin:0;
	padding:0;
}



/* ========================================== */
/* フォント */
/* ========================================== */

.font-base {
	font-family:"Noto Sans JP", sans-serif;
}

.font-accent,
.container h2 {
color: #404040;
font-family: "Poppins", "Noto Sans JP", sans-serif;
font-weight: 700;
}

.font-xs {
  font-size: 11px;
  line-height: 1.4rem;
}



/* ========================================== */
/* ヘッダー */
/* ========================================== */

header {
box-shadow: 0 3px 6px rgba(0,0,0,0.16);
}

.navbar {
padding: 4px;
}

header.navbar .navbar-brand {
padding: 0 15px;
margin: 0;
}

header .brand-logo img {
	width: 109px!important;
}

header a {
	text-decoration:none;
	transition: opacity 0.3s;
}

@media (hover: hover) {
header a:hover {
opacity: 0.6;
}
}

.navbar-nav {
max-width: 300px;
width: 77%;
margin: auto;
}

.navbar-nav .nav-main {
display: flex;
flex-wrap: wrap;
margin-top: 14px;
padding: 0 6px;
}

.navbar-nav .nav-item.nav-link {
position: relative;
}

.navbar-nav .nav-main .nav-item.nav-link {
width: 50%;
line-height: 1;
}

.navbar-nav .nav-main .nav-item:nth-child(2n+1)::after {
    content: "";
    border-bottom: 1px solid #707070;
    width: calc(200% + 12px);
    display: inline-block;
position: relative;
left: -6px;
}

header .nav-link,
header .nav-link a,
header .nav-link:hover,
header .nav-link a:hover {
color: #333333;
font-size: 16px;
font-weight: bold;
	border-bottom:none;
  -ms-transition: opacity .3s linear;
  -webkit-transition: opacity .3s linear;
  transition: opacity .3s linear;
}

.navbar-toggler {
background-color: #EF9E3D;
width: 50px;
height: 50px;
padding: 0 9px;
border-radius: 0;
}

header .nav-item.nav-link .material-symbols-outlined {
font-size:16px;
position: relative;
top: 3px;
}


.navbar .btn {
border-radius: 999px;
position: relative;
color: #fff;
font-family: "Poppins", sans-serif;
font-size: 16px;
box-shadow: 1px 1px 4px rgba(0,0,0,0.25);
transition: opacity 0.3s;
}

.navbar .btn:before {
	content: "";
	background-repeat: no-repeat;
	background-size: contain;
	display: inline-block;
	vertical-align: baseline;
	position: relative;
	width: 20px;
	height: 20px;
	left: -12px;
	top: 4px;
}

.navbar .btn.btn-join,
.navbar .btn.btn-mypage {
background-color: #EF9E3D;
padding: 8px 0 9px;
}

.navbar .btn.btn-join:before,
.navbar .btn.btn-mypage:before {
	background-image: url(../../images/mypage.svg);
}

.navbar .btn.btn-login {
background-color: #F1685D;
padding: 8px 0 9px;
}

.navbar .btn.btn-login:before {
	background-image: url(../../images/login.svg);
}

.navbar .btn.btn-logout {
background-color: #F1685D;
padding: 8px 0 9px;
}

.navbar .btn.btn-logout:before {
	background-image: url(../../images/logout.svg);
	top: 5px;
}


.sp-nav-fc {
margin-top: 28px;
}

.sp-nav-fc .fc-logo {
background: #FFFDB8;
background: linear-gradient(90deg, rgba(255, 253, 184, 1) 0%, rgba(255, 206, 143, 1) 100%);
text-align: center;
font-family: "Poppins", "Noto Sans JP", sans-serif;
font-weight: bold;
font-size: 16px;
padding: 10.6px 0;
}

.nav_inner_fanclub {
padding: 20px 26px 24px;
background-color: #F4F6F7;
margin-bottom: 100px;
}

.nav_inner_fanclub p {
text-align: center;
font-size: 20px;
margin-bottom: 20px;
}

.contents_list_sp {
    display: flex;
    flex-wrap: wrap;
padding: 0 6px;
}

.contents_list_sp li {
width: calc(50% - 6px);
position: relative;
margin-bottom: 16px;
margin-left: 6px;
}

.contents_list_sp li a {
color: #333333;
border-bottom: 1px solid;
font-size: 16px;
}

.contents_list_sp li span.not-login::before {
  font-family: "Material Symbols Outlined";
  content: "\e898";
  font-size: 18px;
  font-variation-settings:  'FILL' 1;
  color: #D9D0D5;
  display: inline-block;
}


@media screen and (max-width: 991px) {
header.navbar {
	padding:0;
}

.navbar-toggler-custom-icon {
	height:25px;
}

.collapse.show{
	height:100vh;
}

}

@media screen and (min-width: 992px) {

header.navbar .navbar-brand {
padding: 2px 15px 0;
}

header .brand-logo img {
	width: 192px!important;
}

header .header_nav {
	color:#333;
	text-decoration:none;
	padding:0 0 1px !important;
	margin:0 .5rem;
	position:relative;
	-webkit-transition: opacity .3s ease;
	transition: opacity .3s ease;
}

header .header_nav:hover {
	opacity:0.8;
	text-decoration:none;
}

header .header_nav::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 1px;
	-webkit-transform: scaleX(0);
	-ms-transform: scaleX(0);
	transform: scaleX(0);
	background-color: #333;
	-webkit-transition: scaleX .3s ease;
	transition: scaleX .3s ease;
}

header .header_nav:hover::after {
	-webkit-transform: scaleX(1);
	-ms-transform: scaleX(1);
	transform: scaleX(1);
}

.navbar-expand-lg .navbar-nav .nav-link:first-child {
margin-left: 32px;
}

.navbar-nav {
min-width: 463px;
margin: inherit;
}

.navbar-nav .nav-main {
margin-top: 0;
padding: 0;
}
.navbar-nav .nav-main .nav-item.nav-link,
.navbar-nav .nav-fc .nav-item.nav-link {
width: auto;
line-height: inherit;
padding-left: 8px;
}
.navbar-nav .nav-main .nav-link:nth-child(2n+1)::after {
content: none;
}

.navbar .btn {
border-radius: 6px;
font-size: 12px;
box-shadow: none;
}

.navbar .btn:before {
	position: absolute;
	left: 50%;
transform: translateX(-50%);
	top: 17px;
}

.navbar .btn.btn-join {
padding: 38px 19.5px 12px;
margin-right: 4px;
}
.navbar .btn.btn-mypage {
padding: 38px 7.2px 12px;
margin-right: 4px;
}

.navbar .btn.btn-login {
padding: 38px 15.6px 12px;
}

.navbar .btn.btn-logout {
padding: 38px 9.4px 12px;
}
.navbar .btn.btn-logout:before {
	top: 17px;
transform: translateX(-36%);
}

}


/* ========================================== */
/* CONTENTS */
/* ========================================== */

.container h2 {
	margin:50px auto;
}

@media screen and (max-width: 991px) {

.container h2 {
	margin:10px auto 50px;
}

}

@media screen and (max-width: 767px) {

.container h2 {
	font-size:26px;
}

}


/* ========================================== */
/* フッター */
/* ========================================== */

footer {
background: #EF9E3D;
background: linear-gradient(180deg,rgba(239, 158, 61, 0.45) 0%, rgba(239, 158, 61, 0.15) 100%);
	padding:48px 0;
}

footer .footer-about li.col-6 {
padding-left:5px!important;
padding-right:5px!important;
}

footer .footer-about .logo {
max-width:200px;
}


footer .footer-navigation ul {
	margin-bottom:32px;
}

footer .footer-navigation p {
font-size:20px;
font-weight:600;
color:#000;
margin-bottom:12px;
display: inline-block;
}

footer .footer-navigation li {
margin-bottom:16px;
font-size:14px;
}

footer .footer-navigation li .material-symbols-outlined {
font-size:16px;
position: relative;
top: 3px;
}

footer .footer-navigation li:before {
content: "- ";
}

footer li a {
	color:#000000;
}


@media (hover: hover) {
footer .footer-about .logo a:hover,
footer li a:hover {
	opacity:0.6;
	color:#000000;
}
}

footer ul.infolink {
display: flex;
justify-content: center;
gap: 20px;
}
footer hr {
max-width: 1030px;
margin: auto;
border-color: #D6D6D6;
}


footer .copy {
font-size: 14px;
text-align: center;
}



@media screen and (max-width: 991px) {

footer li {
}
	
}

@media screen and (max-width: 767px) {
footer .footer-about .logo {
max-width:192px;
}

footer .footer-navigation p {
font-size:16px;
	cursor: pointer;
pointer-events: auto;
position: relative;
}

footer .footer-navigation p::after {
  font-family: "Material Symbols Outlined";
    content: "\e316";
    position: absolute;
    display: inline;
transform: rotate(0deg);
font-size: 16px;
color: #000;
margin-left: 6px;
}

footer .footer-navigation p.select::after {
transform: rotate(180deg);
}

footer .footer-navigation li {
margin-bottom:16px;
font-size:14px;
}

footer hr {
margin: 0 15px;
}

footer ul.infolink {
flex-direction: column;
}

footer .copy {
font-size: 12px;
}

　
}


/* ========================================== */
/* 共通カラー */
/* ========================================== */
/* ベースカラー */
/* 背景 */
.bg-base {
  /* サイト全体の背景色 */
  background-color: #fff;
}
.bg-toggle {
  /* サイト全体の背景色 */
  background-color: #333;
}

/* メインカラー */
/* 背景 */
.bg-main {
  /* 主にヘッダの背景色 */
  background-color: #212121;
}
/* サブカラー */
.bg-sub {
  /* 主にフッタの背景色 */
  background-color: #F0F0F0;
}
/* アクセントカラー */
/* 任意でUIパーツの色を増やしたいときに定義を増やす */
.bg-accent-light-gray {
  background-color: #f8f8f8;
}
.bg-accent-light-red {
  background-color: #efdfdf;
}

/* テキスト */
.text-base {
  color: #fff;
}
.text-main {
  color: #333;
}
.text-accent-light-gray {
  color: #c0c0c0;
}
.red {color:#FF0004;}

/* ========================================== */
/* UIパーツ別 */
/* ========================================== */
/* ボタン */
.btn {
  border-radius: 2rem;
}
.btn-main {
  color: #E36F96 !important;
  background-color: transparent;
  background-image: none;
  border-color: #E36F96;
}
.btn-main:hover {
  color: #fff !important;
  background-color: #E36F96;
  border-color: #E36F96;
}

a.btn {
	text-decoration:none;
}


/* アラート */
.alert-main {
  color: #856404;
  background-color: #fff3cd;
  border-color: #ffeeba;
}
.alert-registration-mail.alert,
.alert-mypage-change-email.alert {
  border: none;
}
.alert-registration-mail.alert .alert-heading,
.alert-mypage-change-email.alert .alert-heading {
  color: #ff0000;
}
.alert-registration-mail.alert .alert-body,
.alert-mypage-change-email.alert .alert-body {
  color: #808080;
}

/* バッジ（ラベル） */
.badge-history-status.badge {
  font-size: 100%;
  font-weight: normal;
  padding: .5em 1em;
}
.badge-history-status.badge-secondary {
  color: #343a40;
  background-color: #e9ecef;
}

/* ========================================== */
/* 画面別 */
/* ========================================== */


/* マイページ履歴 */
@media screen and (min-width: 768px) {
.row-history-left {
  border-right: 1px solid rgba(0,0,0,.1);
}
}


/*--------------------
  MYPAGE
--------------------*/
@media screen and (min-width: 768px) {
.row-history-left {
  border-right: 1px solid rgba(0,0,0,.1);
}
}

.mypage-plan-contract-footer {
    display: none;
}

.uploaded-photo-status-label, .shipping-history-status-label, .ec-history-status-label, .ticket-history-status-label, .ticket-history-ticket-status-label {
    border-radius: 2rem;
	padding: 6px 1em;
}

/*membership-card*/

.membership-card-image .membership-card-image-on-member-number {
right: 3%;
bottom: 2%;
color:#fff;
font-size: 16px;
}

@media screen and (max-width: 575px) {
.membership-card-image .membership-card-image-on-member-number {
font-size: 4vw;
bottom: 0;
}
}

/*------------------------
 pagination上余白
------------------------*/
ul.pagination {
	margin-top: 80px;
}

/*--------------------------------
 form 内容確認ページ
--------------------------------*/
form dd{
	margin-bottom:1rem;
}
form dt label{
	font-weight: 700;
}

/*--------------------
  STORE
--------------------*/
/* TAG */
#store .store_tag ul{
  text-align: left!important;
  display: inline;
}

#store .store_tag ul li{
  padding: 0!important;
  margin-left: 1em;
}

/* 商品名 */
#store h6,
#store .ec-product-name,
#store p {
overflow-wrap: anywhere;
word-break: normal;
line-break: strict;
}