@charset "UTF-8";
/****************************************
Setting
*****************************************/
html, body, div, span, applet, object, iframe, 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, dl, dt, dd, ol, ul, li, fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td, figure {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-weight: normal;
  font-style: normal;
  font-family: inherit;
  vertical-align: baseline; }

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, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, figure {
  _text-align: left;
  /* IE6センタリング */ }

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

* {
  letter-spacing: 0; }

/* IE7 */
ul {
  list-style: none; }

body {
  font-size: 16px;
  line-height: 1.8em;
  color: #333;
  position: relative;
  /* IE7拡大用 */
  _text-align: center;
  /* IE6センタリング */ }

/* font-style */
strong {
  font-weight: bold;
  /* font-style */ }

em {
  font-weight: bold;
  /* font-style */ }

.itaric {
  font-style: italic; }

.small {
  font-size: 80%; }

.big {
  font-size: 140%;
  font-weight: bold; }

.clear {
  clear: both; }

.hidden {
  display: none; }

.no-align, .no-alignment, .no-wrap, .wrapping {
  overflow: hidden; }

:focus {
  -moz-outline-style: none; }

/* Links */
a, a:visited {
  color: #0088cc;
  text-decoration: none; }

a:hover, a:active {
  text-decoration: underline; }

a:active, a:focus {
  outline: 0 none; }

/****************************************
img png_gif
*****************************************/
img {
  behavior: url(iepngfix.htc); }

/*** #a37e39 gold ***/
/*** #9e2226 red ***/
/*** #5d5b57 darkgray***/
/*** #E67E22 ***/
/*** #D35400 ***/
/*** #F1C40F ***/
/*** #F39C12 ***/
/*** #FF3333 ***/
/*** #33CCFF ***/
/*** #FFFF00 ***/
/*** #FFF462 ***/
/*** #3596BC ***/
/*** #325D80 ***/
/*** #8E44AD***/
/*** #16A085 ***/
/*** #FF6600 ***/
/*** #FF99CC ***/
.w10 {
  width: 10%; }

.w15 {
  width: 15%; }

.w20 {
  width: 20%; }

.w25 {
  width: 25%; }

.w30 {
  width: 30%; }

.w35 {
  width: 35%; }

.w40 {
  width: 40%; }

.w45 {
  width: 45%; }

.w50 {
  width: 50%; }

.w55 {
  width: 55%; }

.w60 {
  width: 60%; }

.w65 {
  width: 65%; }

.w70 {
  width: 70%; }

.w75 {
  width: 75%; }

.w80 {
  width: 80%; }

.w85 {
  width: 85%; }

.w90 {
  width: 90%; }

.w95 {
  width: 95%; }

.w100 {
  width: 100%; }

/****************************************
font-style
*****************************************/
body {
  font-family: 'Open Sans' , 'Helvetica Neue' , Helvetica , Arial , Verdana ,  'Yu Gothic Medium', '游ゴシック Medium', YuGothic, "游ゴシック体",  'ヒラギノ角ゴ Pro W3' , 'Hiragino Kaku Gothic Pro' , 'Meiryo UI' , "メイリオ" , Meiryo ,sans-serif;
  font-weight: normal;
  font-weight: 400;
  font-size: 0.9285em;
  font-size: 14px;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: subpixel-antialiased; }

.body-copy {
  font-family: 'Open Sans' , 'Helvetica Neue' , Helvetica , Arial , Verdana ,  'Yu Gothic Medium', '游ゴシック Medium', YuGothic, "游ゴシック体",  'ヒラギノ角ゴ Pro W3' , 'Hiragino Kaku Gothic Pro' , 'Meiryo UI' , "メイリオ" , Meiryo ,sans-serif; }

/*　Safari・Chrome用指定　*/
@media screen and (-webkit-min-device-pixel-ratio: 0) {
  body {
    font-family: 'Open Sans' , 'Helvetica Neue' , Helvetica , Arial , Verdana ,  'Yu Gothic Medium', '游ゴシック Medium', YuGothic, "游ゴシック体",  'ヒラギノ角ゴ Pro W3' , 'Hiragino Kaku Gothic Pro' , 'Meiryo UI' , "メイリオ" , Meiryo ,sans-serif;
    font-weight: normal;
    font-weight: 400;
    font-size: 0.9285em;
    font-size: 14px;
    -webkit-text-size-adjust: 100%;
    -webkit-font-smoothing: subpixel-antialiased; } }
@media screen and (max-width: 390px) {
  body {
    /* font-size: 1em; */
    font-size: 0.9285em; } }
.number {
  font-size: 1.2em; }

span.pre {
  white-space: pre;
  white-space: -moz-pre-wrap; }

/***********************************
one-page-scroll edit-style
***********************************/
html, body {
  position: relative;
  width: 100%;
  height: 100%;
  margin: 0 0;
  padding: 0 0;
  color: #333333; }

*, *:before, *:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box; }

a, a:visited {
  color: #333;
  text-decoration: none; }

a:hover {
  color: #666;
  text-decoration: none; }

img {
  width: 100%;
  border: 0 #FFF;
  margin: 0;
  padding: 0; }

h3, h4, h5, h6 {
  margin: 0;
  padding: 0; }

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

.left, .right {
  display: inline-block; }

.mt-1 {
  margin-top: 1em; }

.mt-2 {
  margin-top: 2em; }

.mt-3 {
  margin-top: 3em; }

.mt-6 {
  margin-top: 6em; }

.mt-10 {
  margin-top: 10em; }

.mb-1 {
  margin-bottom: 1em; }

.mb-2 {
  margin-bottom: 2em; }

.mb-3 {
  margin-bottom: 3em; }

.mb-6 {
  margin-bottom: 6em; }

.mb-10 {
  margin-bottom: 10em; }

.pt-1 {
  padding-top: 1em; }

.pt-1-5 {
  padding-top: 1.5em; }

.pt-2 {
  padding-top: 2em; }

.pt-3 {
  padding-top: 3em; }

.pt-4 {
  padding-top: 4em; }

.pt-6 {
  padding-top: 6em; }

.pb-1 {
  padding-bottom: 1em; }

.pb-2 {
  padding-bottom: 2em; }

.pb-3 {
  padding-bottom: 3em; }

.pb-4 {
  padding-bottom: 4em; }

.pb-5 {
  padding-bottom: 5em; }

.pb-6 {
  padding-bottom: 6em; }

.pb-7 {
  padding-bottom: 7em; }

.pb-10 {
  padding-bottom: 10em; }

.ind-1 {
  text-indent: 1em; }

.ind-2 {
  text-indent: 2em; }

.ind-3 {
  text-indent: 3em; }

/* view-size-point */
/*** #028484 Greenr rgb(02,132,132) ***/
/*** #0068B7 Blue rgb(0,104,183) ***/
/*** #999999 ***/
/*** #BAD7E0  skyblue ***/
/*** #00A0E9 ***/
/*** #FFF100 ***/
/*** #ed8f26 ***/
/*** #87bd42 ***/
/*** #30a1d2 ***/
/*** #4c2d13 ***/
body .h1, body .h2, body .h3, body .h4, body .h5, body .h6, body h1, body h2, body h3, body h4, body h5, body h6, body p {
  color: #333; }

img {
  vertical-align: top; }

/**************************
font-color-setting
**************************/
html, body {
  color: #333; }

.text-wht {
  color: #FFF; }

.text-gray {
  color: #666; }

.text-small {
  font-size: 0.8em; }

.text-x-small {
  font-size: 0.7em; }

.text-large {
  font-size: 1.2em; }

p.text-bold {
  font-weight: bold !important; }

body .container-fluid p,
body .container p {
  line-height: 1.8;
  font-size: 16px; }

body .container-fluid p.lh-1,
body .container p.lh-1 {
  line-height: 1; }
body .container-fluid p.lh-1-5,
body .container p.lh-1-5 {
  line-height: 1.5; }
body .container-fluid p.lh-1-6,
body .container p.lh-1-6 {
  line-height: 1.6; }
body .container-fluid p.lh-1-8,
body .container p.lh-1-8 {
  line-height: 1.8; }
body .container-fluid p.lh-2,
body .container p.lh-2 {
  line-height: 2; }
body .container-fluid p.lh-2-3,
body .container p.lh-2-3 {
  line-height: 2.3; }
body .container-fluid p.lh-2-5,
body .container p.lh-2-5 {
  line-height: 2.5; }
body .container-fluid p.lh-3,
body .container p.lh-3 {
  line-height: 3; }
body .container-fluid p.fs-9,
body .container p.fs-9 {
  font-size: 9px; }
body .container-fluid p.fs-10,
body .container p.fs-10 {
  font-size: 10px; }
body .container-fluid p.fs-12,
body .container p.fs-12 {
  font-size: 12px; }
body .container-fluid p.fs-13,
body .container p.fs-13 {
  font-size: 13px; }
body .container-fluid p.fs-14,
body .container p.fs-14 {
  font-size: 14px; }
body .container-fluid p.fs-15,
body .container p.fs-15 {
  font-size: 15px; }
body .container-fluid p.text-center-cstm,
body .container p.text-center-cstm {
  text-align: center; }
  @media screen and (max-width: 328px) {
    body .container-fluid p.text-center-cstm,
    body .container p.text-center-cstm {
      text-align: left; } }

/**************************
hover
**************************/
a {
  -webkit-backface-visibility: hidden;
  /* chrome */
  backface-visibility: hidden;
  /* chrome */ }
  a img {
    -webkit-transition: all 0.4s;
    -moz-transition: all 0.4s;
    transition: all 0.4s;
    opacity: 1;
    -webkit-backface-visibility: hidden;
    /* chrome */
    backface-visibility: hidden;
    /* chrome */
    background: transparent;
    /* chrome */ }
  a:hover img {
    /* opacity: 0.6; */ }

/**************************
responsive
**************************/
body #wrap {
  width: 100%;
  overflow: hidden !important; }

/*
@media (min-width: 1200px) {
        .container {
            width: 960px;
        }
}
*/
body .container {
  width: 100%; }

@media (min-width: 1328px) {
  body .container {
    width: 1280px; } }
.hidden-sp {
  display: block; }
  @media (max-width: 768px) {
    .hidden-sp {
      display: none; } }

.visible-sp {
  display: none; }
  @media (max-width: 768px) {
    .visible-sp {
      display: block; } }

br.hidden-sp {
  display: inline; }
  @media (max-width: 768px) {
    br.hidden-sp {
      display: none; } }

.visible-sp {
  display: none; }
  @media (max-width: 768px) {
    .visible-sp {
      display: inline; } }

/**************************
header
**************************/
header {
  margin: 0 auto;
  /* overflow: hidden; */
  *zoom: 1;
  text-align: center;
  box-sizing: border-box; }

/**************************
global-menu
*************************/
.global-menu-wrap {
  position: relative;
  display: inline-block;
  width: 100%;
  margin: 0 0;
  padding: 0 0;
  height: 50px;
  text-align: center;
  vertical-align: middle;
  -webkit-transition: all .5s ease;
  -moz-transition: all .5s ease;
  -ms-transition: all .5s ease;
  transition: all .5s ease;
  pointer-events: none; }
  @media screen and (min-width: 768px) {
    .global-menu-wrap {
      pointer-events: auto; } }

.global-menu {
  display: block;
  width: 100%;
  margin: 0 auto;
  -webkit-transition: all .3s ease;
  -moz-transition: all .3s ease;
  -ms-transition: all .3s ease;
  transition: all .3s ease; }
  .global-menu ul {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    /* justify-content:center; */
    justify-content: flex-start;
    height: auto;
    width: 100%;
    margin: 0 auto;
    gap: 15px 30px; }
    @media screen and (min-width: 768px) {
      .global-menu ul {
        display: flex;
        flex-wrap: nowrap;
        justify-content: space-between;
        height: 88px;
        gap: auto auto; } }
  .global-menu li {
    display: inline-block;
    margin: 0 0;
    padding: 0 0;
    text-align: center;
    width: 98px;
    height: 88px;
    vertical-align: top;
    -webkit-transition: all .3s ease;
    -moz-transition: all .3s ease;
    -ms-transition: all .3s ease;
    transition: all .3s ease; }
    @media screen and (min-width: 768px) {
      .global-menu li {
        width: 98px;
        height: 88px; } }
    .global-menu li a {
      position: relative;
      display: block;
      width: 100%;
      height: 100%;
      margin: 0 0;
      padding: 0 0;
      line-height: 0;
      color: #333;
      font-size: 14px;
      /* letter-spacing: 0.15em; */
      font-weight: bold;
      vertical-align: top;
      cursor: pointer;
      -webkit-transition: all .3s ease;
      -moz-transition: all .3s ease;
      -ms-transition: all .3s ease;
      transition: all .3s ease;
      pointer-events: auto; }
      .global-menu li a > img {
        height: auto;
        left: 0;
        position: absolute;
        width: 100%;
        vertical-align: top; }
      .global-menu li a span {
        position: absolute;
        display: inline-block;
        width: 100%;
        height: 14px;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        margin: auto auto;
        color: #FFF;
        font-size: 12px;
        line-height: 1;
        text-align: center;
        font-weight: bold; }
        .global-menu li a span.brspan {
          height: 30px;
          line-height: 1.2; }
        .global-menu li a span.whtspan {
          /* color: #FFF; */ }
        .global-menu li a span.iconspan {
          width: 33px;
          height: 33px;
          transform: translate(0, -2px); }
      .global-menu li a:hover {
        -moz-transform: scale(0.98);
        -webkit-transform: scale(0.98);
        -ms-transform: scale(0.98);
        transform: scale(0.98); }
        .global-menu li a:hover > img:last-of-type {
          opacity: 0;
          transition: opacity .3s; }
        .global-menu li a:hover > img {
          opacity: 1; }
        .global-menu li a:hover span {
          color: #000; }

.home .global-menu-wrap {
  position: relative;
  display: inline-block;
  width: 100%;
  margin: 0 0;
  padding: 0 0;
  height: 50px;
  text-align: center;
  vertical-align: middle;
  -webkit-transition: all .5s ease;
  -moz-transition: all .5s ease;
  -ms-transition: all .5s ease;
  transition: all .5s ease; }

.home .global-menu {
  display: block;
  width: 100%;
  margin: 0 auto;
  -webkit-transition: all .3s ease;
  -moz-transition: all .3s ease;
  -ms-transition: all .3s ease;
  transition: all .3s ease; }
  .home .global-menu ul {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    /* justify-content:center; */
    justify-content: flex-start;
    height: auto;
    width: 100%;
    margin: 0 auto;
    gap: 15px 30px; }
    @media screen and (min-width: 768px) {
      .home .global-menu ul {
        display: flex;
        flex-wrap: nowrap;
        justify-content: space-between;
        height: 88px;
        gap: auto auto; } }
    @media screen and (min-width: 1280px) {
      .home .global-menu ul {
        height: calc(88 / 1280 * 100vw); } }
  .home .global-menu li {
    display: inline-block;
    margin: 0 0;
    padding: 0 0;
    text-align: center;
    width: 98px;
    height: 88px;
    vertical-align: top;
    -webkit-transition: all .3s ease;
    -moz-transition: all .3s ease;
    -ms-transition: all .3s ease;
    transition: all .3s ease; }
    @media screen and (min-width: 768px) {
      .home .global-menu li {
        width: 98px;
        height: 88px; } }
    @media screen and (min-width: 1280px) {
      .home .global-menu li {
        width: calc(98 / 1280 * 100vw);
        height: calc(88 / 1280 * 100vw); } }
    .home .global-menu li a {
      position: relative;
      display: block;
      width: 100%;
      height: 100%;
      margin: 0 0;
      padding: 0 0;
      line-height: 0;
      color: #333;
      font-size: 14px;
      /* letter-spacing: 0.15em; */
      font-weight: bold;
      vertical-align: top;
      cursor: pointer;
      -webkit-transition: all .3s ease;
      -moz-transition: all .3s ease;
      -ms-transition: all .3s ease;
      transition: all .3s ease; }
      @media screen and (min-width: 1280px) {
        .home .global-menu li a {
          font-size: calc(14 / 1280 * 100vw); } }
      .home .global-menu li a > img {
        height: auto;
        left: 0;
        position: absolute;
        width: 100%;
        vertical-align: top; }
      .home .global-menu li a span {
        position: absolute;
        display: inline-block;
        width: 100%;
        height: 14px;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        margin: auto auto;
        color: #FFF;
        font-size: 12px;
        line-height: 1;
        text-align: center;
        font-weight: bold; }
        .home .global-menu li a span.brspan {
          height: 30px;
          line-height: 1.2; }
          @media screen and (min-width: 1280px) {
            .home .global-menu li a span.brspan {
              height: calc(30 / 1280 * 100vw); } }
        .home .global-menu li a span.whtspan {
          /* color: #FFF; */ }
        .home .global-menu li a span.iconspan {
          width: 33px;
          height: 33px;
          transform: translate(0, -2px); }
          @media screen and (min-width: 1280px) {
            .home .global-menu li a span.iconspan {
              width: calc(33 / 1280 * 100vw);
              height: calc(33 / 1280 * 100vw); } }
        @media screen and (min-width: 1280px) {
          .home .global-menu li a span {
            height: 14px;
            height: calc(14 / 1280 * 100vw);
            font-size: 12px;
            font-size: calc(12 / 1280 * 100vw); } }
      .home .global-menu li a:hover {
        -moz-transform: scale(0.98);
        -webkit-transform: scale(0.98);
        -ms-transform: scale(0.98);
        transform: scale(0.98); }
        .home .global-menu li a:hover > img:last-of-type {
          opacity: 0;
          transition: opacity .3s; }
        .home .global-menu li a:hover > img {
          opacity: 1; }
        .home .global-menu li a:hover span {
          color: #000; }

header .global-menu-wrap {
  max-width: 100%; }
  @media screen and (min-width: 1176px) {
    header .global-menu-wrap {
      max-width: 676px; } }
  header .global-menu-wrap .global-menu ul {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    height: auto;
    width: 100%;
    margin: 0 auto;
    gap: 15px 30px; }
    @media screen and (min-width: 1176px) {
      header .global-menu-wrap .global-menu ul {
        display: flex;
        flex-wrap: nowrap;
        justify-content: space-between;
        height: 88px;
        gap: auto auto; } }
  header .global-menu-wrap .global-menu ul li:not(.current) {
    display: none; }
    @media screen and (min-width: 840px) {
      header .global-menu-wrap .global-menu ul li:not(.current) {
        display: inline-block; } }
    @media screen and (min-width: 1176px) {
      header .global-menu-wrap .global-menu ul li:not(.current) {
        display: inline-block; } }
  header .global-menu-wrap .global-menu ul li.current a > img:last-of-type {
    opacity: 0; }
  header .global-menu-wrap .global-menu ul li.current a > img {
    opacity: 1; }
  header .global-menu-wrap .global-menu ul li.current a span {
    color: #000; }

#slideMenu .btn-homemenu {
  max-width: 226px;
  margin-top: 117px;
  margin-left: auto;
  margin-right: auto; }
  #slideMenu .btn-homemenu ul {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    /* justify-content:center; */
    justify-content: flex-start;
    height: auto;
    width: 100%;
    margin: 0 auto;
    gap: 15px 30px; }
    #slideMenu .btn-homemenu ul li {
      display: inline-block;
      margin: 0 0;
      padding: 0 0;
      text-align: center;
      width: 98px;
      height: 88px;
      vertical-align: top; }
      @media screen and (min-width: 768px) {
        #slideMenu .btn-homemenu ul li {
          width: 98px;
          height: 88px; } }
      #slideMenu .btn-homemenu ul li:first-child {
        align-self: center; }
      #slideMenu .btn-homemenu ul li a {
        position: relative;
        display: block;
        width: 100%;
        height: 100%;
        margin: 0 0;
        padding: 0 0;
        line-height: 0;
        color: #333;
        font-size: 14px;
        /* letter-spacing: 0.15em; */
        font-weight: bold;
        vertical-align: top;
        cursor: pointer; }
        #slideMenu .btn-homemenu ul li a > img {
          height: auto;
          left: 0;
          position: absolute;
          width: 100%;
          vertical-align: top; }
        #slideMenu .btn-homemenu ul li a span {
          position: absolute;
          display: inline-block;
          width: 100%;
          height: 14px;
          top: 0;
          left: 0;
          right: 0;
          bottom: 0;
          margin: auto auto;
          color: #FFF;
          font-size: 12px;
          line-height: 1;
          text-align: center;
          font-weight: bold; }
          #slideMenu .btn-homemenu ul li a span.brspan {
            height: 30px;
            line-height: 1.2; }
          #slideMenu .btn-homemenu ul li a span.whtspan {
            /* color: #FFF; */ }
          #slideMenu .btn-homemenu ul li a span.iconspan {
            width: 33px;
            height: 33px;
            transform: translate(0, -2px); }
        #slideMenu .btn-homemenu ul li a:hover span {
          color: #000; }

#slideMenu .homemenu-logo {
  position: absolute;
  display: inline-block;
  margin: 0;
  padding: 0;
  top: 37px;
  left: 5px;
  right: auto;
  bottom: 0;
  width: 122px;
  height: 88px;
  vertical-align: top; }
  #slideMenu .homemenu-logo a {
    position: relative;
    display: block;
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    cursor: pointer; }
  #slideMenu .homemenu-logo img {
    /* max-width: 280px; */
    width: 100%;
    height: auto; }

@media screen and (max-width: 768px) {
  .global-menu .person-right {
    transform: scaleX(-1); } }

@media screen and (max-width: 1176px) {
  #slideMenu .person-right {
    transform: scaleX(-1); } }

/**************************
nav
**************************/
#navToggle {
  display: none;
  /* position:absolute; */
  position: fixed;
  right: 13px;
  top: 13px;
  width: 30px;
  height: 25px;
  cursor: pointer; }

#navToggle div {
  position: relative; }

#navToggle span {
  display: block;
  position: absolute;
  width: 100%;
  /* border-bottom:solid 3px #FFF; */
  border-bottom: solid 3px #333;
  -webkit-transition: .35s ease-in-out;
  -moz-transition: .35s ease-in-out;
  transition: .35s ease-in-out; }

#navToggle span:nth-child(1) {
  top: 0; }

#navToggle span:nth-child(2) {
  top: 11px; }

#navToggle span:nth-child(3) {
  top: 22px; }

#slideMenu .menu {
  display: none; }

@media screen and (max-width: 840px) {
  #slideMenu .menu {
    /* display: none; */ }

  #slideMenu.openNav {
    height: 100%; }
    #slideMenu.openNav .menu {
      height: 100%; }

  #slideMenu .menu {
    display: block;
    position: fixed;
    right: 0;
    top: -600px;
    height: 600px;
    /* background:rgba(0,0,0,.8); */
    background: rgba(100, 100, 100, 0.9);
    width: 100%;
    padding: 0;
    -webkit-transition: .5s ease-in-out;
    -moz-transition: .5s ease-in-out;
    transition: .5s ease-in-out;
    text-align: center;
    z-index: 666; }

  #slideMenu ul {
    margin: 0;
    padding: 0; }

  #slideMenu ul li {
    display: block;
    height: auto;
    min-height: 44px;
    margin: 0;
    /* border-top: 1px #EEE solid; */
    border-bottom: 0 none;
    line-height: 1.8; }
    #slideMenu ul li.menu-os-wrap {
      padding-top: 5px;
      /* background: rgba(193,39,45, 0.9); */ }

  #slideMenu ul li a {
    display: block;
    /* width: 100%; */
    width: 100px;
    height: 44px;
    margin: 0 auto;
    color: #FFF;
    font-size: 15px;
    line-height: 44px;
    text-decoration: none;
    vertical-align: middle; }
    #slideMenu ul li a.menu-home {
      width: 140px;
      height: 40px;
      height: auto; }
    #slideMenu ul li a.menu-os {
      width: 140px; }

  #slideMenu ul li::after {
    content: ''; }

  #slideMenu ul li:last-child {
    /* border-bottom: 1px #EEE solid; */ }

  #slideMenu ul li a.sns-icon {
    display: inline-block;
    margin: 0 10px;
    margin-top: 20px;
    padding: 4px auto;
    width: 32px;
    height: 32px;
    text-align: center;
    /* background: #333333; */
    background-color: #FFF;
    vertical-align: middle;
    line-height: 1;
    border-radius: 50%;
    text-decoration: none; }
  #slideMenu ul li a.sns-icon, #slideMenu ul li a.sns-icon:hover {
    color: #555 !important; }
  #slideMenu ul li a.sns-icon i {
    color: #1a1a1a !important;
    font-size: 24px;
    line-height: 32px; }

  #navToggle {
    display: block;
    z-index: 999; }

  .openNav #navToggle span {
    border-bottom: solid 3px #FFF; }

  .openNav #navToggle span:nth-child(1) {
    top: 11px;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    transform: rotate(-45deg); }

  .openNav #navToggle span:nth-child(2) {
    top: 11px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg); }

  .openNav #navToggle span:nth-child(3) {
    top: 11px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg); }

  .openNav .menu {
    -moz-transform: translateY(601px);
    -webkit-transform: translateY(601px);
    transform: translateY(601px); } }
#slideMenu.openNav #homemenu {
  /* background: rgba(33,33,33,0.8); */
  padding-top: 45px;
  padding-bottom: 45px; }
  #slideMenu.openNav #homemenu li a, #slideMenu.openNav #homemenu li a:visited {
    color: #FFF; }

@media screen and (max-width: 1176px) {
  #slideMenu.openNav {
    height: 100%;
    height: 100vh; }
    #slideMenu.openNav .menu {
      height: 100%;
      height: 100vh; }

  #slideMenu .menu {
    top: -600px;
    height: 600px; }

  #slideMenu ul li {
    line-height: 1; }
    #slideMenu ul li:first-child {
      /* margin-top: 20%; */ } }
/**************************
page-menu
**************************/
.page-menu {
  /* 
  padding-top: 30px;
  */
  padding-bottom: 24px;
  padding-left: 15px;
  padding-right: 15px;
  display: block;
  width: 100%;
  margin: 0 auto;
  text-align: center;
  -webkit-transition: all .3s ease;
  -moz-transition: all .3s ease;
  -ms-transition: all .3s ease;
  transition: all .3s ease; }
  @media screen and (max-width: 700px) {
    .page-menu {
      /*
      padding-top: 30px;
      */
      padding-bottom: 30px; } }
  .page-menu li {
    position: relative;
    display: inline-block;
    margin: 0 0;
    padding: 0 0;
    padding-left: 10px;
    padding-right: 10px;
    text-align: center;
    /* width: 100px; */
    min-width: 175px;
    /* height: 60px; */
    height: calc(60 / 1280 * 100vw);
    -webkit-transition: all .3s ease;
    -moz-transition: all .3s ease;
    -ms-transition: all .3s ease;
    transition: all .3s ease;
    /* border-right: 1px solid #CCC; */ }
    @media screen and (max-width: 700px) {
      .page-menu li {
        width: 100%;
        height: 55px;
        border-right: 0 none; } }
    .page-menu li::before {
      content: '';
      position: absolute;
      display: block;
      top: 0;
      left: 0;
      bottom: 0;
      margin: auto 0;
      padding: 0 0;
      width: 1px;
      /* height: 50px; */
      height: calc(50 / 1280 * 100vw);
      background: #FFF; }
      @media screen and (max-width: 700px) {
        .page-menu li::before {
          display: none; } }
    .page-menu li:last-child {
      border-right: 0 none; }
      .page-menu li:last-child::after {
        content: '';
        position: absolute;
        display: block;
        top: 0;
        left: auto;
        right: 0;
        bottom: 0;
        margin: auto 0;
        padding: 0 0;
        width: 1px;
        /* height: 50px; */
        height: calc(50 / 1280 * 100vw);
        background: #FFF; }
        @media screen and (max-width: 700px) {
          .page-menu li:last-child::after {
            display: none; } }
    .page-menu li a {
      position: relative;
      display: block;
      width: 100%;
      /* height: 60px; */
      height: calc(60 / 1280 * 100vw);
      margin: 0 0;
      padding-top: 0.75em;
      padding-left: 10px;
      padding-right: 10px;
      color: #FFF;
      /* font-size:14px; */
      line-height: 1.3;
      font-size: calc(16 / 1280 * 100vw);
      font-weight: bold;
      vertical-align: baseline;
      z-index: 3;
      overflow: visible;
    /*
    &:hover {
        background: #FFF;
        color: $main-color;
			@media screen and (max-width: 700px) {    
                
    		}
    }
    */ }
      @media screen and (max-width: 700px) {
        .page-menu li a {
          border-right: 0 none;
          height: 100%;
          font-size: 14px; } }
      .page-menu li a.current, .page-menu li a:hover {
        /* border-bottom: 1px #FFF solid; */
        color: #0068b7; }
        @media screen and (max-width: 700px) {
          .page-menu li a.current, .page-menu li a:hover {
            /* color: #FFF; */ } }
        .page-menu li a.current::before, .page-menu li a:hover::before {
          content: '';
          position: absolute;
          display: block;
          top: 0;
          left: 0;
          right: 0;
          bottom: 0;
          margin: auto auto;
          padding: 0 0;
          width: 100%;
          height: 100%;
          background: #FFF;
          z-index: -1; }
          @media screen and (max-width: 700px) {
            .page-menu li a.current::before, .page-menu li a:hover::before {
              top: 0;
              left: 0;
              right: 0;
              bottom: 0;
              margin: auto 0;
              width: 100%; } }
        .page-menu li a.current::after, .page-menu li a:hover::after {
          content: '';
          position: absolute;
          display: block;
          top: auto;
          left: 0;
          right: 0;
          bottom: -24px;
          margin: 0 auto;
          padding: 0 0;
          width: 100%;
          height: 24px;
          clip-path: polygon(0 0, 100% 0%, 50% 100%);
          background: #FFF;
          z-index: -1; }
          @media screen and (max-width: 700px) {
            .page-menu li a.current::after, .page-menu li a:hover::after {
              top: 0;
              left: auto;
              right: -10px;
              bottom: 0;
              width: 10px;
              height: 100%;
              clip-path: polygon(0 0, 100% 50%, 0 100%); } }
      .page-menu li a span {
        font-size: calc(12 / 1280 * 100vw);
        font-weight: bold; }
        @media screen and (max-width: 700px) {
          .page-menu li a span {
            font-size: 11px; } }
      .page-menu li a.current span::after, .page-menu li a:hover span::after {
        content: '';
        position: absolute;
        display: block;
        top: auto;
        left: 0;
        right: 0;
        bottom: -48px;
        margin: 0 auto;
        padding: 0 0;
        width: 100%;
        height: 24px;
        clip-path: polygon(0 0, 100% 0%, 50% 100%);
        background: #0068b7;
        z-index: -2; }
        @media screen and (max-width: 700px) {
          .page-menu li a.current span::after, .page-menu li a:hover span::after {
            display: none; } }

@media screen and (max-width: 700px) {
  .product .page-menu li {
    /*
    width: auto;
    height: 20px;
    */ } }
.product .page-menu li a.current {
  /*
  border-bottom: 1px #FFF solid;
  */ }

/**************************
top
**************************/
#logo .opc {
  opacity: 0.8; }

header .logo {
  position: absolute;
  display: inline-block;
  margin: 0;
  padding: 0;
  top: 0;
  left: 0;
  right: auto;
  bottom: 0;
  width: 122px;
  height: 88px;
  vertical-align: top; }
  header .logo a {
    position: relative;
    display: block;
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0; }
  header .logo img {
    /* max-width: 280px; */
    width: 100%;
    height: auto; }

/**************************
sns-menu
**************************/
.sns-menu {
  position: absolute;
  display: inline-block;
  margin: 0 0;
  padding: 0 0;
  top: 0;
  left: auto;
  right: 15px;
  bottom: auto;
  width: 150px;
  height: 40px;
  text-align: center;
  vertical-align: bottom;
  -webkit-transition: all .5s ease;
  -moz-transition: all .5s ease;
  -ms-transition: all .5s ease;
  transition: all .5s ease; }
  @media screen and (max-width: 960px) {
    .sns-menu {
      right: 10px; } }
  @media screen and (max-width: 768px) {
    .sns-menu {
      display: none; } }

footer .sns-menu {
  position: absolute;
  display: inline-block;
  margin: 0 0;
  padding: 0 0;
  top: 0;
  left: auto;
  right: 15px;
  bottom: auto;
  width: 100px;
  height: 40px;
  text-align: center;
  vertical-align: bottom;
  -webkit-transition: all .5s ease;
  -moz-transition: all .5s ease;
  -ms-transition: all .5s ease;
  transition: all .5s ease; }
  @media screen and (max-width: 700px) {
    footer .sns-menu {
      display: none; } }

.sns-menu .list-inline > li {
  display: inline-block;
  padding-right: 4px;
  padding-left: 4px; }

a.sns-icon {
  display: inline-block;
  margin: 0;
  margin-top: 5px;
  margin-left: 10px;
  padding: 1px auto;
  width: 28px;
  height: 28px;
  text-align: center;
  /* background: #333333; */
  background-color: #000;
  vertical-align: middle;
  line-height: 1;
  border-radius: 4px; }
  a.sns-icon.facebook-icon {
    background-color: #FFF;
    width: 20px;
    height: 20px; }
    a.sns-icon.facebook-icon i {
      color: #000 !important;
      font-size: 20px;
      line-height: 20px; }

a.sns-icon, a.sns-icon:hover {
  color: #555 !important; }

a.sns-icon i {
  color: #FFF !important;
  font-size: 22px;
  line-height: 28px; }

a.sns-icon i.fa-facebook-f {
  /* margin-right: -5px; */
  margin-top: 3px; }

/**************************
effect
**************************/
/*----- フェードイン -----*/
.inviewfadeIn {
  opacity: 0;
  transition: 2s; }

.fadeIn {
  opacity: 1.0; }

/*----- フェードインしながら上へスライド -----*/
.inviewfadeInUp {
  opacity: 0;
  transform: translate(0, 60px);
  -webkit-transform: translate(0, 60px);
  transition: 1.4s; }

/*----- フェードインしながら上へスライド遅く -----*/
.inviewfadeInSlowUp {
  opacity: 0;
  transform: translate(0, 60px);
  -webkit-transform: translate(0, 60px);
  transition: 3.4s; }

.fadeInUp {
  opacity: 1.0;
  transform: translate(0, 0);
  -webkit-transform: translate(0, 0); }

/*----- フェードインしながらズームイン -----*/
.inviewzoomIn {
  opacity: 0;
  -webkit-transform: scale(0.96);
  -ms-transform: scale(0.96);
  transform: scale(0.96);
  -webkit-transition: all 1.4s ease-out;
  -o-transition: all 1.4s ease-out;
  transition: all 1.4s ease-out; }

.zoomIn {
  opacity: 1;
  -webkit-transform: scale(1);
  -ms-transform: scale(1);
  transform: scale(1); }

.gotocon-down {
  display: block;
  padding: 7px;
  width: 40px;
  height: 40px;
  border: 2px #FFF solid;
  border-radius: 50%;
  vertical-align: middle; }
  .gotocon-down span.glyphicon {
    line-height: 1;
    font-size: 26px;
    text-shadow: none; }

/**************************
footer
**************************/
#footer-cont {
  position: relative;
  background-color: #FFF;
  padding-top: 60px;
  padding-bottom: 3em;
  text-align: center;
  color: #333; }
  @media screen and (max-width: 420px) {
    #footer-cont {
      padding-top: 30px;
      padding-bottom: 10px; } }
  #footer-cont a, #footer-cont a:hover {
    color: #333; }
  #footer-cont .logo {
    display: inline-block;
    /* margin: 5em auto; */
    width: 100%;
    max-width: 255px;
    height: auto; }
    @media screen and (max-width: 768px) {
      #footer-cont .logo {
        margin: 0 auto; } }
    @media screen and (max-width: 420px) {
      #footer-cont .logo {
        max-width: 180px; } }

.foot-logo-wrap {
  padding-top: 10px;
  padding-right: 20px;
  text-align: right; }
  @media screen and (max-width: 768px) {
    .foot-logo-wrap {
      text-align: center;
      padding-right: 15px;
      padding-bottom: 2em; } }

.foot-address-wrap {
  text-align: left;
  padding-left: 30px; }
  @media screen and (max-width: 768px) {
    .foot-address-wrap {
      padding-left: 15px;
      padding-right: 15px; } }
  .foot-address-wrap .foot-address-wrap-inner {
    border-left: 1px #333 solid;
    padding-left: 25px; }
    @media screen and (max-width: 768px) {
      .foot-address-wrap .foot-address-wrap-inner {
        text-align: left;
        max-width: 420px;
        margin-left: auto;
        margin-right: auto; } }
    @media screen and (max-width: 420px) {
      .foot-address-wrap .foot-address-wrap-inner {
        padding-left: 10px; } }
  .foot-address-wrap dl {
    display: block; }
    @media screen and (max-width: 420px) {
      .foot-address-wrap dl {
        display: none; } }
  .foot-address-wrap dt {
    display: inline-block;
    width: 70px;
    vertical-align: top; }
    @media screen and (max-width: 420px) {
      .foot-address-wrap dt {
        /* width: 100%; */
        line-height: 1.8;
        /* font-weight: bold; */
        width: 40px;
        font-size: 7px;
        margin-right: 5px; } }
  .foot-address-wrap dd {
    display: inline-block;
    width: calc(100% - 70px);
    vertical-align: top; }
    @media screen and (max-width: 420px) {
      .foot-address-wrap dd {
        /* width: 100%; */
        width: calc(100% - 45px);
        line-height: 1.8;
        font-size: 7px; } }
    .foot-address-wrap dd span {
      display: inline-block;
      width: 80px;
      padding-left: 10px; }
      @media screen and (max-width: 420px) {
        .foot-address-wrap dd span {
          /* width: 100%; */
          line-height: 1.8;
          padding-left: 0;
          width: 40px;
          padding-left: 5px;
          /* font-weight: bold; */ } }
  .foot-address-wrap .sp-foot-info {
    display: none; }
    @media screen and (max-width: 420px) {
      .foot-address-wrap .sp-foot-info {
        display: block;
        font-size: 7px; } }

.foot-menu {
  padding-top: 55px; }
  @media screen and (max-width: 420px) {
    .foot-menu {
      padding-top: 10px; } }
  .foot-menu li {
    padding: 5px 0; }
    .foot-menu li a {
      border-right: 1px #333 solid;
      padding: 0 20px; }
      @media screen and (max-width: 420px) {
        .foot-menu li a {
          /* border-right: 0 none; */
          font-size: 7px;
          padding: 0 5px; } }
    .foot-menu li:last-child a {
      border-right: 0 none; }

footer {
  background-color: rgba(0, 0, 0, 0);
  position: relative;
  top: auto;
  bottom: 0;
  left: 0;
  right: 0;
  display: block;
  width: 100%;
  height: 40px;
  padding: 5px auto;
  color: #000;
  font-size: 14px;
  text-align: center;
  z-index: 10; }
  @media screen and (min-width: 1176px) {
    footer {
      position: absolute; } }

.home footer {
  background-color: rgba(0, 0, 0, 0);
  position: absolute;
  top: auto;
  bottom: 0;
  left: 0;
  right: 0;
  display: block;
  width: 100%;
  height: 40px;
  padding: 5px auto;
  color: #000;
  font-size: 14px;
  text-align: center;
  z-index: 10; }
  @media screen and (min-width: 1176px) {
    .home footer {
      position: absolute; } }

footer .copyright {
  position: absolute;
  display: inline-block;
  margin: 0 auto;
  padding: 0 0;
  top: 0;
  left: 0;
  right: 0;
  bottom: auto;
  height: 40px;
  font-size: 10px;
  line-height: 40px;
  text-align: center;
  vertical-align: top; }
footer .foot-info-cont {
  position: absolute;
  display: inline-block;
  margin: 0 0;
  padding: 0 0;
  top: 0;
  left: auto;
  right: 115px;
  bottom: auto;
  width: 400px;
  height: 40px;
  line-height: 40px;
  text-align: right;
  vertical-align: bottom; }
  @media screen and (max-width: 700px) {
    footer .foot-info-cont {
      width: 100%;
      position: relative;
      text-align: center;
      height: 24px;
      padding-top: 15px;
      line-height: 24px;
      top: auto;
      bottom: auto;
      left: auto;
      right: auto; } }
  footer .foot-info-cont .phone {
    display: inline-block;
    padding-left: 5px; }
    @media screen and (max-width: 700px) {
      footer .foot-info-cont .phone {
        width: 100%;
        position: relative;
        text-align: center; } }
    footer .foot-info-cont .phone .phone-num {
      font-size: 18px;
      font-weight: 600;
      padding-left: 5px; }

/**********************************
page-top
**********************************/
#page-top {
  width: 40px;
  height: 40px;
  display: block;
  position: fixed;
  top: auto;
  right: 15px;
  bottom: 60px;
  z-index: 11; }
  @media screen and (max-width: 420px) {
    #page-top {
      bottom: 30px; } }
  #page-top p {
    margin: 0;
    padding: 0;
    text-align: center;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s; }
    #page-top p:hover {
      opacity: 1;
      -webkit-filter: invert(15%);
      filter: invert(15%); }

#move-page-top {
  color: #fff;
  line-height: 50px;
  text-decoration: none;
  display: block;
  cursor: pointer; }

.back-btn {
  height: 70px; }
  .back-btn a.btn-back {
    display: block;
    margin: 0;
    vertical-align: middle;
    padding: 17px 0;
    font-size: 14px;
    color: #FFF;
    letter-spacing: 0.1em; }
    .back-btn a.btn-back img {
      diplay: inline-block;
      width: 36px;
      height: 36px;
      vertical-align: middle;
      margin-right: 10px; }
    .back-btn a.btn-back:hover {
      color: #DDD; }
      .back-btn a.btn-back:hover img {
        opacity: 0.7; }

/**********************************
mark
**********************************/
.mailmark {
  letter-spacing: 0.02em; }

.form_ul span.mailmark {
  color: #333; }

.mailmark::before {
  content: "@"; }

/**********************************
pre
**********************************/
span.pre {
  white-space: pre;
  white-space: -moz-pre-wrap; }

/**********************************
edit
**********************************/
.bg-home {
  /*
  background:url("images/bg-home.jpg") center center no-repeat;
  background-size: cover;
  background-attachment: fixed;
  */ }

body.home {
  min-height: 100vh; }

body.home {
  min-height: 100vh; }
body.bg-home {
  position: relative;
  background: rgba(255, 255, 255, 0); }
  body.bg-home::before {
    content: '';
    position: fixed;
    display: block;
    width: 100%;
    height: 100vh;
    top: 0;
    left: 0;
    margin: 0;
    padding: 0;
    z-index: 0;
    background: url("images/bg-home.jpg") center center no-repeat;
    background-size: cover; }

.container .nm-section {
  margin-left: -15px;
  margin-right: -15px; }

p.lead {
  text-align: center;
  font-size: 24px !important;
  letter-spacing: 0.02em;
  line-height: 1.88;
  color: #1a1a1a;
  padding-bottom: 80px; }
  @media screen and (max-width: 768px) {
    p.lead {
      font-size: 23px !important;
      padding-left: 15px;
      padding-right: 15px;
      padding-bottom: 40px; } }
  @media screen and (max-width: 420px) {
    p.lead {
      text-align: left;
      font-size: 16px !important;
      padding-bottom: 20px; } }

p.lead-sub {
  text-align: center;
  font-size: 19px !important;
  letter-spacing: 0.135em;
  line-height: 1.7;
  color: #333; }
  @media screen and (max-width: 768px) {
    p.lead-sub {
      font-size: 19px !important;
      padding-left: 15px;
      padding-right: 15px; } }
  @media screen and (max-width: 420px) {
    p.lead-sub {
      text-align: left;
      font-size: 16px !important; } }

.img-icon-insta-wrap {
  position: relative; }

.img-icon-insta {
  display: block;
  position: absolute;
  top: 0px;
  left: 0px;
  /* -webkit-transform: translate3d(0, 0, -1px); */
  /* transform: translate3d(0, 0, -1px); */
  width: 96px;
  height: 101px; }

/**********************************
header
**********************************/
header {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  display: block;
  height: 162px;
  margin: 0 0;
  padding: 37px 0;
  z-index: 333; }
  @media screen and (min-width: 1176px) {
    header {
      position: fixed;
      height: 162px; } }

.header-inner {
  position: relative;
  margin: 0 auto;
  padding: 0 15px;
  text-align: center;
  display: block;
  width: 100%;
  height: 88px; }
  @media screen and (min-width: 1176px) {
    .header-inner {
      max-width: 1168px;
      height: 88px;
      margin: 0 auto;
      padding: 0 0; } }

header .logo {
  position: absolute;
  display: inline-block;
  margin: auto 0;
  padding: 0;
  top: 0;
  left: 5px;
  right: auto;
  bottom: 0;
  width: 122px;
  height: 88px;
  vertical-align: top; }
  @media screen and (min-width: cstmwidth) {
    header .logo {
      left: 0;
      width: 130px;
      height: 95px; } }
  @media screen and (min-width: 1600px) {
    header .logo {
      width: 162px;
      height: 118px; } }
  header .logo a {
    position: relative;
    display: block;
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    cursor: pointer; }
  header .logo img {
    /* max-width: 280px; */
    width: 100%;
    height: auto; }

/**********************************
hero1
**********************************/
.home #hero1 {
  position: relative;
  width: 100%;
  height: 100%;
  height: 100vh !important;
  -webkit-scroll-behavior: smooth;
  -webkit-scroll-snap-type: mandatory;
  scroll-snap-type: mandatory;
  -webkit-scroll-snap-points-y: repeat(100%);
  -webkit-backface-visibility: hidden;
  text-align: center; }

.home #hero1-main {
  position: absolute;
  display: block;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  margin: auto auto;
  padding: 50px 15px;
  z-index: 30;
  vertical-align: top;
  line-height: 0;
  /*
  -webkit-transform: translateY(20%);
  -ms-transform: translateY(20%);
  transform: translateY(20%);
  */ }
  @media screen and (min-width: 768px) {
    .home #hero1-main {
      width: 726px;
      height: 450px;
      padding: 0 0; } }
  @media screen and (min-width: 1280px) {
    .home #hero1-main {
      width: calc(726 / 1280 * 100vw);
      height: calc(450 / 1280 * 100vw); } }

.home #hero1-main-inner {
  display: flex;
  flex-wrap: nowrap;
  flex-direction: column;
  width: 100%;
  height: 100%; }

.home #hero1-main-inner .main-logo {
  width: 100%; }
.home #hero1-main-inner .space-01 {
  width: 100%;
  height: 30px; }
  @media screen and (min-width: 768px) {
    .home #hero1-main-inner .space-01 {
      height: 47px; } }
  @media screen and (min-width: 1280px) {
    .home #hero1-main-inner .space-01 {
      height: calc(47 / 1280 * 100vw); } }
.home #hero1-main-inner .global-menu-wrap {
  width: 100%;
  max-width: 226px;
  height: 294px;
  margin: 0 auto; }
  @media screen and (min-width: 768px) {
    .home #hero1-main-inner .global-menu-wrap {
      max-width: 100%;
      height: 88px; } }
  @media screen and (min-width: 1280px) {
    .home #hero1-main-inner .global-menu-wrap {
      height: calc(88 / 1280 * 100vw); } }
.home #hero1-main-inner .space-02 {
  width: 100%;
  height: 20px; }
  @media screen and (min-width: 768px) {
    .home #hero1-main-inner .space-02 {
      height: 32px; } }
  @media screen and (min-width: 1280px) {
    .home #hero1-main-inner .space-02 {
      height: calc(32 / 1280 * 100vw); } }
.home #hero1-main-inner .sub-logo {
  width: 100%; }

/**********************************
cont-wrapper
**********************************/
.cont-wrapper {
  position: relative;
  display: block;
  margin: 0 auto 30px auto;
  width: 100%;
  height: 100%;
  border-left: 4px solid rgba(255, 255, 255, 0.4);
  border-top: 4px solid rgba(0, 0, 0, 0.4);
  border-right: 4px solid rgba(0, 0, 0, 0.2);
  border-bottom: 4px solid rgba(255, 255, 255, 0.5);
  border-radius: 4px;
  background: rgba(33, 33, 33, 0.4); }
  @media screen and (min-width: 1176px) {
    .cont-wrapper {
      margin: 168px auto 30px auto;
      max-width: 1176px;
      max-height: calc(100vh - 224px);
      overflow-y: scroll;
      border-left: 4px solid rgba(255, 255, 255, 0.4);
      border-top: 4px solid rgba(0, 0, 0, 0.4);
      border-right: 4px solid rgba(0, 0, 0, 0.2);
      border-bottom: 4px solid rgba(255, 255, 255, 0.5);
      border-radius: 4px; } }

.cont-wrap {
  padding-top: 40px;
  text-align: center; }

.content-item p {
  text-align: left;
  color: #FFF;
  font-size: 15px; }
  .content-item p.indent {
    text-indent: 1em; }
  .content-item p.mark-indent {
    padding-left: 1em;
    text-indent: -1em; }
  .content-item p a, .content-item p a:visited {
    color: #FFF;
    text-decoration: underline; }
  .content-item p a:hover {
    color: #FFF;
    text-decoration: none; }
.content-item h3 {
  margin-bottom: 1em; }
  .content-item h3.title-line {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 16px;
    font-weight: 400;
    color: #FFF;
    letter-spacing: 0.1em; }
  .content-item h3.title-line::before {
    margin-right: 16px;
    content: '';
    flex-grow: 1;
    height: 1px;
    display: inline-block;
    background-color: #FFF; }
  .content-item h3.title-line::after {
    margin-left: 16px;
    content: '';
    flex-grow: 1;
    height: 1px;
    display: inline-block;
    background-color: #FFF; }
.content-item .img-wrapper {
  margin-bottom: 1rem; }
  @media screen and (min-width: 768px) {
    .content-item .img-wrapper {
      margin-bottom: 0; } }
.content-item dl dt, .content-item dl dd {
  color: #FFF;
  font-size: 14px;
  vertical-align: top;
  line-height: 2; }
.content-item dl dt {
  text-align: right; }
.content-item dl dd {
  text-align: left; }
.content-item .pb-1rem {
  padding-bottom: 1rem; }
.content-item .pb-40px {
  padding-bottom: 40px; }

.fa-content-item.content-item {
  padding-left: 15px;
  padding-right: 15px;
  padding-bottom: 40px; }
  @media screen and (min-width: 768px) {
    .fa-content-item.content-item {
      padding-left: 15px;
      padding-right: 15px; } }
  @media screen and (min-width: 1176px) {
    .fa-content-item.content-item {
      padding-left: 15px;
      padding-right: 15px; } }

/* ****************************************
list-cstm
**************************************** */
@media all {
  .col-lg-1.pd-0, .col-lg-10.pd-0, .col-lg-11.pd-0, .col-lg-12.pd-0, .col-lg-2.pd-0, .col-lg-3.pd-0, .col-lg-4.pd-0, .col-lg-5.pd-0, .col-lg-6.pd-0, .col-lg-7.pd-0, .col-lg-8.pd-0, .col-lg-9.pd-0, .col-md-1.pd-0, .col-md-10.pd-0, .col-md-11.pd-0, .col-md-12.pd-0, .col-md-2.pd-0, .col-md-3.pd-0, .col-md-4.pd-0, .col-md-5.pd-0, .col-md-6.pd-0, .col-md-7.pd-0, .col-md-8.pd-0, .col-md-9.pd-0, .col-sm-1.pd-0, .col-sm-10.pd-0, .col-sm-11.pd-0, .col-sm-12.pd-0, .col-sm-2.pd-0, .col-sm-3.pd-0, .col-sm-4.pd-0, .col-sm-5.pd-0, .col-sm-6.pd-0, .col-sm-7.pd-0, .col-sm-8.pd-0, .col-sm-9.pd-0, .col-xs-1.pd-0, .col-xs-10.pd-0, .col-xs-11.pd-0, .col-xs-12.pd-0, .col-xs-2.pd-0, .col-xs-3.pd-0, .col-xs-4.pd-0, .col-xs-5.pd-0, .col-xs-6.pd-0, .col-xs-7.pd-0, .col-xs-8.pd-0, .col-xs-9.pd-0 {
    padding-left: 0;
    padding-right: 0; } }
.cont-list.pd-0 {
  /* padding: 0; */ }

.cont-list {
  position: relative;
  overflow: hidden;
  text-align: center;
  /* height: 320px; */
  position: relative;
  /* height resp */
  height: 100%;
  /* height resp */
  padding: 25% 0 0;
  /* height resp */ }
  @media screen and (max-width: 768px) {
    .cont-list {
      min-height: 240px; } }
  @media screen and (max-width: 420px) {
    .cont-list {
      min-height: 140px; } }
  .cont-list.col-xs-4 {
    width: 33.333333%; }
    @media screen and (max-width: 420px) {
      .cont-list.col-xs-4 {
        width: 100%; } }

a.cont-list {
  text-decoration: none; }

.cont-list:before {
  z-index: 1;
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.2); }

.cont-list.cont-list-bdr:before {
  border: 10px #FFF solid; }

.cont-list:after {
  position: absolute;
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  top: 0;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -ms-background-size: cover;
  background-size: cover;
  -webkit-transition: all .6s ease-out;
  -moz-transition: all .6s ease-out;
  -ms-transition: all .6s ease-out;
  transition: all .6s ease-out;
  background-attachment: fixed;
  background-position: center center; }

.cont-list:hover:before {
  /* opacity: .1; */
  background-color: rgba(0, 0, 0, 0.5); }

.cont-list.cont-list-nohover:hover:before {
  background-color: rgba(0, 0, 0, 0.2); }

.cont-list:hover:after {
  /* opacity: .8; */
  -moz-transform: scale(1.1) rotate(0.1deg);
  -webkit-transform: scale(1.1) rotate(0.1deg);
  -ms-transform: scale(1.1) rotate(0.1deg);
  transform: scale(1.1) rotate(0.1deg); }

.cont-list .list-inner {
  z-index: 3;
  /* position: relative; */
  padding: 20px 0;
  text-align: center;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%; }

.cont-list .list-inner h4 {
  display: block;
  width: 200px;
  height: 40px;
  padding: 0 auto;
  font-size: 24px;
  font-weight: 600;
  color: #FFF;
  vertical-align: middle;
  line-height: 38px;
  letter-spacing: 0.2em;
  border: 1px #FFF solid;
  /* text-shadow: 0 0 0.5em rgba(0,0,0,0.9);  */
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto; }
  .cont-list .list-inner h4.nml-wgt {
    font-weight: normal; }
  .cont-list .list-inner h4 span {
    font-weight: normal; }
  @media screen and (max-width: 768px) {
    .cont-list .list-inner h4 {
      font-size: 22px; } }
  @media screen and (max-width: 420px) {
    .cont-list .list-inner h4 {
      font-size: 18px; } }
  .cont-list .list-inner h4 .btn-play {
    width: 80px;
    height: 80px;
    vertical-align: middle;
    margin: 0 10px; }
    @media screen and (max-width: 768px) {
      .cont-list .list-inner h4 .btn-play {
        width: 60px;
        height: 60px; } }
    @media screen and (max-width: 420px) {
      .cont-list .list-inner h4 .btn-play {
        width: 30px;
        height: 30px; } }

.cont-list.t-1:after {
  background: url(images/img-01-01@2x.jpg) no-repeat center center;
  background-size: cover;
  background-color: #EEE; }

.cont-list.t-2:after {
  background: url(images/img-01-02@2x.jpg) no-repeat center center;
  background-size: cover;
  background-color: #EEE; }

.cont-list.t-3:after {
  background: url(images/img-01-03@2x.jpg) no-repeat center center;
  background-size: cover;
  background-color: #EEE; }

.cont-list.t-4:after {
  background: url(images/img-01-04@2x.jpg) no-repeat center center;
  background-size: cover;
  background-color: #EEE; }

.cont-list.t-5:after {
  background: url(images/img-01-05@2x.jpg) no-repeat center center;
  background-size: cover;
  background-color: #EEE; }

/**********************************
about-cont
**********************************/
.about-cont {
  height: 35.9375vw; }
  @media screen and (max-width: 900px) {
    .about-cont {
      height: 45vw; } }
  @media screen and (max-width: 768px) {
    .about-cont {
      height: 55vw; } }
  @media screen and (max-width: 700px) {
    .about-cont {
      height: auto; } }
  @media screen and (max-width: 420px) {
    .about-cont {
      height: auto; } }
  .about-cont .left {
    width: 50%;
    position: relative;
    overflow: hidden;
    text-align: center;
    position: relative;
    height: 35.9375vw;
    padding: 0 0;
    /* height resp */
    background: url(images/img-02-01@2x.jpg) no-repeat center center;
    background-size: cover; }
    @media screen and (max-width: 900px) {
      .about-cont .left {
        height: 45vw; } }
    @media screen and (max-width: 768px) {
      .about-cont .left {
        height: 55vw; } }
    @media screen and (max-width: 700px) {
      .about-cont .left {
        width: 100%;
        height: 71.875vw; } }
    @media screen and (max-width: 420px) {
      .about-cont .left {
        width: 100%;
        height: 71.875vw; } }
  .about-cont .right {
    width: 50%;
    padding: 30px 30px;
    padding-top: 40px;
    vertical-align: top; }
    @media screen and (max-width: 700px) {
      .about-cont .right {
        width: 100%;
        padding: 30px 15px;
        padding-top: 20px; } }
    @media screen and (max-width: 420px) {
      .about-cont .right {
        width: 100%;
        padding: 30px 15px;
        padding-top: 20px; } }
    .about-cont .right .gaiyo-list {
      width: 100%;
      margin: 0 0;
      font-size: 15px;
      line-height: 1.85;
      letter-spacing: 0.01em;
      vertical-align: top; }
      @media screen and (max-width: 800px) {
        .about-cont .right .gaiyo-list {
          font-size: 14px;
          line-height: 1.2; } }
      @media screen and (max-width: 420px) {
        .about-cont .right .gaiyo-list {
          font-size: 14px;
          padding-left: 0; } }
      .about-cont .right .gaiyo-list dt {
        display: inline-block;
        width: 100px;
        vertical-align: top;
        line-height: 1.85;
        /* margin-bottom: 10px; */ }
      .about-cont .right .gaiyo-list dd {
        display: inline-block;
        width: calc(100% - 100px);
        vertical-align: top;
        line-height: 1.85; }

/**********************************
googlemap
**********************************/
.map-wrap {
  position: relative;
  padding-bottom: 35.9375vw;
  padding-top: 30px;
  height: 0;
  overflow: hidden; }
  @media screen and (max-width: 420px) {
    .map-wrap {
      padding-bottom: 71.875%; } }

.map-wrap iframe,
.map-wrap object,
.map-wrap embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%; }

/**********************************
access-cont
**********************************/
.access-cont {
  background-color: #0068b7;
  color: #FFF; }
  .access-cont .access-cont-inner {
    width: 100%;
    max-width: 970px;
    margin: 0 auto;
    padding-top: 80px;
    padding-bottom: 80px;
    padding-left: 15px;
    padding-right: 15px; }
    @media screen and (max-width: 970px) {
      .access-cont .access-cont-inner {
        padding-top: 30px;
        padding-bottom: 30px;
        padding-left: 15px;
        padding-right: 15px; } }
  .access-cont h4 {
    color: #FFF;
    width: 100%;
    height: 30px;
    font-size: 24px;
    font-weight: 600;
    line-height: 24px;
    vertical-align: middle;
    border-left: 2px #FFF solid;
    margin-bottom: 20px;
    padding-left: 5px; }
  .access-cont .access-list {
    width: 100%;
    margin: 0 0;
    font-size: 15px;
    line-height: 1.85;
    letter-spacing: 0.01em;
    vertical-align: top; }
    @media screen and (max-width: 800px) {
      .access-cont .access-list {
        font-size: 14px;
        line-height: 1.2; } }
    @media screen and (max-width: 420px) {
      .access-cont .access-list {
        font-size: 14px;
        padding-left: 0; } }
    .access-cont .access-list dt {
      display: inline-block;
      width: 50px;
      vertical-align: top;
      line-height: 1.85;
      /* margin-bottom: 10px; */
      padding-top: 8px;
      padding-bottom: 8px; }
    .access-cont .access-list dd {
      display: inline-block;
      width: calc(100% - 50px);
      vertical-align: top;
      line-height: 1.85;
      padding-top: 8px;
      padding-bottom: 8px; }

/**********************************
timeline-list
**********************************/
.timeline-wrap {
  padding-top: 30px;
  padding-bottom: 180px; }
  @media screen and (max-width: 700px) {
    .timeline-wrap {
      padding-bottom: 50px; } }
  .timeline-wrap .conttitle {
    padding-bottom: 30px; }

.timeline-list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  position: relative;
  /* background: rgba(242,242,242,0.9); */
  border-top: 1px #DDD solid;
  margin: 0;
  padding: 0; }
  @media screen and (max-width: 420px) {
    .timeline-list li {
      display: block; } }
  .timeline-list li:last-child {
    border-bottom: 1px #DDD solid; }
  .timeline-list li span {
    display: inline-block;
    margin: 0;
    padding: 15px 30px;
    vertical-align: top;
    line-height: 2; }
    @media screen and (max-width: 768px) {
      .timeline-list li span {
        padding: 10px 15px; } }
    @media screen and (max-width: 420px) {
      .timeline-list li span {
        padding: 10px 10px; } }
  .timeline-list li .left {
    width: 24%;
    font-size: 13px;
    color: #0068b7;
    background: rgba(242, 242, 242, 0.9); }
    @media screen and (max-width: 420px) {
      .timeline-list li .left {
        width: 100%; } }
  .timeline-list li .right {
    width: 76%;
    font-size: 14px;
    text-align: left; }
    @media screen and (max-width: 420px) {
      .timeline-list li .right {
        width: 100%; } }

/**********************************
co-cont
**********************************/
.co-content-item.content-item {
  padding-left: 15px;
  padding-right: 15px;
  padding-bottom: 40px; }
  @media screen and (min-width: 768px) {
    .co-content-item.content-item {
      padding-left: 30px;
      padding-right: 30px; } }
  @media screen and (min-width: 1176px) {
    .co-content-item.content-item {
      padding-left: 50px;
      padding-right: 50px; } }

/**********************************
fa-cont
**********************************/
.fa-cont-wrap {
  padding-left: 15px;
  padding-right: 15px;
  padding-bottom: 40px; }
  @media screen and (min-width: 768px) {
    .fa-cont-wrap {
      padding-left: 30px;
      padding-right: 30px; } }

.fa-cont-table {
  padding-bottom: 40px; }

.fa-cont-table table {
  width: 100%;
  border-collapse: collapse;
  border-top: 1px solid #FFF;
  border-left: 1px solid #FFF;
  border-right: 1px solid #FFF; }
.fa-cont-table tr {
  width: 100%; }
  .fa-cont-table tr.trs1 {
    height: 32px; }
.fa-cont-table th {
  color: #000;
  font-size: 14px;
  border-bottom: 1px solid #FFF;
  background: rgba(255, 255, 255, 0.35);
  line-height: 23pt;
  padding: 6px auto; }
  .fa-cont-table th.s1 {
    width: 80%;
    padding-left: 15pt;
    text-align: center;
    letter-spacing: 0.1em; }
  .fa-cont-table th.s2 {
    width: 20%;
    padding-left: auto;
    padding-right: auto;
    text-align: center;
    border-left: 1px solid #FFF; }
.fa-cont-table td {
  color: #000;
  font-size: 14px;
  border-bottom: 1px solid #FFF;
  background: rgba(255, 255, 255, 0.35);
  line-height: 1.6;
  padding-top: 8px;
  padding-bottom: 8px; }
  .fa-cont-table td.s1 {
    width: 80%;
    padding-left: 15px;
    text-align: left; }
  .fa-cont-table td.s2 {
    width: 20%;
    padding-left: auto;
    padding-right: auto;
    text-align: center;
    border-left: 1px solid #FFF; }

.fa-grid-wrap {
  display: grid;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  gap: 20px 20px; }
  @media screen and (min-width: 768px) {
    .fa-grid-wrap {
      grid-template-columns: 1fr 1fr 1fr; } }
  .fa-grid-wrap .fa-grid-item.item-s {
    grid-row: span 1;
    grid-column: span 1; }
  .fa-grid-wrap .fa-grid-item.item-m {
    grid-row: span 1;
    grid-column: span 1; }
    @media screen and (min-width: 768px) {
      .fa-grid-wrap .fa-grid-item.item-m {
        grid-column: span 2; } }
  .fa-grid-wrap .fa-grid-item img {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%; }

/**********************************
pr-cont
**********************************/
.pr-cont-wrap {
  padding-top: 60px;
  padding-left: 15px;
  padding-right: 15px;
  padding-bottom: 40px; }
  @media screen and (min-width: 768px) {
    .pr-cont-wrap {
      padding-left: 30px;
      padding-right: 30px; } }

.pr-grid-wrap {
  display: grid;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  gap: 60px 30px; }
  @media screen and (min-width: 768px) {
    .pr-grid-wrap {
      grid-template-columns: 1fr 1fr; } }
  .pr-grid-wrap .pr-grid-item {
    position: relative; }
    .pr-grid-wrap .pr-grid-item.item-s {
      grid-row: span 1;
      grid-column: span 1; }
    .pr-grid-wrap .pr-grid-item.item-m {
      grid-row: span 1;
      grid-column: span 1; }
      @media screen and (min-width: 768px) {
        .pr-grid-wrap .pr-grid-item.item-m {
          grid-row: span 2;
          grid-column: span 1; } }
    .pr-grid-wrap .pr-grid-item img {
      display: block;
      height: 100%;
      object-fit: cover;
      width: 100%; }
    .pr-grid-wrap .pr-grid-item h5 {
      position: absolute;
      display: block;
      top: -28px;
      left: 0;
      width: auto;
      height: 28px;
      margin: 0 0;
      padding: 7px 1em;
      line-height: 20px;
      font-size: 14px;
      color: #FFF;
      background: black;
      text-align: left;
      font-weight: 600;
      vertical-align: top;
      line-height: 1; }

.product-cont-grid {
  width: 100%;
  margin: 0 auto;
  display: -ms-grid;
  display: grid;
  grid-row-gap: 10px;
  grid-column-gap: 10px;
  -ms-grid-columns: 1fr 1fr;
  grid-template-columns: 1fr 1fr;
  -ms-grid-rows: auto;
  grid-template-rows: auto; }
  @media screen and (min-width: 700px) {
    .product-cont-grid {
      grid-row-gap: 20px;
      grid-column-gap: 20px;
      -ms-grid-columns: 1fr 1fr 1fr 1fr 1fr;
      grid-template-columns: 1fr 1fr 1fr 1fr 1fr; } }

.product-cont-grid .grid-item {
  -ms-grid-column-span: 1;
  grid-column: span 1;
  -ms-grid-row-span: 1;
  grid-row: span 1; }
  .product-cont-grid .grid-item.item-clm-2 {
    -ms-grid-column-span: 2;
    grid-column: span 2; }
    @media screen and (min-width: 700px) {
      .product-cont-grid .grid-item.item-clm-2 {
        -ms-grid-column-span: 2;
        grid-column: span 2; } }
  .product-cont-grid .grid-item.item-clm-3 {
    -ms-grid-column-span: 2;
    grid-column: span 2; }
    @media screen and (min-width: 700px) {
      .product-cont-grid .grid-item.item-clm-3 {
        -ms-grid-column-span: 3;
        grid-column: span 3; } }
  .product-cont-grid .grid-item.item-clm-4 {
    -ms-grid-column-span: 2;
    grid-column: span 2; }
    @media screen and (min-width: 700px) {
      .product-cont-grid .grid-item.item-clm-4 {
        -ms-grid-column-span: 4;
        grid-column: span 4; } }
  .product-cont-grid .grid-item.item-clm-5 {
    -ms-grid-column-span: 2;
    grid-column: span 2; }
    @media screen and (min-width: 700px) {
      .product-cont-grid .grid-item.item-clm-5 {
        -ms-grid-column-span: 5;
        grid-column: span 5; } }

@media screen and (min-width: 700px) {
  .product-cont-grid .grid-item.item-clm3-1 {
    grid-column: 2 / span 1; } }
@media screen and (min-width: 700px) {
  .product-cont-grid .grid-item.item-clm3-2 {
    grid-column: 3 / span 1; } }
@media screen and (min-width: 700px) {
  .product-cont-grid .grid-item.item-clm3-3 {
    grid-column: 4 / span 1; } }
.product-cont-grid .grid-item.item-clm3-4 {
  grid-column: 1 / span 2; }
  @media screen and (min-width: 700px) {
    .product-cont-grid .grid-item.item-clm3-4 {
      grid-column: 2 / span 3; } }

.pr-cont {
  padding-top: 50px;
  padding-bottom: 50px; }
  .pr-cont table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 0; }
  .pr-cont tr {
    width: 100%; }
    .pr-cont tr.trs1 {
      height: 32px; }
  .pr-cont th {
    color: #555;
    font-size: 14px;
    font-weight: bold;
    border-bottom: 1px solid #DDD;
    background: #BAD7E0;
    line-height: 23pt;
    padding: 6px auto; }
    .pr-cont th.s1 {
      width: 10%;
      text-align: center; }
    .pr-cont th.s2 {
      width: 27%;
      padding-left: 15px;
      padding-right: 15px;
      text-align: left; }
    .pr-cont th.s3 {
      width: 27%;
      padding-left: 15px;
      padding-right: 15px;
      text-align: left; }
    .pr-cont th.s4 {
      width: 36%;
      padding-left: 15px;
      padding-right: 15px;
      text-align: left; }
  .pr-cont td {
    color: #333;
    font-size: 14px;
    border-bottom: 1px solid #DDD;
    line-height: 2; }
    .pr-cont td.s1 {
      width: 10%;
      text-align: center;
      font-weight: bold; }
    .pr-cont td.s2 {
      width: 27%;
      min-width: 140px;
      padding-left: 15px;
      padding-right: 15px;
      text-align: left; }
    .pr-cont td.s3 {
      width: 27%;
      padding-left: 15px;
      padding-right: 15px;
      text-align: left; }
    .pr-cont td.s4 {
      width: 36%;
      padding-left: 15px;
      padding-right: 15px;
      text-align: left; }
  .pr-cont .table > tbody > tr > td {
    padding-top: 15px;
    padding-bottom: 15px; }
  .pr-cont .table-responsive {
    overflow-x: auto; }
  .pr-cont .table-responsive::-webkit-scrollbar {
    height: 5px; }
  .pr-cont .table-responsive::-webkit-scrollbar-track {
    border-radius: 5px;
    background: #eee; }
  .pr-cont .table-responsive::-webkit-scrollbar-thumb {
    border-radius: 5px;
    background: #666; }

/**********************************
scrl-btn
**********************************/
.home #hero1 .scroll-box {
  position: absolute;
  display: block;
  width: 40px;
  height: 50px;
  top: auto;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0 auto;
  padding: 0 0 10px 0;
  z-index: 1; }

.home #hero1 .scroll-box img {
  width: 100%;
  margin: 0;
  padding: 0; }

.page #hero1 .scroll-box {
  position: absolute;
  display: block;
  width: 40px;
  height: 50px;
  top: auto;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0 auto;
  padding: 0 0 10px 0;
  z-index: 1; }

.page #hero1 .scroll-box img {
  width: 100%;
  margin: 0;
  padding: 0; }

/**********************************
con1
**********************************/
/**********************************
foot-sns-menu
**********************************/
.foot-sns-menu-wrap {
  padding-top: 60px; }
  @media screen and (max-width: 420px) {
    .foot-sns-menu-wrap {
      padding-top: 30px; } }

.icon-large {
  display: inline-block;
  width: 88px;
  height: 88px;
  margin: 25px 10px;
  padding: 0 0; }
  @media screen and (max-width: 420px) {
    .icon-large {
      width: 44px;
      height: 44px;
      margin: 20px 10px 10px 10px; } }

.icon-hash {
  display: inline-block;
  width: 195px;
  height: 30px;
  margin: 25px auto;
  padding: 0 0; }
  @media screen and (max-width: 420px) {
    .icon-hash {
      width: 97.5px;
      height: 22px;
      margin: 13px 10px; } }

/**********************************
con2
**********************************/
.btn-cstm-lg {
  display: inline-block;
  position: relative;
  margin-top: 23px;
  width: 100%;
  height: 70px;
  text-align: left; }

.btn-cstm-lg a {
  display: block;
  margin: 0;
  width: 100%;
  cursor: pointer;
  text-decoration: none;
  background: #ed8f26;
  line-height: 70px;
  padding: auto;
  padding-left: 3em;
  font-size: 18px;
  color: #FFF;
  font-weight: bold;
  font-weight: 600;
  letter-spacing: .1em;
  border-radius: 2px;
  -webkit-transition: all .6s;
  -moz-transition: all .6s;
  -ms-transition: all .6s;
  -o-transition: all .6s;
  transition: all .6s; }
  .btn-cstm-lg a::before {
    font-family: 'FontAwesome';
    content: "\f105";
    position: absolute;
    display: inline-block;
    top: 0;
    right: 10px;
    line-height: 70px;
    vertical-align: middle;
    font-size: 24px;
    color: #FFF; }
  .btn-cstm-lg a:hover {
    background: rgba(237, 143, 38, 0.8); }
  @media screen and (max-width: 768px) {
    .btn-cstm-lg a {
      padding-left: auto; } }

body .btn-cstm-contact {
  font-family: "游ゴシック体", "Yu Gothic", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif; }

.btn-cstm-contact {
  display: block;
  position: relative;
  margin: 0 auto;
  margin-top: 46px;
  width: 430px;
  height: 107px;
  text-align: center; }
  @media screen and (max-width: 460px) {
    .btn-cstm-contact {
      width: 100%;
      max-width: 320px;
      height: 70px; } }

.btn-cstm-contact a {
  display: block;
  margin: 0;
  width: 100%;
  cursor: pointer;
  text-decoration: none;
  background: #c1272d;
  line-height: 107px;
  padding: auto;
  padding-left: 3em;
  font-size: 24px;
  color: #FFF;
  font-weight: bold;
  font-weight: 600;
  letter-spacing: .1em;
  border-radius: 7px;
  -webkit-transition: all .6s;
  -moz-transition: all .6s;
  -ms-transition: all .6s;
  -o-transition: all .6s;
  transition: all .6s; }
  @media screen and (max-width: 460px) {
    .btn-cstm-contact a {
      font-size: 20px;
      line-height: 70px;
      padding-left: 1em; } }
  .btn-cstm-contact a::before {
    content: "";
    position: absolute;
    display: block;
    top: 35px;
    left: 4em;
    line-height: 107px;
    width: 47px;
    height: 30px;
    background: url("images/img-icon-contact@2x.png") no-repeat;
    background-size: contain;
    z-index: 3; }
    @media screen and (max-width: 460px) {
      .btn-cstm-contact a::before {
        width: 33px;
        height: 21px;
        top: 24px;
        left: 30px; } }
  .btn-cstm-contact a:hover {
    background: rgba(193, 39, 45, 0.8); }

body .btn-cstm-detail {
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif; }

.btn-cstm-detail {
  display: block;
  position: relative;
  margin: 0 auto;
  margin-top: 46px;
  width: 233px;
  height: 58px;
  text-align: center; }
  @media screen and (max-width: 420px) {
    .btn-cstm-detail {
      /* width: 100%; */ } }

.btn-cstm-detail a {
  display: block;
  margin: 0;
  width: 100%;
  cursor: pointer;
  text-decoration: none;
  background: #1a1a1a;
  /* #1a1a1a */
  line-height: 58px;
  padding: auto;
  font-size: 17px;
  color: #FFF;
  font-weight: normal;
  font-weight: 500;
  letter-spacing: 0.1em;
  border-radius: 7px;
  -webkit-transition: all .6s;
  -moz-transition: all .6s;
  -ms-transition: all .6s;
  -o-transition: all .6s;
  transition: all .6s; }
  .btn-cstm-detail a i {
    padding-left: 10px; }
  .btn-cstm-detail a:hover {
    background: rgba(26, 26, 26, 0.8); }

/**********************************
flex
**********************************/
.list-pict {
  list-style: none;
  margin: 0 auto;
  padding-left: 0;
  padding-right: 0;
  display: -ms-grid;
  display: grid;
  grid-gap: 20px;
  -ms-grid-columns: 1.38fr 0.78fr 0.84fr;
  grid-template-columns: 1.38fr 0.78fr 0.84fr;
  -ms-grid-rows: auto;
  grid-template-rows: auto; }
  @media screen and (max-width: 768px) {
    .list-pict {
      display: block; } }

.list-pict li {
  font-size: 0;
  line-height: 0;
  vertical-align: middle;
  margin: 0;
  padding: 0;
  overflow: hidden; }
  @media screen and (max-width: 768px) {
    .list-pict li {
      margin-bottom: 20px; } }

.list-pict li.box_1 {
  -ms-grid-row: 1;
  -ms-grid-row-span: 2;
  grid-row: 1/ span 2;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
  grid-column: 1 / span 1; }

/* for IE10 IE11 */
_:-ms-input-placeholder, :root .list-pict li.box_1 {
  padding-right: 10px; }
  @media screen and (max-width: 768px) {
    _:-ms-input-placeholder, :root .list-pict li.box_1 {
      padding-right: 0; } }

.list-pict li.box_2 {
  -ms-grid-row: 1;
  -ms-grid-row-span: 1;
  grid-row: 1/ span 1;
  -ms-grid-column: 2;
  -ms-grid-column-span: 1;
  grid-column: 2 / span 1; }

/* for IE10 IE11 */
_:-ms-input-placeholder, :root .list-pict li.box_2 {
  padding-left: 10px;
  padding-right: 10px;
  padding-bottom: 10px; }
  @media screen and (max-width: 768px) {
    _:-ms-input-placeholder, :root .list-pict li.box_2 {
      padding-left: 0;
      padding-right: 0;
      padding-bottom: 0; } }

.list-pict li.box_3 {
  -ms-grid-row: 1;
  -ms-grid-row-span: 1;
  grid-row: 1/ span 1;
  -ms-grid-column: 3;
  -ms-grid-column-span: 1;
  grid-column: 3 / span 1; }

/* for IE10 IE11 */
_:-ms-input-placeholder, :root .list-pict li.box_3 {
  padding-left: 10px;
  padding-bottom: 10px; }
  @media screen and (max-width: 768px) {
    _:-ms-input-placeholder, :root .list-pict li.box_3 {
      padding-left: 0;
      padding-bottom: 0; } }

.list-pict li.box_4 {
  -ms-grid-row: 2;
  -ms-grid-row-span: 1;
  grid-row: 2/ span 1;
  -ms-grid-column: 2;
  -ms-grid-column-span: 1;
  grid-column: 2 / span 1; }

/* for IE10 IE11 */
_:-ms-input-placeholder, :root .list-pict li.box_4 {
  padding-top: 10px;
  padding-left: 10px;
  padding-right: 10px; }
  @media screen and (max-width: 768px) {
    _:-ms-input-placeholder, :root .list-pict li.box_4 {
      padding-top: 0;
      padding-left: 0;
      padding-right: 0; } }

.list-pict li.box_5 {
  -ms-grid-row: 2;
  -ms-grid-row-span: 1;
  grid-row: 2/ span 1;
  -ms-grid-column: 3;
  -ms-grid-column-span: 1;
  grid-column: 3 / span 1; }

/* for IE10 IE11 */
_:-ms-input-placeholder, :root .list-pict li.box_5 {
  padding-top: 10px;
  padding-left: 10px; }
  @media screen and (max-width: 768px) {
    _:-ms-input-placeholder, :root .list-pict li.box_5 {
      padding-top: 0;
      padding-left: 0; } }

.list-pict li {
  position: relative;
  overflow: hidden; }

.list-pict li img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover; }

.list-room {
  list-style: none;
  margin: 0 auto;
  padding-left: 0;
  padding-right: 0;
  display: -ms-grid;
  display: grid;
  grid-gap: 20px;
  -ms-grid-columns: 1.2fr 0.8fr;
  grid-template-columns: 1.2fr 0.8fr;
  -ms-grid-rows: auto;
  grid-template-rows: auto; }

.list-room li {
  font-size: 0;
  line-height: 0;
  vertical-align: middle;
  margin: 0;
  padding: 0;
  overflow: hidden; }

.list-room li.box_1 {
  -ms-grid-row: 1;
  -ms-grid-row-span: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
  grid-column: 1 / span 1; }

.list-room li.box_2 {
  -ms-grid-row: 2;
  -ms-grid-row-span: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1; }

.list-room li.box_3 {
  -ms-grid-row: 1;
  -ms-grid-row-span: 2;
  grid-row: 1/ span 2;
  -ms-grid-column: 2;
  -ms-grid-column-span: 1;
  grid-column: 2 / span 1; }

.list-room li {
  position: relative;
  overflow: hidden; }

.list-room li img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover; }

/**********************************
about-grid-01
**********************************/
.about-grid-01 {
  text-align: left;
  vertical-align: top;
  margin-right: -15px;
  margin-left: -15px;
  margin-bottom: 115px; }
  .about-grid-01 .left {
    position: relative;
    width: 53%;
    vertical-align: top; }
    @media screen and (max-width: 420px) {
      .about-grid-01 .left {
        width: 100%;
        padding-left: 15px;
        padding-right: 15px; } }
  .about-grid-01 .right {
    position: relative;
    width: 47%;
    vertical-align: top; }
    @media screen and (max-width: 420px) {
      .about-grid-01 .right {
        width: 100%;
        padding-left: 15px;
        padding-right: 15px; } }
    .about-grid-01 .right p {
      font-size: 15px;
      line-height: 2;
      letter-spacing: 0.135em;
      padding-left: 13%; }
      @media screen and (max-width: 420px) {
        .about-grid-01 .right p {
          padding-top: 30px;
          padding-left: 0; } }
      .about-grid-01 .right p.about-name {
        font-size: 22px;
        padding-top: 18px;
        letter-spacing: 0.135em;
        text-align: right !important; }
        @media screen and (max-width: 420px) {
          .about-grid-01 .right p.about-name {
            font-size: 18px; } }
        .about-grid-01 .right p.about-name span {
          display: inline-block;
          /* padding-right: 1em; */
          font-size: 18px;
          letter-spacing: 0.14em; }
          @media screen and (max-width: 420px) {
            .about-grid-01 .right p.about-name span {
              font-size: 14px; } }
      .about-grid-01 .right p.cap-text.text-small {
        padding-top: 1em;
        font-size: 13px;
        line-height: 1.428; }
    .about-grid-01 .right .gaiyo-list {
      width: 100%;
      margin: 0 0;
      padding-left: 13%;
      font-size: 18px;
      line-height: 1.85;
      letter-spacing: 0.12em;
      vertical-align: top; }
      @media screen and (max-width: 420px) {
        .about-grid-01 .right .gaiyo-list {
          font-size: 16px;
          padding-top: 30px;
          padding-left: 0; } }
      .about-grid-01 .right .gaiyo-list dt {
        display: inline-block;
        width: 110px;
        vertical-align: top;
        line-height: 1.85;
        /* margin-bottom: 10px; */
        letter-spacing: 0.12em; }
      .about-grid-01 .right .gaiyo-list dd {
        display: inline-block;
        width: calc(100% - 110px);
        vertical-align: top;
        line-height: 1.85;
        /* margin-bottom: 10px; */
        letter-spacing: 0.12em; }

/**********************************
news-grid-01
**********************************/
.news-grid-01 {
  text-align: center;
  vertical-align: top;
  margin-right: -15px;
  margin-left: -15px; }
  .news-grid-01 .left {
    position: relative;
    width: 50%;
    vertical-align: top; }
    @media screen and (max-width: 420px) {
      .news-grid-01 .left {
        width: 100%;
        padding-left: 15px;
        padding-right: 15px; } }
  .news-grid-01 .right {
    position: relative;
    width: 50%;
    vertical-align: top;
    padding-left: 30px;
    padding-right: 30px; }
    @media screen and (max-width: 420px) {
      .news-grid-01 .right {
        width: 100%;
        padding-left: 15px;
        padding-right: 15px; } }
    .news-grid-01 .right.bnr-pdf-wrap {
      padding-top: 80px; }
      @media screen and (max-width: 420px) {
        .news-grid-01 .right.bnr-pdf-wrap {
          padding-top: 20px; } }

.fb-wrap h3 {
  margin-bottom: 30px; }
  @media screen and (max-width: 767px) {
    .fb-wrap h3 {
      margin-bottom: 30px; } }

.bnr-pdf-wrap {
  vertical-align: middle;
  text-align: center; }
  .bnr-pdf-wrap .bnr-pdf {
    display: inline-block;
    margin: 40px auto; }
    @media screen and (max-width: 768px) {
      .bnr-pdf-wrap .bnr-pdf {
        margin: 20px auto; } }
    .bnr-pdf-wrap .bnr-pdf img {
      max-width: 390px;
      margin: 0 auto; }

/**************************
form
**************************/
#formWrap {
  width: 100%;
  max-width: 796px;
  margin: 0 auto;
  color: #333;
  line-height: 1; }
  @media screen and (max-width: 826px) {
    #formWrap {
      padding-left: 15px;
      padding-right: 15px; } }
  @media screen and (max-width: 572px) {
    #formWrap {
      padding-left: 0;
      padding-right: 0; } }
  #formWrap table.formTable {
    width: 100%;
    margin: 0 auto;
    margin-bottom: 13px;
    border-collapse: collapse; }
  #formWrap table.formTable tr.spacebar th, #formWrap table.formTable tr.spacebar td {
    padding: 0 0;
    height: 13px;
    background: rgba(255, 255, 255, 0); }
  #formWrap table.formTable td, #formWrap table.formTable th {
    vertical-align: middle;
    background: #FFF; }
  #formWrap table.formTable th {
    /* width:30%; */
    width: 100px;
    /* font-weight:normal; */
    font-weight: bold;
    text-align: center;
    font-size: 12px;
    padding: 5px 0; }
    #formWrap table.formTable th span {
      display: inline-block;
      width: 100%;
      height: 30px;
      padding: 0 10px;
      font-weight: bold;
      border-right: 1px solid #333;
      vertical-align: middle;
      line-height: 30px;
      white-space: nowrap; }
  #formWrap table.formTable td {
    padding: 5px 15px; }

/*　responsive　*/
@media screen and (max-width: 572px) {
  #formWrap {
    width: 95%;
    margin: 0 auto; }
    #formWrap table.formTable th, #formWrap table.formTable td {
      width: auto;
      display: block; }
    #formWrap table.formTable th {
      /* margin-top:5px; */
      padding: 5px 10px;
      border-bottom: 0; }
      #formWrap table.formTable th span {
        height: 30px;
        padding: 0 10px;
        border-right: 0 none;
        border-bottom: 1px solid #333; }
    #formWrap table.formTable td {
      padding: 10px 10px; }
    #formWrap input[type="text"], #formWrap textarea {
      width: 100%;
      padding: 5px;
      /* font-size: 110%; */
      display: block; }
    #formWrap input[type="submit"], #formWrap input[type="reset"], #formWrap input[type="button"] {
      display: block;
      width: 100%;
      height: 40px; } }
/**********************************
contact-cont
**********************************/
#formWrap {
  text-align: left; }
  #formWrap label {
    width: 100%;
    text-align: left;
    margin-bottom: 20px; }
  #formWrap input {
    width: 100%;
    /* max-width: 600px; */
    /* margin-bottom: 10px; */
    border: 1px solid #000; }
  #formWrap textarea {
    width: 100%;
    /* max-width: 600px; */
    margin-bottom: 10px; }
  #formWrap input[type="submit"] {
    font-size: 16px;
    display: block;
    margin-left: auto;
    margin-right: auto;
    padding: 8px;
    background: #7fbf29;
    font-weight: bold;
    color: #FFF;
    width: 50%;
    height: 50px;
    cursor: pointer;
    box-shadow: 0 0 1px #b5ebb2;
    border: 0 solid #7fbf29;
    letter-spacing: 0.2em; }
  #formWrap input[type="button"] {
    font-size: 16px;
    display: block;
    margin-left: auto;
    margin-right: auto;
    padding: 8px;
    background: #EEE;
    font-weight: normal;
    color: #333;
    /* border-radius: 4px; */
    width: 50%;
    height: 50px;
    cursor: pointer;
    box-shadow: 0 0 1px #b5ebb2;
    border: 1px solid #666; }
  #formWrap input[type="reset"] {
    font-size: 16px;
    display: block;
    margin-left: auto;
    margin-right: auto;
    padding: 8px;
    background: #EEE;
    font-weight: normal;
    color: #333;
    /* border-radius: 4px; */
    width: 50%;
    height: 50px;
    cursor: pointer;
    box-shadow: 0 0 1px #b5ebb2;
    border: 1px solid #666; }
  #formWrap input[type="submit"]:hover {
    opacity: 0.8; }
  #formWrap input[type="submit"][disabled] {
    color: #666;
    border: 2px solid #666; }
  #formWrap input[type="submit"][disabled]:hover {
    cursor: not-allowed;
    opacity: 1; }

.contact-cont {
  /* width: 80%; */
  width: 100%;
  max-width: 796px;
  margin: 0 auto;
  padding: 60px 0 40px 0;
  text-align: left; }
  .contact-cont h4 {
    font-size: 16px !important;
    font-weight: bold;
    text-align: left;
    padding-bottom: 24px;
    color: #FFF; }
  .contact-cont p {
    font-size: 15px !important;
    text-align: left;
    padding-bottom: 20px;
    color: #FFF; }
    .contact-cont p a {
      color: #0068b7; }

.subject-select-wrap .radio-group-button {
  display: flex;
  gap: 10px;
  /* ボタン間の余白 */ }
.subject-select-wrap .radio-group-button input[type="radio"] {
  display: none; }
.subject-select-wrap .radio-group-button label {
  display: block;
  padding: 15px 30px;
  border: 0 none;
  border-radius: 0;
  cursor: pointer;
  font-weight: bold;
  color: #333;
  background-color: #FFF;
  text-align: center;
  transition: all 0.3s ease; }
.subject-select-wrap .radio-group-button label:hover {
  background-color: #f5f5f5;
  /* ホバー時の背景色 */ }
.subject-select-wrap .radio-group-button input[type="radio"]:checked + label {
  background-color: #7fbf29;
  color: #fff;
  border-color: #7fbf29; }

#formWrap .radio-group-button label {
  text-align: center;
  margin-bottom: 13px; }
  @media screen and (max-width: 572px) {
    #formWrap .radio-group-button label {
      margin-bottom: 26px;
      line-height: 1.3; } }

#formWrap {
  /* ▼IE10・IE11 */
  /* ▼Chrome・Safari・Opera */
  /* ▼Firefox19以上 */
  /* ▼CSS4 */ }
  @media screen and (max-width: 572px) {
    #formWrap :-ms-input-placeholder {
      font-size: 80%; } }
  @media screen and (max-width: 572px) {
    #formWrap ::-webkit-input-placeholder {
      font-size: 80%; } }
  @media screen and (max-width: 572px) {
    #formWrap ::-moz-placeholder {
      font-size: 80%; } }
  @media screen and (max-width: 572px) {
    #formWrap ::placeholder {
      font-size: 80%; } }

.textarea-wrap {
  width: 100%;
  text-align: left;
  margin-bottom: 30px; }
  .textarea-wrap label {
    width: 100%;
    text-align: left;
    margin-bottom: 20px; }
  .textarea-wrap input {
    width: 100%;
    /* max-width: 600px; */
    /* margin-bottom: 10px; */
    border: 1px solid #000; }
  .textarea-wrap textarea {
    width: 100%;
    /* max-width: 600px; */
    margin-bottom: 10px;
    border: 1px solid #000; }
  .textarea-wrap input[type="submit"] {
    font-size: 18px;
    display: block;
    margin-left: auto;
    margin-right: auto;
    padding: 8px;
    background: #F8F8F8;
    font-weight: bold;
    color: #394287;
    border-radius: 4px;
    width: 50%;
    height: 50px;
    cursor: pointer;
    box-shadow: 0 0 1px #b5ebb2;
    border: 2px solid #394287; }
  .textarea-wrap input[type="reset"] {
    font-size: 18px;
    display: block;
    margin-left: auto;
    margin-right: auto;
    padding: 8px;
    background: #EEE;
    font-weight: normal;
    color: #333;
    border-radius: 4px;
    width: 50%;
    height: 50px;
    cursor: pointer;
    box-shadow: 0 0 1px #b5ebb2;
    border: 1px solid #666; }
  .textarea-wrap input[type="submit"][disabled] {
    color: #666;
    border: 2px solid #666; }
  .textarea-wrap input[type="submit"][disabled]:hover {
    cursor: not-allowed;
    opacity: 1; }
  .textarea-wrap .textarea-title {
    display: inline-block;
    vertical-align: middle;
    background: #FFF;
    width: 100%;
    font-weight: bold;
    text-align: left;
    font-size: 12px;
    padding: 5px 0 0 15px; }
    @media screen and (max-width: 572px) {
      .textarea-wrap .textarea-title {
        padding: 5px 10px 5px 10px; } }
    .textarea-wrap .textarea-title span {
      display: inline-block;
      width: 100px;
      height: 30px;
      padding: 0 0;
      text-align: center;
      font-weight: bold;
      border-bottom: 1px solid #333;
      vertical-align: middle;
      line-height: 30px;
      white-space: nowrap; }
      @media screen and (max-width: 572px) {
        .textarea-wrap .textarea-title span {
          width: 100%; } }
  .textarea-wrap .textarea-cont {
    vertical-align: middle;
    background: #FFF;
    padding: 5px 15px; }
    @media screen and (max-width: 572px) {
      .textarea-wrap .textarea-cont {
        padding: 5px 10px; } }

.btn-back-contact {
  display: block;
  position: relative;
  margin: 0 auto;
  margin-top: 26px;
  width: 340px;
  height: 50px;
  text-align: center; }
  @media screen and (max-width: 460px) {
    .btn-back-contact {
      width: 100%;
      max-width: 340px;
      height: 50px; } }

.btn-back-contact a {
  display: block;
  margin: 0;
  width: 100%;
  cursor: pointer;
  text-decoration: none;
  background: rgba(0, 68, 153, 0.6);
  line-height: 50px;
  padding: auto;
  font-size: 16px;
  color: #FFF;
  font-weight: bold;
  font-weight: 600;
  letter-spacing: .1em;
  border-radius: 0;
  -webkit-transition: all .6s;
  -moz-transition: all .6s;
  -ms-transition: all .6s;
  -o-transition: all .6s;
  transition: all .6s; }
  @media screen and (max-width: 460px) {
    .btn-back-contact a {
      font-size: 16px;
      line-height: 50px; } }
  .btn-back-contact a:hover {
    background: #004499; }

.contact-check .cont-wrapper {
  position: relative;
  display: block;
  margin: 0 auto 30px auto;
  width: 100%;
  height: 100%;
  border-left: 4px solid rgba(255, 255, 255, 0.4);
  border-top: 4px solid rgba(0, 0, 0, 0.4);
  border-right: 4px solid rgba(0, 0, 0, 0.2);
  border-bottom: 4px solid rgba(255, 255, 255, 0.5);
  border-radius: 4px;
  background: rgba(33, 33, 33, 0.4); }
  @media screen and (min-width: 1176px) {
    .contact-check .cont-wrapper {
      margin: 30px auto 30px auto;
      max-width: 1176px;
      height: calc(100vh - 100px);
      max-height: 100%;
      overflow-y: scroll;
      border-left: 4px solid rgba(255, 255, 255, 0.4);
      border-top: 4px solid rgba(0, 0, 0, 0.4);
      border-right: 4px solid rgba(0, 0, 0, 0.2);
      border-bottom: 4px solid rgba(255, 255, 255, 0.5);
      border-radius: 4px; } }

.contact-check .cont-wrap {
  padding-top: 40px;
  padding-bottom: 40px;
  text-align: center; }

.contact-check #formWrap {
  background: rgba(255, 255, 255, 0.9);
  padding: 15px; }
  .contact-check #formWrap h3 {
    padding: 13px 13px; }
  .contact-check #formWrap p {
    margin-bottom: 13px;
    padding: 0 13px; }
  .contact-check #formWrap .err-text {
    font-weight: bold;
    color: red; }
  .contact-check #formWrap table.formTable {
    margin-bottom: 20px; }
  .contact-check #formWrap table.formTable th {
    padding: 10px 15px;
    width: 126px; }
  .contact-check #formWrap table.formTable td {
    padding: 10px 15px; }
  .contact-check #formWrap input[type="button"] {
    margin-top: 20px; }
    .contact-check #formWrap input[type="button"]:hover {
      background: rgba(0, 0, 0, 0.15); }

.controls {
  display: none;
  width: 100%;
  margin-top: 40px;
  text-align: center; }
  @media screen and (min-width: 1176px) {
    .controls {
      display: block; } }
  .controls button {
    font-size: 14px;
    display: inline-block;
    margin-left: auto;
    margin-right: auto;
    padding: 0;
    background: #333;
    font-weight: bold;
    color: #394287;
    border-radius: 1px;
    width: 40px;
    height: 40px;
    cursor: pointer;
    border: 0 none; }

.ex-icon {
  display: inline-block;
  width: 1em; }
  .ex-icon img {
    display: inline-block;
    width: 100%;
    vertical-align: baseline; }

/**************************
print-adjust
**************************/
@media print {
  /**************************
  header
  **************************/
  header {
    margin: 0 auto;
    /* overflow: hidden; */
    *zoom: 1;
    text-align: center;
    box-sizing: border-box; }

  header {
    position: fixed;
    top: 1px;
    left: 0;
    margin-top: -1px;
    width: 100%;
    display: block;
    height: 96px;
    z-index: 333;
    background: #1a1a1a;
    /* #1a1a1a */ }

  .header-inner {
    position: relative;
    margin: 0 auto;
    text-align: center;
    display: block;
    width: 100%;
    max-width: 1200px;
    height: 100%; }

  /*----- フェードイン -----*/
  .inviewfadeIn {
    opacity: 1;
    transition: none; }

  .fadeIn {
    opacity: 1; } }

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