@charset "utf-8";

:root {
}

/* モバイル　ALL */
@media screen and (max-width: 425px) {
	:root {
		--Width: 100%;

		--Margin_L: 0 0 var(--Size_36);
		--Margin_M: 0 0 var(--Size_24);
		--Margin_S: 0 0 var(--Size_12);

		--Width_L: 0 var(--Size_12) var(--Size_36);
		--Width_M: 0 var(--Size_12) var(--Size_24);
		--Width_S: 0 var(--Size_12) var(--Size_12);
		--Width_0: 0 var(--Size_12);

		--padding: var(--Size_12);

		/* ウェルカムマップ */
		--Iframe_aspect-ratio: 4 / 3;

		/* Flex 制御*/
		--Flex-direction_CRRR: column;
		--Flex-direction_CRCC: column;
		--Flex-direction_CCRR: column;
		--Flex-direction_CCCR: column;
		--Flex-direction_CCCC: column;
		--Flex-direction_RCCC: row;
		--Flex-direction_CrRRR: column-reverse;
		--Flex-direction_CrRCrR: column-reverse;
		--Flex-direction_RRRCrR: row;
		--Flex-direction_CrCrCrCrR: row;

		--Flex-direction_CRRRRR: column;
		--Flex-direction_CCRRRR: column;
		--Flex-direction_CCCRRR: column;
	}
}

/* タブレット */
@media screen and (min-width:426px) and (max-width: 768px) {
	:root {
		--Width: 100%;

		--Margin_L: 0 0 var(--Size_36);
		--Margin_M: 0 0 var(--Size_24);
		--Margin_S: 0 0 var(--Size_12);

		--Width_L: 0 var(--Size_12) var(--Size_36);
		--Width_M: 0 var(--Size_12) var(--Size_24);
		--Width_S: 0 var(--Size_12) var(--Size_12);
		--Width_0: 0 var(--Size_12);

		--padding: var(--Size_12);

		/* ウェルカムマップ */
		--Iframe_aspect-ratio: 4 / 3;

		/* Flex 制御*/
		--Flex-direction_CRRR: row;
		--Flex-direction_CRCC: row;
		--Flex-direction_CCRR: column;
		--Flex-direction_CCCR: column;
		--Flex-direction_CCCC: column;
		--Flex-direction_RRCC: row;
		--Flex-direction_CrRRR: row;
		--Flex-direction_CrRCrR: column-reverse;
		--Flex-direction_RRRCrR: column-reverse;
		--Flex-direction_CrCrCrCrR: column-reverse;

		--Flex-direction_CRRRRR: row;
		--Flex-direction_CCRRRR: column;
		--Flex-direction_CCCRRR: column;
	}
}

/* ノートパソコン */
@media screen and (min-width:769px) and ( max-width:1024px) {
	:root {
		--Width: 100%;

		--Margin_L: 0 0 var(--Size_36);
		--Margin_M: 0 0 var(--Size_24);
		--Margin_S: 0 0 var(--Size_12);

		--Width_L: 0 var(--Size_12) var(--Size_36);
		--Width_M: 0 var(--Size_12) var(--Size_24);
		--Width_S: 0 var(--Size_12) var(--Size_12);
		--Width_0: 0 var(--Size_12);

		--padding: var(--Size_12);

		/* ウェルカムマップ */
		--Iframe_aspect-ratio: 4 / 3;

		/* Flex 制御*/
		--Flex-direction_CRRR: row;
		--Flex-direction_CRCC: column;
		--Flex-direction_CCRR: row;
		--Flex-direction_CCCR: column;
		--Flex-direction_CCCC: column;
		--Flex-direction_RRCC: column;
		--Flex-direction_CrRRR: row;
		--Flex-direction_CrRCrR: row;
		--Flex-direction_RRRCrR: row;
		--Flex-direction_CrCrCrCrR: column-reverse;

		--Flex-direction_CRRRRR: row;
		--Flex-direction_CCRRRR: row;
		--Flex-direction_CCCRRR: column;
	}
}

/* ノートパソコン L */
@media screen and (min-width:1025px) and ( max-width:1440px) {
	:root {
		--Width: 1024px;

		--Margin_L: 0 0 var(--Size_36);
		--Margin_M: 0 0 var(--Size_24);
		--Margin_S: 0 0 var(--Size_12);

		--Width_L: 0 calc( calc( 100% - var(--Width) ) / 2) var(--Size_36);
		--Width_M: 0 calc( calc( 100% - var(--Width) ) / 2) var(--Size_24);
		--Width_S: 0 calc( calc( 100% - var(--Width) ) / 2) var(--Size_12);
		--Width_0: 0 calc( calc( 100% - var(--Width) ) / 2);

		/* ウェルカムマップ */
		--Iframe_aspect-ratio: 16 / 4.5;

		/* Flex 制御*/
		--Flex-direction_CRRR: row;
		--Flex-direction_CRCC: column;
		--Flex-direction_CCRR: row;
		--Flex-direction_CCCR: row;
		--Flex-direction_CCCC: column;
		--Flex-direction_RRCC: column;
		--Flex-direction_CrRRR: row;
		--Flex-direction_CrRCrR: column-reverse;
		--Flex-direction_RRRCrR: row;
		--Flex-direction_CrCrCrCrR: column-reverse;

		--Flex-direction_CRRRRR: row;
		--Flex-direction_CCRRRR: row;
		--Flex-direction_CCCRRR: row;
	}
}

/* 2K以上 */
@media screen and (min-width:1441px) and ( max-width:2560px) {
	:root {
		--Width: 1280px;

		--Margin_L: 0 0 var(--Size_36);
		--Margin_M: 0 0 var(--Size_24);
		--Margin_S: 0 0 var(--Size_12);

		--Width_L: 0 calc( calc( 100% - var(--Width) ) / 2) var(--Size_36);
		--Width_M: 0 calc( calc( 100% - var(--Width) ) / 2) var(--Size_24);
		--Width_S: 0 calc( calc( 100% - var(--Width) ) / 2) var(--Size_12);
		--Width_0: 0 calc( calc( 100% - var(--Width) ) / 2);

		/* ウェルカムマップ */
		--Iframe_aspect-ratio: 16 / 4.5;

		/* Flex 制御*/
		--Flex-direction_CRRR: row;
		--Flex-direction_CRCC: column;
		--Flex-direction_CCRR: row;
		--Flex-direction_CCCR: row;
		--Flex-direction_CCCC: column;
		--Flex-direction_RRCC: column;
		--Flex-direction_CrRRR: row;
		--Flex-direction_CrRCrR: row;
		--Flex-direction_RRRCrR: row;
		--Flex-direction_CrCrCrCrR: column-reverse;

		--Flex-direction_CRRRRR: row;
		--Flex-direction_CCRRRR: row;
		--Flex-direction_CCCRRR: row;
	}
}

/* 4K以上 */
@media screen and (min-width:2561px) {
	:root {
		--Width: 1280px;

		--Margin_L: 0 0 var(--Size_36);
		--Margin_M: 0 0 var(--Size_24);
		--Margin_S: 0 0 var(--Size_12);

		--Width_L: 0 calc( calc( 100% - var(--Width) ) / 2) var(--Size_36);
		--Width_M: 0 calc( calc( 100% - var(--Width) ) / 2) var(--Size_24);
		--Width_S: 0 calc( calc( 100% - var(--Width) ) / 2) var(--Size_12);
		--Width_0: 0 calc( calc( 100% - var(--Width) ) / 2);

		/* ウェルカムマップ */
		--Iframe_aspect-ratio: 16 / 4.5;

		/* Flex 制御*/
		--Flex-direction_CRRR: row;
		--Flex-direction_CRCC: column;
		--Flex-direction_CCRR: row;
		--Flex-direction_CCCR: row;
		--Flex-direction_CCCC: column;
		--Flex-direction_RRCC: column;
		--Flex-direction_CrRRR: row;
		--Flex-direction_CrRCrR: row;
		--Flex-direction_RRRCrR: row;
		--Flex-direction_CrCrCrCrR: column-reverse;

		--Flex-direction_CRRRRR: row;
		--Flex-direction_CCRRRR: row;
		--Flex-direction_CCCRRR: row;
	}
}




/* Set */

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 62.5%;
	font: inherit;
	vertical-align: baseline;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
}

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

html {
	max-width: 100%;
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}

body {
	position: relative;
	display: flex;
	flex-direction: column;
	padding: 0;
	min-height: 100vh;
	background: var(--Color_1D100);
	-webkit-animation: fadeIn 4s ease 0s 1 normal;
	animation: fadeIn 2s ease 0s 1 normal;
}

header, article, section, div, footer,
table, tr, th, td, ol, ul, li, dl, dt, dd,
h1, h2, h3, h4, h5, h6, p, span, b, i, a {
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}

body.jp {
	font-family: "Noto Serif JP", serif;
  font-weight: 400;
  font-style: normal;
}

body.en {
  font-family: "Noto Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-variation-settings:
    "wdth" 100;
}

body.kr {
  font-family: "Noto Sans KR", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

body.ct {
  font-family: "Noto Sans TC", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

body.cs {
  font-family: "Noto Sans SC", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

@keyframes fadeIn         { 0% { opacity: 0 } 100% { opacity: 1 } }
@-webkit-keyframes fadeIn { 0% { opacity: 0 } 100% { opacity: 1 } }

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
	content: '';
	content: none;
}

p, ol, ul, dl {
	color: var(--Color_FF100);
	line-height: 1.6;
}

ol, ul {
	list-style: none;
}

p, ol li, ul li, dl dt, dl dd {
	font-size: var(--Size_10);
}

span {
	font-size: var(--Size_08);
}

a {
	color: var(--Color_FF100);
	text-decoration: none;
	border: 0;
	transition: var(--Transition_04s);
	-o-transition: var(--Transition_04s);
	-moz-transition: var(--Transition_04s);
	-webkit-transition: var(--Transition_04s);
}

a:hover {

}

span.none {
	display: none;
}

figure {
	margin: 0;
}

img {
	max-width: 100%;
	vertical-align: bottom;
	object-fit: cover;
}






/* ーーーーーーーーーーーーーーーーーーーー
   H
ーーーーーーーーーーーーーーーーーーーー */

h1 {
	display: none;
}

h2 {
	display: flex;
	justify-content: center;
	margin: var(--Width_M);
	padding: var(--Size_08) 0;
	font-size: var(--Size_16);
	color: var(--Color_FF100);
	line-height: 1;
	letter-spacing: 2px;
	font-weight: 600;
	border-radius: var(--Border-radius_S);
	--tile: var(--Size_60);
	background-color: var(--Color_A060);
	background-image: url("https://rokuten.jp/wp-content/themes/Rokuten/svg/pattern_rokuten_006.svg");
	background-repeat: repeat;
	background-size: var(--tile);
	background-position: 0 0;
	backdrop-filter: var(--backdrop-filter_blur);
	-o-backdrop-filter: var(--backdrop-filter_blur);
	-moz-backdrop-filter: var(--backdrop-filter_blur);
	-webkit-backdrop-filter: var(--backdrop-filter_blur);
	animation: h2PatternLeft 8s linear infinite;
}

.kanda h2 {
	background-color: var(--Color_K060);
	background-image: url("https://rokuten.jp/wp-content/themes/Rokuten/svg/pattern_kanda_006.svg");
	background-size: var(--tile);
}

.osaka h2 {
	background-color: var(--Color_O060);
	background-image: url("https://rokuten.jp/wp-content/themes/Rokuten/svg/pattern_osaka_006.svg");
	background-size: var(--tile);
}

.naha h2 {
	background-color: var(--Color_N060);
	background-image: url("https://rokuten.jp/wp-content/themes/Rokuten/svg/pattern_naha_006.svg");
	background-size: var(--tile);
}


/* 右→左へ、タイル1枚分だけ移動（継ぎ目が出にくい） */
@keyframes h2PatternLeft{
	to{ background-position: calc(var(--tile) * -1) 0; }
}

/* 優しさ対応（動きが苦手な人向け） */
@media (prefers-reduced-motion: reduce){
	h2{ animation: none !important; }
}


h3 {
	position: relative;
	margin: var(--Width_M);
	padding: var(--Size_04) var(--Size_06);
	color: var(--Color_FF100);
	font-size: var(--Size_12);
	--tile: var(--Size_40);
	background-color: var(--Color_A010);
	background-image: url("https://rokuten.jp/wp-content/themes/Rokuten/svg/pattern_rokuten_006.svg");
	background-repeat: repeat;
	background-size: var(--tile);
	background-position: 0 0;
	border-bottom:  3px var(--Color_A100) solid;
	border-left: var(--Size_06) var(--Color_A100) solid;
	backdrop-filter: var(--backdrop-filter_blur);
	-o-backdrop-filter: var(--backdrop-filter_blur);
	-moz-backdrop-filter: var(--backdrop-filter_blur);
	-webkit-backdrop-filter: var(--backdrop-filter_blur);
	animation: h3PatternLeft 4s linear infinite;
}

.kanda h3 {
	background-color: var(--Color_K010);
	background: url("https://rokuten.jp/wp-content/themes/Rokuten/svg/pattern_kanda_006.svg");
	background-size: var(--tile);
	border-bottom: 3px var(--Color_K100) solid;
	border-left: var(--Size_06) var(--Color_K100) solid;
}

.osaka h3 {
	background-color: var(--Color_O010);
	background: url("https://rokuten.jp/wp-content/themes/Rokuten/svg/pattern_osaka_006.svg");
	background-size: var(--tile);
	border-bottom: 3px var(--Color_O100) solid;
	border-left: var(--Size_06) var(--Color_O100) solid;
}

.naha h3 {
	background-color: var(--Color_N010);
	background: url("https://rokuten.jp/wp-content/themes/Rokuten/svg/pattern_naha_006.svg");
	background-size: var(--tile);
	border-bottom: 3px var(--Color_N100) solid;
	border-left: var(--Size_06) var(--Color_N100) solid;
}

h3:after {
	content: '';
	position: absolute;
	right: 0;
	bottom: -3px;
	display: block;
	width: 70%;
	border-bottom: 3px var(--Color_1D060) solid;
}


/* 右→左へ、タイル1枚分だけ移動（継ぎ目が出にくい） */
@keyframes h3PatternLeft{
	to{ background-position: calc(var(--tile) * -1) 0; }
}

/* 優しさ対応（動きが苦手な人向け） */
@media (prefers-reduced-motion: reduce){
	h3{ animation: none !important; }
}

h4 {
	position: relative;
	display: inline-block;
	margin: var(--Width_S);
	padding: var(--Size_06);
	font-size: var(--Size_10);
	color: var(--Color_FF100);
	font-weight: 600;
	line-height: 1.6;
	background: var(--Color_A010);
	border: 1px var(--Color_A100) solid;
	border-radius: var(--Border-radius_S);
	backdrop-filter: var(--backdrop-filter_blur);
	-o-backdrop-filter: var(--backdrop-filter_blur);
	-moz-backdrop-filter: var(--backdrop-filter_blur);
	-webkit-backdrop-filter: var(--backdrop-filter_blur);
}

.kanda h4 {
	background: var(--Color_K010);
	border: 1px var(--Color_K040) solid;
}

.osaka h4 {
	background: var(--Color_O010);
	border: 1px var(--Color_O040) solid;
}

.naha h4 {
	background: var(--Color_N010);
	border: 1px var(--Color_N040) solid;
}

h4 em,
h4 span {
	font-size: var(--Size_08);
	font-weight: 400;
}

h5 {
	color: var(--Color_FF100);
	margin: 0 0 var(--Size_10);
	padding: var(--Size_06);
	font-size: var(--Size_12);
	font-weight: 600;
	line-height: 1.5;
	background: url("https://rokuten.jp/wp-content/themes/Rokuten/svg/higaki_006.svg");
	border-bottom: 1px var(--Color_A100) solid;
}












/* ーーーーーーーーーーーーーーーーーーーー
   アーティクル
ーーーーーーーーーーーーーーーーーーーー */

article {
	flex: 1;
	position: relative;
	display: flex;
	flex-direction: column;
	max-width: 100%;
	& main {
		flex: 1;
	}
}








/* ーーーーーーーーーーーーーーーーーーーー
   コンテンツ
ーーーーーーーーーーーーーーーーーーーー */

section#contents {
	flex: 1;
	position: relative;
	display: flex;
	flex-direction: column;
	padding: 0;
	& > p {
		margin: var(--Width_M);
		& a {
			display: inline-flex;
			margin: 0;
			padding: var(--Size_02) var(--Size_02);
			color: var(--Color_FF100);
			font-size: var(--Size_12);
			font-weight: 600;
		}
	}
	& ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		margin: var(--Width_M);
		& li {
			& img {
				width: 100%;
			}
		}
	}
	& ol {
		display: flex;
		flex-direction: column;
		flex-wrap: wrap;
		justify-content: space-between;
		margin: var(--Width_M);
		& li {
			transition: var(--Transition_04s);
			-o-transition: var(--Transition_04s);
			-moz-transition: var(--Transition_04s);
			-webkit-transition: var(--Transition_04s);
			& img {
				width: 100%;
			}
		}
	}
}

section#contents.page {
	flex: 1;
	position: relative;
	display: flex;
	flex-direction: column;
	padding: var(--Size_48) 0 0;
}



p.p24 {
	padding: 0 0 var(--Size_24);
}

.kanda p a {
	background: var(--Color_K020);
}

.osaka p a {
	background: var(--Color_O020);
}

.naha p a {
	background: var(--Color_N020);
}








/* ーーーーーーーーーーーーーーーーーーーー
   QRコード誘導
ーーーーーーーーーーーーーーーーーーーー */

.welcome > h2 {
	margin: 0 0 var(--Size_12);
	background: url("https://rokuten.jp/wp-content/themes/Rokuten/svg/pattern_kanda_006.svg"), var(--Color_A060);
	background-size: var(--Size_60);
}

.welcome > div {
	margin: 0 0 var(--Size_24);
	padding: var(--Size_06);
	border-radius: var(--Border-radius_S);
	backdrop-filter: var(--backdrop-filter_blur);
	-o-backdrop-filter: var(--backdrop-filter_blur);
	-moz-backdrop-filter: var(--backdrop-filter_blur);
	-webkit-backdrop-filter: var(--backdrop-filter_blur);
}

.welcome div.kanda {
	background: var(--Color_K010);
	border: var(--Border_K060);
}

.welcome div.osaka {
	background: var(--Color_O010);
	border: var(--Border_O060);
}

.welcome div h2 {
	margin: 0 0 var(--Size_24);
}

.welcome .kanda h2 {
	background: url("https://rokuten.jp/wp-content/themes/Rokuten/svg/pattern_kanda_006.svg"), var(--Color_K060);
	background-size: var(--Size_60);
}

.welcome .osaka h2 {
	background: url("https://rokuten.jp/wp-content/themes/Rokuten/svg/pattern_kanda_006.svg"), var(--Color_O060);
	background-size: var(--Size_60);
}

.welcome .kanda h3 {
	background: var(--Color_K010);
	border-bottom: 3px var(--Color_K100) solid;
	border-left: var(--Size_06) var(--Color_K100) solid;
}

.welcome .osaka h3 {
	background: var(--Color_O010);
	border-bottom: 3px var(--Color_O100) solid;
	border-left: var(--Size_06) var(--Color_O100) solid;
}

.welcome div iframe {
	margin: 0 0 var(--Size_12);
	width: 100%;
	border-radius: var(--Border-radius_S);
	aspect-ratio: var(--Iframe_aspect-ratio);
	filter: saturate(10%);
}

.welcome div iframe:hover {
	filter: saturate(0%);
}

.welcome div .btn {
	margin: var(--Size_12) 0 var(--Size_24);
	text-align: center;
}

.welcome div .btn a {
	margin: 0 0 var(--Size_12);
	padding: var(--Size_04) var(--Size_08);
	width: 100%;
	font-size: var(--Size_12);
	font-weight: 600;
	background: var(--Color_A080);
	border: var(--Border_A100);
	border-radius: var(--Border-radius_S);
}

.welcome ul {
	flex-direction: row;
	justify-content: flex-start;
	gap: var(--Size_06);
	padding: 0;
}

.welcome ul li a {
	display: flex;
	align-items: center;
	gap: var(--Size_04);
	padding: var(--Size_02) var(--Size_08) var(--Size_02) var(--Size_02);
	border: 1px var(--Color_A100) solid;
	border-radius: var(--Border-radius_L);
}

.welcome .kanda ul li a {
	border: 1px var(--Color_K100) solid;
}

.welcome .osaka ul li a {
	border: 1px var(--Color_O100) solid;
}

.welcome ul li a strong {
	display: flex;
	justify-content: center;
	align-items: center;
	width: var(--Size_22);
	height: var(--Size_22);
	font-size: var(--Size_14);
	line-height: 1;
	background: var(--Color_A100);
	border-radius: var(--Border-radius_L);
}

.welcome ul li a em {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	line-height: 1;
}

.welcome ul li a:hover {
	background: var(--Color_A040);
	opacity: 1;
}

.kanda .welcome ul li a:hover {
	background: var(--Color_K040);
	opacity: 1;
}

.osaka .welcome ul li a:hover {
	background: var(--Color_O040);
	opacity: 1;
}









/* ーーーーーーーーーーーーーーーーーーーー
   ギミック
ーーーーーーーーーーーーーーーーーーーー */

.glo {
	z-index: 0;
	transition: var(--Transition_06s);
	-o-transition: var(--Transition_06s);
	-moz-transition: var(--Transition_06s);
	-webkit-transition: var(--Transition_06s);
	backdrop-filter: var(--backdrop-filter_blur);
	-o-backdrop-filter: var(--backdrop-filter_blur);
	-moz-backdrop-filter: var(--backdrop-filter_blur);
	-webkit-backdrop-filter: var(--backdrop-filter_blur);
}

.glo:before {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: -1;
	border-radius: var(--Border-radius_S);
	background: var(--Linear-gradient_BTN0);
	filter: blur(0);
	transition: var(--Transition_06s);
	-o-transition: var(--Transition_06s);
	-moz-transition: var(--Transition_06s);
	-webkit-transition: var(--Transition_06s);
}

.glo:hover {
	transform: var(--Transform_rZ);
}

.glo:hover:before {
	background: var(--Linear-gradient_BTN);
	filter: blur(18px);
}









