/* CSS Document */


/* ==========================================================================
	common
	========================================================================== */

.disnon {
    display: none!important;
}

.pc-none {
	display: none!important;
}

.l-section-inner_sss {
	width: 455px;
	margin: 0 auto;
}

.l-section-inner_ss {
	width: 720px;
	margin: 0 auto;
}

.l-section-inner_s {
	width: 860px;
	margin: 0 auto;
}

.l-section-inner_m {
	width: 1080px;
	margin: 0 auto;
}

.l-section-inner_l {
    width: 1200px;
    margin: 0 auto;
}

.l-section-inner_xl {
	width: 88%;
	max-width: 1800px;
	height: auto;
	margin: 0 auto;
	position: relative;
}


.section-title {
    margin-bottom: 64px;
}

.lt-narrow          { letter-spacing: 0.03em; }

.section-cap {
    font-size: 1.8rem;
    line-height: 2.4;
    color: #000;
}

.l-col-2 {
    width: 49.5%;
    display: inline-block;
    vertical-align: middle;
}


#js-all-wrapper {
    visibility: hidden;
    width: 100%;
    height: 100vh;
    overflow: hidden;
}

#js-all-wrapper-mask {
  position: absolute;
  left: 0;
  top: 0;
  background: #19244a;
  background-size: cover;
  width: 100vw;
  height: 100vh;
  transition: 0.8s;
  z-index: 10000;
  overflow: hidden;
}

.all-wrapper-mask-logo {
    width: 240px;
    position: absolute;
    top: 45vh;
    left: 50%;
    margin-left: -110px;
    margin-top: -60px;
    text-align: center;
    display: inline;
}

.loader,
.loader:after {
    border-radius: 50%;
    width: 5em;
    height: 5em;
}
.loader {
    margin: 60px auto;
    font-size: 5px;
    position: absolute;
    top: calc(45vh + 100px);
    left: 50%;
    margin-left: -2.5em;
    margin-top: -2.5em;
    text-align: center;
    text-indent: -9999em;
    border-top: 1.1em solid rgba(255, 255, 255, 0.2);
    border-right: 1.1em solid rgba(255, 255, 255, 0.2);
    border-bottom: 1.1em solid rgba(255, 255, 255, 0.2);
    border-left: 1.1em solid #ffffff;
    -webkit-transform: translateZ(0);
    -ms-transform: translateZ(0);
    transform: translateZ(0);
    -webkit-animation: load8 1.1s infinite linear;
    animation: load8 1.1s infinite linear;
}
@-webkit-keyframes load8 {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@keyframes load8 {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}



/* ==========================================================================
	header
	========================================================================== */

.l-header {
    width: 100%;
    height: 80px;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 100;
}

.l-header-inner {
    position: relative;
    width: 100%;
    height: 100%;
    background: url(../img/bg-header.jpg) no-repeat;
    background-size: cover;
    border: 0;
    border-bottom: 4px solid #c21500;
    border-image: linear-gradient(to right, #fbfcce 0%, #67440b 100%);
    border-image-slice: 1;
}

.l-header-logo {
    position: absolute;
    left: 0;
    top: 18px;
}

.l-header-nav {
    margin: 29px 0 0px 190px;
    display: inline-block;
}

.l-header-nav li {
    font-size: 1.6rem;
    padding-right: 26px;
    display: inline-block;
    color: #472105;
    font-weight: bold;
    letter-spacing: -1px;
    text-shadow: 3px 3px 5px #FFF;
    position: relative;
}

.l-header-nav li::after {
    content: " ";
    position: absolute;
    right: 11px;
    width: 1px;
    top: 5px;
    height: 16px;
    background: #ccc;
}

.l-header-nav li:last-child::after {
    content: none;
}

.l-header-nav li a {
    color: #472105;
}

.l-header-sns {
    position: absolute;
    right: 0;
    top: 29px;
}

.l-header-sns li {
    display: inline-block;
    padding-left: 7px;
    vertical-align: middle;
}

.l-header-sns li img {
    height: 28px;
}


/* ==========================================================================
    key-visual
    ========================================================================== */

.l-key-visual {
    width: 100%;
    /* height: 70.417vw; bannerあり */
    height:65.417vw;
    position: relative;
    background: -webkit-linear-gradient(#eee, transparent) bottom no-repeat;  /* org #162775 */
    background: linear-gradient(#eee, transparent) bottom no-repeat; 
}

.l-key-visual-img {
    background: url(../img/key-visual.png?t=261201) no-repeat;
    background-position: top right;
    background-size: cover;
    width: 100%;
    height: 100%;
    z-index: 0;
    position: absolute;
    top: 0;
    left: 0;
}

.l-key-visual-item {
    background: url(../img/key-visual-item.png?t=261201) no-repeat;
    background-position: center;
    background-size: cover;
    width: 100vw;
    height: 69vw;
    z-index: 1;
    position: absolute;
    top: -2.5vw;
    left: 0vw;
}

.l-key-visual-logo-sub {
    position: absolute;
    left: 0;
    top: 56px;
    width: 240px;
    z-index: 2;
}

.l-key-visual-logo {
    position: absolute;
    left: 0;
    top: clamp(120px, calc(200px + (200 - 120) * ((100vw - 1024px) / (1600 - 1024))), 280px);
    z-index: 2;
}


.l-key-visual-logo img {
    width: 28vw; /* 30vw */
    max-width: 423px;
}

.vl-1st_logo                { top: clamp(20px, 15px + 2.0vw, 35px); }
.vl-1st_logo img            { }



.l-key-visual-title {
    position: absolute;
    right: -26px;
    top: 40px;
    z-index: 2;
}

.l-key-visual-title img {
    width: 11vw;
    max-width: 168px;
}

.l-key-visual-banner {
    position: absolute;
    left: 0;
    top: clamp(380px, calc(380px + (530 - 380) * ((100vw - 1024px) / (1600 - 1024))), 530px); /* 1st top: clamp(490px, 360px + 16vw, 620px); */
    z-index: 2;
}

.l-key-visual-banner li {
    width: 28vw;
    max-width: 430px;
    margin: 0 0 24px 0;
    position: relative;
    box-shadow: 50px 80px 100px rgb(0 0 0 / 60%);
    cursor: pointer;
}
.l-key-visual-banner__mov {
    margin-left: -1.8vw;
}

.l-key-visual-banner li:nth-child(n+3) {
    width: 23vw;
    max-width: 360px;
    margin-left: 2vw;
}

.l-key-visual-banner li.l-key-visual-banner__award_p        { cursor: auto; }

.l-key-visual-banner li.l-key-visual-banner__award_p,
.l-key-visual-banner li.l-key-visual-banner__scode {
    width: 28vw;
    margin-left: 0vw;
    max-width: 430px;
}


.l-key-visual-banner li img {
    width: 100%;
}

.js-modal-video-open img {
    width: 100%;
}

.btn-movie {
    position: absolute;
    width: 80px;
    height: 100px;
    background: url(../img/btn-movie.png?t=241201);
    background-size: cover;
    top: 50%;
    left: 50%;
    margin-left: -40px;
    margin-top: -50px;
}

.btn-movie {
    transition: 0.3s;
}

.l-key-visual-banner li:nth-child(1):hover .btn-movie {
    transform: scale(1.2,1.2);
    transition: 0.4s;
}

@media screen and (max-width: 1600px) {
    .btn-movie {
        position: absolute;
        width: 5vw;
        height: 7vw;
        background: url(../img/btn-movie.png);
        background-size: cover;
        top: 50%;
        left: 50%;
        margin-left: -2.5vw;
        margin-top: -3.5vw;
    }
}


#modal-video {
    cursor: pointer;
    display: flex;
    justify-content: center;
    align-items: center;
    position: fixed;
    z-index: 100;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.75);
    transition: 0.5s;
}

#modal-video.close {
    filter: opacity(0);
    visibility: hidden;
}

#modal-video.open {
    filter: opacity(1);
    visibility: visible;
}

#modal-video iframe {
    width: 64vw;
    height: 36vw;
}


.hd_mov_wrap                {     display: flex; align-content: center; align-items: center; justify-content: center; }
.l-key-visual-banner li img.hd_mov_play-button         { position: absolute; width: 20%; transition: all 0.4s;
}


.l-key-visual-banner__mov:hover .hd_mov_play-button {
    transform: scale(1.2,1.2);
    transition: 0.4s;
}



/* ==========================================================================
    main
    ========================================================================== */

.l-main {
    margin-top: 80px;
    width: 100%;
    height: 100%;
    min-height: 100vh;
    position: relative;
}


.l-main-bg {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(../img/bg-img-01.jpg) no-repeat;
    background-size: cover;
    background-position: center top;
    content: " ";
    z-index: -1; 
}


/* ==========================================================================
    cam-section
    ========================================================================== */

.l-cam-section {
    margin-bottom: 100px;
}

.l-cam-section-clm-2 { 
    margin-bottom: 40px;
}

.l-cam-section-clm-2 li {
    width: 100%;
    margin-bottom: 32px;
    box-shadow: 10px 20px 50px rgb(0 0 0 / 30%);
}

.l-cam-section-clm-2 li:nth-child(2) {
    margin-bottom: 0;
}

.l-cam-section-clm-2 li img {
    width: 100%;
}

.l-cam-section-goods {
    position: relative;
}

.l-cam-section-goods > img {
    box-shadow: 10px 20px 50px rgb(0 0 0 / 30%);
}

.l-cam-section-goods-item {
    position: absolute;
    top: 210px;
    width: 78%;
    left: 23.5%;
}

.l-cam-section-goods-item li {
    width: 30%;
    margin-right: 1.5%;
    display: inline-block;
    vertical-align: top;
}

.l-cam-section-goods-tw {
    margin-top: 32px;
}


/* ==========================================================================
    reg-section
    ========================================================================== */

.l-reg-section {
    padding: 108px 0 80px 0;
    text-align: center;
    background: url(../img/reg-bg.jpg) no-repeat;
    background-size: cover;
    background-position: 50% 50%;
    position: relative;
    z-index: 0;
}

.l-reg-section .section-txt {
    text-align: center;
    font-size: 2.5rem;
    font-weight: 600;
    color: #FFF;
    margin-top: -44px;
}

.l-reg-section-list-title {
    margin: 56px 0 24px 0;
}

.l-reg-section-list-title li {
    display: inline-block;
    vertical-align: top;
    padding: 10px 0;
    font-weight: bold;
    text-align: center;
    border-radius: 50px;
    background: rgba(255, 255, 255, 0.1);
    color: #FFF;
    font-size: 1.8rem;
}

.l-reg-section-list-title li:nth-child(1) {
    width: 69.5%;
}

.l-reg-section-list-title li:nth-child(2) {
    width: 27%;
    margin-left: 2%;
}

.l-reg-section-list-01 {
    margin-bottom: 40px;
}

.l-reg-section-list-01 li {
    vertical-align: text-top;
    display: inline-block;
}


.l-reg-section-list-app-store {
    width: 30.1%;
    margin-right: 2%;
}

.l-reg-section-list-play-store {
    width: 37.4%;
    margin-right: 2%;
}

.l-reg-section-list-steam-store {
    width: 26.6%;
}


.l-reg-section-list-02 {
    text-align: left;
}

.l-reg-section-list-02 li {
    width: 18.4%;
    margin-right: 1.5%;
    margin-bottom: 32px;
    vertical-align: text-top;
    display: inline-block;
}


.l-reg-section-list-02 li:nth-child(5n) {
    margin-right: 0;
}

.l-reg-section-cap {
    text-align: left;
    font-size: 1.45rem;
    color: #FFF;
}



/*------------
l-ex-camp-section 230601
-------------*/

.l-ex-camp-bg               {
    padding-bottom: 2%;
    background: url(../img/extra/bg-img-h_aniv.webp);
    background-size: cover;
    background-position: initial;
}

.l-ex-camp-bg.ex-camp_1st           { position: relative; z-index: 1; background: url(../2023_1st/bg-img-1_aniv-c.webp); margin-top: clamp(-280px, calc(-5px - (220 * (100vw - 1024px) / (1600 - 1024))), -5px); 
    margin-bottom: clamp(20px, 15px + 2.5vw, 70px);}


.l-ex-camp-section          {}

.ex-camp-outter-outter      { max-width: 1080px; margin: 0 auto; }

@media screen and (max-width: 1080px){
    .l-ex-camp-bg.ex-camp_1st       { margin-top: 0; }
    .ex-camp-outter-outter      { max-width: 960px; margin: 0 auto; }
}

@media screen and (max-width: 960px){
    .ex-camp-outter-outter      { width: 94%; margin: 0 auto; }
}

.l-ex-camp-logo             {
    display: block;
    margin: 0 auto;
    width: 50%;
    max-width: 400px;
}

.ex-camp_1st .l-ex-camp-logo    { width: 92%; max-width: 1100px; margin: 2vw auto; }


.ex-camp-inner-outter       {
    margin-bottom: 48px;
    border: 8px solid #d1d1d1;
    border-left: none;
    border-right: none;
    border-image: linear-gradient(to right, #610000 25%, #b50000 50%,  #610000 75% );
    border-image-slice: 1;

}

.ex-camp-inner              {

    background: hsla(0, 0%, 100%, 0.7);
    box-sizing: border-box;
    padding: 24px; /* 30px */
    border: 8px solid #d1d1d1;
    border-top: none;
    border-bottom: none;
    border-image: linear-gradient(to right, #eee 0%, #d1d1d1 100%);
    border-image-slice: 1;

    box-shadow: 10px 20px 50px rgb(0 0 0 / 20%);

}

.ex-camp_1st .ex-camp-inner,
.ex-camp_1st .ex-camp-inner-outter          { border: none; }

.ex-camp_1st .ex-camp-inner-outter          { max-width: 1200px; }

.ex-camp_1st .ex-camp-inner                 {
    margin-bottom: 2vw;
    background: url(../2023_1st/index_cam_blk_base.png);
    background-size: cover;
    background-position: initial; }


.l-ex-camp-section .section-title                  { margin: 5% auto;  }
.l-ex-camp-section .section-title img              { display: block; margin: 0 auto; }


.l-ex-camp-section .section-cap             {
    text-align: left;
    font-size: 2.2rem;
    line-height: 2.1;
}

@media screen and (max-width: 1023px){
    .l-ex-camp-section .section-cap  {
        font-size: 1.7rem;
        line-height: 1.9;
    }
}

.l-ex-camp-section .section-cap a       { text-decoration: underline; text-underline-offset: 0.4em; }

.free-btn-img                    { margin: 5% auto;  }
.free-btn-img a                  { display: block; margin: 0 auto; width: 90%; max-width: 460px; filter: drop-shadow(0 5px 5px hsla(0, 0%, 0%, 0.6));  }



.ex-camp_fx             {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.ex-camp-inner                      { width: 49.5%; margin-left: 0; margin-right: 0; }
.ex-camp-inner.ex-camp_big         { width: 100%; padding: 0; }


.more_inner .l-ex-camp-logo         { width: 100%; max-width: 700px; }
.more_inner .ex-camp-inner          { width: auto; padding: 0; border: none; margin: 2em auto; }

.more_inner .ex-camp-inner-outter   { border: none; }


@media screen and (max-width: 1023px){
    .ex-camp-inner.ex-camp_big         { width: 100%; padding: 0 !important; }

    .ex-camp-inner.ex-camp_big img     { width: 100%;  }

}





/* ==========================================================================
    news-section
    ========================================================================== */


.l-news-section {
    padding: 5% 0 0px 0;
    text-align: center;
    margin-top: clamp(-100px, 600px - 40vw, 100px);
    /* 1st & aw-badge
    margin-top: clamp(-100px, 680px - 40vw, 240px); */
}

/* 1st & aw-badge */
@media screen and (max-width: 1023px){
    .l-news-section { margin-top: 0; }
}


.l-news-section-list {
    margin: 80px auto 80px auto;
}

.l-news-section-list li {
    margin-bottom: 48px;
    background: #FFF;
    box-sizing: border-box;
    padding: 56px;
    border: 8px solid #d1d1d1;
    border-image: linear-gradient(to right, #eee 0%, #d1d1d1 100%);
    border-image-slice: 1;
    box-shadow: 10px 20px 50px rgb(0 0 0 / 20%);
}

.l-news-section-list li .section-title {
    text-align: left;
    font-size: 2.4rem;
    font-weight: bold;
    margin: 38px 0 24px 0;
}

.l-news-section-list li .section-cap {
    text-align: left; 
    font-size: 1.7rem;
    line-height: 2.1;
}


.l-news-section-list .btn-default {
    margin-top: 68px;
}

.js-more-news {
    display: none;
}

.l-news-section-list.js-open .js-more-news-btn {
    display: none;
}

.js-more-news-btn.js-open {
    display: none;
}



.js-more-news-btn {
    cursor: pointer;
}

.js-more-news-btn img {
    box-shadow: 10px 20px 50px rgb(0 0 0 / 60%);
    transition: 0.3s;
}

.js-more-news-btn img:hover {
    opacity: 0.8;
    transition: 0.3s;
}

.btn-list_type2{display: -webkit-flex; display: -moz-flex; display: -ms-flex; display: -o-flex; display: flex; flex-wrap: wrap; margin-top: 4%;
    justify-content: center;
}


.btn-list_type2 li{width: 48%; padding:1%;
    margin-bottom: auto;
    background: none;
    padding: auto;
    border: none;
    border-image: none;
    border-image-slice: 1;
    box-shadow: none;
}

.news-center-text-title{font-size: 200%; padding-top:3%; text-align: center;}



/* ==========================================================================
    about-section
    ========================================================================== */


.l-about-section {
    padding: 80px 0 120px 0;
    text-align: center;
    position: relative;
}

.l-about-section::after {
    position: absolute;
    bottom: -5px;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(../img/about-section-bg.png) no-repeat;
    background-size: 100%;
    background-position: bottom;
    content: " ";
    z-index: -1;
}

.l-about-section::before {
    position: absolute;
    bottom: 0px;
    left: 0;
    width: 100%;
    height: 900px;
    background: -webkit-linear-gradient(transparent, #FFF) bottom no-repeat;
    background: linear-gradient(transparent, #FFF) bottom no-repeat;
    background-size: 100%;
    background-position: bottom;
    content: " ";
    z-index: -1;
}

.l-about-section .section-title {
    margin-bottom: 40px;
}

.l-about-section .section-cap {
    line-height: 2.4;
    color: #212121;
    font-weight: 600;
    font-size: 2rem;
    text-shadow: 2px 2px 5px #FFF;
}

.section-movie-embed {
    margin: 0px auto 80px auto;
    padding-top: 80px;
}

.section-movie-embed iframe {
    width: 800px!important;
    height: 452px!important;
    box-shadow: 10px 20px 50px rgb(0 0 0 / 60%);
}

.l-about-section .section-img {
    width: calc(100% + 48px);
    margin-left: -24px;
    margin-right: -24px;
}

.l-about-section .section-img img {
    width: 100%;
}



/* ==========================================================================
    point-section
    ========================================================================== */

.l-point-bg {
    background: url(../img/bg-img-02.webp) no-repeat;
    background-size: cover;
    background-position: center;
}

.l-point-section {
    padding: 160px 0 128px 0;
    text-align: center;
}

.l-point-section-list-1 {
    margin-top: -54px;
}

.l-point-section-list > li {
    padding: 80px 0;
}

.l-point-section-list li.l-point-section-list-1 .l-col-2:nth-child(2) {
    padding-left: 60px;
    box-sizing: border-box;
}

.l-point-section-list li.l-point-section-list-2 .l-col-2:nth-child(1) {
    padding-right: 60px;
    box-sizing: border-box;
}

.l-point-section-list li.l-point-section-list-3 .l-col-2:nth-child(2) {
    padding-left: 60px;
    box-sizing: border-box;
}

.l-point-section-list li.l-point-section-list-4 .l-col-2:nth-child(1) {
    padding-right: 60px;
    box-sizing: border-box;
}

.l-point-section-list {
    text-align: left;
}

.l-point-section-list .section-title {
    margin: 0 0 34px -20px;
}

.l-point-section-list .section-cap {
    font-size: 1.8rem;
    width: 98%;
    color: #212121;
    line-height: 2.2;
    font-weight: 600;
    letter-spacing: 0;
    text-shadow: 2px 2px 5px #FFF;
}

.l-point-section-list-sm {
    position: relative;
    z-index: 1;
    box-shadow: 10px 20px 50px rgb(0 0 0 / 60%);
}

.l-point-section-list-sm::after {
    background: url(../img/sm-flame.jpg);
    background-size: cover;
    position: absolute;
    width: calc(100% + 24px);
    height: calc(100% + 24px);
    content: " ";
    top: -12px;
    left: -12px;
    z-index: -1;
}

.l-point-section-list-sm .slick-dots {
    position: absolute;
    bottom: -54px;
    left: -12px;
}

.l-point-section-list-sm .slick-dots {
    position: absolute;
}

.l-point-section-list-sm .slick-dots li {
    width: 42px;
    height: 6px;
    background: #a8906a;
    display: inline-block;
    margin: 0 10px 0 0;
    text-indent: 100%;
    overflow: hidden;
    cursor: pointer;
    box-shadow: 10px 10px 15px rgb(0 0 0 / 10%);
    transition: 0.3s;
}

.l-point-section-list-sm .slick-dots li:hover {
    opacity: 0.8;
    transition: 0.3s;
}

.l-point-section-list-sm .slick-dots li.slick-active {
    background: #623e00;
}

.l-point-section-list-sm .slick-dots li.slick-active:hover {
    opacity: 1;
}

.l-point-section li.slick-slide {
    position: relative;
}

.l-point-section li.slick-slide::after {
    content:" ";
    position:absolute;
    top:0; right:0; bottom:0; left:0;
    box-shadow: inset 0px 0px 20px rgb(0 0 0 / 80%);
}


/* ==========================================================================
    movie-section
    ========================================================================== */

.l-movie-section {
    padding: 80px 0 100px 0;
    text-align: center;
}

.l-movie-section-slider {
    position: relative;
    overflow: hidden;
}


.l-movie-section-slider::after {
  content: " ";
  display: block;
  position: absolute;
  width: 8vw;
  height: 100%;
  bottom: 35px;
  left: 0px;
  background: -webkit-linear-gradient(270deg,transparent, rgb(231,215,198,0.8)) left repeat;
  background: linear-gradient(270deg,transparent, rgb(231,215,198,0.8)) left repeat;
  z-index: 1;
}

.l-movie-section-slider::before {
  content: " ";
  display: block;
  position: absolute;
  width: 8vw;
  height: 100%;
  bottom: 35px;
  right: 0px;
  background: -webkit-linear-gradient(90deg,transparent, rgb(231,215,198,0.8)) left repeat;
  background: linear-gradient(90deg,transparent, rgb(231,215,198,0.8)) left repeat;
  z-index: 1;
}


.l-movie-section-slider li iframe {
    width: 784px!important;
    height: 443px!important;
    box-shadow: 14px 0px 10px rgb(0 0 0 / 10%);
}


/* mov_slider--innr 241025 */
.mov_slider--innr       { position: relative; margin: 0 auto; width: 95%; max-width: 784px;     box-shadow: 14px 0px 10px rgb(0 0 0 / 10%);   }

.mov_slider--innr .btn-movie2            { 

    position: absolute;
    width: 140px;
    height: 140px;
    background: url(../img/mov_maker_00.png);
    background-size: cover;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: all 0.4s;
 }

.mov_slider--innr:hover  { cursor:pointer; }

.mov_slider--innr:hover .btn-movie2          { transform: translate(-50%, -50%) scale(1.2);  }


.mov_title                  { margin-top: 0.5em; font-size: 1.6rem;  color: #552900;  font-weight: 600; }



.update_patch {
    z-index: 3;
    color: #ffffff;
    background-color: hsl(0, 100%, 35%);
    font-size: 1.2em; font-weight: bold; line-height: 1.4;
    border-radius: 0.25em;
    padding: 0.25em 0.75em;
    display: inline-block;
    border: 1px solid #ffffff;
    text-align: center;
    text-indent: 0;
    position: absolute;
    top:  1%;
    left: 1%;
}


@keyframes flash {
    0%,
    100% {
      opacity: 1;
    }
    50% {
      opacity: 0.05;
    }
  }
  
  .twinkle {
     animation: flash 4s ease-out infinite;
  }
  


.l-movie-section .slick-slide {
    padding: 0 0px;
    box-sizing: border-box;
}

.l-movie-section-slider .slick-arrow {
    background: url(../img/btn-arrow.png);
    background-size: 100%;
    width: 80px;
    height: 108px;
    text-indent: 100%;
    overflow: hidden;
    position: absolute;
    top: 50%;
    z-index: 2;
    margin-top: -80px;
    cursor: pointer;
}

.l-movie-section-slider .slick-prev {
    left: 12.5%;
    transform:rotate(180deg);
    transition: 0.3s;
}

.l-movie-section-slider .slick-prev:hover {
    left: 12%;
    transition: 0.3s;
}

.l-movie-section-slider .slick-next {
    right: 12.5%;
    transition: 0.3s;
}

.l-movie-section-slider .slick-next:hover {
    right: 12%;
    transition: 0.3s;
}

.l-movie-section-slider .slick-dots {
    margin-top: 24px;
}

.l-movie-section-slider .slick-dots li {
    width: 12px;
    height: 12px;
    border-radius: 100px;
    background: #a8906a;
    display: inline-block;
    margin: 0 12px 0 0;
    text-indent: 100%;
    overflow: hidden;
    cursor: pointer;
    box-shadow: 10px 10px 15px rgb(0 0 0 / 10%);
    vertical-align: middle;
    color: #a8906a;
    font-size: 10rem;
    transition: 0.3s;
}

.l-movie-section-slider .slick-dots li:hover {
    opacity: 0.8;
    transition: 0.3s;
}

.l-movie-section-slider .slick-dots li.slick-active {
    background: #623e00;
    color: #623e00;
    width: 16px;
    height: 16px;
}

.l-movie-section-slider .slick-dots li.slick-active:hover {
    opacity: 1;
}

.l-movie-section-slider .slick-dots li button {
    overflow: hidden;
    text-indent: 100%;
}


/* ==========================================================================
    chara-section
    ========================================================================== */

.l-chara-section {
    padding: 128px 0 60px 0;
    text-align: center;
    background: url(../img/bg-img-06.jpg) no-repeat;
    background-size: cover;
    background-position: 50% 50%;
    position: relative;
    z-index: 0;
}

.l-chara-section:after {
    width: 100%;
    height: 340px;
    top: 50%;
    left: 0;
    margin-top: -140px;
    content: " ";
    background: url(../img/chara-obi.png) no-repeat;
    background-size: 100% 100%;
    background-position: 50% 50%;
    position: absolute;
    z-index: -1;
    opacity: 0.5;
}



.l-chara-section .section-title {
    position: relative;
    z-index: 10;
}

.l-chara-section-slider {
    margin-top: -60px;
}


.l-chara-section-slider .js-slider-chara .slick-slide img {
    margin: 0 auto;
}

.l-chara-section-slider .js-slider-chara-btn .slick-slide {
    position: relative;
}

.js-slider-chara-btn::after {
    background: url(../img/chara-circle.png);
    position: absolute;
    top: 0;
    left: 50%;
    margin-left: -90px;
    width: 180px;
    height: 180px;
    background-size: cover;
    content: " ";
    transition: 0.3s;
}

.l-chara-section-slider .js-slider-chara-btn .slick-slide {
    cursor: pointer;
}

.l-chara-section-slider .js-slider-chara-btn .slick-slide img {
    display: initial;
    filter: grayscale(100%);
    transition: 0.3s;
    position: relative;
}

.l-chara-section-slider .js-slider-chara-btn .slick-current.slick-slide img {
    filter: initial;
    transition: 0.3s;
}

.l-chara-section-slider .js-slider-chara-btn .slick-current.slick-slide::after {
    filter: initial;
    transition: 0.3s;
}


.l-chara-section-slider .slick-prev {
    left: 12.5%;
    transform: rotate(180deg);
    transition: 0.3s;
}
.l-chara-section-slider .slick-arrow {
    background: url(../img/btn-arrow.png);
    background-size: 100%;
    width: 80px;
    height: 108px;
    text-indent: 100%;
    overflow: hidden;
    position: absolute;
    top: 50%;
    z-index: 2;
    margin-top: -60px;
    cursor: pointer;
}

.l-chara-section-slider .slick-prev {
    left: 0%;
    transform: rotate(180deg);
    transition: 0.3s;
}

.l-chara-section-slider .slick-prev:hover {
    left: 1%;
    transition: 0.3s;
}

.l-chara-section-slider .slick-next {
    right: 0%;
    transition: 0.3s;
}

.l-chara-section-slider .slick-next:hover {
    right: 1%;
    transition: 0.3s;
}

.js-slider-chara-btn {
    margin-top: -210px;
}


.l-chara-section-slider-info {
    width: 30%;
    margin-left: 4%;
    display: inline-block;
    vertical-align: top;
    margin-top: 160px;
}

.l-chara-section-slider-img {
    width: 65%;
    display: inline-block;
    vertical-align: top;
}

.l-chara-section-slider-info-name {
    font-size: 4.8rem;
    color: #FFF;
    text-align: left;
    font-weight: bold;
    background: linear-gradient(90deg, #aaa, #aaa 30%, #FFF);
    background: -webkit-linear-gradient(90deg, #aaa, #aaa 30%, #FFF);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.l-chara-section-slider-info-name-sub {
    font-size: 1.3rem;
    color: #FFF;
    text-align: left;
    font-weight: bold;
    background: linear-gradient(90deg, #aaa, #aaa 30%, #FFF);
    background: -webkit-linear-gradient(90deg, #aaa, #aaa 30%, #FFF);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.l-chara-section-slider-info-cv {
    font-size: 2.4rem;
    color: #cfb8a2;
    text-align: left;
    font-weight: bold;
    margin-top: 10px;
}

.l-chara-section-slider-info-cap {
    font-size: 1.8rem;
    color: #ccc;
    text-align: left;
    margin-top: 40px;
    font-weight: bold;
}



/* ==========================================================================
    cbt-section
    ========================================================================== */

.l-cbt-section {
    padding: 108px 0 108px 0;
    text-align: center;
    background: url(../img/bg-img-03.jpg) no-repeat;
    background-size: cover;
    background-position: 50% 50%;
    position: relative;
    z-index: 0;
}

.l-cbt-section-chara-01 {
    position: absolute;
    left: 0%;
    bottom: 0;
    z-index: -1;
}

.l-cbt-section-chara-01 img {
    width: 40vw;
}

.l-cbt-section-chara-02 {
    position: absolute;
    right: 2%;
    bottom: 0;
    z-index: -1;
}

.l-cbt-section-chara-02 img {
    width: 35vw;
}

.l-cbt-section .section-title {
    margin-bottom: 21px;
}

.l-cbt-section .btn-cv {
    margin: 28px auto 60px auto;
}

.btn-cv img {
    box-shadow: 10px 20px 50px rgb(0 0 0 / 100%);
}


.l-cbt-section-termbox {
    width: 800px;
    height: 300px;
    border: 1px solid #dddddd;
    margin: 70px auto 0 auto;
    overflow-x: hidden;
    background: #FFF;
}

.l-cbt-section-termbox-inner {
    width: 100%;
    height: 100%;
    overflow: auto;
    padding: 34px 40px;
    box-sizing: border-box;
    text-align: left;
}

.l-cbt-section-termbox-inner h3 {
    font-size: 2rem;
    letter-spacing: 0;
    margin: 0 0 18px 0;
    font-weight: bold;
}

.l-cbt-section-termbox-inner h4 {
    font-size: 1.8rem;
    letter-spacing: 0;
    margin: 40px 0 18px 0;
    font-weight: bold;
}

.l-cbt-section-termbox-inner p {
    font-size: 1.5rem;
    line-height: 2.2;
    color: #000;
    letter-spacing: 0;
    text-indent: -12px;
    padding-left: 10px;
}


.close{
    width: 100%;
    height: 100%;
    position: absolute; top:0;
   background: url(../img/close-bg.png) no-repeat;
}
 .close img{
    width: 100%;
    height: 100%;
 }


.close-txt{
    width: 100%;
    position: absolute; top:50%;
	text-align: center;
	color: #fff;
	font-size:30px;
    text-shadow: 
    #000 2px 0px 2px, #000 -2px 0px 2px,
    #000 0px -2px 2px, #000 -2px 0px 2px,
    #000 2px 2px 2px, #000 -2px 2px 2px,
    #000 2px -2px 2px, #000 -2px -2px 2px,
    #000 1px 2px 2px, #000 -1px 2px 2px,
    #000 1px -2px 2px, #000 -1px -2px 2px,
    #000 2px 1px 2px, #000 -2px 1px 2px,
    #000 2px -1px 2px, #000 -2px -1px 2px,
    #000 1px 1px 2px, #000 -1px 1px 2px,
    #000 1px -1px 2px, #000 -1px -1px 2px;
}


@media screen and (max-width: 640px) {
.close-txt{
	font-size:5vw;

}

}


/* ==========================================================================
    tw-section
    ========================================================================== */


.l-end-bg {
    padding: 40px 0 40px 0;
    text-align: center;
    background: url(../img/bg-img-05.webp) no-repeat;
    background-size: cover;
}

.l-tw-section {
    padding: 140px 0 180px 0;
}

.l-tw-section-embed {
    margin: 60px auto;
    width: 780px;
}

.twitter-tweet {
    margin: 0 auto;
}

.l-tw-section-embed iframe {
    text-align: center;
}

.btn-default img {
    box-shadow: 10px 20px 50px rgb(0 0 0 / 60%);
}



/* ==========================================================================
    media-section
    ========================================================================== */

.l-media-section {
    padding: 60px 0 40px 0;
    text-align: center;
    position: relative;
    z-index: 0;
}

.l-media-section-list {
    text-align: left;
}

.l-media-section-list li {
    width: 31.5%;
    display: inline-block;
    vertical-align: top;
    margin-right: 2%;
    margin-bottom: 48px;
    position: relative;
    padding-bottom: 40px;
}

.l-media-section-list li:nth-child(3n) {
    margin-right: 0%;
}


.l-media-section-list-title {
    margin-top: 24px;
    font-size: 1.6rem;
    color: #552900;
    font-weight: 600;
}

.l-media-section-list-more {
    font-size: 1.6rem;
    color: #552900;
    font-weight: 600;
    text-align: right;
    position: absolute;
    bottom: 0;
    right: 0;
    text-decoration: underline;
}


/* ==========================================================================
    under-page-title
    ========================================================================== */

.l-under-page2,
.l-under-page {
    padding: 80px 0 160px 0;
    margin: 0 auto;
    position: relative;
}

.l-under-page::after  {
    background: url(../img/bg-under-page-title.png);
    background-size: cover;
    background-position: center;
    width: 100%;
    height: 520px;
    position: absolute;
    left: 0;
    top: 0;
    content: " ";
    z-index: -1;
}


.l-under-page2 h2.section-title,
.l-under-page h2.section-title {
    width: 100%;
    background: url(../img/bg-title-h2.jpg);
    background-size: cover;
    color: #FFF;
    font-size: 3.2rem;
    padding: 40px 30px;
    box-sizing: border-box;
    line-height: 1.4;
    font-weight: bold;
    text-shadow: 2px 2px 14px #482200;
    margin: 80px auto 20px auto;
    text-align: center;
}



.l-under-page h3.section-title {
    width: 100%;
    background: url(../img/bg-title-h3.jpg);
    background-size: cover;
    color: #9f0000;
    font-size: 2.8rem;
    padding: 26px 30px;
    box-sizing: border-box;
    line-height: 1.4;
    font-weight: bold;
    margin: 80px auto 0px auto;
    text-align: center;
}


.l-under-page h4.section-title {
    font-size: 2.4rem;
    color: #9f0000;
    font-weight: bold;
    letter-spacing: 0px;
    text-shadow: 2px 2px 10px #FFF;
    margin: 80px auto 20px auto;
}

.l-under-page .section-cap {
    text-align: left;
    font-size: 1.7rem;
    font-weight: 600;
    line-height: 2.1;
    margin: 20px auto;
    text-shadow: 2px 2px 5px #fff;
    color: #000;
}

.l-under-page .section-cap-bg {
    text-align: left;
    font-size: 1.7rem;
    font-weight: 600;
    line-height: 2.1;
    margin-bottom: 20px;
    background: rgba(255,255,255,0.50);
    padding: 3% 5%;
    box-sizing: border-box;
    color: #000;
}

.l-under-page .section-cap a, .l-under-page .section-cap-bg a {
    text-decoration: underline;
    color: #083d77;
    font-weight: 600;
}

.l-under-page .section-cap a {
    text-shadow: 2px 2px 5px #fff;
}

.l-under-page .section-img {
    margin: 48px auto;
}

.l-under-page .section-img img {
    width: 100%;
}

.l-under-page .section-movie-embed {
    margin: 80px auto 80px auto;
    padding-top: 0;
}

.l-under-page .l-section-inner_ss .section-movie-embed iframe {
    width: 100%!important;
    height: 405px!important;
}

.l-under-page .l-section-inner_s .section-movie-embed iframe {
    width: 100%!important;
    height: 484px!important;
}

.l-under-page .l-section-inner_m .section-movie-embed iframe {
    width: 100%!important;
    height: 608px!important;
}

.l-under-page .l-section-inner_l .section-movie-embed iframe {
    width: 100%!important;
    height: 675px!important;
}


.l-under-page .js-modal-video-open {
    margin: 80px auto;
    cursor: pointer;
    transition: 0.3s;
    position: relative;
    box-shadow: 10px 20px 50px rgb(0 0 0 / 60%);
}

.l-under-page .btn-movie {
    position: absolute;
    width: 100px;
    height: 126px;
    background: url(../img/btn-movie.png);
    background-size: cover;
    top: 50%;
    left: 50%;
    margin-left: -50px;
    margin-top: -63px;
}

.l-under-page .js-modal-video-open:hover .btn-movie {
    transform: scale(0.8,0.8);
    transition: 0.4s;
}

.l-under-page .js-modal-video-open:hover {
    opacity: 0.8;
    transition: 0.3s;
} 

.btn-normal {
    margin: 60px auto 100px auto;
    background: url(../img/btn-normal.jpg);
    background-size: cover;
    width: 360px;
    height: 80px;
    text-align: center;
    color: #FFF;
    font-size: 2.1rem;
    font-weight: bold;
    line-height: 3.8;
}




/* ==========================================================================
    footer-section
    ========================================================================== */

.l-footer {
    padding: 80px 0 0 0;
    background: #211000;
    text-align: center;
}

.l-footer-notes {
    margin-bottom: 60px;
    color: #FFF;
    font-size: 1.45rem;
}

.l-footer-sns {
    margin: 20px auto 68px auto;
}

.l-footer-sns li {
    display: inline-block;
    padding: 0 12px;
    vertical-align: middle;
}

.l-footer-sns li img {
    height: 32px;
}

.l-footer-info .l-col-2 {
    vertical-align: top;
}

.l-footer-info-ico {
    width: 160px;
    display: inline-block;
    vertical-align: top;
}

.l-footer-info-txt {
    display: inline-block;
    vertical-align: top;
    color: #FFF;
    text-align: left;
    font-size: 1.6rem;
    line-height: 2;
}

.l-footer-info-txt a {
    text-decoration: underline;
    color: #FFF;
}

.l-footer-info-txt span {
    display: block;
    font-size: 1.35rem;
    margin: 6px 0;
    line-height: 1.8;
}

.l-footer-info-txt a {
    margin-bottom: 10px;
    display: inline-block;
}

.l-footer-info .l-col-2:nth-child(1) .l-footer-info-txt {
    width: 320px;
    margin-right: 0px;
    margin-left: 30px;
    line-height: 2.6;
    letter-spacing: -1.8px;
}

.l-footer-info .l-col-2:nth-child(2) .l-footer-info-txt {
    width: 100%;
    letter-spacing: -1px;
}


.l-footer-info .l-col-2:nth-child(1) .l-footer-info-txt dt {
    display: inline-block;
    width: 28%;
    vertical-align: top;
}

.l-footer-info .l-col-2:nth-child(1) .l-footer-info-txt dd {
    display: inline-block;
    width: 70%;
    vertical-align: top;
}

.l-footer-info .l-col-2:nth-child(2) .l-footer-info-txt dt {
    display: inline-block;
    width: 16%;
    vertical-align: top;
    margin-left: 5px;
}

.l-footer-info .l-col-2:nth-child(2) .l-footer-info-txt dd {
    display: inline-block;
    width: 82%;
    vertical-align: top;
}

.l-footer-banner {
    margin-top: 40px;
}

.l-footer-banner img {
    box-shadow: 10px 20px 50px rgb(0 0 0 / 40%);
}

.l-footer-logo {
    margin: 48px auto 80px auto;
}


.l-footer-end {
    background: none;
    padding: 1.5em 0;
    color: #FFF;
}

.l-footer-end-cap {
    color: #FFF;
    font-size: 1.5rem;
}

.l-footer-end-copyright {
    margin-top: 24px;
    color: #FFF;
    font-size: 1.45rem;
}


.template-footer__rights {
    color: #ddd;
    font-size: 10px;
    font-family: 'Roboto', 'Helvetica Neue', Helvetica, arial, sans-serif;
}


/* ==========================================================================
    etc
    ========================================================================== */

.mask_wrap          { -webkit-mask-box-image:linear-gradient(90deg, rgba(0,0,0,0) 0%, rgba(0,0,0,1) 15%, rgba(0,0,0,1) 100%); }

.l-fix-item {
    width: 560px;
    height: 210px;
    padding: 32px 0 0 60px;
    position: fixed;
    bottom: -250px;
    right: -0px;
    z-index: 10;
    transition: 0.6s;
    text-align: center;
    background: url(../img/fix-item-03-back.png) no-repeat;
    background-position: top left;
    background-size: cover;
    /*
    -webkit-mask-box-image:linear-gradient(90deg, rgba(0,0,0,0) 0%, rgba(0,0,0,1) 13%, rgba(0,0,0,1) 100%);
    */

}

.fix-inner-wrap         { transform: scale(0.82); }

.l-fix-item-list li {
    height: 74px;
    display: inline-block;
    margin: 0 4px;
}
.l-fix-item--catch      { width: 90%; }

.l-fix-item-list li img {
    height: 58px; /* 64px */
    filter: drop-shadow(0px 0px 7px hsla(59, 100%, 65%, 0.7)) 
            drop-shadow(0px 0px 2px hsla(59, 100%, 80%, 0.9));
}

.l-fix-item.js-move {
    bottom: -2px;
    transition: 0.6s;
}

.l-fix-item-wiki {
    margin-left: 6px;
    margin-top: -13px;
    margin-bottom: 14px;
}

.l-fix-item-wiki img {
    height: 69px;
}


/* ==========================================================================
    js-effect
    ========================================================================== */


.js-effect-left, .js-effect-right, .js-effect-zoom, .js-effect-fade-in, .js-effect-left-mask {
    opacity: 1;
}

.move {
  animation-duration: 2.4s;
  animation-fill-mode: both;
}

.js-effect-zoom.move {
    animation-duration: 2.4s;
}

.js-effect-slide-left-mask.move {
    animation-duration: 2s;
}

.js-effect-slide-left.move {
    animation-duration: 1s;
}

.js-effect-fade-in.move {
    animation-duration: 1.3s;
}

.js-effect-left.move {
    animation-duration: 1.6s;
}

.js-effect-right.move {
    animation-duration: 1.6s;
}



.move:nth-child(1) {
  animation-delay: 0.1s;
}
.move:nth-child(1) a::after {
  animation-delay: 0.25s;
}
.move:nth-child(2) {
  animation-delay: 0.2s;
}
.move:nth-child(2) a::after {
  animation-delay: 0.5s;
}
.move:nth-child(3) {
  animation-delay: 0.3s;
}
.move:nth-child(3) a::after {
  animation-delay: 0.75s;
}
.move:nth-child(4) {
  animation-delay: 0.4s;
}
.move:nth-child(4) a::after {
  animation-delay: 1s;
}
.move:nth-child(5) {
  animation-delay: 0.5s;
}
.move:nth-child(5) a::after {
  animation-delay: 1.25s;
}
.move:nth-child(6) {
  animation-delay: 0.6s;
}
.move:nth-child(6) a::after {
  animation-delay: 1.5s;
}
.move:nth-child(7) {
  animation-delay: 0.7s;
}
.move:nth-child(7) a::after {
  animation-delay: 1.75s;
}
.move:nth-child(8) {
  animation-delay: 0.8s;
}
.move:nth-child(8) a::after {
  animation-delay: 2s;
}
.move:nth-child(9) {
  animation-delay: 0.9s;
}
.move:nth-child(9) a::after {
  animation-delay: 2.25s;
}
.move:nth-child(10) {
  animation-delay: 1s;
}
.move:nth-child(10) a::after {
  animation-delay: 2.5s;
}
.move:nth-child(11) {
  animation-delay: 1.1s;
}
.move:nth-child(11) a::after {
  animation-delay: 2.75s;
}
.move:nth-child(12) {
  animation-delay: 1.2s;
}
.move:nth-child(12) a::after {
  animation-delay: 3s;
}

.js-effect-left.move {
  animation-name: mo-left;
}

.js-effect-right.move {
  animation-name: mo-right;
}

.js-effect-fade-in.move {
  animation-name: mo-fade-in;
}

.js-effect-slide-left-mask.move {
  animation-name: mo-slide-left-mask;
}

.js-effect-zoom.move {
  animation-name: mo-zoom;
}

.js-effect-left-mask {
  animation-name: mo-left;
}

@keyframes mo-left {
  0% {
    transform: rotate(0deg) translate3D(0, -1050px, 0);
    opacity: 1;
  }
  100% {
    transform: rotate(0) translate3D(0, 0, 0);
    opacity: 1;
  }
}

@keyframes mo-right {
  0% {
    transform: rotate(0deg) translate3D(0, 1050px, 0);
    opacity: 1;
  }
  100% {
    transform: rotate(0) translate3D(0, 0, 0);
    opacity: 1;
  }
}

@keyframes mo-slide-left-mask {
  0% {
    left: 0;
  }
  100% {
    left: 100%;
  }
}

@keyframes mo-fade-in {
  0% {
    transform: translate3d(0px, 30px, 0px);
        opacity: 0;
  }
  100% {
    transform: translate3d(0px, 0%, 0px);
        opacity: 1;
  }
}

@keyframes mo-zoom {
  0% {
    transform: scale(1.3,1.3);
  }
  100% {
    transform: scale(1.0,1.0);
  }
}

