@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
section.fv {
    position: relative;
    z-index: 1;
    background: rgb(0,163,201);
    background: url(/assets/img/lp/2025/esports_lp/bg01.webp) no-repeat top center/cover,linear-gradient(-38deg, rgba(0,163,201,1) 50%, rgba(29,32,136,1) 80%);
    padding-bottom: 4.5em;
}
section.fv img {
    width: 100%;
}
section.fv span.field {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 14.5%;
}
section.fv h2 {
    text-align: right;
    color: #fff;
    font-size: 5em;
    position: absolute;
    width: 100%;
    margin: 0 auto;
    bottom: 2.8em;
	right: 0.5em;
	z-index: 1;
	font-weight: 600;
	line-height: 1.2;
    text-shadow: 0.07em 0.07em 0.07em rgba(21, 67, 154, 1), -0.07em -0.07em 0.07em rgba(21, 67, 154, 1), -0.07em 0.07em 0.07em rgba(21, 67, 154, 1), 0.07em -0.07em 0.07em rgba(21, 67, 154, 1);
}
section.fv .more {
    position: absolute;
    width: 100%;
    margin: 0 auto;
    bottom: 4em;
    box-sizing: border-box;
}
section.fv p.sub {
    text-align: center;
    color: #fff;
    font-size: 1.875em;
    font-weight: 700;
    margin: 1em auto;
    width: fit-content;
    padding: 0 1.6em;
    position: relative;
}
section.fv p.sub:before,section.fv p.sub:after {
    content: '';
    display: block;
    width: 1.2em;
    aspect-ratio: 1/1;
    background: url(/assets/img/lp/2025/esports_lp/arrow_icon.webp) no-repeat center/contain;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
section.fv p.sub:before {
    left: 0;
}
section.fv p.sub:after {
    right: 0;
}

ul.cta.flexA {
    padding: 0 0.5%;
}
ul.cta.flexA li {
    width: calc(100%/3 - 1%);
    border: 1px solid;
    border-radius: 10px;
    box-sizing: border-box;
    color: #fff;
    position: relative;
    padding: 0 1.3em;
}
ul.cta.flexA li:before {
    content: '';
    display: block;
    width: 0.8em;
    height: 0.8em;
    border-right: 0.25em solid;
    border-bottom: 0.25em solid;
    pointer-events: none;
    position: absolute;
    right: 0.4em;
    top: 50%;
    transform: rotate(-45deg) translateY(-50%);
}
ul.cta.flexA li.doc {
    background: url(/assets/img/lp/2025/esports_lp/doc_icon.webp) no-repeat center/cover,linear-gradient(0deg, rgba(0,105,52,1) 0%, rgba(141,194,31,1) 100%);
}
ul.cta.flexA li.oc {
    background: url(/assets/img/lp/2025/esports_lp/oc_icon.webp) no-repeat center/cover,linear-gradient(0deg, rgba(233,85,19,1) 0%, rgba(247,181,44,1) 100%);
}
ul.cta.flexA li.ol {
    background: url(/assets/img/lp/2025/esports_lp/ol_icon.webp) no-repeat center/cover,linear-gradient(0deg, rgba(137,9,16,1) 0%, rgba(230,0,18,1) 100%);
}
ul.cta.flexA li a {
    width: 100%;
    height: 100%;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    font-size: 1.725em;
    line-height: 1.1;
    padding: 0.3em;
    font-weight: 700;
    filter: drop-shadow(2px 2px 2px rgba(0,0,0,0.3));
}

#main .tabPanel {
	overflow: hidden;
	margin-top: -4.5em;
	position: relative;
	z-index: 1;
}
#main .tabList {
	margin-bottom: -0.5rem;
	display: flex;
	position: relative;
	align-items: flex-end;
}
#main .tabList li {
	width: 45%;
	padding-bottom: 0.5rem;
}
#main .tabList a {
	margin: 0 -0.1rem;
	padding: 0.5rem 0.5rem 0.4rem;
	display: block;
	color: #FFF;
	font-weight: 900;
	font-size: 1.6em;
	text-align: center;
	text-shadow: 2px 2px 2px rgba(0, 0, 0, 0.3);
	border: 0.2rem solid #fff;
	border-bottom-width: 0.3rem;
	border-radius: 2.5rem 2.5rem 0 0;
	transition: 0s;
}
#main .tabList a::after {
	position: absolute;
	left: 0;
	top: calc(100% - 0.5rem);
	width: 100%;
	height: 0.5rem;
	background-color: #1d2088;
	content: '';
	display: none;
}
#main .tabList .item01 a, .game .c-key-bg {
	background-color: #1d2088 !important;
}
#main .tabList .item02 a,
#main .tabList .item02 a::after, .anime .c-key-bg {
	background-color: #d02d26 !important;
}

#main .tabList .on {
	width: 55%;
}
#main .tabList .on a::after {
	display: block;
}
#main .tabList .on a {
	padding: 1.2rem 0.5rem 0.8rem 2.5rem;
	font-size: 1.892em;
	border-width: 0.3rem;
	border-bottom: none;
}
#main .tabList .on a::after {
	opacity: 1;
}
#main .tabList .item01.on a {
	border-radius: 0 4rem 0 0;
	border-left: none;
	background: url(/assets/img/lp/2025/esports_lp/game_icon.webp) no-repeat 1rem 1rem / 5rem;
}
#main .tabList .item02.on a {
	padding-left: 4.2rem;
	border-radius: 2.5rem 0 0 0;
	border-right: none;
	background: url(/assets/img/lp/2025/esports_lp/anime_icon.webp) no-repeat 1.5rem 1rem / 5rem;
}
#main .tabBox {
	padding: 3.5rem 2rem 0;
	background-color: #FFF;
}


.game  .c-key {
	color: #1d2088;
}
.game  .c-key02 {
	color: #00a3c9;
}
.game  .c-key-bdr {
	border-color: #1d2088!important;
}
.anime  .c-key {
	color: #d02d26;
}
.anime  .c-key02 {
	color: #ff8a5f;
}
.anime  .c-key-bdr {
	border-color: #d02d26!important;
}
.prologue_box  .c-key02 {
	color: #15439A;
}

#main .head02 {
	margin: 0 auto 2rem;
	width: fit-content;
	font-size: 2.1em;
	font-weight: 700;
	text-align: center;
	line-height: 1.23;
	position: relative;
	z-index: 1;
}
#main .line {
	margin: 0 auto 2rem;
	width: fit-content;
	font-weight: 700;
	text-align: center;
	line-height: 1.23;
	position: relative;
	z-index: 1;
}
#main .head02:before,
#main .line:before {
    content: '';
    display: block;
    width: 100%;
    height: 0.5em;
    background: repeating-linear-gradient(-45deg, transparent, transparent 0.1em, rgba(116, 218, 230, 1) 0.1em, rgba(116, 218, 230, 1) 0.3em );
    position: absolute;
    bottom: 0;
    z-index: -1;
}
#main .anime .head02:before {
    background: repeating-linear-gradient(-45deg, transparent, transparent 0.1em, rgba(255, 138, 95, 1) 0.1em, rgba(255, 138, 95, 1) 0.3em);
}

#main .title {
	margin: 0 auto 2rem;
	width: fit-content;
	font-size: 2.1em;
	font-weight: 700;
	text-align: center;
	position: relative;
	z-index: 1;
}

#main .head03 {
    font-size: 2em;
    font-weight: 700;
    text-align: center;
    margin: 0.5em auto;
}
#main .head03 span {
    font-size: 0.775em;
    color: #fff;
    padding: 0.2em 0.9em;
    border-radius: 4.5em;
    display: inline-block;
}
#main .game .head03 span {
    background: #00a3c9;
}
#main .anime .head03 span {
    background: #ff8a5f;;
}

#main .tabBox .photo {
	margin-bottom: 1.5rem;
}
#main .tabBox h6,#main .tabBox p {
	line-height: 1.73;
	font-weight: 500;
	font-size: 1.7em;
	text-align: justify;
}
#main .reasonBox {
	margin: 2.3rem -2rem 0;
	padding: 2.9rem 2rem 3rem;
	position: relative;
}
#main .reasonBox,#main .faq-map {
	background: url(/assets/img/lp/2025/esports_lp/bg02.webp) repeat top center/23rem,#ccedf4;
}
#main .reasonBox::after,#main .faq-map::after {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	content: '';
	pointer-events: none;
	background: url(/assets/img/lp/2025/esports_lp/bg03.webp) repeat-x left 1.8rem top / 7.55rem,
	url(/assets/img/lp/2025/esports_lp/bg04.webp) repeat-x left 1.8rem bottom / 7.55rem;
}
#main .tabBox02 .reasonBox {
	background-color: #ffe8df;
}
#main .reasonBox h4 {
	margin-bottom: 5.8rem;
	text-align: center;
}
#main .reasonBox h4 img {
	max-width: 100%;
}
#main .reason {
	margin-bottom: 5.7rem;
	padding: 3.7rem 2.3rem 1.9rem;
	position: relative;
	background-color: #FFF;
	border: 0.25rem solid;
	border-radius: 1rem;
}
#main .reason:last-child {
    margin-bottom: 1em;
}
#main .reason h5 {
	margin-bottom: 1.3rem;
	position: relative;
	font-size: 2em;
	font-weight: 700;
	line-height: 1.39;
	z-index: 2;
}
#main .reason h5 .notes {
    margin-left: 0.5em;
}
#main .reason p:not(:last-child) {
	margin-bottom: 0.5rem;
}
#main .reason .notes {
	font-size: 1.6rem;
}
#main .reason .num {
	position: absolute;
	left: calc(50% - 1.3rem);
	top: -2.8rem;
	z-index: 1;
}
#main .reason .num img {
	width: 2.95em;
}
#main .reason .num::before {
	width: 7.6rem;
	height: 3.65rem;
	position: absolute;
	left: 50%;
	top: -0.85rem;
	content: '';
	transform: translateX(-50%);
	z-index: -1;
	background: #fff;
	border: 0.16em solid #1d2088;
	border-bottom: 2px solid #fff!important;
	border-radius: 0.8em 0.8em 0 0;
}
#main .anime .reason .num::before {
    border: 0.16em solid #d02d26;
}
#main .reason .num::after {
	width: 1.5rem;
	height: 1.8rem;
	position: absolute;
	right: -3.2rem;
	top: -1.9rem;
	content: '';
	background: no-repeat right top / 100%;
}
#main .game .reason .num::after {
    background-image: url(/assets/img/lp/2025/esports_lp/game_num_top.webp);
}
#main .anime .reason .num::after {
    background-image: url(/assets/img/lp/2025/esports_lp/anime_num_top.webp);
}
#main .reason .item {
    margin: 1.5em auto;
}

#main .gallery, #main .interview, #main .tabBox .cta, #main .faq-map .cta {
    margin: 4.3rem -2rem 0;
}
#main .gallery .img {
    width: calc(100%/3);
    border-bottom: 1px solid;
    color: #fff;
}
#main .gallery .img:nth-child(3n - 2),#main .gallery .img:nth-child(3n - 1) {
    border-right: 1px solid;
}
#main .gallery .img img {
    height: 100%;
    object-fit: cover;
}

#main .game .interview .img,#main .game .interview .profile {
    background: #ccedf4;
}
#main .anime .interview .img,#main .anime .interview .profile {
    background: #ffe8df;
}
#main .interview .img, #main .interview .profile {
    padding: 1em 0;
}
#main .interview .profile {
    padding-bottom: 2em;
}
#main .interview .profile p {
    text-align: center;
}
ruby > rt {
    font-size: 0.675em;
    font-weight: 400;
}
#main .interview .profile p span.job {
    font-size: 0.875em;
    display: block;
}
#main .interview .comment {
    word-break: break-all;
    padding: 2.7em;
}
#main .game .interview .comment {
    background: #e5f6f9;
}
#main .anime .interview .comment {
    background: #fff3ef;
}


#main .faq-map {
	padding: 4rem 1.9rem;
	background-color: #e9eefd;
	position: relative;
	margin: 2em auto 0;
	overflow: hidden;
}
#main .faq-map .head02 {
	margin-bottom: 3.3rem;
}
#main .faqDl {
    margin: 3.3rem 0;
}
#main .faqDl dt {
	margin-top: 0.8rem;
	padding: 0.5rem 7.7rem 0.6rem;
	position: relative;
	font-size: 1.8em;
	font-weight: 700;
	line-height: 1.625;
	letter-spacing: -0.02rem;
	border: 0.2rem solid;
	background: url(/assets/img/lp/2025/esports_lp/q_icon.webp) no-repeat 1.1rem 1.5rem / 5.35rem, #FFF;
	cursor: pointer;
	color: #2a61e8;
	min-height: 3.5em;
	display: flex;
	align-items: center;
}
#main .faqDl dt:before,
#main .faqDl dt:after {
	position: absolute;
	right: 1.3rem;
	top: calc(50% - 0.7rem);
	width: 3.5rem;
	height: 1.4rem;
	background: url(/assets/img/lp/2025/esports_lp/toggle_icon.webp) no-repeat center center / 100%;
	transition: all .3s ease;
	content: "";
}
#main .faqDl dt:after {
	transform: rotate(90deg);
}
#main .faqDl dt.on:after {
	transform: rotate(180deg);
	opacity: 0;
}
#main .faqDl dd {
	margin-bottom: 0.8rem;
	padding: 0.3rem 2.4rem 0.8rem 7.7rem;
	display: none;
	font-size: 1.7em;
	font-weight: 500;
	line-height: 1.73;
	letter-spacing: -0.02rem;
	border: 0.2rem solid #2a61e8;
	border-top: none;
	background: url(/assets/img/lp/2025/esports_lp/a_icon.webp) no-repeat 1.1rem 1.5rem / 5.35rem, #FFF;
	text-align: justify;
}

.google-map {
 	position: relative;
	width: 100%;
	height: 0;
	padding-top: 75%;
}
 
.google-map iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
#main .map .google-map {
    margin: 2em auto;
}
#main .map .add {
    color: #2a61e8;
    font-weight: 700;
    font-size: 1.7em;
}
.emblem {
	position: absolute;
	right: 0;
	top: 40%;
	width: 90%;
	text-align: right;
	z-index: 0;
}
.Small {
	font-size: 0.7em;
	padding-left:5px;
}
.prologuelist {
	position: relative;
	top: -5em;
}
.prologuelist li {
	background: url("/assets/img/lp/2025/esports_lp/l_btn.webp") no-repeat center;
	background-size: 100% auto;
	padding: 2em 0 2.1em 3em;
	font-size: 2em;
	line-height: 1;
	margin-top: -0.8em;
	color: #154399;
	font-weight: 500;
}
.prologuelistwrap p {
	text-align: center;
	font-size: 2em;
	color: #FFF;
	margin-top: -2.3em;
	font-weight: 600;
}
.inner {
	width: 90%;
	margin: 0 auto;
}
.prologue {
	margin-top: 2em;
}
.prologuelistwrap {
	background: url(/assets/img/lp/2025/esports_lp/bg05.webp) repeat top center/23rem,#154399;
	position: relative;
	z-index: 0;
	padding-bottom: 14em;
	margin-top: 7em;
}
.prologue_employmentwrap {
	background: url("/assets/img/lp/2025/esports_lp/triangle.webp") no-repeat top center;
	padding-top: 30em;
	margin-top: -15em;
	position: relative;
	z-index: 1;
	background-size: 100% auto;
}
.big {
	font-size: 120%;
}
.prologue_text01 {
	background: #FFF;
	padding: 3% 3% 0;
    margin: -13em auto 0;
	width: 100%;
	font-size: 1.7em;
	font-weight: 500;
	line-height: 2.5;
	letter-spacing: 1px;
	color: #15439A;
}
.yel {
	padding: 0.5rem 1rem;
	background: #FFFF00;
	-webkit-box-shadow: 3px 3px 0 #15439A;
	box-shadow: 3px 3px 0 #15439A;
	border: 2px solid #15439A;
	margin-right: 8px;
}
.prologue_text02 {
	background: url("/assets/img/lp/2025/esports_lp/bottom_line.webp") no-repeat center bottom;
	padding-bottom: 30px;
	background-size: 223px auto;
	width: 90%;
	margin: 3% auto 0;
}
.prologue_text02 p {
	color: transparent;
  	text-shadow: 2px 2px 0 #9AC4F0;
  	-webkit-text-stroke: 1.2px #15439A;
	text-align: center;
	font-size: 3em;
	font-weight: 800;
	font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
	line-height: 1.3;
}
.prologue_text02 p span {
	text-shadow: 2px 2px 0 #FFFF00;
}
.prologue_box {
	background: #CBEDF4;
	border: 2px solid #15439A;
	border-radius: 20px;
	width: 90%;
	padding: 3% 5%;
	margin: 1em auto 0;
}
.prologue_text03 {
	display: flex;
	justify-content: center;
	align-items: center;
	background: url("/assets/img/lp/2025/esports_lp/game_num_top.webp") no-repeat;
	background-position: top 0 right 10px;
	background-size: 10% auto;
}
.circle {
 	width: calc(80% / 2);
 	border-radius: 100%;
 	display: flex;
 	justify-content: center;
	align-items: center;
	color: #FFF;
    background: linear-gradient(0deg, rgba(29, 32, 136, 1) , rgba(0, 163, 201, 1));
 	text-align:center;
	font-size: 1.5em;
	line-height: 1.2;
	font-weight: 500;
}
.circle:before{
 	content: '';
 	display: block;
 	padding-top: 100%;
}
.circle span {
	font-size: 2em;
}
.Number span {
	font-size: 2.8em;
	color: transparent;
  	text-shadow: 2px 2px 0 #FFFF00;
  	-webkit-text-stroke: 2px #15439A;
	padding-right: 5px;
}

.Number {
	color: #15439A;
	font-family: "Oswald", sans-serif;
	font-weight: 500;
	font-size: 3.7em;
	width: 50%;
	margin:0 0 0 5px;
	line-height: 0.8;
}
.prologue_box li {
	font-size: 1.5em;
	border-bottom: dashed 1px #15439A;
	padding-bottom: 1em;
	margin-top: 1em;
	font-weight: 500;
}

.prologue_box li p {
	margin-top: 5px;
}
.other {
	text-align: right;
	margin-top: 10px;
	color: #15439A;
	display: block;
	font-size: 1.2em;
	font-weight: 500;
}
.c-key05 span {
	background: #00A3C9;
	padding: 0.1em 0.3em;
	color: #FFF;
	font-size: 1em;
	font-weight: 500;
	line-height: 1.9;
}

.iframe_wrap {
    position: relative;
    padding-top: 56.4179%;
    width: 100%;
}

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

.youtube {
	margin-bottom: 2em;
}

.access_text {
	text-align: center;
	font-size: 1.7em;
	font-weight: 500;
	margin-top: 10px;
}
.map figure {
	text-align: center;
	margin-bottom: 2em;
}

.Achievements {
	width: 94%;
	text-align: right;
	display: block;
	margin-top: -5px;
	font-size: 1.2em;
}
@media all and (min-width: 897px) {
#gHeader.scroll:before {
    opacity: 0;
    display: none;
}
section.fv {
    top: -50px;
	margin-bottom: -50px;
}
ul.cta.flexA li a {
    font-size: 1em;
    padding: 0.3em 0;
}
ul.cta.flexA li:before {
    border-width: 3px;
    width: 0.5em;
    height: 0.5em;
}
section.fv h2 {
    font-size: 3em;
    bottom: 3em;
}
section.fv p.sub {
    font-size: 1.1875em;
}

#main .tabList .on a {
    font-size: 1.;
    font-size: 1.125em;
}
#main .tabList a {
    font-size: 1em;
}
#main .tabList .item01.on a,#main .tabList .item02.on a {
    background-size: 3.5rem;
}
#main .tabPanel {
    margin-top: -7.6em;
}
#main .head02 {
    font-size: 1.3125em;
}
#main .head03 {
    font-size: 1.25em;
}
#main .tabBox h6, #main .tabBox p {
    font-size: 0.9375em;
}
#main .reason h5 {
    font-size: 1.25em;
}
#main .reason .num img {
    width: 1.975em;
}
#main .reason {
    padding: 2.3rem 1.7rem 1.9rem;
}
#main .reason .num::before {
    width: 6.4rem;
}
#main .interview .comment {
    padding: 1.5em;
}
#main .interview .profile {
    padding-bottom: 1.5em;
}
#main .faqDl dt {
    font-size: 1em;
    padding-right: 5rem;
    min-height: 4.3em;
}
#main .faqDl dd {
    font-size: 0.9375em;
}
#main .faqDl dt,#main .faqDl dd {
    background-size: 1.875em;
    padding-left: 5rem;
}
#main .faqDl dt:before, #main .faqDl dt:after {
    width: 1.875em;
}
#main .map .add {
    font-size: 0.9375em;
}
header#gHeader ul.cta.flexA li {
    width: 100%;
    font-size: 1.125em;
    margin-top: 1.5rem;
    background-size: 6.5em;
    background-position: center left;
    padding: 0 3em;
    box-shadow: 0.1rem 0.2rem 0.6rem rgba(0, 0, 0, 0.4);
}
header#gHeader ul.cta.flexA li a {
    min-height: 4em;
}
header#gHeader ul.cta.flexA li:before {
    right: 1.4em;
}
ul.cta.flexA li {
    transition: 0.3s;
	opacity:  1;
}
ul.cta.flexA li:hover {
    transform: scale(1.03);
}
.emblem {
	top: 42.5% !important;
}
	
section.fv .more {
	bottom:3em;
}
#main .title {
	font-size: 1.3125em;
}
.prologuelist li {
	font-size: 1.2em;
}
.prologuelistwrap p {
    font-size: 1.3125em;
    margin-top: -1.5em;
}
.prologuelist {
    top: -2.5em;
}
.prologuelistwrap {
	margin-top: 4em;
}
.prologue_text01 {
    font-size: 1em;
    line-height: 2.7;
	margin: -25em auto 0;
}
.prologue_text02 p {
	font-size: 1.8em;
}
.circle {
	font-size: 0.9em;
}
.Number {
	font-size: 2em;
}
.Number span {
	font-size: 3.3em;
}
.prologue_box li {
	font-size: 0.9375em;
}
.other {
	font-size: 0.8em;
}
.access_text {
	font-size: 0.9375em;
}
.Achievements {
	font-size: 0.8em;
}
}

