@charset "UTF-8";
/**
 * YUI 3.5.0 - reset.css (http://developer.yahoo.com/yui/3/cssreset/)
 * http://cssreset.com
 * Copyright 2012 Yahoo! Inc. All rights reserved.
 * http://yuilibrary.com/license/
 */
html {
  color: #000;
  background: #FFF; }

/*
	TODO remove settings on BODY since we can't namespace it.
*/
/*
	TODO test putting a class on HEAD.
		- Fails on FF.
*/
body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
code,
form,
fieldset,
legend,
input,
textarea,
p,
blockquote,
th,
td {
  margin: 0;
  padding: 0; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

fieldset,
img {
  border: 0; }

/*
	TODO think about hanlding inheritence differently, maybe letting IE6 fail a bit...
*/
address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
  font-style: normal;
  font-weight: normal; }

ol,
ul {
  list-style: none; }

caption,
th {
  text-align: left; }

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%;
  font-weight: bold; }

q:before,
q:after {
  content: ''; }

abbr,
acronym {
  border: 0;
  font-variant: normal; }

/* to preserve line-height and selector appearance */
sup {
  vertical-align: text-top; }

sub {
  vertical-align: text-bottom; }

input,
textarea,
select {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit; }

/*to enable resizing for IE*/
input,
textarea,
select {
  *font-size: 100%; }

/*because legend doesn't inherit in IE */
legend {
  color: #000; }

/* YUI CSS Detection Stamp */
#yui3-css-stamp.cssreset {
  display: none; }

/* original written by sasa */
h1, h2, h3, h4, h5, h6, a, button, div, input, li, p, span, textarea, th, td {
  font-family: Lucida grande, Lucida Sans Unicode, verdana,"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 1px; }

h1, h2, h3, h4, h5, h6, a, button, div, input, li, p, textarea, th, td {
  color: #000; }

a, button, div, input, li, p, span, textarea, th, td {
  font-size: 14px; }

a {
  color: #0044cc;
  cursor: pointer;
  text-decoration: underline; }

button {
  cursor: pointer; }

div.page-top {
  background: #333;
  position: fixed;
  display: none;
  right: 10px;
  bottom: 10px; }
  div.page-top a {
    color: #fff;
    padding: 7px;
    text-decoration: none;
    display: block;
    text-align: center;
    background-color: #aaa;
    font-size: 12px; }
    div.page-top a img {
      display: block;
      margin: 0 auto 10px;
      width: 70%; }

footer {
  background: #000; }
  footer a, footer div, footer p {
    color: #fff; }
  footer div.copyright {
    background: #333;
    color: #b3b3b3;
    text-align: center;
    padding: 20px 0;
    font-size: 10px; }
  footer div.address {
    margin: 15px 0;
    text-align: center; }
  footer div.footer-links {
    padding: 30px 0;
    text-align: center; }
    footer div.footer-links a {
      font-size: 11px;
      margin: 0 10px; }
      footer div.footer-links a:before {
        background: url("../images/icon-arrow02.png") 0 0 no-repeat;
        background-size: auto 14px;
        content: "";
        display: inline-block;
        margin-right: 4px;
        height: 12px;
        width: 12px; }
  footer a.company-name:hover div.name {
    color: #23527c;
    text-decoration: underline; }
  footer div.name {
    font-size: 24px;
    font-weight: bold;
    text-align: center; }
  footer div.employment-agency {
    font-size: 11px;
    text-align: center;
    margin: 10px 0;}
  footer div.tel {
    margin-bottom: 40px;
    text-align: center; }
    footer div.tel span.number {
      font-size: 25px; }
      footer div.tel span.number a {
        font-size: inherit; }

nav {
  background: #000;
  height: 36px;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 999;
  filter: alpha(opacity=90);
  -moz-opacity: 0.9;
  opacity: 0.9; }
  nav div.nav-title {
    color: #b3b3b3;
    float: left;
    font-size: 12px;
    margin: 7px;
    margin-left: 34px; }

  nav div.nav-links {
  	background: #000;
    float: right; }
    nav span.employment-agency {
    color: #fff;
    font-size: 10px;
    float: left;
    margin: 10px;}
    nav div.nav-links a {
      background: #ffeb5b;
      border-right: 1px solid #fff;
      color: #000;
      float: left;
      font-weight: bold;
      height: 36px;
      margin: 0;
      min-width: 150px;
      padding: 7px 10px 0;
      text-align: center;
      position: relative;
      z-index: 0;
      -webkit-transition: all 0.3s cubic-bezier(0.02, 0.01, 0.47, 1);
      transition: all 0.3s cubic-bezier(0.02, 0.01, 0.47, 1); }
      nav div.nav-links a:before {
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: #1d89ff;
        content: '';
        opacity: 0;
        -webkit-transition: opacity 0.15s ease-out, -webkit-transform 0.15s ease-out;
        transition: opacity 0.15s ease-out, -webkit-transform 0.15s ease-out;
        transition: transform 0.15s ease-out, opacity 0.15s ease-out;
        transition: transform 0.15s ease-out, opacity 0.15s ease-out, -webkit-transform 0.15s ease-out;
        z-index: -1;
        -webkit-transform: scaleX(0);
        transform: scaleX(0); }
      nav div.nav-links a:hover, nav div.nav-links a:focus {
        text-decoration: none;
        box-shadow: 0 1px 8px rgba(58, 51, 53, 0.3);
        color: #fff;
        -webkit-transition: all 0.5s cubic-bezier(0.02, 0.01, 0.47, 1);
        transition: all 0.5s cubic-bezier(0.02, 0.01, 0.47, 1); }
        nav div.nav-links a:hover span.icon, nav div.nav-links a:focus span.icon {
          background: url("../images/icon-arrow-white.png") 0 0 no-repeat; }
      nav div.nav-links a:hover:before, nav div.nav-links a:focus:before {
        opacity: 1;
        -webkit-transition: opacity 0.2s ease-in, -webkit-transform 0.2s ease-in;
        transition: opacity 0.2s ease-in, -webkit-transform 0.2s ease-in;
        transition: transform 0.2s ease-in, opacity 0.2s ease-in;
        transition: transform 0.2s ease-in, opacity 0.2s ease-in, -webkit-transform 0.2s ease-in;
        -webkit-transform: scaleX(1);
        transform: scaleX(1); }
      nav div.nav-links a span.icon {
        background: url("../images/icon-arrow.png") 0 0 no-repeat;
        background-size: contain;
        height: 14px;
        width: 14px;
        display: inline-block; }
      nav div.nav-links a:last-child {
        border-right: none; }

section.about {
  overflow: hidden;
  padding: 70px 7%; }
  section.about div.item {
    float: left;
    width: 33%; }
    section.about div.item div.icon {
      text-align: center; }
      section.about div.item div.icon img {
        height: 100px; }
    section.about div.item h2 {
      text-align: center;
      font-size: 20px;
      height: 80px;
      line-height: 40px;
      margin-top: 40px; }
      section.about div.item h2.one-row {
        padding-top: 18px; }
    section.about div.item p {
      font-size: 12px;
      margin: 0 25px; }

section.contact {
  clear: both;
  overflow: hidden; }
  section.contact div.item {
    float: left;
    padding: 25px 0;
    width: 50%; }
    section.contact div.item a {
      border: 1px solid #ffeb5b;
      color: #ffeb5b;
      display: block;
      margin: 0 auto;
      padding: 8px 0;
      text-align: center;
      width: 60%;
      position: relative;
      z-index: 0;
      -webkit-transition: all 0.3s cubic-bezier(0.02, 0.01, 0.47, 1);
      transition: all 0.3s cubic-bezier(0.02, 0.01, 0.47, 1); }
      section.contact div.item a:before {
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: #ffeb5b;
        content: '';
        opacity: 0;
        -webkit-transition: opacity 0.15s ease-out, -webkit-transform 0.15s ease-out;
        transition: opacity 0.15s ease-out, -webkit-transform 0.15s ease-out;
        transition: transform 0.15s ease-out, opacity 0.15s ease-out;
        transition: transform 0.15s ease-out, opacity 0.15s ease-out, -webkit-transform 0.15s ease-out;
        z-index: -1;
        -webkit-transform: scaleX(0);
        transform: scaleX(0); }
      section.contact div.item a:hover, section.contact div.item a:focus {
        text-decoration: none;
        box-shadow: 0 1px 8px rgba(58, 51, 53, 0.3);
        color: #333;
        -webkit-transition: all 0.5s cubic-bezier(0.02, 0.01, 0.47, 1);
        transition: all 0.5s cubic-bezier(0.02, 0.01, 0.47, 1); }
        section.contact div.item a:hover span.icon, section.contact div.item a:focus span.icon {
          background: url("../images/icon-arrow.png") 0 0 no-repeat; }
      section.contact div.item a:hover:before, section.contact div.item a:focus:before {
        opacity: 1;
        -webkit-transition: opacity 0.2s ease-in, -webkit-transform 0.2s ease-in;
        transition: opacity 0.2s ease-in, -webkit-transform 0.2s ease-in;
        transition: transform 0.2s ease-in, opacity 0.2s ease-in;
        transition: transform 0.2s ease-in, opacity 0.2s ease-in, -webkit-transform 0.2s ease-in;
        -webkit-transform: scaleX(1);
        transform: scaleX(1); }
      section.contact div.item a span.icon {
        background: url("../images/icon-arrow-yellow.png") 0 0 no-repeat;
        background-size: contain;
        float: right;
        height: 14px;
        margin-top: 3px;
        margin-right: 5px;
        width: 14px;
        display: inline-block; }
    section.contact div.item p {
      color: #fff;
      font-size: 17px;
      text-align: center; }
  section.contact div.left {
    background: #000; }
  section.contact div.right {
    background: #333; }

section.detail div.content {
  background: #000 no-repeat;
  background-size: contain;
  background-image: url("../images/bg-detail.jpg");
  background-size: contain;
  height: 1000px;
  position: relative; }
  section.detail div.content div.item {
    position: absolute; }
    section.detail div.content div.item div.border {
      border-bottom: 1px solid #fff;
      margin-top: 5px;
      margin-bottom: 15px;
      height: 1px;
      width: 40px; }
    section.detail div.content div.item div.step {
      color: #fff; }
      section.detail div.content div.item div.step span.number {
        font-size: 18px; }
    section.detail div.content div.item h3 {
      color: #fff;
      font-size: 30px; }
    section.detail div.content div.item p.description {
      color: #fff;
      clear: both;
      font-size: 16px;
      line-height: 25px; }
  section.detail div.content div.step01 {
    top: 17%;
    right: 4%; }
    section.detail div.content div.step01 div.border {
      float: right; }
    section.detail div.content div.step01 div.step {
      text-align: right; }
    section.detail div.content div.step01 h3 {
      text-align: right; }
    section.detail div.content div.step01 p.description {
      text-align: right; }
  section.detail div.content div.step02 {
    top: 42%;
    left: 4%; }
  section.detail div.content div.step03 {
    top: 65%;
    right: 4%; }
    section.detail div.content div.step03 div.border {
      float: right; }
    section.detail div.content div.step03 div.step {
      text-align: right; }
    section.detail div.content div.step03 h3 {
      text-align: right; }
    section.detail div.content div.step03 p.description {
      text-align: right; }
  section.detail div.content div.step04 {
    top: 91%;
    left: 4%; }
section.detail div.head {
  margin: 80px 0; }
  section.detail div.head div.border {
    border: 1px solid #00a1ff;
    margin: 17px auto 25px;
    height: 1px;
    width: 40px; }
  section.detail div.head h2 {
    font-weight: bold;
    text-align: center; }

section.registration {
  margin: 70px 0; }
  section.registration a {
    background: #ffeb5b;
    color: #000;
    display: block;
    font-weight: bold;
    margin: 30px auto 0;
    padding: 7px 0;
    text-align: center;
    width: 350px;
    position: relative;
    z-index: 0;
    -webkit-transition: all 0.3s cubic-bezier(0.02, 0.01, 0.47, 1);
    transition: all 0.3s cubic-bezier(0.02, 0.01, 0.47, 1); }
    section.registration a:before {
      position: absolute;
      bottom: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background: #1d89ff;
      content: '';
      opacity: 0;
      -webkit-transition: opacity 0.15s ease-out, -webkit-transform 0.15s ease-out;
      transition: opacity 0.15s ease-out, -webkit-transform 0.15s ease-out;
      transition: transform 0.15s ease-out, opacity 0.15s ease-out;
      transition: transform 0.15s ease-out, opacity 0.15s ease-out, -webkit-transform 0.15s ease-out;
      z-index: -1;
      -webkit-transform: scaleX(0);
      transform: scaleX(0); }
    section.registration a:hover, section.registration a:focus {
      text-decoration: none;
      box-shadow: 0 1px 8px rgba(58, 51, 53, 0.3);
      color: #fff;
      -webkit-transition: all 0.5s cubic-bezier(0.02, 0.01, 0.47, 1);
      transition: all 0.5s cubic-bezier(0.02, 0.01, 0.47, 1); }
      section.registration a:hover span.icon, section.registration a:focus span.icon {
        background: url("../images/icon-arrow-white.png") 0 0 no-repeat; }
    section.registration a:hover:before, section.registration a:focus:before {
      opacity: 1;
      -webkit-transition: opacity 0.2s ease-in, -webkit-transform 0.2s ease-in;
      transition: opacity 0.2s ease-in, -webkit-transform 0.2s ease-in;
      transition: transform 0.2s ease-in, opacity 0.2s ease-in;
      transition: transform 0.2s ease-in, opacity 0.2s ease-in, -webkit-transform 0.2s ease-in;
      -webkit-transform: scaleX(1);
      transform: scaleX(1); }
    section.registration a span.icon {
      background: url("../images/icon-arrow.png") 0 0 no-repeat;
      background-size: contain;
      float: right;
      height: 14px;
      margin-top: 3px;
      margin-right: 5px;
      width: 14px;
      display: inline-block; }
  section.registration div.border {
    border: 1px solid #00a1ff;
    margin: 17px auto 25px;
    height: 1px;
    width: 40px; }
  section.registration h2 {
    font-weight: bold;
    text-align: center; }
  section.registration p {
    font-size: 16px;
    text-align: center; }

section.visual {
  padding: 130px 0;
  background: #e1e1e1 no-repeat center center;
  background-size: cover;
  background-image: url("../images/bg-visual.png");
  background-color: #15190a; }
  section.visual div.inner {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    align-items: center;
    min-height: 200px;
    -webkit-flex-direction: column;
    flex-direction: column; }
    section.visual div.inner h1 {
      color: #fff;
      font-size: 23px; }
    section.visual div.inner div.title-en {
      color: #ff0;
      font-size: 32px; }
    section.visual div.inner p.description {
      color: #fff;
      font-size: 15px;
      font-weight: normal;
      letter-spacing: 4px;
      line-height: 55px;
      margin-top: 20px;
      min-width: 800px;
      text-align: center; }

@media screen and (max-width: 767px) {
  div.page-top a {
    font-size: 8px; }

  footer div.address {
    font-size: 12px; }
  footer div.footer-links a {
    font-size: 8px;
    margin: 0; }
    footer div.employment-agency {
    font-size: 8px;}
    footer div.footer-links a:before {
      background-size: auto 10px;
      margin-right: 2px;
      height: 9px;
      width: 9px; }
  footer div.name {
    font-size: 18px; }

  nav div.nav-links {
    float: left;
    width: 100%; }
    nav span.employment-agency {
    font-size: 9px;
    height: 10px;}
    nav div.nav-links a {
      font-size: 9px;
      min-width: auto;
      padding: 11px 0 0; }
      nav div.nav-links a:nth-child(2) {
        width: 38%; }
      nav div.nav-links a:nth-child(3) {
        width: 27%; }
      nav div.nav-links a:nth-child(4) {
        width: 35%; }
      nav div.nav-links a span.icon, nav div.nav-links a:hover span.icon {
        background-size: auto 8px;
        height: 8px;
        width: 8px; }
  nav div.nav-title {
    font-size: 9px;
    margin-left: 10px;
    min-height: auto;
    width: 100%;
    height: 15px;}

  section.about {
    padding: 0 20px; }
    section.about div.item {
      border-bottom: 1px solid #e6e6e6;
      padding: 30px 0;
      width: 100%; }
      section.about div.item.right {
        border-bottom: none; }
      section.about div.item div.icon img {
        height: 80px; }
      section.about div.item h2 {
        font-size: 16px;
        height: auto;
        line-height: 28px;
        margin-top: 20px; }
      section.about div.item p {
        margin: 0; }

  section.contact div.item {
    width: 100%; }
    section.contact div.item a {
      font-size: 11px;
      padding: 12px 0;
      width: 70%; }
      section.contact div.item a span.icon, section.contact div.item a:hover span.icon {
        background-size: auto 8px; }
    section.contact div.item p {
      font-size: 12px; }

  section.detail div.content {
    background: #4d4d4d;
    background-image: none;
    position: inherit; }
    section.detail div.content div.item {
      background-repeat: no-repeat;
      background-size: contain;
      padding-top: 165px;
      padding-bottom: 20px;
      position: inherit; }
      section.detail div.content div.item div.border {
        float: left;
        margin-left: 12px;
        margin-bottom: 10px;
        width: 30px; }
      section.detail div.content div.item div.step {
        font-size: 10px;
        margin-top: 20px;
        margin-left: 12px;
        text-align: left; }
        section.detail div.content div.item div.step span.number {
          font-size: 14px; }
      section.detail div.content div.item h3 {
        font-size: 18px;
        margin-top: 15px;
        margin-left: 12px;
        text-align: left; }
      section.detail div.content div.item p.description {
        line-height: 18px;
        margin: 0 12px;
        text-align: left; }
    section.detail div.content div.step01 {
      background-image: url("../images/bg-step01.png"); }
    section.detail div.content div.step02 {
      background-image: url("../images/bg-step02.png"); }
    section.detail div.content div.step03 {
      background-image: url("../images/bg-step03.png"); }
    section.detail div.content div.step04 {
      background-image: url("../images/bg-step04.png"); }
  section.detail div.head {
    margin: 40px 0; }
    section.detail div.head h2 {
      font-size: 16px; }

  section.registration {
    margin: 40px 0; }
    section.registration a {
      font-size: 11px;
      margin-top: 20px;
      padding: 12px 0;
      width: 70%; }
      section.registration a span.icon, section.registration a:hover span.icon {
        background-size: auto 8px; }
    section.registration h2 {
      font-size: 16px; }
    section.registration p {
      font-size: 12px;
      margin: 0 30px;
      text-align: center; }

  section.visual {
    padding: 90px 0 10px; }
    section.visual div.inner div.title-en {
      font-size: 4.6vw; }
    section.visual div.inner h1 {
      font-size: 3.3vw; }
    section.visual div.inner p.description {
      font-size: 3.0vw;
      line-height: 6.0vw;
      margin-top: 80px;
      min-width: auto;
      width: 100%; } }
