@charset "UTF-8";
/* CSS Document */

/* ***** Loading Animation ***** */
.loader{ 
	position:absolute;
	top: 40vh;
	left: 50%;
	z-index: 0;
}

.loader > .spin{
	border:solid 5px cyan;
	border-radius: 100%;
	position:absolute;
	box-shadow: 0px 0px 2px 2px cyan;
}

.spin.a{
	width:80px;
	height:80px;
	top: -45px; left: -45px;
	-webkit-animation: rotOuter 1.5s infinite linear;
}

.spin.b{
	width:70px;
	height:70px;
	top:-40px;
	left:-40px;
	-webkit-animation: rotInner 1.5s infinite linear;
}

.loader .txt{
	position:absolute;
	width: 90px;
	line-height: 90px;
	top:-45px; left: -45px;
	text-align: center;
}

@-webkit-keyframes rotInner{
	0%   { -webkit-transform: rotateY(-0deg)   rotateX(30deg); }
	50%  { -webkit-transform: rotateY(-180deg) rotateX(210deg); }
	100% { -webkit-transform: rotateY(-360deg) rotateX(390deg); }
}
@-webkit-keyframes rotOuter{
	0%   { -webkit-transform: rotateY(0deg)   rotateX(30deg); }
	50%  { -webkit-transform: rotateY(180deg) rotateX(30deg); }
	100% { -webkit-transform: rotateY(360deg) rotateX(30deg); }
}

/* **************************************************************** */
/*             MAIN-IMAGE  LAYOUT
/* **************************************************************** */

.main-slider {
	width: 100%;
	height: 700px;
	margin: 0;
	padding: 0;
	float: left;
}

.main-slider ul.slider {
	width: 100%;
	margin: 0;
	padding: 0;
	height: 100%;
	float: left;
	z-index: 0;
}

.main-slider .filter {
	width: 100%;
	margin: 0;
	padding: 0;
	height: 100%;
	background-color:rgba(0,0,0,0.3);
	float: left;
	z-index: 999;
	display: block;
	top: -700px;
	position: relative;
}

.main-slider .bg {
    display: flex;
    width: 700px;
    margin: 0;
    padding: 30px 0;
    background-color: rgba(36,28,139,0.60);
    float: right;
    position: absolute;
    top: 100px;
    right: 0;
    z-index: 99;
}

.main-slide .bg .copy {
	color: #FFF;
	font-size:20px;
	font-weight: 700;
	font-family: "Noto Serif JP", serif;
	line-height: 1.7em;
	width: 80%;
	margin: 0 10%;
}

.main-slide .bg .copy .en {
	font-size:55px;
}

.main-slide .bg .copy h1 {
	font-size:36px;
    margin: 50px 0 30px;
    letter-spacing: 0.2em;
}


.slide {
  position: relative;
  width: 100%;
  height: 700px;
  overflow: hidden;
  z-index: 0;
}


.slide-image {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  animation: slider-1 24s linear infinite;
}

.slide-image:nth-child(1) {
  background-image: url("../images/top/main01.webp");
  animation-delay: -2s;
}

.slide-image:nth-child(2) {
  background-image: url("../images/top/main02.webp");
  animation-delay: 6s;
}

.slide-image:nth-child(3) {
 background-image: url("../images/top/main04.webp");
  animation-delay: 14s;
}

.slide-image:nth-child(4) {
  background-image: url("../images/top/main01.webp");
  animation-delay: 22s;
}

@keyframes slider-1 {
  0% {
    opacity: 0;
    transform: scale(1);
  }
  4.16% {
    opacity: 1;
  }
  33.33% {
    opacity: 1;
  }
  41.66% {
    opacity: 0;
    transform: scale(1.2);
  }
  100% {
    opacity: 0;
  }
}

/* ***** Main Visual Layout ***** */
.main {
	width: 100%;
	height:65vh;
	margin: 0;
	padding: 0;
	float: left;
	z-index: 0;
}

/* video */

.videoblock {
	width: 100%;
	height: 65vh;
	margin: 0;
	background-color: #FFFFFF;
	z-index: 0;
    background-image: url("../images/top/main01.webp");
    background-repeat: no-repeat;
    background-size: 110%;
    background-position: center right;
}

/* 1.5秒間かけてフェードイン */
.fadeIn {
    animation-name: fadeIn;
    animation-delay: 1500ms;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateY(50px);
    opacity: 0;
}
@keyframes fadeIn {
    0% {
    }
    100% {
        transform: translateY(0);
        opacity: 1;
    }
}

.bg {
    display: flex;
    width: 700px;
    margin: 100px 0 0;
    padding: 30px 0;
    background-color: rgba(36,28,139,0.60);
    float: right;
}

.bg .copy {
	color: #FFF;
	font-size:20px;
	font-weight: 700;
	font-family: "Noto Serif JP", serif;
	line-height: 1.7em;
	width: 80%;
	margin: 0 10%;
}

.bg .copy .en {
	font-size:55px;
}

.bg .copy h1 {
	font-size:36px;
    margin: 50px 0 30px;
    letter-spacing: 0.2em;
}





/* ********************************************************* 
            Common Rayout
************************************************************ */

.frontpage .glid {
	width: 40%;
	margin: 0;
	padding: 0 5%;
	float: left;
}

.frontpage .sentence {
	width: 100%;
	margin: 50px 0;
	padding: 0;
	float: left;
}

.fixed-bg {
    min-height: 70vh;
    background-attachment: fixed;
    background-size: 40%;
    background-position: center right 5%;
    background-repeat: no-repeat;
}

.fixed-bg.bg-01 { background-image: url("../images/top/img01.webp"); }
.fixed-bg.bg-02 { background-image: url("../images/top/img02.webp"); }
.fixed-bg.bg-03 { background-image: url("../images/top/img03.webp"); }
.fixed-bg.bg-04 { background-image: url("../images/top/img04.webp"); }

.filter {
    width: 100%;
    margin: 0;
    padding: 0;
    background-color: rgba(255,255,255,0.00);
    display: flex;
}


/* ********************************************************* 
            purchased Rayout
************************************************************ */

.frontpage .purchased {
	width: 100%;
	margin: 0;
	padding:0;
	float: left;
}

.frontpage .purchased ul {
	width: 80%;
	margin: 0 10%;
	padding:0;
	float: left;
}

.frontpage .purchased ul li {
	width:30%;
	margin: 0 1.5% 20px;
	padding: 0;
	float: left;
}

.frontpage .purchased ul li a {
	width:100%;
    display: block;
	margin: 0 1.5%;
	padding:10px 0;
    color: #241c8b;
    text-align: center;
    border: #241c8b 1px solid;
    box-sizing: border-box;
    border-radius: 5px;
    transition: ease 0.5s all;
}

.frontpage .purchased ul li a:hover {
    background-color: #241c8b;
    color: #FFF;
}





/* ********************************************************* 
            TOPICS Rayout
************************************************************ */

.frontpage .topics {
	width: 100%;
	margin: 0;
	padding: 0 0 50px;
	float: left;
}

.frontpage .topics .glid {
	width: 90%;
	margin: 0 5%;
	padding: 0;
	float: left;
}

.frontpage .topics .list_box {
	width: 100%;
    max-width: 960px;
	margin: 0 auto;
	padding: 0;
}

.frontpage .topics .list_box a {
	width: 85%;
	margin: 5px 7.5% 0;
	padding: 0;
	float: left;
	color: #000;
	border-bottom: #000 1px dotted;
	transition: ease 0.5s all;
    display: block;
}

.frontpage .topics .list_box .more_btn a {
	margin: 0;
	border-bottom: none;
}

.frontpage .topics .list_box table {
	width: 100%;
	margin: 0;
	padding: 0;
	border-collapse: collapse;
}

.frontpage .topics .list_box td {
	text-align: center;
	padding: 10px;
	transition: ease 0.5s all;
}

.frontpage .topics .list_box a:hover td {
	background-color: rgba(36,28,139,1.00);
    color: #FFF;
}

.frontpage .topics .list_box td:nth-of-type(1) {
	width: 120px;
}

.frontpage .topics .list_box td:nth-of-type(2) {
	text-align: left;
}

.frontpage .topics .list_box td:nth-of-type(3) {
	width: 60px;
	color: #B5B5B5;
	font-size: 13px;
	text-align: left;
	background-image: url("../images/common/arr_topics.png");
	background-repeat: no-repeat;
	background-position: center right 10px;
	vertical-align: middle;
}


/* ********************************************************* 
            Company Rayout
************************************************************ */

.frontpage .company {
	width: 100%;
	margin: 0;
	float: left;
}


/* ***************************************************************
           RESPONSIVE  RAYOUT
****************************************************************** */

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

.main-slider .bg { width: 50%; }
.bg .copy { width: 90%;margin: 0 5%;font-size: 18px; }
.bg .copy .en {	font-size:4vw; }
.bg .copy h1 { font-size:2.5vw;letter-spacing: 0.1em;margin: 30px 0 20px; }

.content { margin: 0; }

.fixed-bg {
    min-height: auto;
    background-attachment:scroll;
    background-size: cover;
}

.filter { background-color: rgba(255,255,255,0.70); }

.frontpage .glid { width: 90%; }

.frontpage .purchased ul li a {	background-color: rgba(255,255,255,1.00); }

.frontpage .topics .list_box td:nth-of-type(1) {
	width: 90%;
    text-align: left;
    padding: 0 5%;
    float: left;
}

.frontpage .topics .list_box td:nth-of-type(2) {
	width: 90%;
    text-align: left;
    padding: 0.3em 5%;
    float: left;
    background-image: url("../images/common/arr_topics.png");
	background-repeat: no-repeat;
	background-position: center right 10px;
}

.frontpage .topics .list_box td:nth-of-type(3) {
    display: none;
}


}

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

.main-slider .bg { width: 100%;height: 100%;padding-top: 40vh; }

}

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

.main-slider .bg { top: 80px; }

.bg .copy { font-size: 15px;letter-spacing: 0; }
.bg .copy .en {	font-size:26px; }
.bg .copy h1 { font-size:18px; }

}

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

.frontpage .purchased ul {
	width: 100%;
	margin: 0;
}

}

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

.frontpage .purchased ul li {
	width:40%;
	margin: 0 5% 20px;
}

}
