@charset "UTF-8";

body {
	position: relative;
	font-size: 16px;
	line-height: 1.6;
	font-family: 'Hiragino Kaku Gothic ProN', 'Meiryo', 'Osaka', 'MS PGothic', 'YuGothic', 'Arial','Helvetica Neue','Helvetica',sans-serif;
	letter-spacing: .03em;
	word-break: break-word;
	word-wrap: break-word;
	overflow-wrap: break-word;
}

*, *::before, *::after {
	box-sizing: border-box;
}

input[type=number]::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

input[type="number"] {
	-moz-appearance:textfield;
}

input::-ms-reveal {
	visibility:hidden;
}

input::-ms-clear {
	visibility:hidden;
}

input:invalid {
	box-shadow: none;
}

a {
	text-decoration: none;
	outline: none;
}

/*************************************
**************************************
				color
**************************************
*************************************/
.primary {
	color: #FF5F6D;
}

.headline {
	color: #FF5F6D;
}

.text {
	color: #343434;
}

.sub_text {
	color: #777777;
}

.accent {
	color: #777777;
}

.navigation_tint {
	color: #343434;
}

.bg_primary {
	background: #FF5F6D;
	color: #fff;
}

.background {
	background: #FFFFFF;
}

.navigation_bar {
	background: #FFFFFF;
}

.tab_bar {
	background: #FFFFFF;
}

.contents {
	background: #FFFFFF;
}

.gradient {
	background: rgb(255,95,109);
	background: -webkit-linear-gradient(135deg, rgba(255,95,109,1) 0%, rgba(255,195,113,1) 100%);
	background: linear-gradient(135deg, rgba(255,95,109,1) 0%, rgba(255,195,113,1) 100%);
	color: #FFF;
}

:root {
	--primary-color: #FF5F6D;
	--text-color: #343434;
	--sub-text-color: #777777;
	--accent-color: #4C7FA3;
	--background-color: #FFFFFF;
	--contents-color: #121413;
	--gradient-color: linear-gradient(90deg, #FF5F6D 0%, #FFC371 100%);
	--alpha-text-color: #C7C7CC;
	--alpha-primary-color: rgba(255, 114, 110, 0.05);
	--navigation-color: #0C0D0D;
	--navigation-tint-color: #343434;
	--light-text-color: #868686;
}

/***************************
			header
***************************/
.page {
	padding: 56px 0 49px;
	overflow: hidden;
}

.page_entry .matter__item {
	text-align: center;
}

.header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	min-height: 56px;
	z-index: 999;
}

.header__bg {
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	transition: .2s ease;
}

.header__title {
	text-align: center;
}

.header__home-link {
	display: inline-block;
	width: 100%;
	vertical-align: middle;
}

.header__title_main {
	display: block;
	font-size: 24px;
	font-weight: bold;
	line-height: 56px;
}

.header__title_sub {
	display: block;
	position: absolute;
	top: -9999px;
	font-size: 20px;
	font-weight: bold;
}

.header__logo {
	display: inline-block;
	height: 56px;
	max-width: 100%;
	max-height: 56px;
	padding: 0;
	margin: 0 auto;
	line-height: 1;
	vertical-align: middle;
	text-align: center;
	object-fit: contain;
}

.header__lp {
	position: absolute;
	display: none;
	width: 100%;
	top: 100%;
	left: 0;
	padding: 12px;
}

.hero__lp {
	position: absolute;
	z-index: 2;
	bottom: 24px;
	right: 24px;
	padding: 28px 79px;
	border-radius: 6px;
}

.lp {
	color: #FFFFFF;
	text-align: center;
}

.lp__inner {
	display: flex;
	justify-content: center;
	align-items: center;
}

.lp-bg::before {
	content: "";
	position: absolute;
	display: block;
	z-index: -1;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: inherit;
	opacity: .8;
}

.hero__lp .lp-bg::before {
	border-radius: 6px;
}

.lp__txt {
	display: inline-block;
	margin-bottom: 20px;
	font-size: 36px;
	font-weight: bold;
}

.lp__sub-txt {
	margin-bottom: 6px;
	font-weight: bold;
}

.lp__link {
	display: block;
	width: 280px;
	margin: 0 auto;
	background: #FFFFFF;
	padding: 16px 24px;
	border-radius: 40px;
	color: #343434;
	font-weight: bold;
}

.lp__txt-link {
	display: inline-block;
	margin-top: 16px;
	color: #FFF;
	text-decoration: underline;
	font-size: 14px;
}

.lp__badge {
	display: inline-block;
	vertical-align: middle;
}

 .lp__badge-img {
	height: 52px;
}

.header .lp__link,
.header .lp__badge {
	margin: 0 0 0 40px;
}

.header .lp__badge-img {
	height: 48px;
}

.header .lp__txt-link {
	margin-top: 0;
}

.top_img-hide .top__img-list {
	display:none;
}

.top_video-hide .hero__item-sp {
	display:none;
}

.hero_img-hide .hero__list {
	display: none;
}

.hero_video-hide .hero__video {
	display: none;
}

.hero__lp .lp__link {
	margin: 0 auto;
}

.hero .slick-dots {
	left: 0;
	width: auto;
	bottom: 0;
	padding: 24px;
}

.caption__wrapper {
	position: absolute;
	z-index: 2;
	width: calc(100% - 48px);
	max-height: 80%;
	color: #FFF;
	overflow: hidden;
}

.caption_shadow {
	text-shadow: 2px 2px 6px #000;
}

.position-left {
	top: 50%;
	left: 5%;
	transform: translateY(-50%);
}

.position-center {
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	text-align: center;
}

.position-right {
	top: 50%;
	right: 5%;
	transform: translateY(-50%);
	text-align: right;
}

.caption {
	font-size: 18px;
	white-space: pre-wrap;
}

.proposal,
.proposal-stay {
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	z-index: 997;
	text-align: center;
	
}

.proposal__inner,
.proposal-stay__inner {
	position: relative;
	padding: 16px 24px 32px;
	background-color: rgba(255, 255, 255, 0.9);
}

.proposal__title {
	display: none;
}

.proposal__txt {
	margin-bottom: 16px;
	font-weight: bold;
	text-align: center;
	color: #343431;
}

.proposal__link {
	display: block;
	width: 100%;
	max-width: 400px;
	margin: 0 auto;
	padding: 10px 16px;
	border-radius: 4px;
	color: #FFFFFF;
	font-size: 18px;
	font-weight: bold;
}

.proposal__btn {
	display: block;
	width: 100%;
	max-width: 400px;
	margin: 0 auto;
	padding: 16px;
	border-radius: 4px;
	border: none;
	color: #FFFFFF;
	font-size: 18px;
	font-weight: bold;
	cursor: pointer;
}

.inactive__btn {
	position: relative;
	pointer-events: none;
}

.inactive__btn::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
	display: block;
	width: 100%;
	height: 100%;
	background-color: rgba(255, 255, 255, .6);
}

.proposal__txt-link {
	display: flex;
	max-width: 400px;
	margin: 8px auto 0;
	padding: 8px 0;
	white-space: nowrap;
	color: #343434;
	font-size: 12px;
	text-decoration: underline;
	justify-content: center;
}

.proposal__link-wrapper + .proposal__txt-link {
	display: inline-block;
}

.proposal__badge {
	display: inline-block;
	margin: 0 8px;
	vertical-align: middle;
}

.proposal__badge-img {
	height: 40px;
}

.header-bar {
	display: flex;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 997;
	width: 100%;
	height: 56px;
	align-items: center;
}

.header-bar__icon {
	height: 24px;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	margin: auto 0 auto 16px;
	font-size: 24px;
	cursor: pointer;
}

.header-bar__icon_right {
	left: auto;
	right: 0;
	margin: auto 16px auto 0;
}

.header-bar__icon_text {
	background: transparent;
	border: none;
	color: #fff;
	font-size: 18px;
}

.header-bar__txt {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	height: 16px;
	margin: auto 0 auto 16px;
	line-height: 1;
	font-size: 16px;
	cursor: pointer;
}

.header-bar__icon_login {
	color: #FFFFFF;
}

.header-bar__txt_right {
	left: auto;
	right: 0;
	margin: auto 16px auto 0;
}

.menu::-webkit-scrollbar {
	display: none;
}

.nav {
	position: fixed;
	z-index: 1;
	bottom: 0;
	width: 100%;
	padding-bottom: env(safe-area-inset-bottom);
	/*blurの指定*/
	/*background-color: rgba(12,13,13,.9);
	-webkit-transition-property: background-color,-webkit-backdrop-filter;
	transition-property: background-color,-webkit-backdrop-filter;
	transition-property: background-color,backdrop-filter;
	transition-property: background-color,backdrop-filter,-webkit-backdrop-filter;
	-webkit-backdrop-filter: saturate(180%) blur(20px);
	backdrop-filter: saturate(180%) blur(20px);*/
}

/*アイコンとタブの色が被らない対策*/
.nav::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	background-color: rgba(255, 255, 255, .05);
}

.nav__list {
	position: relative;
	z-index: 2;
	display: flex;
	height: 49px;
	justify-content: space-around;
	align-items: center;
}

.nav__item {
	position: relative;
	font-size: 10px;
	letter-spacing: normal;
	width: 6em;
}

.nav__link {
	display: block;
	vertical-align: middle;
	line-height: 24px;
	overflow: hidden;
	-webkit-font-smoothing: antialiased;
	color: #A8A8A8;
}

.nav__link::before {
	font-family: 'icon';
	display: block;
	width: 24px;
	height: 24px;
	font-size: 24px;
	margin: 0 auto 2px;
}

.nav__text {
	display: block;
	font-size: 10px;
	line-height: 1.4;
	text-align: center;
	font-weight: bold;
}

.nav__icon_home::before {
	content: "\e919";
}

.nav__icon_timeline::before {
	content: "\e92e";
}

.nav__icon_store::before {
	content: "\e95f";
}

.nav__icon_chat::before {
	content: "\e951";
}

.nav__icon_mypage::before {
	content: "\e91f";
}

.nav-item__unread {
	position: absolute;
	top: -4px;
	left: 35px;
	display: inline-block;
	padding: 5px;
	border-radius: 9999px;
	white-space: nowrap;
}

.nav-item__unread__txt {
	color: #FFFFFF;
	font-size: 12px;
	line-height: 12px;
	min-width: 12px;
	text-align: center;
}

/***************************
			main
***************************/
.main {
	position: relative;
}

.page__container_settings {
	min-height: calc(100vh - 120px);
	margin-bottom: 0;
}

.page__container-mail {
	margin: 0;
}

.page__wide-wrapper {
    padding: 16px 0 40px;
position: relative;}

.page__headline {
	position: relative;
	margin: 0 0 16px 24px;
	line-height: 1;
	text-align: left;
	font-size: 24px;
	font-weight: bold;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.page__headline_nav {
	position: absolute;
	top: -100%;
	left: 0;
	right: 0;
	line-height: 54px;
	z-index: 997;
}

.page__sub-txt {
	font-size: 14px;
	font-weight: normal;
	line-height: 1.6;
}


.details {
	min-height: 400px;
}

/***************************
		header__banner
***************************/

.header__banner {
	display: flex;
	align-items: center;
	padding: 16px 12px;
	background: #F2F2F2;
}

.main .header__banner {
	position: relative;
	z-index: 1000;
}

.header__banner .icon__img {
	flex: none;
	width: 46px;
	margin: 0 8px 0 0;
	border-radius: 12px;
	box-shadow: 0px 0px 6px 0px rgb(0 0 0 / 16%);
	overflow: hidden;
}

.header__banner .headline__group {
	flex-grow: 2;
	margin: 0 8px 0 0;
}

.header__banner .headline {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	margin: 0 0 4px;
	font-size: 14px;
	font-weight: bold;
	line-height: 1.5;
	color: #343434;
}

.header__banner .headline__text {
	font-size: 13px;
	color: #343434;
}

.header__banner .btn {
	display: block;
	padding: 12px 10px;
	font-size: 11px;
	background: #FF726E;
	border-radius: 36px;
	font-weight: bold;
	color: #FFF;
	text-align: center;
	text-decoration: none;
	white-space: nowrap;
}


/***************************
		background
***************************/
.background-layer,
.background-layer .page__wrapper {
	background: transparent !important;
}

.background-layer__inner {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	padding-top: 100vh;
	z-index: -999;
	overflow: hidden;
}

.background-layer__mask,
.background-layer__gradient {
	display: none;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.background-layer__mask {
	background: var(--contents-color);
	opacity: .5;
}

.background-layer__gradient {
	background: var(--gradient-color);
}

.mainvisual-mask {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	width: 100%;
	height: 100%;
}

.mainvisual-mask_dot {
	background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2 2"><path fill="" d="M1,1H0V0H1ZM2,1H1V2H2Z" /></svg>');
	background-repeat: repeat;
	background-size: 2px;
}

.scrolldown {
	position: absolute;
	bottom: 40px;
	left: 50%;
	width: 120px;
	height: 32px;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	z-index: 2;
}

.scrolldown span {
	position: absolute;
	top: -15px;
	left: 50%;
	transform: translatex(-50%);
	color: #FFF;
	font-size: 18px;
	text-shadow: 0 0 10px rgb(0 0 0 / .4);
}

.scrolldown::after {
	content: "";
	position: absolute;
	top: 0;
	right: 50%;
	width: 1px;
	height: 30px;
	background: #FFF;
	animation: pathmove 1.4s ease-in-out infinite;
	opacity: 0;
}

@keyframes pathmove{
	0%{
		height:0;
		top:0;
		opacity: 0;
	}
	30%{
		height:30px;
		opacity: 1;
	}
	100%{
		height:0;
		top:50px;
		opacity: 0;
	}
}

/***************************
		common item
***************************/
.tag {
    display: inline-block;
    font-size: 14px;
    border-radius: 4px;
    padding: .2em 1em;
}

.tag_premium {
	font-weight: bold;
	color: #fff;
	background: var(--primary-color);
}

.section {
	position: relative;
	padding: 40px 0 24px;
	z-index: 1;
}

.headline {
	font-size: 24px;
	font-weight: bold;
}

.headline__wrapper {
	margin: 0 0 24px 0;
}

.section__sub-container {
	margin: 0 0 24px 0;
}

.section__sub-container .headline__wrapper {
	margin: 0 0 16px 0;
}

.section__sub-container .headline {
	font-size: 16px;
}

.sub_text.note::before {
	content: "※"
}

.contents_empty {
	max-width: 800px;
	margin: 0 auto 8px;
	padding: 80px 24px;
	font-size: 20px;
	text-align: center;
}

.contents_empty__sub {
	display: block;
	padding: 16px 0 0;
	font-size: 16px;
}

.background-layer .contents_empty {
	background: transparent;
}

.img-clip{
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	object-fit: cover;
	font-family: 'object-fit: cover;';
}

.clearfix:after {
	content: '';
	display: block;
	clear: both;
}

.ellipsis {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.noScroll {
	overflow: hidden;
}

.sub_background {
	background-color: rgba(0, 0, 0, 0.1);
}

.bg_translucent {
	background: #FFFFFF;
}

.alert {
	display: none;
	position: fixed;
	top: 50%;
	left: 50%;
	z-index: 999;
	width: calc(100% - 48px);
	max-width: 470px;
	border-radius: 10px;
	background: #FFF;
	transform: translate(-50%, -50%);
	color: #343434;
}

.alert__inner {
	padding: 40px 20px;
	text-align: center;
}

.alert__title {
	font-size: 18px;
	font-weight: bold;
}

.alert__discription {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: 8px;
	font-size: 16px;
}

.alert__discription .icon_coin {
	display: inline-block;
	font-weight: normal;
	-webkit-font-smoothing: auto;
}

.alert__discription .icon_coin::before {
	font-weight: normal;
	margin: 0 4px 0 16px;
	color: #F5CB00;
	font-size: 18px;
}

.alert__sub-txt {
	margin-top: 18px;
	font-size: 14px;
	opacity: .6;
}

.alert__actions {
	display: flex;
	justify-content: flex-end;
	padding: 20px;
	background: rgba(0, 0, 0, .1);
	border-radius: 0px 0px 10px 10px;
}

.alert__action {
	border: none;
	border-radius: 4px;
	width: 100%;
	max-width: 120px;
	margin: 0 5px;
	padding: 12px;
	background: rgba(0, 0, 0, .1);
	color: #343434;
	font-size: 14px;
	text-align: center;
}

.alert__action_destructive,.alert__action_ok {
	background: #FF726E;
	color: #FFF;
	font-weight: bold;
	white-space: nowrap;
}

.alert_single::before {
	content: "\e912";
	font-family: 'icon';
	display: block;
	margin-bottom: 8px;
	font-size: 32px;
	font-weight: normal;
	-webkit-font-smoothing: antialiased;
}


.alert_single {
	width: auto;
	padding: 20px;
	text-align: center;
	box-shadow:0px 0px 10px 4px rgba(0,0,0,0.16);
}

.app-confirmation .alert {
	display: block;
	position: static;
	top: auto;
	left: auto;
	transform: none;
	margin: 0 auto;
	width: 100%;
}

.app-confirmation .alert__inner {
	padding: 60px 20px 20px;
}

.app-confirmation .alert__actions {
	justify-content: center;
	background: none;
}

.app-confirmation .alert__action {
	margin: 0 12px;
	text-align: center;
}

.walkthrough__inner {
    position: fixed;
    width: calc(100% - 48px);max-width: 500px;top: 50%;
    left: 50%;
    z-index: 999;
    border-radius: 10px;
    transform: translate(-50%, -50%);
	text-align: center;
}

.walkthrough-inner {
	position: relative;
	padding: 40px 20px;
}

.walkthrough__img {
	width: 100%;
	max-width: 320px;
	margin: auto;
}

.walkthrough__icon-img {
	display: inline-block!important;
	width: 16px;
	vertical-align: text-bottom;
}

.walkthrough__text-group {
	margin: 24px 0;
}

.walkthrough__caption {
	margin: 0 0 16px;
	font-weight: bold;
}

.walkthrough__btn {
	position: absolute;
	bottom: -30px;
	right: 24px;
	border: none;
	line-height: 1;
	padding: .5em 1em;
	border-radius: 1em;
	font-weight: bold;
}

.walkthrough .slick-slider .slick-list {
	overflow: visible;
}

.walkthrough .slick-dotted.slick-slider {
	margin-bottom: 56px;
}

.walkthrough .slick-dots {
	position: static;
}

.floating {
	position: fixed;
	left: 0;
	bottom: 0;
	z-index: 999;
	width:100%;
	border-radius: 10px 10px 0 0;
	text-align: center;
	box-shadow: 0px -6px 10px -4px rgb(0 0 0 / 20%);
}

.floating__inner {
	padding: 32px 24px;
	text-align: center;
}

.floating_lottery .floating__inner {
	padding: 0 24px 32px;
}

.floating__title {
	margin-bottom: 16px;
	font-size: 16px;
	font-weight: bold;
}

.floating__txt {
	font-size: 16px;
	margin-bottom: 16px;
}

.floating__sub-txt {
	font-size: 14px;
	opacity: .6;
}

.floating__header {
	padding: 40px 24px;
}

.floating__header .floating__title{
	margin-bottom: 0;
}

.floating__footer {
	padding: 16px 24px;
	border-top: 1px solid var(--alpha-text-color);
}

.floating__close-btn{
    position: absolute;
    right: 16px;
    top: 16px;
    border: none;
    background: transparent;
    font-size: 24px;
    color: inherit;
    z-index: 1;
}

.btn-list__item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 24px;
	text-align: left;
}

.btn-list__item:last-child {
	margin-bottom: 0;
}

.btn-list__headline {
	font-size: 18px;
	font-weight: bold;
}

.btn-list__headline.icon_coin::before {
	color: #F5CB00;
	margin-right: 4px;
}

.btn-list__txt {
	margin-top: 8px;
	font-size: 14px;
}


.btn-list__btn {
	min-width: 120px;
	padding: 1em 24px;
	border: none;
	border-radius: 1.5em;
	font-size: 18px;
	font-weight: bold;
	line-height: 1;
}

.form__input::placeholder {
	opacity: .5;
	color: inherit;
}

.form__input:-ms-input-placeholder {
	opacity: .5;
	color: inherit;
}

.form__input::-ms-input-placeholder {
	opacity: .5;
	color: inherit;
}

.form__input:disabled {
	cursor: default;
}

.flag {
	display: none;
}

.more-txt {
	display: inline-block;
	font-weight: bold;
	padding: 0 0 8px 24px;
}

@keyframes onAutoFillStart { from {} to {}}

input:-webkit-autofill {
	animation-name: onAutoFillStart;
	transition: background-color 50000s ease-in-out 0s;
}

.login input:-webkit-autofill {
	-webkit-text-fill-color: #FFFFFF !important;
}

/*************************************
**************************************
				home
**************************************
*************************************/


/***************************
			drawer
***************************/

.drawer {
	position: fixed;
	bottom: 0;
	left: 0;
	z-index: 999;
	width: 100%;
	height: auto;
	max-height: 0;
	border-top-left-radius: 8px;
	border-top-right-radius: 8px;
	transition: max-height 0.2s ease;
}

.drawer_popup {
	box-shadow: 0px 0px 20px 0px rgba(0,0,0,0.2);
}

.drawer__title {
	position: relative;
	margin: 24px 16px 16px;
	font-weight: bold;
	text-align: center;
	color: #343434;
}

.drawer__title_inline {
	display: flex;
	margin: 16px 24px;
	color: #343434;
	justify-content: space-between;
	align-items: center;
}

.drawer__close {
	font-weight: normal;
	font-size: 14px;
}

.drawer__inner {
	position: relative;
}

.drawer__item {
	display: block;
}

.drawer-item__wrapper {
	position: relative;
	height: 100%;
	padding: 12px 0 120px;
}

.drawer__list {
	height: 100%;
	max-height: calc(100% - 40px);
	}

.drawer__list::-webkit-scrollbar {
	display: none;
}

.mask,
.drawer__mask,
.enroll__mask,
.mask-walkthrough {
	display: none;
	position: fixed;
	z-index: 998;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, .5);
}

.mask-walkthrough {
	display: block;
	z-index: 999;
}

.switch {
	display: none;
}

#drawer-switch:checked ~ .drawer {
	max-height: calc(100% - 40px);
	transition: all 0.2s ease;
}

#drawer-switch:checked ~ .drawer__mask {
	display: block;
}

#drawer-switch:checked ~ .drawer .drawer-btn__wrapper{
	bottom: 0;
}

.drawer__close {
	font-weight: normal;
	font-size: 14px;
	cursor: pointer;
}

.fanclub__text-group {
	width: 100%;
	margin-left: 8PX;
	overflow: hidden;
}

.text-group_group {
	font-size: 14px;
}

.text-group_club {
	font-size: 16px;
	font-weight: bold;
}

.text-group_group {
	font-size: 14px;
}

.drawer-btn__wrapper {
	position: fixed;
	width: 100%;
	padding: 16px 24px 40px;
}

.drawer__btn{
	display: block;
	max-width: 500px;
	margin: 0 auto;
	padding: 16px;
	border-radius: 4px;
	color: #FFF;
	font-size: 18px;
	font-weight: bold;
	text-align: center;
	cursor: pointer;
}

.drawer__btn_nomal {
	background: #FF726E;
	background: -moz-linear-gradient(90deg, #FF5F6D 0%, #FFC371 100%);
	background: -webkit-linear-gradient(90deg, #FF5F6D 0%, #FFC371 100%);
	background: linear-gradient(90deg, #FF5F6D 0%, #FFC371 100%);
}

.drawer__btn_premium {
	margin-top: 16px;
	background: #B48400;
	background: -webkit-linear-gradient(left, #B48400 0%, #F7D30E 100%);
	background: linear-gradient(to right, #B48400 0%, #F7D30E 100%);
}

.drawer__btn-group .drawer__btn {
	max-width: none;
	border-radius: 0;
	color: #343434;
}

.drawer__btn-group .drawer__btn {
	max-width: none;
	border-radius: 0;
	color: #343434;
}

.drawer__btn-group .drawer__btn:first-child {
	margin-top: 8px;
}

.drawer__btn-group .drawer__btn:nth-last-child(2) {
	margin-bottom: 8px;
}

.drawer__btn-group .drawer__btn-cancel {
	border-top: 1px solid;
	border-color: var(--alpha-text-color);
	color: #007AFF;
}

.change-plan__nomal-btn {
	margin-top: 16px;
}

.fanclub {
	position: relative;
	display: flex;
	width: 100%;
	padding: 16px 24px;
	align-items: center;
}

.fanclub_border {
	padding: 16px 0;
}

.fanclub_border::after {
	content: "";
	position: absolute;
	right: 0;
	bottom: 0;
	width: calc(100% - 80px);
	text-align: right;
	border-bottom: 1px solid;
	border-color: var(--alpha-text-color);
}

.fanclub__online-icon::after {
	font-family: 'icon';
	content: "\e90e";
	margin-left: 8px;
	font-size: 24px;
	color: #53D853;
	-webkit-font-smoothing: antialiased;
}

.fanclub-img__wrapper {
	position: relative;
	padding-top: 72px;
	padding-right: 72px;
	border-radius: 50%;
	overflow: hidden;
}

.fanclub__thumb {
	position: relative;
}

.fanclub__label {
	position: absolute;
	left: 0;
	right: 0;
	bottom: -4px;
	text-align: center;
}

.fanclub-label__txt {
	display: inline-block;
	padding: .5em .8em;
	background: #D50000;
	border-radius: 1em;
	line-height: 1;
	color: #FFFFFF;
	font-size: 10px;
	font-weight: bold;
}

.matter__list {
	padding: 0 16px 0 32px;
	color: #343435;
}

.drawer .matter__list {
	max-height: 40vh;
}

.matter__item {
	margin-bottom: 8px;
	font-size: 12px;
}

.matter__link {
	color: #343434;
	font-weight: bold;
	text-decoration: underline;
}

.matter__icon::before {
	content: "\e929";
	font-family: 'icon';
	vertical-align: middle;
	font-size: 14px;
	font-weight: normal;
	-webkit-font-smoothing: antialiased;
}

.matter-btn__wrapper {
	margin: 24px 16px;
	text-align: center;
}

.slick-dots li button::before,
.slick-dots li.slick-active button:before {
	color: var(--primary-color)!important;
}


/***************************
		Unusual-button
***************************/

.unusual {
	padding: 24px 0 0;
}

.unusual__text {
	margin: 0 0 8px ;
	font-size: 18px;
	font-weight: bold;
	text-align: center;
}

.buttonInner {
	display: block;
	width: calc(100% - 48px);
	max-width: 400px;
	padding: .8em 1.5em;
	margin: 8px auto;
	border: none;
	border-radius: 1.5em;
	color: #FFF;
	text-align: center;
	line-height: 1;
}

/*********************
		full-visual
*********************/

.full-visual {
	position: relative;
}
.store .full-visual {
	padding-top: 96%;
	position: relative;
	z-index: 0;
}

.store .full-visual_empty::before {
	content: "\e95f";
	font-family: "icon";
	position: absolute;
	top: 28px;
	right: 0;
	padding-right: 8%;
	font-size: 32vw;
	line-height: 1;
	opacity: .3;
	-webkit-font-smoothing: antialiased;
	text-align: center;
}

.full-visual__item {
	position: relative;
}

.blur::after {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	-webkit-backdrop-filter: blur(20px);
	/* backdrop-filter: blur(20px); */
	background: rgb(0 0 0 / 60%);
	z-index: 999;
}

.full-visual__img-wrapper {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 0;
}

.full-visual__slider, .full-visual__slider .slick-list, .full-visual__slider .slick-track {
	height: 100%;
}

.full-visual__img {
	display: block;
	position: absolute;
	top: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	font-family: 'object-fit: cover;';
	filter: blur(10px);
}

.full-visual__headline {
	position: absolute;
	width: 100%;
	top: 50%;
	transform: translateY(-50%);
	padding: 0 10%;
	text-align: center;
	z-index: -1;
	font-size: 14px;
}
.full-visual__title {
	font-size: 1.4em;
	font-weight: bold;
}

.full-visual__sub-title {
	font-size: 1em;
	padding: 1em 0;
}

.store {
	margin-top: -56px;
}

.store .charge {
	padding: 0 24px;
}

.store__banner {
	position: absolute;
	width: 100%;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 999;
	font-size: 12px;
}

.store__banner-item {
	margin: 0 6px;
	color: #fff;
}

.store__banner-item a {
	display: block;
	color: #fff;
}

.store__banner-img-wrapper {
	position: relative;
	padding-top: 40%;
	border-radius: 6px;
	overflow: hidden;
}

.store__banner-img-wrapper_mask::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #000;
	opacity: .4;
}

.store__banner-mask-text {
	position: absolute;
	font-weight: bold;
top: 50%;left: 50%;width: 100%;transform: translate(-50%,-50%);padding: 16px;text-align: center;z-index: 1;font-size: 1.6em;}

.store__banner-img {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	object-fit: cover;
	font-family: 'object-fit: cover;';
}
.store__banner-caption {
    margin: 8px 0 4px;
    font-weight: bold;
    opacity: .6;
}

.store__banner-title {
    font-weight: bold;
    font-size: 1.4em;
}


.store .headline__wrapper {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 24px;
}

.store .section {
	max-width: 880px;
	margin: 0 auto;
}

.register-banner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin: 0 24px 24px 24px;
	padding: 12px;
	border-radius: 6px;
	font-size: 24px;
}

.register-banner__contents {
	display: flex;
	align-items: center;
	flex: 1;
}

.register-banner__icon {
    display: inline-block;width: 16%;
    min-width: 48px;
	object-fit: cover;
	margin: 0 0.8em 0 0;
box-shadow: 0px 0px 6px 0px rgb(0 0 0 / 20%);border-radius: 22%;} 

.register-banner__group {
	flex: 1;
	margin: 0 .8em 0 0;
}

.register-banner__title {
	font-weight: bold;
}

.register-banner__text {
	font-size: .8em;
	margin: 4px 0 0 0;
}

.register-banner__btn {
	display: inline-block;
	font-size: .8em;
	line-height: 1;
	padding: 1.2em 1em;
	border-radius: 2em;
}

.register-banner__btn.primary {
	background: #fff;
}

.register-banner__img-group {
	display: none;
}

.alert .register-banner {
	display: block;
}

.alert .register-banner__contents {
	display: block;
	padding: 40px 20px;
	margin: 0;
}

.alert .register-banner__icon,
.alert .register-banner__group {
	margin-right: 0;
}

.alert .register-banner__btn {
	background: #FF726E;
	color: #fff
;}

.register-banner.alert__inner {
	max-width: none;
width: auto;padding: 0;}


.flat-tab__item {
	display: none;
}

.flat-tab__tab-item {
	opacity: .5;
	padding: 0 0 8px 0;
}

.flat-tab input {
	display: none;
}

#flatTabSwitch_0:checked ~ .flat-tab__tab label[for="flatTabSwitch_0"] {
	font-weight: bold;
	opacity: 1;
	border-bottom: 2px solid;
}

#flatTabSwitch_0:checked ~ .flat-tab__item_0 {
	display: block;
}

#flatTabSwitch_1:checked ~ .flat-tab__tab label[for="flatTabSwitch_1"] {
	font-weight: bold;
	opacity: 1;
	border-bottom: 2px solid;
}

#flatTabSwitch_1:checked ~ .flat-tab__item_1 {
	display: block;
}

#flatTabSwitch_2:checked ~ .flat-tab__tab label[for="flatTabSwitch_2"] {
	font-weight: bold;
	opacity: 1;
	border-bottom: 2px solid;
}

#flatTabSwitch_2:checked ~ .flat-tab__item_2 {
	display: block;
}

#flatTabSwitch_3:checked ~ .flat-tab__tab label[for="flatTabSwitch_3"] {
	font-weight: bold;
	opacity: 1;
	border-bottom: 2px solid;
}

#flatTabSwitch_3:checked ~ .flat-tab__item_3 {
	display: block;
}

@media screen and (max-width: 540px) {
	.register-banner {
		font-size: 12px;
	}

	.alert .register-banner__btn {
		font-size: 1.4em;
	}

}



@media screen and (min-width: 768px) {
	.store {
		margin-top: 0;
	}

	.full-visual__title { 
		font-size: 2em;
	}
	
	.full-visual__sub-title {
		width: 48%;
		margin: auto;
	}
	
	.store__banner {
		font-size: 16px
	}
	
	.store .section {
		padding: 40px;
	}

	.store .headline__wrapper {
		padding: 24px 0 ;
	}

	.store .charge__inner {
		font-size: 20px;
		max-width: 560px;
	}

	.register-banner {
		
		margin: 0 0 40px;
		padding: 40px;
	}
	
	.walkthrough-inner {
		padding: 60px 20px;
	}
}

@media screen and (min-width: 1080px) {

	.store .full-visual {
		padding-top: 30%;
		z-index: 1;
	}

	.store .full-visual_empty {
		overflow: hidden;
	}

	.full-visual__sub-title {
		margin: 0;
	}
	 
	.full-visual__headline {
		padding: 0 8%;
		text-align: left;
		z-index: 0;
	}
	.store__banner {
		transform: none;
		top: 70%;
		left: auto;
		right: 0;
		width: 48%;
		
	}
	.store__banner .slick-list {
		padding: 0 30% 0 0 !important;
	}
	.store__banner-caption,
	.store__banner-title,
	.store__banner-text {
		color: var(--text-color);
	}

	.store__banner-item {
		margin: 0 0.4% 0 0;
	}

	.store .charge {
		padding: 0 0 80px 0;
	}
	.store .charge__inner {
		width: 48%;
		margin: 0;
		padding: 0;
		box-shadow: none;
	}

	.page__wide-wrapper {
		padding: 40px 8% 120px;
	}
	.store .slick-arrow {
		width: 32px;
		height: 32px;
		top: auto;
		bottom: 100%;
		margin: 8px 0;
	}
	
	.store .slick-arrow::before {
		font-size: 32px;
	}
	.store .slick-prev {
		transform: rotate(-180deg);
	}
	.store .slick-next {
		transform: none;
		right: auto;
		left: 60px;
	}

	.full-visual__button {
		display: inline-block;
		padding: 1em 1.5em;
		border-radius: calc(1.5em + 1px);
		border: solid 1px;
		line-height: 1;
	}
	

	.store .more__btn {
		font-weight: bold;
		font-size: 20px;
	}

	.store .section {
		max-width: none;
		padding: 60px 0;
	}

	
	.full-visual__headline { 
		font-size: 20px;
	}
	.store .slick-arrow {
		width: 56px;
		height: 56px;
	}

	.store .slick-arrow::before {
		font-size: 56px;
	}

	.store .slick-next {
		left: 80px;
	}

	.register-banner__btn {
		display: none;
	}

	.register-banner {
		padding: 40px 80px;
		border-radius: 24px;
	}

	.register-banner__contents {
		display: block;
	min-width: 240px;margin: 20px 0;}

	.register-banner__icon {
		width: 72px;
		margin-bottom: 32px;
	}

	.register-banner__img-group {
		display: block;
	}

	.register-banner__img {
		
		width: 240px;
		border-radius: 24px;
		margin: 20px  auto;
	}
	
	.register-banner__title {
		margin: 0 0 12px 0;
	}
	
	.flat-tab__tab-item {
		font-size: .8em;
		margin-right: 8px;
		cursor: pointer;
	}

	
}

@media screen and (min-width: 1240px) {
	.register-banner {
		flex: 1;
		flex-wrap: wrap;
		order: 2;
	}

	.alarm__group {
		width: 56%;
		max-width: 700px;
		margin-right: 80px;
	}
}


/*==========gallery==========*/

.section .gallery__wrapper {
	max-width: 880px;
	padding: 24px 0;
	margin: 0 auto;
}


.gallery__wrapper::before {
	content: "";
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: inherit;
}

.gallery__list {
	font-size: 0;
	letter-spacing: 0;
	list-style: none;
}

.gallery__inner {
	display: block;
	border-radius: 6px;
	background: transparent!important;
}

.gallery-img__wrapper {
	display: block;
	position: relative;
	padding-top: 100%;
	padding-right: 100%;
	overflow: hidden;
}

.background-layer .gallery__wrapper {
	background: transparent !important;
}

.gallery__item {
	display: inline-block;
	width: calc(100%/3);
	padding: .5px;
}

.gallery__item:nth-of-type(1) {
	float: left;
	width: calc(100%/3*2 - .5px);
}

.gallery-video::before {
	content: "\e920";
	display: block;
	position: absolute;
	top: 16px;
	right: 16px;
	z-index: 2;
	width: 24px;
	height: 24px;
	margin: auto 0;
	color: #FFF;
	font-family: 'icon';
	font-size: 24px;
	line-height: 1;
	-webkit-font-smoothing: antialiased;
}

.gallery__item .grid__soldout::after {
	font-size: 8vw;
}

.gallery__item:nth-of-type(1) .grid__soldout::after {
	font-size: 18vw;
}

/*==========gallery-list==========*/

.section .gallery__wrapper {
	max-width: 880px;
	padding: 24px 0;
	margin: 0 auto;
}

/*.gallery__wrapper {
	padding: 24px 0;
}*/

.gallery__wrapper::before {
	content: "";
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: inherit;
}

.gallery__list {
	font-size: 0;
	letter-spacing: 0;
	list-style: none;
}

.gallery__inner {
	display: block;
	border-radius: 6px;
	background: transparent!important;
}

.background-layer .gallery__wrapper {
	background: transparent !important;
}
	
.gallery-list .gallery__item:nth-of-type(1), .gallery__item:nth-of-type(10) {
	float: left;
	width: calc(100%/3*2 - .5px);
}

.gallery-list .gallery__item:nth-of-type(10) {
	float: right;
}

.gallery-list .gallery__item .grid__soldout {
	border-radius: 0;
}

.gallery-list .gallery__item .grid__soldout::after {
	font-size: 21vw;
}

.gallery-list .gallery__item:nth-of-type(1) .grid__soldout::after,
.gallery-list .gallery__item:nth-of-type(10) .grid__soldout::after {
	font-size: 42vw;
}


@media screen and (min-width: 768px) {
	
	.section .gallery__wrapper {
		padding: 24px;
	}
	
	.gallery__wrapper {
		padding: 30px 28px 0;
	}
	
	.gallery .title-optionable {
		display: block;
		padding: 0 0 0 40px;
	}
	
	.gallery .title-optionable .headline {
		margin-bottom: 24px;
	}
	
	.gallery__list {
		padding: 0;
	}

	.gallery__item {
		width: calc(100%/4);
		padding: 0 12px;
		margin: 0 0 24px;
	}
	
	.gallery__item:nth-of-type(7),
	.gallery__item:nth-of-type(13) {
		width: calc(100%/4);
		float: none;
	}
	
	.gallery__item:nth-of-type(1),
	.gallery__item:nth-of-type(10){
		width: calc(100%/2 - 1px);
		float: left;
	}

	.gallery-img__wrapper {
		border-radius: 6px;
	}

	.walkthrough__btn {
	    bottom: -60px;
	}
	
	/*==========gallery-list==========*/
	
	.gallery-list .section .gallery__wrapper {
		padding: 24px;
	}
	
	.gallery-list .gallery__wrapper {
		padding: 30px 28px 0;
	}
	
	.gallery-list .title-optionable {
		display: block;
		padding: 0 0 0 40px;
	}
	
	.gallery-list .title-optionable .headline {
		margin-bottom: 24px;
	}
	
	.gallery-list .gallery__list {
		max-width: 1120px;
		margin: 0 auto;
	}
	
	.gallery-list .gallery__list {
		padding: 0;
	}
	
	.gallery-list .gallery__item {
		width: calc(100%/4);
		padding: 0 12px;
		margin: 0 0 24px;
	}
	
	.gallery-list .gallery__item:nth-of-type(1) {
		float: left;
		width: calc(100%/2 - 1px);
	}

	.gallery-list .gallery__item:nth-of-type(10) {
		float:left;
		width: calc(100%/4);
		padding: 0 12px;
		margin: 0 0 24px;
	}

	.gallery-list .gallery__item:nth-of-type(12) {
		float:right;
		width: calc(100%/2 - 1px);
	}
	
	.gallery-list .gallery-img__wrapper {
		border-radius: 6px;
	}

	.gallery-list .gallery__item .grid__soldout::after,
	.gallery-list .gallery__item:nth-of-type(10) .grid__soldout::after {
		font-size: clamp(80px,12vw,140px);
	}

	.gallery-list .gallery__item:nth-of-type(1) .grid__soldout::after,
	.gallery-list .gallery__item:nth-of-type(12) .grid__soldout::after {
		font-size: clamp(200px,26vw,300px);
	}
}
@media screen and (min-width: 1080px) {
	.store .gallery__list {
		margin: 0 -.8%;
	}
	
	.store .gallery__item {
		width: calc(100%/6);
		padding: 0 .8%;
		margin: 0 0 1.6%;
	}
	
	.store .gallery__item:nth-of-type(7),
	.store .gallery__item:nth-of-type(13) {
		width: calc(100%/6);
	}
	
	.store .gallery__item:nth-of-type(1){
		width: calc(100%/3 - 1px);
	}
	
	
}

/*************************************
				note
*************************************/

.note__wrapper {
	max-width: 880px;
	margin: 0 auto;
	padding: 24px;
}

.note__wrapper::before {
	content: "";
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: inherit;
}

.note__list {
	margin: -16px 0 0 0;
	list-style: none;
}

.note__item {
	position: relative;
}

.note__item::after {
	content: "";
	display: block;
	position: absolute;
	width: 100%;
	bottom: 0;
	border: solid 1px;
	border-color: var(--alpha-text-color);
}

.note__inner {
	display: flex;
	align-items: flex-start;
	padding: 16px 0;
}

.note__contents {
	width: 54%;
	margin: 0 16px 0 0;
	font-size: 14px;
	color: var(--text-color);
}

.note__title {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	margin: 0 0 4px;
	font-size: 16px;
	line-height: 1.5;
}

.note__introduction {
	display: block;
	height: 24px;
	margin-bottom: 8px;
	opacity: .6;
}

.review-number {
	display: inline-block;
	margin: 0 8px 0 0;
}

.review-number::before {
	content: "\e960";
	margin: 0 4px 0 0;
	color: #F5CB00;
	font-family: 'icon' !important;
}

.limit-day {
	display: inline-block;
	color: var(--primary-color);
}

.note__img__wrapper {
	position: relative;
	width: calc(46% - 16px);
	border-radius: 4px;
	overflow: hidden;
}

.note__img__wrapper::before {
	content: "";
	display: block;
	padding-top: 40%;
}

.store .note__list {
	padding: 0 24px;
}

@media screen and (min-width: 768px) {
	.note__wrapper {
		padding: 30px 40px 0;
	}
	
	.note__item {
		margin: 0 0 8px 0;
	}
	
	.note__item::after {
		content: none;
	}
	
	.note__contents {
		width: calc(55% - 40px);
		margin: 0 40px 0 0;
	}
	.note__img__wrapper {
		width: 45%;
	}
	.store .note__list {
		padding: 0;
	}
}

@media screen and (min-width: 1080px) {
	.store .note__list {
		display: flex;
	margin: 0 -.8%;}

	.store .note__item {
		width: 33.33%;
	padding: 0 .8%;}

	.store .note__inner {
		flex-wrap: wrap;
	padding: 0;}
	.store .note__contents {
		width: 100%;
	    margin: 16px 0;
	    order: 1;
	font-size: 18px;}

	.store .note__title {
		font-weight: bold;
	font-size: 24px;}
	
	.store .note__img__wrapper {
		width: 100%;
	}

	
}

/*************************************
				alarm
*************************************/



.alarm__list {
	padding: 0 24px;
	list-style: none;
}

.alarm__item {
	margin: 16px 0;
}

.fanclub-label__txt {
	display: inline-block;
	padding: .5em .8em;
	background: #E04136;
	border-radius: 1em;
	line-height: 1;
	color: #FFFFFF;
	font-size: 10px;
	font-weight: bold;
}

.alarm__inner {
	display: flex;
	align-items: center;  
	padding: 16px;
	border-radius: 6px;
	box-shadow: 0px 0px 6px 0px rgb(0 0 0 / 20%);
}


.alarm_img__wrapper {
	position: relative;
	width: 24%;
	margin: 0 16px 0 0;
	padding-top: 24%;
	border-radius: 6px;
	overflow: hidden;
}


.alarm__contents {
	flex: 1;
}

.alarm__title {
	display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin: 0 0 4px;
    font-weight: bold;
    line-height: 1.5;
}

.alarm__sub-text.icon_coin::before {
	vertical-align: middle;
	margin: 0;
	line-height: 1;
	font-size: 20px;
	letter-spacing: -.3em;
}

.alarm__sub-text .text {
	vertical-align: middle;
	opacity: .6;
}

@media screen and (min-width: 768px) {
	.alarm__list {
		padding: 0;
	}
}

@media screen and (min-width: 1080px) {
	
	.alarm__list {
		overflow: hidden;
	}

	.alarm__item {
		float: left;
		width: 50%;
	}
	
	.store .alarm__item:first-child {
		width: 68%;
		margin: 0 0 16px 0;
	}
	
	.alarm_img__wrapper {
		width: 34%;
		padding-top: 34%;
	}

	.alarm__contents {
		padding: 0 6% 0 0;
	}

	.store .alarm__item:first-child .alarm__contents {
		font-size: 24px;
		padding: 0 6% 0 0;
	}
	
	.store .alarm__item:not(:first-child) {
		float: right;
		width: 32%;
		margin: 0 0 16px 0;
	}
	
	.alarm__inner {
		box-shadow: none;
		border-radius: 0;
		border-bottom: none;
		padding: 0;
	}

	.section__sub-container {
		border-bottom: 1px solid var(--alpha-text-color);
		padding: 16px 0;margin: 0;
	}
}

@media screen and (min-width: 1240px) {
	.store .section__sub-container:first-child {
		border-top: 1px solid var(--alpha-text-color);
	}
	.alarm__container {
		display: flex;
		align-items: flex-start;}
}

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

	.store .full-visual_empty::before {
		top: 50%;
		left: 50%;
		transform: translate(-50%,-50%);
		min-width: 200px;
		min-height: 200px;
		padding-right: 0;
		font-size: clamp(200px, 50vw, 50vw);
	}

	.gallery__item .grid__soldout::after {
		font-size: clamp(100px,13vw,118px);
	}

	.gallery__item:nth-of-type(1) .grid__soldout::after {
		font-size: clamp(210px,28vw,250px);
	}

	.alarm__list_flat {
		margin: -16px 0 0 0;
	}
	.alarm__list_flat .alarm__item {
		margin: 0;
	}
	.alarm__list_flat .alarm__inner {
		box-shadow: none;
		border-radius: 0;
		border-bottom: 1px solid var(--alpha-text-color);
		padding: 16px 0;
	}
	.alarm__list_flat .alarm_img__wrapper {
		order: 2;
		margin: 0 0 0 16px;
	}
}

/*********************
		general
*********************/

.general {
	position: relative;
	color: #FFFFFF;
}

.general__inner {
	max-width: 1084px;
	padding: 16px 24px;
	margin: 0 auto;
}

.general::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,.2);
}

.general__title {
	position: relative;
	z-index: 1;
	margin-bottom: 4px;
	color: #FFFFFF;
	font-weight: bold;
}

.general__txt {
	position: relative;
	font-size: 14px;
}

/*********************
Transition from home
*********************/

.category-tag {
	display: inline-block;
	margin: 0 16px 0 0;
	padding: 3px 14px;
	border-radius: 10px;
	border: 1px solid #FFF;
	color: var(--text-color);
	font-size: 13px;
	line-height: 1;
}

.detail__items .category-tag {
	margin: 0 16px 0 0;
}

/*********************
      detail
*********************/

.detail {
	padding: 24px 0;
}

.detail__title {
	font-size: 24px;
	padding: 0 24px 4px;
}

.detail__post-date {
	display: inline-block;
	margin: 0 24px 24px;
	font-size: 14px;
	color: var(--text-color);
    opacity: 60%;
}

.detail__txt {
	margin: 0 0 8px;
	padding: 0 24px;
}

.product .detail__txt {
	margin: 0;
	padding: 0;
}

.detail__group ~ .more-txt {
	padding: 0 0 8px 24px;
}

.detail__txt .more-txt {
	padding: 0;
}

.detail__img, .detail__video {
	width: 100%;
	margin: 0 0 24px;
	display: block;
}

.detail__video video {
	width: 100%;
	display: block;
}

.detail__img_noimage {
	display: none;
}

/*==========video==========*/

.detail__iframe {
	position: relative;
	padding-bottom: calc(56.25% + 27px);
	overflow: hidden;
	width: calc(100% + 48px);
	margin: 24px 0 24px -24px;
}

.detail__iframe iframe {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

.detail__video {
	position: relative;
	background: #000;
}

/*=======================*/

.detail__card {
	position: relative;
	display: flex;
	margin: 8px 0;
	align-items: center;
	border: .5px solid;
	border-radius: 12px;
	border-color: var(--alpha-text-color);
	overflow: hidden;
	box-shadow: none;
	color: var(--text-color);
	text-decoration: none;
}
	
.card__thumbnail-wrapper {
	position: relative;
	width: 88px;
	padding-top: 88px;
	overflow: hidden;
}

.card__description {
	padding: 12px;
	font-size: 14px;
	line-height: 1.3;
	flex: 1;
}

.card__text {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	margin: 0 0 4px;
}

.card__url {
	display: -webkit-box;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
	overflow: hidden;
	opacity: .5;
}

.share__wrapper {
	margin: 24px 24px 0;
}

.share__items {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	padding: 0 0 16px;
	border-bottom: 1px solid #C7C7CC;
}

.share__title {
	margin: 0 8px 0 0;
	font-size: 12px;
}

.share__link {
	position: relative;
	display: block;
	width: 40px;
	height: 40px;
	overflow: hidden;
	color: var(--text-color);
}

.share__link::before {
	content: "";
	display: block;
	padding-top: 100%;
}

.share__icon::before {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	font-family: 'icon';
	font-size: 24px;
}

.feed-detail .share__items {
	padding: 0 0 16px;
	border-top: 0;
	border-bottom: 1px solid #C7C7CC;
}

/*********************
      detail pager
*********************/

.pager_text .pager__list {
	display: table;
	width: 100%;
}

.pager_text .pre, .pager_text .back, .pager_text .next {
	display: table-cell;
	width: 33.33%;
}

.pager_text .pager__item {
	height: 40px;
	line-height: 40px;
	border-radius: 0;
}

.pager__text-link {
	padding: 8px 16px;
	font-size: 14px;
}

.pager__text-link_inactive {
	pointer-events: none;
	opacity: .3;
}

.pager_text .pre__text,
.pager_text .next__text {
	position: relative;
}

.pager_text .pre__text {
	padding-left: 16px;
}

.pager_text .next__text {
	padding-right: 16px;
}

.pager_text .pre__text::before,
.pager_text .next__text::after {
	position: absolute;
	top: 50%;
	content: "";
	display: inline-block;
	width: 8px;
	height: 8px;
	transform: translateY(-50%) rotate(-135deg);
	border-color: var(--text-color);
}

.pager_text .pre__text::before {
	left: 0;
	border-top: 1px solid;
	border-right: 1px solid;
}

.pager_text .next__text::after {
	right: 0;
	border-bottom: 1px solid;
	border-left: 1px solid;
}

.simple-pager {
    display: flex;
    margin: 0 -16px;
    font-size: 14px;
}

.simple-pager__item {
	position: relative;
	width: 50%;
}

.simple-pager__inner {
	display: block;
	padding: 0 24px;
}

.simple-pager__item:first-child {
	border-right: 1px solid var(--alpha-text-color);
}

.simple-pager__inner::before {
	content: "\e903";
	font-family: 'icon' !important;
	position:absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	margin: auto 0;
}

.simple-pager__item:first-child .simple-pager__inner::before {
	right: auto;
	left: 0;
	transform: translateY(-50%) rotate(180deg);
}

.simple-pager__label {
    margin-bottom: .5em;
    font-size: .9em;
    opacity: .6;
}

.simple-pager__title {
    display: -webkit-box;
    font-size: 1em;
    height: calc(2em * 1.4);
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    line-height: 1.4;
}


/*************************
          detail pick-up
*************************/

.detail__pickup {
	margin: 20px 0 0 0;
	padding: 24px 24px 0;
}

.detail .page__sub-headline {
	display: block;
	padding: 0 0 24px;
	font-size: 20px;
	font-weight: normal;
}

.detail .page__sub-headline::after {
	content: none;
}

.pickup__list {
	list-style: none;
}
	
.pickup__item {
	margin: 0 0 16px;
}

.pickup__item:last-of-type {
	margin: 0;
} 
	
.pickup__link {
	display: flex;
	align-items: center;
}
	
.pickup__thumbnail-wrapper {
	position: relative;
	width: 80px;
	height: 80px;
}

.pickup__thumbnail-wrapper::before {
	display: block;
	content: "";
	padding-top: 100%;
}

.pickup__link .detail__img {
	margin: 0;
}

.pickup__item .noimage__inner_logo {
	width: 64px;
	height: auto;
}

.pickup__item .noimage__inner_wrapper {
	display: flex;
	justify-content: center;
	align-items: center;
	overflow: hidden;
}

.pickup__item .noimage__inner_text {
	max-width: 64px;
	max-height: 64px;
	font-size: 14px;
	overflow: hidden;
}

.pickup__description {
	width: calc(100% - 80px);
	max-height: 80px;
	padding:  0 10px;
	line-height: 1.3;
	font-size: 14px;
	overflow: hidden;
}
	
.pickup__text {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	margin: 0 0 4px;
}

.detail__pickup .pager_text{
	margin: 24px 0 0!important;
	text-align:center;
}

/***************************
      SCHEDULE-detail
****************************/

.detail__items {
	margin: 0 24px 8px; 
	font-size: 0;
	letter-spacing: 0;
}

.detail__schedule-date {
	display: inline-block;
	font-size: 0;
	font-weight: bold;
	letter-spacing: normal;
}

.detail__schedule-date .fixed-icon::after {
	content: "\e963";
	font-family: 'icon';
	display: inline-block;
	margin: 0 0 0 8px;
	font-size: 16px;
	font-weight: normal;
	line-height: 1;
}

.detail__schedule-date .detail__date-wrapper:nth-of-type(2) {
	padding: 0;
}

.detail__date-wrapper {
	display: inline-block;
	padding-right: 8px;
}

.detail__date-wrapper:nth-of-type(2)::before {
	content: "-";
	padding-right: 10px;
	font-size: 16px;
}

.detail__schedule-date .year {
	display: inline-block;
	padding-right: 6px;
	font-size: 12px;
	font-weight: normal;
    opacity: 60%;
}

.detail__schedule-date .day {
	display: inline-block;
	font-size: 20px;
	font-weight: bold;
}

.detail__items ~ .detail__title{
	padding: 0 24px 24px;
}

.detail__pickup .schedule__items {
	display: flex;
	align-items: baseline;
}

.detail__pickup .pickup__date {
	display: inline-block;
	color: var(--text-color);
    opacity: 60%;
}

.detail__pickup .schedule__date {
	flex-shrink: 0;
	display: inline-block;
	margin-bottom: 8px;
	font-size: 14px;
}

.detail__pickup .schedule__text {
	display: -webkit-box;
	max-height: 44.8px;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
	line-height: 1.4;
}

.detail__pickup .year {
	display: inline-block;
	font-size: 12px;
    opacity: 60%;
}

.detail__pickup .day {
	display: inline-block;
	font-size: 14px;
}

.detail__pickup .date__wrapper {
	display: inline-block;
}

.detail__pickup .date__wrapper:nth-of-type(2)::before {
	content: "-";
	font-size: 14px;
	line-height: 14px;
	font-weight: bold;
}

.transparent {
	background: transparent;
}

.transparent_inherit {
	background: inherit;
}

.transparent_txt {
	color: transparent;
	margin-top: -999px;
}

/***************************
           PRODUCT
****************************/

.product__wrapper {
	padding: 24px;
}

.product::before {
	content: "";
	position: absolute;
	top: 0;
	width: 100%;
	height: 100px;
	background: rgb(0,0,0,0);
	background: -webkit-linear-gradient(bottom, rgba(0,0,0,0) 0%, rgba(0,0,0,0.4) 100%);
	background: linear-gradient(to top, rgba(0,0,0,0) 0%, rgba(0,0,0,0.4) 100%);
}

.product__title {
	margin-bottom: 8px;
	font-size: 24px;
}

.product__release-date {
	margin-bottom: 16px;
	color: var(--light-text-color);
}

.product__img {
	width: 100%;
	margin-top: -56px;
}

.history__wrapper::before {
	content: "";
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: inherit;
}

.background-layer .history__wrapper {
	background: transparent;
}
	

.history {
	margin-top: 24px;
}

.history_list {
	margin: 0;
	padding: 24px 24px 40px;
}

.history__item {
	list-style: none;
	padding-bottom: 24px;
	border: none;
}

.history__item:last-child {
	margin: 0;
	padding: 0;
}

.history__date {
	margin-bottom: 4px;
	color: var(--light-text-color);
}

.headline_hide {
	position: absolute;
	left: 99999px;
}

/*************************************
**************************************
				timeline
**************************************
*************************************/

.header__title {
	width: 100%;
	text-align: center;
	padding: 0 40px;
	transition: .1s ease;
}

.header-bar__search {
	height: 24px;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	margin: auto 24px auto 16px;
	font-size: 24px;
	cursor: pointer;
}

.timeline-search,
.chat-search {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 999;
	width: 100%;
	max-height: 0;
	overflow: hidden;
}



/*************************************
**************************************
				search
**************************************
*************************************/

#drawer-switch:checked ~ .search {
	max-height: 100%;
}

.search__item {
	position: relative;
	padding: 16px;
}

.search-item__inner {
	display: flex;
	align-items: center;
}

.search__form {
	flex: 1;
}

.search__close {
	padding: 0 0 0 16px;
	font-size: 14px;
	cursor: pointer;
}

.search-field__wrapper {
	position: relative;
}

.search__field {
	position: relative;
	display: block;
	width: 100%;
	height: 38px;
	line-height: 38px;
	padding: 0 44px 0 16px;
	border-radius: 4px;
	border: none;
	background: #F0F0F0;
	font-size: 16px;
}

::-webkit-search-cancel-button {
	-webkit-appearance: none;
}

.search__button,
.feed-detail__main .icon_search::before {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	height: 38px;
	margin: auto 0;
	padding: 0 10px;
	border: none;
	background: none;
	font-size: 24px;
	cursor: pointer;
	color: var(--primary-color);
}

.search__tab {
	margin: 0 auto;
	font-size: 0;
}

.search-tab__item {
	display: inline-block;
	margin: 10px 8px 0 0;
	padding: 8px 16px;
	border-radius: 4px;
	font-size: 14px;
}

/************************
      detail-feed
************************/

.header-bar__archive {
	position: fixed;
	display: block;
	top: 16px;
	right: 16px;
	z-index: 999;
	height: 24px;
	font-size: 24px;
	cursor: pointer;
}


.feed-detail .page__sub-headline {
	display: none;
}

.feed-detail__sub {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 998;
	width: 100%;
	height: 100%;
	padding: 56px 0 0;
	background: var(--contents-color);
	transition: all 0.3s ease-in-out 0s;
	transform: translateX(100%);
}


.feed-detail__main {
	background: var(--contents-color);
}

.feed-detail__search {
	position: fixed;
	width: 100%;
	top: 56px;
	left: 0;
	padding: 4px 24px;
	z-index: 996;
}

.feed-detail__search ~ .feed-detail__list {
	padding-top: 46px;
}

.feed-detail__item {
	position: relative;
	padding: 24px 0 16px;
	border-bottom: solid 1px var(--alpha-text-color);
}

.feed-detail__link {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.feed-detail__link:last-child {
	margin: 0 0 24px;
}

.txtItem {
	display: block;
}

.archive-switch__close {
	display: none;
}

#archive-switch:checked ~ .feed-detail__sub {
	transform: translateX(0);
}

#archive-switch:checked ~ [class*=" icon_"] {
	display: none;
}

#archive-switch:checked ~ .archive-switch__close {
	display: block;
}

.archive__wrapper{
	height: 100%;
	overflow: scroll;
}

.archive__wrapper::-webkit-scrollbar {
	display: none;
}

.archive__list {
	list-style: none;
}

.archive__item {
	background: var(--contents-color);
}

.archive__item::after {
	content: "";
	display: block;
	border-bottom: solid 1px;
	border-color: var(--alpha-text-color);
}

.archive__item_inline .archive__inner {
	display: flex;
	align-items: center;
}

.archive__item_inline .archive__txt-wrapper {
	flex: 1;
	margin-left: 8px;
}

.archive__inner {
	display: block;
	padding: 30px 24px;
	font-size: 16px;
	color: var(--text-color);
}

.archive__img-wrapper {
	position: relative;
	width: 40%;
	padding-top: 40%;
	overflow: hidden;
	border-radius: 4px;
}

.archive__img {
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	object-fit: cover;
	font-family: 'object-fit: cover;';
}

.archive__date {
	position: relative;
	
}

.archive__date::after {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	content: "";
	display: block;
	width: 8px;
	height: 8px;
	border-top: 2px solid;
	border-right: 2px solid;
	border-color:  var(--alpha-text-color);
	transform: rotate(45deg);
}

.feed-detail .pager_text {
	padding: 24px 0;
	text-align: center;
}

.modal__mask {
	display: none;
	position: fixed;
	z-index: 997;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0, .5);
}

.search-modal {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 997;
	width: 100%;
	height: 100%;
	padding: 0 0 24px 0;
	background: var(--contents-color);
}

.search-modal__search {
	display: none;
	position: fixed;
	top: 56px;
	left: 0;
	width: 100%;
	padding: 4px 24px;
	z-index: 996;
	max-height: none;
}

.search-modal ul {
	height: 100%;
}

.search-modal__empty {
	display: none;
	padding: 40px 0;
    text-align: center;
}

.search-modal__empty span {
	display: block;
}

.search-modal__empty-title {
	margin: 0 0 16px 0;
	font-weight: bold;
	font-size: 20px;
}


.modal-swich:checked ~ .search-modal,
.modal-swich:checked ~ .modal__mask {
	display: block;
}

.modal-swich:checked ~ .search-modal .search-modal__search {
	display: block;
}

.feed-detail .detail__card {
	opacity:1;
}

.feed-detail .simplebar-mask {
	position: static;
}

/*************************************
**************************************
				mail
**************************************
*************************************/

.member {
	display: flex;
	align-items: center;
	margin: 0 0 16px 0;
	padding: 0 24px;
}

.member-img {
	width: 32px;
	height: 32px;
	border-radius: 16px;
	object-fit: cover;
	overflow: hidden;
}

.member-name {
	padding: 0 0 0 8px;
	font-size: 14px;
}

.mail {
	padding: 24px 0;
	margin: 0 0 8px 0;
}

.mail__inner {
	display: block;
	padding: 0 24px 0;
}

.mail__inner .member {
	padding: 0;
}

.mail__premium {
	display: inline-block;
	width: 90px;
	margin: 0 0 0 16px;
	padding: 2px;
	border-radius: 4px;
	color: #FFF;
	font-size: 12px;
	letter-spacing: 0;
	text-align: center;
}

.mail__title {
	font-size: 16px;
	margin-bottom: 8px;
}

.mail__date {
	display: inline-block;
	padding: 0 0 12px 0;
	font-size: 14px;
}

.mail__favorite-count {
	display: inline-block;
	font-size: 14px;
}

.mail__favorite-count::before {
	content: "\e917";
	margin: 0 0 0 16px;
	padding: 0 2px 0 0;
	font-family: 'icon' !important;
	font-weight: normal;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.mail__text {
	font-size: 14px;
}

.mail-favorite__txt,
.mail-reply__text {
	line-height: 1;
}

.premium-mail__text {
	font-size: 14px;
}

.premium__contents {
	padding: 12px 0 0;
	font-size: 14px;
	font-weight: bold;
}

.mail-grid__wrapper {
	display: block;
	overflow: hidden;
}

.mail-grid__inner {
	margin: 12px -1px 0 0;
	font-size: 0;
	letter-spacing: 0;
}

.mail-grid__item {
	display: inline-block;
	overflow: hidden;
	position: relative;
	color: #323232;
	outline: none;
}

.mail-grid__item_movie::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	background: rgba(0, 0, 0, .2);
	width: 100%;
	height: 100%;
}

.mail-grid__item_movie::after {
	content: "\e920";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 1;
	width: 48px;
	height: 48px;
	margin: auto;
	color: #FFF;
	font-size: 48px;
	font-family: 'icon' !important;
	line-height: 1;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/*-----mail-grid_1-----*/

.mail-grid_1 .mail-grid__item {
	width: 100%;
	padding-top: 100%;
}

/*-----mail-grid_2-----*/

.mail-grid_2 .mail-grid__item {
	width: calc(100%/2 - 1px);
	padding-top: calc(100%/2 - 1px);
	margin: 0 1px 1px 0;
}

.mail-grid_2 .mail-grid__item:nth-of-type(2) {
	margin-right: 0;
}

/*-----mail-grid_3-----*/

.mail-grid_3 .mail-grid__item:nth-of-type(1) {
	width: calc(100%/3*2 - 1px);
	padding-top: calc(100%/3*2 - 1px);
	margin: 0 1px 1px 0;
	float: left;
}

.mail-grid_3 .mail-grid__item:nth-of-type(2) {
	width: calc(100%/3 - 1px);
	padding-top: calc(100%/3 - 1px);
	margin: 0 1px 1px 0;
}

.mail-grid_3 .mail-grid__item:nth-of-type(3) {
	width: calc(100%/3 - 1px);
	padding-top: calc(100%/3 - 1px);
}

.mail-grid_3 .mail-grid__item:nth-of-type(2),
.mail-grid_3 .mail-grid__item:nth-of-type(3) {
	margin-right: 0;
}

/*-----mail-grid_4-----*/

.mail-grid_4 .mail-grid__item {
	width: calc(100%/2 - 1px);
	padding-top: calc(100%/2 - 1px);
	margin: 0 1px 1px 0;
}

.mail-grid_4 .mail-grid__item:nth-of-type(2) {
	margin-right: 0;
}

/*-----mail-grid end-----*/

.mail__img {
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	object-fit: cover;
	font-family: 'object-fit: cover;';
}

.mail__icon-wrapper {
	display: block;
	position: relative;
	padding-top: 160%;
}

.mail__img-icon {
	position: absolute;
	top: 74px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 2;
}

.mail__img-icon .mail__img {
	position: static;
	width: 116px;
	height: 116px;
	border-radius: 100%;
}

.mail__icon-bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.mail__icon-bg image {
	width: 100%;
	height: 100%;
}

.mail__img-wrapper {
	position: relative;
	border-radius: 100%;
}

.mail__img-wrapper:before {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	width: 130px;
	height: 130px;
	border-radius: 100%;
	background: linear-gradient(#ff5f6d 0%, #ffc371 100%);
	opacity: 0.6;
	z-index: -1;
}

.mail__img-wrapper:after {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	width: 146px;
	height: 146px;
	border-radius: 100%;
	background: linear-gradient(#ff5f6d 0%, #ffc371 100%);
	opacity: 0.4;
	z-index: -1;
}

.mail__img-time {
	text-align: center;
	color: #FFF;
	margin-top: 20px;
}

.mail__img-close {
	position: absolute;
	left: 50%;
	bottom: 60px;
	transform: translateX(-50%);
}

.mail__action {
	width: 100%;
	padding: 24px 0 0;
	font-size: 0;
	letter-spacing: 0;
	text-align: center;
}

.mail__favorite,
.mail__reply,
.mail__replied {
	display: inline-block;
	width: 50%;
	font-size: 16px;
}

.mail-favorite__inner {
	display: inline-block;
	cursor: pointer;
}

.mail-favorite__input {
	display: none;
}

.mail-favorite__txt {
	vertical-align: middle;
	line-height: 1;
}

.mail-favorite__txt::before {
	content: "\e918";
	padding: 0 8px 0 0;
	font-family: 'icon' !important;
	font-weight: normal;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	vertical-align: middle;
}

.mail-favorite__input:checked ~ .mail-favorite__txt {
	color: #ED4956;
	font-weight: bold;
}

.mail-favorite__input:checked ~ .mail-favorite__txt::before {
	content: "\e917";
	color: #ED4956;
}

.mail-reply__text::before {
	content: "\e91b";
	font-family: 'icon' !important;
	padding: 0 8px 0 0;
	vertical-align: middle;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.mail__replied {
	font-weight: bold;
}

.mail-replied__text::before {
	content: "\e925";
	padding: 0 8px 0 0;
	font-family: 'icon' !important;
	font-weight: normal;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/*-----media-grid-----*/

.media-grid__wrapper {
	overflow: hidden;
	display: block;
}

.media-grid__inner {
	margin: 12px -1px 0 0;
	font-size: 0;
	letter-spacing: 0;
}

.media-grid__item {
	display: inline-block;
	overflow: hidden;
	position: relative;
	color: #323232;
	outline: none;
}

.media-grid__item {
	width: calc(100%/3 - 1px);
	padding-top: calc(100%/3 - 1px);
	margin: 0 1px 1px 0;
}

.media__img {
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	font-family: 'object-fit: cover;';
}

.media-grid__item:nth-of-type(3n) {	
	margin-right: 0;
}

/*************************************
**************************************
				mail_detail
**************************************
*************************************/

/*.main__mail-detail {
	margin-bottom: -56px;
}*/

.header-favorite__input {
	display: none;
}

.header-favorite__switch {
	height: 24px;
	position: fixed;
	top: 16px;
	right: 24px;
	z-index: 998;
	font-size: 24px;
	color: #ED4956;
	line-height: 1;
	cursor: pointer;
}

.header-favorite__switch::before {
	content: "\e918";
	font-family: 'icon' !important;
	font-weight: normal;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.header-favorite__text {
	display: none;
}

.header-favorite__input:checked ~ .header-favorite__switch::before {
	content: "\e917";
	color: #ED4956;
}

.mail-detail {
	margin: 0;
}

.mail__title_small {
	font-size: 14px;
}

.mail-grid__wrapper_space {
	margin: 0;
	padding: 0 24px;
}

.mail-comment__wrapper {
	display: block;
	width: 100%;
	padding: 16px 24px 0;
}

.mail-comment__inner {
	display: table;
}

.mail__thumbnail {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	margin-right: 16px;
}

.mail__contents {
	display: table-cell;
	padding: 16px;
	border-radius: 6px;
	vertical-align: top;
}

.mail__thumbnail-img {
	border-radius: 50%;
	width: 32px;
	height: 32px;
}

.mail-contents__default {
	display: block;
	font-size: 14px;
	font-weight: bold;
}

.mail-contents__text {
	font-size: 14px;
}

.mail-contents__date {
	display: table-cell;
	min-width: 48px;
	padding: 0 0 0 8px;
	font-size: 12px;
	text-align: left;
	vertical-align: bottom;
}

/* 入力フィールド */

.send__inner {
	position: relative;
	padding: 16px;
}

.send-end {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
	width: 100%;
	height: 100%;
	padding: 18px;
	background-color: rgba(0, 0, 0, 0.5);
	color: #FFF;
	font-size: 18px;
	line-height: 1;
	text-align: center;
}

.send-end__text {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	width: 100%;
}

.send__form {
	width: 100%;
	padding-bottom: env(safe-area-inset-bottom);
}

.send-field__wrapper {
	position: relative;
}

.send__field {
	display: block;
	width: 100%;
	height: 40px;
	max-height: 100px;
	padding: 8px 44px 8px 16px;
	border-radius: 19px;
	border: none;
	background: #F0F0F0;
	font-size: 16px;
	font-family: 'Hiragino Kaku Gothic ProN', 'Meiryo', 'Osaka', 'MS PGothic', 'YuGothic', 'Arial','Helvetica Neue','Helvetica',sans-serif;
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	resize:none;
}

.send__button {
	position: absolute;
	right: 0;
	bottom: 8px;
	height: 24px;
	margin: auto 16px auto 0;
	padding: 0 0 0 10px;
	border: none;
	background: none;
	font-size: 24px;
	cursor: pointer;
}

/*************************************
**************************************
				timeline-backnumber
**************************************
*************************************/

.backnumber-timeline__wrapper {
	width: 100%;
	margin: 0 0 8px 0;
	padding: 24px;
}

.backnumber-timeline,
.backnumber-timeline__text {
	margin-bottom: 16px !important;
}

.backnumber-btn__timeline {
	margin: 16px auto !important;
}

/*************************************
**************************************
				mypage
**************************************
*************************************/

.return {
	cursor: pointer;
}

.members__container {
	position: relative;
	padding: 80px 0 0;
}

.members__container .settings {
	display: none;
}


.charge__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
max-width: 440px;margin: -72px auto 0;padding: 16px;
font-size: 14px;box-shadow: 0px 0px 20px 0px rgb(0 0 0 / 10%);border-radius: 6px;}

.charge__inner::before {
	content: "\e910";
	color: #F5CB00;
	font-family: 'icon';
	display: inline-block;
	line-height: 1;
	margin-right: 4px;
	font-size: 3.4em;
	font-weight: normal;
	-webkit-font-smoothing: antialiased;
}

.charge__head {
	font-size: 1em;
	opacity: .6;
}
.charge__count {
	font-weight: bold;
	font-size: 1.6em;
line-height: 1.4;}
.charge__group {
	flex: 1;
	overflow: hidden;
}

.charge__button {
	padding: 1em 1.5em;
	font-size: 1em;
	line-height: 1;
	border-radius: 1.5em;
font-weight: bold;}

.charge__button::before {
	content: "\e92c";

	font-family: 'icon';
	display: inline;
	margin: 0 4px 0 0;
	font-weight: normal;
	-webkit-font-smoothing: antialiased;
	vertical-align: text-bottom;
}
}


/*ストア実装後マイページから無くなったら削除*/

.charges {
	max-width: 400px;
	margin: 24px auto;
}

.charges__item {
	display: inline-block;
	margin: 0 0 16px 20px;
}

.charges__count {
	font-size: 24px;
	font-weight: bold;
}

/*↓チャージボタン追加レイアウト↓*/
.charges__item {
	display: flex;
	align-items: center;
	justify-content:space-between;
	margin: 0 20px 12px 20px;
}

.charges__sub-text {
	font-size: 12px; 
	font-weight: 100;
	opacity: .6;
}

.charges__button {
	display: inline-block;
	float: right;
	width: 100px;
	padding: 4px 12px;
	background: linear-gradient(90deg, #FF5F6D 0%, #FFC371 100%);
	border-radius: 15px;
	font-size: 12px;
	color: #FFF;
}

.charges__count {
	flex: 1 1 0%;
	margin-top: 8px;
	font-size: 20px;
	font-weight: bold;
}

.charges__count .hold__name {
	display: none;
}

.charges__item::before {
	font-family: 'icon';
	display: inline-block;
	line-height: 1;
	margin-right: 4px;
	font-size: 18px;
	font-weight: normal;
	-webkit-font-smoothing: antialiased;
}

.charges__count_point::before {
	content: "\e935";
	color: #00BC89;
}

.charges__count_coin::before {
	content: "\e910";
	color: #F5CB00;
}

.charges__txt {
	font-size: 14px;
}

.card {
	position: relative;
	border-radius: 6px;
	box-shadow:0px 0px 10px 4px rgba(0,0,0,0.16);
}

#morningcall .card {
	overflow: hidden;
}

.enroll {
	position: relative;
	margin-bottom: 24px;
	padding: 0 24px;
	text-align: center;
}

.enroll-card {
	text-align: left;
}

.enroll-card {
	overflow: hidden;
}

.enroll-card__header {
	padding: 6px 16px;
	color: #FFFFFF;
	font-size: 12px;
	text-align: center;
	border-bottom: 1px solid rgba(255,255,255,.1);
}

.enroll-card__inner {
	position: relative;
	display: flex;
	font-size: 14px;
}

.enroll-card__txt-wrapper {
	padding: 16px;
	flex: 1;
}

.enroll-card__subtxt {
	margin-top: 4px;
}

.expired-tag {
	display: inline-block;
	margin: 0 0 0 8px;
	padding: 4px 8px;
	border-radius: 30px;
	background: #E04136;
	color: #FFF;
	font-size: 11px;
	font-weight: bold;
	line-height: 1;
}

.enroll-card__label {
	position: relative;
	display: flex;
	right: 0;
	top: 0;
	padding: 0 24px;
	align-items: center;
	cursor: pointer;
}

.enroll-card__label::before {
	content: "";
	position: absolute;
	top: 8px;
	left: 0;
	height: calc(100% - 16px);
	border-left: 1px solid;
	border-color: var(--alpha-text-color);
}

.enroll__link {
	display: inline-block;
	padding: .8em 1.5em;
	border: 1px solid;
	border-color: inherit;
	border-radius: calc(1.5em + 2px);
	font-size: 16px;
	color: inherit;
	text-align: center;
}

.enroll__txt-link-wrapper {
	margin-top: 16px;
	text-align: right;
	font-size: 14px;
}

.enroll__txt-link::after {
	content: "\e903";
	font-family: 'icon';
	line-height: 1;
	font-size: 16px;
	font-weight: normal;
	-webkit-font-smoothing: antialiased;
	vertical-align: middle;
}

.enroll-switch:checked ~ .enroll__mask {
	display: block;
}

.members {
	position: relative;
	width: calc(100% - 48px);
	max-width: 400px;
	margin: 46px auto 24px;
}

.members-small {
	width: calc(100% - 32px);
}

.members__premium {
	padding: 8px 20px;
	border-radius: 4px 4px 0 0;
	color: #FFFFFF;
	font-size: 12px;
	font-weight: bold;
}

.members__title {
	padding: 20px;
	font-size: 24px;
	font-weight: bold;
}

.members__label {
	position: relative;
}

.clip-img__wrapper {
	display: block;
	position: relative;
	overflow: hidden;
}

.members-bg__wrapper {
	padding-top: 94px;
}

.members-bg__wrapper_bg {
	position: absolute;
	padding-top: 56%;
	padding-right: 100%;
	margin-top: -56px;
	z-index: 0;
}

.members-bg__wrapper::before {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 1;
	background: inherit;
	opacity: .2;
	height: calc(100% + 1px);
}

.members-bg__mask::before {
	top: auto;
	bottom: 0;
	height: 80px;
	opacity: 1;
	background: linear-gradient(to top, rgba(0, 0, 0, .4), transparent);
}

.members__bg-grad {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 1;
	height: calc(100% + 1px);
}

.members__item {
	position: absolute;
	left: 20px;
	bottom: 10px;
	right: 20px;
	display: flex;
	margin: auto;
	z-index: 2;
	justify-content: space-between;
	align-items: center;
}

.issue__date {
	color: #FFFFFF;
	font-size: 12px;
	z-index: 2;
}

.issue__number {
	color: #FFFFFF;
	font-weight: bold;
}

.issue-owner {
	position: absolute;
	top: -10px;
	right: 20px;
	z-index: 4;
	padding: 4px;
	background: rgba(255, 255, 255, 0.5);
	border-radius: 50%;
}

.issue-img__wrapper {
	padding-top: 60px;
	padding-right: 60px;
	border-radius: 50%;
}

.issue__gender {
	position: absolute;
	right: 0;
	bottom: 4px;
	width: 24px;
	height: 24px;
	padding: 4px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.7);
}

.issue__gender::before {
	font-size: 16px;
	line-height: 1;
	display: block;
}

.expired-label {
	height: 94px;
	background: #E04136;
}

.expired-text {
	padding: 6px 0 0;
	color: #FFF;
	font-size: 18px;
	font-weight: bold;
	text-align: center;
}

.expired-button {
	display: inline-block;
	float: right;
	width: 100px;
	padding: 4px 12px;
	background: linear-gradient(90deg, #FF5F6D 0%, #FFC371 100%);
	border-radius: 15px;
	font-size: 12px;
	color: #FFF;
}

.members__profile {
	position: relative;
	padding: 20px;
}

.members__name {
	display: -webkit-box;
	margin-bottom: 34px;
	padding-right: 76px;
	font-size: 16px;
	font-weight: bold;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
	line-height: 1.4;
}

.members__btn {
	display: block;
	margin: 0 -20px -20px;
	padding: 1.15em .8em;
	border-top: 1px solid;
	border-color: var(--alpha-text-color);
	text-align: center;
	font-size: 14px;
}

.members__txt {
	display: -webkit-box;
	max-height: 67.2px;
	margin: 20px 0;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	overflow: hidden;
	line-height: 1.4;
}

.introduce__item {
	display: table;
	width: 100%;
	margin-bottom: 8px;
}

.introduce__que{
	display: table-cell;
	width: 30%;
	min-width: 4.12em;
	font-size: 16px;
}

.introduce__ans {
	display: table-cell;
	font-weight: bold;
	text-align: right;
	padding-left: 16px;
}

.local {
	list-style: none;
	margin: 40px 0 24px;
}

.enroll + .local {
	margin-top: 24px;
}

.local__link {
	display: block;
	position: relative;
	padding: 24px 24px 24px 60px;
	vertical-align: middle;
	line-height: 1.3;
	-webkit-font-smoothing: antialiased;
}

.local__link::before {
	display: block;
	position: absolute;
	top: 0;
	left: 24px;
	bottom: 0;
	width: 24px;
	height: 24px;
	margin: auto 0;
	font-family: 'icon';
	font-size: 24px;
	line-height: 1;
	-webkit-font-smoothing: antialiased;
}

.local__link_coin::before {
	content: "\e961";
}

.local__link_collection::before {
	content: "\e962";
}

.select-members,.select-country {
	display: none;
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	width: calc(100% - 48px);
	padding: 24px;
	border-radius: 8px;
	z-index: 999;
}

.select-members__mask,
.select-country__mask {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #000;
	opacity: .4;
	z-index: 998;
}

.select-members__close,
.select-country__close {
	position: absolute;
	top: -32px;
	right: 0;
	color: #FFFFFF;
	font-size: 24px;
	cursor: pointer;
}

.select-members__headline,
.select-country__headline {
	margin-bottom: 12px;
	text-align: center;
}

.select-members__notice {
	display: block;
	text-align: center;
	font-size: 12px;
}

.select-members__notice::before {
	content: "※";
	vertical-align: middle;
}

.select-members__list,
.select-country__list {
	height: calc(100vh - 240px);
	overflow: auto;
	list-style: none;
}

.select-members__item,
.select-country__item {
	margin: 24px 0;
}

.select-members__label,
.select-country__label {
	position: relative;
	display: flex;
	align-items: center;
	cursor: pointer;
}

.select-members__img-wrapper {
	position: relative;
	display: block;
	width: 64px;
	padding-top: 64px;
	border-radius: 50%;
	overflow: hidden;
}

.select-members__name {
	display: block;
	flex: 1;
	padding: 0 40px 0 16px;
	white-space: nowrap;
	text-overflow:ellipsis;
	overflow: hidden;
	font-weight: bold;
}

.select-members__name::after {
	content: "\e90e";
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	font-family: 'icon' !important;
	font-weight: normal;
	font-size: 28px;
	color: #53D853;
	line-height: 1;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	opacity: 0;
	transition: .1s ease;
}

.select-members__check {
	display: none;
}

.select-members__check:checked ~ .select-members__name::after {
	opacity: 1;
}



/*************************************
**************************************
				settings
**************************************
*************************************/
.login {
	color: #FFFFFF;
}

.login::after {
	content: "";
	display: block;
	position: fixed;
	top: 0;
	z-index: -1;
	width: 100%;
	height: 100%;
	background: rgb(255,95,109);
	background: -webkit-linear-gradient(135deg, rgba(255,95,109,1) 0%, rgba(255,195,113,1) 100%);
	background: linear-gradient(135deg, rgba(255,95,109,1) 0%, rgba(255,195,113,1) 100%);
}

.login__container {
	width: calc(100% - 48px);
	max-width: 400px;
	margin: 0 auto;
}

.login__btn {
	display: block;
	width: 100%;
	max-width: 300px;
	padding: 10px;
	margin: 16px auto;
	border: none;
	border-radius: 4px;
	background: #FFFFFF;
	font-size: 18px;
	font-weight: bold;
	letter-spacing: .1em;
	text-indent: .1em;
	opacity: 1;
}

.login__txt {
	margin-top: 64px;
	padding-bottom: 24px;
	font-size: 14px;
	text-align: center;
}

.login .header-bar__icon {
	display: block;
}

.settings__inner {
	padding: 24px;
}

.settings__card {
	padding: 20px;
	margin-bottom: 24px;
}

.settings__title {
	margin-bottom: 12px;
	font-weight: bold;
	text-align: left;
}

.settings__title_sub {
	display: block;
	margin: -4px 0 12px;
	font-size: 14px;
	font-weight: normal;
}

.settings__txt {
	font-size: 14px;
}

.settings__list {
	list-style: none;
}

.settings__item {
	position: relative;
}

.settings__item button {
	background: none;
	border: none;
	text-align: left;
}

.settings__announce {
	position: relative;
	margin-top: 4px;
	padding-left: 20px;
	font-size: 13px;
}

.settings__announce a {
	text-decoration: underline;
}

.settings__announce::before {
	content: "\e91a";
	font-family: "icon";
	position:absolute;
	left:0;
	top:0;
	font-size: 16px;
	line-height: 1;
	-webkit-font-smoothing: antialiased;
}

.settings__label {
	display: block;
	padding: 16px 0;
	line-height: 1.6;
}

.settings__label_next {
	display: block;
	width: 100%;
	padding-right: 24px;
}

.settings__label_next::after {
	content: "\e903";
	font-family: 'icon';
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	margin: auto auto auto 0;
	width: 16px;
	height: 16px;
	line-height: 1;
	color: var(--light-text-color);
	font-size: 16px;
	font-weight: normal;
	-webkit-font-smoothing: antialiased;
}

.settings__sub-label {
	display: block;
	margin: 8px 0 0;
	font-size: 14px;
	font-weight: normal;
}

.form-settings__item {
	padding-right: 66px;
}

.form__toggle {
	position: absolute;
	z-index: 5;
	top: 0;
	right: 0;
	bottom: 0;
	height: 30px;
	margin: auto 0;
	cursor: pointer;
}

.toggle__switch {
	display: none;
}

.toggle {
	position: relative;
	display: block;
	width: 50px;
	height: 30px;
	border-radius: 50px;
	background: #F2F2F2;
	font-size: 12px;
	color: #17BF63;
	vertical-align: middle;
}

.toggle__item {
	position: absolute;
	top: 0px;
	bottom: 0;
	left: 3px;
	display: block;
	width: 26px;
	height: 26px;
	margin: auto 0;
	background: #FFF;
	border-radius: 13px;
	box-shadow: 0px 4px 20px 6px rgba(0,0,0,0.3);
	transition: 0.2s ease-in 0s;
}

.toggle__switch:checked ~ .toggle__item {
	left: 20px;
}

.hold .settings__txt {
	text-align: left;
} 

.hold .settings__txt:first-of-type {
	margin-top: 24px;
}

.hold__name {
	margin-bottom: 8px;
	font-size: 14px;
	font-weight: normal;
	text-align: left;
}

.hold__count {
	display: block;
	margin-bottom: 16px;
	font-size: 24px;
	font-weight: bold;
	line-height: 1;
}

.charges__count .hold__count {
	display: inline-block;
	margin-bottom: 6px;
	width: calc(100% - 100px);
	text-align: left;
}

.hold__count::before {
	font-family: 'icon';
	display: inline-block;
	margin-right: 8px;
	line-height: 24px;
	font-size: 18px;
	font-weight: normal;
	color: #00BC89;
	vertical-align: bottom;
	-webkit-font-smoothing: antialiased;
}

.hold__count_point::before {
	content: "\e935";
	color: #00BC89;
}

.hold__count_coin::before {
	content: "\e910";
	color: #F5CB00;
}

.purchase {
	position: relative;
	overflow: hidden;
}

.purchase__list {
	text-align: left;
	margin: 24px 0;
}

.purchase__item {
	display: table;
	width: 100%;
	height: 80px;
	border-bottom: 1px solid;
	border-color: var(--alpha-text-color);
}

.purchase__label {
	display: table-cell;
	font-size: 18px;
	font-weight: bold;
	line-height: 1;
	vertical-align: middle;
}

.purchase__label::before {
	font-family: 'icon';
	display: inline-block;
	margin-right: 8px;
	font-size: 16px;
	font-weight: normal;
	vertical-align: bottom;
	-webkit-font-smoothing: antialiased;
}

.purchase__label_point::before {
	content: "\e935";
	color: #00BC89;
}

.purchase__label_coin::before {
	content: "\e910";
	color: #F5CB00;
}

.purchase-btn__wrapper {
	position: relative;
	display: table-cell;
	width: 100px;
	text-align: center;
	vertical-align: middle;
}

.purchase__tip {
	position: absolute;
	display: block;
	top: -20px;
	width: 100%;
	font-size: 12px;
}

.purchase__btn {
	display: block;
	width: 100%;
	padding: .5em;
	border: 1px solid;
	border-radius: 1em;
	background: transparent;
	font-size: 14px;
	line-height: 1;
}

.purchase__btn_point,
.purchase__btn_coin {
	color: #343434;
	border: none;
}

.purchase__btn_point {
	background: #00BC89;
}

.purchase__btn_coin {
	background: #F5CB00;
}

.purchase__label-addition {
	margin: 6px 8px 0 24px;
	font-weight: normal;
	font-size: 12px;
	line-height: 1.2;
}

.purchase__label-value {
	font-weight: bold;
}

.purchase__link {
	display: block;
	margin-bottom: 16px;
	font-size: 14px;
	text-decoration: underline;
}

.record__item {
	padding: 0 0 16px;
	margin-bottom: 16px;
	border-bottom: 1px solid;
	border-color: var(--alpha-text-color);
	list-style: none;
}

.record__date {
	font-size: 14px;
	margin-bottom: 8px;
}

.record__title {
	margin-bottom: 4px;
}

.record__text {
	font-size: 14px;
}
.record__count {
	margin-left: 8px;
	font-weight: bold;
}

.payment-select__wrapper {
	margin: 24px 24px 0;
	padding: 24px;
	border-radius: 6px;
}

.payment-select__title {
	margin: 0 0 16px;
	text-align: center;
}

.payment-plan__wrapper {
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: 500px;
	margin: 0 auto;
}

.payment-plan__detail {
	font-weight: bold;
	text-align: right;
}

.payment-plan__monthly {
	display: block;
	font-size: 14px;
	font-weight: normal;
}

.payment-select__link-wrapper {
	margin: 8px 24px 0;
	font-size: 12px;
	text-align: right;
}

.payment-select__link {
	padding: 0 4px;
	text-decoration: underline;
}

.payment {
	margin-bottom: 40px;
}

.payment__title {
	margin: 8px 0 16px;
	font-size: 18px;
	text-align: center;
}

.payment__title-main {
	margin: 24px 0 16px;
}

.payment__item {
	padding: 16px 0;
	text-align: center;
	list-style: none;
}

.payment__img {
	display: inline-block;
	height: 20px;
}

.payment-img__soft-bank .payment__img {
	margin: 4px auto 0;
}

.payment-img__wrapper_au .payment__img,
.payment-img__wrapper_docomo .payment__img,
.payment-img__soft-bank {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
}

.payment-img__wrapper_docomo .payment__img {
	height: 30px;
}

.payment-img__wrapper_au .payment__img {
	height: 25px;
}

.payment-img__soft-bank {
	width: 100%;
}


.payment_credit .payment__img {
	display: block;
	margin: 4px auto;
}

.payment__txt {
	margin-top: 8px;
}

.payment_sub-img__wrapper {
	max-width: 200px;
	margin: 0 auto;
	background-color: rgba(255, 255, 255, 0.7);
}
	
.payment_sub-img {
	width: 100%;
	max-width: 320px;
	margin: 8px auto 0;
	padding: 8px;
}

.payment-img__wrapper {
	position: relative;
	display: block;
	max-width: 400px;
	height: 87px;
	background: #FFFFFF;
	margin: 0 auto;
	padding: 16px;
	color: #343434;
	border: 1px solid;
	border-color: var(--alpha-text-color);
	border-radius: 4px;
}

/*.payment_career .payment-img__wrapper {
	padding: 27px 16px
}*/

.payment__inner {
	display: block;
}

.payment__link {
	font-size: 14px;
	text-decoration: underline;
}

.payment__link.pc{
	display: none;
}

.payment-page__wrapper .subscription__notice-text {
	max-width: 824px;
	margin: 0 auto;
	padding: 0 24px 40px;
}

/*************************************
**************************************
		subscription-period
**************************************
*************************************/

.rate-plan .subscription__notice-text {
	max-width: none;
}

.rate-plan__list {
	max-width: 480px;
	margin: 0 auto;
	padding: 0 0 24px;
	list-style: none;
}

.rate-plan__item {
	position: relative;
	margin: 32px 0 0;
}

.plan-button {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 12px 32px 12px 24px;
	border-radius: 40px;
	box-shadow: 0px 0px 6px 0px rgba(0,0,0,0.3);
}

.plan-button__inner-detail {
	display: flex;
}

.plan-tag {
	position: absolute;
	top: -5px;
	left: 0;
	z-index: 2;
	width: 62px;
	height: 62px;
	transform: rotate(-20deg);
}

.plan-tag__icon {
	position: absolute;
}

.icon_jagged:before {
	color: var(--contents-color);
	font-size: 62px;
}

.icon_jagged_border:before {
	position: absolute;
	top: 2px;
	left: 2px;
	font-size: 58px;
}

.plan-tag__text {
	position: absolute;
	top: 14px;
	right: 13px;
	font-size: 15px;
	font-weight: bold;
	text-align: center;
	line-height: 1.2;
}

.plan-manth__wrapper {
	position: relative;
}

.plan-catch {
	padding: 0 0 0 24px;
	font-weight: bold;
}

.plan-button__inner-rate {
	font-size: 24px;
	text-align: right;
	line-height: 1.3;
	white-space: nowrap;
}

.month__text {
	font-size: 28px;
}

.monthly-rate {
	display: block;
	font-size: 14px;
}

.plan-tag ~ .plan-catch {
	padding: 0 0 0 68px;
}

.plan-tag ~ .plan-button {
	padding: 12px 32px 12px 68px;
}

.plan-button__popular {
	color: #FFF;
}

.rate-plan__text-wrapper {
	text-align: center;
}

.rate-plan__text-link {
	position: relative;
	display: inline-block;
}

.rate-plan__text {
	font-weight: bold;
	text-decoration: underline;
}

/*************************************
**************************************
			rate-plan__change
**************************************
*************************************/

.rate-plan__change .subscription__title {
	font-size: 16px;
	font-weight: normal;
}
.rate-plan__change .headline__wrapper {
	text-align: center;
	padding: 16px 0 24px;
}

.rate-plan__change-title {
	font-size: 20px;
	font-weight: bold;
	text-align: center;
}

.headline__accessory_premium {
	background: linear-gradient(90deg, #B48400 0%, #F7D30E 100%);
}

.plan-select +.rate-plan__text {
	display: inline-block;
	padding: 0 34px 0 0;
}

.plan-select {
	position: absolute;
	right: 6px;
	width: 20px;
	height: 20px;
	padding: 2px;
	background: #FFF;
	border: 1px solid;
	border-color: var(--alpha-text-color);
	border-radius: 50%;
}

.plan-select::before {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	width: 14px;
	height: 14px;
	margin: auto;
	font-size: 14px;
	font-weight: bold;
}

.pointer-none {
	pointer-events: none;
}


/*************************************
**************************************
				top
**************************************
*************************************/

/*.site-top input[type="search"] {
	-webkit-appearance: searchfield;
}

.site-top input[type="search"]::-webkit-search-cancel-button {
	-webkit-appearance: searchfield-cancel-button;
}*/

.site-top .text-btn__wrapper-pc {
	display: none;
}

.site-top .text-btn__wrapper-sp {
	position: fixed;
	bottom: 0;
	width: 100%;
}

.site-top .text-btn__wrapper-sp .text-btn_login {
	display: block;
	padding: 24px 16px;
	background: rgba(255,255,255,.2);
	backdrop-filter: saturate(120%) blur(20px);
	-webkit-backdrop-filter: saturate(120%) blur(20px);
	color: #343434;
	font-weight: normal;
	text-decoration: none;
	text-align: center;
	overflow: hidden;
}

.site-top::before {
	content: "";
	display: block;
	position: fixed;
	top: 0;
	z-index: -1;
	width: 100%;
	height: 100%;
	background:rgba(255,255,255,.35);
}

.site-top::after {
	content: "";
	display: block;
	position: fixed;
	top: 0;
	z-index: -2;
	width: 100%;
	height: 100%;
	background-image: url("../images/fanmily-top_sp.jpg");
	background-repeat: no-repeat;
	background-size: cover;
}

.site-top__txt {
	color: #343434;
	font-weight: bold;
}

.site-top__wrapper {
	position: relative;
	height: 100vh;
}

.site-top__wrapper .logo__wrapper {
	padding: 80px 0 8px;
}

.site-top__wrapper .logo-mark {
	width: 64px;
	height: 64px;
}

.site-top__container {
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	width: 100%;
	max-width: 500px;
	padding: 0 24px;
	text-align: center;
}

.site-top__container .form__section {
	margin: 0 -16px 40px;
}

.site-top__container .form-input__wrapper {
	padding: 16px;
}

.site-top__container .form__input {
	height: auto;
	padding: 14px 50px 14px 16px;
	background: #FFF;
	border-radius: 30px;
	border: none;
	box-shadow: 0px 0px 10px 6px rgba(0,0,0,0.2);
}

.site-top__btn {
	position: absolute;
	top: 50%;
	right: 18px;
	transform: translateY(-50%);
	margin: 0;
	padding: 16px;
	background: none;
	border-radius: 24px;
	border: none;
	font-size: 16px;
	outline: none;
}

 .hidden-text {
	position: absolute;
	left: -9999px;
}

.hidden {
	display: none;
}

.site-top-info__container {
	margin: 40px auto 0;
}

.site-top-info__wrapper {
	display: flex;
	justify-content: center;
}

.site-top-info__btn {
	display: block;
	width: 116px;
	height: 36px;
	margin-right: 24px;
	background-color: var(--primary-color);
	color: #FFFFFF;
	font-size: 12px;
	border-radius: 3px;
	text-align: center;
	line-height: 36px;
}

.site-top-info__btn_mail::before {
	font-family: "icon";
	content: "\e91b";
	margin-right: 6px;
	font-size: 16px;
	vertical-align: bottom;
}

.site-top-info__btn_txt {
	font-size: 12px;
	color: #fff; 
	text-align: center;
	text-shadow: 1px 0px 3px #343434;
}


/*************************************
**************************************
				top-search
**************************************
*************************************/

.top-search .header-bar {
	background: rgba(255,255,255,.2);
	backdrop-filter: saturate(120%) blur(14px);
	-webkit-backdrop-filter: saturate(120%) blur(14px);
}

.top-search .search-item__inner {
	width: 100%;
	padding: 0 8px 0 16px;
}

.top-search .search__field {
	border-radius: 20px;
}

.top-search .search__button {
	padding: 0 16px;
	font-size: 16px;
}

.top-search .search__close {
	color: #343434;
}

.top-search__wrapper {
	padding: 56px 0 0;
}

.top-search__inner {
	list-style: none;
}

.top-search__item {
	position: relative;
	overflow: hidden;
}

.top-search__item::after {
	content: "";
	position: absolute;
	bottom: 0;
	display: block;
	width: 100%;
	height: 1px;
	border-bottom: 1px solid #282828;
}

.top-search__result {
	display: flex;
}

.result-img__wrrapper {
	position: relative;
	display: block;
	width: 50%;
	padding-top: 28.125%;
}

.result-img {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	width: 100%;
	height: 100%;
	font-family: 'object-fit: cover;';
	object-fit: cover;
}

.result-description__wrapper {
	position: relative;
	width: 50%;
	background: #343434;
	color: #FFF;
}

.result-description__wrapper::before {
	position: absolute;
	right: 0;
	content: "";
	display: block;
	width: 110%;
	height: 100%;
	transform:skewX(-20deg) scale(1);
	background: #343434;
}

.result-description {
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	width: 100%;
	padding: 0 10px;
	font-size: 14px;
	font-weight: bold;
	overflow: hidden;
	text-overflow: ellipsis;
}

.result-sub {
	display: block;
	margin: 4px 0 0;
	font-size: 13px;
	font-weight: normal;
}

.top-search__no-result {
	padding: 20px 16px;
	border-bottom: 1px solid;
	border-color: var(--alpha-text-color);
	color: #343434;
}

/*************************************
**************************************
				form
**************************************
*************************************/
.form {
	position: relative;
}

.form__section {
	margin-bottom: 40px;
}

.form-input__wrapper {
	position: relative;
	width: 100%;
	margin: 16px 0;
	padding: 16px 0;
	overflow: hidden;
}

.form-input__wrapper_column {
	display: flex;
}

.inline .form-input__wrapper {
	margin-top: 0;
	letter-spacing: normal;
}

.form__label {
	position: absolute;
	top: 0;
	font-size: 12px;
	opacity: .4;
}

.form__label_line {
	display: inline-block;
	top: 0;
	bottom: 0;
	left: auto;
	right: 99999px;
	height: 12px;
	margin: auto;
	line-height: 1;
	width: 16px;
	text-align: right;
}

.form__label_login {
	color: #FFFFFF;
}


.form__label_hide {
	left: 99999px;
}

.form__label_show {
	font-size: 14px;
}

.form__input {
	display: block;
	width: 100%;
	height: 40px;
	padding: 8px 0;
	background: transparent;
	border: none;
	border-radius: 0;
	cursor: text;
	font-size: 16px;
	border-bottom: 1px solid;
	border-color: var(--alpha-text-color);
}

.form__input_login {
	color: #FFFFFF;
	border-bottom: 1px solid #FFFFFF;
}

.form__input_inicon {
	padding-right: 32px;
}

.form__input_pr {
	border: none;
	resize: none;
	overflow: auto;
}

.form__input option {
	color: #343434;
}

.testArea {
	font-size: 16px;
	letter-spacing: .03em;
}

.select-color {
	cursor: pointer;
	}

.form__input_show {
	border: none;
}

.form__btn {
	display: block;
	position: relative;
	width: 100%;
	max-width: 300px;
	padding: 10px;
	margin: 32px auto 16px;
	border: none;
	border-radius: 4px;
	color: #FFFFFF;
	font-size: 18px;
	font-weight: bold;
	line-height: 1.5;
	letter-spacing: .1em;
	text-indent: .1em;
	text-align: center;
}

.form__caption {
	margin-bottom: 16px;
	font-weight: bold;
}

.form__txt {
	font-size: 14px;
	text-align: center;
}

.form__list {
	margin-bottom: 16px;
	list-style-position: outside;
	margin-left: 24px;
}

.form__txt-link {
	padding: 8px;
}

.form-link__wrapper {
	margin-bottom: 16px;
	text-align: center;
}

.form__announce {
	font-size: 12px;
	margin: 16px 0 24px;
	padding: 16px;
}

.form__icon {
	position: absolute;
	display: block;
	top: 0;
	bottom: 0;
	right: 0;
	width: 2em;
	height: 2em;
	z-index: 2;
	margin: auto;
	padding: .5em;
	cursor: pointer;
	font-size: 18px;
}

.form__headline {
	margin: 16px 0;
	text-align: center;
}

.form__numbers {
	display: flex;
	max-width: 300px;
	margin: 0 auto;
	padding-bottom: 24px;
	justify-content: space-around;
	align-items: center;
}

.form__input_error {
	border-color: #E04136!important;
}

.form__error {
	margin-top: 4px;
	color: #E04136;
	font-size: 12px;
}


.auth__number {
	display: block;
	width: 40px;
	padding: 16px 0;
	background: transparent;
	border: none;
	border-bottom: 1px solid;
	border-color: var(--alpha-text-color);
	border-radius: 0;
	font-size: 24px;
	font-weight: bold;
	text-align: center;
}

.text-btn__wrapper {
	margin-top: 16px;
	text-align: center;
}

.text-btn {
	padding: 8px 0;
	border: none;
	background: transparent;
	font-size: 14px;
	font-weight: bold;
	text-align: center;
	text-decoration: underline;
}

.text-btn_login {
	color: #FFFFFF;
}

.form__save-btn {
	position: fixed;
	top: 0;
	right: 0;
	z-index: 998;
	margin: 10px;
	font-size: 16px;
}

.form__label_select {
	top: 0;
	bottom: 0;
	height: 16px;
	margin: auto 0;
	font-size: 16px;
	line-height: 1;
}

.form__input_right {
	display: inline-block;
	text-align:right;
	vertical-align: baseline;
}

.selectTxt {
	height: 40px;
}

.selectObj {
	position: absolute;
	left: 0px;
	opacity: 0;
}

.form__img-group {
	position: relative;
	margin-top: 16px;
}

.form-img__wrapper {
	position: relative;
	height: 90px;
	width: 90px;
	border-radius: 50%;
	overflow: hidden;
	margin: 0 auto;
}

.form__img {
	border-radius: 50%;
}

.form__canvas,
.form__file {
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	width: 90px;
	height: 90px;
	margin: 0 auto;
	opacity: 0;
	z-index: 3;
	cursor: pointer;
}

.form__canvas {
	opacity: 1;
}

.form__file-label {
	display: none;
	
	cursor: pointer;
}

.form-img__icon{
	position: absolute;
	display: block;
	top: 60px;
	left: 0;
	right: 0;
	width: 2em;
	line-height: 2em;
	font-size: 16px;
	background: rgba(0,0,0,.5);
	text-align: center;
	border-radius: 50%;
	margin: 0 auto;
	color: #FFFFFF;
	transform: translate(28px, 0px);
	z-index: 3;
}

.form-img__icon::before {
	display: block;
	letter-spacing: normal;
}

.form__members-label,
.form__country-label {
	position: absolute;
	display: flex;
	top: -96px;
	left: 0;
	right: 0;
	width: calc(100% - 32px);
	max-width: 500px;
	margin: 12px auto;
	border-radius: 6px;
	align-items: center;
	cursor: default;
	box-shadow: 0px 0px 6px 0px rgba(0,0,0,0.2);
}

.form__members-img-wrapper {
	position: relative;
	display: block;
	width: 72px;
	padding-top: 72px;
	border-radius: 6px 0 0 6px;
	overflow: hidden;
}

.form__members-group {
	padding: 0 16px;
	flex: 1;
	overflow: hidden;
}

.form__members-sub {
	display: block;
	margin-bottom: 4px;
	font-size: 14px;
}

.form__members-name {
	display: block;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.form__members-btn {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	cursor: pointer;
}

.inline {
	display: flex;
}

.inline__wrapper {
	position: relative;
}

.inline .form-input__wrapper:nth-of-type(n+2) {
	margin-left: 16px;

}

.section__title {
	padding: 24px 0 8px;
}

.section__title_hide {
	position: absolute;
	left: 100%;
}

.section__txt {
	font-size: 14px;
	margin-bottom: 24px;
}

.form__read {
	margin-bottom:40px;
}

.form__read_center {
	text-align: center;
}

.label__icon:nth-child(2) {
	margin-left: 8px;
}

.label__icon::before {
	font-family: 'icon';
	width: 16px;
	height: 16px;
	line-height: 1;
	color: #00BC89;
	font-size: 16px;
	font-weight: normal;
	-webkit-font-smoothing: antialiased;
}

.label__icon_point::before {
	content: "\e935";
	color: #00BC89;
}

.label__icon_coin::before {
	content: "\e910";
	color: #F5CB00;
}

.backnumber__item {
	text-align: center;
	margin: 24px 0;
	font-weight: bold;
}

.backnumber__label {
	font-weight: bold;
}

.backnumber__count {
	margin-top: 8px;
	font-size: 24px;
}

.backnumber__count span {
	font-size: 14px
}

.backnumber__caption {
	margin-bottom: 16px;
	text-align: center;
	font-size: 12px;
}

.backnumber__caption_left {
	text-align: left;
	margin-bottom: 8px;
}

.backnumber__table {
	display: flex;
	padding: 20px;
	justify-content: space-between;
	align-items: center;
	border-radius: 6px;
}

.backnumber-btn__wrapper {
	text-align: center;
}

/*************************************
**************************************
			edit-profile
**************************************
*************************************/

.edit-profile .form__label,
.form-input__wrapper_outline .form__label {
	position: static;
	margin-bottom: 8px;
	font-size: 16px;
}

.edit-profile  .form__input,
.form-input__wrapper_outline .form__input {
	height: 56px;
	padding: 16px;
	border: 1px solid var(--alpha-text-color);
	border-radius: 4px;
}

.edit-profile .form__input_pr {
	height: 88px !important;
}

.edit-profile .form__input_right {
	text-align: left;
}

.edit-profile .form__input_right::before {
	font-family: 'icon' !important;
	content:  "\e903";
	position: absolute;
	right: 12px;
	transform: rotate(90deg);
}

.edit-profile .form__label_line {
	display: none;
}

/*************************************
**************************************
				info
**************************************
*************************************/
.info_app {
	margin-top: -56px;
}

.subscription_app {
	margin-top: -56px;
	padding-bottom: 180px;
}

.info__read {
	width: calc(100% - 48px);
	margin: 24px auto 40px;
	padding: 16px;
	font-size: 14px;
}

.info__inner {
	padding: 24px 24px 8px 24px;
}

.info__cell {
	 margin-bottom: 40px;
}

.info__cell:last-child {
	margin-bottom: 0;
}

.info__title {
	padding-bottom: 8px;
	font-size: 18px;
	font-weight: bold;
}

.info__text {
	margin: 16px 0 24px;
	padding-bottom: 8px;
}

.info__list {
	list-style-position: outside;
	margin: 16px 0 16px 24px;
}

.info__list_disc {
	list-style: disc;
}

.info__list_number {
	position: relative;
	margin-left: 0;
	padding-left: 32px;
	list-style: none;
	counter-reset: number;
}

.info__list_number > li::before {
	counter-increment: number;
	content: "(" counter(number) ") ";
	position: absolute;
	left: 0;
}

.info__item {
	margin-bottom: 8px;
}

.info__img-wrapper {
	margin: 24px 0;
}

.info__item_cell {
	padding: 8px;
}

.info__item_inside {
	padding-left: 24px;
}

.info__item_widely {
	margin-bottom: 16px;
}

.info__img {
	width: 100%;
	max-width: 300px;
	margin: 0 auto;
	padding: 24px 24px 24px 0
}

.info__sign {
	margin-right: 20px;
	text-align: right;
}

.info__btn {
	display: block;
	max-width: 327px;
	margin: 24px 0;
	padding: 8px;
	color: #FFFFFF;
	text-align: center;
	border-radius: 4px;	
}

.info__link {
	text-decoration: underline;
}

.info__caption {
	font-weight: bold;
	margin-bottom: 8px;
}

.info__moderate {
	margin-top: 16px;
	font-size: 14px;
}

.info__inner-title {
	margin-bottom: 8px;
	font-weight: bold;
}

.info__inner-text {
	margin-bottom: 24px;
}

.info__page-link {
	margin-top: -64px;
	padding-top: 64px;
}

.info__item_title {
	padding-right: 16px;
	font-weight: bold;
}

.info__item table,
.info__item th,
.info__item td {
	padding: 4px;
}

.sign__inner {
	margin: 40px 0;
}

.sign__title {
	margin-bottom: 8px;
	font-weight: bold;
}

.error {
	overflow: hidden;
}

.error__inner {
	position: absolute;
	top: 50%;
	left: 50%;
	width: calc(100% - 48px);
	max-width: 400px;
	margin: 0 auto;
	transform: translate(-50%, -50%);
}

.error__detail {
	text-align: center;
	margin-bottom: 40px;
	padding: 40px;
	border-radius: 6px;
}

.error__title {
	font-size: 64px;
	line-height: 1;
	letter-spacing: .05em;
	font-weight: bold;
}

.error__sub-title {
	margin-bottom: 16px;
}

.error__txt {
	text-align: center;
}

/*************************************
**************************************
				support
**************************************
*************************************/

.support .section__title {
	padding: 0 0 24px;
	font-weight: bold;
}

/*************************************
**************************************
				maintenance
**************************************
*************************************/

.maintenance {
	background: #343434;
}

.maintenance__detail {
	padding: 80px 16px;
	background: #121413;
}

.maintenance__title {
	padding: 0 0 16px;
	color: #FF726E;
	font-size: 22px;
}

.maintenance__txt {
	font-size: 14px;
	color: #BFBFBF;
}

.maintenance__txt_vertical {
	display: inline-block;
	transform: rotate(90deg);
}

.maintenance__time {
	margin: 32px -16px 0;
	padding: 8px;
	background: #737373;
}

/*************************************
**************************************
				kickback
**************************************
*************************************/

.kickback__img {
	margin: 0 auto 16px;
}

/*************************************
**************************************
				pager
**************************************
*************************************/

.pager {
	position: relative;
	padding: 24px 0;
	z-index: 1;
}

.pager__list {
	margin: 0;
	padding: 0;
	font-size: 0;
	text-align: center;
}

.pager__item {
	display: none;
	position: relative;
	width: 50px;
	height: 50px;
	margin: 0 4px;
	padding: 0;
	border-radius: 4px;
	font-size: 16px;
	text-align: center;
	overflow: hidden;
}

.pager_small .pager__item {
	width: 32px;
	height: 32px;
}

.pre,
.next {
	display: inline-block;
	width: 40%;
	height: 50px;
	text-align: center;
}

.pager__link {
	display: table;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	color: #fff;
	text-decoration: none;
	text-align: center;
	vertical-align: middle;
}

.pager__number {
	display: table-cell;
	vertical-align: middle;
}

/*************************************
**************************************
				icon_feed
**************************************
*************************************/

.logo__wrapper {
	padding: 40px 0;
}

.logo {
	width: 100%;
	max-width: 200px;
	margin: 0 auto;
}

.login-button__inner {
	padding: 0;
}

.login__link {
	max-width: none;
	padding: 31px;
	border-radius: 0;
	line-height: 1;
}

/*************************************
**************************************
			subscription
**************************************
*************************************/

.subscription__section {
	position: relative;
}

.subscription__section .headline__wrapper {
	display: block;	
}

.subscription__inner {
	margin-bottom: 24px;
	padding: 4px 0 20px;
}

.subscription__headline {
	font-size: 24px;
	text-align: center;
	padding: 24px 24px 0;
}

.subscription__title {
	font-size: 20px;
	text-align: center;
	margin-bottom: 24px;
}

.subscription__notice {
	margin: 0 0 40px;
}

.subscription-change__wrapper .subscription__notice {
	padding: 24px;
	background: #FFF;
	border: 1px solid;
	border-color: var(--alpha-text-color);
	border-radius: 6px;
}

.subscription-change__wrapper .subscription__notice-text {
	max-width: none;
	margin: 0;
	color: #D61414;
}

.subscription__notice-title {
	margin: 24px 0 16px;
	font-size: 16px;
}

.subscription__notice-text {
	/*max-width: 400px;*/
	margin: 0 auto 16px;
	font-size: 14px;
}

.subscription__notice-btn {
	font-size: 16px;
	text-align: center;
}

.subscription-select__title {
	margin: 24px 0 16px;
}

.subscription-select__matter {
	padding: 0 0 16px;
}

.subscription-btn__wrapper {
	margin: 24px 0 0;
}

.subscription-btn__inner {
	margin: 0 0 24px;
}

.subscription-btn__inner:last-of-type {
	margin: 0;
}

.subscription-btn {
	margin: 0 auto;
	padding: 16px 4px;
	font-size: 16px;
	text-align: center;
}

.subscription-btn__description {
	max-width: 400px;
	margin: 8px auto 0;
	font-size: 14px;
}

.subscription__list {
	list-style: none;
	counter-reset: number;
}

.subscription__item {
	position: relative;
	width: 100%;
	margin-bottom: 12px;
	padding: 16px;
	border-radius: 6px;
}

.subscription-label__inner {
	display: block;
	padding: 16px;
}

.subscription__caption {
	text-align: left;
}

.subscription__caption::before {
	font-size: 24px;
	vertical-align: middle;
}

.subscription__caption-title {
	margin: 0 0 0 4px;
	font-family: 'Hiragino Kaku Gothic ProN', 'Meiryo', 'Osaka', 'MS PGothic', 'YuGothic', 'Arial','Helvetica Neue','Helvetica',sans-serif;
	font-weight: bold;
	vertical-align: middle;
}

.subscription__txt {
	margin-top: 8px;
	font-size: 14px;
}

.subscription__sub-txt {
	margin-top: 8px;
	font-size: 12px;
	text-align: right;
}

.subscription__read {
	margin-bottom: 24px;
}

.subscription__read:last-child {
	margin-bottom: 0;
}

.subscription__img {
	width: 100%;
	margin-top: 24px;
}

.subscription__bg {
	padding-top: 56.25%;
	z-index: 0;
}

.subscription__bg::before {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 1;
	background: inherit;
	opacity: .2;
}

.subscription__label {
	position: relative;
	display: table;
	width: 100%;
	height: 100px;
	margin-bottom: 8px;
	border-radius: 6px;
	-webkit-font-smoothing: auto;
}

.subscription__group {
	padding: 40px 24px;
}

.subscription__group .headline__wrapper {
	padding: 0;
	text-align: left;
}

.subscription__group_island .headline__wrapper {
	text-align: center;
}

.subscription__wrapper {
	padding: 0;
	margin: 24px auto 0;
}

.subscription-form__title {
	margin: 0 0 16px;
	font-size: 24px;
	font-weight: bold;
	text-align: center;
}

.subscription-form__section .text-btn__wrapper {
	margin: 40px 0;
}


.diamond__wrapper {
	position: absolute;
	right: 0;
	left: 0;
	margin: 0 auto;
	padding: 16px 0;
	height: 76px;
	overflow: hidden;
	text-align: center;
	transform: rotate(180deg);
}

.diamond {
	content: "";
	display: inline-block;
	width: 120px;
	height: 120px;
	background: inherit;
	transform: rotate(135deg) skew(calc((90deg - 80deg) / 2),calc((90deg - 80deg) / 2)); /* calc((90deg - 欲しい角度) / 2) */
}

#premium .headline__wrapper {
	margin: 40px auto 0;
	text-align: center;
}

.sample {
	max-width: 400px;
	margin: 24px auto 0;
	border: 1px solid rgba(255,255,255,.1);
	border-radius: 6px;
}

#morningcall .sample {
	margin: 48px auto 0;
}

.sample__header {
	display: flex;
	height: 56px;
	margin-bottom: 24px;
	padding: 0 16px;
	border-radius: 6px 4px 0 0;
	font-size: 24px;
	justify-content: space-between;
	align-items: center;
}


.sample .icon_heart_paint {
	color: #ED4956;
}

.sample__send {
	margin-top: 14px;
	padding: 8px 16px;
	border-radius: 0 0 4px 4px;
	color: #D3D3D3;
}

.sample__img {
	position: relative;
	width: 100%;
	z-index: 1;
	border-radius: 6px;
}

.sample .send__button {
	cursor: default;
}

.sample-img__wrapper {
	display: block;
	position: absolute;
	top: 0;
	width: 100%;
	height: 100%;
	padding-top: 100%;
	overflow: hidden;
	border-radius: 6px;
}

.sample-img__wrapper_1on1 {
	width: 88%;
	top: 5%;
	left: 0;
	right: 0;
	margin: auto;
}

.live-label {
	position: absolute;
	top: 64%;
	width: 80%;
	margin-left: 10px;
	z-index: 1;
	border-radius: 28px;
	align-items: center;
}

.live-label__bg {
	content: "";
	position: absolute;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: 0;
	border-radius: 28px;
	opacity: .9;
}

.live-label__img {
	position: relative;
	width: 100%;
	z-index: 1;
}

.device {
	border: none;
}

.device__card {
	position: relative;
	width: 80%;
	margin: 24px 0 0 auto;
	border-radius: 48px 48px 0 0;
	overflow: hidden;
}

.device__label {
	max-width: 320px;
	top: auto;
	bottom: 4%;
	width: 70%;
	margin-left: 0;
}

.device__label_top {
	bottom: 14%;
}

.davice-mail__img {
	display: none;
}

.table__wrapper {
	padding: 24px 16px;
	border-radius: 6px;
}

.table__title {
	font-size: 20px;
	font-weight: bold;
	text-align: center;
}

.table {
	display: flex;
	justify-content: center;
	padding: 10px 0;
	border-radius: 6px;
}

.table__item {
	display: block;
	width: 50%;
	text-align: center;
}

.table__item:last-child {
	border-bottom: none;
}

.table__que {
	font-size: 14px;
	margin: 0 0 16px 0;
}
.table__ans {
	font-size: 14px;
}

.table__ans-charge {
	margin: 0 0 0 8px;
	color: #B48400;
	font-size: 20px;
	font-weight: bold;
}

.table__bottom-group {
	position: relative;
	margin: 18px 0 0;
	padding: 32px 0 0;
	text-align: center;
	font-size: 14px;
}

.table__bottom-group::before,
.table__bottom-group::after {
	content: "";
	position: absolute;
	top: 0;
	width: 45%;
	border-bottom: 1px dotted #C7C7CC;
}

.table__bottom-group::before {
	left: 0;
}
.table__bottom-group::after {
	right: 0;
}

.table__btn-wrapper::before {
	content: " ";
	position: absolute;
	top: -5px;
	right: 0;
	left: 0;
	margin: 0 auto;
	display: block;
	width: 0;
	height: 0;
	background: inherit;
	border: 8px solid transparent;
	border-top: 10px solid;
}

.table__btn-wrapper {
	margin: 0 0 16px;
	font-size: 20px;
	font-weight: bold;
}

.table__btn {
	display: block;
	width: 100%;
	max-width: 400px;
	margin: 0 auto 40px;
	padding: 16px;
	color: #FFFFFF;
	font-size: 20px;
	font-weight: bold;
	border-radius: 44px;
	text-align: center;
}

.headline__accessory {
	display: inline-block;
	width: 64px;
	height: 2px;
}

/*monthly delete*/

.monthly__wrapper {
	position: relative;
	margin: 18px 0 0;
	padding: 32px 0 0;
	text-align: center;
	font-size: 14px;
}

.monthly__wrapper::before,
.monthly__wrapper::after {
	content: "";
	position: absolute;
	top: 0;
	width: 45%;
	border-bottom: 1px dotted;
	border-color: var(--alpha-text-color);
}

.monthly__wrapper::before {
	left: 0;
}
.monthly__wrapper::after {
	right: 0;
}

.monthly__text::before {
	content: " ";
	position: absolute;
	top: -5px;
	right: 0;
	left: 0;
	margin: 0 auto;
	display: block;
	width: 0;
	height: 0;
	background: inherit;
	border: 8px solid transparent;
	border-top: 10px solid;
}

.monthly__text {
	margin: 0 0 16px;
	font-size: 20px;
	font-weight: bold;
}

.monthly__coution {
	display: inline-block;
	padding: 0 8px;
}

.vandle__text {
	padding: 0 10px;
	text-align: center;
}

.vandle__btn {
	padding: 0px;
}

.vandle__btn-img {
	display: block;
	width: 100%;
	border-radius: 4px;
	box-shadow: 0px 4px 20px 6px rgba(0,0,0,0.3);
}

.subscription-info__title {
	text-align: center;
	font-weight: bold;
}

.subscription-info__item {
	padding: 16px;
}

.subscription-info__item:nth-of-type(1) {
	margin-bottom: 16px;
}

.subscription-form__section {
	display: none;
}

.proposal-stay__text {
	display: none;
}

.proposal-stay__group .proposal__btn {
	border-radius: 30px;
}

/*lottery*/


.scratch-card__inner{
	max-width: 400px;
	padding: 16px;
}

.scratch-card__item {
	padding: 3em 24px;
	border-radius: 6px 6px 0 0;
	background: #FFF;
	text-align: center;
}

.scratch-card__title {
	display: -webkit-box;
	max-height: 59.8px;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
	color: #343434;
	font-size: 24px;
	line-height: 1.3;
}

.scratch-card__date {
	display: block;
	padding: 10px 0 24px;
	color: #777;
	font-size: 14px;
	line-height: 1;
}

.scratch-card__img-wrapper {
	display: block;
	position: relative;
	padding-top: 100%;
	width: 100%;
	overflow: hidden;
	border-radius: 16px;
	box-shadow: 0px 0px 10px 4px rgba(0,0,0,0.1);
	cursor: pointer;
}

.scratch-card__footer {
	min-height: 16px;
	margin-top: -1px;
	background: url(https://resource.fanmily.jp/service/scratch/image/scratch_edge.svg) repeat-x;
}

/*morning call*/

.morning-call__img {
	position: absolute;
	z-index: 3;
}

.morning-call__img_first {
	top: -30px;
	right: -30px;
}

.morning-call__img_second {
	bottom: 30px;
	left: -30px;
}

#morningcall .mail__wrapper {
	position: relative;
}

/*************************************
**************************************
				viewer
**************************************
*************************************/

.viewer {
	background: #000;
}

.viewer__wrapper {
	position: fixed;
	width: 100%;
}

.viewer__header {
	display: flex;
	align-items: center;
	justify-content: center;
	position: absolute;
	z-index: 3;
	transform: translateY(0);
	width: 100%;
	height: 64px;
	transition: all .4s ease;
	background: rgba(0, 0, 0, .5);
	color: #FFF;
}

.viewer__back {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 24px;
	height: 24px;
	margin: auto 0;
	color: #FFF;
	font-size: 24px;
}

.viewer__number {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	font-size: 16px;
}

.viewer__img {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	display: block;
	max-width: 100%;
	max-height: 100%;
	width: auto;
	height: auto;
	margin: auto;
}

.open,
.viewer__header_close {
	cursor: pointer;
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 2;
	transition: all .4s ease;
}

.viewer__header_close {
	pointer-events: none;
}

#barTrigger {
	display: none;
}

#barTrigger:checked ~ .viewer__header_close {
	pointer-events: auto;
}

#barTrigger:checked ~ .viewer__header {
	transform: translateY(-100%);
}

.viewer-video__item {
	position: relative;
	height: 100%;
	overflow: hidden;
}

.video-jsx.vjs-tech {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	max-width: 100%;
	max-height: 100%;
}

.video-js {
	position: absolute;
	top: 0;
	left: 0;
	width: 100% !important;
	height: 100% !important;
}

.vjs-big-play-centered .vjs-big-play-button {
	z-index: 3;
}

.vjs-has-started.vjs-user-inactive.vjs-playing .vjs-control-bar,
.vjs-has-started .vjs-control-bar {
	opacity: 1;
	z-index: 3;
}

.vjs-has-started .vjs-control-bar {
	height: 64px;
	background: rgba(0, 0, 0, .5);
}

.vjs-button > .vjs-icon-placeholder:before {
	height: 24px;
	font-size: 24px;
	top: 0;
	bottom: 0;
	margin: auto 0;
	line-height: 1;
}

.video-js .vjs-time-control {
	line-height: 6.5em;
}

.video-js .vjs-volume-bar {
	margin: 3em .45em;
}

.video-modal {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 9999;
}

.video-modal__mask {
	position: absolute;
	width: 100%;
	height: 100%;
	background: #000;
	opacity: .4;
}

.video-modal__container {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	width: 100%;
	max-width: 800px;
	margin: auto;
}

.video-modal__inner {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	padding-top: 56.25%;
	transform: translate(-50%, -50%);
	
}

.video-modal__close {
	position: absolute;
	top: -50px;
	right: 0;
	font-size: 40px;
	color: #FFF;
}

.video-modal video,
.video-modal iframe {
	width: 100%;
}

.video-modal iframe {
	object-fit: fill;
}

.subscription__detail .app:before {
	content:"App限定";
	display: block;
	width:-moz-fit-content; /* Firefox */
	width:fit-content; /* other browsers */
	color: #fff;
	line-height: 1;
	margin-bottom: 10px;
	border-radius: 100px;
	font-size: 12px;
	padding: 4px 10px;
	background: var(--primary-color);
}

/*************************************
**************************************
			lottery
**************************************
*************************************/
.sold-out::before,
.coming-soon::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 1;
}

.sold-out::before {
	background: rgba(0, 0, 0, .5);
}

.sold-out::after {
	content: "\e93e";
	font-family: "icon";
	display: block;
	position: absolute;
	top: 50%;
	right: 80px;
	transform: translateY(-50%);
	z-index: 2;
	text-align: center;
	font-size: 72px;
	line-height: 1;
	color: #FFF;
	-webkit-font-smoothing: antialiased;
}

.coming-soon::before {
	background: rgba(255, 255, 255, .5);
}

.lottery__head {
    text-align: center;
    margin-top: -56px;
    padding-top: 56px;
}

.lottery__img-container {
    position: relative;
    padding-top: 40%;
    overflow: hidden;
}

.lottery__img-container .lottery__bg-grad {
	position: absolute;
	width: 100%;
	height: 20%;
	top: 0;
	left: 0;
	transform: rotate(180deg);
}

.lottery__detail-container {
    flex: 1;
    width: 100%;
    padding: 24px;
}

.lottery__headline {
    padding: 24px 24px 0;
    margin-bottom: .6em;
    font-size: 18px;
}

.lottery__headline_top {
    display: block;
}

.lottery__headline_inner {
    display: none;
}

.lottery__definition dt {
	margin: 4px 8px 4px 0;
}

.lottery__definition dd {
	font-weight: bold;
}

.lottery__detail-container small {
	display: block;
	padding: 0 8px;
	font-size: 12px;
	font-weight: normal;
	opacity: .6;
}

.lottery__nav-link {
	position: fixed;
	top: 16px;
	right: 16px;
	z-index: 999;
	color: var(--navigation-tint-color);
}

.lottery__nav-link_collection::before {
	font-family: 'icon' !important;
	content: "\e94d";
	font-size: 24px;
}

.lottery__nav-link_return {
    right: auto;
    left: 16px;
}

.lottery__nav-link_return::before {
    display: inline-block;
    font-family: 'icon' !important;
    content: "\e903";
    transform: rotate(180deg);
    font-size: 24px;
    vertical-align: middle;
}

.lottery__link-txt {
	display: none;
}

.lottery-btn {
	display: flex;
	align-items: center;
}

.lottery-btn__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 8px 0;
	padding: .8em 1em;
	font-size: 24px;
	font-weight: bold;
	line-height: 1;
	text-align: center;
	border: none;
	border-radius: 1.3em;
	letter-spacing: .05em;
	overflow:hidden;
}


.lottery-btn__txt {
	margin: 0 24px 4px 0;
}

.lottery-btn__sub-txt {
	font-size: 14px;
}

.lottery-btn__txt span {
	margin-bottom: 8px;
	vertical-align: middle;
}

.lottery-btn__txt span::before {
	font-family: "icon";
	content: "\e910";
	margin: 0 2px 0 8px;
	color: #F5CB00;
	font-size: 1.4em;
	-webkit-font-smoothing: antialiased;
	vertical-align: top;
	line-height: 1;
}

.lottery__head-btn {
    display: none;
}

.lottery__float-btn {
    position: fixed;
    justify-content: space-between;
    align-items: normal;
    bottom: 0;
    right: 0;
    width: 100%;
    padding: 0;
    border-radius: 0;
    z-index: 998;
    background: var(--background-color);
    box-shadow: 0px 0px 20px 0px rgb(0 0 0 / 20%);
}

.lottery__float-btn .lottery-btn__detail {
    padding: 16px 24px;
    margin: 0 auto;
}

.lottery__float-btn .lottery-btn__btn {
	flex: 1;
	max-width: 360px;
	margin: 0;
	border-radius: 1em 0 0 0;
	/* font-size: 30px; */
	overflow: hidden;
}

.lottery__float-btn .lottery-btn__txt {
	margin: 0 0 8px 0;
}

.lottery__summary {
	position: relative;
	margin: 24px;
	padding: 16px;
	text-align: center;
	font-size: 16px;
}

.lottery__summary:before,
.lottery__summary:after,
.lottery__summary p:before,
.lottery__summary p:after { 
  content:'';
  width: 1em;
  height: 1em;
  position: absolute;
  display: inline-block;
}

.lottery__summary:before,
.lottery__summary p:before {
  border-right: solid 1px var(--text-color);
  border-top: solid 1px var(--text-color);
  top:0;
  right: 0;
}

.lottery__summary:after,
.lottery__summary p:after {
  border-left: solid 1px var(--text-color);
  border-top: solid 1px var(--text-color);
  top:0;
  left: 0;
}

.lottery__summary p:before,
.lottery__summary p:after {
	top: auto;
	bottom: 0;
}

.lottery__summary p:before {
	transform: rotate(90deg);
}

.lottery__summary p:after {
	transform: rotate(-90deg);
}

.lottery__container {
	padding: 24px;
}

.lottery__annotation {
    display: flex;
    width: 100%;
    justify-content: center;
    padding: 0 0 40px 1em;
    font-size: 14px;
    opacity: .6;
}

.lottery .page__headline {
	display: block;
	width: 100%;
	text-align: center;
	margin: 64px 0 24px;
}

.lottery-collection .page__sub-headline::after {
	content: none;
}

.lottery-collection .archive__img-wrapper {
	padding-top: 16%;

}

.lottery-collection .archive__txt {
	display: -webkit-box;
	height: calc(2em * 1.4);
	font-size: 16px;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
	line-height: 1.4;
}

.lottery-collection .grid {
	counter-reset: number 0; 
}

.lottery-collection .grid__img {
	z-index: 2;
}

.lottery-collection .grid__inner::before {
	content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 6px;
	border: 1px dotted var(--alpha-text-color);
	z-index: 1;
}

.lottery-collection .grid__inner::after {
    counter-increment: number 1;
    content: counter(number) " ";
    position: absolute;
    right: 10%;
    bottom: -10%;
    color: var(--alpha-text-color);
    z-index: 1;
    line-height: 1;
    font-size: clamp(0px,22vw,200px);
    font-weight: bold;
    opacity: .2;
    white-space: nowrap;
    letter-spacing: -.2em;
    z-index: 0;
}


.lottery-play {
	padding-bottom: 32px;
}

.lottery-play::before {
	content: "";
	position: fixed;
	width: 100%;
	height: 100%;
	background: inherit;
	opacity: .7;
	z-index: 1;
}

.lottery-play .floating {
	position: absolute;
}

.lottery-play__popup .floating {
	position: fixed;
}

.lottery-play__bg {
    position: fixed;
    width: 100%;
    height: 100%;
    object-fit: cover;
    font-family: 'object-fit: cover;';
    z-index: 0;
}

.lottery-play__wrapper {
	position: relative;
	width: 100%;
	height: 100%;
	padding: 10% 24px;
	z-index: 2;
}

.lottery-play__headline {
	text-align: center;
	font-size: 64px;
	margin: 0 auto;
}

.lottery-play__title {
	text-align: center;
	font-size: 18px;
	font-weight: bold;
}

.lottery-play__txt {
	text-align: center;
	font-size: 16px;
}

.lottery-play__sub-txt {
	text-align: center;
	margin: 40px 0;
}

.lottery-play__list{
    margin: 2em -16px 2em 0;
}

.lottery-play__btn-wrapper {
	display: flex;
	width: 100%;
	justify-content: center;
}

#prize ~ .lottery-play__btn-wrapper {
	position: absolute;
	left: 0;
	right: 0;
	top: auto;
}

.lottery-play__btn {
	display: inline-block;
	min-width: 90px;
	margin-left: 12px;
	padding: 1em 24px;
	border-radius: calc(1.5em + 1px);
	font-size: 12px;
	font-weight: bold;
	text-align: center;
	line-height: 1;
	border: 1px solid;
	background: transparent;
}

.lottery-play__btn:first-child {
	margin-left: 0;
}

.lottery-play__btn_play {
    border: none;
    color: #FFF;
}

.lottery-play__floating .lottery-play__sub-txt {
	margin: 20px 0;
}

.lottery-animation {
	display: none;
	position: absolute;
	z-index: 900;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: 0 auto;
}

#lastPrize {
	z-index: -1;
	width: 100%;
	height: 560px;
	left: 50%;
	bottom: auto;
	transform: translate(-50%, 0)scale(1.4);
}

.grid {
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	margin-right: -16px;
}

.grid__item {
	width: calc(100% / 3);
	padding: 0 16px 16px 0;
	overflow: hidden;
}

.grid__soldout {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
	z-index: 3;
	border-radius: 6px;
}

.grid__soldout::before {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,.4);
}

.grid__soldout::after {
	font-family: 'icon' !important;
	content: "\e93e";
	position: absolute;
	top: 50%;
	left: 50%;
	font-size: clamp(0px,19vw,150px);
	line-height: 1;
	transform: translate(-50%,-50%);
	color: #fff;
	z-index: 2;
	text-align: center;
}

.grid__inner {
	position: relative;
	display: block;
	padding-top: 100%;
	border-radius: 6px;
	overflow: hidden;
}

.grid__img {
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	object-fit: cover;
	font-family: 'object-fit: cover;';
}

.grid__inner .prizeAnim {
	padding: 4px;
}

.grid__inner .prizeMask {
	border-radius: 10px;
}

.grid__tag {
	position: absolute;
	top: 0;
	right: 0;
	height: 16%;
	margin: 8px;
	z-index: 0;
}

.lottery__contents .grid__item:only-child {
    width: 100%;
    max-width: 500px;
    margin: 0 auto;
}

.lottery__contents .grid__item:first-child:nth-last-child(2),
.lottery__contents .grid__item:first-child:nth-last-child(2) ~ .grid__item {
    width: calc(100% / 2);
}

.award__headline {
	position: relative;
	display: flex;
	margin-bottom: 24px;
	align-items: center;
	font-weight: bold;
	line-height: 1;
	font-size: 1em;
}

.award__main {
    font-size: 3.5em;
    padding-right: 4px;
}

.award__headline .award__sub {
    padding-left: 24px;
    font-weight: normal;
    opacity: .6;
    font-size: .8em;
}

.lottery__contents .award__headline .gradient {
	content: "";
	position: absolute;
	width: 100%;
	height: 50%;
	z-index: 0;
}

.lottery__contents .award__headline .contentsGradLiner{
	content: "";
	position: absolute;
	width: 50%;
	height: 50%;
	z-index: 0;
}

.lottery__contents .award__headline span {
	position: relative;
	z-index: 1;
	opacity: .8;
}

.lottery-collection__container {
	padding: 24px;
}

.lottery-collection__title {
	font-size: 18px;
	margin-bottom: 2.5em;
}

.lottery-collection .archive__list {
	position: relative;
}

.lottery-collection .award__title {
	display: block;
	height: auto;
	margin: 12px 0 1.5em;
}

.lottery-collection .feed-detail__main{
	overflow-y: visible;
}

.lottery-collection .archive__list .active .archive__img-wrapper::before {
	content: "選択中";
	position: absolute;
	display: inline-block;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	width: 100%;
	color: #fff;
	text-align: center;
	z-index: 1;
	font-weight: bold;
}

.lottery-collection .archive__list .active .archive__img-wrapper::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--primary-color);
	opacity: .4;
}


.award__contents {
    margin: 0 0 48px 0;
}

.award__title {
    font-weight: bold;
    display: -webkit-box;
    margin: 12px 0;
    font-size: 1em;
    height: calc(2em * 1.4);
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    line-height: 1.4;
}

.lottery__contents:first-child .award__title {
	height: auto;
}

.award__sub-txt {
    font-size: 14px;
    opacity: .6;
    margin: 12px 0;
}

.award_digital .grid {
	counter-reset: number 0;
}

.award_digital .grid__inner::before {
    counter-increment: number 1;
    content: counter(number) " ";
    position: absolute;
    right: 10%;
    bottom: -10%;
    color: #fff;
    z-index: 1;
    line-height: 1;
    font-size: clamp(0px,24vw,200px);
    font-weight: bold;
    opacity: .9;
    white-space: nowrap;
    letter-spacing: -.2em;
}

/*カウンター1カラム*/
.award_digital .grid__item:only-child .grid__inner::before {
	font-size: clamp(0px,80vw,300px)
}

/*カウンター2カラム*/
.award_digital .grid__item:first-child:nth-last-child(2) .grid__inner::before,
.award_digital .grid__item:first-child:nth-last-child(2)  ~ .grid__item .grid__inner::before {
	font-size: clamp(0px,38vw,300px);
}

.award_digital .grid__inner::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	/* backdrop-filter: saturate(100%) blur(20px);
	-webkit-backdrop-filter: saturate(100%) blur(20px); */
}

/*ラスト賞*/
.award_last .grid__inner::before {
	counter-increment: number 1;
	content: counter(number) " ";
	position: absolute;
	right: 10%;
	bottom: -10%;
	color: #fff;
	z-index: 1;
	line-height: 1;
	font-size: clamp(0px,24vw,200px);
	font-weight: bold;
	opacity: .9;
	white-space: nowrap;
	letter-spacing: -.2em;
}

.award_last .grid__inner::before {
	content: "SECRET";
	bottom: 50%;
	right: 50%;
	transform: translate(50%, 50%);
	font-size: clamp(0px,15vw,80px);
	letter-spacing: normal;
}

/*soldout1カラム*/
.award .grid__item:only-child .grid__soldout::after {
    font-size: clamp(0px,56vw,300px);
}

/*soldout2カラム*/
.award .grid__item:first-child:nth-last-child(2) .grid__soldout::after,
.award .grid__item:first-child:nth-last-child(2)  ~ .grid__item .grid__soldout::after {
    font-size: clamp(0px,28vw,230px);
}

.prize {
    margin-top: 24px;
}

.prize__title {
    display: -webkit-box;
    font-size: 14px;
    margin-top: 8px;
    max-height: calc(2em * 1.4);
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    line-height: 1.4;
}

.prize-detail {
    align-items: flex-start;
    margin-top: -56px;
    padding-top: 56px;
}

.prize-detail__img-wrapper {
    position: relative;
    display: block;
    max-width: 327px;
    margin: 16px auto 0;
    border-radius: 6px;
}

.prize-detail .icon_play::before {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	font-size: 80px;
	color: #fff;
	text-shadow: 0px 0px 10px rgba(0,0,0,0.6);
}

.prize-detail__img {
    display: block;
    width: 100%;
    height: 100%;
    max-height: 327px;
    margin: 0 auto;
    border-radius: 6px;
    object-fit: contain;
    font-family: 'object-fit: contain;';
    /* border: 1px solid var(--alpha-text-color); */
}

.prize-detail__detail {
	position: relative;
	margin: 16px 0 0;
}

.prize-detail__headline {
	font-weight: bold;
}

.prize-detail__main {
    padding-right: 4px;
    font-size: 48px;
    line-height: 48px;
    vertical-align: middle;
}

.prize-detail__main_last {
	font-size: 32px;
}

.prize-detail__txt {
    padding: 24px 0 0;
}

.prize-detail__annotation {
	display: block;
	opacity: .6;
	font-size: 14px;
	padding: 16px 0;
}

.prize-detail__title {
    display: block;
    padding: 1em 0;
}

.prize-detail__child:nth-child(2) {
	position: relative;
}

.prize-detail__child:nth-child(2)::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	border-top: 1px solid;
	opacity: .2;
}

.lottery-prize__download {
    position: absolute;
    top: 0;
    right: 0;
    padding: 1em 1.5em;
    line-height: 1;
    border-radius: 2em;
    overflow: hidden;
    /* background: var(--alpha-text-color); */
    color: var(--text-color);
    font-size: 14px;
    z-index: 1;
}  

.lottery-prize__download::before {
    content: "\e93c";
    font-family: "icon";
    display: inline-block;
    margin-right: 8px;
    font-size: 1.4em;
    vertical-align: middle;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
} 

.lottery-prize__download::after {
	content: "";
	position: absolute;
	display: block;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--text-color);
	z-index: -1;
	opacity: .2;
}

.lottery-play .grid {
	flex-wrap: wrap;
}

.lottery-play .grid__item {
	width: calc(100% / 3);
}

.play-modal {
    position: fixed;
    top: 100%;
    left: 0;
    width: 100%;
    height: 100%;
    transition: .3s ease;
    z-index: 2;
    backdrop-filter: saturate(100%) blur(20px);
    -webkit-backdrop-filter: saturate(100%) blur(20px);
}

.play-modal__img-wrapper {
	position: relative;
	width: 320px;
	margin: 3em auto 2em;
	padding-top: 320px;
	border-radius: 16px;
	overflow: hidden;
	z-index: 2;
}

.prizeImg {
	padding: 4px;
	border-radius: 10px;
}

.prizeImg_1st{
	background: #FAC900;
}

.prizeImg_2nd{
	background: #979AC9;
}

.prizeImg_3rd{
	background: #C76B00;
}

.prizeFadein {
	opacity: 0;
}

.reconfirm {
	display: none;
}

/*************************************
**************************************
			   chat
**************************************
*************************************/

.chat-list__items{
	position: relative;
	list-style: none;
}

.chat-list__img {
	width: 50px;
	height: 50px;
	border-radius: 50%;
	object-fit: cover;
	overflow: hidden;
}

.chat-list__txt {
	line-height: 14px;
	font-size: 14px;
	font-weight: bold;
	padding-bottom: 4px;
}

.chat-list-sub__txt {
	line-height: 1.4;
	font-size: 12px;
	opacity: .6;
}

.chat-list-txt__wrapper {
	padding: 0 0 0 12px;
	flex: 1;
	overflow: hidden;
}

.chat__container .page__wrapper {
	max-width: 800px;
	width: 100%;
}

.chat__container .search__button {
	line-height: 38px;
}

.chat__container_room .search-field__wrapper {
	display: block;
}

.chat__container_room .search__button {
	position: initial;
	margin-right: 8px;
	padding: 0;
}

.chat__container_room .icon_search {
	display: inline-block;
	color: #757575;
}

.chat__container_room .icon_search::before {
	margin-right: 8px;
}

.chat-list__item {
	display: flex;
	padding: 8px 24px 8px 24px;
	align-items: center;
}

.chat-list .icon_owner {
	font-size: 14px;
	margin: 0 0 0 4px;
}

.chat-list__button {
	position: relative;
	width: 100px;
	height: 30px;
	margin-left: 12px;
	border-radius: 4px;
	border: none;
	color: var(--text-color);
	font-size: 14px;
}

.chat-list__button::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--text-color);
	opacity: .1;
	content: "";
}

.chat-list {
	padding: 16px 0;
}

.chat-search__wrapper .chat-list {
	margin: 16px 0 8px 0;
	padding: 0;
}

.chat-list__badge {
	display: inline-block;
	margin-top: 8px;
	padding: 5px;
	border-radius: 9999px;
	background: var(--primary-color);
}

.chat-list-badge__txt {
	color: #fff;
	font-size: 12px;
	line-height: 12px;
	min-width: 12px;
	text-align: center;
}

.chat-list-sub__txt_line {
	display: -webkit-box;
	max-height: 32px;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
}

.chat-list__time {
	margin: 4px 0 0 0;
	font-size: 10px;
	opacity: .6;
	white-space: nowrap;
	line-height: 10px;
}

.chat-list-txt__container {
	display: flex;
	align-items: center;
}

.chat-list-txt__container:last-child {
	padding-bottom: 0;
}

.chat-list__lavel {
	min-width: 60px;
	margin: 0 8px 4px 8px;
	padding: 0 4px;
	font-size: 10px;
	border-radius: 2px;
	background: var(--primary-color);
	color: #fff;
}

.chat-list__lavel_owner {
	background: var(--text-color);
	color: var(--contents-color);
	opacity: .6;
}

.chat-list__container {
	padding: 70px 24px 24px 24px;
}

.room-absence-txt {
	margin: 16px 0;
	font-size: 16px;
	font-weight: bold;
}

.room-absence-sub-txt {
	margin: 0 0 32px 0;
	color: var(--text-color);
	font-size: 12px;
	opacity: .6;
}

.room-absence {
	text-align: center;
	margin: 80px 0 32px 0;
}

.icon_conversation {
	color: var(--text-color);
	font-size: 80px;
	opacity: .2;
}

.chat__button {
	display: block;
	width: 100%;
	max-width: 327px;
	height: 48px;
	line-height: 16px;
	margin: 0 auto;
	padding: 16px 0;
	border-radius: 4px;
	background: var(--primary-color);
	color: var(--contents-color);
}

.room-invite-img__wrapper {
	display: block;
	position: relative;
	padding-top: 32%;
	border-radius: 6px;
	overflow: hidden;

}

.room-invite-img {
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	width: 100%;
	height: 100%;
	margin: auto;
	object-fit: cover;
}

.chat-list__container .chat-list__item {
	margin-bottom: 0;
	padding: 8px 0;
}

.chat-list-sub__member {
	font-size: 10px;
	margin-top: 4px;
}

.room-invite-txt {
	position: absolute;
	bottom: 0;
	left: 0;
	padding: 8px 16px;
	color: #fff;
	font-size: 14px;
	font-weight: bold;
}

.chat__container .icon_arrow_right {
	position: absolute;
	right: 16px;
	bottom: 12px;
	width: 18px;
	height: 18px;
	background: #fff;
	border-radius: 50%;
	color: #707070;
	padding: 3px;
	font-size: 12px;
}

.chat-balloon__wrapper {
	text-align: center;
}

.chat-balloon {
	display: inline-block;
	position: relative;
	margin: 8px 0;
	padding: 8px 12px;
}

.chat-balloon::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--text-color);
	opacity: .1;
	border-radius: 4px;
}

.chat-balloon:before {
	content: "";
	position: absolute;
	top: -18px;
	left: 50%;
	margin-left: -10px;
	border: 10px solid transparent;
	border-bottom: 8px solid;
	border-bottom-color: var(--text-color);
	opacity: .1;
}

.chat-balloon-txt {
	margin: 0;
	padding: 0;	
	font-size: 12px;
	text-align: left;
}

.chat-list-item__wrapper {
	display: block;
}

.chat-page .header__title {
	position: relative;
}

.chat-page .create-button {
	display: block;
	position: absolute;
	top: 50%;
	right: 24px;
	transform: translateY(-50%);
	font-size: 24px;
}

.chat-list-txt__title {
	display: flex;
	font-weight: bold;
}

.chat-list-side__wrapper {
	height: 50px;
	min-width: 32px;
	margin-left: 8px;
	text-align: right;
}

.chat-list__txt_member {
	white-space: nowrap;
}

.room-create-txt__wpapper {
	display: none;
}

.room-create-txt::before {
	font-family: 'icon';
	content: "\e92c";
	margin-right: 4px;
}

.members__deal {
	display: flex;
	height: 48px;
	border-top: 1px solid;
	border-color: var(--alpha-text-color);
}

.members-mute, .members-report {
	width: 100%;
	font-size: 14px;
	border: none;
	background:var(--contents-color);
	color: var(--text-color);
}

.members-report {
	border-right: 1px solid;
	border-color: var(--alpha-text-color);
}

.modal-swich:checked ~ .member-modal {
	display: block;
}

.member-modal{
	display: none;
	margin: auto;
	position: absolute;
	top: 60px;
	left: 50%;
	transform: translate(-50%);
	width: calc(100% - 48px);
	max-width: 400px;
	z-index: 997;
	border-radius: 6px;
}

.select-report__wrapper {
	max-height: 400px;
	overflow: scroll;
}

.black-txt {
	position: absolute;
	top: 104%;
	right: 0;
	color: #fff;
	border: none;
	background: transparent;
	padding: 0;
}

.black-txt::after {
	font-family:'icon';
	content: "\e903";
	margin-left: 8px;
}

.member-modal .members__txt {
	max-height: 200px;
	overflow: scroll;
	-webkit-line-clamp: inherit;
	-ms-overflow-style: none;
	scrollbar-width: none;
}

.member-modal .members__txt::-webkit-scrollbar {
	display:none;   /* Chrome, Safari 対応 */
}

.member-modal .members__name {
	height: auto;
}

.member-modal .card {
	max-height: calc(100% - 104px);
	overflow: scroll;
	-ms-overflow-style: none;
	scrollbar-width: none;
}

.member-modal .card::-webkit-scrollbar {
	display:none;   /* Chrome, Safari 対応 */
}

.select-report__item {
	padding: 0 0 0 16px;
	border-top: 1px solid #c7c7cc;
	list-style: none;
}

.select-report__label {
	position: relative;
	display: block;
	width: 100%;
	padding: 12px 0 12px 28px;
	cursor: pointer;
}

.select-report__input {
	display: none;
}

.select-report__label::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	width: 20px;
	height: 20px;
	margin: auto;
	border: 1px solid #D6D6D6;
	border-radius: 50%;
	background: #FFFFFF;
}

.select-report__label::after {
	content: "";
	position: absolute;
	display: block;
	top: 0;
	left: 5px;
	bottom: 0;
	width: 10px;
	height: 10px;
	margin: auto;
	border-radius: 50%;
	transform: scale(0) translateY(4px);
	transition: all ease 100ms;
}

.select-report__input:checked + .select-report__label::after {
	transform: scale(1);
	background: var(--primary-color);
}

.chat-list__label {
	position: absolute;
	top: 0%;
	left: 0%;
	width: 100%;
	height: 100%;
	cursor: pointer;
	z-index: 1;
}

.tag-list {
	margin:8px 24px 0 24px;
	font-size: 0;
	list-style: none;
}

.tag-list__items {
	display: inline-block;
	max-width: 200px;
	margin: 8px 8px 0 0;
	padding: 8px 12px;
	font-size: 14px;
	border-radius: 16px;
	border: solid 1px var(--alpha-text-color);
	line-height: 1;
}


.chat-setting .tag-list__items:hover {
	opacity: 1;!important
	transition: none;!important
}

.chat-list-item__tag {
	width: 50px;
	height: 50px;
	border-radius: 50%;
	border: 1px solid var(--alpha-text-color);
	text-align: center;
	font-size: 24px;
	line-height: 50px;
	color: var(--text-color);
}

.tag-list__title {
	padding-top: 24px;
	text-align: center;
	font-size: 16px;
	font-weight: bold;
}

.chat__container .contents_empty {
	margin: 32px 0 0 0;
}

.chat-list__title {
	padding-top: 24px;
	text-align: center;
	font-size: 16px;
}

.txt-count__area_over .txt-count {
	color: #E04136;
}

.txt-count__area {
	position: absolute;
	top:0;
	right: 0;
}

.form__title {
	margin-bottom: 10px;
	font-weight: bold;
}

.edit-error__txt {
	font-size: 14px;
	color: #E04136;
	padding-right: 68px;
}

.edit-room .form__input {
	border: 1px solid;
	border-color: var(--alpha-text-color);
	border-radius: 4px;
}

.form__input_edit {
	height: 160px;
	resize:none;
}

.form__input_tag {
	height: 100px;
	margin-top: -14px;
}

.txt-count__wrapper {
	position: relative;
	margin-top: 6px;
}

.chat-setting__title {
	margin-bottom: 8px;
    font-weight: bold;
}

.chat-setting__txt {
	margin-bottom: 32px;
}

.chat-setting .tag-list {
	margin: 0 0 32px 0
}

.chat-setting .text-btn {
	text-align: inherit;
	font-weight: inherit;
}

.chat-setting .text-btn__wrapper {
	display: none;
}

.chat-setting-notice {
	border: 1px solid ;
	border-color: var(--alpha-text-color);
	border-radius: 6px;
}

.chat-setting .form__img-group {
	margin: 16px 0 40px 0;
}

.chat-setting .icon_edit {
	margin-right: 8px;
}

.chat-setting-notice__button {
	padding: 16px;
	list-style: none;
	background: transparent;
	border: none;
	width: 100%;
    text-align: inherit;
}

.chat-setting-notice__item {
	position: relative;
	list-style: none;
	border-bottom: 1px solid ;
	border-color: var(--alpha-text-color);
}

.chat-setting-notice__item:last-child {
	border-bottom: none;
}

.chat-setting-list__item {
	position: relative;
}

.chat-setting-list__link {
	display: block;
	padding: 16px 0;
}

.chat-setting-list__link::after {
	content: "\e903";
	font-family: 'icon';
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	margin: auto auto auto 0;
	width: 16px;
	height: 16px;
	line-height: 1;
	color: var(--light-text-color);
	-webkit-font-smoothing: antialiased;
}

.chat-setting-list {
	list-style: none;
	margin: 16px 0;
}

.chat-setting-delete {
	width: 100%;
	padding: 16px 0;
	color: #E04136;
	background: transparent;
	border: none;
	text-align: inherit;
}

.chat-setting-notice-checked::after {
	font-family: "icon";
	content: "\e912";
	position: absolute;
	right: 16px;
	top: 0;
	bottom: 0;
	margin: auto auto auto 0;
	height: 16px;
	color: var(--primary-color);
}

.chat-setting-notice-checked {
	pointer-events: none;
}

.chat-page .room-edit__link {
	display: inline-block;
	font-weight: inherit;
	font-size: 16px;
	color: var(--navigation-tint-color);
}

.chat__container_room .chat-list:first-child {
	padding: 0;
}

.chat-list-img__wrapper {
	position: relative;
	background: #FFF;
	border-radius: 50%;
}

.chat-list__img-badge {
	position: absolute;
	bottom: 0;
	right: 0;
	width: 16px;
	height: 16px;
}

.chat__container_room .alert {
	display: block;
}

.chat__container_room .alert__inner {
	position: relative;
}

.chat .slick-list {
	overflow: inherit;
}

.chat__container_room .icon_owner {
	margin: 0;
	vertical-align: text-bottom;
}

.chat__container_room .slick-prev,
.chat__container_room .slick-next {
	width: 40px;
    height: 40px;
	display: none;
}

.chat__container_room .alert_premium {
	display: none;
}

/*watanabe.css*/

.chat .two-column__sub,
.setting-switch__open,
.chat .two-column__main .chat-setting,
.chat .input__hidden,
.page_chat #footer {
	display: none;
}

.chat-detail .chat-detail__head {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 64px;
	z-index: 1000;
	display: flex;
	align-items: center;
	padding: 8px 16px;
}

.chat-detail .chat-detail__txt {
	margin: 0 0 0 40px;
	width: calc(100% - 82px);
	line-height: 1;
}

.chat-detail .chat-detail__name__wrapper {
	display: flex;
	align-items: center;
	font-size: 16px;
	-webkit-line-clamp: 1;
	white-space: nowrap;
}

.chat-detail .chat-detail__name__wrapper .official-img {
	width: 16px;
	height: 16px;
	margin: 0 0 0 4px;
}

.chat-detail .chat-detail__count {
	margin: 2px 0 0 0;
	font-size: 10px;
	opacity: .6;
}

.chat-detail .header-bar__icon {
	color: var(--navigation-tint-color);
}

.chat-detail .header-bar__icon_left {
	right: 56px;
	left: auto;
	border: none;
}

/*-------トーク内検索---------*/

#chatSearchSwitch:checked ~ .search {
	max-height: 100%;
}

.chat-detail .search__item {
	height: 64px;
	padding: 12px 24px;
}

/*-------グループチャットに参加するボタン------*/

.chat .chat-detail__join {
	position: fixed;
	bottom: 0;
	left: 0;
	display: block;
	width: 100%;
	z-index: 100;
	display: none;
}

.chat .chat-join__form {
	width: 100%;	
}

.chat .chat-join__button {
	display: block;
	width: 100%;
	height: 52px;
	border: none;
	color: #FFFFFF;
	font-size: 16px;
	font-weight: bold;
	display: none;
}

.chat-detail__inner__bg {
	position:fixed;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	display: block;
	width: 100%;
	height: 100vh;
	z-index: -1;
}

/*-------------入力フォーム------------*/

.chat .chat-send__container {
	position: fixed;
	bottom: 0;
	left: 0;
	display: block;
	width: 100%;
	z-index: 100;
	/* padding-bottom: env(safe-area-inset-bottom); */
	background: var(--navigation-color);
}

.chat .scroll-button__block {
	position: absolute;
	bottom: 100%;
	right: 8px;
}

.chat .scroll-button {
	position: relative;
	display: block;
	width: 30px;
	height: 30px;
	margin: 0 0 8px 0;
	padding: 0;
	border-radius: 4px;
	border: none;
	box-shadow: 0px 0px 4px var(--alpha-text-color);
	cursor: pointer;
}

.chat .scroll-button::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border-radius: 4px;
	border: 1px solid var(--text-color);
	opacity: .1;
	content: "";
}

.chat .scroll-button__icon {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	display: block;
	font-size: 20px;
}

#translationButton:checked + .scroll-button__icon::before {
	color: var(--primary-color);
}

.chat .scrollUnderButton {
	transition: .3s ease;
}

.chat .send__inner {
	padding: 0;
}

.chat .send-item__wrapper {
	position: relative;
	display: flex;
	align-items: flex-end;
	min-height: 52px;
	padding: 8px 4px;
	/* padding-bottom: env(safe-area-inset-bottom); */
}

.chat .chat-send__group {
	display: flex;
	margin: 0 4px 0 0;
}

.chat .chat-send__item {
	position: relative;
	width: 24px;
	height: 24px;
	font-size: 24px;
	margin: 7px 4px;
	color: var(--navigation-tint-color);
	cursor: pointer;
}

.chat .chat-send__item .chat-img__file {
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	width: 100%;
	height: 100%;
	opacity: 0;
}

.chat .chat-send__item::before {
	display: block;
}

.chat .send__form {
	position: relative;
	padding-bottom: 0;
}

.chat .send-field__wrapper {
	width: calc(100% - 36px);
}

.chat .send__field {
	max-height: 116px;
	padding: 8px 16px;
	border: 1px solid var(--alphatext--color);
	color: var(--text-color);
}

.chat .send__field::placeholder {
	color: var(--text-color);
	opacity: .6;
}

.chat .send__button {
	bottom: 7px;
	right: 4px;
	width: 24px;
	margin: 0;
	padding: 0;
	opacity: .6;
}

/*------機能制限（書き込み／閲覧制限）------*/

.chat .write-inhibit {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,.5);
	color: #FFFFFF;
	font-size: 16px;
	font-weight: bold;
	text-align: center;
	line-height: 1;
	display: none;
}

.chat .write-inhibit__txt {
	position: absolute;
	top: 50%;
	left: 50%;
	transform:translate(-50%,-50%);
	width: 100%;
}

.chat .write-inhibit__subtxt {
	display: block;
	margin: 4px 0 0 0;
	font-size: 14px;
	font-weight: normal;
}

.chat .viewing-restrictions {
	min-height: 700px;
	margin: auto;
	padding: 80px 24px;
	text-align: center;
}

.chat .viewing-restrictions__txt {
	font-size: 24px;
	font-weight: bold;
}

.chat .viewing-restrictions__subtxt__wrapper {
	margin: 16px 0 0 0;
	padding: 16px 24px;
	border-radius: 6px;
	background: var(--alpha-text-color);
}

/*-----------スタンプ・スパスタ----------*/

.chat .chat-img__input{
	display: none; 
}

.chat-send__item_icon.active {
	color: var(--primary-color);
} 

.chat .super-.stamp__pickup__container {
	position: relative;
}

.chat .stamp-select__block {
	position: relative;
	display: none;
	width: 100%;
	height: 274px;
}

.chat .send-item__form {
	position: relative;
	height: 100%;
	overflow-y: scroll;
	-ms-overflow-style: none;
	scrollbar-width: none;
}

.chat .send-item__form::-webkit-scrollbar {
	display:none;   /* Chrome, Safari 対応 */
}

.stamp-select__block .purchase__block {
	position: fixed;
	bottom: 0;
	left: 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	height: 48px;
	padding: 8px 16px;
	z-index: 1;
}

.stamp-select__block .charge__btn {
	height: 30px;
	padding: 0 16px;
	border-radius: 18px;
	font-weight: bold;
	line-height: 30px;
	white-space: nowrap;
}

.stamp-select__block .owned-coin__wrapper {
	display: flex;
	align-items: center;
	margin: 0 0 0 16px;
	overflow: hidden;
}

.stamp-select__block .owned-coin__text {
	width: 84px;
	font-weight: bold;
}

.stamp-select__block .icon_coin {
	flex: 1;
	margin: 0 0 0 6px;
	font-size: 18px;
	font-weight: bold;
}

.icon_coin::before {
	display: inline-block;
	margin: 0 4px 0 0;
	font-size: 18px;
	color: #F5CB00;
	-webkit-font-smoothing: antialiased;
}

.stamp-select__block .charge-coin {
	display: inline-block;
	vertical-align: middle;
	font-size: 12px;
	font-weight: bold;
}

/*---------スタンプ・スパスタレイアウト---------*/

.chat .square-grid__list {
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
	padding: 10px 0;
	list-style: none;
}

.chat .square-grid__list_superstamp {
	padding: 10px 0 48px;
}

.chat .square-grid__item {
	position: relative;
	width: 25%;
	margin: 0 0 16px;
	padding: 11px 22px;
}

.chat .stamp-img__wrapper {
	position: relative;
	display: block;
	width: 100%;
	margin: auto;
	padding: 100% 0 0;
	border: none;
	border-radius: 4px;
	overflow: hidden;
}

.square-grid__list_superstamp .square-grid__item {
	padding: 4px 11px 0;
}

.square-grid__list_superstamp .stamp-img__wrapper {
	padding: 0 11px;
	border-radius: 0;
}

.square-grid__list_superstamp .img-clip__wrapper {
	position: relative;
	display: block;
	padding-top: 100%;
	border-radius: 4px;
	overflow: hidden;
}

.square-grid__list_superstamp .super-stamp__area {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	display: block;
	width: calc(100% - 22px);
	margin: auto;
}

.square-grid__list_superstamp .icon_coin {
	margin: 4px -11px 0;
	color: var(--text-color);
	font-size: 12px;
	font-weight: normal;
	vertical-align: middle;
	line-height: 1;
}

.square-grid__list_superstamp .icon_coin::before {
	font-size: 12px;
	vertical-align: middle;
}

.square-grid__list_superstamp .stamp-function {
	position: absolute;
	top: 0;
	right: 11px;
	height: 16px;
}

.square-grid__list_superstamp .icon_play,
.square-grid__list_superstamp .icon_comment {
	float: right;
	display: inline-block;
	font-size: 16px;
	line-height: 1;
	vertical-align: top;
	color: var(--text-color);
}

.square-grid__list_superstamp .stamp-function span:not(:first-child) {
	margin: 0 4px 0 0;
}

/*---------スパスタpickup---------*/

.super-stamp__pickup {
	position: fixed;
	bottom: 0px;
	left: 0;
	right: 0;
	display: none;
	height: 274px;
	background: rgba(0,0,0,.8);
	color: #FFFFFF;
	z-index: 1;
}

.super-stamp__pickup .purchase__block {
	position: static;
	padding: 14px 10px;
}

.super-stamp__pickup .super-stamp__back {
	font-size: 14px;
	line-height: 1;
}

.super-stamp__pickup .purchase__label {
	color: var(--contents-color);
}

.super-stamp__pickup .super-stamp__back::before {
	display: inline-block;
	width: 16px;
	height: 16px;
	margin: 0 6px 0 0;
	vertical-align: middle;
	font-size: 16px;
	font-weight: bold;
}

.super-stamp__pickup .chat-stamp__wrapper_superstamp {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	margin: auto;
	transform: translate(-50%,-55%);
	border-radius: 4px;
}

.pickup__chat-stamp__img {
	position: relative;
	width: 100px;
	height: 100px;
	margin: auto;
}


.super-stamp__pickup .chat-stamp {
	display: block;
	padding-top: 100%;
	border-radius: 4px;
	overflow: hidden;
}

.super-stamp__pickup .chat-stamp > svg {
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	object-fit: cover;
	font-family: 'object-fit: cover;';
}

.super-stamp__pickup .super-stamp__name {
	width: calc(100% - 32px);
	margin: 6px auto 0;
	font-size: 14px;
	text-align: center;
}

.super-stamp__pickup .chat-stamp__wrapper_superstamp .icon_coin {
	flex: auto;
	margin: 4px auto 0;
	font-size: 14px;
	text-align: center;
}

.super-stamp__pickup .chat-stamp__wrapper_superstamp .icon_coin::before {
	font-size: 14px;
}

.super-stamp__pickup__form {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 52px;
	margin: auto;
	padding: 0 8px;
	box-shadow: -3px 0px 10px rgb(0 0 0 / 16%);
}

.chat .pickup__form {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: calc(100% - 76px);
	height: 40px;
	padding: 8px 16px;
	border: none;
	font-size: 16px;
	font-family: 'Hiragino Kaku Gothic ProN', 'Meiryo', 'Osaka', 'MS PGothic', 'YuGothic', 'Arial','Helvetica Neue','Helvetica',sans-serif;
	line-height: 1.4;
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	resize:none;
}

.chat .pickup__form__button {
	position: absolute;
	top: 0;
	bottom: 0;
	right: 8px;
	margin: auto;
	display: block;
	width: 60px;
	padding: 8px 16px;
	font-size: 14px;
	font-weight: bold;
	line-height: 1;
	border: none;
	background: none;
}

.hide .send-item__wrapper,
.hide .purchase__block,
.hide .chat-stamp__wrapper_superstamp,
.hide .square-grid__list {
	display: none;
}

.hide .chat .stamp-select__block,
.hide .send-item__form,
.hide .stamp-select__block,
.hide .super-stamp__pickup {
	height: auto;
}

.hide .scroll-button__block {
	bottom: calc(100% + 52px);
}

.chat-stamp__wrapper_superstamp .chat-stamp + .chat-stamp {
	opacity: 0;
	position: absolute;
	top: 0;
}

.animHide .lottieAnim {
	opacity: 0;
}

.chat__container .animHide .chat-stamp + .chat-stamp {
	display: block;
	opacity: 1;
}

.lottieAnim svg ~ svg {
	display: none;
}

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

.chat-detail .chat-detail__inner {
	height: calc(100% - 64px);
	margin: 8px 0 0 0;
	padding: 8px 8px 80px;
	line-height: 1.4;
}

.chat-detail__inner .chat-announce {
	position: fixed;
	top: 72px;
	left: 50%;
	transform: translateX(-50%);
	display: none;
	width: calc(100% - 16px);
	padding: 16px;
	font-size: 0;
	letter-spacing: 0;
	border-radius: 4px;
	box-shadow:0px 0px 6px rgba(0,0,0,0.16);
	z-index: 100;
}

.chat-detail__inner .chat-announce__item {
	display: inline-block;
	vertical-align: top;
}

.chat-detail__inner .chat-announce .info::before {
	font-family: 'icon' !important;
	font-size: 20px;
	color: var(--accent-color);
	content: "\e91a";
	line-height: 1;
}

.chat-detail__inner .chat-announce__item.text {
	width: calc(100% - 36px);
	margin: 0 0 0 16px;
	font-size: 14px;
}

.chat-detail__inner .chat-information {
	margin: 16px 24px 8px;
	text-align: center;
	font-size: 12px;
}

.chat-detail__inner .chat-information_full {
	margin: 16px auto 8px;
}

.chat-detail__inner .chat-information__inner {
	position: relative;
	display: inline-block;
	padding: 8px;
	color: var(--contents-color)!important;
	z-index: 1;
}

.chat-detail__inner .chat-information__inner::before {
	position: absolute;
	top: 0;
	left: 0;
	display: inline-block;
	width: 100%;
	height: 100%;
	border-radius: 16px;
	background: var(--text-color);
	opacity: .4;
	content: "";
	z-index: -1;
}

.chat-detail__inner .chat-information__inner > span {
	font-weight: bold;
}

.chat-detail__inner .chat-information__inner_wide {
	width: 100%;
	padding: 8px 40px;
}

.chat-detail__inner .information__txt span {
	font-weight: bold;
}

.chat-detail__inner .chat-information__inner_wide::after {
	position:absolute;
	top: 50%;
	left: 16px;
	transform: translateY(-50%);
	margin: auto 0;
	color: var(--contents-color);
	font-family: 'icon' !important;
	content: "\e957";
}

.chat-block {
	display: flex;
	align-items: flex-start;
}

.chat .profile {
	width: 30px;
	height: 30px;
	margin: 0 6px 0 0;
	border-radius: 50%;
}

.chat__container {
	display: flex;
	flex-direction: column;
	flex: 1;
}

.chat .members__name {
	display: block;
	max-width: 20.03em;
	width: 100%;
	margin-bottom: 4px;
	padding-right: 0;
	font-size: 10px;
	-webkit-line-clamp: 1;
	white-space: nowrap;
}

.chat .members__name_owner {
	display: flex;
	align-items: center;
	max-width: 21.03em;
	padding: 0 16px 0 0;
}

.chat .members__name_owner .icon_owner::before {
	margin: 0 0 0 4px;
}

.chat__container .chat__group {
	display: flex;
	align-items: flex-end;
	margin: 0 0 8px 0;
}

.chat__container .chat__item {
	position: relative;
	max-width: 76%;
}

.chat__container .chat__item_img {
	display: inline-block;
	width: 100%;
	max-width: 268px !important;
	min-width: 150px;
	letter-spacing: 0;
	font-size: 0;
}

.chat__container .chat-img__wrapper {
	position: relative;
	display: block;
	padding-top: 100%;
	padding-right: 100%;
	overflow: hidden;
}


.chat__container .chat-grid__item {
	display: inline-block;
	padding-right: 0;
	color: #323232;
}

/*-----chat-grid_1-----*/

.chat-grid_1 .chat-grid__item {
	width: 100%;
	padding-top: 100%;
	border-radius: 6px;
}

/*-----chat-grid_2-----*/

.chat-grid_2 .chat-grid__item {
	width: calc(100%/2 - 1px);
	padding-top: calc(100%/2 - 1px);
	margin: 0 1px 1px 0;
}

.chat-grid_2 .chat-grid__item:nth-of-type(1) {
	border-radius: 6px 0 0 6px;
}

.chat-grid_2 .chat-grid__item:nth-of-type(2) {
	margin-right: 0;
	border-radius: 0 6px 6px 0;
}

/*-----chat-grid_3-----*/

.chat-grid_3 .chat-grid__item:nth-of-type(1) {
	float: left;
	width: calc(100%/3*2 - 1px);
	padding-top: calc(100%/3*2 - 1px);
	margin: 0 1px 1px 0;
	border-radius: 6px 0 0 6px;
}

.chat-grid_3 .chat-grid__item:nth-of-type(2) {
	width: calc(100%/3 - 1px);
	padding-top: calc(100%/3 - 1px);
	margin: 0 1px 1px 0;
	border-radius:0 6px 0 0;
}

.chat-grid_3 .chat-grid__item:nth-of-type(3) {
	width: calc(100%/3 - 1px);
	padding-top: calc(100%/3 - 1px);
	border-radius: 0 0 6px 0;
}

.chat-grid_3 .chat-grid__item:nth-of-type(2),
.chat-grid_3 .chat-grid__item:nth-of-type(3) {
	margin-right: 0;
}

/*-----chat-grid_4-----*/

.chat-grid_4 .chat-grid__item {
	width: calc(100%/2 - 1px);
	padding-top: calc(100%/2 - 1px);
	margin: 0 1px 1px 0;
}

.chat-grid_4 .chat-grid__item:nth-of-type(1) {
	border-radius: 6px 0 0 0;
}

.chat-grid_4 .chat-grid__item:nth-of-type(2) {
	margin-right: 0;
	border-radius: 0 6px 0 0;
}

.chat-grid_4 .chat-grid__item:nth-of-type(3) {
	border-radius: 0 0 0 6px;
}

.chat-grid_4 .chat-grid__item:nth-of-type(4) {
	border-radius: 0 0 6px 0;
}


.chat__container .chat__inner {
	position: relative;
	display: flex;
	flex-direction: column;
	flex: 1;
	min-width: 0;
	width: 100%;
	height: 100%;
	padding: 8px 16px;
}

.chat__container .chat__inner::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border-radius: 4px;
	background: var(--alpha-text-color);
	content: "";
}

.chat__group_reply .chat__inner::before {
	border-radius: 4px 4px 0 0;
}

.chat__group_reply .chat__inner:last-of-type::before {
	content: "";
	border-radius: 0 0 4px 4px;
}

.chat__group_reply .chat__inner:nth-of-type(2n)::before {
	content: "";
	width: 100%;
	border-top: 1px solid var(--alpha-text-color);
}

.chat-block_icon .chat__group_reply .chat__inner:nth-of-type(2n)::before {
	border-top: 1px solid rgba(255,255,255,.1);
}

.chat__container .chat-reply__item {
	display: flex;
	margin: 16px 0 0 4px;
}

.chat-reply__item .icon_reply_arrow {
	margin: 0 4px 0 0;
	opacity: .6;
}

.chat-reply__item .chat__inner.gradient {
	margin: 0 32px 0 0;
	padding: 8px 40px 8px 16px;
	border-radius: 4px;
	border: none;
}

.chat-reply__item .chat__inner.gradient::before {
	background: none;
}

.chat__container .chat__inner_reply {
	position: relative;
	flex-direction: row;
	align-items: flex-start;
	flex: none;
}

.chat__container .chat__inner_reply:only-of-type::before {
	border-radius: 4px;
}

.chat__container .chat__group_superstamp {
	margin: 0 0 40px 0!important;
}

.chat__group_superstamp .gradient {
	margin: 0 32px 0 0;
	padding: 8px 40px 8px 16px;
	border-radius: 4px;
}

.chat__container .chat__inner.gradient::before {
	content: none;
}

.chat__inner.gradient .chat__txt_strong,
.chat__inner.gradient .icon_present {
	font-weight: bold;
}

.chat__inner.gradient .icon_present::before {
	display: inline-block;
	margin: 0 4px;
}

.chat-block_me .chat__group {
	flex-direction: row-reverse;
}

.chat-block_me .chat__inner::before {
	border: 1px solid var(--alpha-text-color);
	background: transparent;
}

.chat-block .chat__inner_icon::before {
	background: var(--primary-color);
}

.chat-block_me .chat__group_reply .chat__inner:nth-of-type(2n)::before {
	border-top: none;
}

.chat__container .chat-img__wrapper_video::before {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	background: rgba(0, 0, 0, .2);
	z-index: 1;
	content: "";
}

.chat__container .video__mark {
	position: absolute;
	top: 50%;
	left: 50%;
	margin: auto;
	color: #FFF;
	transform: translate(-50%, -50%);
	z-index: 1;
	content: "";
	text-align: center;
}

.chat__container .icon_play {
	width: 40px;
	height: 40px;
	font-size: 40px;
	line-height: 1;
}

.chat__container .video__second {
	margin: 4px 0 0 0;
	font-size: 12px;
}

.chat__container .chat__txt {
	position: relative;
	font-size: 14px;
}

.chat__inner_icon .chat-reply__name,
.chat__inner_icon .chat__txt,
.chat__group_superstamp .chat__txt {
	color: #FFFFFF;
}

.chat__container .chat-stamp__wrapper {
	width: 80px;
	height: 80px;
	padding: 8px;
}

.chat__group_superstamp .present {
	font-weight: bold;
}

.chat__container .chat-stamp__wrapper_superstamp {
	position: absolute;
	top: 0;
	left: calc(100% - 32px);
	width: 64px;
	height: 64px;
	margin: auto;
	padding: 0;
}

.chat__container .chat-stamp {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
	border-radius: 4px;
}

.chat__container .chat-stamp + .chat-stamp {
	display: none;
}

.chat__container_reply {
	position: relative;
	flex-direction: row;
	align-items: flex-start;
	flex: none;
	margin: 0 0 8px 0;
	padding: 0 0 12px 0;
}

.chat__container_reply::after {
	position: absolute;
	bottom: 0;
	left: -16px;
	right: -16px;
	height: 1px;
	background: var(--alpha-text-color);
	content: "";
}

.chat .chat__group_reply-superstamp {
	margin: 0 0 40px!important;
}

.chat__container .chat__inner_reply-thumbnail {
	padding: 8px 56px 12px 16px;
}

.chat__container_reply .profile {
	width: 24px;
	height: 24px;
	margin: 4px 8px 0 0;
}

.chat__reply {
	position: relative;
	flex: 1;
	min-width: 0;
}

.chat__reply__inner {
	display: flex;
	align-items: center;
	font-size: 12px;
}

.chat__reply .chat-reply__name {
	display: -webkit-box;
	max-height: 16.5px;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
	overflow: hidden;
	font-weight: bold;
}

.chat__reply .owner::after {
	margin: 0 0 0 4px;
	font-family:'icon' !important;
	content: "\e954";
}


.chat__reply .chat__txt {
	display: -webkit-box;
	max-height: 33.6px;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	font-size: 12px;
	opacity: .6;
	overflow: hidden;
}

.chat__inner_reply-thumbnail .chat__reply_thumbnail {
	position: absolute;
	top: 8px;
	right: 16px;
	flex: none;
}

.chat__inner_reply-thumbnail .clip-img__wrapper_thumbnail {
	width: 32px;
	height: 32px;
	margin: 0;
	border-radius: 4px;
}

.chat__inner_reply-thumbnail .clip-img__wrapper_video::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border-radius: 4px;
	background: rgba(0, 0, 0, .2);
	z-index: 1;
	content: "";
}

.chat__inner_reply-thumbnail .clip-img__wrapper_video .icon_play {
	width: 10px;
	height: 10px;
	font-size: 10px;
}

.chat__container .chat-item__information {
	position: relative;
	display: flex;
	align-items: flex-end;
	margin: 0 0 0 4px;
}

.chat__container .chat__time {
	display: inline-block;
	margin: 0 64px 0 0;
	font-size: 10px;
	opacity: .6;
	white-space: nowrap;
}

.chat__group_superstamp .chat-item__information {
	margin: 0px 0 0 36px;
}

/*-------入力フォームリプライ------*/

.chat-send__container .chat__container_reply {
	display: none;
	margin: 0;
	padding: 16px 40px 16px 8px;
	background: var(--alpha-text-color);
}

.chat-send__container .chat__container_reply-icon {
	background: var(--primary-color);
	color: #FFFFFF;
}

.chat-send__container .chat__inner_reply-thumbnail {
	padding: 16px 80px 16px 8px;
}

.chat-send__container .chat__reply__inner,
.chat-send__container .owner::after {
	font-size: 10px;
}

.chat-send__container .chat__txt {
	display: block;
	max-height: 19.2px;
}

.chat-send__container .chat__reply_thumbnail {
	top: 50%;
	right: 32px;
	transform: translateY(-50%);}

.chat-send__container .clip-img__wrapper_thumbnail {
	width: 40px;
	height: 40px;
}

.chat-send__container .reply-switch__close {
	position: absolute;
	top: 8px;
	right: 8px;
	width: 16px;
	height: 16px;
}

.chat-send__container .icon_close:before {
	font-size: 16px;
}

.chat-send__container .chat__container_reply::after {
	content: none;
}

/*-------機能／リプライ／削除------*/

.chat__container .chat__function__wrapper {
	position: relative;
}

.chat__container .chat__function {
	position: absolute;
	right: 28px;
	top: 50%;
	transform: translateY(-50%);
	width: 40px;
	height: 40px;
	cursor: pointer;
}

.chat__container .chat__function-mark {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	display: block;
	width: 4px;
	height: 4px;
	margin: auto;
	border-radius: 50%;
	background: var(
	--text-color);
	opacity: .6;
}

.chat__container .chat__function-mark::before,
.chat__container .chat__function-mark::after {
	position: absolute;
	top: 0;
	display: block;
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: var(--text-color);
	content: "";
}

.chat__container .chat__function-mark::before {
	left: -8px;
}

.chat__container .chat__function-mark::after {
	left: 8px;
}

.chat__container .chat-function__item {
	position: absolute;
	bottom: 100%;
	right: -16px;
	display: none;
	margin: 8px 0;
	padding: 8px;
	border: none;
	border-radius: 2px;
	background: var(--text-color);
	font-size: 14px;
	line-height: 1;
	opacity: .6;
	color: var(--contents-color);
	white-space: nowrap;
}

.chat__container .chat-function__item::before {
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	display: block;
	width: 0;
	height: 0;
	border-right: 5px solid transparent;
	border-left: 5px solid transparent;
	border-top: 10px solid var(--text-color);
	content: "";
}

.chat-block_me .chat__container .chat__time {
	margin: 0 0 0 64px;
}

.chat-block_me .chat__function {
	right: auto;
	left: 28px;
}

.chat__container .chat__function-mark {
	right: 50%;
	left: auto;
	transform: translate(50%, -50%);
}

.chat-block_me .chat-function__item {
	right: -2px;
}

.function-switch:checked ~ .function__list {
	display: block;
}

/*-------profile------*/

.chat .member-modal {
	position: fixed;
	top: 50%;
	transform: translate(-50%,-50%);
}

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

.chat__container .chat-link__list {
	margin: 6px 0 0 0;
	list-style: none;
}

.chat__container .chat-link__item {
	position: relative;
	padding: 10px 0;
}

.chat__container .chat-link__item:not(:first-of-type)::after {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 1px;
	background: var(--text-color);
	opacity: .1;
	content: "";
}

.chat__container .chat-link__item:last-of-type {
	padding-bottom: 0;
}

.chat-link__group {
	position: relative;
	display: block;
	overflow: hidden;
}

.chat-link__title {
	font-weight: bold;
}

.chat-link__description {
	display: -webkit-box;
	max-height: 33.6px;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	font-size: 12px;
	opacity: .6;
	white-space: normal;
}

.between {
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0 0 0 8px;
}

.chat__item .between::before {
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	border-left: solid 1px var(--text-color);
	opacity: .6;
	content: "";
}

.chat-link__group:not(:first-of-type) > .chat__item .between::before {
	border-top: solid 1px var(--text-color);
}

.chat-link__group .between__grow {
	align-self: flex-start;
	flex: 1;
	padding: 0 8px 0 0;
}

.chat-link__group .between__fix {
	width: 48px;
	height: 48px;
	border-radius: 6px;
}

.chat-block_me .chat__container .chat-item__information {
	flex-direction: row-reverse;
	margin: 0 4px 0 0;
}

.chat-block_me .chat__group_superstamp .gradient {
	padding: 8px 16px 8px 40px;
	border: none;
}

.chat-block_me .chat__group_superstamp .gradient::before {
	background: none;
}

.chat-block_me .chat-reply__item .chat__inner.gradient {
	margin: 0 0 0 32px;
	padding: 8px 16px 8px 40px;
}

.chat-block_me .chat__container .chat-stamp__wrapper_superstamp {
	left: -32px;
}

.chat-block_me .chat__group_superstamp .chat-item__information {
	margin: 0 36px 0 0;
}

/*-------キックされた人--------*/

.alert-kick__mask {
	display: none;
	position: fixed;
	z-index: 998;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, .5);
	pointer-events: none;
}

/*-------閲覧制限／利用制限--------*/

.viewing-restrictions,
.write-inhibit {
	display: none;
}

/*-------トーク内検索結果------*/

.chat-list_talk .chat-list__item {
	align-items: flex-start;
}

.chat-list_talk .chat-list-sub__txt_link.accent {
	opacity: 1;
}

.chat-list_talk .chat-list-sub__txt {
	display: -webkit-box;
	max-height: 80px;
	-webkit-line-clamp: 5;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.asterisk {
	color: #E04136;
	font-weight: normal;
	margin-left: 4px;
}

.edit-error__txt_img-group {
	padding: 0;
}

/*************************************
**************************************
			　gallery
**************************************
*************************************/

.gallery__img-wrapper,
.note__img-wrapper{
	position: relative;
}

.gallery__icon-feed__wrapper {
	position: absolute;
	top: 16%;
	left: 6%;
	width: 60%;
	z-index: 0;
}

.gallery__icon-feed__wrapper::before {
	content: "";
	padding-top: 100%;
	display: block;
}

.gallery__icon-feed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	font-family: 'object-fit: cover;';
}

.gallery__icon-feed__wrapper .icon_play {
	position: absolute;
	top: 4%;
	right: 6%;
	width: 24px;
	height: 24px;
	font-size: 24px;
	color: #FFFFFF;
}

/*************************************
**************************************
				note
**************************************
*************************************/

/*-------subscription------*/

.note__cover-img__wrapper {
	position: absolute;
	top: 8%;
	left: 6%;
	width: 64%;
	height: 25.6%;
	z-index: 0;
}

.note__cover-img__wrapper::before {
	content: "";
	padding-top: 40%;
	display: block;
}

.note__cover-img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	font-family: 'object-fit: cover;';
}


/*-------note.html------*/
.feed-detail__flex .feed-detail__sub {
	position: relative;
	height: auto;
	padding: 0;
	transition: none;
	transform: none;
	z-index: 0;
}

.feed-detail__flex .archive__wrapper {
	height: auto;
	padding: 24px 24px 16px;
	overflow: auto;
}

.feed-detail__flex .note__wrapper {
	padding: 24px 24px 0;
}

.toggle-tab {
	display: flex;
	width: 100%;
	padding: 2px;
	border-radius: 8px;
	background: var(--alpha-text-color);
	text-align: center;
} 

.toggle-tab .archive__item {
	width: 50%;
	margin-right: 2px;
	background: transparent;
}

.toggle-tab .archive__item:last-of-type {
	margin-right: 0;
}

.toggle-tab .archive__inner {
	padding: 8px 24px;
	border-radius: 6px;
	font-size: 14px;
	white-space: nowrap;
}

.toggle-tab .archive__item::after {
	border: none;
}

.toggle-tab .archive__inner_select {
	background: var(--contents-color);
}

.contents_empty .text_br {
	display: inline-block;
}

/*-------note-detail.html------*/

.note-detail .detail {
	padding: 0;
}

.note__img__wrapper {
	position: relative;
	width: 100%;
	overflow: hidden;
}

.note-detail .note__img__wrapper {
	margin: 0 0 16px;
}

.note__img__wrapper::before {
	content: "";
	display: block;
	padding-top: 40%;
}

.note-detail .detail__title {
	padding: 0 24px;
}

.note-detail .review__container {
	margin: 16px 0 0 0;
	padding: 0 24px;
	font-size: 20px;
}

.toolchip__mask {
	content: "";
	position: fixed;
	z-index: 998;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0);
}

.toolchip {
	position: relative;
	z-index: 1;
}

.toolchip__inner {
	position: absolute;
	top: 16px;
	left: 24px;
	max-width: calc(100% - 48px);
	padding: 16px;
	border-radius: 4px;
	background-color: var(--contents-color);
	filter: drop-shadow(0px 0px 8px rgba(0,0,0,0.16));
	transform: translateZ(0);
	color: var(--text-color);
	font-size: 12px;
}

.toolchip__inner::before {
	content: "";
	position: absolute;
	left: 32px;
	bottom: 100%;
	width: 0;
	height: 0;
	border-bottom: 8px solid;
	border-color: var(--contents-color);
	border-right: 8px solid transparent;
	border-left: 8px solid transparent;
}

.review-star {
	display: inline-block;
	margin: 0 4px 0 0;
	color: #F5CB00;
}

.note-detail .review-number {
	display: inline-block;
	padding: 0 0 4px 0;
	font-size: 18px;
	color: var(--text-color);
	line-height: 1;
}

.detail__introduction {
	margin: 40px 0 48px;
	padding: 0 24px;
	opacity: .6;
}

.note-detail .more-read,
.gallery-detail .more-read {
	padding: 0 24px 48px;
}

.note-detail .more-read__title,
.gallery-detail .more-read__title {
	display: flex;
	margin: 0 0 24px;
	align-items: center;
	justify-content: center;
	white-space: nowrap;
	font-weight: bold;
}

.note-detail .more-read__title::before,
.note-detail .more-read__title::after,
.gallery-detail .more-read__title::before,
.gallery-detail .more-read__title::after {
	content: "";
	flex-grow: 1;
	border-top: 1px dashed;
	border-color: var(--light-text-color);
}

.note-detail .more-read__title::before,
.gallery-detail .more-read__title::before {
	margin-right: 1em;
}

.note-detail .more-read__title::after,
.gallery-detail .more-read__title::after {
	margin-left: 1em;
}

.note-detail .more-read__inner,
.gallery-detail .more-read__inner {
	text-align: center;
}

.note-detail .more-read__txt,
.gallery-detail .more-read__txt{
	margin-bottom: 24px;
	font-weight: bold;
}

.note-detail .more-read__txt .purchase__label_coin,
.gallery-detail .more-read__txt .purchase__label_coin {
	display: inline-block;
	padding: 0 2px 0 0;
	font-size: 16px;
	font-weight: bold;
	vertical-align: baseline;
}

.note-detail .more-read__txt .purchase__label_coin::before,
.gallery-detail .more-read__txt .purchase__label_coin::before {
	margin: 0 4px 0 0;
	font-size: 16px;
	line-height: 16px;
	vertical-align: baseline;
}

.note-detail .btn__announce,
.gallery-detail .btn__announce {
	margin: 0 0 8px;
	color: #E04136;
	font-size: 14px;
	font-weight: bold;
}

.note-detail .form__btn,
.gallery-detail .form__btn {
	margin: 0 auto;
}

.note-detail .proposal__link,
.gallery-detail .proposal__link {
	background: var(--primary-color);
	text-align: center;
}

.note-detail .proposal__txt-link,
.gallery-detail .proposal__txt-link {
	color: var(--text-color);
}

.review-form {
	width: 100%;
	padding: 0 24px;
	text-align: center;
}

.review-form__inner {
	padding: 24px 16px;
	border: 1px solid;
	border-color: var(--alpha-text-color);
	border-radius: 4px;
	background-color: var(--contents-color);}

.review__txt {
	margin: 0 0 40px;
	font-size: 16px;
	font-weight: bold;
}

.review-star__list {
	margin: 0 0 24px;
	font-size: 0;
	letter-spacing: 0;
	list-style: none;
}

.review-star__item {
	display: inline-block;
	width: 40px;
	height: 40px;
	margin: 0 8px 0 0;
	cursor: pointer;
}

.review-star__item:last-of-type {
	margin-right: 0;
}

.review-star__item > span::before {
	font-size: 40px;
}

.review-star__item > .icon_star_empty {
	color: var(--light-text-color);
}

.review-star__item > .icon_star_full {
	color: #F5CB00;
}

.form__btn_cover::before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #FFFFFF;
	opacity: .6;
	z-index: 1;
}

/*-------note-purchased.html------*/

.note-purchased .note__wrapper {
	max-width: none;
}

/*-------gallery-detail.html------*/

.gallery .page__wrapper {
	padding: 40px 0;
}

.gallery .detail__title {
	max-width: 800px;
	padding: 40px 24px 0;
	margin: 0 auto;
	text-align: center;
}

.gallery .detail__introduction {
	max-width: 800px;
	margin: 16px auto 48px;
	padding: 0 24px;
	text-align: center;
}

.gallery .detail__img-wrapper {
	margin: 40px auto 0;
	border-radius: 6px;
	overflow: hidden;
	box-shadow: 0px 0px 20px 0px rgb(0 0 0 / 20%);
}

.gallery .detail__img-wrapper_square,
.gallery .detail__img-wrapper_wide {
	position: relative;
	width: 160px;
	height: 160px;
	padding-top: 160px;
	padding-right: 160px;
	margin: 0 auto;
	border-radius: 6px;
	overflow: hidden;
	object-fit: cover;
}

.gallery .detail__img-wrapper_wide {
	width: 285px;
	height: 160px;
	padding-top: 160px;
	padding-right: 285px;
}

.gallery .detail__video {
	margin: 0;
	border-radius: 6px;
	overflow: hidden;
}

.gallery .detail__img {
	margin: 0;
}

.gallery .detail__txt {
	margin: 16px 0 0;
	padding: 0;
	font-size: 14px;
	text-align: center;
}

.gallery .detail__link {
	color: var(--text-color);
	text-decoration: underline;
}

.gallery .more-read {
	max-width: 800px;
	margin: 0 auto;
}

@media screen and (min-width: 768px) {
	
	/*------subscription.html-lottery-----*/
	
	.scratch-card__inner {
		position: relative;
		max-width: 560px;
	}

	.subscription__wrapper .scratch-card__item {
		padding: 3em 24px;
	}
	
	.scratch-card__item {
		padding: 48px 100px;
	}
	
	/*-------note.html------*/
	.feed-detail__flex {
		display: flex;
	}
	
	.feed-detail__flex .feed-detail__main {
		margin: 0 auto;
		padding: 0 0 80px 40px;
	}

	.feed-detail__flex .feed-detail__sub {
		padding: 0 0 40px;
	}

	.feed-detail__flex .archive__wrapper {
		padding: 8px 0;
	}

	.feed-detail__flex .toggle-tab {
		display: block;
		width: auto;
		padding: 0;
		background: transparent;text-align: left;
	} 

	.feed-detail__flex .note__wrapper {
		padding: 0;
	}

	.feed-detail__flex .archive__item {
		width: auto;
		margin: 0;
	}
	
	.feed-detail__flex .archive__inner_select::before {
		content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		width: 4px;
		height: 20px;
		margin: auto;
		border-radius: 3px;
		background: var(--primary-color);
	}
	
	.feed-detail__flex .archive__item::after,
	.feed-detail__flex .archive__date::after {
		content: none;
	}

	.toggle-tab .archive__inner {
		border-radius: 0;
	}

	.toggle-tab .archive__inner_select {
		background: transparent;
	}
	
	/*-------note-detail.html------*/

	.toolchip__mask {
		display: none;
	}
	
	.toolchip__inner {
		left: 0;
		max-width: none;
		padding: 16px 40px 16px 16px;
	}
	
	.checkbox__input:checked ~ .toolchip {
		display: none;
	}

	.toolchip .close-btn {
		display: block;
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;width: 40px;
		height: 40px;
		margin: auto;
		text-align: center;
		cursor: pointer;
	}

	.toolchip .close-btn::before,
	.toolchip .close-btn::after {
		content:"";
		display: block;
		position: absolute;
		top: 50%;left: 50%;
		width: 14px;
		height: 14px;
		line-height: 14px;
		transform: translate(-50%,-50%);
	}
	
	.toolchip .close-btn::before{
		border: solid 1px;
		border-color: var(--text-color);
		border-radius: 50%;
	}

	.toolchip .close-btn::after {
		content: "\e90f";
		color: var(--text-color);
		font-family: 'icon'!important;
		font-size: 10px;
	}
	
	.note-detail .detail__title,
	.gallery-detail .detail__title,
	.detail__introduction,
	.note-detail .review__container,
	.note-detail .more-read,
	.review-form {
		padding-right: 0;
		padding-left: 0;
	}
	
	.note-detail .detail,
	.gallery-detail .detail {
		padding: 0 40px 24px;
	}
	
	.form__btn_cover:hover {
		opacity: 1!important;
	}
	
	/*-------note-purchased.html------*/

	.note-purchased .note__wrapper {
		padding: 0;
	}
	
	/*-------gallery-detail.html------*/
	
	.gallery .page__wrapper {
		padding: 80px 40px;
	}
	
	.gallery .detail__img-wrapper_square {
		width: 320px;
		height: 320px;
		padding-top: 320px;
		padding-right: 320px;
	}
	
	.gallery .detail__img-wrapper_wide {
		width: 320px;
		height: 180px;
		padding-top: 180px;
		padding-right: 320px;
	}
	
	
	.gallery .detail__introduction {
		text-align: left;
	}
	
	.gallery .detail__title {
		font-size: 32px;
	}
	
	.gallery .detail__items {
		display: flex;
		max-width: 1080px;
		padding: 0;
		margin: 160px auto 0;
	}
	
	.gallery .detail__items:nth-of-type(1) {
		margin: 80px auto 0;
	}
	
	.gallery .detail__items:nth-of-type(even) {
		flex-direction: row-reverse;
	}
	
	.gallery .detail__item_img {
		width: 60%;
	}
	
	.gallery .detail__items .detail__img-wrapper {
		position: relative;
		z-index: 2;
		margin: 0;
		border-radius: none;
		overflow: visible;
		box-shadow: none;
	}
	
	.gallery .detail__img {
		box-shadow: 0px 0px 20px 0px rgb(0 0 0 / 20%);
	}
	
	.gallery .detail__video {
		border-radius: 0;
	}
	
	.gallery .detail__video video {
		box-shadow: 0px 0px 20px 0px rgb(0 0 0 / 20%);
	}
	
	.gallery .detail__items .detail__txt {
		display: table;
		width: 40%;
		padding: 40px 0 0 64px;
		margin: 0;
		font-size: 14px;
		text-align: left;
	}
	
	.gallery .detail__items:nth-of-type(even) .detail__txt {
		padding: 40px 64px 0 0;
	}
	
	.gallery .detail__img-wrapper::after {
		position: absolute;
		z-index: -1;
		right: -30px;
		bottom: -30px;
		content: "";
		display: block;
		width: 230px;
		height: 230px;
		background: var(--primary-color);
	}
	
	.gallery .detail__items:nth-of-type(even) .detail__img-wrapper::after {
		left: -30px;
	}
	
	.gallery .share__wrapper {
		margin: 120px 0 0;
	}
	
}

/*************************************
**************************************
				short cut
**************************************
*************************************/

.shortcut .page {
	padding: 0;
}

.shortcut .members-bg__wrapper_bg {
	margin: 0;
}

.shortcut-headline {
	position: absolute;
	bottom: 8px;
	width: 100%;
	padding: 0 24px;
	text-align: center;
	z-index: 1;
} 

.shortcut__container {
	position: relative;
	padding: 0 24px;
} 

.shortcut-flow__item{
	margin: 16px auto 0;
	padding: 24px;
	border-radius: 16px;
	background: var(--contents-color);
} 

.shortcut-flow__headline {
	width: 138px;
	margin: auto;
	padding: 7px 8px 4px;
	border-radius: 20px;
	background: var(--accent-color);
	font-family: 'Hind', sans-serif;
	text-align: center;
	letter-spacing: .08em;
	color: var(--contents-color);
}

.shortcut__txt {
	margin: 16px auto;
	font-size: 16px;
	text-align: center;
	color: var(--text-color);
}

.txt__accent {
	color: var(--accent-color);
}

.shortcut__txt_fc {
	font-size: 18px;
	color: var(--text-color);
}

.shortcut__txt .icon_add {
	display: inline-block;
	margin: 0 2px;
	vertical-align: text-bottom;
}

.shortcut-img__wrapper {
	max-width: 280px;
	margin: auto;
}

.shortcut-img {
	width: 100%;
}

.shortcut-result {
	margin: 24px auto 0;
}

/*************************************
**************************************
	          service-end
**************************************
*************************************/

.page__container_service-end {
	min-height: calc(100vh - 120px);
}

.service-end__inner {

	position: absolute;
	top: 50%;
	left: 50%;
	width: calc(100% - 48px);
	max-width: 800px;
	margin: 0 auto;
	transform: translate(-50%, -50%);
}

.service-end__detail {
	text-align: center;
}

.service-end__title {
	margin: 0 0 8px;
	font-size: 22px;
	letter-spacing: .05em;
	font-weight: bold;
}

.service-end__sub-title {
	font-size:14px;
}

@media screen and (min-width: 768px) {
	.lottery__head {
		display: flex;
		justify-content: center;
		align-items: start;
		padding: 6% 4%;
		text-align: left;
		margin-top: 0;
	}
	
	.lottery__img-container {
		width: 50%;
		padding-top: 20%;
		border-radius: 16px;
	}
	
	.lottery__img-container::after {
		content: none;
	}
	
	.lottery__detail-container {
		margin-left: 4%;
		padding: 0;
	}
	.lottery__bg-grad {
		background: transparent!important;
	}
	.lottery__headline {
		font-size: 20px;
		padding: 0;
	}
	.lottery__headline_top {
		display: none;
	}

	.lottery__headline_inner {
		display: block;
	}
	.lottery__definition{
		display: flex;
		flex-wrap: wrap;
		align-items: center;
	}
	.lottery__detail-container small {
		display: inline-block;
	}
	.lottery__nav-link {
		position: static;
		display: inline-block;
		margin: 20px 0;
		color:var(--text-color);
	}
	.lottery__nav-link_collection::before {
		content: none;
	}
	.lottery__nav-link_return {
		position: absolute;
		top: -8px;
		left: 0;
		right: auto;
		z-index: 0;
	}
	.lottery__nav-link_return::before {
		font-size: 20px;
	}

	.lottery__link-txt {
		display: inline-block;
		font-weight: bold;
		padding: 8px 0;
		vertical-align: middle;
	}
	.lottery__nav-link_collection .lottery__link-txt::after {
		font-family: 'icon' !important;
		content: "\e903";
	}
	.lottery-btn__btn {
		min-width: 180px;
	}
	.lottery-btn__txt {
		font-size: 18px;
	}
	.lottery__head-btn {
		display: flex;
		flex-wrap: wrap;
		position: relative;
		padding-top: 16px;
	}
	.lottery__head-btn::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		border-top: 1px solid var(--text-color);
		opacity: .2;
	}

	.lottery__float-btn {
		display: none;
		bottom: 40px;
		right: 0;
		width: auto;
		padding: 24px 40px;
		border-radius: 16px 0 0 16px;
		text-align: center;
	}
	.lottery__float-btn .lottery-btn__detail {
		padding: 16px;
	}
	.lottery__float-btn .lottery-btn__btn {
		border-radius: 1.3em;
		font-size: 24px;
	}
	.lottery__summary {
		margin: 0 24px 80px 24px;
		padding: 40px;
		font-size: 18px;
	}

	.lottery__container {
		display: flex;
		flex-wrap: wrap;
		padding: 0;
		margin-top: 64px;
	}

	.lottery__annotation {
		position: relative;
		padding: 40px 0 0;
		margin: 0 24px;
		}

	.lottery__annotation::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		border-top: 1px solid var(--text-color);
		opacity: .2;
	}

	.grid__soldout::after {
    	font-size: clamp(0px,8vw,86px);
    }

    .lottery__contents {
		width: 50%;
		padding: 0 24px;
	}

	.lottery__contents:first-child {
		width: 100%;
		font-size: 24px;
	}

	.lottery__contents:first-child .award__contents {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		min-height: 400px;
	}

	.lottery__contents:first-child .award__column {
		width: 50%;
	}

	.lottery__contents:first-child .award__column:first-child {
		padding-right: 6%;
	}

	.award_wide {
		width: 100%;
	}

	.lottery__contents:first-child.award_wide .award__column {
		width: 100%;
	}

	.award_wide .grid__item {
		width: calc(100% / 5);
	}
	
	/*soldout1カラム*/
	.award .grid__item:only-child .grid__soldout::after {
		font-size: clamp(0px,26vw,284px);
	}
	
	/*soldout2カラム*/
	.award .grid__item:first-child:nth-last-child(2) .grid__soldout::after,
	.award .grid__item:first-child:nth-last-child(2)  ~ .grid__item .grid__soldout::after {
		font-size: clamp(0px,12vw,132px);
	}

	/*カウンター1カラム*/
	.award_digital .grid__item:only-child .grid__inner::before {
		/* font-size: clamp(0px,7.5vw,80px); */
	}
	
	/*カウンター2カラム*/
	.award_digital .grid__item:first-child:nth-last-child(2) .grid__inner::before,
	.award_digital .grid__item:first-child:nth-last-child(2)  ~ .grid__item .grid__inner::before {
		font-size: clamp(0px,17vw,188px);
	}

	.award_digital .grid__inner::before {
		font-size: clamp(0px,11vw,120px);
	}

	.award_digital.award_wide .grid__inner::before {
		font-size: clamp(0px,14vw,160px);
	}

	.award_digital.award_wide .grid__soldout::after {
		font-size: clamp(0px,10vw,110px);
	}
	.lottery-collection .feed-detail__main {
		margin: 0 auto;
		padding: 80px 0 80px 40px;
	}

	.lottery-collection .grid__item {
		width: calc(100% / 5);
	}
	.lottery-collection .feed-detail__sub ~  .feed-detail__main .grid__item {
		width: calc(100% / 3);
	}
	.lottery-collection .grid__inner::after {
		font-size: clamp(0px,15vw,170px);
	}
	.lottery-collection__container {
		padding: 0;
	}
	.lottery-collection__title {
		font-size: 24px;
	}
	.lottery-collection .archive__list .active .archive__img-wrapper::before,
	.lottery-collection .archive__list .active .archive__img-wrapper::after {
		content: none;
	}

	.lottery-collection .archive__list .active::before {
		content: "・";
		position: absolute;
		left: -16px;
		font-size: 40px;
		color: var(--primary-color);
	}
	
	.prize-detail {
		position: relative;
		flex-wrap: nowrap;
		padding-top: 56px;
	}
	.prize-detail__img-wrapper {
		width: 50%;
		max-width: none;
		margin: 0;
	}
	.prize-detail__img {
		max-height: none;
	}
	
	.prize-detail__detail {
		width: 50%;
		margin: 0 0 0 40px;
	}

	.prize-detail__headline {
		font-size: 30px;
	}
	
	.prize-detail__main {
		padding-right: 4px;
		font-size: 72px;
		vertical-align: middle;
		line-height: 1;
	}

	.prize-detail__main_last {
		font-size: 42px;
	}


	.prize-detail__title {
		font-size: 22px;
	}

	.lottery-prize__download {
		top: 10px
	}
}


@media screen and (min-width: 1080px) {

	.lottery-collection .grid__inner::after {
		font-size: clamp(0px,16vw,170px);
	}
}

@media screen and (min-width: 1280px) {

	.lottery__headline {
		font-size: 24px;
	}
	
	.chat__container .chat__item {
		min-width: 268px;
	}
}

/*********************
		order
*********************/
.order {
	z-index: 999;
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background: rgba(0, 0, 0, .8);
}

.order_announce {
	top: auto;
	background: transparent;
}

.order__container {
	position: absolute;
	bottom: 0;
	width: 100%;
	padding: 24px 24px 0;
	border-top-left-radius: 8px;
	border-top-right-radius: 8px;
	box-shadow: -3px 0px 10px 4px rgba(0,0,0,0.16);
}

.order__title,
.order__txt {
	max-width: 400px;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
}

.order__title {
	margin-bottom: 8px;
	font-weight: bold;
}

.order__txt {
	font-size: 12px;
	line-height: 1.5;
}

.order .form__btn {
	margin: 16px auto 24px;
}

/*************************************
**************************************
				download
**************************************
*************************************/

.download__img-wrapper {
	position: relative;
	padding-top: 56.25%;
}

.download__img {
	object-fit: cover;
	font-family: 'object-fit: cover;';
}

.download__container {
	position: relative;
	width: calc(100% - 48px);
	max-width: 600px;
	margin: -24px auto 40px;
	padding: 32px 16px;
	border-radius: 8px;
	text-align: center;
	box-shadow: 0px 0px 20px 0px rgba(0,0,0,0.1);
}

.download__headline {
	margin-bottom: 32px;
	font-size: 18px;
	font-weight: bold;
}

.download__headline br {
	display: none;
}

.download__txt {
	font-size: 16px;
	margin-bottom: 24px;
}

.download__txt br {
	display: none;
}

.download__link {
	padding: 1em 3em;
	color: #FFFFFF;
	font-size: 18px;
	font-weight: bold;
	line-height: 1;
	border-radius: 1.5em;
}

.download__badge-wrapper {
	display: flex;
	margin-bottom: 20px;
	justify-content: center;
}


.download__badge {
	margin: 0 6px;
}

.download__badge-img {
	max-width: 100%;
	height: 48px;
}


.download__txt-link {
	text-decoration: underline;
	font-size: 14px;
}

/*************************************
**************************************
			cancel-membership
**************************************
*************************************/

.fanclub-details__wrapper {
	display: flex;
	align-items: center;
}

.fanclub-details__wrapper .form-img__wrapper {
	width: 68px;
	height: 68px;
	margin: 0 auto;
}

.fanclub-details__inner {
	flex: 1;
	padding: 0 0 0 8px;
}

.fanclub-details__item {
	font-size: 14px;
}

.fanclub-details__item_name {
	font-size: 18px;
	font-weight: bold;
}

.fanclub-details__item_number span,
.fanclub-details__item_coin span {
	padding: 0 0 0 4px;
	font-size: 16px;
	font-weight: bold;
}

.fanclub-details__item_coin {
	padding: 24px 0;
	text-align: center;
}

/****fanclub-detail  end****/

.cancel-fanclub {
	margin: 0 0 40px;
}

.cancel-fanclub .form__caption {
	text-align: center;
}

.cancel-fanclub .fanclub-details__inner {
	padding: 16px 0 0;
}

.cancel-fanclub .fanclub-details__wrapper {
	display: block;
	text-align: center;
}

.service-list {
	max-width: 400px;
	padding: 0 16px;
	margin: 0 auto 16px;
	font-size: 14px;
	border-radius: 4px;
	list-style: none;
}

.service-list__item {
	display: flex;
	justify-content: space-between;
	padding: 16px 0;
	border-bottom: 1px solid #C7C7CC;
}

.service-list__item:last-of-type {
	border: none;
}

.cancel-membership .form__read {
	margin: 0 0 16px;
}

.cancel-membership .info__link {
	display: inline-block;
	margin: 0 0 40px;
}

.checkbox__wrapper {
	margin: 32px 0 8px;
}

.form__checkbox {
	display: inline-block;
}

.checkbox__input {
	display: none;
}

.form__checkbox_icon::before {
	content: "\e90e";
	display: inline-block;
	color: var(--text-color);
	opacity: .4;
	font-size: 24px;
	font-family: "icon";
	line-height: 1;
}

.checkbox__input:checked ~ .form__checkbox_icon::before {
	color: var(--primary-color);
	opacity: 1;
}

.form__checkbox_icon,
.checkbox__txt {
	display: inline-block;
	cursor: pointer;
	vertical-align: middle;
}

.form__checkbox_icon {
	line-height: 1;
}

.checkbox__txt {
	padding-left: 4px;
	font-size: 14px;
	font-weight: bold;
}

/*************************************
**************************************
			cancel-completed
**************************************
*************************************/

.cancel-completed {
	text-align: center;
}

.cancel-completed .page__headline {
	margin: 0;
	padding: 40px 0 0;
	text-align: center;
	font-size: 60px;
	font-weight: normal;
}

.cancel-completed .form__read br:nth-of-type(2) {
	display: none;
}

.cancel-completed .form__read_caution {
	margin: 24px 0 16px;
	font-size: 14px;
	text-align: left;
}

/*************************************
**************************************
			expired
**************************************
*************************************/

.page__container_expired .page__headline_nav {
	position: static;
	margin: 0 0 24px;
	text-align: center;
}

/*************************************
**************************************
			phone-number
**************************************
*************************************/

.form__label-wrapper .form__label_show {
	position: static;
	display: inline-block;
}

.unregistered {
	position: relative;
	margin: 0 0 0 4px;
	padding: 0 0 0 18px;
	color: #E04136;
	font-size: 12px;
	font-weight: bold;
}

.unregistered::before {
	position: absolute;
	top: 1.5px;
	left: 2px;
	z-index: 2;
	font-size: 10px;
	font-weight: bold;
	color: #FFF;
	/*color: var(--contents-color);*/
}

.unregistered::after {
	content: "";
	position: absolute;
	top: -1px;
	left: 0;
	width: 14.5px;
	height: 14.5px;
	border-radius: 9px;
	background: #E04136;
}

.form__country-label {
	position: static;
	width: 98px;
	height: 40px;
	margin: 0;
	padding: 0;
	box-shadow: none;
	border-radius: 0px;
}

.form__country-number {
	position: relative;
	display: flex;
	justify-content: space-between;
	width: 100%;
	padding: 8px 8px 8px 0;
}

.country-number__short {
	opacity: .6;
}

.form__input_phone-number {
	flex: 1;
}

.phone .form__txt {
	text-align: left;
}

.phone .form__btn:disabled,
.auth-code .form__btn:disabled {
	position: relative;
	pointer-events: none;
}

.phone .form__btn:disabled::before,
.auth-code .form__btn:disabled::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	background:rgba(255,255,255,.5);
	border-radius: 4px;
}

.select-country {
	width: 100%;
	height: 100%;
	padding: 24px 0;
	border-radius: 0;
}

.select-country__close {
	top: 24px;
	right: 24px;
	color: var(--text-color);
}

.select-country__list {
	height: 100%;
	padding: 0 0 12px 0;
}

.select-country__item {
	margin: 0;
	border-bottom: 1px solid #c7c7cc;
}

.select-country__label {
	padding: 16px 24px;
}

.select-country__label input {
	display: none;
}

.select-country__name {
	flex: 1;
}

.select-country__number {
	min-width: 50px;
	text-align: right;
}

.triangle::after {
	content: "";
	display: inline-block;
	margin: 0 0 2px 4px;
	border-top: 8px solid;
	border-color: var(--primary-color);
	border-right: 6px solid transparent;
	border-left: 6px solid transparent;
	pointer-events: none;
}

.form__country-label.triangle::after {
	display: none;
}

/**********************************
			new
**********************************/

.tag-icon {
	margin-left: 8px;
	font-size: 16px;
}

/**********************************
			ticket
**********************************/

.ticket__wrapper {
	margin: 0 24px 24px ;
	font-size: 14px;
}

.ticket {
	display: block;
}

.ticket__playguide {
	border-radius:6px 6px 0 0;
	background: var(--primary-color);
	color: #FFF;
	text-align: center;
	padding: 8px 12px;
}

.ticket__txt-wrapper {
	border: .5px solid;
	border-radius:0 0 6px 6px;
	color: var(--primary-color);
	padding: 8px 12px;
}

.ticket__txt {
	position: relative;
	padding-right: 16px;
}

.ticket__txt::after {
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%) rotate(-135deg);
	width: 8px;
	height: 8px;
	border-bottom: 1px solid;
	border-left: 1px solid;
	content: "";
}

/*************************************
**************************************
			responsive
**************************************
*************************************/
@media screen and (max-width: 359px) {
	.form__txt_long {
		text-align: left;
	}

	.drawer__btn {
		font-size: 16px;
		padding: 16px 12px;
	}
}

@media screen and (max-width: 374px) {
	.enroll__link {
		padding: .8em .6em;
	}
	
	/*watanabe.css*/
	
	.chat .member-modal {
		top: 60px;
		transform: translateX(-50%);
	}

	.chat .members__txt {
		max-height: 40px;
	}
}

@media screen and (max-width: 420px) {
	
	.play-modal__img-wrapper {
		width: 260px;
		padding-top: 260px;
	}

	#lastPrize {
		width: 100%;
		height: 430px;
		top: 24px;
		transform: translate(-50%, 0) scale(1.6);
	}
}

@media screen and (max-width: 767px) {
	
	.alert__action {
		max-width: none;
	}

	.logo__wrapper {
		height: 100%;
	}
	
	.menu .simplebar-mask {
		overflow: visible;
	}
	.hero {
		display: none;
	}
	
	nav.header-nav {
		display: none;
	}
	
	.header .top__title_sub {
		display: none;
	}
	
	.page__wrapper {
		background: transparent!important;
	}
	
	.proposal__inner {
		background: rgba(255, 255, 255, 0.9)!important;
	}

	.charges__button {
		color: #FFFFFF !important;
	}
	
	.search__field {
		color: #343434!important;
	}

	.record__item:last-child {
		padding-bottom: 0;
		margin-bottom: 0;
		border-bottom: none;
	}
	
	/*********************
		  chat
	*********************/
	
/* 	.chat-search__wrapper {
		padding-top: 46px;
	}  */
	
	
	.tag-list__wrapper .page__headline {
		position: inherit;
		font-size: 16px;
		text-align: center;
		line-height: 16px;
		padding: 24px 0 8px 0px;
		margin: 0;
	}
	
	.edit-room .form__input {
		padding: 8px;
	}
	
	/*********************
		  feed-detail
	*********************/
	.feed-detail__sub,
	.feed-detail__main {
		max-height: none !important;
	}
	
	
	/*********************
			mail
	*********************/
	
	.timeline__grid-group {
		height: auto!important;
	}
	
	.mail {
		position: static!important;
	}	

	/*********************
			 store
	*********************/
	.grid__soldout {
		border-radius: 0;
	}
	
	.gallery__item .grid__soldout::after {
		font-size: 22vw;
	}

	.gallery__item:nth-of-type(1) .grid__soldout::after {
		font-size: 44vw;
	}

	/*********************
			lottery
	*********************/
	.lottery-btn__inner{
		display: flex;
		width: 100%;
	}

	.floating_lottery .floating__inner {
		padding: 32px 24px;
	}

	.floating__header {
		padding: 32px 24px 24px;
	}

	.lottery__float-btn .lottery-btn__btn {
		font-size: 22px;
		padding:.8em 0.2em;
	}

	#morningcall .subscription__wrapper{
		width: 88%;
	}
}


@media screen and (max-width: 1279px) {
	/*********************
		  feed-detail
	*********************/
	
	.detail__inner,
	.detail__pickup,
	.note-detail__inner {
		max-height: none !important;
	}

	.detail__pickup .simplebar-content-wrapper {
		height: 100%!important;
	}
}

@media screen and (min-width: 768px) {
	
	.contents_empty {
		font-size: 32px;
		background: rgba(0,0,0,.1)!important;
	}

	.page {
		max-width: none;
		margin: 0 auto;
		padding: 94px 0 0;
	}

	.page_home {
		padding-bottom: 0 !important;
	}

	.page_home .header {
		position: fixed!important;
		top: 0!important;
		opacity: 1;
	}
	
	.caption__wrapper {
		width: 60%;
	}
	
	.position-left {
		left: 10%;
	}

	.header__banner {
		display: none;
	}

	.proposal {
		position: relative;
		z-index: 1;
	}

	.proposal__txt {
		color: #FFFFFF;
	}

	.proposal__txt-link {
		display: inline-block;
		max-width: none;
		margin-top: 24px;
		border-bottom: none;
		text-decoration: underline;
		font-size: 14px;
	}
	
	.proposal .proposal__txt-link {
		color: #FFFFFF;
	}

	.proposal__inner {
		position: relative;
		padding: 88px 40px;
	}
	
	.proposal__badge-img {
		height: 52px;
	}
	
	.change-plan__inner {
		padding: 16px 0 24px;
	}

	.proposal__title {
		display: inline-block;
		margin-bottom: 32px;
		font-size: 36px;
		font-weight: bold;
		color: #FFFFFF;
	}

	.proposal__link {
		display: block;
		width: 320px;
		margin: 0 auto;
		padding: 26px 24px;
		border-radius: 50px;
		background: #FFFFFF !important;
		color: #343434;
		font-weight: bold;
	}

	.proposal__txt-link_side {
		color: inherit;
		text-align: left;
	}

	.proposal .ellipsis {
		white-space: normal;
	}
	
	.header {
		display: flex;
		height: auto;
		align-items: center;
		min-height: 94px;
	}

	.header__logo {
		max-width: 100%;
		max-height: 70px;
		height: auto;
	}

	.header__title {
		text-align: left;
		padding: 0 12px 0 24px;
		display: block;
		width: 30%;
		vertical-align: top;
		opacity: 1 !important;
	}

	.header__title_sub {
		position: relative;
		margin-bottom: 12px;
		top: auto;
		font-size: 16px;
	}
	
	.header-nav__item {
		position: relative;
		display: inline-block;
	}
	.header-nav__item::after {
		content: "";
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		height: 14px;
		border-right: .5px solid;
		border-color: var(--alpha-text-color);
		margin: auto;
	}
	
	.header-nav__item:last-child::after {
		content: none;
	}
	
	.header-nav__link {
		display: inline-block;
		padding: 0 16px;
		line-height: 28px;
		font-size: 14px;
		white-space: nowrap;
	}

	.primary.header-nav__link {
		font-weight: bold;
	}
	
	.header-nav__unread {
		position: absolute;
		top: 4px;
		right: 8px;
		display: inline-block;
		width: 4px;
		height: 4px;
		border-radius: 50%;
	}
	
	.header-nav {
		display: inline-flex;
		padding: 8px 24px;
		width: 70%;
		justify-content: flex-end;
		align-items: center;
	}

	.header-nav__list {
		text-align: right;
	}
	
	.avatar {
		position: relative;
		display: flex;
		width: 192px;
		height: 50px;
		margin-left: 24px;
		padding: 0 16px 0 4px;
		border-radius: 25px;
		color: #343434;
		align-items: center;
		flex-shrink: 0;
	}
	.avatar::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		margin: auto;
		display: block;
		width: calc(100% - 4px);
		height: calc(100% - 4px);
		border-radius: 23px;
		background: #FFFFFF;
	}

	.avatar__img-wrapper {
		height: 42px;
		padding-right: 42px;
		border-radius: 50%;
		vertical-align: middle;
	}
	
	.avatar__name {
		position: relative;
		display: -webkit-box;
		padding-left: 10px;
		-webkit-box-orient: vertical;
		-webkit-line-clamp: 2;
		overflow: hidden;
		line-height: 1.2;
		font-size: 14px;
	}

	.mask {
		background: linear-gradient(0deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.6) 100%);
	}

	.bg {
		opacity: 1 !important;
	}
	
	.menu {
		position: absolute;
		z-index: 1;
		top: 0;
		right: 0;
	}

	.header-bar__icon {
		display: none;
	}

	.nav {
		display: none;
	}
	
	.nav__list {
		display: block;
		height: auto;
		padding: 8px 24px;
		margin-bottom: 24px;
	}

	.nav__text {
		position: relative;
		left: 0;
		padding-left: 32px;
		font-size: 16px;
		text-align: left;
		font-weight: normal;
	}

	.nav__item {
		letter-spacing: .03em;
		width: auto;
	}
	
	.nav__link {
		padding: 16px 0;
	}

	.nav__link::before {
		position: absolute;
	}
	
	.page__container,
	.page__container_premium.subscription,
	.page__container_expired {
		/* background: var(--contents-color); */
	}
	
	.page__container_timeline,
	.page__container_mypage,
	.page__container_period,
	.subscription {
		/* background: var(--background-color); */
	}
	
	.download {
		background: transparent;
	}
	
	.page__wrapper {
		padding: 80px 40px;
		max-width: 1080px;
		margin: 0 auto;
	}

	.page__wrapper_full {
		max-width: none;
	}

	.page__wrapper_detail {
		max-width: 1080px;
		margin: 0 auto;
		padding: 0;
	}

	.page__wrapper::before {
		content: "";
		position: absolute;
		width: 100%;
		height: 100%;
		top: 0;
		left: 0;
		background: inherit;
		z-index: -1;
	}

	.page__headline {
		position: static;
		display: block;
		margin: 0 auto 50px;
		font-size: 32px;
		font-weight: bold;
		text-align: center;
	}

	.page__sub-txt {
		font-size: 16px;
		margin-top: 24px;
	}
	
	.details {
		min-height: 700px;
	}
	
	.history__wrapper {
		padding: 80px 0;
	}

	.biography__wrapper + .history__wrapper {
		padding: 0 0 80px;
	}

	.history_list {
		max-width: 848px;
		margin: 0 auto;
		padding: 0 40px;
	}
	
	.history__item {
		padding: 24px 0;
		border-bottom: dotted 1px;
		border-color: var(--alpha-text-color);
	}
	
	.history__item:last-child {
		padding: 24px 0;
		border-bottom: none;
	}
	
	.drawer {
		left: -1px;
		width: 50%;
		max-height: none;
		height: 100%;
		overflow: hidden;
		border-top-left-radius: 4px;
		border-top-right-radius: 4px;
		-webkit-transform: translate(-100%, 0%);
				transform: translate(-100%, 0%);
	}
	
	#drawer-switch:checked ~ .drawer {
		max-height: 100%;
		transition: transform 0.2s ease;
	}

	#drawer-switch:checked ~ .drawer__mask {
		display: block;
	}

	.drawer_popup {
		top: 50%;
		bottom: auto;
		left: 0;
		right: 0;
		width: 400px;
		height: auto;
		margin: auto;
		border-radius: 6px;
		z-index: -1;
		opacity: 0;
		transform: translateY(-50%);
	}

	#drawer-switch:checked ~ .drawer_popup {
		max-height: 500px;
		z-index: 999;
		opacity: 1;
		transition: transform 0.2s ease;
	}

	.drawer-item__wrapper {
		height: 100%;
		padding-bottom: 0;
	}

	.drawer__list {
		height: auto;
		max-height: calc(100% - 160px);
		margin-bottom: 0;
	}
	
	.drawer-btn__wrapper {
		position:relative;
	}

	.drawer .matter__list {
		max-height: 250px;
		overflow: hidden;
		overflow-y: scroll;
	}

	.simple-pager {
		margin: 0;
		font-size: 16px;
	}

	.simple-pager__inner {
		padding: 0 32px;
	}

/************************
          detail
************************/
	
	.detail {
		max-width: 880px;
		margin: 0 auto;
		padding: 0 40px 24px;
	}

	.detail__inner,
	.note-detail__inner {
		padding: 80px 0 0;
	}
	
	.detail__title {
		padding: 0 0 8px;
	}

	.detail__post-date {
		margin: 0 0 24px;
	}
	
	.detail__txt {
		padding: 0;
	}

	.detail__card {
		max-width: 506px;
		margin: 16px 0;
	}
	
	.ticket__wrapper {
		max-width: 506px;
		margin: 0 0 24px;
	}

	.card__thumbnail-wrapper {
		width: 24%;
		padding-top: 24%;
	}
	
	.share__wrapper {
		margin: 40px 0 0;
	}
	
	.detail__img_noimage {
		position: relative;
		display: block;
		height: 380px;
	}
	
	.noimage__inner {
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
	}
	
	.noimage__inner_logo {
		width: 160px;
	}
	
	.noimage__inner_text {
		width: 300px;
		font-size: 20px;
		text-align: center;
	}

	.detail .pager_text {
		padding: 24px 0;
	}

	.detail__pickup {
	    padding: 24px 0;
	}

	.detail__pickup .pager_text {
		margin: 16px 0 0 !important;
	}

	/************************
		SCHEDULE detail
	************************/
	
	.detail__items {
		margin: 0 0 16px;
	}

	.detail__items ~ .detail__title{
		padding: 0 0 24px;
	}

	/************************
			detail-feed
	************************/

	.header-bar__archive,
	.archive-switch__close {
		display: none !important;
	}
	
	.feed-detail {
		background: var(--contents-color);
	}
	
	.feed-detail .page__wrapper {
		display: flex;
		width: 100vw;
		padding: 0 0 0 40px;
	}

	.feed-detail .lottery-collection {
		display: flex;
	}
	
	
	.feed-detail_full .page__wrapper {
		padding: 0;
	}
	
	.feed-detail__sub {
		position: static;
		top: auto;
		left: auto;
		max-width: 280px;
		padding: 80px 0 40px;
		transform: none;
		background: transparent;
	}

	.feed-detail .page__wrapper::after {
		content: "";
		display: block;
		clear: both;
	}

	.feed-detail__search {
		position: static;
		padding: 0;
		background: transparent !important;
	}
	
	.archive__wrapper {
		height: calc(100vh - 355px);
		padding: 8px 0;
	}
	
	.page__sub-headline {
		position: relative;
		display: block!important;
		padding: 0 16px 10px;
		font-weight: bold;
	}
	
	.page__sub-headline::after {
		position: absolute;
		bottom: 0;
		left: 0;
		content: "";
		display: block;
		width: 100%;
		height: 1px;
		background: var(--alpha-text-color);
	}
	
	.archive__item {
		background: none;
	}
	
	.archive__inner {
		padding: 8px 16px!important;
	}
	
	.archive__inner_select {
		position: relative;
		font-weight: bold;
		color: var(--primary-color);
	}

	.archive__inner .archive__inner_select {
		background: transparent;
	}
	
	.archive__inner_select::before {
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		margin: auto;
		content: "";
		width: 4px;
		height: 20px;
		background: var(--primary-color);
		border-radius: 3px;
	}

	.archive__item::after,
	.archive__date::after {
		content: none;
	}

	.feed-detail__sub .pager_text {
		margin: 8px 0 0 0;
	}
	
	.feed-detail__main {
		flex: 1;
		width: 100%;
		height: 100%;
		margin: 0 calc(50% - 50vw) 0 0;
		padding: 80px 60px 80px 40px;
		overflow-y: scroll;
	}

	.feed-detail_full .feed-detail__main {
		max-width: 760px;
		margin: auto;
		padding: 80px 40px;
	}
	
	.feed-detail__main::-webkit-scrollbar {
		display: none;
	}

	.feed-detail__inner {
		max-width: 680px;
	}

	.feed-detail .page__headline {
		margin: 0 0 40px 16px;
		text-align: left;
	}

	.feed-detail_full .page__headline {
		margin: 0 0 40px;
		text-align: center;
	}

	.lottery .page__headline {
		display: block;
		width: 100%;
		text-align: center;
	}
	
	.search-field__wrapper_button .search__field {
		background: #f0f0f0;
		border-bottom: none;
	}
	
	.search-field__wrapper_button {
		position: absolute;
		top: 80px;
		left: 0;
		padding: 4px 40px;
		background: var(--contents-color);
	}

	.search-field__wrapper_modal {
		position: relative;
		max-width: 560px;
		right: 0;
		margin: 0 auto;
		padding: 0;
	}

 	.search-modal-body.news__wrapper {
	 	top: 38px;
	 	max-width: 560px;
	 	padding: 24px 26px 24px 0;
	}
	
	.search-modal {
		top: 186px;
		right: 0;
		width: calc(100% - 80px);
		max-width: 800px;
		height: calc(100vh - 254px);
		max-height: 800px;
		margin: auto;
		padding: 80px 120px;
		border-radius: 6px;
		overflow: hidden;
	}

	.search-modal,
	.modal__mask {
		z-index: 998;
	}

	.search-modal__search {
		position: static;
		padding: 0;
		background: transparent !important;
	}
	
	.feed-detail__list {
		padding: 0;
	}
	
	.feed-detail__item {
		list-style: none;
	}

	.feed-detail__main .pager_text {
		margin: 0 0 16px 0;
		background: var(--contents-color);
	}
	
	.feed-detail__main .pager__item {
		width: 40%;
	}
	
	.feed-detail .more-txt {
		padding: 0;
	}

	.detail__group ~ .more-txt {
		padding: 0 0 8px;
	}

	.detail__iframe {
		padding-bottom: 56.25%;
		width: 100%;
		margin-left: 0;
	}

	.detail__video,
	.detail__video video {
		max-height: 382px;
	}
	/************************
			PRODUCT
	************************/
	
	.product {
		/*max-width: 800px;*/
		margin: 0 auto;
	}
	
	.product::before {
		content: none;
	}
	
	.product__img {
		float: left;
		max-width: 380px;
		margin-top: 0;
	}
	
	.product__wrapper {
		float: right;
		width: calc(100% - 380px);
		padding: 0 0 0 40px;
	}
	
	.product__title {
		padding: 0 0 8px 0;
	}
	
	.product__release-date {
		padding: 0 0 0 0;
	}
	
	.product__wrapper .detail__txt {
		float: none;
		width: 100%;
	}
	
	.transparent {
		background: inherit!important;
		box-shadow: 0px 0px 1px 0px #C7C7CC;
	}

	.settings__inner {
		max-width: 600px;
		margin: 0 auto;
		padding: 24px 0 24px 0;
	}
	
	.settings__inner_wide {
		max-width: 880px;
	}
	
	.settings__inner_inline {
		position: relative;
		margin: 0 0 0 auto;
		width: calc(100% - 300px);
	}
	
	.settings__list {
		margin-bottom: 24px;
	}
	
	.alert__inner {
		padding: 60px 20px;
	}

	.floating {
		top: 50%;
		left: 50%;
		bottom: auto;
		width: calc(100% - 48px);
		max-width: 480px;
		transform: translate(-50%, -50%);
		border-radius: 10px;
	}

	.floating__close-btn {
		top: -40px;
		right: -8px;
		color: #FFF;
		font-size: 32px;
	}

	.floating__title {
		margin-bottom: 40px;
	}

	.floating .btn-list {
		max-width: 380px;
		margin: 0 auto;
	}
	
	.form__section_account {
		margin-top: 72px;
		padding-top: 40px;
		border-top: 1px solid;
		border-color: var(--alpha-text-color);
	}
	
	.form__img-group {
		display: flex;
		align-items: center;
		margin: 40px 0 24px;
	}
	
	.form__file,
	.form__canvas,
	.form-img__wrapper {
		width: 120px;
		height: 120px;
		margin: 0 auto 0 0;
	}

	.form__file-label {
		display: inline-block;
		width: auto;
		height: auto;
		margin-bottom: 8px;
		padding: .5em 1em;
		color: #FFF;
		line-height: 1;
		font-size: 14px;
		opacity: 1;
		border-radius: 1em;
		
	}

	.form__img-group .text-btn {
		display: block;
	}

	.form-img__icon {
		display: none;
	}
	
	.form-input__wrapper {
		border: none;
	}
	
	.form-input__group .form-input__wrapper {
		width: calc((100% - 16px) / 2);
		margin-right: 16px;
		float: left;
	}
	
	.form-input__group .form-input__wrapper:last-of-type {
		margin-right: 0;
	}
	
	.inline .form-input__wrapper {
		padding: 0;
	}
	
	.form__input {
		height: 56px;
		padding: 16px;
		border: 1px solid;
		border-color: var(--alpha-text-color);
		border-radius: 4px;
	}
	
	.form__input_login {
		border: 1px solid #FFFFFF;
	}
	
	.form__input_pr {
		height: 88px !important;
	}
	
	.form__input_right {
		text-align: left;
	}
	
	.form__input_right::before {
		font-family: 'icon' !important;
		content:  "\e903";
		position: absolute;
		right: 12px;
		transform: rotate(90deg);
	}
	
	.form__input_show {
		padding-left: 0;
		border: none;
	}
	
	.form__label {
		position: static;
		margin-bottom: 8px;
		font-size: 16px;
	}
	
	.form__label_line {
		display: none;
	}
	
	.form__icon {
		bottom: -30px;
	}
	
	.form__btn {
		margin: 72px auto 16px;
	}

	.form__save-btn {
		position: absolute;
		margin: 16px;
	}

	.form_members {
		margin-top: 0 !important;
	}

	.form__members-label {
		position: static;
		width: 100%;
		max-width: none;
		margin: 24px 0 0 0;
		box-shadow: none;
	}

	.form__members-img-wrapper {
		width: 88px;
		padding-top: 88px;
		border-radius: 4px;
	}

	.form__members-group {
		padding: 0 0 0 24px;
	}

	.form__members-txt {
		display: none;
	}

	.form__members-btn {
		position: static;
		display: inline-block;
		width: auto;
		height: auto;
		margin-top: 8px;
		padding: .5em 1em;
		color: #FFF;
		line-height: 1;
		font-size: 14px;
		border-radius: 1em;
		opacity: 1;
	}

	.members__bg-container {
		width: calc(100% - 80px);
		max-width: 720px;
		margin: 0 auto;
		position: relative;
	}

	.members__container {
		max-width: 880px;
		margin: 0 auto;
		padding: 240px 40px 80px;
	}

	.members-bg__wrapper_bg {
		margin-top: 0px;
	}

	.members__container .members,
	.members__container .local {
		float: left;
		width: 50%;
		max-width: 400px;
		clear: left;
	}

	.members__container .charges,
	.members__container .enroll,
	.members__container .settings {
		display: block;
		float: right;
		width: 50%;
		clear: right;
		max-width: 400px;
		padding-left: 40px;
	}

	.members__container .settings {
		margin: -148px 0 0 0;
	}

	.select-members {
		max-width: 800px;
		padding: 48px;
	}

	.select-members__notice {
		margin-bottom: 12px;
	}

	.select-members__list {
		height: auto;
		max-height: 400px;
	}

	.select-members__list .simplebar-content {
		display: flex;
		flex-wrap: wrap;
	}

	.simplebar-content:before,
	.simplebar-content:after {
		display: block;
	}

	.select-members__item {
		width: 50%;
		margin-bottom: 0;
	}

	.select-members__name::after {
		top: auto;
		bottom: 0;
		left: 52px;
		right: auto;
		transform: none;
	}

	.settings__item {
		border-bottom: 1px solid;
		border-color: var(--alpha-text-color);
	}

	.settings__label {
		padding: 32px 0;
	}


	.members__container .settings__label::before {
		margin-right: 8px;
		font-size: 24px;
		vertical-align: middle;
	}

	.members__container .settings__label {
		padding: 14px 0;
	}
	
	.info__read {
		width: 100%;
		margin: 0 0 40px 0;
	}
	
	.info__page-link {
		margin-top: -96px;
		padding-top: 96px;
	}
	
	.hero {
		position: relative;
		z-index: 0;
	}
	
	/*.hero__item:not(:first-of-type) {
		display: none;
	}*/
	
	.hero__item.slick-slide:not(:first-of-type) {
		display: block;
	}
	
	.hero__item {
		padding-top: calc(100vh - 80px);
		width: 100%;
	}
	
	.hero__img {
		position: absolute;
	}
	
	.slick-prev,
	.slick-next {
		z-index: 1;
		height: 80px;
		width: 80px;
	}
	
	.slick-prev {
		left: 0px;
		transform: translateY(-50%) rotate(-180deg);
	}
	
	.slick-next {
		right: 0px;
	}
	
	.slick-prev::before,
	.slick-next::before{
		content: "\e903";
		font-family: 'icon';
		font-size: 56px;
		border: none;
		text-shadow: 0 0 4px rgba(0,0,0,0.8);
	}
	
	.top {
		display: none;
	}

	.top__title {
		display: none;
	}

	.general__inner {
		position: relative;
		display: table;
		table-layout: fixed;
		width: 100%;
		align-items: center;
		padding: 24px 40px;
	}

	.general__title {
		display: table-cell;
		max-width: 240px;
		width: 30%;
		vertical-align: middle;
	}

	.general__title:before {
		content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		right: 0;
		width: 1px;
		height: 100%;
		margin: auto;
		background: #FFFFFF;
	}

	.general__txt {
		display: table-cell;
		padding-left: 32px;
		vertical-align: middle;
	}

	.section {
		margin: 0;
		padding: 58px 0 64px;
	}

	.section__inner {
		max-width: 1120px;
		margin: 0 auto;
	}

	.section__inner_wide {
		max-width: none;
	}

	.section__title_hide {
		position: static;
	}
	
	.section__title_sp {
		display: none;
	}

	.headline {
		font-size: 40px;
	}

	.section__sub-container .headline {
		font-size: 32px;
	}


	.form_members .text-btn__wrapper {
		margin: 0 0 0 24px;
		flex: 1;
		text-align: left;
	}

	.video-modal__container {
		width: 80%;
	}
	
	/*************************************
	**************************************
				maintenance
	**************************************
	*************************************/
	
	.maintenance__inner {
		max-width: 800px;
	}
	
	.maintenance__title {
		font-size: 40px;
	}
	
	.maintenance__txt {
		font-size: 16px;
	}
	
	.maintenance__txt_br {
		display: none;
	}

	.maintenance__txt_vertical {
		transform: none;
	}
	
	.pager {
		padding: 40px 0 0;
	}
	
	.history__wrapper + .pager {
		padding: 0 0 80px;
	}
	
	.pre,
	.next {
		width: 50px;
	}
	
	.pager__item {
		display: inline-block;
	}
	
	.pager__link {
		opacity: .2;
	}
	
	.next__link::before {
		content: "\e903";
		font-family: 'icon' !important;
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		width: 24px;
		height: 24px;
		margin: auto;
	}
	
	.pre__link::before {
		content: "\e902";
		font-family: 'icon' !important;
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		width: 24px;
		height: 24px;
		margin: auto;
	}
	
	.pager__link:hover,
	.pager__link.active {
		opacity: 1;
	}
	
	.next__text,
	.pre__text {
		text-indent: -999px;
		white-space: nowrap;
		overflow: hidden;
	}
	
	/*************************************
	**************************************
				top
	**************************************
	*************************************/
	
	.site-top .text-btn__wrapper-pc {
		display: block;
	}
	
	.site-top .text-btn__wrapper-sp {
		display: none;
	}
	
	.site-top::after {
		background-image: url("../images/fanmily-top.jpg");
	}
	
	.site-top__txt {
		font-size: 20px;
	}
	
	/*************************************
	**************************************
				top-search
	**************************************
	*************************************/
	
	.top-search::before {
		content: "";
		display: block;
		position: fixed;
		top: 0;
		z-index: -1;
		width: 100%;
		height: 100%;
		background: rgba(255,255,255,.35);
		backdrop-filter: saturate(100%) blur(10px);
		-webkit-backdrop-filter: saturate(100%) blur(10px);
	}
	
	.top-search::after {
		content: "";
		display: block;
		position: fixed;
		top: 0;
		z-index: -2;
		width: 100%;
		height: 100%;
		background-image: url(../images/fanmily-top.jpg);
		background-repeat: no-repeat;
		background-size: cover;
	}
	
	.top-search .search-item__inner {
		max-width: 800px;
		margin: 0 auto;
	}
	
	.search-item__inner .search__close {
		display: block;
	}
	
	.search-item__inner .search__field {
		padding: 0 44px 0 16px;
		border: none;
		background: #F0F0F0;
	}
	
	.top-search__inner {
		max-width: 720px;
		margin: 60px auto;
	}
	
	.top-search__item {
		border-radius: 6px;
		border-bottom: none;
		margin: 0 0 40px;
		box-shadow: 0px 0px 6px 4px rgba(0,0,0,0.2);
	}
	.top-search__item::after {
		display: none;
	}
	
	.result-description {
		padding: 0 24px 0 10px;
	}
	
	.result-main {
		font-size: 18px;
	}
	
	.top-search__no-result {
		max-width: 800px;
		margin: 60px auto;
		padding: 20px 24px;
		border: none;
		font-size: 18px;
		font-weight: bold;
		text-align: center;
	}
	
	/*************************************
	**************************************
				timeline
	**************************************
	*************************************/
	
	.page__container_timeline .page__wrapper {
		padding: 0 40px;
	}
	
	.timeline__feed {
		position: relative;
		display: flex;
		width: 100vw;
		max-width: 1080px;
		margin: 0 auto;
	}
	
	.header-bar__search {
		display: none;
	}
	
	.search__item {
		display: flex;
		align-items: center;
		padding: 0;
	}
	
	.search-item__inner {
		flex: 1 1 0%;
	}
	
	.side-menu {
		position: static;
		top: auto;
		left: auto;
		padding: 80px 0 0;
		transform: none;
		background: transparent;
	}
	
	.page__container_timeline .side-menu {
		width: 300px;
	}
	
	.side-menu .page__headline {
		text-align: left;
	}
	
	.timeline-search,
	.chat-search {
		position: static;
		max-height: 100%;
		overflow: visible;
	}
	
	.search__item {
		display: block;
	}
	
	.timeline-search .search__close,
	.chat-search .search__close {
		display: none;
	}
	
	.search__form {
		width: 100%;
	}
	
	.search__tab {
		margin: 24px 0 0;
	}
	
	.search-tab__item {
		margin: 4px 8px 0 0;
		opacity: .5;
	}
	
	.search-tab__item:hover {
		opacity: 1;
	}
	
	.search-tab__item_active {
		opacity: 1;
	}
	
	.timeline__grid-wrapper {
		flex: 1;
		width: 100%;
		height: 100vh;
		margin: 0 calc(50% - 50vw) 0 0;
		padding: 80px 60px 80px 40px;
		overflow-y: scroll;
	}
	
	.timeline__grid-group {
		max-width: 680px;
	}
	
	.timeline__grid-wrapper .pager {
		max-width: 680px;
	}
	
	/*************************************
	**************************************
				mail_detail
	**************************************
	*************************************/
	
	.header-favorite__wrapper {
		width: 50%;
		margin: 0 0 8px auto;
		text-align: left;
	}
	
	.header-favorite__switch {
		position: static;
		height: 32px;
		font-size: 32px;
	}
	
	.header-favorite__text {
		position: absolute;
		top: 7px;
		padding: 0 0 0 8px;
		display: inline-block;
		font-size: 16px;
	}
	
	.header-favorite__input:checked ~ .header-favorite__switch .header-favorite__text {
		color: #ED4956;
		font-weight: bold;
	}
	
	.mail-detail {
		margin: auto;
		padding: 0 40px;
	}
	
	.mail-detail .mail__inner {
		float: right;
		width: 50%;
		padding: 0 0 0 20px;
	}
	
	.mail-detail .mail-grid__wrapper {
		float: left;
		width: 50%;
		min-height: 500px;
		padding: 0 20px 0 0;
	}
	
	.mail-detail .mail-grid__inner {
		margin: 0;
	}
	
	.mail-detail .mail-comment__wrapper {
		float: right;
		width: 50%;
		padding: 16px 0 24px 20px;
		clear: right;
	}
	
	.mail-detail .mail-detail__text {
		height: 300px;
		padding: 16px;
		margin: 0 0 24px;
		/*border-top: 1px dashed;
		border-bottom: 1px dashed;*/
		border: 1px solid var(--alpha-text-color);
		border-radius: 6px;
		overflow: hidden;
		overflow-y: scroll;
	}
	
	.mail-detail .mail-comment__inner {
		display: block;
		font-size: 0;
		letter-spacing: 0;
	}
	
	.mail-detail .mail__thumbnail {
		display: inline-block;
	}
	
	.mail-detail .mail__contents {
		display: inline-block;
		width: calc(100% - 48px);
	}
	
	.mail-detail .mail-contents__date {
		padding: 0 0 0 48px;
	}
	
	.send {
		position: relative;
		/*max-width: 880px;*/
		margin: 0 auto 0 20px;
		padding: 0 40px 0 60px;
		text-align: right;
	}
	
	.send__field {
		height: 100px;
		border-radius: 4px;
	}
	
	.send__inner {
		display: inline-block;
		width: 50%;
		padding: 0;
		border-radius: 4px;
		overflow: hidden;
	}

	/*************************************
	**************************************
				mypage
	**************************************
	*************************************/
	.charges__item {
		margin: 0 0 16px auto;
	}

	.enroll {
		padding: 48px 0 0 40px;
	}

	.charges__item::before,
	.hold__count::before {
		margin-right: 8px;
		font-size: 44px;
		line-height: 1;
	}

	.charges__count .hold__count {
		display: block;
		width: 100%;
		text-align: left;
	}

	.charges__count .hold__name{
		display: inline-block;
		vertical-align: top;
		font-size: 14px;
		float: left;
	}

	.charges__button {
		width: auto;
		padding: 0;
		font-size: 16px;
		background: transparent;
		font-weight: bold;
	}

	.charges__button::after {
		font-family: 'icon' !important;
		content: "\e903";
	}

	.hold {
		max-width: 600px;
		margin: 8px auto 0;
	}

	.hold__inline {
		display: flex;
		justify-content: space-around;
	}

	.hold__inline .hold__count {
		margin-bottom: 16px;
	}

	.hold__inline .hold__count::before {
		font-size: 36px;
	}


	.hold__inner {
		text-align: center;
	}

	.hold__count-group {
		display: inline-block;
		text-align: center;
	}

	.hold__count-group .hold__name {
		padding-left: 64px;
	}

	.hold__count {
		position: relative;
		display: inline-block;
		font-size: 38px;
		text-align: center;
	}

	.purchase {
		text-align: center;
	}

	.purchase__link {
		display: inline-block;
		margin: 16px;
	}

	.purchase__label, 
	.purchase__label::before {
		font-size: 24px;
		line-height: 24px;
	}

	.purchase__btn {
		font-size: 18px;
	}

	
	.record__list {
		margin-bottom: 50px;
		border-top: 1px solid;
		border-color: var(--alpha-text-color);
	}

	
	.record__item {
		margin-bottom: 0;
		padding: 16px 0;
	}
	
	.record__item:last-child {
		margin-bottom: 0;
		padding: 16px 0;
	}
	
	.site-top-info__wrapper {
		bottom: 60px;
	}
	
	.site-top-info__btn_txt {
		bottom: 112px;
	}
	
	.purchase__label-addition {
		margin: 6px 8px 0 32px;
		font-size: 14px;
	}
	
	.purchase-btn__wrapper {
		width: 120px;
	}
	
	/*************************************
	**************************************
				backnumber
	**************************************
	*************************************/
	
	.backnumber .form__read br {
		display: none;
	}
	
	.backnumber-btn__wrapper {
		max-width: 800px;
		margin: 0 auto;
	}
	
	.backnumber__table {
		padding: 40px;
	}
	
	.backnumber-list__caution {
		max-width: 500px;
		margin: 40px auto 0;
	}
	
	/*************************************
	**************************************
				premium
	**************************************
	*************************************/
	
	.subscription-change__wrapper .subscription__notice {
		margin: 0 0 60px;
	}
	
	.subscription-change__wrapper .subscription__notice-title {
		margin: 40px 0 16px;
	}
	
	/*.subscription-change__wrapper .subscription__notice-text {
		margin: 0 auto 40px;
	}*/
	
	.subscription-change__wrapper .subscription-btn__wrapper,
	.subscription-change__wrapper .subscription-btn__inner {
		margin: 40px 0 0;
	}
	
	/*************************************
	**************************************
				payment-selection
	**************************************
	*************************************/
	
	.payment-page__wrapper{
		max-width: none;
		margin: 0;
		padding: 0
	}
	
	/*.payment-select {
		max-width: 824px;
		margin: 0 auto;
		padding: 16px;
	}*/
	
	.payment-select__wrapper {
		max-width: 776px;
		margin: 60px auto 0;
		padding: 24px 40px;
		background-color: rgba(0, 0, 0, 0.1)!important;
	}
	
	.payment__wrapper {
		display: flex;
		justify-content: center;
		max-width: 824px;
		margin: 0 auto;
		padding: 0 24px;
	}
	
	.payment-select__link-wrapper {
		max-width: 776px;
		margin: 8px auto 0;
		padding: 0 0 40px;
	}
	
	.payment__wrapper .payment {
		width: 50%;
		margin: 0 12px;
		padding: 24px;
		background-color: rgba(0, 0, 0, 0.1);
		border-radius: 6px;
	}
	
	.payment-plan__wrapper {
		justify-content: center;
	}
	
	.payment-page__wrapper .payment__title-main {
		margin: 0;
		padding: 40px 0 16px;
	}
	
	.payment-plan__title,
	.payment-plan__detail {
		padding: 0 14px;
	}
	
	.payment-page__wrapper .subscription__notice-text {
		padding: 24px 32px 40px;
	}
	
	.payment-select + .payment__title-main {
		margin: 40px 0 16px;
	}

	.payment__link.sp {
	    display: none;
	}

	.payment__link.pc{
	    display: inline-block;
    }

	/*************************************
	**************************************
	service-end
	**************************************
	*************************************/

	.service-end__title {
		font-size: 40px;
	}

	.service-end__sub-title {
		font-size: 16px;
	}

	/*************************************
	**************************************
				login-button
	**************************************
	*************************************/
	
	.login-button {
		position: fixed;
	}
	
	.login-button__inner {
		position: relative;
		width: 100%;
		padding: 24px;
		background-color: rgba(255, 255, 255, 0.7);
	}
	
	.login__link {
		display: block;
		width: 100%;
		max-width: 400px;
		margin: 0 auto;
		
		padding: 16px;
		border-radius: 4px;
	}
	
	/*************************************
	**************************************
				viewer
	**************************************
	*************************************/
	
	.viewer__img {
		max-width: 700px;
	}
	
	.main_viewer {
		width: 100%;
		height: 100vh;
		margin: 0 auto;
	}
	
	/*************************************
	**************************************
				lottery
	**************************************
	*************************************/
	
	.order__container {
		bottom: 50%;
		left: 50%;
		transform: translate(-50%);
		width: auto;
		border: 1px solid;
		border-color: var(--alpha-text-color);
		border-radius: 6px;
	}
	
	.order_announce {
		display: none;
	}

	.lottery-play {
		height: 100vh;
	}

	.lottery-play__txt {
    	font-size: 20px;
    }

    .lottery-play__wrapper {
    	position: absolute;
    	width: 100%;
    	height: auto;
    	top: 50%;
    	left: 50%;
    	transform: translate(-50%, -50%);
    	max-width: 1080px;
    	margin: 0 auto;
    	padding: 10% 40px;
    	z-index: 2;
    }

    .lottery-play__headline {
    	font-size: 100px;
    }
    
    .lottery-play__list {
    	margin: 3em -24px 2em 0;
    }

    .lottery-play__floating.floating {
    	position: static;
    	transform: none;
    	margin: 80px auto 0;
    	border-radius: 16px;
    	max-width: 640px;
    }

    .lottery-play__btn {
    	min-width: 200px;
    	margin-left: 24px;
    	font-size: 14px;
    }

	.lottery-play .grid__item {
    	width: calc(100% / 5);
    	padding: 0 24px 24px 0;
    }

    #lastPrize {
    	top: -30%;
    	max-width: 560px;
    	margin: auto;
    	bottom: 0;
    }

	.floating__header {
		background: transparent!important;
	}
	
	/*************************************
	**************************************
				subscription
	**************************************
	*************************************/
	
	.page-subscription {
		padding-bottom: 120px!important;
	}
	
	#mail {
		padding: 80px 0 0;
	}
	
	#members {
		padding: 0 0 80px;
	}
	
	.subscription__headline {
		font-size: 40px;
	}
	
	.subscription__group-max {
		max-width: 880px;
		margin: 0 auto;
		text-align: center;
		font-size: 20px;
	}
	
	.subscription__list {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		font-size: 0;
		letter-spacing: 0;
	}
	
	.subscription__label {
		display: inline-block;
		width: calc(100% / 3 - 8px);
		height: 200px;
		margin: 4px;
		vertical-align: middle;
		text-align: center;
	}
	
	.subscription-label__inner {
		padding: 48px 16px;
	}
	
	.subscription__caption {
		margin: 0 0 16px;
		font-size: 16px;
		text-align: center;
	}
	
	.subscription__group_island .subscription__caption {
		margin: 0 0 24px;
	}
	
	.subscription__caption-title {
		font-size: 20px;
	}
	
	.subscription__txt {
		margin: 0;
	}
	
	.subscription__group-column {
		display: flex;
		align-items: center;
		max-width: 1000px;
		margin: 0 auto;
		padding: 60px 24px;
	}
	
	
	.subscription__section:nth-of-type(even) .subscription__group-column .subscription__detail {
		order: 2;
		padding: 0 0 0 80px;
	}
	
	.subscription__detail {
		padding: 0 80px 0 0;
		flex: 1 1 0%;
	}
	
	.subscription__detail .headline {
		margin: 0 0 24px;
	}

	.subscription__detail .app:before {
		padding: 8px 18px;
		font-size: 20px;
	}
	
	.headline__accessory {
		width: 80px;
	}
	
	.subscription__read {
		margin: 40px 0 0;
	}

	.subscription__wrapper .send__field {
		height: 40px;
		border-radius: 40px;
	}
	
	.sample {
		width: 400px;
	}
	
	.diamond__wrapper {
		bottom: -200px;
		padding: 100px 0;
	}
	
	.diamond {
		width: 500px;
		height: 500px;
	}
	
	#premium .headline__wrapper {
		margin: 60px auto 50px;
	}
	
	#premium .subscription__list {
		max-width: 800px;
		margin: 0 auto;
	}
	
	#premium .subscription__item {
		padding: 60px;
	}
	
	#premium .subscription__caption {
		font-size: 24px;
		margin: 0 0 32px;
	}

	#morningcall .card:before {
		content:"";
		display: block;
	}

	.mail__wrapper {
		padding: 0 0 24px;
		border: none;
	}
	
	#morningcall .mail__wrapper {
		padding: 0 50px 24px;
		border: none;
	}
	
	.device__card-mail {
		padding: 20px 16px;
		box-shadow: none;
	}
	
	#morningcall .device__card-mail {
		padding: 15px 12px;
	}
	
	.davice-mail__img {
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		z-index: 2;
		width: 100%;
	}
	
	.sample__send {
		padding: 8px 24px;
	}
	
	.subscription__group_charge {
		max-width: 848px;
		margin: 0 auto;
	}
	
	.table__wrapper {
		padding: 80px 48px 100px;
	}
	
	.table__title {
		font-size: 40px;
	}
	
	.subscription__group_island .headline__wrapper {
		margin: 30px auto 60px;
	}
	
	.table {
		padding: 76px 0 16px;
	}
	
	.table__que,
	.table__ans {
		font-size: 24px;
	}
	
	.table__ans-charge,
	.monthly__text {
		font-size: 40px;
	}

	.table__bottom-group {
		margin: 60px 0 0;
		padding: 60px 0 0;
	}

	.table__btn {
		font-size: 28px;
		padding: 20px;
		margin: 0 auto 64px;
	}

	.vandle__btn {
		margin: 40px auto 0;
	}
	
	.monthly__wrapper {
		margin: 60px 0 0;
		padding: 60px 0 0;
	}
	
	.monthly__coution {
		font-size: 16px;
	}
	
	.monthly__text::before {
		border: 14px solid transparent;
		border-top: 16px solid;
	}
	
	.subscription__sub-txt {
		font-size: 14px;
	}
	
	.subscription-info {
		max-width: 800px;
		margin: 40px auto 80px;
		border-radius: 6px;
	}
	
	.vandle {
		text-align: center;
	}
	
	.subscription-form__section {
		display: block;
		text-align: center;
	}
	
	.subscription-form__title {
		margin: 0 0 60px;
		font-size: 40px;
	}
	
	.subscription-form__section .subscription__group {
		max-width: 880px;
		margin: 0 auto;
		padding: 80px 40px;
	}
	
	.subscription-form__wrapper {
		display: flex;
		align-items: flex-end;
		margin: 40px 0 0;
		text-align: left;
	}
	
	.subscription__group .error__text {
		margin: 8px 0 0;
		text-align: left;
	}
	
	.subscription-form__wrapper .form-input__wrapper {
		margin: 0;
		padding: 0 16px 0 0;
	}
	
	.subscription-form__wrapper .form__btn {
		width: 140px;
		height: 56px;
		margin: 0;
	}
	
	.subscription_stay {
		margin-bottom: 180px;
	}
	
	.subscription-info__title br {
		display: none;
	}
	
	.subscription .proposal-stay__inner {
		display: flex;
		justify-content: center;
		align-items: center;
	}
	
	.subscription .proposal-stay__group {
		width: 320px;
	}
	
	.subscription .proposal__txt-link {
		display: flex;
		max-width: 300px;
		margin-top: 12px;
	}
	
	.proposal-stay__text {
		display: block;
		padding: 0 40px 0 0;
		color: #343434;
		font-size: 16px;
		font-weight: bold;
	}

	.morning-call__img_first {
		top: -20px;
		right: 0;
	}
	
	.morning-call__img_second {
		bottom: 150px;
		left: 10px;
	}

	.mail__icon-wrapper {
		padding-top: 206%;
	}
	
	/*************************************
	**************************************
				cancel-membership
	**************************************
	*************************************/
	
	.cancel-membership .settings__inner {
		display: flex;
		max-width: 800px;
	}
	
	.cancel-membership .cancel-fanclub {
		width: 300px;
	}
	
	.cancel-membership .form__section {
		flex: 1;
		padding: 0 0 0 56px;
	}
	
	/*************************************
	**************************************
				cancel-completed
	**************************************
	*************************************/
	
	.cancel-completed .page__headline {
		font-size: 80px;
	}

	.cancel-completed .settings__inner {
		padding: 80px 0 0;
	}
	
	.cancel-completed .form__read br:nth-of-type(2) {
		display: block;
	}
	
	.cancel-completed .form__btn {
		margin: 0 auto 40px;
	}
	
	/*************************************
	**************************************
				expired
	**************************************
	*************************************/
	
	.page__container_expired .page__headline_nav {
		margin: 0 auto 50px;
	}
	
	/*************************************
	**************************************
				phone-number
	**************************************
	*************************************/
	
	.phone {
		padding: 0;
	}
	
	.phone .form__txt {
		text-align: center;
	}
	
	.form__country-label {
		position: relative;
		width: 120px;
		margin: 0 16px 0 0;
		padding: 0;
	}
	
	.form__country-number {
		justify-content: flex-start;
		padding: 15px 10px 15px 10px;
		cursor: pointer;
	}
	
	.country-name.triangle::after {
		display: none;
	}
	
	.form__country-label.triangle {
		position: relative;
		top: auto;
		right: auto;
		left: auto;
		bottom: auto;
	}
	
	.form__country-label.triangle::after {
		position: absolute;
		right: 8px;
		display: inline-block;
		margin: 0;
	} 
	
	.country-number__short {
		padding: 0 0 0 4px;
		color: var(--primary-color);
		opacity: 1;
	}
	
	.select-country {
		width: 500px;
		height: 500px;
		border-radius: 6px;
	}
	
	.select-country__list {
		height: auto;
		max-height: 440px;
		padding: 0;
		border-radius: 0 0 6px 6px;
	}
	
	.select-country__item:last-child {
		border: none;
	}
	
	.select-country__close {
		top: -32px;
		right: 0;
		color: #FFF;;
	}
	
	/*==========hover==========*/
	/****animation*****/
	a,
	.buttonInner,
	.header-nav__link 
	.header__avatar::before,
	.search__field,
	.site-top__container .form__input,
	.settings__item button:hover {
		-webkit-transition: all 0.3s ease 0s;
				transition: all 0.3s ease 0s;
	}
	
	/*****透過 0.7******/
	.header__logo:hover,
	.primary.header-nav__link:hover,
	.footer__link:hover,
	.form__btn:hover,
	.form__txt-link:hover,
	.form__file-label:hover,
	.login__btn:hover,
	.text-btn_login:hover,
	.text-btn:hover,
	.buttonInner:hover,
	.alert__action:hover,
	.drawer__btn:hover,
	/*layout*/
	.hover-action:hover,
	.banner__link:hover,
	.information__link:hover,
	.biography__link:hover,
	.members-profile-item__inner:hover,
	.discography-item__inner:hover,
	.contact__link:hover,
	.feed-detail__item:hover,
	.detail__card:hover,
	.ticket:hover,
	.share__link:hover,
	.sns__link:hover,
	.mail-grid__item:hover,
	.send__button:hover,
	.pickup__link:hover,
	.lottery a:hover,
	.lottery div[data-href]:hover,
	.note__inner:hover,
	.video__img-wrapper:hover,
	/*mypage*/
	a.primary.settings__label:hover,
	.purchase__link:hover,
	.payment-select__link:hover,
	.payment-img__wrapper:hover,
	.form__members-btn:hover,
	/*subsc*/
	.subscription-label__inner:hover,
	.plan-button:hover,
	.top-search__result:hover,
	.proposal__txt-link:hover,
	.proposal__btn:hover,
	.proposal__badge:hover,
	.lp__txt-link:hover,
	.lp__badge:hover,
	.purchase__btn:hover,
	.payment__link:hover,
	.rate-plan__text:hover,
	/*info*/
	.info__link:hover,
	.matter__link:hover,
	.table__btn:hover,
	.download__link:hover,
	.download__badge:hover,
	.download__txt-link:hover,
	/*chat*/
	.chat__button:hover,
	.room-create-txt__wpapper:hover,
	.tag-list__items:hover,
	.chat-list__button:hover,
	.chat-list__label:hover + .chat-list__item {
		opacity: .7;
		transition: .3s ease;
	}
	
	/****primaryカラー*****/
	.mask .header__title_sub,
	.mask a.navigation_tint:hover,
	.header__title_main:hover,
	.header-nav__link:hover,
	.select-members__label:hover,
	.pager_text .pager__text-link:hover,
	/*layout*/
	.more__btn:hover,
	.notice__inner:hover .text,
	.news__inner:hover .text,
	.schedule__inner:hover .schedule__text,
	.archive__inner:hover,
	.mail-reply__text:hover,
	.mail-replied__text:hover,
	/*mypage*/
	.members__btn:hover,
	.local__link:hover,
	a.text.settings__label:hover,
	.enroll__txt-link:hover,
	.enroll-card__label:hover,
	.charges__button:hover,
	.payment-select__link:hover,
	.plan-button.text:hover,
	.settings__item button:hover {
		color: var(--primary-color)!important;
	}
	
	/****背景 alpha-primary*****/
	.notice__inner:hover,
	.news__inner:hover,
	.schedule__inner:hover,
	.timeline__pick .mail:hover {
		background: var(--alpha-primary-color)!important;
	}
	
	/****背景 primary*****/
	.enroll__link:hover {
		background: var(--primary-color)!important;
		border-color: var(--primary-color)!important;
	}
	
	/****下線*****/
	/*.mail__inner:hover a.mail__title,*/
	.information__text a:hover,
	.detail__txt a:hover {
		text-decoration: underline;
	}
	
	/****白黒反転*****/
	.lp__link:hover,
	.proposal__link:hover {
		background: #343434!important;
		color: #FFF !important;
	}
	
	.enroll__link:hover,
	.header__avatar:hover {
		color: #FFF !important;
	}
	
	.header__avatar:hover::before {
		background: #343434 !important;
	}
	
	/****線 gradient*****/
/*	.timeline__grid-group .mail:hover::before {
		content: "";
		background: var(--gradient-color) !important;
		top: -4px;
		left: -4px;
		right: -4px;
		bottom: -4px;
		display: block;
		position: absolute;
		border-radius: 8px;
		z-index: 0;
	}
	
	.timeline__grid-group .mail:hover::after {
		content: "";
		background: var(--contents-color) !important;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		display: block;
		position: absolute;
		border-radius: 6px;
	}

	.mail:hover div,
	.mail:hover p,
	.mail:hover dl,
	.mail:hover .mail__title {
		position: relative;
		z-index: 2;
	}*/
	
	/****shadow*****/
	.search__field:hover,
	.site-top__container .form__input:hover {
		box-shadow: 0 1px 6px rgba(34,34,34,.4);
		background: #FFF;
	}
	
	/****その他*****/
	.mail-favorite__inner:hover,
	.header-favorite__switch:hover {
		color: #ED4956;
	}

	.search__close:hover {
		font-weight: bold;
	}

	.download__container {
		padding: 64px;
	}

	.download__headline {
		font-size: 28px;
		margin-bottom: 56px;
	}
	
	.download__txt {
		font-size: 20px;
		line-height: 1.8;
	}

	.download__link {
		font-size: 22px;
	}

	.download__badge-img {
		height: 56px;
	}
	
/*************************************
**************************************
		       chat
**************************************
*************************************/
	
	.chat .search__button {
		width: 48px;
		background: var(--primary-color);
		border-radius: 0 4px 4px 0;
	}
	
	.chat .search__button.icon_search {
		color: var(--contents-color);
	}
	
	.chat .icon_search::before {
		color: #fff;
	}
	
	.chat-list__item {
		padding: 8px 16px 8px 16px;
	}
	
	.chat-list__container {
		padding: 40px 0 24px 0;
	}
	
	.room-invite-txt {
		font-size: 18px;
	}
	
	.chat-list__container .chat-list__item {
		padding: 16px;
	}
	
	.chat-list__container .chat-list__item.active,
	.chat-list__container .chat-list__item:hover {
		border-radius: 4px;
		background: var(--alpha-primary-color);
	}
	
	.chat-page .create-button {
		display: none;
	}
	
	.room-absence-txt_br {
		display: none;
	}
	
	.room-absence {
		margin-bottom: 0px;
	}
	
	.chat__container_room .search__button {
		width: auto;
		background: transparent;
	}

	.chat__container_room .icon_search::before {
		color: #757575;
	}
	
	.room-create-txt__wpapper {
		display: block;
		text-align: right;
	}
	
	.room-create__link {
		display: inline-block;
		margin-top: 16px;
		font-size: 14px;
		font-weight: bold;
	}
	
	.member-modal {
		z-index: 998;
	}
	
	.tag-list__title {
		font-size: 32px;
	}
	
	.chat-list__item_hover {
		padding: 16px;
		margin-bottom: 0;
	}
	
	.chat-list__item_hover:hover  {
		border-radius: 4px;
		background: var(--alpha-primary-color);
	}
	
	.tag-list {
		margin:8px 16px 0 16px;
	}
	
	.tag-list__wrapper .page__headline{
		font-size: 32px;
	}
	
	.chat-search__wrapper {
		margin-top: 0;
	} 
	
	.chat-setting__txt {
		margin-bottom: 48px;
	}
	
	.chat-setting .tag-list {
		margin: 0 0 48px 0;
	}
	
	.chat-setting-list {
		margin-top: 32px;
	}
	
	.chat-setting .form__img-group {
		margin:0 0 40px 0 ;
	}
	
	.chat-setting .text-btn__wrapper {
		display: flex;
		align-items: center;
	}
	
	.chat__container_room .slick-prev::before, 
	.chat__container_room .slick-next::before {
		font-size: 40px;
	}
	
	.chat__container_room .slick-prev, 
	.chat__container_room .slick-next {
		display: block;
	}
	
	.icon_conversation {
		font-size: 160px;
	}
	
	/*watanabe.css*/
	
	.chat .two-column {
		padding: 0 40px;
		overflow: hidden;
	}
	
	.chat .two-column__main {
		position: relative;
		float: right;
		display: block;
		width: 50%;
		height: 100vh;
		padding: 80px 0 0 0;
	}

	.chat-detail .chat-detail__head {
		position: absolute;
		display: block;
		top: 80px;
		padding: 16px 8px;
		background: var(--contents-color);
		z-index: 100;
	}

	.chat-detail .chat-detail__head::before {
		position: absolute;
		bottom: 0;
		display: block;
		width: calc(100% - 16px);
		border: 1px solid var(--text-color);
		content: "";
		opacity: .1;
	}
	
	
	.chat-detail .chat-detail__name,
	.chat-detail .chat-detail__count {
		color: var(--text-color);
	}

	.chat-detail .chat-detail__txt {
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		width: calc(100% - 80px);
		margin: 0;
	}

	.chat-detail .header-bar__icon {
		display: block;
	}

	.chat-detail__head > a.header-bar__icon,
	.chat__container .chat-function__list {
		display: none;
	}

	.chat-detail .header-bar__icon_left {
		right: 48px;
	}

	.chat-detail .header-bar__icon_left::before {
		color: var(--text-color);
	}

	.chat-detail .header-bar__icon_right {
		margin: auto 8px auto 0;
		color: var(--text-color);
	}


/*------------トーク内検索---------------*/

	.chat-detail .chat-search,
	.chat-detail .setting-switch__close {
		display: none;
	}

	#chatSearchSwitch:checked ~ .chat-search,
	#settingSwitch:checked ~ .chat-setting {
		position: absolute;
		display: block;
		background: var(--contents-color);
		overflow-y: scroll;
		-ms-overflow-style: none;    /* IE, Edge 対応 */
		scrollbar-width: none;       /* Firefox 対応 */
	}

	.chat .chat-setting::-webkit-scrollbar {
		display:none;   /* Chrome, Safari 対応 */
	}

	.chat-detail .search__item {
		padding: 12px 8px;
	}

	.chat-detail .search__close {
		display: block;
	}
	
	.chat-detail .search__form {
		width: calc(100% - 100px);
	}

/*----------------設定------------------*/
	
	.chat-detail .chat-setting {
		top: 80px;
		left: 0;
		width: 100%;
		height: calc(100% - 80px);
		padding: 16px;
		border-radius: 4px;
		z-index: 101;
		overflow-y: scroll;
		-ms-overflow-style: none;    /* IE, Edge 対応 */
		scrollbar-width: none;       /* Firefox 対応 */
	}

	.chat-detail .chat-setting::-webkit-scrollbar {
		display:none;   /* Chrome, Safari 対応 */
	}

	.chat-detail .setting-switch__close {
		position: absolute;
		top: 16px;
		right: 16px;
		display: block;
		width: 24px;
		height: 24px;
		font-size: 24px;
		cursor: pointer;
	}

/*----------グループチャットに参加するボタン----------*/ 

	.chat .chat-detail__join {
		position: absolute;
		padding: 24px;
	}

	.chat .chat-join__button {
		max-width: 440px;
		margin: auto;
		border-radius: 4px;
	}

/*----------------入力フォーム-----------------*/


    .chat .chat-send__container {
	    position: absolute;
	    display: block;
	    background: transparent;
	}

	.chat .scroll-button {
		width: 40px;
		height: 40px;
		margin: 0 0 16px;
	}

	.chat .scroll-button__icon {
		font-size: 26px;
	}

	.chat .send__inner {
		display: block;
		width: 100%;
		border-radius: 0;
		background: var(--contents-color);
		overflow: initial;
	}

	.chat .send-item__wrapper {
		align-items: flex-start;
		flex-direction: column-reverse;
		padding: 0;
		background: var(--contents-color);
	}

	.chat .chat-send__item {
		position: relative;
		margin: 16px 16px 16px 0;
		color: var(--text-color-);
	}

	.chat .send-field__wrapper {
		width: 100%;
		height: 112px;
		margin: 0;
		border-radius: 4px;
	}

	.chat .send__field {
		width: 100%;
		height: 100% !important;
		padding: 8px;
		border: 1px solid var(--alpha-text-color);
		color: var(--text-color);
	}

	.chat .send__button {
		bottom: -40px;
	}

/*----------------スタンプ・スパスタ-----------------*/

	.chat .stamp-select__block {
		position: absolute;
		left: -20%;/*スタンプの時 */
		bottom: 56px;
		width: 375px;
		height: 320px;
		box-shadow: 0px 0px 10px 0px rgb(0 0 0 / 16%);
		z-index: 101;
		overflow: hidden;
	}
	.chat .square-grid__list {
		height: 320px;
		padding: 16px;
		overflow-y: scroll;
	}

	.chat .square-grid__list_superstamp {
		padding: 16px 16px 48px;
	}
	.chat .square-grid__item {
		width: calc((100% - 24px) / 4);
		margin: 0 8px 8px 0;
		padding: 15px;
	}

	.chat .square-grid__item:nth-of-type(4n) {
		margin-right: 0;
	}

	.square-grid__list_superstamp .square-grid__item {
		padding: 5px;
	}

	.super-stamp__pickup {
		position: absolute;
		height: 100%;
	}

	.square-grid__list_superstamp .stamp-function {
		right: 4px
	}

	.square-grid__list_superstamp .purchase__label_coin {
		margin:  4px -16px 0;
	}

	.stamp-select__block .purchase__block {
		position: absolute;
		padding: 8px 10px;
	}

	.super-stamp__pickup .purchase__block {
		position: static;
	}

	.square-grid__list_superstamp .super-stamp__area {
		width: calc(100% - 30px);
	}
	
	.hide .chat-stamp__wrapper_superstamp {
		display: block;
	}

	.hide .send-item__wrapper,
	.hide .square-grid__list,
	.hide .purchase__block {
		display: flex;
	}

	.hide .chat .stamp-select__block,
	.hide .send-item__form,
	.hide .stamp-select__block,
	.hide .super-stamp__pickup {
		height: 320px;
	}
	
	.hide .scroll-button__block {
		bottom: 100%;
	}

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

	.chat-detail .chat-detail__inner {
		margin: 0;
		padding: 72px 8px 192px;
		height: 100%;
		overflow-y: scroll;
		-ms-overflow-style: none;    /* IE, Edge 対応 */
		scrollbar-width: none;       /* Firefox 対応 */
	}
	.chat-detail .chat-detail__inner::-webkit-scrollbar {  /* Chrome, Safari 対応 */
		display:none;
	}

	.chat-detail__inner .chat-announce {
		position: absolute;
	}

	.chat__container .chat__group {
		position: relative;
		margin: 0 0 16px 0;
	}

	.chat-block .profile {
		width: 40px;
		height: 40px;
	}

	.chat__container_reply .profile {
		width: 30px;
		height: 30px;
	}

	.chat-block .members__name {
		font-size: 12px;
	}

	.chat__container .chat__item  {
		max-width: none;
		min-width: 165px;
	}

/*-------入力フォームリプライ------*/

	.chat-send__container .chat__container_reply {
		position: relative;
		margin: 0 0 8px;
		padding: 8px 10px;
	}

	.chat-send__container .chat__container_reply::before {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		border: 1px solid var(--text-color);
		border-radius: 4px;
		opacity: .1;
		content: "";
	}

	.chat-send__container .chat__inner_reply-thumbnail {
		padding: 8px 88px 8px 10px;
	}

	.chat-send__container .chat__reply_thumbnail {
		right: 42px;
	}

	.chat-send__container .reply-switch__close {
		width: 24px;
		height: 24px;
		right: 10px;
	}

	.chat-send__container .icon_close:before {
		font-size: 24px
			
	}


/*	サブ*/
	.chat .two-column__sub {
		float: left;
		display: block;
		max-width: 415px;
		width: 50%;
		padding: 80px 64px 40px 24px;
		overflow: hidden;
	}

	.chat .two-column__head {
		position: relative;
		margin: 0 0 40px;
	}

	.chat .two-column__title {
		font-size: 32px;
		font-weight: bold; 
	}

	.chat .create-button {
		position: absolute;
		top: 50%;
		right: 0;
		transform: translateY(-50%);
		display: block;
		font-size:24px;
	}

	.two-column__sub.chat-list .search__field {
		margin: 0 0 16px 0;
	}

	.two-column__sub.chat-list .search__field:hover {
		box-shadow: none;
		background: #F0F0F0;
	}

	.two-column__sub .chat-list__container {
		position: relative;
		height: calc(100vh - 395px);
		padding: 8px 5px 5px;
		overflow: hidden;
	}

	.two-column__sub .chat-list__container::after {
		display: block;
		content: "";
		width: 100%;
		height: 40px;
	}

	.two-column__sub .room-list__container,
	.two-column__sub .search-recommend__container {
		height: 100%;
		overflow-y: scroll;
		-ms-overflow-style: none;    /* IE, Edge 対応 */
		scrollbar-width: none;       /* Firefox 対応 */
	}

	.two-column__sub .room-list__container::-webkit-scrollbar,
	.two-column__sub .search-recommend__container::-webkit-scrollbar {
		display:none;   /* Chrome, Safari 対応 */
	}

	.two-column__sub .search-recommend__container {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		padding: 5px;
		display: none;
	}
	
	.two-column__sub .search-recommend__close {
		display: block;
		margin: 0 0 10px;
		text-align: right;
		cursor: pointer;
	}
	
	.two-column__sub .search-recommend__inner {
		height: calc(100% - 40px);
		border-radius: 6px;
		box-shadow: 0px 3px 10px rgba(0,0,0,0.16);
		overflow-y: scroll;
		-ms-overflow-style: none;    /* IE, Edge 対応 */
		scrollbar-width: none;       /* Firefox 対応 */
	}

	.two-column__sub .search-recommend__inner::-webkit-scrollbar {  /* Chrome, Safari 対応 */
		display:none;
	}

	.two-column__sub .search-recommend__inner .chat-list {
		padding: 0;
	}
	
	.chat-list .chat-list__wrapper {
		height: calc(100% - 153px);
		overflow-y: scroll;
	}

	.chat-block_me .chat__function {
		margin: 0 8px 0 0;
	}

	.chat .mask {
		background: rgba(0, 0, 0, .5);
	}

	.chat .viewing-restrictions {
		max-width: 800px;
		height: 100vh;
		padding: 80px 40px;
	}

	.chat .viewing-restrictions__txt {
		font-size: 32px;
	}

	.chat .viewing-restrictions__subtxt__wrapper {
		margin: 24px 0 0 0;
		padding: 80px;
		font-size: 32px;
	}
	.form__input_edit {
		height: 160px;
	}
	.form__input_tag {
		height: 100px;
	}
	
	/*********************
		support
	*********************/
	
	
}

@media screen and (min-width: 940px) {
	.login__wrapper {
		height: 100vh;
	}
	
	.login__container {
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
	}

	.download {
		position: relative;
		display: flex;
		align-items: center;
		padding: 120px 2%;
		margin: 0 auto;
		max-width: 1680px;
		justify-content: space-around;
	}

	.download__img-wrapper {
		margin-right: -6%;
		padding-top: 38%;
		width: 56%;
		box-shadow: 0px 0px 20px 0px rgba(0,0,0,0.4);
		z-index: 1;
	}

	.download__container {
		position: static;
		margin: 0;
		box-shadow: none;
		border-radius: 0;
		z-index: 0;
		max-width: none;
		padding: 0 40px;
		width: 44%;
	}

	.download__container::before {
		content: "";
		position: absolute;
		top: 50%;
		right: 3%;
		transform: translateY(-50%);
		width: 44%;
		height: calc(100% - 120px);
		background: inherit;
		z-index: -1;
	}

	.download__headline br {
		display: block;
	}
	
	.edit-error__txt_img-group {
		margin-top: -18px;
	}
}

@media screen and (min-width: 1024px) {
	/*watanabe.css*/
	.chat .two-column__main {
		width: calc(100% - 415px);
	}

	.chat-detail .chat-detail__inner {
        padding: 72px 24px 192px;
	}
	
    .chat-detail .chat-detail__head {
	    padding: 16px 24px;
	}

	.chat-detail .chat-detail__head::before{
		width: calc(100% - 48px);
	}

	.chat-detail .header-bar__icon_left {
		right: 64px;
	}

	.chat-detail .header-bar__icon_right {
		margin: auto 24px auto 0;
	}

	.chat-detail .search__item {
		padding: 12px 24px;
	}

	.chat-detail__inner .chat-announce {
		top: 160px;
		width: calc(100% - 48px);
	}

    .chat .chat-send__container {
    	padding: 0 24px;
    }

    .chat .scroll-button__block {
		right: 24px;
	}
	
	.caption {
		font-size: 32px;
	}
}

@media screen and (min-width: 1280px) {
	/*************************************
	**************************************
				    detail
	**************************************
	*************************************/
	.detail {
		position: relative;
		max-width: 1620px;
		padding: 0 40px;
	}

	.detail__inner,
	.note-detail__inner {
		height: 100%;
		padding: 80px 310px 0;
		overflow-y:scroll;
		scrollbar-width: none;
	}
	
	.detail__inner::-webkit-scrollbar {
		display: none;
	}

	.detail__inner::after {
		content: "";
		display: block;
		height: 80px;
	}
	
	.detail__pickup {
		position: absolute;
		top: 0;
		right: 40px;
		width: 270px;
		margin: 0;
		padding: 80px 0 40px;
	}

	.pickup__wrapper::-webkit-scrollbar {
		display: none;
	}

	.page__wrapper_detail{
		max-width: none;
		min-height: 700px;
	}
	
	.detail .page__sub-headline {
		padding: 0 0 40px;
		font-size: 20px;
		font-weight: normal;
	}
	
	.detail .page__sub-headline::after {
		content: none;
	}

	.detail .pager_text {
		margin: 0 0 16px;
	}

	.subscription_stay {
		margin-bottom: 180px;
	}
	
	.drawer__icon {
		position: absolute;
		top: 0;
		right: 44px;
	}
	
	.drawer__icon::after {
		content: "\e903";
		font-family: 'icon';
		display: inline-block;
		width: 16px;
		line-height: 1;
		font-size: 16px;
		vertical-align: middle;
		-webkit-font-smoothing: antialiased;
		-webkit-transform:rotate(90deg);
		transform:rotate(90deg);
	}
	
	.drawer-title__wrapper {
		position: relative;
	}

	.download__headline br {
		display: none;
	}

	.download__txt br {
		display: block;
	}
}

@media screen and (min-width: 1500px) {
    /*************************************
	**************************************
				   detail
	**************************************
	*************************************/

	.detail__inner {
		padding: 80px 370px 0;
	}
	
	.detail__pickup {
		width: 330px;
	}
}


@media all and (-ms-high-contrast: none) {
	video.hero__img {
		height: auto;
	}
}
