@charset "UTF-8";
/*------------------------------------------------------------
	デフォルトスタイル
------------------------------------------------------------*/
html {
  -webkit-text-size-adjust: 100%; }

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td, p {
  margin: 0;
  padding: 0;
  background: transparent;
  border: 0;
  outline: 0;
  font-weight: normal;
  font-size: 100%; }

body {
  width: 100%;
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  font-family: ArialMT, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", メイリオ, sans-serif;
  font-size: 13px; }

body,
table,
input, textarea, select, option {
  font: Arial, Helvetica, sans-serif;
  /*font-family: HiraKakuProN-W3;*/
  /*font-size: 85%;*/ }

article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary {
  display: block; }

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

:focus {
  outline: 0; }

ins {
  text-decoration: none; }

del {
  text-decoration: line-through; }

em {
  font-weight: bold;
  font-style: normal; }

.clearfix:after {
  visibility: hidden;
  display: block;
  content: " ";
  clear: both;
  height: 0; }

/* ************************************************ */
/*                       共通                       */
/* ************************************************ */
header, footer, nav, section, article, main, aside, hgroup {
  display: block; }

html {
  font-size: 10px; }

body {
  font-family: "Hiragino Maru Gothic W4 JIS2004", "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 1.5rem; }

#page img,
#page input {
  margin: 0;
  max-width: 100%;
  height: auto;
  vertical-align: top;
  -webkit-backface-visibility: hidden; }

.hover:hover {
  opacity: 0.7;
  filter: alpha(opacity=70);
  /* ie lt 8 */
  -ms-filter: "alpha(opacity=70)";
  /* ie 8 */
  -moz-opacity: 0.7;
  /* FF lt 1.5, Netscape */
  -khtml-opacity: 0.7;
  /* Safari 1.x */
  zoom: 1;
  -webkit-transition: all 0.4s ease;
  -moz-transition: all 0.4s ease;
  -o-transition: all 0.4s ease; }

@media (min-width: 750px) {
  html {
    overflow-y: hidden; }

  body {
    overflow-y: hidden; }

  .pc {
    display: block; }

  .sp {
    display: none; } }
@media (max-width: 750px) {
  .pc {
    display: none; }

  .sp {
    display: block; } }
/*
日本語フォント：@include font(noto);
英語フォント：@include font(db);
*/
/* ************************************************ */
/*                      common                      */
/* ************************************************ */
#pageLoading {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #fff;
  z-index: 999; }

@media (min-width: 750px) {
  #header {
    padding: 15px 50px 0;
    min-height: 35px;
    text-align: center; }
    #header .contact {
      font-family: 'Didact Gothic', sans-serif;
      position: absolute;
      top: 10px;
      right: 50px;
      letter-spacing: 5px; }
      #header .contact:hover {
        opacity: 0.7;
        filter: alpha(opacity=70);
        /* ie lt 8 */
        -ms-filter: "alpha(opacity=70)";
        /* ie 8 */
        -moz-opacity: 0.7;
        /* FF lt 1.5, Netscape */
        -khtml-opacity: 0.7;
        /* Safari 1.x */
        zoom: 1; }
      #header .contact a {
        padding: .3em 2.5em .3em 2em;
        border: 1px solid #777;
        display: inline-block;
        position: relative;
        color: #000;
        font-size: 1.2rem;
        text-decoration: none; }
        #header .contact a::before {
          position: absolute;
          display: block;
          top: 10px;
          right: 16px;
          width: 4px;
          height: 4px;
          border-top: 2px solid #000;
          border-right: 2px solid #000;
          -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
          content: ""; }
    #header #spGlobalNav {
      display: none; } }
@media (max-width: 750px) {
  #header {
    zoom: 1;
    position: fixed;
    width: 100%;
    background-color: #898989;
    z-index: 2; }
    #header:after {
      display: block;
      clear: both;
      height: 0;
      visibility: hidden;
      content: " "; }
    #header .logo {
      padding: 4.26667% 23.46667% 3.86667% 34.93333%;
      float: left;
      width: 29.86667%; }
    #header .contact {
      padding-top: 4.13333%;
      float: left;
      width: 6.66667%; }
      #header .contact a {
        padding-top: 70%;
        display: block;
        width: 100%;
        background: url(/img/common/header_contact_sp.png) left top no-repeat;
        background-size: 100%;
        font-size: 0; }
    #header #spGlobalNav {
      display: block; }
      #header #spGlobalNav .hamburgerBtn {
        margin: 10px 10px 0 0;
        position: absolute;
        top: 0;
        left: 0;
        display: inline-block;
        overflow: hidden;
        width: 40px;
        height: 36px;
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
        box-shadow: none;
        border-radius: none;
        border: none;
        cursor: pointer;
        -webkit-transition: background 0.3s;
        transition: background 0.3s; }
        #header #spGlobalNav .hamburgerBtn:focus {
          outline: none; }
        #header #spGlobalNav .hamburgerBtn span {
          display: block;
          position: absolute;
          top: 16px;
          right: 9px;
          left: 9px;
          height: 3px;
          background: #fff;
          -webkit-transition: background 0 0.3s;
          transition: background 0 0.3s; }
          #header #spGlobalNav .hamburgerBtn span::before {
            display: block;
            position: absolute;
            top: -10px;
            left: 0;
            width: 100%;
            height: 3px;
            background-color: #fff;
            content: "";
            -webkit-transition-duration: 0.3s, 0.3s;
            transition-duration: 0.3s, 0.3s;
            -webkit-transition-delay: 0.3s, 0;
            transition-delay: 0.3s, 0; }
          #header #spGlobalNav .hamburgerBtn span::after {
            display: block;
            position: absolute;
            bottom: -10px;
            left: 0;
            width: 100%;
            height: 3px;
            background-color: #fff;
            content: "";
            -webkit-transition-duration: 0.3s, 0.3s;
            transition-duration: 0.3s, 0.3s;
            -webkit-transition-delay: 0.3s, 0;
            transition-delay: 0.3s, 0; }
        #header #spGlobalNav .hamburgerBtn.active span {
          background: none; }
          #header #spGlobalNav .hamburgerBtn.active span::before {
            top: 0;
            -webkit-transform: rotate(45deg);
            -ms-transform: rotate(45deg);
            transform: rotate(45deg);
            -webkit-transition-delay: 0, 0.3s;
            transition-delay: 0, 0.3s; }
          #header #spGlobalNav .hamburgerBtn.active span::after {
            bottom: 0;
            -webkit-transform: rotate(-45deg);
            -ms-transform: rotate(-45deg);
            transform: rotate(-45deg);
            -webkit-transition-delay: 0, 0.3s;
            transition-delay: 0, 0.3s; }
      #header #spGlobalNav ul {
        display: none;
        position: absolute;
        top: 50px;
        left: 0;
        width: 100%;
        z-index: 999; }
        #header #spGlobalNav ul li {
          border-bottom: 1px solid #000; }
          #header #spGlobalNav ul li a {
            padding: 1em;
            display: block;
            color: #000;
            background-color: #fff;
            text-align: center;
            text-decoration: none; }
            #header #spGlobalNav ul li a br {
              display: none; }
            #header #spGlobalNav ul li a span {
              display: none; } }

aside #rightSide {
  position: fixed;
  top: 49%;
  right: 0;
  width: 50px;
  background-color: #fff;
  z-index: 3; }
  aside #rightSide span {
    padding: 12px 13px 12px 12px;
    display: block;
    cursor: pointer; }
aside #bottomSide {
  position: fixed;
  bottom: 0;
  width: 100%;
  height: 50px;
  background-color: #fff;
  text-align: center;
  z-index: 3; }
  aside #bottomSide span {
    padding-top: 13px;
    display: inline-block; }
@media (max-width: 750px) {
  aside {
    display: none; } }

#footer {
  position: fixed;
  top: 58%;
  width: 300px;
  z-index: 3; }
  #footer small {
    font-family: 'Didact Gothic', sans-serif;
    padding-top: 14px;
    display: block;
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
    -webkit-transform: rotate(-90deg);
    transform: rotate(-90deg);
    letter-spacing: .1em;
    font-size: 1.2rem; }
  @media (max-width: 750px) {
    #footer {
      display: none; } }

/* ************************************************ */
/*                       index                      */
/* ************************************************ */
@media (max-width: 750px) {
  #index #spBg,
  #index #spBg span {
    padding-bottom: 108px;
    display: block;
    position: fixed;
    top: 3%;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(/img/index/bg_main_01.jpg) center top no-repeat;
    background-size: 100% auto;
    content: ""; } }
#index #main .lightbox {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
  z-index: 2; }
  #index #main .lightbox .lightboxInner {
    padding: 3.15789% 2.31579% 3.57895% 2.31579%;
    margin: 5.26316% auto 0;
    display: none;
    width: 77.47368%;
    background-color: #fff; }
    #index #main .lightbox .lightboxInner .ttl {
      font-family: 'Didact Gothic', sans-serif;
      margin-bottom: 2.71739%; }
      #index #main .lightbox .lightboxInner .ttl h3 {
        margin-right: .5em;
        display: inline-block;
        font-size: 3rem; }
      #index #main .lightbox .lightboxInner .ttl .category {
        display: inline-block;
        font-size: 1.6rem; }
    #index #main .lightbox .lightboxInner .subImages {
      margin-bottom: 3.53261%;
      display: flex;
      justify-content: space-between; }
      #index #main .lightbox .lightboxInner .subImages li {
        width: 31.25%; }
    #index #main .lightbox .lightboxInner p {
      font-family: 'Noto Sans JP', sans-serif;
      font-size: 1.4rem; }
  #index #main .lightbox .prevBtn {
    margin-top: -15px;
    position: absolute;
    top: 50%;
    left: 2.47423%;
    cursor: pointer; }
  #index #main .lightbox .nextBtn {
    margin-top: -15px;
    position: absolute;
    top: 50%;
    right: 2.47423%;
    cursor: pointer; }
  #index #main .lightbox .closeBtn {
    margin: 1.47368% 8.84211% 0% 0%;
    margin-left: auto;
    width: 1.89474%;
    cursor: pointer; }
@media (min-width: 750px) {
  #index #main {
    margin: 0 50px 50px;
    position: relative;
    height: 800px;
    overflow: hidden;
    z-index: 1; }
    #index #main.normal {
      background-size: auto 100%; }
    #index #main.adjust {
      background-size: 100% auto; }
    #index #main #bgArea {
      position: absolute;
      top: 0;
      left: 0;
      display: flex;
      width: 100%;
      z-index: 1; }
      #index #main #bgArea span {
        display: block;
        width: 100%;
        height: 100%; }
      #index #main #bgArea #leftBg {
        width: 32%;
        background: url(/img/index/bg_main_01.jpg) center top no-repeat;
        background-size: cover; }
        #index #main #bgArea #leftBg span {
          background: url(/img/index/bg_main_01.jpg) center top no-repeat;
          background-size: cover; }
      #index #main #bgArea #centerBg {
        width: 36%;
        background: url(/img/index/bg_main_02.jpg) center top no-repeat;
        background-size: cover; }
        #index #main #bgArea #centerBg span {
          background: url(/img/index/bg_main_02.jpg) center top no-repeat;
          background-size: cover; }
      #index #main #bgArea #rightBg {
        width: 32%;
        background: url(/img/index/bg_main_03.jpg) center top no-repeat;
        background-size: cover; }
        #index #main #bgArea #rightBg span {
          background: url(/img/index/bg_main_03.jpg) center top no-repeat;
          background-size: cover; }
    #index #main #pcGlobalNav {
      position: absolute;
      top: 0;
      right: 0;
      display: flex;
      justify-content: center;
      flex-direction: column;
      width: 0;
      height: 100%;
      background-color: #fff;
      z-index: 3; }
      #index #main #pcGlobalNav li {
        font-family: 'Didact Gothic', sans-serif;
        margin-bottom: 0.5em;
        padding-left: 100px;
        display: block; }
        #index #main #pcGlobalNav li a {
          color: #111;
          font-size: 1.6rem;
          text-decoration: none; }
          #index #main #pcGlobalNav li a:hover {
            text-decoration: underline; } }
@media (max-width: 750px) {
  #index #main {
    position: relative;
    background: none;
    z-index: 1; }
    #index #main #pcGlobalNav {
      display: none; }
    #index #main .lightbox {
      position: fixed; }
      #index #main .lightbox .lightboxInner {
        padding: 4% 4% 4.53333% 4%;
        margin: 13.33333% auto 0;
        width: 66.66667%; }
      #index #main .lightbox .closeBtn {
        margin: 2.66667% 13.33333% 0% 0%;
        margin-left: auto;
        width: 6.66667%;
        cursor: pointer; }
        #index #main .lightbox .closeBtn img {
          width: 100%; } }
#index #main section {
  position: relative;
  z-index: 2; }
  #index #main section .outline {
    display: flex;
    align-items: center; }
  #index #main section .commonHead {
    font-family: 'Didact Gothic', sans-serif;
    margin-bottom: 40px;
    padding: .3em 0 .4em 0;
    border: 1px solid #fff;
    width: 180px;
    line-height: 1;
    color: #fff;
    font-size: 2.2rem;
    text-align: center;
    letter-spacing: .3em; }
  @media (max-width: 750px) {
    #index #main section .outline {
      display: block; }
    #index #main section .commonHead {
      margin: 0 auto 14.66667%;
      width: 48%; } }
#index #main #top {
  display: block;
  align-items: center; }
  #index #main #top .outline {
    justify-content: center; }
    #index #main #top .outline .inner {
      text-align: center; }
      #index #main #top .outline .inner h2 {
        margin-bottom: 30px;
        text-align: center; }
      #index #main #top .outline .inner .desc {
        font-family: 'Didact Gothic', sans-serif;
        margin-bottom: 40px;
        color: #fff;
        font-size: 1.6rem;
        text-align: center;
        letter-spacing: .2em; }
      #index #main #top .outline .inner .btn {
        -moz-transition: 0.4s;
        -o-transition: 0.4s;
        -webkit-transition: 0.4s;
        transition: 0.4s;
        margin: 0 auto;
        width: 170px;
        display: block; }
        #index #main #top .outline .inner .btn:hover {
          opacity: 0.7;
          filter: alpha(opacity=70);
          /* ie lt 8 */
          -ms-filter: "alpha(opacity=70)";
          /* ie 8 */
          -moz-opacity: 0.7;
          /* FF lt 1.5, Netscape */
          -khtml-opacity: 0.7;
          /* Safari 1.x */
          zoom: 1; }
  @media (max-width: 750px) {
    #index #main #top .outline {
      display: flex; }
      #index #main #top .outline .inner {
        text-align: left; }
        #index #main #top .outline .inner h2 {
          padding: 0% 25.06667% 3.33333% 15.06667%; }
        #index #main #top .outline .inner .desc {
          padding: 0% 11.73333% 3.33333% 15.06667%;
          font-size: 1.4rem;
          text-align: left;
          letter-spacing: .2em; }
        #index #main #top .outline .inner .btn {
          padding: 0% 28.93333% 0% 15.06667%;
          width: auto; } }
#index #main #about {
  display: none;
  background: url(/img/index/about_bg.png) 90% 50% no-repeat;
  background-size: 40.52632%; }
  #index #main #about .outline .inner {
    padding-left: 75px; }
    #index #main #about .outline .inner .copy {
      margin-bottom: 20px; }
    #index #main #about .outline .inner .desc {
      font-family: 'Noto Sans JP', sans-serif;
      margin-bottom: 30px;
      line-height: 1.616;
      color: #fff;
      font-size: 1.6rem; }
    #index #main #about .outline .inner .btn {
      -moz-transition: 0.4s;
      -o-transition: 0.4s;
      -webkit-transition: 0.4s;
      transition: 0.4s;
      display: block;
      width: 170px; }
      #index #main #about .outline .inner .btn:hover {
        opacity: 0.7;
        filter: alpha(opacity=70);
        /* ie lt 8 */
        -ms-filter: "alpha(opacity=70)";
        /* ie 8 */
        -moz-opacity: 0.7;
        /* FF lt 1.5, Netscape */
        -khtml-opacity: 0.7;
        /* Safari 1.x */
        zoom: 1; }
  @media (max-width: 750px) {
    #index #main #about {
      padding: 13.06667% 0;
      display: block;
      background: none; }
      #index #main #about .outline .inner {
        margin: 0 auto;
        padding: 0;
        width: 74.66667%; }
        #index #main #about .outline .inner .commonHead {
          margin: 0 auto 19.64286%;
          width: 64.28571%; }
        #index #main #about .outline .inner .copy {
          margin-bottom: 7.14286%; }
        #index #main #about .outline .inner .desc {
          margin-bottom: 16.07143%; }
        #index #main #about .outline .inner .btn {
          margin: 0 auto;
          width: 75%; } }
#index #main #works {
  display: none; }
  #index #main #works .outline .inner {
    padding-left: 75px;
    position: relative;
    z-index: 1; }
    #index #main #works .outline .inner .workList {
      zoom: 1; }
      #index #main #works .outline .inner .workList:after {
        display: block;
        clear: both;
        height: 0;
        visibility: hidden;
        content: " "; }
      #index #main #works .outline .inner .workList li {
        margin: 0% 2.28571% 3.42857% 0%;
        position: relative;
        float: left;
        width: 21.14286%;
        cursor: pointer; }
        #index #main #works .outline .inner .workList li .image {
          position: relative;
          z-index: 1; }
        #index #main #works .outline .inner .workList li .txt {
          font-family: 'Didact Gothic', sans-serif;
          display: none;
          position: absolute;
          top: 0;
          left: 0;
          width: 100%;
          height: 100%;
          color: #fff;
          z-index: 2; }
          #index #main #works .outline .inner .workList li .txt .name {
            padding: 3em 0 0 8%;
            font-size: 1.6rem; }
          #index #main #works .outline .inner .workList li .txt .category {
            padding-left: 8%;
            font-size: 1.4rem; }
        #index #main #works .outline .inner .workList li .data {
          display: none; }
        #index #main #works .outline .inner .workList li:hover .txt {
          display: block;
          background-color: rgba(0, 0, 0, 0.7); }
  @media (max-width: 750px) {
    #index #main #works {
      padding: 13.06667% 0;
      display: block; }
      #index #main #works .outline .inner {
        margin: 0 auto;
        padding: 0;
        width: 86.66667%; }
        #index #main #works .outline .inner .commonHead {
          margin: 0 auto 16.92308%;
          width: 55.38462%; }
        #index #main #works .outline .inner .workList li {
          margin: 0 0 7.69231%;
          width: 46.92308%; }
          #index #main #works .outline .inner .workList li:nth-child(odd) {
            float: left; }
          #index #main #works .outline .inner .workList li:nth-child(even) {
            float: right; }
          #index #main #works .outline .inner .workList li .txt {
            display: block; }
            #index #main #works .outline .inner .workList li .txt .name {
              display: none; }
            #index #main #works .outline .inner .workList li .txt .category {
              padding: 0;
              position: absolute;
              bottom: 5%;
              left: 10%;
              font-weight: bold;
              font-size: 1.4rem; }
          #index #main #works .outline .inner .workList li:hover .txt {
            background: none; } }
#index #main #recruit {
  display: none; }
  #index #main #recruit .outline .inner {
    zoom: 1;
    padding-left: 75px; }
    #index #main #recruit .outline .inner:after {
      display: block;
      clear: both;
      height: 0;
      visibility: hidden;
      content: " "; }
    #index #main #recruit .outline .inner .copy {
      margin-bottom: 20px; }
    #index #main #recruit .outline .inner .desc {
      font-family: 'Noto Sans JP', sans-serif;
      margin-bottom: 30px;
      line-height: 1.616;
      color: #fff;
      font-size: 1.4rem; }
    #index #main #recruit .outline .inner .btn {
      -moz-transition: 0.4s;
      -o-transition: 0.4s;
      -webkit-transition: 0.4s;
      transition: 0.4s;
      display: block;
      width: 170px; }
      #index #main #recruit .outline .inner .btn:hover {
        opacity: 0.7;
        filter: alpha(opacity=70);
        /* ie lt 8 */
        -ms-filter: "alpha(opacity=70)";
        /* ie 8 */
        -moz-opacity: 0.7;
        /* FF lt 1.5, Netscape */
        -khtml-opacity: 0.7;
        /* Safari 1.x */
        zoom: 1; }
    #index #main #recruit .outline .inner .solution {
      margin-right: 11.65714%;
      float: left;
      width: 40%; }
    #index #main #recruit .outline .inner .account {
      float: left;
      width: 40%; }
  @media (max-width: 750px) {
    #index #main #recruit {
      padding: 13.06667% 0;
      display: block;
      background: none; }
      #index #main #recruit .outline .inner {
        margin: 0 auto;
        padding: 0;
        width: 74.66667%; }
        #index #main #recruit .outline .inner .commonHead {
          margin: 0 auto 19.64286%;
          width: 64.28571%; }
        #index #main #recruit .outline .inner .copy {
          margin: 0 auto 7.14286%;
          width: 69.64286%; }
        #index #main #recruit .outline .inner .desc {
          margin-bottom: 12.5%; }
        #index #main #recruit .outline .inner .btn {
          margin: 0 auto;
          width: 75%; }
        #index #main #recruit .outline .inner .solution {
          margin: 0 0 17.85714%;
          float: none;
          width: auto; }
        #index #main #recruit .outline .inner .account {
          float: none;
          width: auto; } }
#index #main #access {
  display: none; }
  #index #main #access .outline .inner {
    padding-left: 75px;
    width: 95%; }
    #index #main #access .outline .inner .commonHead {
      margin-bottom: 0; }
    #index #main #access .outline .inner .layout {
      font-family: 'Noto Sans JP', sans-serif;
      zoom: 1; }
      #index #main #access .outline .inner .layout:after {
        display: block;
        clear: both;
        height: 0;
        visibility: hidden;
        content: " "; }
      #index #main #access .outline .inner .layout .address {
        margin-right: 2.28571%;
        padding-top: 2em;
        float: left;
        width: 30.74286%; }
        #index #main #access .outline .inner .layout .address p {
          margin-bottom: .5em;
          line-height: 1.8;
          color: #fff;
          font-size: 1.4rem; }
      #index #main #access .outline .inner .layout .gmap {
        float: left;
        width: 58.51429%; }
        #index #main #access .outline .inner .layout .gmap img {
          width: 100%;
          max-width: 512px; }
    #index #main #access .outline .inner .btn {
      -moz-transition: 0.4s;
      -o-transition: 0.4s;
      -webkit-transition: 0.4s;
      transition: 0.4s;
      display: block;
      width: 170px; }
      #index #main #access .outline .inner .btn:hover {
        opacity: 0.7;
        filter: alpha(opacity=70);
        /* ie lt 8 */
        -ms-filter: "alpha(opacity=70)";
        /* ie 8 */
        -moz-opacity: 0.7;
        /* FF lt 1.5, Netscape */
        -khtml-opacity: 0.7;
        /* Safari 1.x */
        zoom: 1; }
  @media (max-width: 750px) {
    #index #main #access {
      padding: 13.06667% 0;
      display: block; }
      #index #main #access .outline .inner {
        margin: 0 auto;
        padding: 0;
        width: 74.66667%; }
        #index #main #access .outline .inner .commonHead {
          margin: 0 auto 19.64286%;
          width: 64.28571%; }
        #index #main #access .outline .inner .layout .address {
          margin: 0 0 3.57143%;
          padding-top: 0;
          float: none;
          width: auto; }
        #index #main #access .outline .inner .layout .gmap {
          float: none;
          width: auto; }
          #index #main #access .outline .inner .layout .gmap #map {
            position: relative;
            height: 300px;
            z-index: 1; }
        #index #main #access .outline .inner .btn {
          display: none; } }
@media (min-width: 750px) {
  #index #main #contact {
    display: none; }
    #index #main #contact .outline .inner {
      padding-left: 75px;
      width: 95%; }
      #index #main #contact .outline .inner .desc {
        font-family: 'Noto Sans JP', sans-serif;
        margin-bottom: 40px;
        line-height: 1.616;
        color: #fff;
        font-size: 1.6rem; }
      #index #main #contact .outline .inner form {
        font-family: 'Noto Sans JP', sans-serif;
        width: 91.42857%; }
        #index #main #contact .outline .inner form dl:nth-child(odd) {
          margin-bottom: 20px;
          clear: both;
          float: left; }
        #index #main #contact .outline .inner form dl:nth-child(even) {
          float: right; }
        #index #main #contact .outline .inner form dl:nth-child(1), #index #main #contact .outline .inner form dl:nth-child(2), #index #main #contact .outline .inner form dl:nth-child(3), #index #main #contact .outline .inner form dl:nth-child(4) {
          zoom: 1;
          width: 47.5%; }
          #index #main #contact .outline .inner form dl:nth-child(1):after, #index #main #contact .outline .inner form dl:nth-child(2):after, #index #main #contact .outline .inner form dl:nth-child(3):after, #index #main #contact .outline .inner form dl:nth-child(4):after {
            display: block;
            clear: both;
            height: 0;
            visibility: hidden;
            content: " "; }
          #index #main #contact .outline .inner form dl:nth-child(1) dt, #index #main #contact .outline .inner form dl:nth-child(2) dt, #index #main #contact .outline .inner form dl:nth-child(3) dt, #index #main #contact .outline .inner form dl:nth-child(4) dt {
            padding: 1.31579% 1.31579% 0% 0%;
            float: left;
            width: 30.26316%;
            color: #fff;
            font-weight: bold; }
            #index #main #contact .outline .inner form dl:nth-child(1) dt::after, #index #main #contact .outline .inner form dl:nth-child(2) dt::after, #index #main #contact .outline .inner form dl:nth-child(3) dt::after, #index #main #contact .outline .inner form dl:nth-child(4) dt::after {
              color: #e60012;
              font-size: 1rem;
              content: "※"; }
            #index #main #contact .outline .inner form dl:nth-child(1) dt .note, #index #main #contact .outline .inner form dl:nth-child(2) dt .note, #index #main #contact .outline .inner form dl:nth-child(3) dt .note, #index #main #contact .outline .inner form dl:nth-child(4) dt .note {
              font-size: 1.2rem; }
          #index #main #contact .outline .inner form dl:nth-child(1) dd, #index #main #contact .outline .inner form dl:nth-child(2) dd, #index #main #contact .outline .inner form dl:nth-child(3) dd, #index #main #contact .outline .inner form dl:nth-child(4) dd {
            float: right;
            width: 68.42105%; }
            #index #main #contact .outline .inner form dl:nth-child(1) dd input, #index #main #contact .outline .inner form dl:nth-child(2) dd input, #index #main #contact .outline .inner form dl:nth-child(3) dd input, #index #main #contact .outline .inner form dl:nth-child(4) dd input {
              font-family: 'Noto Sans JP', sans-serif;
              padding: 3%;
              border: none;
              display: inline-block;
              width: 94%;
              background-color: #fff;
              font-size: 1.4rem; }
        #index #main #contact .outline .inner form dl:nth-child(5) {
          zoom: 1;
          margin-bottom: 20px;
          clear: both;
          float: none;
          width: auto; }
          #index #main #contact .outline .inner form dl:nth-child(5):after {
            display: block;
            clear: both;
            height: 0;
            visibility: hidden;
            content: " "; }
          #index #main #contact .outline .inner form dl:nth-child(5) dt {
            padding: 3.125% 0.625% 0% 0%;
            float: left;
            width: 14.375%;
            color: #fff; }
            #index #main #contact .outline .inner form dl:nth-child(5) dt::after {
              color: #e60012;
              font-size: 1rem;
              content: "※"; }
          #index #main #contact .outline .inner form dl:nth-child(5) dd {
            float: right;
            width: 85%; }
            #index #main #contact .outline .inner form dl:nth-child(5) dd textarea {
              font-family: 'Noto Sans JP', sans-serif;
              padding: 1%;
              border: none;
              display: inline-block;
              width: 98%;
              height: 80px;
              background-color: #fff;
              font-size: 1.4rem; }
        #index #main #contact .outline .inner form button {
          margin: 0 auto;
          padding: 0;
          border: 0;
          display: block;
          width: 170px;
          cursor: pointer; }
          #index #main #contact .outline .inner form button:hover {
            opacity: 0.7;
            filter: alpha(opacity=70);
            /* ie lt 8 */
            -ms-filter: "alpha(opacity=70)";
            /* ie 8 */
            -moz-opacity: 0.7;
            /* FF lt 1.5, Netscape */
            -khtml-opacity: 0.7;
            /* Safari 1.x */
            zoom: 1; } }
@media (max-width: 750px) {
  #index #main #contact {
    padding: 13.06667% 0;
    display: block; }
    #index #main #contact .outline .inner {
      margin: 0 auto;
      padding: 0;
      width: 74.66667%; }
      #index #main #contact .outline .inner .commonHead {
        margin: 0 auto 8.92857%;
        width: 64.28571%; }
      #index #main #contact .outline .inner .desc {
        display: none; }
      #index #main #contact .outline .inner form dl {
        margin-bottom: 4.46429%; }
        #index #main #contact .outline .inner form dl dt {
          margin-bottom: 0.89286%;
          color: #fff;
          font-weight: bold;
          font-size: 1.4rem; }
          #index #main #contact .outline .inner form dl dt::after {
            color: #e60012;
            font-size: 1rem;
            content: "※"; }
          #index #main #contact .outline .inner form dl dt .note {
            font-size: 1.2rem; }
        #index #main #contact .outline .inner form dl dd input {
          padding: 3%;
          width: 94%; }
        #index #main #contact .outline .inner form dl dd textarea {
          padding: 3%;
          width: 94%;
          height: 70px; }
      #index #main #contact .outline .inner form button {
        margin: 0 auto;
        padding: 0;
        border: 0;
        display: block;
        width: 75%;
        cursor: pointer; }
        #index #main #contact .outline .inner form button img {
          width: 100%; } }
