@charset "utf-8";


@font-face {
    font-family: "YakuHanJP";
    font-style: normal;
    font-weight: 300;
    src: url("../fonts/YakuHanJP/YakuHanJP-Light.woff2") format("woff2"),
    url("../fonts/YakuHanJP/YakuHanJP-Light.woff") format("woff");
}

@font-face {
    font-family: "YakuHanJP";
    font-style: normal;
    font-weight: 400;
    src: url("../fonts/YakuHanJP/YakuHanJP-Regular.woff2") format("woff2"),
    url("../fonts/YakuHanJP/YakuHanJP-Regular.woff") format("woff");
}

@font-face {
    font-family: "YakuHanJP";
    font-style: normal;
    font-weight: 500;
    src: url("../fonts/YakuHanJP/YakuHanJP-Medium.woff2") format("woff2"),
    url("../fonts/YakuHanJP/YakuHanJP-Medium.woff") format("woff");
}

@font-face {
    font-family: "YakuHanJP";
    font-style: normal;
    font-weight: 700;
    src: url("../fonts/YakuHanJP/YakuHanJP-Bold.woff2") format("woff2"),
    url("../fonts/YakuHanJP/YakuHanJP-Bold.woff") format("woff");
}


* {
	margin: 0;
	padding: 0;
	-webkit-backface-visibility: hidden;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

html {
	-webkit-text-size-adjust: none;
	height: 100%;
	background: transparent;
}

body {
	margin: 0;
	padding: 0;
	width: 100%;
	height: 100%;
	font-weight: 300;
	font-size: 16px;
	font-family: YakuHanJP, "Hiragino Sans", "BIZ UDPGothic", Meiryo, sans-serif;
	font-feature-settings: 'palt' 1;
	text-align: center;
	line-height: 1.8;
	-webkit-font-smoothing: antialiased;
	letter-spacing: 0.1em;
	color: #4b4845;
	background: #fcffe3;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	padding: 0;
	margin: 0;
	font-weight: 300;
}

ul,
ol {
	margin: 0;
	padding: 0;
	list-style-type: none;
}

p {
	padding: 0;
	margin: 0;
}

img {
	width: 100%;
	-webkit-touch-callout: none;
	-ms-interpolation-mode: bicubic;
	vertical-align: bottom;
}

a {
	word-break: break-all;
	text-decoration: underline;
	color: #4b4845;
	outline: none;
	transition: opacity 0.4s cubic-bezier(.57,0,.26,1);
}

a:active,
a:hover,
a:focus {
	outline: none;
}

@media (any-hover: hover) {
	a:hover {
		opacity: .4;
	}
}


table {
	border-collapse: collapse;
}

.wrapper ::before,
.wrapper ::after {
	font-family: "Hiragino Sans", "BIZ UDPGothic", Meiryo, sans-serif;
	font-feature-settings: normal;
}

button {
	-webkit-user-select: none;
	user-select: none;
	touch-action: manipulation;
		outline: none;
		border: none;
		background: none;
}

@-webkit-keyframes fadeIn {
	0% { opacity: 0;}
	100% { opacity: 1;}
}

@keyframes fadeIn {
	0% { opacity: 0;}
	100% { opacity: 1;}
}

@-webkit-keyframes fadeOut {
	0% { opacity: 1;}
	100% { opacity: 0;}
}

@keyframes fadeOut {
	0% { opacity: 1;}
	100% { opacity: 0;}
}

/*--------------------------------------
loading
--------------------------------------*/
.loading {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #f5b9b0;
	z-index: 5000;
}

.loading::after {
}

.loading p {
	margin: -20px 0 0 -20px;
	padding-top: 38px;
	overflow: hidden;
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	width: 40px;
	height: 0;
	border: 1px solid #fff;
	border-radius: 50%;
	border-top-color: transparent;
	animation: spin 0.75s infinite linear;
	z-index: 5002;
}

@keyframes spin {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}


.loading::before {
	content: "";
	margin: -20px 0 0 -20px;
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	width: 38px;
	height: 38px;
	opacity: .2;
	border: 1px solid #fff;
	border-radius: 50%;
	z-index: 5001;
}

@keyframes bgCyclePause {
  /* 色1を保持（#dee99f） */
  0%   { background-color: #f5b9b0; }
  20%  { background-color: #f5b9b0; }

  /* 色1→色2フェード（#f0b4ac） */
  30%  { background-color: #d4dd83; }

  /* 色2を保持 */
  50%  { background-color: #d4dd83; }

  /* 色2→色3フェード（#cfaf8f） */
  60%  { background-color: #c19d7e; }

  /* 色3を保持 */
  80%  { background-color: #c19d7e; }

  /* 色3→色1フェード */
  90%  { background-color: #f5b9b0; }

  /* 戻り（ループ） */
  100% { background-color: #f5b9b0; }
}

@keyframes pinkGreen {
  0%, 20% { background: #f5b9b0; }  /* ピンクで停止 */
  21%     { background: #f5b9b0; }  /* 明示的にストップ */
  100%    { background: #d4dd83; }  /* 徐々にグリーンへ */
}

@keyframes greenBrown {
  0%, 20% { background: #d4dd83; }  /* グリーンで停止 */
  21%     { background: #d4dd83; }
  100%    { background: #c19d7e; }  /* 徐々にブラウンへ */
}

@keyframes brownPink {
  0%, 20% { background: #c19d7e; }  /* ブラウンで停止 */
  21%     { background: #c19d7e; }
  100%    { background: #f5b9b0; }  /* 徐々にピンクへ */
}

@keyframes pinkGreenColor {
  0%, 20% { color: #f5b9b0; }  /* ピンクで停止 */
  21%     { color: #f5b9b0; }  /* 明示的にストップ */
  100%    { color: #d4dd83; }  /* 徐々にグリーンへ */
}

@keyframes greenBrownColor {
  0%, 20% { color: #d4dd83; }  /* グリーンで停止 */
  21%     { color: #d4dd83; }
  100%    { color: #c19d7e; }  /* 徐々にブラウンへ */
}

@keyframes brownPinkColor {
  0%, 20% { color: #c19d7e; }  /* ブラウンで停止 */
  21%     { color: #c19d7e; }
  100%    { color: #f5b9b0; }  /* 徐々にピンクへ */
}

@keyframes pinkGreenBorder {
  0%, 20% { border-color: #f5b9b0; }  /* ピンクで停止 */
  21%     { border-color: #f5b9b0; }  /* 明示的にストップ */
  100%    { border-color: #d4dd83; }  /* 徐々にグリーンへ */
}

@keyframes greenBrownBorder {
  0%, 20% { border-color: #d4dd83; }  /* グリーンで停止 */
  21%     { border-color: #d4dd83; }
  100%    { border-color: #c19d7e; }  /* 徐々にブラウンへ */
}

@keyframes brownPinkBorder {
  0%, 20% { border-color: #c19d7e; }  /* ブラウンで停止 */
  21%     { border-color: #c19d7e; }
  100%    { border-color: #f5b9b0; }  /* 徐々にピンクへ */
}

/*--------------------------------------
コンテンツ
--------------------------------------*/
.wrapper {
	position: relative;
	width: 100%;
	height: auto !important;
	height: 100%;
	min-height: 100%;
}

.container {
	overflow: hidden;
	text-align: left;
	width: 100%;
	height: auto;
}

/*--------------------------------------
header
--------------------------------------*/
#top {
	padding: 2% 0 5%;
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 100%;
	background: #f9d2d4;
	z-index: 10;
}

#home #top {
	padding: 0;
	height: 100vh;
}

.pink #top {
	animation: pinkGreen 8s ease-in-out forwards;
	z-index: 10;
}

.green #top {
	animation: greenBrown 8s ease-in-out forwards;
	z-index: 10;
}

.brown #top {
	animation: brownPink 8s ease-in-out forwards;
	z-index: 10;
}

#top .intro {
	padding-bottom: 13%;
	position: absolute;
	top: 50%;
	left: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 40%;
	transform: translate(-50%, -50%);
}

#top .intro li {
	opacity: 0;
	transition: transform 2.5s cubic-bezier(.57,0,.26,1) 0.5s, opacity 2s cubic-bezier(.57,0,.26,1) 1s;
}

#top .intro li:nth-of-type(1) {
	transform: translateX(180%);
	width: 7.8475%;
}

#top .intro li:nth-of-type(2) {
	transform: translateX(70%);
	width: 8.273%;
}

#top .intro li:nth-of-type(3) {
	transform: translateX(-20%);
width: 6.722%;
}

#top .intro li:nth-of-type(4) {
	transform: translateX(-90%);
	width: 13.048%;
}

#top .intro li:nth-of-type(5) {
	transition: opacity 2.5s cubic-bezier(.57,0,.26,1) 2s;
}

#top.active .intro li {
	opacity: 1;
}

#top.active .intro li:nth-of-type(1) {
	transform: translateX(-408%);
}

#top.active .intro li:nth-of-type(2) {
	transform: translateX(-128%);
}

#top.active .intro li:nth-of-type(3) {
	transform: translateX(171%);
}

#top.active .intro li:nth-of-type(4) {
	transform: translateX(245%);
}

#top.active .intro li:nth-of-type(5) {
	opacity: 1;
}

#top .intro li:nth-of-type(5) {
	position: absolute;
	bottom: 0;
	left: 50%;
	width: 56.83%;
	transform: translateX(-50%);
}

#top .intro li p {
	overflow: hidden;
	width: 100%;
	height: 0;
}

#top .intro li:nth-of-type(1) p {
	padding-top: 275.18%;
	background: url(../images/common/header/o.svg) no-repeat;
	background-size: 100% auto;
}

#top .intro li:nth-of-type(2) p {
	padding-top: 253.66%;
	background: url(../images/common/header/n.svg) no-repeat;
	background-size: 100% auto;
}

#top .intro li:nth-of-type(3) p {
	padding-top: 312.19%;
	background: url(../images/common/header/e.svg) no-repeat;
	background-size: 100% auto;
}

#top .intro li:nth-of-type(4) p {
	padding-top: 160.83%;
	background: url(../images/common/header/w.svg) no-repeat;
	background-size: 100% auto;
}

#top .intro li:nth-of-type(5) p {
	padding-top: 44.55%;
	background: url(../images/common/header/title.svg) no-repeat;
	background-size: 100% auto;
}

.siteTitle {
	padding-top: calc(12.5% * 0.8);
	overflow: hidden;
	width: calc(100% * 0.4);
	height: 0;
	opacity: 0;
	background: url(../images/common/header/title_sub.svg) no-repeat center center;
	background-size: 100% auto;
	z-index: 5;
}

#top.active .siteTitle {
	opacity: 1;
}

#home .siteTitle {
	padding: 0;
	width: 0;
	background: none;
}


nav {
z-index: 100;
}

#top .globalNav {
	position: absolute;
	bottom: 4%;
	left: 50%;
	display:flex;
	justify-content: center;
	align-items: center;
	opacity: 0;
	transition: opacity 2.5s cubic-bezier(.57,0,.26,1) 2s;
	transform: translateX(-50%);
	z-index: 100;
}

#top.active .globalNav {
	opacity: 1;
}

body.bonus-1 #top .globalNav {
	opacity: 1;
	transition: none;
}

#top .globalNav li {
	padding: 0 1em;
	position: relative;
	overflow: hidden;
	flex-grow: 1;
}

.globalNav a {
	position: relative;
	display: block;
	position: relative;
	color: #fcfef3;
	text-decoration: none;
	-webkit-user-select: none;
	user-select: none;
	transform: scaleX(1.25);
}

.globalNav a p {
	white-space: nowrap;
	font-size: 24px;
	line-height: 1.6;
	font-family: 'Oswald', serif;
	font-weight: 400;
	transform: scaleX(0.8);
	letter-spacing: 0.15em;
	text-align: center;
	-webkit-user-select: none;
	user-select: none;
}

.globalNav > li > a {
}

.globalNav a:hover {
}

.globalNav a::after {
	content: "";
	display: block;
	letter-spacing: 0.05em;
	font-weight: 700;
	font-size: 14px;
	font-family: YakuHanJP, "Hiragino Kaku Gothic ProN", "Hiragino Sans", "BIZ UDPGothic", Meiryo, sans-serif;
	font-feature-settings: 'palt' 1;
	text-align: center;
	line-height: 1.2;
	transform: scaleX(0.8);
}

.globalNav > li:nth-of-type(1) a::after {
	content: "最新情報";
}

.globalNav > li:nth-of-type(2) a::after {
	content: "リリース詳細";
}

.globalNav > li:nth-of-type(3) a::after {
	content: "予約・購入特典";
}

.globalNav > li:nth-of-type(4) a::after {
	content: "店舗別オリジナル特典";
}

.globalNav > li:nth-of-type(5) a::after {
	content: "プロフィール";
}

@media only screen and (max-width: 1340px) {
	.globalNav a p {
		font-size: 22px;
	}

	.globalNav > li a::after {
		font-size: 13px;
	}
}

@media only screen and (max-width: 1240px) {
	.globalNav a p {
		font-size: 1.6vw;
	}

	.globalNav > li a::after {
		font-size: 13px;
	}
}

	#menu-btn {
		position: fixed;
		display: none;
		top: -1px;
		left: 2px;
		height: 53px;
		width: 72px;
	opacity: 0;
		outline: none;
		border: none;
		background: none;
		cursor: pointer;
		z-index: 2000;
		-webkit-tap-highlight-color:rgba(0, 0, 0, 0);
	}

body.active #menu-btn {
	animation: fadeIn 1.5s cubic-bezier(.17,.67,.6,.92) 2s 1 forwards;
}

	body.active #menu-btn,
	#menu-btn {
		opacity: 1;
		animation: none;
	}

@keyframes fade {
	from {
		opacity: 0;
		}
	to {
		opacity: 1;
	}
}

	#menu-btn::before,
	#menu-btn::after,
	#menu-btn span {
		content: "";
		margin-left: calc((100% - 12px) / -2);
		padding-top: 1px;
		position: absolute;
		top: 0;
		left: 50%;
		overflow: hidden;
		display: block;
		width: calc(100% - 12px);
		height: 0;
		background: #fff;
	}

#menu-btn::before {
	top: 14px;
	animation: btnTr 0.8s cubic-bezier(.17,.67,.07,.99) 0s forwards;
	transition:  0.4s ease-in-out;
}

#menu-btn span {
	top: 26px;
	-webkit-transition:  0.4s ease-in-out;
	transition:  0.4s ease-in-out;
}

#menu-btn::after {
	top: 38px;
	animation: btnBr 0.8s cubic-bezier(.17,.67,.07,.99) 0s forwards;
	transition:  0.4s ease-in-out;
}

#menu-btn:hover::before {
}

#menu-btn:hover::after {
}

#menu-btn.active:hover::before {
}

#menu-btn.active:hover::after {
}

#menu-btn.active:hover::before,
#menu-btn.active:hover::after {
}

#menu-btn.active::before {
	background: #fff;
	animation: btnT 0.8s cubic-bezier(.17,.67,.07,.99) 0s forwards;
}

#menu-btn.active span {
	background: #fff;
	opacity: 0;
}

#menu-btn.active::after {
	background: #fff;
	animation: btnB 0.8s cubic-bezier(.17,.67,.07,.99) 0s forwards;
}

/* btnT */
@keyframes btnT {
	0% { transform: translateY(4px);}
	20% { transform: translateY(12px) rotate(0deg);}
	100% { transform: translateY(12px) rotate(-30deg);}
}

/* btnTr */
@keyframes btnTr {
	0% { transform: translateY(12px) rotate(-30deg);}
	30% { transform: translateY(12px) rotate(0deg);}
	100% { transform: translateY(0px);}
}

/* btnB */
@keyframes btnB {
	0% { transform: translateY(-4px);}
	20% { transform: translateY(-12px) rotate(0deg);}
	100% { transform: translateY(-12px) rotate(30deg);}
}

/* btnBr */
@keyframes btnBr {
	0% { transform: translateY(-12px) rotate(30deg);}
	30% { transform: translateY(-12px) rotate(0deg);}
	100% { transform: translateY(0px);}
}

	#menu-btn.b::before,
	#menu-btn.b::after,
	#menu-btn.b span {
		background: #474c4d;
	}

.menu {
	will-change: transform;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	display: none;
	-webkit-backface-visibility:hidden;
	backface-visibility:hidden;
	z-index: 1099;
}

.menu.active {
}

	.menu button {
		content: "";
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100vh;
		outline: none;
		cursor: default;
		border: none;
		background: none;
		z-index: 302;
	}

.menu div {
		position: relative;
		width: 100%;
	height: 100vh;
		display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	background: #f5b9b0;
	z-index: 303;
}

.menu .globalNav {
	margin: 0 auto;
	padding: 0 0 4em;
	padding: 0;
	position: relative;
	display: table;
	text-align: center;
	z-index: 304;
	filter: blur(24px);
	transition: filter 1s cubic-bezier(.57,0,.26,1) 0.2s;
}

.filter .menu .globalNav {
	filter: blur(0px);
}

.menu .globalNav li {
	margin: 0 auto;
	padding: 0;
	display: table;
	position: relative;
	width: 100%;
}

#top .globalNav li.subscription {
	width: 36%;
	flex-grow: 0;
}

@media only screen and (max-width: 1140px) {
}

#top .sns-link {
	padding: 16px 16px 0 0 ;
	position: absolute;
	top: 0;
	left: 0;
	display:flex;
	justify-content: end;
	align-items: center;
	width: 100%;
	flex: 1;
	opacity: 0;
	transition: opacity 1.7s cubic-bezier(.57,0,.26,1) 3s;
	z-index: 100;
	}

#top.active .sns-link {
	opacity: 1;
}

body.bonus-1 #top .sns-link {
	opacity: 1;
	transition: none;
	}

.sns-link li {
	width: 3.2vw;
	max-width: 34px;
}

.sns-link .x a,
.sns-link .instagram a,
.sns-link .facebook a,
.sns-link .twitter a {
	padding-top: 100%;
	position: relative;
	overflow: hidden;
	display: block;
	width: 100%;
	height: 0;
}

.sns-link .twitter a {
	background: url(../images/common/nav/sns/twitter.svg) no-repeat center center;
	background-size: 100% auto;
}

.sns-link .facebook a {
	background: url(../images/common/nav/sns/facebook.svg) no-repeat center center;
	background-size: 100% auto;
}

@media only screen and (max-width: 1240px) {

}

#top .scroll {
	padding: 0 0 calc(16em * 0.8);
	overflow: hidden;
	position: absolute;
	bottom: 4%;
	right: 16px;
	width: 1.4em;
	opacity: 0;
	font-size: 18px;
	transition: opacity 1s cubic-bezier(.17,.67,.6,.92) 3s;
	z-index: 122;
}

#top.active .scroll {
	opacity: 1;
}

#top.active.up .scroll {
	opacity: 0;
}

.scroll p {
	padding-top: 9em;
	overflow: hidden;
	position: absolute;
	top: 0;
	left: calc(50% - 1px);
	height: 0;
	width: 1px;
}

.scroll p::before,
.scroll p::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 1px;
	height: 100%;
	background: #fff;
	opacity: .3;
	mix-blend-mode: multiply;
}

.scroll p::after {
	opacity: 1;
	mix-blend-mode: normal;
	background: #fff;
	-webkit-animation: scrollDown 3s cubic-bezier(.17,.67,.07,.99) 0s infinite forwards;
	animation: scrollDown 3s cubic-bezier(.17,.67,.07,.99) 0s infinite forwards;
}

/* scrollDown */
@-webkit-keyframes scrollDown {
	0% { transform: translate3d(0, -100%, 0);}
	100% { transform: translate3d(0, 100%, 0);}
}

@keyframes scrollDown {
	0% { transform: translate3d(0, -100%, 0);}
	100% { transform: translate3d(0, 100%, 0);}
}

.scroll::before {
	content: "SCROLL";
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	overflow: hidden;
	writing-mode: vertical-rl;
	font-size: 18px;
	font-family: 'Oswald', serif;
	font-weight: 400;
	transform: scaleX(0.8);
	line-height: 1.4;
	color: #fff;
	-webkit-user-select: none;
	user-select: none;
}



/*--------------------------------------
 * コンテンツ
 * ---------------------------------------*/

.primary {
	position: relative;
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	z-index: 100;
}

body.bonus-1 .primary {
	padding: 120px 0 180px;
}

.notice li {
	padding-top: 0.1em;
	display: flex;
	align-items: start;
}

.notice li::before {
	content: "※";
	font-size: 14px;
	line-height: 1.7;
}

.notice p {
	font-size: 14px;
	line-height: 1.7;
	text-align: left;
}

.primary section {
	position: relative;
	width: 100%;
}


.bonus-1 .primary section h1,
.primary section h2,
#bonus-1 h3,
#bonus-2 h3 {
	padding: 0 0 0;
	position: relative;
	letter-spacing: 0.15em;
	font-size: 48px;
	line-height: 1.2;
	font-family: 'Oswald', "Hiragino Sans", "ヒラギノ角ゴ Pro W3", 'Hiragino Kaku Gothic Pro', "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", verdana, sans-serif;
	font-weight: 400;
	transform: scaleX(0.8);
	text-align: center;
	color: #454541;
	-webkit-user-select: none;
	user-select: none;
}

.pink.bonus-1 .primary section h1,
.pink .primary section h2,
.pink #bonus-1 h3,
.pink #bonus-2 h3 {
	animation: pinkGreenColor 8s ease-in-out forwards;
	z-index: 10;
}

.green.bonus-1 .primary section h1,
.green .primary section h2,
.green #bonus-1 h3,
.green #bonus-2 h3 {
	animation: greenBrownColor 8s ease-in-out forwards;
	z-index: 10;
}

.brown.bonus-1 .primary section h1,
.brown .primary section h2,
.brown #bonus-1 h3,
.brown #bonus-2 h3 {
	animation: brownPinkColor 8s ease-in-out forwards;
	z-index: 10;
}

.bonus-1 .primary section h1::after,
#bonus-1 h3::after,
#bonus-2 h3::after,
.primary section h2::after {
	content: "";
	padding-top: 0.5em;
	display: block;
	letter-spacing: 0.1em;
	font-weight: 500;
	font-size: 20px;
	font-family: YakuHanJP, "Hiragino Sans", "BIZ UDPGothic", Meiryo, sans-serif;
	font-feature-settings: 'palt' 1;
	line-height: 1.2;
	transform: scaleX(1.25);
}


.primary section#information h2::after {
	content: "最新情報";
}

.primary section#release h2::after {
	content: "リリース詳細";
}

.bonus-1 .primary section h1::after,
#bonus-1 h3::after {
	content: "予約・購入特典";
}

#bonus-2 h3::after {
	content: "店舗別オリジナル特典";
}

.primary section#profile h2::after {
	content: "プロフィール";
}

@media only screen and (max-width: 2000px) {
}

@media only screen and (max-width: 1080px) {
}


.primary section .contents {
	margin: 0 auto;
	padding: 0 72px 0;
	position: relative;
	max-width: 1240px;
	width: 100%;
	z-index: 2;
}

.bonus-1 .primary section .contents {
	padding-top: 48px;
}

@media only screen and (max-width: 1080px) {
	.primary section .contents {
		padding: 0 48px 0;
	}
}

.item {
	opacity: 0;
	transform: translateY(3vh);
	transition: opacity 1s cubic-bezier(.57,0,.26,1) 0s, transform 1s cubic-bezier(.57,0,.26,1) 0s;
}

.item.active {
	opacity: 1;
	transform: translateY(0);
}

/*--------------------------------------
news
---------------------------------------*/
#information {
	padding: 120px 0 0;
}

@media only screen and (max-width: 1240px) {
}

#information h2 {
	color: #fcfef3;
}

#information .entryList {
	padding-top: 32px;
}

#information.active .entryList {
	}

#information .link {
	padding-top: 24px;
	display: flex;
	justify-content: space-between;
	gap: 16px;
	width: 100%;
}

#information .entryList li {
	position: relative;
	border-bottom: solid 1px rgba(0, 0, 0, .1);
}

#information .entryList li:first-child {
	border-top: solid 1px rgba(0, 0, 0, .1);
}


#information .entryList li:nth-of-type(n+4) {
	display: none;
}

#information .entry a {
	padding: 24px 48px 24px 0;
	position: relative;
	display: flex;
	align-items: start;
	overflow: hidden;
	text-decoration: none;
}

#information .entry a:hover {
}

#information .entry a::after {
	content: "";
	padding-top: 16px;
	position: absolute;
	top: 50%;
	right: 16px;
	display: block;
	width: 16px;
	height: 0;
	transform: rotate(-45deg) translateY(-50%);
	border: solid 1px;
	border-top: none;
	border-left: none;
	transition: 0.4s ease-in-out;
}

.pink #information .entry a::after {
	animation: pinkGreenColor 8s ease-in-out forwards;
}

.green #information .entry a::after {
	animation: greenBrownColor 8s ease-in-out forwards;
}

.brown #information .entry a::after {
	animation: brownPinkColor 8s ease-in-out forwards;
}

#information .entryList + ul a:hover::after,
#information .entry a:hover::after {
	right: 8px;
}

#information .entry span {
	width: 8em;
	text-align: left;
	line-height: 1.7;
	flex-shrink: 0;
}

#information .entry p {
	padding: 0;
text-align: left;
	line-height: 1.7;
	flex: 1;
}

#information .link a {
	padding: 0 2em;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0 0.5em;
	height: 3em;
	text-decoration: none;
	color: #fff;
	-webkit-user-select: none;
	user-select: none;
	transition: background 0.4s cubic-bezier(.57,0,.26,1),  color 0.4s cubic-bezier(.57,0,.26,1), opacity 0.4s cubic-bezier(.57,0,.26,1);
}

.pink #information .link a {
	animation: pinkGreen 8s ease-in-out forwards;
}

.green #information .link a {
	animation: greenBrown 8s ease-in-out forwards;
}

.brown #information .link a {
	animation: brownPink 8s ease-in-out forwards;
}

#information .link a:hover {
}

#information .link li:nth-of-type(2) a::before {
	content: "";
	padding-top: 1.2em;
	display: block;
	width: 1.6em;
	height: 0;
	background: url(../images/contents/information/mail.svg) no-repeat center center;
	background-size: 100% auto;
}

#information .link a br {
	display: none;
}

/*--------------------------------------
release
---------------------------------------*/
#release {
	padding: 120px 0 0;
}

@media only screen and (max-width: 1080px) {
}

#release .VIZL-2473 {
	padding-top: 48px;
}

#release .VIZL-2473 > h3 {
	margin: 0 auto;
	padding-top: 89px;
	overflow: hidden;
	width: 300px;
	height: 0;
	background: url(../images/contents/release/title.svg) no-repeat;
	background-size: 100% auto;
}

#release .detail {
	overflow: hidden;
}

#release .date {
	padding: 24px 0 32px;
}

#release .date p {
	font-size: 26px;
	font-weight: 600;
	text-align: center;
	line-height: 1.2;
}

#release .type > ul {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	gap: 32px;
}

#release .type > ul > li {
	display: flex;
	flex-direction: column;
	width: calc((100% - 32px * 1) / 2);
}

#release .jacket {
	margin-bottom: 8px;
	position: relative;
	display: flex;
	align-items: end;
	justify-content: center;
	width: 100%;
}

#release .jacket img {
	width: calc(100% * 0.86);
	background: #f6f4cc;
}

#release .limited .jacket img {
	width: 100%;
}

#release .normal .jacket {
	padding-top: 136.7%;
}

#release .normal .jacket img {
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	z-index: 1;
}

#release .jacket::before {
	content: "NOW\APRINTING";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	white-space: pre;
	text-align: center;
	font-family: 'Oswald', "Hiragino Sans", "ヒラギノ角ゴ Pro W3", 'Hiragino Kaku Gothic Pro', "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", verdana, sans-serif;
	font-weight: 400;
	transform: scaleX(0.8);
	line-height: 1.1;
	font-size: 40px;
	opacity: .1;
	z-index: 2;
}

#release .normal .jacket::before {
	left: 50%;
	width: calc(100% * 0.86);
	height: calc(100% * 0.86);
	transform: translateY(12%) translateX(-50%) scaleX(0.8);
}

#release .type > ul > li > ul {
	display: flex;
	flex-grow: 1;
}

#release .vos-limited .data::after {
	content: "";
	margin: -16px auto 0 auto;
	padding-top: calc(128% * 0.4);
	display: block;
	width: calc(100% * 0.4);
	height: 0;
	background: url(../images/contents/release/keyholder.webp) no-repeat;
	background-size: 100% auto;
}

#release .data dt {
	padding: 0 0 0 0.75em;
	position: relative;
}

#release .data dt::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.7em;
	display: block;
	width: 0.5em;
	height: 0.5em;
	background: #4b4845;
}

#release .data > p,
#release .data dd {
	padding: 0 0 0 0.75em;
}

#release .vos-limited .data dd {
	padding: 0 0 16px 0.75em;
}

#release .data dd p,
#release .data > p {
	padding-top: 4px;
	font-size: 14px;
	line-height: 1.6;
}

#release .data h3 {
	margin-bottom: 8px;
	padding: 1em 0;
	text-align: center;
	font-size: 18px;
	line-height: 1.2;
	font-weight: 500;
	border-top: solid 1px;
	border-bottom: solid 1px;
}

#release .track-list dl {
	padding: 40px 0 64px;
	display: flex;
	flex-direction: column;
	align-items: center;
}

#release .track-list dt {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 8em;
	height: 2.2em;
	line-height: 1.2;
	border: solid 1px;
}

#release .track-list dd {
	padding: 8px 0 0 0;
	flex: 1;
}

#release .track-list ol {
	padding: 0 0 0 0;
	counter-reset: listcount;
}


#release .track-list ol > li {
	padding: 0 0 20px 0;
	display: flex;
	align-items: start;
	flex-wrap: wrap;
}


#release .track-list ol > li::before {
	counter-increment: listcount;
	content: counter(listcount, decimal-leading-zero) ".";
	padding-right: 4px;
	text-align: left;
	font-size: 18px;
	line-height: 1.2;
	z-index: 1;
}

#release .track-list ol > li > p {
	line-height: 1.2;
	font-size: 18px;
}


#release .v > div {
	position: relative;
	padding: 0 0 56.25%;
	height: 100%;
}

.v > div iframe,
.v > div object,
.v > div embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 3;
}


#release .bonus-detail {
	padding: 120px 0 0;
}

#release .bonus-detail > .lead {
	padding: 32px 0 24px;
	font-size: 20px;
}

#release .bonus-detail .bonus {
	margin-bottom: 40px;
	position: relative;
	text-align: center;
	background: transparent;
	border: solid 1px;
	border-radius: 12px;
	transition: opacity 1s cubic-bezier(.57,0,.26,1) 0s, transform 1s cubic-bezier(.57,0,.26,1) 0s,  background 1s cubic-bezier(.57,0,.26,1) 0s;
}

#release .bonus-detail .bonus.open {
	background: #fff;
}

.pink #release .bonus-detail .bonus {
	animation: pinkGreenBorder 8s ease-in-out forwards;
}

.green #release .bonus-detail .bonus {
	animation: greenBrownBorder 8s ease-in-out forwards;
}

.brown #release .bonus-detail .bonus {
	animation: brownPinkBorder 8s ease-in-out forwards;
}

#release .bonus-detail .bonus-1-live_salesarea-detail {
	margin: 0;
}

#release #bonus-2 .bonus {
	margin-bottom: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
}


@media only screen and (max-width: 1080px) {
}

#release #bonus-1 .bonus::after {
	content: "";
	position: absolute;
	top: 29px;
	right: 21px;
	display: block;
	width: 17px;
	height: 1px;
	background: #4b4845;
	z-index: 1;
}

.pink #release #bonus-1 .bonus::after {
	animation: pinkGreen 8s ease-in-out forwards;
}

.green #release #bonus-1 .bonus::after {
	animation: greenBrown 8s ease-in-out forwards;
}

.brown #release #bonus-1 .bonus::after {
	animation: brownPink 8s ease-in-out forwards;
}

#bornus-detail .contents > div > h3,
#release .bonus-detail .bonus > dt {
	padding: 48px 24px 48px;
	font-size: 28px;
	text-align: center;
	font-weight: 500;
	line-height: 1.2;
	cursor: pointer;
	-webkit-user-select: none;
	user-select: none;
}

#release #bonus-1 .bonus > dt::before {
	content: "";
	position: absolute;
	top: 16px;
	right: 16px;
	display: block;
	width: 25px;
	height: 25px;
	border: solid 1px;
	z-index: 10;
}

.pink #release #bonus-1 .bonus > dt::before {
	animation: pinkGreenBorder 8s ease-in-out forwards;
}

.green #release #bonus-1 .bonus > dt::before {
	animation: greenBrownBorder 8s ease-in-out forwards;
}

.brown #release #bonus-1 .bonus > dt::before {
	animation: brownPinkBorder 8s ease-in-out forwards;
}

#release #bonus-1 .bonus > dt::after {
	content: "";
	position: absolute;
	top: 21px;
	right: 29px;
	display: block;
	width: 1px;
	height: 17px;
	background: #4b4845;
	transition: transform 0.5s cubic-bezier(.57,0,.26,1) 0s;
	z-index: 10;
}

.pink #release #bonus-1 .bonus > dt::after {
	animation: pinkGreen 8s ease-in-out forwards;
}

.green #release #bonus-1 .bonus > dt::after {
	animation: greenBrown 8s ease-in-out forwards;
}

.brown #release #bonus-1 .bonus > dt::after {
	animation: brownPink 8s ease-in-out forwards;
}

#release .bonus-detail .bonus.open > dt::after {
	transform: rotate(90deg);
}

#bornus-detail .contents > div > h3 span,
#release .bonus-detail .bonus > dt span {
	padding-bottom: 0.8em;
	font-size: 22px;
	display: flex;
	justify-content: center;
	align-items: center;
}

#bornus-detail .contents > div > h3 span::after,
#bornus-detail .contents > div > h3 span::before,
#release .bonus-detail .bonus > dt span::after,
#release .bonus-detail .bonus > dt span::before {
	content: "";
	margin: 0 0.5em;
	display: block;
	width: 3em;
	height: 1px;
	background: #4b4845;
}

@media only screen and (max-width: 1240px) {
	#bornus-detail .contents > div > h3 span,
	#release .bonus-detail .bonus > dt span {
		padding-bottom: 0.4em;
	}
}

@media only screen and (max-width: 1080px) {
	#bornus-detail .contents > div > h3,
	#release .bonus-detail .bonus > dt {
		font-size: 2.4vw;
	}
}

#release .bonus-detail .bonus > dd {
	padding: 0 48px 56px;
	display: none;
	text-align: left;
}

#release .bonus-detail .bonus > dd .lead {
	padding: 0 0 24px 0;
}

#release .bonus-detail .bonus > dd > dl {
	display: flex;
	align-items: start;
	flex-wrap: wrap;
}

#release .bonus-detail .bonus > dd > dl > dt {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 8em;
	height: 2.4em;
	border: solid 1px;
}

#release .bonus-detail .bonus > dd > dl > dd {
	padding: 0 0 32px 16px;
	position: relative;
	width: calc(100% - 8em);
}

#release .bonus-detail .bonus > dd > dl > dd:last-child {
	padding: 0 0 0 16px;
	margin-top: auto;
	line-height: 2.4;
}

#release .bonus-detail .bonus > dd > dl > dd:nth-of-type(2) p {
	padding-top: 0.25em;
}

#release .present {
}

#release .info li,
#release .present li {
	padding-right: 19%;
	display: flex;
}

#release .info li {
}

#release .info + .notice {
	padding-right: 19%;
}

#release .bonus-1-ec_order-detail .present li,
#release .bonus-1-ec_order-detail .info li,
#release .bonus-1-ec_order-detail .info + .notice {
	padding-right: 0;
}

#release .present li::before {
	content: "・";
}

body.bonus-1 #bornus-detail #content dl::after,
#release .bonus > dd > dl > dd:nth-of-type(1)::after {
	content: "";
	padding-top: calc(154.5% * 0.15 + 4px);
	position: absolute;
	top: 0;
	right: 0;
	display: block;
	width: calc(100% * 0.15);
	height: 0;
	flex-shrink: 0;
	white-space: pre;
	text-align: center;
	font-size: 11px;
	line-height: 1.6;
}

body.bonus-1 #bornus-detail #content dl::after {
	margin: 8px 0;
	position: static;
}

body#bonus-1-1 #bornus-detail #content dl::after,
#release .bonus-1-1-detail > dd > dl > dd:nth-of-type(1)::after {
	content: "SpecialトレカA";
	background: url(../images/contents/release/bonus-1/card/card-a.webp) no-repeat;
	background-size: 100% auto;
}

body#bonus-1-2 #bornus-detail #content dl::after,
#release .bonus-1-2-detail > dd > dl > dd:nth-of-type(1)::after {
	content: "SpecialトレカB";
	background: url(../images/contents/release/bonus-1/card/card-b.webp) no-repeat;
	background-size: 100% auto;
}

body#bonus-1-3 #bornus-detail #content dl::after,
#release .bonus-1-3-detail > dd > dl > dd:nth-of-type(1)::after {
	content: "SpecialトレカC";
	background: url(../images/contents/release/bonus-1/card/card-c.webp) no-repeat;
	background-size: 100% auto;
}

#release .bonus-1-ec_order-detail > dd > dl > dd:nth-of-type(1)::after {
	display: none;
}

body#bonus-1-live_salesarea #bornus-detail #content dl::after,
#release .bonus-1-live_salesarea-detail > dd > dl > dd:nth-of-type(1)::after {
	content: "SpecialトレカD";
	background: url(../images/contents/release/bonus-1/card/card-d.webp) no-repeat;
	background-size: 100% auto;
}


#release .info li::before {
	content: "";
	margin: 0.75em 0.5em 0 0;
	display: block;
	width: 0.5em;
	height: 0.5em;
	flex-shrink: 0;
	background: #4b4845;
}

#release .present li > p {
}

#release .info {
	padding-top: 16px;
}

body.bonus-1 #bornus-detail .type,
#release .bonus-detail .bonus .link.disabled,
#release .bonus-detail .bonus .type {
	position: relative;
}

body.bonus-1 #bornus-detail .type.disabled::before,
#release .bonus-detail .bonus .link.disabled::before,
#release .bonus-detail .bonus .type.disabled::before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 10;
}


#release .bonus-detail .bonus .type li {
	padding-top: 24px;
	position: relative;
	z-index: 5;
}

#release .bonus-detail .bonus-1-live_salesarea-detail .type li {
	padding: 4px 0 0;
	display: flex;
}

#release .bonus-detail .bonus-1-live_salesarea-detail .type li::before {
	content: "・";
}

.bonus-1 #bornus-detail .type a,
#release .bonus-detail .bonus .link a,
#release .bonus-detail .bonus .type a {
	padding: 24px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	font-weight: 500;
	color: #fff;
	text-decoration: none;
	text-align: center;
	background: #444;
	-webkit-user-select: none;
	user-select: none;
	border-radius: 12px;
}

.bonus-1 #bornus-detail .type a p:nth-of-type(1),
#release .bonus-detail .bonus .link a p:nth-of-type(1),
#release .bonus-detail .bonus .type a p:nth-of-type(1) {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: left;
}

.bonus-1 #bornus-detail .type a p span,
#release .bonus-detail .bonus .link a p span,
#release .bonus-detail .bonus .type a p span {
	display: block;
	text-align: center;
}

.bonus-1 #bornus-detail .type a p:nth-of-type(2),
#release .bonus-detail .bonus .type a p:nth-of-type(2) {
	margin-top: 0.5em;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 8em;
	height: 2.6em;
	font-size: 18px;
	border: solid 1px;
}

body.bonus-1 #bornus-detail .type.disabled a,
#release .bonus-detail .bonus .link.disabled a,
#release .bonus-detail .bonus .type.disabled a {
	opacity: .1;
}

#release .bonus-detail .bonus .link {
	padding: 32px 0 8px;
}

#release .bonus-detail .bonus .link a {
	margin: 0 auto;
	padding: 0;
	width: 14em;
	height: 4em;
	font-size: 18px;
}

#release .bonus-detail .bonus .link + .notice li {
	justify-content: center;
}

#release #bonus-2 .list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 32px;
}

#release #bonus-2 .list > li {
	width: calc((100% - 32px * 2) / 3);
	display: flex;
	justify-content: center;
}

@media only screen and (max-width: 1160px) {

	#release #bonus-2 .list > li {
		width: calc((100% - 32px * 1) / 2);
	}

}

#release #bonus-2 .list > li dl {
display: flex;
	flex-direction: column;
	width: 100%;
}

#release #bonus-2 .list > li dt {
	padding-left: 0.8em;
	position: relative;
display: flex;
	align-items: end;
flex-grow: 1;
	text-align: left;
	font-weight: 500;
	font-size: 18px;
	line-height: 1.6;
}

@media only screen and (max-width: 1160px) {
	#release #bonus-2 .list > li dt {
		font-size: 16px;
	}
	#release #bonus-2 .list > li dt br {
		display: none;
	}
}

#release #bonus-2 .list > li dt::before {
	content: "";
	position: absolute;
	top: 0.5em;
	left: 0;
	display: block;
	width: 0.5em;
	height: 0.5em;
	flex-shrink: 0;
	background: #4b4845;
}

#release #bonus-2 .list .rakuten dt::before,
#release #bonus-2 .list .vos dt::before {
	top: auto;
	bottom: 0.5em;
}

#release #bonus-2 .list > li dd {
	padding-top: 8px;
display: flex;
	flex-direction: column;
}

#release #bonus-2 .list > li dd::before {
	content: "";
	margin-bottom: 8px;
	padding-top: 142%; 
	display: block;
	width: 100%;
	height: 0;
}

#release #bonus-2 .list .vos dd::before {
	background: url(../images/contents/release/bonus-2/vos.webp) no-repeat;
	background-size: 100% auto;
}

#release #bonus-2 .list .tower dd::before {
	background: url(../images/contents/release/bonus-2/tower.webp) no-repeat;
	background-size: 100% auto;
}

#release #bonus-2 .list .hmv dd::before {
	background: url(../images/contents/release/bonus-2/hmv.webp) no-repeat;
	background-size: 100% auto;
}

#release #bonus-2 .list .rakuten dd::before {
	background: url(../images/contents/release/bonus-2/rakuten.webp) no-repeat;
	background-size: 100% auto;
}

#release #bonus-2 .list .seven dd::before {
	background: url(../images/contents/release/bonus-2/seven.webp) no-repeat;
	background-size: 100% auto;
}

#release #bonus-2 .list > li dd p {
	font-size: 14px;
	white-space: nowrap;
}

/*--------------------------------------
profile
---------------------------------------*/
#profile {
	padding: 120px 0 180px;
}

.primary section#profile .contents {
	padding-top: 32px;
}

#profile .contents > div {
	padding-bottom: 32px;
	position: relative;
}

@media only screen and (max-width: 1080px) {
}


#profile .link {
}


#profile .link li {
}

#profile .sns-link > ul {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 16px;
}

#profile .sns-link li {
	width: auto;
	max-width: none;
}

#profile .sns-link li:last-child {
	padding-bottom: 16px;
	width: 100%;
}

#profile .sns-link::after {
	margin: 8px 0 8px;
}

#profile .link a,
#profile .sns-link li a {
	padding-top: 0;
	position: relative;
	overflow: hidden;
	display: flex;
	align-items: center;
	width: auto;
	height: auto;
	font-size: 13px;
	background: none;
	text-decoration: none;
	user-select: none;
}

#profile .link a::before,
#profile .sns-link li a::before {
	content: "";
	margin-right: 0.3em;
	display: block;
	width: 1.4em;
	height: 1.4em;
	flex-shrink: 0;
}

#profile .link a::before,
#profile .sns-link .fc a::before {
	background: url(../images/contents/profile/link.svg) no-repeat center center;
	background-size: 100% auto;
}

#profile .sns-link .x a::before {
	background: url(../images/contents/profile/sns/x.svg) no-repeat center center;
	background-size: 100% auto;
}

#profile .sns-link .youtube a::before {
	background: url(../images/contents/profile/sns/youtube.svg) no-repeat center center;
	background-size: 100% auto;
}

#profile .sns-link .instagram a::before {
	background: url(../images/contents/profile/sns/instagram.svg) no-repeat;
	background-size: 100% auto;
}

/*--------------------------------------
上部へボタン
---------------------------------------*/

ul.toTop {
	overflow: hidden;
	position: fixed;
	bottom: 0;
	right: 0;
	opacity: 0;
	transition: opacity 1.2s cubic-bezier(.34,0,0,.99);
z-index: 1001;
}

.wrapper.active .toTop {
	opacity: 1;
}

.toTop a {
	padding-top: 48px;
	position: relative;
	display: block;
	overflow: hidden;
	width: 48px;
	height: 0;
}

.toTop a::before {
	content: "";
	margin: -5px 0 0 -11px;
	position: absolute;
	top: 50%;
	left: 50%;
	display: block;
	width: 20px;
	height: 20px;
	border: solid 1px #78786e;
	border-right: none;
	border-bottom: none;
	transition: 0.4s ease-in-out;
	transform: rotate(45deg);
	transform-origin: center center;
}

ul.toTop a:hover {
	opacity: 1;
}

ul.toTop a:hover::before {
	border-color: #d6d6c5;
}

/*--------------------------------------
フッター
---------------------------------------*/

footer {
	padding: 120px 0;
	position: relative;
	clear: both;
	overflow: hidden;
	width: 100%;
	text-align: center;
	z-index: 1000;
}

.pink footer {
	animation: pinkGreen 8s ease-in-out forwards;
}

.green footer {
	animation: greenBrown 8s ease-in-out forwards;
}

.brown footer {
	animation: brownPink 8s ease-in-out forwards;
}

@media only screen and (max-width: 1080px) {
}

footer::before {
	content: "";
	margin: 0 auto;
	padding-top: 9%;
	display: block;
	width: 19%;
	height: 0;
	background: url(../images/common/footer/logo.svg) no-repeat;
	background-size: 100% auto;
}

footer .credit {
}

footer .copyright p {
	font-family: 'Oswald', "Hiragino Sans", "ヒラギノ角ゴ Pro W3", 'Hiragino Kaku Gothic Pro', "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", verdana, sans-serif;
	font-weight: 400;
	transform: scaleX(0.8);
	line-height: 1.1;
	letter-spacing: 0.15em;
	font-size: 16px;
	color: #fff;
}

footer .copyright br {
	display: none;
}

footer .copyright a {
	color: #fff;
	text-decoration: none;
}

.copyright a {

}



/*--------------------------------------------------------------------------------------------------*/


@media only screen and (max-width: 980px) {

	body {
		font-size: 15px;
	}

	.notice li::before,
	.notice p {
		font-size: 13px;
		line-height: 1.6;
	}

	body.bonus-1 .primary {
		padding: 80px 0 96px;
	}

	.primary section .contents {
		padding: 0 40px 0;
	}

	#information {
		padding: 80px 0 0;
	}

	#release {
	padding: 120px 0 0;
	}


}

/*--------------------------------------------------------------------------------------------------*/


@media only screen and (max-width: 860px) {

	.primary section .contents {
		padding: 0 32px 0;
	}

}


/*--------------------------------------------------------------------------------------------------*/


@media only screen and (max-width: 780px) {

}

/*--------------------------------------------------------------------------------------------------*/
@media only screen and (max-width: 520px) {

	body {
		line-height: 1.8;
		font-size: 14px;
	}

	#top {
		padding: 0;
	}

	.siteTitle {
		padding-top: 51px;
	}

	#home .siteTitle,
	#home #top {
		padding: 0;
	}

#top .globalNav {
	display: none;
}

	#menu-btn {
		display: block;
	}

	.menu .globalNav li {
		padding: 1em 0;
	overflow: hidden;
	}

	.globalNav a p {
		font-size: 6vw;
		line-height: 1.2;
	}

	.globalNav > li a::after {
		padding-top: 8px;
		font-size: 12px;
		line-height: 1.2;
	}

	#top .sns-link {
		padding: 8px 8px 0 0;
	}

	.sns-link li {
		width: 34px;
	}

	#top .intro {
		padding-bottom: 33%;
		width: 76%;
	}

	#top .intro li:nth-of-type(5) {
		width: 72%;
	}

	#top .scroll {
		padding: 0 0 calc(11em * 0.8);
		bottom: 8px;
		right: 8px;
		font-size: 18px;
	}

	.scroll p {
		padding-top: 5em;
	}

	body.bonus-1 .primary {
		padding: 56px 0 80px;
	}

	body.bonus-1 .primary section .contents {
		padding-top: 24px;
	}

		body.bonus-1 #bornus-detail .contents > ul,
		body.bonus-1 #bornus-detail .contents > div .lead {
		padding: 0 16px 0;
	}

	.bonus-1 .primary section h1,
	.primary section h2, #bonus-1 h3,
	#bonus-2 h3 {
		font-size: 7.2vw;
		letter-spacing: 0.1em;
	}

	.bonus-1 .primary section h1::after,
	#bonus-1 h3::after, #bonus-2 h3::after,
	.primary section h2::after {
		padding-top: 0.3em;
		font-size: 16px;
	}

	.primary section .contents {
		padding: 0 16px 0;
	}

	#information {
		padding: 56px 0 32px;
	}

	#information .entryList {
		padding-top: 24px;
	}

	#information .entry a {
		padding: 16px 32px 16px 0;
		flex-wrap: wrap;
	}

	#information .entry span {
		width: 100%;
	}

	#information .entry a::after {
		padding-top: 12px;
		right: 8px;
		width: 12px;
	}

	#information .link {
		gap: 8px;
	}

	#information .link li:nth-of-type(1) {
		flex: 1;
	}

	#information .link a {
		padding: 0 1em;
		height: 4em;
		line-height: 1.4;
	}

	#information .link a br {
		display: block;
	}

	#release {
		padding: 56px 0 0;
	}

	#release .VIZL-2473 {
		padding-top: 32px;
	}

	#release .VIZL-2473 > h3 {
		padding-top: 20%;
		width: 65%;
	}

	#release .date {
		padding: 12px 0 16px;
	}

	#release .date p {
		font-size: 18px;
	}

	#release .detail {
		padding: 0 0 32px;
	}

	#release .type > ul {
		flex-direction: column;
		gap: 32px;
	}

	#release .type > ul > li {
		width: 100%;
	}

	#release .jacket {
	}

	#release .normal .jacket {
		padding-top: 0;
	}

	#release .normal .jacket img {
		position: static;
		transform: none;
	}

	#release .jacket::before {
		content: "NOW PRINTING";
		font-size: 29px;
		opacity: .15;
	}

	#release .normal .jacket::before {
		left: 0%;
	width: 100%;
		height: 100%;
		transform: scaleX(0.8);
	}

	#release .data dd p,
	#release .data > p {
		font-size: 13px;
	}

	#release .data h3 {
		font-size: 16px;
	}

	#release .track-list dl {
		padding: 40px 0 32px;
	}

	#release .bonus-detail {
		padding: 56px 0 32px;
	}

	#release .bonus-detail > .lead {
		padding: 16px 0 16px;
		font-size: 14px;
	}

	#release .bonus-detail .bonus {
		margin-bottom: 16px;
	}

	#bornus-detail .contents > div > h3,
	#release .bonus-detail .bonus > dt {
		padding: 24px 16px 24px;
		font-size: 15px;
		line-height: 1.6;
		text-align: left;
	}

	#bornus-detail .contents > div > h3 {
		padding: 24px 16px 16px;
	}

	#bornus-detail .contents > div > h3 span,
	#release .bonus-detail .bonus > dt span {
		padding-bottom: 0.4em;
		letter-spacing: 0;
		font-size: 13px;
	}

	#bornus-detail .contents > div > h3 span::after,
	#bornus-detail .contents > div > h3 span::before,
	#release .bonus-detail .bonus > dt span::after,
	#release .bonus-detail .bonus > dt span::before {
		width: 2em;
	}

	#release #bonus-1 .bonus > dt::before {
		top: 8px;
		right: 8px;
		width: 21px;
		height: 21px;
	}

	#release #bonus-1 .bonus > dt::after {
		top: 13px;
		right: 19px;
		height: 13px;
}

	#release #bonus-1 .bonus::after {
		top: 19px;
		right: 13px;
		width: 13px;
	}

	#release .bonus-detail .bonus > dd {
		padding: 0 16px 48px;
	}

	#release .bonus-detail .bonus > dd > dl > dd:nth-of-type(2) p {
		padding-top: 0;
	}

	#release .bonus-detail .bonus > dd > dl {
		flex-direction: column;
	}

	#release .bonus-detail .bonus > dd .lead {
		padding: 0 0 16px 0;
	}

	#release .bonus-detail .bonus > dd > dl > dt {
		width: 100%;
		height: 2.4em;
	}

	#release .bonus-detail .bonus > dd > dl > dd {
		padding: 8px 0 24px 0;
		display: flex;
		flex-wrap: wrap;
		flex-direction: column;
		width: 100%;
	}

	#release .present {
		order: 1;
	}

	#release .present + div {
		order: 3;
	}

	#release .info + .notice,
	#release .info li,
	#release .present li {
		padding-right: 0;
	}

	body.bonus-1 #bornus-detail #content dl::after,
	#release .bonus > dd > dl > dd:nth-of-type(1)::after {
		margin: 8px auto;
		padding-top: calc(154.5% * 0.3 + 4px);
		width: calc(100% * 0.3);
		position: static;
		order: 2;
	}

	body.bonus-1 #bornus-detail #content dl::after {
		display: none;
	}

	body.bonus-1 #bornus-detail #content dd .notice:nth-of-type(1)::after {
		content: "";
		margin: 8px auto 24px;
		padding-top: calc(154.5% * 0.3 + 4px);
		display: block;
		width: calc(100% * 0.3);
		height: 0;
		flex-shrink: 0;
		white-space: pre;
		text-align: center;
		font-size: 11px;
		line-height: 1.6;
	}

	body#bonus-1-1 #bornus-detail #content dd .notice:nth-of-type(1)::after {
		content: "SpecialトレカA";
		background: url(../images/contents/release/bonus-1/card/card-a.webp) no-repeat;
		background-size: 100% auto;
	}

		body#bonus-1-2 #bornus-detail #content dd .notice:nth-of-type(1)::after {
		content: "SpecialトレカB";
		background: url(../images/contents/release/bonus-1/card/card-b.webp) no-repeat;
		background-size: 100% auto;
	}

		body#bonus-1-3 #bornus-detail #content dd .notice:nth-of-type(1)::after {
		content: "SpecialトレカC";
		background: url(../images/contents/release/bonus-1/card/card-c.webp) no-repeat;
		background-size: 100% auto;
	}

		body#bonus-1-ec_order #bornus-detail #content dd .notice:nth-of-type(1)::after {
		display: none;
	}

		body#bonus-1-live_salesarea #bornus-detail #content dd .notice:nth-of-type(1)::after {
		content: "SpecialトレカD";
		background: url(../images/contents/release/bonus-1/card/card-d.webp) no-repeat;
		background-size: 100% auto;
	}

	.bonus-1 #bornus-detail .type a,
	#release .bonus-detail .bonus .link a,
	#release .bonus-detail .bonus .type a {
		padding: 16px;
	}

	.bonus-1 #bornus-detail .type a p:nth-of-type(1),
	#release .bonus-detail .bonus .link a p:nth-of-type(1),
	#release .bonus-detail .bonus .type a p:nth-of-type(1) {
		font-size: 13px;
	}

	#release .bonus-detail .bonus .link a,
	.bonus-1 #bornus-detail .type a p:nth-of-type(2),
	#release .bonus-detail .bonus .type a p:nth-of-type(2) {
		font-size: 15px;
	}

	#release .bonus-detail .bonus > dd > dl > dd:last-child {
		padding: 8px 0 0 0;
		line-height: 1.8;
	}

	#release #bonus-2 .list {
		align-items: center;
		flex-direction: column;
		gap: 16px;
	}

	#release #bonus-2 .list > li {
		width: 100%;
	}

	#release #bonus-2 .list > li dd::before {
		margin: 0 auto 8px auto;
		padding-top: calc(142% * 0.6);
		width: calc(100% * 0.6)
	}

	#release #bonus-2 .list > li dt {
		font-size: 15px;
	}


	#profile {
		padding: 56px 0;
	}

	.primary section#profile .contents {
		padding-top: 16px;
	}

	#profile .contents > div {
		padding-bottom: 24px;
	}

	#profile .sns-link > ul {
		gap: 8px;
	}

	#profile .sns-link li:last-child {
		padding: 16px 0 24px;
	}

	footer .copyright p {
		font-size: 12px;
	}

	footer::before {
		padding-top: 21%;
		width: 46%;
	}
}

@media screen and (orientation: landscape) {



}
