@charset "utf-8";

@import url('https://fonts.googleapis.com/css?family=Lato:100,300,400,700,900&display=swap');

html, body {
	position: relative;
	height: 100%;
	min-width: 1180px;
	background-position: center center;
	background-repeat: repeat-y;
	background-image: url(../images/bgline1.svg);
	}
@media screen and (max-width: 768px) {
html, body {
	min-width: 100%;
	}
	}

body.entrance{
	font-family: -apple-system, 'Lato', "Helvetica Neue", "游ゴシック Medium",YuGothic,YuGothicM,"Hiragino Kaku Gothic ProN",メイリオ,Meiryo,sans-serif;
	font-weight: normal;
	font-weight: 300;	/*100,300,400,700,900*/
	font-size: 15px;
	line-height: 1em;
	background-color: rgba(255, 255, 255, 1);
	color: #000;
	}
@media screen and (max-width: 768px) {
body.entrance{
	font-size: 16px;
	}
	}

.sp{	display: none !important;	}
@media screen and (max-width: 768px) {
.sp{	display: block !important;	}
	}

.pc{	display: block !important;	}
@media screen and (max-width: 768px) {
.pc{	display: none !important;	}
	}

.spi{	display: none;	}
@media screen and (max-width: 768px) {
.spi{	display: inline;	}
	}

.pci{	display: inline;	}
@media screen and (max-width: 768px) {
.pci{	display: none;	}
	}


/*================================

common

================================*/

html, body, svg{
	margin: 0;
	padding: 0;
	}

* {
	box-sizing: border-box;
	}

.entrance h1,h2,h3,h4,h5,p{
	margin: 0;
	padding: 0;
	font-weight: normal;
	font-weight: 300;
	}

::selection {
	background: #333;
	color: #fff;
	}
::-moz-selection {
	background: #333;
	color: #fff;
	}

.entrance a{
	color: #000;
	text-decoration: none;
	-webkit-transition: all .6s;
	-moz-transition: all .6s;
	-o-transition: all .6s;
	-ms-transition: all .6s;
	transition: all .6s;
	}

.entrance a img{
	-webkit-transition: all .6s;
	-moz-transition: all .6s;
	-o-transition: all .6s;
	-ms-transition: all .6s;
	transition: all .6s;
	}

.entrance a:hover img{
	opacity: 0.7;
	filter: alpha(opacity=70);
	}

.entrance a:focus, *:focus {
	outline: none;
	}

.entrance a.telLink{
	pointer-events: none;
	}
@media screen and (max-width: 768px) {
.entrance a.telLink{
	pointer-events: auto;
	}
	}

.entrance img{
	vertical-align: bottom;
	}

.entrance ul, li{
	margin: 0;
	padding: 0;
	list-style-type: none;
	}


/*================================

vimeo

================================*/

.entrance #vimeo{
	position: fixed;
	overflow: hidden;
	width: 100%;
	min-width: 1200px;
	height: auto;
	margin: auto;
	padding: 0;
	background-color: rgba(0, 0, 0, 0.1);
	}
.entrance #vimeo:before{
	content:"";
	display: block;
	padding-top: 42.5%;
	}
@media screen and (max-width: 768px) {
.entrance #vimeo{
	overflow-x:hidden;
	min-width: 100%;
	}
	}

.entrance #vimeo .loader{
	position: absolute;
	z-index: 0;
	top: 50%; 
	left: 50%;
	width: 60px;
	height: 15px;
	margin-top: -7px;
	margin-left: -30px;
	}

.entrance #vimeo #background{
	position: absolute;
	right: 0; 
	bottom: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(255, 255, 255, 0);
	}

.entrance #vimeo #background-front {
	position: absolute;
	right: 0; 
	bottom: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(255, 255, 255, 0);
	}
.entrance #vimeo #background iframe {
	width: 100%;
	height: 100%;
	}


/*================================

vimeomarge

================================*/

.entrance #vimeomarge{
	position: relative;
	overflow: hidden;
	width: 100%;
	min-width: 1200px;
	height: auto;
	margin: auto;
	padding: 0;
	}
.entrance #vimeomarge:before{
	content:"";
	display: block;
	padding-top: 42.5%;
	}
@media screen and (max-width: 768px) {
.entrance #vimeomarge{
	min-width: 100%;
	}
	}


/*================================

contents

================================*/

.entrance #contents {
	position: relative;
	width: 100%;
	min-width: 1200px;
	height: auto;
	margin: auto;
	padding-bottom: 5em;
	background-color: rgba(255, 255, 255, 1);
	}
@media screen and (max-width: 768px) {
.entrance #contents {
	overflow-x: hidden;
	min-width: 100%;
	max-width: 100%;
	}
	}


/*================================

nameplate

================================*/

.entrance #contents .nameplate {
	width: 100%;
	padding: 6em 0;
	text-align: center;
	}
@media screen and (max-width: 768px) {
.entrance #contents .nameplate {
	padding: 5em 0;
	}
	}

.entrance #contents .nameplate h1{
	width: auto;
	height: 15px;
	margin: auto;
	background-position: center center;
	background-repeat: no-repeat;
	background-image: url(../images/companylogo.svg);
	background-size: contain;
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
	}
@media screen and (max-width: 768px) {
.entrance #contents .nameplate h1{
	height: 12px;
	}
	}

.entrance #contents .nameplate p{
	margin-top: 3em;
	letter-spacing: .05em;
	}
@media screen and (max-width: 768px) {
.entrance #contents .nameplate p{
	font-size: .8em;
	margin-top: 2em;
	}
	}


/*================================

websites

================================*/

.entrance .websites {
	display: block;
	width: 100%;
	padding: 0;
	}
.entrance .websites:after {
	content: "";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
	}

.entrance .websites div.site{
	display: block;
	padding: 0;
	margin: 0;
	float: left;
	}

.entrance .websites div.site:first-child{
	width: 50%;
	}
@media screen and (max-width: 768px) {
.entrance .websites div.site:first-child{
	width: 100%;
	}
	}

.entrance .websites div.site:nth-child(n+2){
	width: 25%;
	}
@media screen and (max-width: 768px) {
.entrance .websites div.site:nth-child(n+2){
	width: 50%;
	}
	}

.entrance .websites div.site #inner {
	position: relative;
	width: 100%;
	}
.entrance .websites div.site #inner:before {
	content:"";
	display: block;
	padding-top: 80%;
	}
.entrance .websites div.site #inner #content {
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	}

.entrance .websites div.site.tomorrowland #inner #content {
	background-image: url(../images/site2020-tomorrowland.jpg?20201029);
	}
.entrance .websites div.site.despres #inner #content {
	background-image: url(../images/site2020-despres.jpg);
	}
.entrance .websites div.site.galerievie #inner #content {
	background-image: url(../images/site2020-galerievie2.jpg?20200218);
	}
.entrance .websites div.site.edition #inner #content {
	background-image: url(../images/site-edition.jpg);
	}
.entrance .websites div.site.caban #inner #content {
	background-image: url(../images/site-caban.jpg);
	}

.entrance .websites div.site #inner #content a{
	display: block;
	width: 100%;
	height: 100%;
	}

.entrance .websites div.site #inner #content a h2{
	display: block;
	width: 100%;
	height: 100%;
	background-position: center center;
	background-repeat: no-repeat;
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
	}

.entrance .websites div.site.tomorrowland #inner #content a h2{
	background-image: url(../images/logo-tomorrowland-black.svg);
	background-size: 40%;
	}
.entrance .websites div.site.despres #inner #content a h2{
	background-image: url(../images/logo-despres.svg);
	background-size: 40%;
	}
.entrance .websites div.site.galerievie #inner #content a h2{
	background-image: url(../images/logo-galerievie.svg);
	background-size: 48%;
	}
.entrance .websites div.site.edition #inner #content a h2{
	background-image: url(../images/logo-edition.svg);
	background-size: 40%;
	}
.entrance .websites div.site.caban #inner #content a h2{
	background-image: url(../images/logo-caban.svg);
	background-size: 40%;
	}
@media screen and (max-width: 768px) {
.entrance .websites div.site.tomorrowland #inner #content a h2{
	background-size: 50%;
	}
.entrance .websites div.site.despres #inner #content a h2{
	background-size: 50%;
	}
.entrance .websites div.site.galerievie #inner #content a h2{
	background-size: 58%;
	}
.entrance .websites div.site.edition #inner #content a h2{
	background-size: 50%;
	}
.entrance .websites div.site.caban #inner #content a h2{
	background-size: 50%;
	}
	}

.entrance .websites div.site #inner #content a:hover{
	background-color: rgba(255, 255, 255, 0.3);
	}


/*================================

allsites

================================*/

.entrance .allsites{
	display: block;
	width: 100%;
	margin-top: 3em;
	text-align: center;
	}
@media screen and (max-width: 768px) {
.entrance .allsites{
	margin-top: 2em;
	}
	}

.entrance .allsites a .inner{
	display: inline-block;
	padding-bottom: .5em;
	border-bottom: 1px solid transparent;
	-webkit-transition: all .6s;
	-moz-transition: all .6s;
	-o-transition: all .6s;
	-ms-transition: all .6s;
	transition: all .6s;
	}

.entrance .allsites a:hover .inner{
	border-bottom: 1px solid #000;
	}

.entrance .allsites a .inner p{
	font-weight: bold;
	padding-left: 1.5em;
	letter-spacing: .05em;
	background-position: left center;
	background-repeat: no-repeat;
	background-image: url(../images/arrow-right-line.svg);
	background-size: contain;
	}


/*================================

companylink

================================*/

.entrance .companylink{
	display: block;
	width: 100%;
	margin-top: 5em;
	}
@media screen and (max-width: 768px) {
.entrance .companylink{
	margin-top: 3em;
	}
	}

.entrance .companylink ul{
	display: block;
	width: 100%;
	margin: 0;
	padding: 0;
	border-top: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
	letter-spacing: -1em;
	}
@media screen and (max-width: 768px) {
.entrance .companylink ul{
	border-bottom: none;
	}
	}

.entrance .companylink ul li{
	display: inline-block;
	width: 20%;
	margin: 0;
	border-right: 1px solid #ccc;
	text-align: center;
	}
@media screen and (max-width: 768px) {
.entrance .companylink ul li{
	display: block;
	width: 100%;
	border-right: none;
	border-bottom: 1px solid #ccc;
	}
	}

.entrance .companylink ul li:last-of-type{
	border-right: none !important;
	}

.entrance .companylink ul li a{
	display: block;
	width: 100%;
	height: 100%;
	padding: 2.5em 0;
	letter-spacing: normal;
	}
@media screen and (max-width: 768px) {
.entrance .companylink ul li a{
	padding: 2em 0;
	}
	}

.entrance .companylink ul li a p{
	display: inline-block;
	border-bottom: 1px solid transparent;
	-webkit-transition: all .6s;
	-moz-transition: all .6s;
	-o-transition: all .6s;
	-ms-transition: all .6s;
	transition: all .6s;
	}

.entrance .companylink ul li:first-of-type a p{
	padding-left: 1.5em;
	background-position: left center;
	background-repeat: no-repeat;
	background-image: url(../images/search-line.svg);
	background-size: contain;
	}

.entrance .companylink ul li a:hover p{
	border-bottom: 1px solid #000;
	}


/*================================

ec

================================*/

.entrance .ec{
	display: block;
	width: 100%;
	margin-top: 4em;
	text-align: center;
	}
@media screen and (max-width: 768px) {
.entrance .ec{
	margin-top: 3em;
	}
	}

.entrance .ec a p{
	display: inline-block;
	width: 340px;
	height: 100px;
	border: 1px solid #000;
	background-position: center center;
	background-repeat: no-repeat;
	background-image: url(../images/eclogo.svg);
	background-size: 50%;
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
	}
@media screen and (max-width: 768px) {
.entrance .ec a p{
	width: 75%;
	height: 100px;
	background-size: 60%;
	}
	}


/*================================

sns

================================*/

.entrance .sns{
	display: block;
	width: 100%;
	margin-top: 4em;
	text-align: center;
	}
@media screen and (max-width: 768px) {
.entrance .sns{
	margin-top: 3em;
	}
	}

.entrance .sns img{
	margin: 0 .6em;
	}


/*================================

footer

================================*/

.entrance footer{
	display: block;
	width: 100%;
	margin-top: 4em;
	text-align: center;
	}
@media screen and (max-width: 768px) {
.entrance footer{
	margin-top: 3em;
	}
	}

.entrance footer ul{
	text-align: center;
	letter-spacing: -1em;
	}

.entrance footer ul li{
	display: inline-block;
	text-align: center;
	letter-spacing: normal;
	font-size: .8em;
	margin: 0 1em;
	}
@media screen and (max-width: 768px) {
.entrance footer ul li{
	display: block;
	text-align: center;
	margin: 1em 0 0;
	}
	}

.entrance footer ul li a{
	border-bottom: 1px solid transparent;
	}

.entrance footer ul li a:hover{
	border-bottom: 1px solid #000;
	}

.entrance footer p{
	margin-top: 6em;
	font-size: .7em;
	}
@media screen and (max-width: 768px) {
.entrance footer p{
	margin-top: 4em;
	font-size: .7em;
	}
	}