@charset "UTF-8";
/* 
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com 
Twitter: @rich_clark
*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent; }

body {
  line-height: 1; }

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block; }

nav ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none; }

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent; }

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none; }

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold; }

del {
  text-decoration: line-through; }

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0; }

input, select {
  vertical-align: middle; }

.clearfix::after {
  display: block;
  clear: both;
  content: ""; }

.hide {
  display: none !important; }

.d-none {
  display: none; }

.disabled {
  pointer-events: none;
  opacity: 0.5; }

.required {
  color: red; }

.text-white {
  color: #fff; }

.text-underline {
  text-decoration: underline; }

.text-italic {
  font-style: italic; }

.text-bold {
  font-weight: bold; }

.text-truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap; }

.text-left {
  text-align: left !important; }

.text-center {
  text-align: center !important; }

.text-right {
  text-align: right !important; }

.float-left {
  float: left; }

.float-right {
  float: right; }

.block {
  display: block; }

.inline-block {
  display: inline-block; }

.pt-5 {
  padding-top: 5px !important; }

.pr-5 {
  padding-right: 5px !important; }

.pb-5 {
  padding-bottom: 5px !important; }

.pl-5 {
  padding-left: 5px !important; }

.mt-5 {
  margin-top: 5px !important; }

.mr-5 {
  margin-right: 5px !important; }

.mb-5 {
  margin-bottom: 5px !important; }

.ml-5 {
  margin-left: 5px !important; }

.pt-10 {
  padding-top: 10px !important; }

.pr-10 {
  padding-right: 10px !important; }

.pb-10 {
  padding-bottom: 10px !important; }

.pl-10 {
  padding-left: 10px !important; }

.mt-10 {
  margin-top: 10px !important; }

.mr-10 {
  margin-right: 10px !important; }

.mb-10 {
  margin-bottom: 10px !important; }

.ml-10 {
  margin-left: 10px !important; }

.pt-15 {
  padding-top: 15px !important; }

.pr-15 {
  padding-right: 15px !important; }

.pb-15 {
  padding-bottom: 15px !important; }

.pl-15 {
  padding-left: 15px !important; }

.mt-15 {
  margin-top: 15px !important; }

.mr-15 {
  margin-right: 15px !important; }

.mb-15 {
  margin-bottom: 15px !important; }

.ml-15 {
  margin-left: 15px !important; }

.pt-20 {
  padding-top: 20px !important; }

.pr-20 {
  padding-right: 20px !important; }

.pb-20 {
  padding-bottom: 20px !important; }

.pl-20 {
  padding-left: 20px !important; }

.mt-20 {
  margin-top: 20px !important; }

.mr-20 {
  margin-right: 20px !important; }

.mb-20 {
  margin-bottom: 20px !important; }

.ml-20 {
  margin-left: 20px !important; }

.pt-25 {
  padding-top: 25px !important; }

.pr-25 {
  padding-right: 25px !important; }

.pb-25 {
  padding-bottom: 25px !important; }

.pl-25 {
  padding-left: 25px !important; }

.mt-25 {
  margin-top: 25px !important; }

.mr-25 {
  margin-right: 25px !important; }

.mb-25 {
  margin-bottom: 25px !important; }

.ml-25 {
  margin-left: 25px !important; }

.pt-30 {
  padding-top: 30px !important; }

.pr-30 {
  padding-right: 30px !important; }

.pb-30 {
  padding-bottom: 30px !important; }

.pl-30 {
  padding-left: 30px !important; }

.mt-30 {
  margin-top: 30px !important; }

.mr-30 {
  margin-right: 30px !important; }

.mb-30 {
  margin-bottom: 30px !important; }

.ml-30 {
  margin-left: 30px !important; }

.pt-35 {
  padding-top: 35px !important; }

.pr-35 {
  padding-right: 35px !important; }

.pb-35 {
  padding-bottom: 35px !important; }

.pl-35 {
  padding-left: 35px !important; }

.mt-35 {
  margin-top: 35px !important; }

.mr-35 {
  margin-right: 35px !important; }

.mb-35 {
  margin-bottom: 35px !important; }

.ml-35 {
  margin-left: 35px !important; }

.pt-40 {
  padding-top: 40px !important; }

.pr-40 {
  padding-right: 40px !important; }

.pb-40 {
  padding-bottom: 40px !important; }

.pl-40 {
  padding-left: 40px !important; }

.mt-40 {
  margin-top: 40px !important; }

.mr-40 {
  margin-right: 40px !important; }

.mb-40 {
  margin-bottom: 40px !important; }

.ml-40 {
  margin-left: 40px !important; }

.pt-45 {
  padding-top: 45px !important; }

.pr-45 {
  padding-right: 45px !important; }

.pb-45 {
  padding-bottom: 45px !important; }

.pl-45 {
  padding-left: 45px !important; }

.mt-45 {
  margin-top: 45px !important; }

.mr-45 {
  margin-right: 45px !important; }

.mb-45 {
  margin-bottom: 45px !important; }

.ml-45 {
  margin-left: 45px !important; }

.pt-50 {
  padding-top: 50px !important; }

.pr-50 {
  padding-right: 50px !important; }

.pb-50 {
  padding-bottom: 50px !important; }

.pl-50 {
  padding-left: 50px !important; }

.mt-50 {
  margin-top: 50px !important; }

.mr-50 {
  margin-right: 50px !important; }

.mb-50 {
  margin-bottom: 50px !important; }

.ml-50 {
  margin-left: 50px !important; }

.pt-55 {
  padding-top: 55px !important; }

.pr-55 {
  padding-right: 55px !important; }

.pb-55 {
  padding-bottom: 55px !important; }

.pl-55 {
  padding-left: 55px !important; }

.mt-55 {
  margin-top: 55px !important; }

.mr-55 {
  margin-right: 55px !important; }

.mb-55 {
  margin-bottom: 55px !important; }

.ml-55 {
  margin-left: 55px !important; }

.pt-60 {
  padding-top: 60px !important; }

.pr-60 {
  padding-right: 60px !important; }

.pb-60 {
  padding-bottom: 60px !important; }

.pl-60 {
  padding-left: 60px !important; }

.mt-60 {
  margin-top: 60px !important; }

.mr-60 {
  margin-right: 60px !important; }

.mb-60 {
  margin-bottom: 60px !important; }

.ml-60 {
  margin-left: 60px !important; }

.pt-65 {
  padding-top: 65px !important; }

.pr-65 {
  padding-right: 65px !important; }

.pb-65 {
  padding-bottom: 65px !important; }

.pl-65 {
  padding-left: 65px !important; }

.mt-65 {
  margin-top: 65px !important; }

.mr-65 {
  margin-right: 65px !important; }

.mb-65 {
  margin-bottom: 65px !important; }

.ml-65 {
  margin-left: 65px !important; }

.pt-70 {
  padding-top: 70px !important; }

.pr-70 {
  padding-right: 70px !important; }

.pb-70 {
  padding-bottom: 70px !important; }

.pl-70 {
  padding-left: 70px !important; }

.mt-70 {
  margin-top: 70px !important; }

.mr-70 {
  margin-right: 70px !important; }

.mb-70 {
  margin-bottom: 70px !important; }

.ml-70 {
  margin-left: 70px !important; }

.pt-75 {
  padding-top: 75px !important; }

.pr-75 {
  padding-right: 75px !important; }

.pb-75 {
  padding-bottom: 75px !important; }

.pl-75 {
  padding-left: 75px !important; }

.mt-75 {
  margin-top: 75px !important; }

.mr-75 {
  margin-right: 75px !important; }

.mb-75 {
  margin-bottom: 75px !important; }

.ml-75 {
  margin-left: 75px !important; }

.pt-80 {
  padding-top: 80px !important; }

.pr-80 {
  padding-right: 80px !important; }

.pb-80 {
  padding-bottom: 80px !important; }

.pl-80 {
  padding-left: 80px !important; }

.mt-80 {
  margin-top: 80px !important; }

.mr-80 {
  margin-right: 80px !important; }

.mb-80 {
  margin-bottom: 80px !important; }

.ml-80 {
  margin-left: 80px !important; }

.pt-85 {
  padding-top: 85px !important; }

.pr-85 {
  padding-right: 85px !important; }

.pb-85 {
  padding-bottom: 85px !important; }

.pl-85 {
  padding-left: 85px !important; }

.mt-85 {
  margin-top: 85px !important; }

.mr-85 {
  margin-right: 85px !important; }

.mb-85 {
  margin-bottom: 85px !important; }

.ml-85 {
  margin-left: 85px !important; }

.pt-90 {
  padding-top: 90px !important; }

.pr-90 {
  padding-right: 90px !important; }

.pb-90 {
  padding-bottom: 90px !important; }

.pl-90 {
  padding-left: 90px !important; }

.mt-90 {
  margin-top: 90px !important; }

.mr-90 {
  margin-right: 90px !important; }

.mb-90 {
  margin-bottom: 90px !important; }

.ml-90 {
  margin-left: 90px !important; }

.pt-95 {
  padding-top: 95px !important; }

.pr-95 {
  padding-right: 95px !important; }

.pb-95 {
  padding-bottom: 95px !important; }

.pl-95 {
  padding-left: 95px !important; }

.mt-95 {
  margin-top: 95px !important; }

.mr-95 {
  margin-right: 95px !important; }

.mb-95 {
  margin-bottom: 95px !important; }

.ml-95 {
  margin-left: 95px !important; }

.pt-100 {
  padding-top: 100px !important; }

.pr-100 {
  padding-right: 100px !important; }

.pb-100 {
  padding-bottom: 100px !important; }

.pl-100 {
  padding-left: 100px !important; }

.mt-100 {
  margin-top: 100px !important; }

.mr-100 {
  margin-right: 100px !important; }

.mb-100 {
  margin-bottom: 100px !important; }

.ml-100 {
  margin-left: 100px !important; }

.line-height-10 {
  line-height: 1; }

.line-height-11 {
  line-height: 1.1; }

.line-height-12 {
  line-height: 1.2; }

.line-height-13 {
  line-height: 1.3; }

.line-height-14 {
  line-height: 1.4; }

.line-height-15 {
  line-height: 1.5; }

.line-height-16 {
  line-height: 1.6; }

.line-height-17 {
  line-height: 1.7; }

.line-height-18 {
  line-height: 1.8; }

.line-height-19 {
  line-height: 1.9; }

.line-height-20 {
  line-height: 2; }

.line-height-21 {
  line-height: 2.1; }

.line-height-22 {
  line-height: 2.2; }

.line-height-23 {
  line-height: 2.3; }

.line-height-24 {
  line-height: 2.4; }

.line-height-25 {
  line-height: 2.5; }

.line-height-26 {
  line-height: 2.6; }

.line-height-27 {
  line-height: 2.7; }

.line-height-28 {
  line-height: 2.8; }

.line-height-29 {
  line-height: 2.9; }

.line-height-30 {
  line-height: 3; }

.font-size-10 {
  font-size: 1rem !important; }

.font-size-11 {
  font-size: 1.1rem !important; }

.font-size-12 {
  font-size: 1.2rem !important; }

.font-size-13 {
  font-size: 1.3rem !important; }

.font-size-14 {
  font-size: 1.4rem !important; }

.font-size-15 {
  font-size: 1.5rem !important; }

.font-size-16 {
  font-size: 1.6rem !important; }

.font-size-17 {
  font-size: 1.7rem !important; }

.font-size-18 {
  font-size: 1.8rem !important; }

.font-size-19 {
  font-size: 1.9rem !important; }

.font-size-20 {
  font-size: 2rem !important; }

.font-size-21 {
  font-size: 2.1rem !important; }

.font-size-22 {
  font-size: 2.2rem !important; }

.font-size-23 {
  font-size: 2.3rem !important; }

.font-size-24 {
  font-size: 2.4rem !important; }

.font-size-25 {
  font-size: 2.5rem !important; }

.font-size-26 {
  font-size: 2.6rem !important; }

.font-size-27 {
  font-size: 2.7rem !important; }

.font-size-28 {
  font-size: 2.8rem !important; }

.font-size-29 {
  font-size: 2.9rem !important; }

.font-size-30 {
  font-size: 3rem !important; }

/*
  setting
*/
/*
  responsive
*/
/*
  Base
*/
*, *:before, *:after {
  box-sizing: border-box; }

html {
  font-size: 62.5%; }

body {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  color: #333;
  line-height: 1.5;
  font-size: 1.4rem;
  font-family: Quicksand, "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; }

a {
  color: #337ab7;
  text-decoration: none; }
  a:hover {
    opacity: 0.7; }
  a.disabled {
    pointer-events: none;
    opacity: 0.5; }

img {
  vertical-align: bottom; }

iframe {
  vertical-align: bottom; }

.open-sans {
  font-family: 'Open Sans', sans-serif;
  font-style: italic; }

.hide {
  display: none; }

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

@media (min-width: 769px) {
  .hide-pc {
    display: none !important; } }

/*
  Layout
*/
.l-header {
  position: fixed;
  z-index: 1000;
  width: 100%;
  border-top: 5px solid #D3FF18;
  background-color: #fff; }
  .l-header .brand {
    float: left; }
  .l-header .nav {
    float: right; }

.l-contents {
  padding-top: 55px; }

.l-container {
  width: 1170px;
  margin: 0 auto;
  padding: 0 15px; }
  .l-container::after {
    display: block;
    clear: both;
    content: ""; }
  @media (max-width: 1170px) {
    .l-container {
      width: 100%; } }

/*
  Block
*/
.brand {
  display: block; }
  .brand__image {
    height: 50px;
    padding: 8px 0; }

.nav-menu {
  display: table;
  table-layout: fixed;
  list-style: none; }
  .nav-menu__item {
    display: table-cell;
    width: 80px;
    height: 50px;
    text-align: center;
    vertical-align: middle; }
  .nav-menu__link {
    position: relative;
    color: #333;
    font-size: 1.8rem; }
    .nav-menu__link:after {
      position: absolute;
      content: '';
      left: 0;
      bottom: 0;
      z-index: -1;
      width: 0;
      border-bottom: 8px solid #D3FF18;
      -o-transition: 0.2s;
      -ms-transition: 0.2s;
      -moz-transition: 0.2s;
      -webkit-transition: 0.2s;
      transition: 0.2s; }
    .nav-menu__link:hover {
      opacity: 1; }
      .nav-menu__link:hover:after {
        width: 100%; }

.nav-dropdown {
  display: none;
  position: fixed;
  z-index: 900;
  top: 55px;
  width: 100%;
  border-bottom: 2px solid #eee;
  background-color: #fff;
  text-align: center;
  opacity: 0.95; }
  .nav-dropdown__link {
    display: block;
    padding: 15px 0;
    font-size: 2.0rem;
    border-top: 1px solid #eee;
    color: #333; }

.kv-wrap {
  position: relative;
  height: 600px; }
  .kv-wrap .kv {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }
    .kv-wrap .kv .slick-list {
      height: 100%; }
      .kv-wrap .kv .slick-list .slick-track {
        height: 100%; }
        .kv-wrap .kv .slick-list .slick-track .slick-slide {
          outline: none; }
    .kv-wrap .kv__item {
      width: 100%; }
    .kv-wrap .kv__image {
      width: 100%;
      height: 100%;
      background-size: cover;
      display: inline-block;
      background-position: center center;
      background-repeat: no-repeat;
      vertical-align: bottom; }
    .kv-wrap .kv__overlay:before {
      position: absolute;
      content: '';
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-color: rgba(0, 0, 0, 0.3); }
  .kv-wrap .kv-sp {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }
    .kv-wrap .kv-sp .slick-list {
      height: 100%; }
      .kv-wrap .kv-sp .slick-list .slick-track {
        height: 100%; }
        .kv-wrap .kv-sp .slick-list .slick-track .slick-slide {
          outline: none; }
    .kv-wrap .kv-sp__item {
      width: 100%; }
    .kv-wrap .kv-sp__image {
      width: 100%;
      height: 100%;
      background-size: cover;
      display: inline-block;
      background-position: center center;
      background-repeat: no-repeat;
      vertical-align: bottom; }
    .kv-wrap .kv-sp__overlay:before {
      position: absolute;
      content: '';
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-color: rgba(0, 0, 0, 0.3); }
  .kv-wrap .catch-text {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    color: #fff;
    width: 80%;
    height: 170px;
    text-align: center;
    text-shadow: 2px 2px 2px #000; }
    .kv-wrap .catch-text__1 {
      font-size: 2.0rem;
      font-style: italic; }
    .kv-wrap .catch-text__2 {
      margin-bottom: 10px;
      font-size: 5.0rem;
      font-style: italic; }
    .kv-wrap .catch-text__3 {
      font-size: 2.4rem;
      font-style: italic; }
  @media (max-width: 1170px) {
    .kv-wrap .catch-text__1 {
      font-size: 1.8rem; }
    .kv-wrap .catch-text__2 {
      font-size: 3.6rem; }
    .kv-wrap .catch-text__3 {
      font-size: 2.0rem; } }
  @media (max-width: 768px) {
    .kv-wrap .catch-text {
      width: 100%; }
      .kv-wrap .catch-text__1 {
        font-size: 1.2rem; }
      .kv-wrap .catch-text__2 {
        font-size: 2.8rem; }
      .kv-wrap .catch-text__3 {
        font-size: 1.4rem; } }

.section-heading {
  text-align: center;
  font-style: italic; }
  .section-heading__main {
    font-size: 3.0rem; }
  .section-heading__line {
    display: inline-block;
    margin: 5px 0;
    border-top: 5px solid #D3FF18; }
  .section-heading__sub {
    color: #888;
    font-size: 1.3rem;
    font-weight: normal; }

.company-policy {
  padding: 80px 0; }
  @media (max-width: 1170px) {
    .company-policy {
      padding: 40px 0; } }
  .company-policy .policy-text {
    margin: 50px 0; }
    .company-policy .policy-text__main {
      margin-bottom: 30px;
      padding: 5px 8px;
      text-align: center;
      font-size: 2.6rem;
      font-weight: bold;
      background-color: #D3FF18; }
      @media (max-width: 1170px) {
        .company-policy .policy-text__main {
          padding: 10px 8px;
          margin-bottom: 15px;
          font-size: 1.8rem; } }
      @media (max-width: 768px) {
        .company-policy .policy-text__main {
          font-size: 1.4rem; } }
    .company-policy .policy-text__sub {
      font-size: 1.6rem;
      line-height: 2.0; }
      @media (max-width: 1170px) {
        .company-policy .policy-text__sub {
          font-size: 1.4rem; } }
  .company-policy .open-mission {
    display: block;
    margin-bottom: 30px; }
    .company-policy .open-mission > img {
      width: 100%; }
  .company-policy .mission-row {
    margin: 0 -30px; }
    @media (max-width: 1170px) {
      .company-policy .mission-row {
        margin: 0; } }
    .company-policy .mission-row::after {
      display: block;
      clear: both;
      content: ""; }
    .company-policy .mission-row__col {
      float: left;
      margin: 0 30px;
      width: 340px; }
      @media (max-width: 1170px) {
        .company-policy .mission-row__col {
          margin: 0 0 30px;
          width: 100%; } }
    .company-policy .mission-row__heading {
      margin-bottom: 15px;
      padding: 5px 0;
      border: 3px solid #D3FF18;
      text-align: center;
      font-size: 1.6rem; }
      @media (max-width: 1170px) {
        .company-policy .mission-row__heading {
          font-size: 1.4rem; } }
    .company-policy .mission-row__body {
      line-height: 2.0; }

.about {
  padding: 80px 0; }
  @media (max-width: 1170px) {
    .about {
      padding: 40px 0; } }
  .about .heading-about {
    margin: 0 0 70px;
    text-align: center;
    color: #333;
    font-size: 2.4rem;
    font-style: italic; }
    @media (max-width: 768px) {
      .about .heading-about {
        font-size: 2.0rem; } }
    .about .heading-about__underline {
      position: relative; }
      .about .heading-about__underline:after {
        position: absolute;
        content: '';
        left: 0;
        bottom: 0;
        z-index: -1;
        width: 100%;
        border-bottom: 8px solid #D3FF18; }
  .about .al-row::after {
    display: block;
    clear: both;
    content: ""; }
  .about .al-row__left {
    float: left;
    width: 50%;
    height: 645px; }
    .about .al-row__left > img {
      width: 100%; }
    @media (max-width: 768px) {
      .about .al-row__left {
        width: 100%;
        height: auto; } }
  .about .al-row__right {
    float: left;
    width: 50%;
    height: 645px;
    padding: 70px;
    border: 7px solid #D3FF18;
    line-height: 2.0;
    font-size: 1.6rem; }
    @media (max-width: 1170px) {
      .about .al-row__right {
        height: auto; } }
    @media (max-width: 768px) {
      .about .al-row__right {
        width: 100%;
        height: auto;
        padding: 35px;
        font-size: 1.4rem; } }

.works {
  padding: 30px;
  background-color: #F0F0F0; }
  .works .works-text {
    width: 660px;
    margin: 20px auto;
    line-height: 2.0; }
    @media (max-width: 1170px) {
      .works .works-text {
        width: 100%; } }

.works-swiper {
  position: absolute;
  left: 0;
  width: 100%;
  height: 378px; }
  @media (max-width: 768px) {
    .works-swiper {
      height: 250px; } }
  .works-swiper .swiper-container {
    width: 100%;
    height: 100%;
    padding-bottom: 30px; }
    .works-swiper .swiper-container .swiper-wrapper .swiper-slide {
      background-position: center;
      background-repeat: no-repeat;
      background-size: contain;
      width: 700px;
      height: 100%; }
      @media (max-width: 768px) {
        .works-swiper .swiper-container .swiper-wrapper .swiper-slide {
          width: 85%; } }
    .works-swiper .swiper-container .swiper-pagination {
      bottom: 0;
      z-index: 100; }
      .works-swiper .swiper-container .swiper-pagination .swiper-pagination-bullet {
        width: 12px;
        height: 12px; }

.works-swiper-dummy {
  margin: 20px 0;
  height: 348px; }
  @media (max-width: 768px) {
    .works-swiper-dummy {
      height: 250px; } }

.lineat-row {
  margin: 60px 0 30px; }
  .lineat-row::after {
    display: block;
    clear: both;
    content: ""; }
  .lineat-row__link {
    float: left;
    width: 50%;
    padding: 10px; }
    @media (max-width: 768px) {
      .lineat-row__link {
        width: 100%; } }
  .lineat-row__image {
    width: 100%; }

.service {
  padding: 80px 0; }
  .service .service-row {
    margin: 30px -20px; }
    .service .service-row::after {
      display: block;
      clear: both;
      content: ""; }
    @media (max-width: 768px) {
      .service .service-row {
        margin: 0; } }
    .service .service-row__col {
      float: left;
      width: 350px;
      margin: 0 20px;
      box-shadow: 5px 5px #aaa; }
      @media (max-width: 1170px) {
        .service .service-row__col {
          width: 30%;
          margin: 15px 1.5%; } }
      @media (max-width: 768px) {
        .service .service-row__col {
          width: 100%;
          margin: 15px 0; } }
    @media (max-width: 1170px) {
      .service .service-row__image {
        display: block;
        width: 100%;
        margin: 0 auto; } }
    .service .service-row__text {
      padding: 30px;
      height: 350px; }
      @media (max-width: 1170px) {
        .service .service-row__text {
          height: auto; } }
    .service .service-row__heading {
      margin-bottom: 10px;
      text-align: center;
      font-size: 1.6rem; }
    .service .service-row__body {
      line-height: 2.0; }
  .service .contact-btn {
    display: block;
    width: 640px;
    margin: 70px auto 0;
    padding: 13px 0;
    text-align: center;
    font-size: 2.0rem;
    font-style: italic;
    color: #fff;
    background-color: #019E93; }
    @media (max-width: 1170px) {
      .service .contact-btn {
        width: 100%; } }

.service-detail {
  color: #fff; }
  .service-detail::after {
    display: block;
    clear: both;
    content: ""; }
  .service-detail__agent {
    position: relative;
    z-index: 0;
    float: left;
    width: 50%;
    height: 780px;
    padding: 50px;
    background-image: url("/assets/company/img/recruit_01.jpg");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center; }
    .service-detail__agent:before {
      position: absolute;
      z-index: -1;
      content: '';
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-color: rgba(0, 0, 0, 0.3); }
    @media (max-width: 1170px) {
      .service-detail__agent {
        width: 100%;
        height: auto;
        padding: 40px 20px; } }
  .service-detail__sales {
    position: relative;
    z-index: 0;
    float: left;
    width: 50%;
    height: 780px;
    padding: 50px;
    background-image: url("/assets/company/img/recruit_02.jpg");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center; }
    .service-detail__sales:before {
      position: absolute;
      z-index: -1;
      content: '';
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-color: rgba(0, 0, 0, 0.3); }
    @media (max-width: 1170px) {
      .service-detail__sales {
        width: 100%;
        height: auto;
        padding: 40px 20px; } }
  .service-detail__heading {
    width: 290px;
    max-width: 100%;
    margin: 0 auto 50px;
    border: 5px solid #fff;
    text-align: center;
    font-size: 4.8rem; }
    @media (max-width: 1170px) {
      .service-detail__heading {
        font-size: 4.0rem;
        margin-bottom: 20px; } }

.contact {
  position: relative;
  margin: 70px 0 50px;
  padding: 40px 50px;
  background-color: #9ED868; }
  @media (max-width: 1170px) {
    .contact {
      padding: 15px; } }
  .contact:before {
    position: absolute;
    content: '';
    left: 50%;
    top: -40px;
    margin-left: -40px;
    border-left: 40px solid transparent;
    border-right: 40px solid transparent;
    border-bottom: 40px solid #9ED868; }
  .contact .contact-text {
    padding: 20px 0;
    border-bottom: 1px solid #888;
    text-align: center;
    line-height: 2.0;
    font-style: italic; }
  .contact .contact-form {
    padding: 30px 180px; }
    @media (max-width: 1170px) {
      .contact .contact-form {
        padding: 30px 0; } }
  .contact .form-row {
    margin: 20px 0; }
    .contact .form-row__label {
      display: block;
      padding: 0px 3px;
      font-style: italic; }
    .contact .form-row__text {
      height: 35px;
      width: 60%;
      font-size: 1.6rem; }
    .contact .form-row__email {
      height: 35px;
      width: 80%;
      font-size: 1.6rem; }
    .contact .form-row__textarea {
      width: 100%;
      font-size: 1.4rem; }
  .contact .form-submit {
    display: block;
    width: 300px;
    max-width: 100%;
    margin: 50px auto 0;
    padding: 13px 0;
    text-align: center;
    font-size: 1.8rem;
    font-style: italic;
    color: #fff;
    background-color: #000; }

.footer-main {
  padding: 30px;
  background-color: #C5C5C5; }
  .footer-main::after {
    display: block;
    clear: both;
    content: ""; }
  .footer-main__logo {
    float: left;
    width: 230px;
    padding: 15px 30px 15px 0; }
    .footer-main__logo > img {
      max-width: 100%; }
    @media (max-width: 768px) {
      .footer-main__logo {
        width: 100%;
        padding: 15px; } }
  .footer-main__col {
    float: left;
    width: 315px;
    padding: 15px;
    font-size: 1.2rem; }
    @media (max-width: 768px) {
      .footer-main__col {
        width: 100%; } }
  .footer-main__map {
    float: left;
    width: 220px; }
    @media (max-width: 768px) {
      .footer-main__map {
        width: 100%;
        text-align: center; } }

.copyright {
  padding: 7px 0;
  text-align: center;
  font-size: 1.1rem;
  color: #fff;
  background-color: #5B5B5B; }

.hamburger-menu {
  position: relative;
  display: inline-block;
  cursor: pointer;
  width: 50px;
  height: 50px;
  padding: 10px;
  vertical-align: top; }
  .hamburger-menu span {
    display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 10px;
    width: 30px;
    height: 5px;
    background-color: #000;
    border-radius: 0px; }
    .hamburger-menu span:nth-of-type(1) {
      top: 10px; }
    .hamburger-menu span:nth-of-type(2) {
      top: 22.5px; }
    .hamburger-menu span:nth-of-type(3) {
      bottom: 10px; }
  .hamburger-menu--normal.active span:nth-of-type(1) {
    -webkit-transform: translateY(12.5px) rotate(-45deg);
    transform: translateY(12.5px) rotate(-45deg); }
  .hamburger-menu--normal.active span:nth-of-type(2) {
    opacity: 0; }
  .hamburger-menu--normal.active span:nth-of-type(3) {
    -webkit-transform: translateY(-12.5px) rotate(45deg);
    transform: translateY(-12.5px) rotate(45deg); }
  .hamburger-menu--rotate.active span:nth-of-type(1) {
    -webkit-transform: translateY(12.5px) rotate(-315deg);
    transform: translateY(12.5px) rotate(-315deg); }
  .hamburger-menu--rotate.active span:nth-of-type(2) {
    opacity: 0; }
  .hamburger-menu--rotate.active span:nth-of-type(3) {
    -webkit-transform: translateY(-12.5px) rotate(315deg);
    transform: translateY(-12.5px) rotate(315deg); }
  .hamburger-menu--fusion span:nth-of-type(1) {
    -webkit-animation: menu-bar01 .75s forwards;
    animation: menu-bar01 .75s forwards; }
  .hamburger-menu--fusion span:nth-of-type(2) {
    transition: all .25s .25s;
    opacity: 1; }
  .hamburger-menu--fusion span:nth-of-type(3) {
    -webkit-animation: menu-bar02 .75s forwards;
    animation: menu-bar02 .75s forwards; }
  .hamburger-menu--fusion.active span:nth-of-type(1) {
    -webkit-animation: active-menu-bar01 .75s forwards;
    animation: active-menu-bar01 .75s forwards; }
  .hamburger-menu--fusion.active span:nth-of-type(2) {
    opacity: 0; }
  .hamburger-menu--fusion.active span:nth-of-type(3) {
    -webkit-animation: active-menu-bar03 .75s forwards;
    animation: active-menu-bar03 .75s forwards; }
@-webkit-keyframes menu-bar01 {
  0% {
    transform: translateY(12.5px) rotate(45deg); }
  50% {
    transform: translateY(12.5px) rotate(0deg); }
  100% {
    transform: translateY(0) rotate(0deg); } }
@-moz-keyframes menu-bar01 {
  0% {
    transform: translateY(12.5px) rotate(45deg); }
  50% {
    transform: translateY(12.5px) rotate(0deg); }
  100% {
    transform: translateY(0) rotate(0deg); } }
@keyframes menu-bar01 {
  0% {
    transform: translateY(12.5px) rotate(45deg); }
  50% {
    transform: translateY(12.5px) rotate(0deg); }
  100% {
    transform: translateY(0) rotate(0deg); } }
@-webkit-keyframes menu-bar02 {
  0% {
    -webkit-transform: translateY(-12.5px) rotate(-45deg); }
  50% {
    -webkit-transform: translateY(-12.5px) rotate(0deg); }
  100% {
    -webkit-transform: translateY(0) rotate(0deg); } }
@-moz-keyframes menu-bar02 {
  0% {
    -webkit-transform: translateY(-12.5px) rotate(-45deg); }
  50% {
    -webkit-transform: translateY(-12.5px) rotate(0deg); }
  100% {
    -webkit-transform: translateY(0) rotate(0deg); } }
@keyframes menu-bar02 {
  0% {
    -webkit-transform: translateY(-12.5px) rotate(-45deg); }
  50% {
    -webkit-transform: translateY(-12.5px) rotate(0deg); }
  100% {
    -webkit-transform: translateY(0) rotate(0deg); } }
@-webkit-keyframes active-menu-bar01 {
  0% {
    -webkit-transform: translateY(0) rotate(0deg); }
  50% {
    -webkit-transform: translateY(12.5px) rotate(0deg); }
  100% {
    -webkit-transform: translateY(12.5px) rotate(45deg); } }
@-moz-keyframes active-menu-bar01 {
  0% {
    -webkit-transform: translateY(0) rotate(0deg); }
  50% {
    -webkit-transform: translateY(12.5px) rotate(0deg); }
  100% {
    -webkit-transform: translateY(12.5px) rotate(45deg); } }
@keyframes active-menu-bar01 {
  0% {
    -webkit-transform: translateY(0) rotate(0deg); }
  50% {
    -webkit-transform: translateY(12.5px) rotate(0deg); }
  100% {
    -webkit-transform: translateY(12.5px) rotate(45deg); } }
@-webkit-keyframes active-menu-bar03 {
  0% {
    transform: translateY(0) rotate(0deg); }
  50% {
    transform: translateY(-12.5px) rotate(0deg); }
  100% {
    transform: translateY(-12.5px) rotate(-45deg); } }
@-moz-keyframes active-menu-bar03 {
  0% {
    transform: translateY(0) rotate(0deg); }
  50% {
    transform: translateY(-12.5px) rotate(0deg); }
  100% {
    transform: translateY(-12.5px) rotate(-45deg); } }
@keyframes active-menu-bar03 {
  0% {
    transform: translateY(0) rotate(0deg); }
  50% {
    transform: translateY(-12.5px) rotate(0deg); }
  100% {
    transform: translateY(-12.5px) rotate(-45deg); } }

/*# sourceMappingURL=style.css.map */
