@charset "utf-8";

/* =saltism css reset page design 2020.09
-------------------------------------------------------------- */
a, abbr, acronym, address, applet, article, aside, audio, b, big, blockquote,
body, canvas, caption, center, cite, code, dd, del, details, dfn, div, dl, dt,
em, embed, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6,
header, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object,
ol, output, p, pre, q, ruby, s, samp, section, small, span, strike, strong, sub,
summary, sup, table, tbody, td, tfoot, th, thead, time, tr, tt, u, ul, var, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
    text-decoration: none;
    box-sizing: border-box;
}

body {
	margin: 0;
	background-color : #000;
	color: #fff;
	/* font-family: 'Alatsi', sans-serif, 游ゴシック;*/
	font-family: 'Inter', sans-serif, 游ゴシック;	
}
canvas { 
	position:fixed; 
	top:0; 
	left:0; 
	width:100%; 
	height:100%;
	z-index: -1;
}

.flip-switch.flip-switch-text {
	margin: 0;
	background-color : #000;
	color: #fff;
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
}

p {
	margin: 0;
	line-height: 1.8;
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
}



section {
	width: 1000px;
	margin: 50px auto 100px;
}

h2 {
	font-size: 55px;
	margin-left	: 7px;
	margin-bottom: 10px;
	/* font-family: 'Alatsi', sans-serif; */
	font-family: 'Inter', sans-serif;
}
h2.titles {
	color: #00CCFF;
	margin-left	: 15px;
	margin-bottom: 15px;
	font-family: 'Vincent', sans-serif;
    letter-spacing: .05em;
}
h2.ja_title {
	color: #00CCFF;
	margin-left	: 15px;
	margin-bottom: 15px;
	font-family: 'Vincent', sans-serif;
    letter-spacing: .05em;
}
h2 span.font {
	font-size: 80%;
	margin: 0 -.18em;
    font-family: 'Kosugi', sans-serif;
}
h2 span.word {
	margin: 0 .1em 0 -.125em
}
h2 span.sub-font {
	font-size: 80%;
	margin: 0 -.1em;
    font-family: 'Kosugi', sans-serif;
}
h2.title-one {
	font-size: 70px;
	text-align: center;
	margin-bottom: 65px;
}
.block {
	overflow: hidden;
}
.blocks {
	overflow: hidden;
	margin: 1% ;
}
.block100 {
	width: 98%;
	margin: 1%;
	padding-bottom: 50px;
	height: auto;
	float: left;
}
.block50 {
	width: 48%;
	margin: 1%;
	padding-bottom: 50px;
	height: auto;
	float: left;
}
.block25 {
	width: 23%;
	margin: 1%;
	padding-bottom: 50px;
	height: auto;
	float: left;
}
.block75 {
	width: 73%;
	margin: 1%;
	padding-bottom: 50px;
	height: auto;
	float: left;
}

p.and {
	margin-bottom: 24px;
}
p.end {
	margin-bottom: 24px;
	text-align: right;
}
p.start {
	margin-bottom: 24px;
	text-align: left;
}

ul {
	list-style: none;
	padding-left: 0;
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
}

img {
	width: 100%;
	height: auto;
}
img.beginner {
	width : 70%;
	margin: 0 15%;
}
img.kage {
	width : 90%;
	margin: 0 5%;
	/* border-radius: 50%; */
	/* box-shadow: 10px 15px rgba(50,50,50,.4); */
}
#saltism {
	height: 100vh;
}
/****************** ロゴイメージ **************************************/
a#logo {
    display: none;
    position: fixed;
    width: 40px;
    height: 40px;
    top: 20px;
    left: 20px;
    z-index: 1002;
}
/******************* サウンド ON / OFF *************************************/
#sound {
    display: block;
    position: fixed;
    bottom: 20px;
    left: 20px;
    z-index: 1002;
}
.flip-switch {
	display: block;
	margin: 0 auto;
	perspective: 50px;
	-webkit-perspective: 50px;
	-moz-perspective: 50px;
	border-radius: 50px;
	-webkit-border-radius: 50px;
	-moz-border-radius: 50px;
}
.flip-switch input {
	opacity: 0;
	position: absolute;
	top: 0;
	right: 100%;
	width: 1px;
	height: 1px;
}
.flip-switch label {
	display: block;
	position: relative;
	height: 22px;
	width: 50px;
	outline: none;
	margin: 0 auto;
	-webkit-appearance: none;
	background: none;
	border: none;
	transform-style: preserve-3d;
	-webkit-transform-style: preserve-3d;
	-moz-transform-style: preserve-3d;
	border-radius: inherit;
	-webkit-border-radius: inherit;
	-moz-border-radius: inherit;
	animation: uncheck 0.6s ease-out;
	-webkit-animation: uncheck 0.6s ease-out;
	-moz-animation: uncheck 0.6s ease-out;
	box-shadow: none;
	-webkit-box-shadow: none;
	-moz-box-shadow: none;
}
.flip-switch label:before, .flip-switch label:after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	height: inherit;
	width: inherit;
	backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
	-moz-backface-visibility: hidden;
	border-radius: inherit;
	-webkit-border-radius: inherit;
	-moz-border-radius: inherit;
	text-align: center;
}
.flip-switch label:before {
	z-index: 2;
	transform: rotateY(0deg);
	-webkit-transform: rotateY(0deg);
	-moz-transform: rotateY(0deg);
	background: #FFF;
}
.flip-switch label:after {
	transform: rotateY(180deg);
	-webkit-transform: rotateY(180deg);
	-moz-transform: rotateY(180deg);
	background: #FF3311;
}
.flip-switch input:checked + label {
	transform: rotateY(180deg);
	-webkit-transform: rotateY(180deg);
	-moz-transform: rotateY(180deg);
	animation: check 0.6s ease-out;
	-webkit-animation: check 0.6s ease-out;
	-moz-animation: check 0.6s ease-out;
}

.flip-switch.flip-switch-text label:before,
.flip-switch.flip-switch-text label:after {
	color: white;
	line-height: 22px;
	font-weight: 900;
	font-size: 10px;
}
.flip-switch.flip-switch-text label:before {
	color: #000;
	content: "♪OFF";
}
.flip-switch.flip-switch-text label:after {
	content: "♪ON";
}

@keyframes check {
	0% {transform: rotateY(0deg);}
	50% {transform: rotateY(195deg);}
	75% {transform: rotateY(165deg);}
	100% {transform: rotateY(180deg);}
}
@-webkit-keyframes check {
	0% {-webkit-transform: rotateY(0deg);}
	50% {-webkit-transform: rotateY(195deg);}
	75% {-webkit-transform: rotateY(165deg);}
	100% {-webkit-transform: rotateY(180deg);}
}
@-moz-keyframes check {
	0% {-moz-transform: rotateY(0deg);}
	50% {-moz-transform: rotateY(195deg);}
	75% {-moz-transform: rotateY(165deg);}
	100% {-moz-transform: rotateY(180deg);}
}
@keyframes uncheck {
	0% {transform: rotateY(180deg);}
	50% {transform: rotateY(-15deg);}
	75% {transform: rotateY(15deg);}
	100% {transform: rotateY(0deg);}
}
@-webkit-keyframes uncheck {
	0% {-webkit-transform: rotateY(180deg);}
	50% {-webkit-transform: rotateY(-15deg);}
	75% {-webkit-transform: rotateY(15deg);}
	100% {-webkit-transform: rotateY(0deg);}
	}
	@-moz-keyframes uncheck {
	0% {-moz-transform: rotateY(180deg);}
	50% {-moz-transform: rotateY(-15deg);}
	75% {-moz-transform: rotateY(15deg);}
	100% {-moz-transform: rotateY(0deg);}
}
/******************* メニュー *************************************/
#switch{
    width: 47px;
    height: 47px;
    display: block;
    position: fixed;
    top: 30px;
    right: 20px;
    -webkit-transition: transform 0.38s ease;
    transition: transform 0.38s ease;
    z-index: 1004;
}

.switch__label {
	width: 44px;
	position: relative;
	display: inline-block;
}
.switch__content {
	display: block;
	position: relative;
	border-radius: 30px;
	height: 20px;
	-webkit-transition: all .1s .4s;
	   -moz-transition: all .1s .4s;
	    -ms-transition: all .1s .4s;
	     -o-transition: all .1s .4s;
	        transition: all .1s .4s;
	overflow: hidden;
}
.switch__content:before {
	content: "";
	display: block;
	position: absolute;
	width: calc(100% - 4px);
	height: calc(100% - 4px);
	top: 0;
	left: 0;
	border: 1.5px solid #000000;
	border-radius: 20px;
	background-color: #fff;
}
.switch__content:after {
	content: "";
	display: block;
	position: absolute;
	background-color: transparent;
	width: 0;
	height: 100%;
	top: 0;
	left: 0;
	
	border-radius: 20px;
	-webkit-transition: all .5s;
	   -moz-transition: all .5s;
	    -ms-transition: all .5s;
	     -o-transition: all .5s;
	        transition: all .5s;
}
.switch__input {
	display: none;
}
.switch__circle {
	display: block;
	top: 5px;
	left: 5px;
	position: absolute;
	width: 10px;
	height: 10px;
	-webkit-border-radius: 10px;
	        border-radius: 10px;
	background-color: #000000;
	-webkit-transition: all .5s;
	   -moz-transition: all .5s;
	    -ms-transition: all .5s;
	     -o-transition: all .5s;
	        transition: all .5s;
}
.switch__input:checked ~ .switch__circle {
	left: 29px;
	background-color: #fff;
}
.switch__input:checked ~ .switch__content {
	border-color: transparent;
	-webkit-transition: all 0s;
	   -moz-transition: all 0s;
	    -ms-transition: all 0s;
	     -o-transition: all 0s;
	        transition: all 0s;
}
 
.switch__input:checked ~ .switch__content:after {
	background-color: #000;
	width: 100%;
}
.backer {
	overflow: hidden;
}

/****************** メニュー **************************************/

#menu{
	position: fixed;
	top: 0;
	right: 0;
	z-index: 1003;
	width: 100vw;
	height: 100vh;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background: #0e0e0e;
}
.menu__item{
	width: 100%;
	height: auto;
	padding: .5em 1em;
	text-align: center;
	color: #fff;
	box-sizing: border-box;
}

/*----------------------------
* アニメーション部分
*----------------------------*/

/* アニメーション前のメニューの状態 */
#menu{
	pointer-events: none;
	opacity: 0;
	transition: opacity .3s linear;
}
/* アニメーション後のメニューの状態 */
#menu.is-active {
	pointer-events: auto;
	opacity: 0.95;
}


.cmn-menu-btn__en {
    display: block;
    color: #00CCFF;
    font-weight: 400;
    font-style: normal;
    letter-spacing: .05em;
    line-height: 1;
    font-size: 28px;
    white-space: nowrap;
    transition: letter-spacing .8s cubic-bezier(.43,.2,.02,1),color .8s cubic-bezier(.43,.2,.02,1);
}
.cmn-menu-btn:hover .cmn-menu-btn__en {
    letter-spacing: .2em;
    font-family: 'Inter', sans-serif, 游ゴシック;
}
.cmn-menu-btn:hover .cmn-menu-btn__ja {
    color: orange;
    transition: color .5s;
}
.cmn-menu-btn:before {
    content: "";
    position: absolute;
    left: 0;
    top: 2px;
    width: 2px;
    height: 90%;
    background: #00CCFF;
}
a:active, a:hover, a:link, a:visited {
    color: #fff;
    text-decoration: none;
}
.cmn-menu-btn {
    position: relative;
    display: block;
    padding-left: 20px;
}
.cmn-menu-btn__ja {
    font-weight: 400;
    display: block;
    color: #fff;
    font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    font-size: 14px;
    letter-spacing: .05em;
    white-space: nowrap;
}
#menu ul {
    display: flex;
    flex-wrap: wrap;
    width: 450px;
    margin-bottom: 130px;
}
#menu li  {
    width: 50%;
    margin-bottom: 37px;
    float: left;
}

/**************************************************************************************************************/

.page-top {
	position: fixed;
	display: none;
	align-items: center;
	justify-content: center;
    width: 50px;
    height: 100px;
    position: fixed;
    top: auto;
    bottom: 40px;
    left: auto;
    right: -12px;
    z-index: 100;
    overflow: visible;
	cursor: pointer;
}

.vertical-cap .line {
    width: 50px;
    height: 1px;
    display: block;
    top: 7px;
    left: -60px;
    position: absolute;
    z-index: auto;
    background: #fff;
    transform-origin: left top;
}
.vertical-cap .txt {
    display: block;
    margin: 0 0 0 1em;
    padding: 0;
    position: relative;
    transform: rotate(90deg);
    transform-origin: left top;
    line-height: 1;
    letter-spacing: 2px;
    color: inherit;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-decoration: none!important;
}
.vertical-cap--pagetop .txt {
    width: 100px;
    top: 0;
    left: 0;
    position: absolute;
    z-index: auto;
    transition: letter-spacing .6s cubic-bezier(.77,0,.175,1);
}

/**********************************************************************************************/

/* ----- 背景用の動画ファイル ----- */
video {
	width: 100%;
	height: auto;
}

video#mainvideo {
	width: 100%;
	height: 100%;
}

.overlay {
	width: 100%;
	height: 100vh;
	position: absolute;
	top: 0;
	left: 0;
	background-image: linear-gradient(45deg, rgba(0,0,0,.4) 50%, rgba(0,0,0,.6) 50%);
	background-size: 4px 4px;
	z-index: 2;
}


#js-scroll-cont, .contents {
    width: 100%;
    top: 0;
    left: 0;
    overflow: hidden;
}
.contents {
    height: 100%;
    display: block;
    position: absolute;
    z-index: 0;
}

#top .scroll-content{padding-top:200vh}
#top .contact{margin-top:150px}

.top-visual-title {
    width: 475px;
    height: 196px;
    display: block;
    top: 50vh;
    left: 50vw;
    position: absolute;
    z-index: 100;
    margin: -140px 0 0 -225px;
    text-align: center;
    pointer-events: none;
}


/************************************************************ トップボタン *********************************/

.top-title-link {
    pointer-events: auto;
}
.top-title-link {
    width: 475px;
    height: auto;
    display: inline-block;
    top: 50vh;
    left: 50vw;
    position: absolute;
    z-index: 100;
    margin: 60px 0 0 -225px;
    text-align: center;
    pointer-events: none;
}
.btn-border {
    margin: 15px 0 0;
    padding: 16px 0 13px 70px;
    text-decoration: none!important;
    font-size: 1.2rem;
    line-height: 1;
    color: #555151;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.btn-border {
	display: none;
    position: relative;
}
.btn-border .txt {
	display: inline-block;
    position: relative;
}
.btn-border--title {
    opacity: 1;
    transform: none;
    pointer-events: auto;
}

.btn-border .txt {
    color: #00CCFF;
    font-family: 'Ranchers', cursive;
    letter-spacing:2.5px;
    transition: transform .6s cubic-bezier(.77,0,.175,1),letter-spacing .6s cubic-bezier(.77,0,.175,1);
}

.btn-border:after, 
.btn-border:before {
    content: "";
    display: block;
    position: absolute;
    z-index: auto;
}
.btn-border:after {
    width: 40px;
    height: 1px;
    top: 25px;
    left: 11px;
    background: #fff;
    animation: lines 1.5s cubic-bezier(.77,0,.175,1) infinite forwards;
    transform-origin: left top;
    transition-property: left,width;
    transition-timing-function: cubic-bezier(.77,0,.175,1);
    transition-duration: .6s;
}
.btn-border:after {
    animation: lines 1.5s cubic-bezier(.77,0,.175,1) infinite forwards;
    transform-origin: left top;
}

@keyframes lines{
	0%{transform:scaleX(0);transform-origin:left top}
	25%{transform:none;transform-origin:left top}
	50%{transform:none;transform-origin:right top}
	75%{transform:scaleX(0);transform-origin:right top}
	to{transform:scaleX(0);transform-origin:left top}
}

.btn-border:before {
    width: 22px;
    height: 22px;
    top: 14px;
    left: 0;
    border: 1px solid #00CCFF;
    transition-property: width,height,top,transform;
    transition-timing-function: cubic-bezier(.77,0,.175,1);
    transition-duration: .6s;
}
.btn-border:hover .txt{transform:translate(-35px);letter-spacing:5px;animation:l 1s .7s ease infinite alternate;}
.btn-border:hover:before{width:100%;height:100%;top:0;}
.btn-border:hover:after{width:60px;left:86%}
.btn-border--title:hover .txt{letter-spacing:3px;}
.btn-border--title:hover:after{width:60px;left:93%;}

.txt{letter-spacing:4px;}


/****************** フッター **************************************/

footer {
	width: 100%;
	height: auto;
	margin: 30px 0;
	text-align: center;
	overflow: hidden;
	font-size: 80%;
}
footer .f-menu {
	position: relative;
	margin-bottom: 30px;
	overflow: hidden; 
}
footer .f-menu ul {
	text-align: center;
	margin-left: -10px;
}

footer .f-menu li{
	display: inline-block;
	min-width: 30px;
	margin: 10px 10px;
	letter-spacing: .1em;
}
footer .f-menu li:hover a {
	color: #00CCFF;
}
footer copyright {
	clear: both;
	font-family: 'Ranchers', cursive;
    letter-spacing: .1em;
}
/****************** PVイメージ **************************************/

.pv {
    /* background: url(../img/pv_bg.png) no-repeat; */
    width: 400px;
    height: 255px;
    display: block;
    margin: 0 auto;
    position: relative;
    /*opacity: 0;*/
}
.pv:before {
    /* background: url(../img/start.png) no-repeat; */
    width: 68px;
    height: 68px;
    position: absolute;
    content: '';
    top: 68px;
    left: 130px;
    z-index: 1;
}
.pv:after {
    background: url(../img/pv_title.png) no-repeat ;
    background-size: 233px auto;
    width: 233px;
    height: 89px;
    position: absolute;
    content: '';
    top: 214px;
    left: 74px;
}
.pv.run {
    -webkit-animation: fade-in-up 0.5s 1.2s both;
    animation: fade-in-up 0.5s 1.2s both;
}
.pv #fv-movie {
    width: 368px;
    height: 230px;
    position: absolute;
    top: 15px;
    left: 8px;
    -webkit-transform: rotate(-5.5deg);
    transform: rotate(-5.5deg);
    cursor: pointer;
    pointer-events: none;
}

/****************** サブヘッダーイメージ **************************************/
#particle-canvas {
	width: 100%;
	height: 100vh;
}
#particle-canvas h1 {
	z-index: 1000;
	position: absolute;
    width: 475px;
    height: auto;
    display: inline-block;
    top: 30vh;
    left: 50vw;
    letter-spacing: .1em;
    margin: 0 0 0 -235px;
    text-align: center;
	font-size: 5em;
}
#particle-canvas h1 p {
    width: auto;
    padding: 5px 0 0 5px;
    text-align: center;
    font-size: 2rem;
    letter-spacing: .2em;
	background: 0;
} 

/****************** ロード画面 **************************************/
@keyframes slideInRight {
  from {
    opacity: 0;
    transform: translateX(150px);
  }
  
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.slideInRight {
  animation-name: slideInRight;
  animation-duration: 1s;
  animation-timing-function: ease;
}

/****************** トップページエフェクト **************************************/
a.fig {
	display: block;
	width: 31.33%;
	margin: 1.5% 1%;
	padding: 1% 2.5%;
	float: left;
}
a.fig:nth-child(2) {
	width: 33.33%;
	margin: 1.5% 0;
	border-left: .5px dotted #ccc;
	border-right: .5px dotted #ccc;
}
.fig-title {
	font-size: 120%;
	text-align: center;
	margin-bottom: 20px;
}
.fig-title span {
	font-size: 14px;
	display: block;
}
figure.efect {
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
	position: relative;
	float: left;
	overflow: hidden;
	margin: 10px 1%;
	max-width: 31.3%;
	max-height: 230px;
	width: 100%;
	color: #ffffff;
	text-align: right;
	font-size: 16px;
	background-color: #000000;
	text-transform: uppercase;
}
figure.efect:after {
	position: absolute;
	top: 0;
	bottom: 0;
	left: -30%;
	right: 70%;
	content: '';
	background-color: rgba(0, 0, 0, 0.7);
	-webkit-transform: skew(20deg) translateX(-75%);
	transform: skew(20deg) translateX(-75%);
	-webkit-transition: all 0.35s ease;
	transition: all 0.35s ease;
}
figure.efect * {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all 0.35s ease;
	transition: all 0.35s ease;
}
figure.efect img {
	max-width: 100%;
}
figure.efect figcaption {
	position: absolute;
	top: 0;
	right: 0;
	z-index: 1;
	padding: 20px;
}
figure.efect h3,
figure.efect .links {
	width: 100%;
	margin: 0;
	padding: 0;
}
figure.efect h3 {
	line-height: 1.3em;
	font-weight: 900;
	font-size: 1.5em;
	margin-bottom: 10px;
    text-shadow: 2px 2px 2px #000;
}
figure.efect .links {
	font-size: 0.8em;
	letter-spacing: 3px;
	font-weight: 300;
	margin: 0;
	padding: 0;
}
figure.efect .links li {
	-webkit-transform: translateX(40px);
	transform: translateX(40px);
	opacity: 0;
	list-style: none;
}
figure.efect a {
	padding: 2px 0;
	display: block;
	color: #ffffff;
	text-decoration: none;
	text-shadow: 2px 2px 2px #000;
}
figure.efect a:hover {
	color: #f39c12;
}
figure.efect:hover:after,
figure.efect.hover:after {
	-webkit-transform: skew(20deg) translateX(0%);
 	 transform: skew(20deg) translateX(0%);
}
figure.efect:hover img,
figure.efect.hover img {
	zoom: 1;
	filter: alpha(opacity=50);
	-webkit-opacity: 0.5;
	opacity: 0.5;
}
figure.efect:hover li,
figure.efect.hover li {
	opacity: 1;
	-webkit-transform: translateX(0px);
	transform: translateX(0px);
}
figure.efect:hover li:first-child,
figure.efect.hover li:first-child {
	-webkit-transition-delay: 0.1s;
	transition-delay: 0.1s;
}
figure.efect:hover li:nth-child(2),
figure.efect.hover li:nth-child(2) {
	-webkit-transition-delay: 0.2s;
	transition-delay: 0.2s;
}
figure.efect:hover li:nth-child(3),
figure.efect.hover li:nth-child(3) {
	-webkit-transition-delay: 0.3s;
	transition-delay: 0.3s;
}
figure.efect:hover li:nth-child(4),
figure.efect.hover li:nth-child(4) {
	-webkit-transition-delay: 0.4s;
	transition-delay: 0.4s;
}

/****************** サービスページエフェクト **************************************/

.snip {
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
	float: left;
	position: relative;
	overflow: hidden;
	margin: 10px 1%;
	max-width: 31.3%;
	color: #ffffff;
	text-align: left;
	font-size: 16px;
	background-color: #0c1116;
	line-height: 1.6em;
	font-weight: 200;
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
}
.snip * {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all 0.35s linear;
	transition: all 0.35s linear;
}
.snip *:before,
.snip *:after {
	-webkit-transition: all 0.35s ease;
	transition: all 0.35s ease;
}
.snip img {
	max-width: 100%;
	backface-visibility: hidden;
	vertical-align: top;
}
.snip figcaption {
	position: absolute;
	top: 50%;
	margin: 0 40px;
	padding: 10px 15px;
	-webkit-transform: translate(0%, -50%);
	transform: translate(0%, -50%);
}
.snip figcaption div {
	-webkit-transform: rotate(-90deg);
	transform: rotate(-90deg);
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	opacity: 0.7;
}
.snip figcaption div:before,
.snip figcaption div:after {
	position: absolute;
	content: '';
	background-color: rgba(255, 255, 255, 0.75);
	left: 50%;
	top: 50%;
}
.snip figcaption div:before {
	width: 1px;
	height: 50px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
.snip figcaption div:after {
	height: 1px;
	width: 50px;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
}
.snip p {
	opacity: 0;
	letter-spacing: 1px;
	margin: 0;
}
.snip a {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
}
.snip:hover img,
.snip.hover img {
	zoom: 1;
	filter: alpha(opacity=15);
	-webkit-opacity: 0.15;
	opacity: 0.15;
}
.snip:hover figcaption p,
.snip.hover figcaption p {
	-webkit-transition-delay: 0.6s;
	transition-delay: 0.6s;
	opacity: 1;
}
.snip:hover figcaption .plus1,
.snip.hover figcaption .plus1,
.snip:hover figcaption .plus2,
.snip.hover figcaption .plus2 {
	-webkit-transform: rotate(0);
	transform: rotate(0);
}
.snip:hover figcaption .plus1:before,
.snip.hover figcaption .plus1:before,
.snip:hover figcaption .plus1:after,
.snip.hover figcaption .plus1:after {
	top: 0%;
	left: 0%;
	-webkit-transition-delay: 0.35s;
	transition-delay: 0.35s;
}
.snip:hover figcaption .plus2:before,
.snip.hover figcaption .plus2:before,
.snip:hover figcaption .plus2:after,
.snip.hover figcaption .plus2:after {
	top: 100%;
	left: 100%;
	-webkit-transition-delay: 0.35s;
	transition-delay: 0.35s;
}


/****************** 概要 **************************************/

.company {
    background-color: hsla(0,0%,50%,.1);
    padding: 72px 102px;
    margin-bottom: 160px;
    line-height: 1.9;
    font-size: 16px;
    font-family: 'Kosugi', sans-serif;
    letter-spacing: 0.05em;
}
.company table {
    width: 100%;
    line-height: 1.9;
    text-align: left;
}
.company th {
    width: 35%;
    color: #00CCFF;
	padding: 9px 0;
}
.company td {
	width: 65%;
    padding: 9px 0;
}

/****************** li GUIDELINS **************************************/

ul.cp_list {
	padding:0.5em;
	list-style-type:none;
}
ul.cp_list li {
	position:relative;
	padding: 0em 0.3em 0.2em 1.3em;
}
ul.cp_list li::before,ul.cp_list li::after {
	position: absolute;
	content: '';
	display: inline-block;
}
ul.cp_list li::before {
	top: 12px;
	left: 0;
	width: 13px;
	height: 2px;
	background-color: #00CCFF;
}

/****************** スクロールバー **************************************/

::-webkit-scrollbar{
	width: 5px;
}
::-webkit-scrollbar-track{
	background: #000;
	border: none;
	border-radius: 10px;
}
::-webkit-scrollbar-thumb{
	background: #666;
	border-radius: 10px;
	box-shadow: none;
}


html, body, a {
	cursor: none;
}

#cursor {
	transform: translate(0, 0);
	pointer-events: none;
	position: fixed;
	top: -4px;
	left: -4px;
	width: 8px;
	height: 8px;
	background: rgba(255, 255, 255, 0.5);
	border-radius: 50%;
	z-index: 1010;
	transition: width 0.3s, height 0.3s, top 0.3s, left 0.3s;
}

/*
#cursor.hov_ {
	top: -16px;
	left: -16px;
	width: 32px;
	height: 32px;
	background: rgba(0, 204, 255, 0.75);
}
*/
#cursor:before {
    content: '';
    width: 22px;
    height: 22px;
    border-radius: 22px;
    position: absolute;
	top: -8px;
	left: -8px;
    z-index: 1;
	border: #fff solid 1px;
	border-radius: 50%;
	transition: width 0.3s, height 0.3s, top 0.3s, left 0.3s;
}
#cursor.hov_:before {
    content: '';
    width: 90px;
    height: 90px;
    position: absolute;
	top: -42px;
	left: -42px;
    z-index: 1;
	border: #fff solid 1px;
	border-radius: 50%;
	transition: width 0.6s, height 0.6s, top 0.6s, left 0.6s;
}

.btn {
	display: block;
	width: 160px;
	margin: 40px auto;
	text-align: center;
	font-size: 14px;
	line-height: 1;
}
.btn a {
	display: block;
	color: #fff;
	text-decoration: none;
	padding: 8px;
	background-color: #007adf;
}

/*********** お問い合わせフォーム ************************************************************/
.contact-block {
    overflow: hidden;
    width: 90%;
    margin: 0 auto;
}
.contact-block iframe,
.contact-block iframe body {
	opacity: 0.9;
}

/********** VIDEO SIZE **************************************************************************/

.top {
	height: 350px;
}
/*
.top video {
	min-width:100%;
    min-height:100%;
    position: relative;
    top: 50%;
    transform: translateY(-50%);
}
*/

.top video {
    min-width: 150%;
    position: relative;
    top: 50%;
    left: -25%;
    transform: translateY(-100%);
}


/****************** タブレット・スマートフォン **************************************/

@media all and (max-width:1200px){
	.header__menu-general-list {
	    width: 32.9428989751vw;
	    min-width: 300px;
	    margin-bottom: 9.5168374817vw;
	}
}

@media all and (max-width:992px){
	section {
	    width: auto;
	    margin: 2% 5% 3%;
	}

	/* html, body, a {
		cursor: pointer;
	}*/
	a {
		cursor: pointer;
	}
	#cursor {
		display: none;
	}
}
@media all and (max-width:768px){
	video#mainvideo {
		width: auto;
		height: 100vh;
		left: -90%;
		position: absolute;
	}
	figure.efect, figure.snip {
		margin: 15px 2.5%;
		max-width: 45%;
		max-height: 230px;
	}
}

@media all and (max-width:767px){
	.contents {
	    height: 100vh;
	    display: block;
	    position: absolute;
	    z-index: 0;
	}
	section, #menu ul, footer {
		width: auto;
		float: none;
	}
	h2.titles {
		width: auto;
		margin: 1% 7% 30px;
		float: none;
	}
	h2.ja_title {
	    font-size: 48px;
	    letter-spacing: .03em;
	}
	.block {
	    width: auto;
	    height: auto;
	    overflow: hidden;
	}
	.blocks {
		margin: 1% 5%;
	    overflow: hidden;
	}
	.block100, .block50 {
		width: 90%;
		margin: 1% 5% 8%;
		line-height: 1.6;
		float: none;
	}
	.block25 {
		display: none;
	}
	.block75 {
		width: 90%;
		margin: 1% 5% 5%;
		float: none;
	}
	.company {
	    background-color: hsla(0,0%,80%,.1);
	    padding: 35px 25px;
	    margin: 5%;
	    margin-bottom: 100px;
	}
	.top video {
	    min-width: 100%;
	    height: auto;
	    position: relative;
	    top: 50%;
	    left: 0%;
	    transform: translateY(-50%);
	}
}

@media all and (max-width:480px){
	a#logo {
	    width: 32px;
	    height: 32px;
	    top: 8px;
	    left: 12px;
	}
	#switch {
	    top: 15px;
	    right: 10px;
	}
	#sound {
	    bottom: 15px;
	    left: 10px;
	}
	.page-top {
	    width: 40px;
	    height: 80px;
	}
	#particle-canvas h1 {
		font-size: 3.5em;
	}
	h2 {
		font-size: 40px;
	}
	h2.title-one {
		font-size: 50px;
	}
	.top-visual-title {
	    width: 300px;
	    height: 124px;
	    display: block;
	    top: 50vh;
	    left: 8vw;
	    position: absolute;
	    z-index: 100;
	    margin: -140px 0 0 0;
	    text-align: center;
	    pointer-events: none;
	}
	
	 #menu li {
		width: 70%;
		margin: 1% 15% 8%;
	}
	.top-visual-title .txt {
	    font-size: 1.5rem;
	    margin: 15px;
	}
	.top-title-link {
	    width: 300px;
	    left: 9vw;
	    margin: 10px 0 0 0;
	}
	video {
		width: auto;
	    height: 100vh;
	    position: relative;
	}
	video#mainvideo {
		width: auto;
		height: 100vh;
		left: -90%;
		position: absolute;
	}
	a.fig, a.fig:nth-child(2) {
		width: 95%;
		margin: 3.5% 2.5%;
	}
	a.fig:nth-child(2) {
		padding: 5% 2.5%;
		border-top: .5px dotted #ccc;
		border-bottom: .5px dotted #ccc;
		border-left: none;
		border-right: none;
	}
	figure.efect, figure.snip {
		margin: 20px 5%;
		max-width: 90%;
		max-height: 230px;
	}
	.pv {
	    height: 230px;
	}
	.pv:after {
	    top: 190px;
	    left: 65px;
	}
	.pv #fv-movie {
	    width: 310px;
	    height: 210px;
	}
}
