@charset "UTF-8";

/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*Reset*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
a,a:active,a:focus,a:hover{outline:0;text-decoration:none}[hidden],template{display:none}html{font-family:"游ゴシック","Yu Gothic",YuGothic,"ヒラギノ角ゴシック Pro","Hiragino Kaku Gothic Pro","メイリオ",Meiryo,Osaka,"ＭＳ Ｐゴシック","MS PGothic",sans-serif;font-size:100%;font-weight:500;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}a{background:0 0}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:700}dfn{font-style:italic}img{border:0}svg:not(:root){overflow:hidden}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}button,input,select,textarea{font-family:inherit;}button,html input[type=button],input[type=reset],input[type=text],input[type=submit],button[type=submit],textarea{border-radius:0;-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=search]{-webkit-appearance:textfield;box-sizing:content-box}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}

html { box-sizing: border-box; } *, *:before, *:after { box-sizing: inherit; }

/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/* Normalize */
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
h3,pre{margin:1em 0}article,aside,details,figcaption,figure,footer,header,hgroup,main,nav,section,summary{display:block}audio,canvas,video{display:inline-block;*display:inline;*zoom:1}audio:not([controls]){display:none;height:0}body,figure,form{margin:0}h1{font-size:2em;margin:.67em 0}h2{font-size:1.5em;margin:.83em 0}h3{font-size:1.17em}h4{font-size:1em;margin:1.33em 0}h5{font-size:.83em;margin:1.67em 0}h6{font-size:.67em;margin:2.33em 0}blockquote{margin:1em 40px}hr{box-sizing:content-box;height:0}mark{background:#ff0;color:#000}pre{white-space:pre;white-space:pre-wrap;word-wrap:break-word}code,kbd,pre,samp{font-family:monospace,serif;_font-family:'courier new',monospace;font-size:1em}q{quotes:none}q:after,q:before{content:'';content:none}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sup{top:-.5em;bottom:-.25em}dl,menu,ol,ul{margin:0;padding:0}dd{margin:0}nav ol,nav ul{list-style:none}img{border:0;-ms-interpolation-mode:bicubic}legend{border:0;padding:0;white-space:normal;*margin-left:-7px}button,input,select,textarea{font-size:100%;margin:0;vertical-align:baseline;*vertical-align:middle}button,input{line-height:normal}button,select{text-transform:none}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer;*overflow:visible}button[disabled],html input[disabled]{cursor:default}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0;*height:13px;*width:13px}input[type=search]{-webkit-appearance:textfield;box-sizing:content-box}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}textarea{overflow:auto;vertical-align:top;resize:vertical}table{border-collapse:collapse;border-spacing:0}button,html,input,select,textarea{color:#3e3e3e;font-weight:500;}html{font-size:16px;line-height:1.4;height:100%}::-moz-selection{background:rgba(3, 169, 244, 0.23);text-shadow:none}::selection{background:rgba(3, 169, 244, 0.23);text-shadow:none}audio,canvas,img,video{vertical-align:middle}fieldset{border:0;margin:0;padding:0}.hidden{display:none!important;visibility:hidden}.clearfix{*zoom:1}.clearfix:after,.clearfix:before{display:table;content:" "}.clearfix:after{clear:both}body,html{font-smoothing:antialiased;font-smooth:always;filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src='data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMC1jMDYwIDYxLjEzNDc3NywgMjAxMC8wMi8xMi0xNzozMjowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNSBNYWNpbnRvc2giIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6OTJBQkFGRUZFOTIyMTFFMEJDRDNEQzkxOTVGOTNBODAiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6OTJBQkFGRjBFOTIyMTFFMEJDRDNEQzkxOTVGOTNBODAiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDo5MkFCQUZFREU5MjIxMUUwQkNEM0RDOTE5NUY5M0E4MCIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDo5MkFCQUZFRUU5MjIxMUUwQkNEM0RDOTE5NUY5M0E4MCIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/PtrV+I8AAAAQSURBVHjaYvj//z8DQIABAAj8Av7bok0WAAAAAElFTkSuQmCC', sizingMethod=crop);zoom:1}

/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*Fonts*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
@font-face {
    font-family: '$century';
    src: url("../css/fonts/gothic.eot") format("eot"), url("../css/fonts/gothic.woff") format("woff"), url("../css/fonts/gothic.ttf") format("truetype");
  }
  @font-face {
    font-family: '$helvetica';
    src: url("../css/fonts/HelveticaBd75.eot") format("eot"), url("../css/fonts/HelveticaBd75.woff") format("woff"), url("../css/fonts/HelveticaBd75.woff2") format("woff2"), url("../css/fonts/HelveticaBd75.ttf") format("truetype");
  }
  @font-face {
    font-family: 'b-crew';
    src: url("../css/fonts/b-crew.eot?8td4ct");
    src: url("../css/fonts/b-crew.eot?8td4ct#iefix") format("embedded-opentype"), url("../css/fonts/b-crew.ttf?8td4ct") format("truetype"), url("../css/fonts/b-crew.woff?8td4ct") format("woff"), url("../css/fonts/b-crew.svg?8td4ct#b-crew") format("svg");
    font-weight: normal;
    font-style: normal;
  }
  [class^="icon-"], [class*=" icon-"] {
    /* use !important to prevent issues with browser extensions that change fonts */
    font-family: 'b-crew' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    /* Better Font Rendering =========== */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  .icon-paper-plane:before {content: "\e900";}
  .icon-phone:before {content: "\e901";}
  .icon-line:before {content: "\e90a";}
  .icon-mail:before {content: "\e905";}
  .icon-open:before {content: "\e89e";}
  .icon-google-plus:before {content: "\ea8b";}
  .icon-facebook:before {content: "\ea90";}
  .icon-instagram:before {content: "\ea92";}
  .icon-twitter:before {content: "\ea96";}

/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*Animation*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
@-webkit-keyframes wave {
    0% {-webkit-transform: translateY(0);transform: translateY(0); }
    50% { -webkit-transform: translateY(-40%);transform: translateY(-40%); }
    100% { -webkit-transform: translateY(0);transform: translateY(0); }
}
@keyframes wave {
    0% { -webkit-transform: translateY(0);transform: translateY(0); }
    50% { -webkit-transform: translateY(-40%);transform: translateY(-40%); }
    100% { -webkit-transform: translateY(0);transform: translateY(0); }
}
@-webkit-keyframes fadeOut {
    0% { opacity: 1; }
    100% { opacity: 0; }
}
@keyframes fadeOut {
    0% { opacity: 1; }
    100% { opacity: 0; }
}
@-webkit-keyframes flash {
    0% { opacity: 1; }
    100% { opacity: 0; }
}
@keyframes flash {
    0% { opacity: 1; }
    100% { opacity: 0; }
}
@-webkit-keyframes LoadingOut {
    0% { opacity: 1; }
    100% { opacity: 0;visibility: hidden; }
}
@keyframes LoadingOut {
    0% { opacity: 1; }
    100% { opacity: 0;visibility: hidden; }
}

/*Slider用*/
@-webkit-keyframes imageAnimation {
    0% { opacity: 0; animation-timing-function: ease-in; }
    8% { opacity: 1; animation-timing-function: ease-out; }
    17% { opacity: 1 }
    25% { opacity: 0 }
    100% { opacity: 0 }
}
@keyframes imageAnimation {
    0% { opacity: 0; animation-timing-function: ease-in; }
    8% { opacity: 1; animation-timing-function: ease-out; }
    17% { opacity: 1 }
    25% { opacity: 0 }
    100% { opacity: 0 }
}

/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*Loading*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
.loader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    z-index: 999;
    background-color: #111111;
    /* -webkit-animation: LoadingOut 1s ease 3s forwards;
    animation: LoadingOut 1s ease 3s forwards; */
}

.loader .loader-inner {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 80%;
    max-width: 440px;
    -webkit-transform: translateX(-50%) translateY(-50%) translateZ(0);
    transform: translateX(-50%) translateY(-50%) translateZ(0);
    overflow: hidden;
}

/*IE hack*/
.android4 .path {
    stroke-dashoffset: 0;
    fill: #ffffff;
}

@media all and (-ms-high-contrast: none) {
    .path {
        stroke-dashoffset: 0!important;
        fill: #ffffff!important;
    }
}
@media all and (-ms-high-contrast: none) {
    *::-ms-backdrop, .path {
        stroke-dashoffset: 0!important;
        fill: #ffffff!important;
    }
}
/*IE hack end*/


/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*Common-parts*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
body, html {
    width: 100%;
    height: 100%;
}

body {
    background: #ffffff;
    color: #000000;
    font-size: 15px;
    line-height: 1.8;
}

/*scroll bar*/
body {
    scrollbar-base-color: #000;/* IE用スクロールバーカラー */
}
.parsonal-inner {
    scrollbar-base-color:#eeeeee;/* IE用スクロールバーカラー */
}
/* スクロールバー幅 */
body::-webkit-scrollbar, .parsonal-inner::-webkit-scrollbar {
    width:10px;
    height: auto;
}
/* 背景 */
body::-webkit-scrollbar-track{
    background-color: #000;
}
.parsonal-inner::-webkit-scrollbar-track {
    background: #eeeeee;
}
/* スクロールバー本体 */
body::-webkit-scrollbar-thumb {
    background:#fff;
}
.parsonal-inner::-webkit-scrollbar-thumb{
    background: #bbbbbb;
}

.br-1, .br-2 {
    display: none;
}
.pc-br {
    display: block;
}

.img-svg {
    width: 100%;
}

.cm-site-links {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
    -moz-box-pack:justify;
    -ms-box-pack:justify;
    box-pack:justify;
    flex-pack:justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    list-style: none;
}

.site-link {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    width: 45%;
}
.site-link a {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    position: relative;
    width: 100%;
    padding: 15%;
    background-color: rgba(0, 0, 0, 0.1);
    color: #ffffff;
    outline: none;
    overflow: hidden;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    text-align: center;
}

.site-link_svg {
    width: 100%;
    max-height: 150px;
}

/*firefox hack*/
@-moz-document url-prefix(){
    .site-link a {
        padding: 60px 15%;
    }
}

.site-link a::before, .site-link a::after {
    position: absolute;
    display: block;
    content: '';
    width: 100%;
    height: 100%;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
}
.site-link a::before {
    top: 0;
    left: 0;
    border-top: 8px solid #ffffff;
    border-left: 8px solid #ffffff;
}
.site-link a::after {
    right: 0;
    bottom: 0;
    border-right: 8px solid #ffffff;
    border-bottom: 8px solid #ffffff;
}
.site-link a:hover {
    background-color: rgba(0, 0, 0, 0.6);
    -webkit-transition: all 0.7s;
    transition: all 0.7s;
}
.site-link a:hover::before, .site-link a:hover::after {
    width: 0;
    height: 0;
    opacity: 0;
    -webkit-transition: all 0.7s;
    transition: all 0.7s;
}

.site-link img {
    width: 100%;
    height: auto;
}

.hv-content {
    position: relative;
    overflow: hidden;
    cursor: pointer;
}
.hv-content a {
    color: #ffffff;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}
.hv-content a:hover {
    color: #00b2bd;
}

.hv-content img {
    position: relative;
    display: block;
}

.hv-content figcaption {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -moz-box-pack:justify;
    -ms-box-pack:justify;
    box-pack:justify;
    flex-pack:justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 1em;
    background-color: rgba(0, 0, 0, 0.6);
    color: #ffffff;
    font-size: 1.25em;
    -webkit-transition: -webkit-transform 0.35s;
    transition: -webkit-transform 0.35s;
    transition: transform 0.35s;
    transition: transform 0.35s, -webkit-transform 0.35s;
    -webkit-transform: translate3d(0, 110%, 0);
    transform: translate3d(0, 110%, 0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    cursor: default;
}

.hv-content-title, .hv-content-links li {
    -webkit-transform: translate3d(0, 200%, 0);
    transform: translate3d(0, 200%, 0);
    -webkit-transition: -webkit-transform 0.35s;
    transition: -webkit-transform 0.35s;
    transition: transform 0.35s;
    transition: transform 0.35s, -webkit-transform 0.35s;
}

.hv-content-title {
    margin: 0;
    font-family: '$century';
    text-align: left;
}

.hv-content-links {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    list-style: none;
}
.hv-content-links li {
    margin: 0 0.5em;
    font-size: 1.5em;
}

.hv-content:hover figcaption {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    top: auto;
    bottom: 0;
}
.hv-content:hover .hv-content-title, .hv-content:hover .hv-content-links li {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}
.hv-content:hover .hv-content-title {
    -webkit-transition-delay: 0.05s;
    transition-delay: 0.05s;
}
.hv-content:hover .hv-content-links li:nth-of-type(1) {
    -webkit-transition-delay: 0.1s;
    transition-delay: 0.1s;
}
.hv-content:hover .hv-content-links li:nth-of-type(2) {
    -webkit-transition-delay: 0.15s;
    transition-delay: 0.15s;
}
.hv-content:hover .hv-content-links li:nth-of-type(3) {
    -webkit-transition-delay: 0.2s;
    transition-delay: 0.2s;
}

.cm-link-list {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: box;
    display: flex;
    width: 100%;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
}

.cm-link {
    position: relative;
    display: block;
    overflow: hidden;
    width: 40%;
    margin: 0 1rem;
    padding: 20px;
    background-color: #111111;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border: 1px solid currentColor;
    color: #ffffff;
    -webkit-transition: 0.4s ease-in-out;
    transition: 0.4s ease-in-out;
    font-family: '$century';
    font-size: 20px;
}
.cm-link:hover {
    outline-width: 0;
}
.cm-link:hover::before {
    -webkit-transform: translateX(0);
    transform: translateX(0);
}
.cm-link::before {
    position: absolute;
    top: 0;
    right: -50px;
    bottom: 0;
    left: 0;
    border-right: 50px solid transparent;
    border-bottom: 150px solid #00b2bd;
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
    -webkit-transition: 0.5s ease-in-out;
    transition: 0.5s ease-in-out;
    content: '';
}

.cm-link-inner {
    position: relative;
    padding-left: 20px;
    z-index: 1;
}
.cm-link-inner::before {
    position: absolute;
    top: 50%;
    left: 0;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 6.5px 0 6.5px 10px;
    border-color: transparent transparent transparent #ffffff;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: '';
}
.cm-link-inner .link-description {
    display: block;
    font-size: 16px;
}

.sns-links {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    padding: 6% 0;
    list-style: none;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
}
.sns-links li {
    margin: 0 2%;
    font-size: 2.5em;
}
.sns-links a {
    color: #111111;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}
.sns-links a:hover {
    color: #00b2bd;
}

/*Section-title animation*/
.js-type-on {
    opacity: 0;
}
.js-type-cursor {
    display: block;
    position: absolute;
    height: 100%;
    top: 0;
    right: -5px;
    width: 2px;
    /* Change colour of Cursor Here */
    background-color: white;
    z-index: 1;
    -webkit-animation: flash 0.5s none infinite alternate;
    animation: flash 0.5s none infinite alternate;
}

.mdn_no-js .js-type-on {
    opacity: 1;
}
.mdn_no-js .js-type-cursor {
    display: none;
}

/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*Header-nav*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
.header-menu {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -moz-box-pack:justify;
    -ms-box-pack:justify;
    -webkit-box-pack: justify;
    box-pack: justify;
    -webkit-flex-pack: justify;
    flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background-color: rgba(0, 0, 0, 0.9);
    text-align: center;
    z-index: 99;
    -webkit-transition: 0.5s;
    transition: 0.5s;
}

.js-hide {
    bottom: -100%;
}

.header-menu-inner {
    padding: 0 5%;
}

.menu-trigger {
    display: none;
}

.header-menu-nav .primary-nav-links {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    margin: 0;
    padding: 0;
    font-size: 15px;
}
.header-menu-nav .primary-nav-links li {
    display: block;
    margin-right: 1px;
}
.header-menu-nav .primary-nav-links .tocall {
    display: none;
}
.header-menu-nav .primary-nav-links li a {
    display: block;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
    width: 100%;
    padding: 30px 40px;
    color: #ffffff;
    font-family: '$century';
    letter-spacing: 0.1em;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-animation-duration: 0.5s;
    animation-duration: 0.5s;
}
.header-menu-nav .primary-nav-links li a:after {
    position: absolute;
    bottom: 20%;
    left: 50%;
    overflow: hidden;
    -webkit-transition: 0.5s;
    transition: 0.5s;
    border-bottom: 1px solid #ffffff;
    width: 0;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    content: '';
}

.header-menu-nav .primary-nav-links li a.active::after, .header-menu-nav .primary-nav-links li a:hover::after {
    width: 50%;
    height: 1px;
}

.header-menu-inner .main-logo {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    margin: 0;
}
.header-menu-inner .main-logo a {
    display: block;
}
.header-menu-inner .main-logo .header-logo-svg {
    display: block;
    width: 97px;
    height: 28.55px;
}

/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*Common-parts*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
.section-title {
    position: absolute;
    width: 100%;
    margin: 0;
    padding: 30px 0;
    background-color: rgba(0, 0, 0, 0.6);
    color: #ffffff;
    text-align: left;
    letter-spacing: 0.05em;
    -webkit-transform: translateY(-100%);
    transform: translateY(-100%);
}
.section-title-inner {
    display: block;
    width: 1000px;
    margin: 0 auto;
}
.section-title-content {
    margin: 0;
    font-family: '$century';
    font-size: 32px;
    font-weight: 400;
}

.section-subtitle {
    margin-bottom: 60px;
    padding-bottom: 30px;
    border-bottom: 1px solid #88888b;
}

.section-content {
    width: 1000px;
    margin: 0 auto;
    padding: 5.5em 40px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.canvas-contents {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
}

.back-particle {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background-color: #ffffff;
    z-index: -999;
}
.particles-js-canvas-el {
    position: absolute!important;
    top: 0;
    left: 0;
    -webkit-backface-visibility: hidden;
}

.main {
    position: relative;
    background-color: #ffffff;
    text-align: center;
    z-index: 15;
}

.js-fadein {
    -webkit-transition: opacity 0.8s linear;
    transition: opacity 0.8s linear;
}

.hidden {
    overflow: hidden;
}

.fadein {
    opacity: 0;
}

.main-container {
    position: relative;
    overflow: hidden;
    z-index: 1;
}

.section {
  width: 100%;
}


/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*Slider*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
.introduction {
    position: relative;
    width: 100%;
    height: 100%;
    background-color: #000;
    overflow: hidden;
    z-index: 1;
}
.introduction::before {
    position: fixed;
    width: 100%;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.3);
    content: '';
    z-index: 0;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
}

.slider-sell {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    z-index: -1;
    opacity: 0;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    -webkit-animation: imageAnimation 36s linear infinite 0s;
    animation: imageAnimation 36s linear infinite 0s;
}
.mdn_no-cssanimations .slider-sell{
    opacity: 1;
}

.slider-2 {
    background: url('../img/slider-2.jpg') no-repeat center center;
    background-size: cover;
}
.slider-3 {
    background: url('../img/slider-3.jpg') no-repeat center center;
    background-size: cover;
    -webkit-animation-delay: 6s;
    animation-delay: 6s;
}
.slider-4 {
    background: url('../img/slider-4.jpg') no-repeat center center;
    background-size: cover;
    -webkit-animation-delay: 12s;
    animation-delay: 12s;
}
.slider-5 {
    background: url('../img/slider-5.jpg') no-repeat center center;
    background-size: cover;
    -webkit-animation-delay: 18s;
    animation-delay: 18s;
}
.slider-7 {
    background: url('../img/slider-7.jpg') no-repeat center bottom;
    background-size: cover;
    -webkit-animation-delay: 24s;
    animation-delay: 24s;
}
.slider-8 {
    background: url('../img/slider-8.jpg') no-repeat center center;
    background-size: cover;
    -webkit-animation-delay: 30s;
    animation-delay: 30s;
}

.android .introduction::after {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: url('../img/android-catch.jpg') no-repeat center bottom;
    background-size: cover;
    content: '';
    z-index: -1;
}
.android .slider-sell {
    display: none;
    visibility: hidden;
}

/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*Catch*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
.catch {
    position: relative;
    display: block;
    width: 100%;
    height: 100vh;
}

.catch .catch-content {
    z-index: 12;
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    text-align: center;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

.catch .catch-logo {
    max-width: 80%;
    margin: 0 auto;
}
.catch .catch-logo img {
    width: 100%;
    max-width: 440px;
}

.catch .scrollnav {
    position: absolute;
    bottom: 10%;
    left: 50%;
    -webkit-transition: opacity .1s ease-in-out;
    transition: opacity .1s ease-in-out;
    -webkit-transform: translate3d(-50%, 0, 0);
    transform: translate3d(-50%, 0, 0);
    opacity: 1;
    z-index: 12;
}
.catch .scrollnav:hover {
    opacity: 0.7;
}
.catch .scrollnav img {
    display: block;
    width: 50%;
    max-width: 50px;
    margin: 10px auto 0 auto;
    padding-top: 10px;
    -webkit-animation: wave 3s ease-in-out infinite;
    animation: wave 3s ease-in-out infinite;
}

/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*Section-title back*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/

.news::after, .about::after, .project::after, .company::after {
    display: block;
    width: 100%;
    height: 600px;
    content: '';
}

.news::after {
    background-image: url("../img/common/news_back.jpg");
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
    background-repeat: no-repeat;
    background-attachment: fixed;
}
.about::after {
    background-image: url("../img/common/about_back.jpg");
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
    background-repeat: no-repeat;
    background-attachment: fixed;
}
.project::after {
    background-image: url("../img/common/project_back.jpg");
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
    background-repeat: no-repeat;
    background-attachment: fixed;
}
.company::after {
    background-image: url("../img/common/company_back.jpg");
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
    background-repeat: no-repeat;
    background-attachment: fixed;
}

/* Hack for iPhone*/
.iPhone .news::after, .iPhone .about::after, .iPhone .project::after, .iPhone .company::after, .iPad .news::after, .iPad .about::after, .iPad .project::after, .iPad .company::after {
    background-attachment: initial;
}

/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*News*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/

.news .no-items {
    width: 100%;
    color: #88888b;
    font-size: 1.5em;
    text-align: center;
}

.news .section-content {
    padding: 5.5em 0;
}

.news-article-list {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: box;
    display: flex;
    width: 100%;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.news-article-link {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: box;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 31.3%;
    margin: 0.5em 1%;
    padding: 0;
    background-color: #ffffff;
    border: 1px solid #bbbbbb;
}

.news-article-thumbnail {
    display: block;
    width: 100%;
    height: 160px;
    background-size: cover;
    background-position: center center;
}

.news-article-info {
    width: 100%;
    height: 100%;
    padding: 1.3em;
}

.news-article-time {
    display: block;
    color: #111111;
    font-size: 14px;
}

.news-article-title {
    width: 100%;
    margin: 0.5em 0;
    color: #111111;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.news-article-link:hover .news-article-title {
    color: #00b2bd;
}

.group-label {
    width: 100%;
    margin: 0;
    color: #88888b;
}

.moreinfo {
    margin: 0;
    padding: 3em 0;
    color: #88888b;
    font-size: 16px;
    font-family: '$century';
}
.moreinfo img {
    display: block;
    width: 24px;
    margin: 10px auto 0 auto;
    padding-top: 10px;
    -webkit-animation: wave 3s ease-in-out infinite;
    animation: wave 3s ease-in-out infinite;
}

/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*About*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
.about .ceo-message h3 {
    color: #88888b;
    font-size: 40px;
    font-family: '$century';
}
.about .section-content {
    padding: 6em 40px 7em 40px;
}


/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*Concept*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
.concept {
    position: relative;
    min-height: 20vh;
    margin-bottom: 30%;
}

.concept-inner {
    position: relative;
    height: 100vh;
}

.concept-text {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    margin: 0;
    padding: 10% 0;
    color: #ffffff;
    font-size: 56px;
    font-family: '$century';
    font-weight: 400;
    text-align: center;
    -webkit-transform: translateX(-50%) translateY(-50%);
    transform: translateX(-50%) translateY(-50%);
}

.concept-text-s {
    display: block;
    font-size: 30px;
}
.concept-text-s::before, .concept-text-s::after {
    padding: 0.5em;
    content: '-';
}


/* IE11だけに適用 */
@media all and (-ms-high-contrast: none) {
}

/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*Project*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
.project .blixzy {
    position: relative;
}
.project .blixzy::after {
    position: absolute;
    bottom: 0;
    left: -50%;
    width: 200vw;
    border-bottom: 1px solid #bbbbbb;
    content: '';
}

.project .blixzy-img, .project .official-img {
    width: 100%;
    height: auto;
}

.project .blixzy-logo, .project .official-logo {
    height: 5em;
}

.project .hv-content {
    margin-bottom: 60px;
}

.project .project-description dt {
    margin-bottom: 50px;
}
.project .project-concept {
    margin-bottom: 30px;
    font-size: 20px;
    font-weight: 700;
}
.project .project-content {
    text-align: left;
}
.project .official .project-content {
    text-align: center;
}
.project .blixzy .project-content {
    margin-bottom: 30px;
}
.project .blixzy .map-container {
    padding: 20px 0;
    border-top: 1px dotted #88888b;
    border-bottom: 1px dotted #88888b;
}
.project .blixzy .map-address {
    margin-bottom: 1.5em;
    text-align: left;
}
.project .blixzy .map-address a {
    text-decoration: underline;
}
.project .blixzy .map-address a:hover {
    text-decoration: none;
}
.project .blixzy .map-address dt, .project .blixzy .map-address dd {
    margin-bottom: 0.8em;
}
.project .official .project-description dt span {
    display: block;
    padding-top: 1em;
    font-size: 20px;
    font-weight: 700;
}

/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*Company*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
.company .company-data {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    padding: 0 20px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -moz-box-pack:justify;
    -ms-box-pack:justify;
    box-pack:justify;
    flex-pack:justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    line-height: 1.6;
}
.company .company-data-inner {
    width: 48%;
}
.company .company-data-inner .data {
    margin-bottom: 3em;
    text-align: left;
}
.company .company-data-inner .data dt {
    margin-bottom: 0.5em;
}
.company .company-data-inner .data dt:before {
    content: '■';
}
.company .company-data-inner .data dd {
    margin-left: 2em;
}
.company .company-data-inner .data ul li {
    margin-bottom: 0.5em;
}
.company .company-data-inner .company-name dd {
    font-weight: 700;
}
.company .company-data-inner .company-address dd ul {
    list-style: none;
}

/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*Cotact*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
.contact .contact-start-message {
    margin-bottom: 30px;
}

.contact .form_area {
    width: 70%;
    margin: 0 auto;
}

.contact .error {
    color: red !important;
}

.contact .caution-text {
    text-align: center;
    font-size: 14px;
}

.contact .footer-form {
    margin: 0 auto;
    padding: 0;
    text-align: left;
}

.contact .footer-form textarea, .contact .footer-form input, .contact .footer-form select {
    padding: 10px;
    background-color: #eeeeee;
    border: 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.contact .footer-form input {
    width: 100%;
}

.contact .footer-form input[name="age"] {
    min-width: 130px;
    width: 27%;
}

.contact .footer-form textarea {
    width: 100%;
}

.contact .footer-form .form_input {
    display: table;
    width: 100%;
    margin: 1.5em 0;
    padding: 0;
}

.contact .footer-form dt, .contact .footer-form dd {
    display: block;
}

.contact .footer-form dd {
    margin: 0;
}

.contact .footer-form .mail-caution {
    color: #88888b;
    font-size: 12px;
}

.contact .parsonal {
    display: block;
    margin: 25px 0;
}
.contact .parsonal .parsonal-inner {
    height: 150px;
    margin-bottom: 1.5em;
    color: #7a7a7a;
    font-size: 13px;
    line-height: 1.4;
    overflow-y: scroll;
}
.contact .parsonal dt {
    width: auto;
    margin-bottom: 1em;
    font-weight: 700;
    text-align: left;
}
.contact .parsonal dd {
    margin-bottom: 1em;
}
.contact .parsonal .parsonal-address .address-content dd {
    margin-bottom: 0;
}
.contact .parsonal .checkboxRequired {
    text-align: center;
}
.contact .parsonal .checkboxRequired .input {
    width: auto;
}

.contact .footer-form .form_button {
    padding: 0;
    text-align: center;
}

.contact .footer-form .form_button input[type="button"], .contact .footer-form .form_button button[type="submit"], .contact .footer-form .form_button button[class="form_before"] {
    max-width: 400px;
    background: #88888b;
    border: 1px solid #88888b;
    color: #ffffff;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.contact .footer-form .form_button input[type="button"]:hover, .contact .footer-form .form_button button[type="submit"]:hover, .contact .footer-form .form_button button[class="form_before"]:hover {
    background: #ffffff;
    color: #88888b;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.contact .footer-form .form_button #confirmation {
    width: 230px;
    padding: 10px;
}

.contact .footer-form .form_button #form_back {
    background: #b8b8b8;
    width: 30%;
    max-width: 150px;
    border-color: #b8b8b8;
}

.contact .footer-form .form_button #form_back:hover {
    background: #ffffff;
    color: #b8b8b8;
}

.contact .footer-form .form_button #send {
    width: 50%;
    max-width: 230px;
    margin: 0 0 0 10px;
    padding: 10px;
    border: 1px solid #88888b;
    text-shadow: none;
    /* font-size: 16px; */
    font-weight: normal;
    line-height: normal;
    -webkit-box-shadow: none;
    box-shadow: none;
    vertical-align: top;
}

@media all and (-ms-high-contrast: none) {
    .contact .footer-form dt {
        vertical-align: middle;
    }
}

/* IE11だけに適用 */
@media all and (-ms-high-contrast: none) {
    *::-ms-backdrop,
    .contact .footer-form dt {
        vertical-align: middle;
    }
}
.hiring-notice {
    text-align: left;
    display: inline-block;
    position: absolute;
    top: 28px;
    left: 406px;
}

.map {
    overflow: hidden;
}
.map .infowin {
    padding: 20px;
    color: #111111;
    font-family: "游ゴシック", "Yu Gothic", YuGothic, "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-weight: 500;
}
.map .infowin p {
    margin-bottom: 5px;
    line-height: 1.6;
}
.map .infowin a {
    text-decoration: underline;
}
.map .infowin a:hover {
    text-decoration: none;
}

/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*Error*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
.error-bg {
    position: fixed;
    width: 100%;
    height: 100vh;
    background: url('../img/common/bg-error.jpg') center bottom no-repeat;
    background-size: cover;
}
.error-bg::after {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.3);
    content: '';
}
.error-page .main-footer {
    background: none;
}
.error-content {
    min-height: 100vh;
}
.error-content-inner {
    position: absolute;
    top: 50%;
    width: 100%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    color: #ffffff;
    text-align: center;
}
.error-title {
    margin: 0 0 0.5em 0;
    font-family: '$century';
    font-size: 56px;
    font-weight: 400;
    line-height: 1;
}
.error-message {
    margin: 0 0 0.5em 0;
    font-family: '$century';
    font-size: 30px;
    line-height: 1;
}
.error-message-ja {
    font-size: 18px;
}

/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
/*Footer*/
/*+~+~+~+~+~+~+~+~+~+~~+~+~+~+~+~+~+~+~+~+~+~+~+~+~+~++~~++*/
.main-footer {
    position: relative;
    padding-top: 120px;
    padding-bottom: 120px;
     background-image: url("../img/common/bg-footer.jpg");
    background-position: center bottom;
    -webkit-background-size: cover;
    background-size: cover;
    background-repeat: no-repeat;
    background-attachment: fixed;
    z-index: 1;
    overflow: hidden;
}

.iPhone .main-footer, .iPad .main-footer {
    background-attachment: initial;
}

.main-footer-inner {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto 50px auto;
    color: #ffffff;
}
.main-footer-inner .cm-site-links {
    margin-bottom: 100px;
}
.main-footer-inner .footer-nav {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
    list-style: none;
    font-family: '$century';
    font-size: 15px;
}
.main-footer-inner .footer-nav li {
    margin: 0;
}
.main-footer-inner .footer-nav li a {
    display: block;
    position: relative;
    padding: 30px 40px;
    color: #ffffff;
}
.main-footer-inner .footer-nav li a:after {
    position: absolute;
    bottom: 20%;
    left: 50%;
    width: 0;
    border-bottom: 1px solid #ffffff;
    overflow: hidden;
    -webkit-transition: 0.5s;
    transition: 0.5s;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    content: '';
}
.main-footer-inner .footer-nav li a:active::after, .main-footer-inner .footer-nav li a:hover::after {
    width: 50%;
    height: 1px;
}

.main-footer .copyright {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
    padding: 30px 0;
    color: #ffffff;
    font-size: 15px;
    text-align: center;
}

.main-footer .pagetop {
    position: absolute;
    right: 10%;
    bottom: 10%;
    text-align: center;
}
.main-footer .pagetop img {
    position: relative;
    width: 40px;
    height: 100%;
    margin-bottom: 10px;
}
.main-footer .pagetop span {
    display: block;
    position: relative;
    color: #ffffff;
    font-size: 14px;
    font-family: '$century';
    line-height: 1.1em;
    letter-spacing: 0.1em;
}

.pagetop, .scrollnav {
    cursor: pointer;
}

