@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; }

header {
  position: fixed;
  top: 10px;
  left: 0;
  width: 100%;
  display: block;
  height: 60px;
  padding-top: 5px;
  padding-bottom: 5px;
  z-index: 333;
  border-top: 1px solid #FFF;
  border-bottom: 1px solid #FFF;
  /* background: rgba(00,76,40,1); */
  -webkit-transition: all .3s ease;
  -moz-transition: all .3s ease;
  -ms-transition: all .3s ease;
  transition: all .3s ease; }
  header.is-header {
    top: 0px;
    height: 50px;
    padding-top: 0;
    padding-bottom: 0;
    border-top: 0 none;
    border-bottom: 0 none; }
  @media screen and (max-width: 768px) {
    header {
      top: 0;
      height: 50px;
      padding-top: 0;
      padding-bottom: 0;
      background: white; } }

.home header {
  top: 80px; }
  .home header.is-header {
    top: 0px; }
  @media screen and (max-width: 768px) {
    .home header {
      top: 0; } }

.header-inner {
  position: relative;
  margin: 0 auto;
  text-align: center;
  display: block;
  width: 100%;
  /* max-width: 1200px; */
  height: 100%;
  background: rgba(255, 255, 255, 0.9); }

/**************************
nav
**************************/
#navToggle {
  display: none;
  position: absolute;
  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: 768px) {
  #slideMenu .menu {
    /* display: none; */ }

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

  #slideMenu .menu {
    display: block;
    position: absolute;
    right: 0;
    top: -600px;
    height: 600px;
    background: rgba(0, 0, 0, 0.8);
    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: 768px) {
  #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%; */ } }
/**************************
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; }

.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 li {
    display: inline-block;
    margin: 0 0;
    padding: 5px 0;
    text-align: center;
    /* width: 100px; */
    height: 50px;
    vertical-align: top;
    -webkit-transition: all .3s ease;
    -moz-transition: all .3s ease;
    -ms-transition: all .3s ease;
    transition: all .3s ease; }
    .global-menu li a {
      position: relative;
      display: block;
      width: 100%;
      height: 40px;
      margin: 0 0;
      padding: 5px 20px;
      padding-top: 18px;
      line-height: 1;
      color: #333;
      font-size: 14px;
      letter-spacing: 0.15em;
      font-weight: bold;
      border-left: 1px solid #CCC;
      vertical-align: top;
      background: rgba(200, 200, 200, 0);
      -webkit-transition: all .3s ease;
      -moz-transition: all .3s ease;
      -ms-transition: all .3s ease;
      transition: all .3s ease; }
      .global-menu li a span {
        position: absolute;
        display: inline-block;
        width: 100%;
        height: 12px;
        top: 3px;
        left: 0;
        right: 0;
        margin: 0 auto;
        color: #555;
        font-size: 12px;
        text-align: center;
        font-weight: normal; }
      .global-menu li a.menu-logo {
        width: 140px;
        padding-top: 8px;
        padding-left: 10px;
        padding-right: 10px; }
        .global-menu li a.menu-logo img {
          width: 100%;
          height: auto; }
      .global-menu li a.current {
        color: #0068b7; }
      .global-menu li a:hover {
        background: rgba(200, 200, 200, 0.5); }
      .global-menu li a.red {
        color: gray; }
      .global-menu li a.red:hover {
        color: #0068b7; }
    .global-menu li:last-child a {
      letter-spacing: 0;
      border-right: 1px solid #CCC; }

@media screen and (max-width: 768px) {
  .global-menu-wrap {
    display: none; }

  .global-menu {
    display: none; } }
/**************************
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: none;
  margin: 0;
  padding: 0;
  top: 12px;
  left: 15px;
  right: auto;
  bottom: auto;
  width: 130px;
  height: 28px;
  vertical-align: middle;
  -webkit-transition: all .5s ease;
  -moz-transition: all .5s ease;
  -ms-transition: all .5s ease;
  transition: all .5s ease; }
  @media screen and (max-width: 768px) {
    header .logo {
      display: inline-block; } }
  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(00,00,00,1); */
  background-color: #000;
  position: fixed;
  top: auto;
  bottom: 0;
  left: 0;
  right: 0;
  display: block;
  width: 100%;
  height: 40px;
  padding: 5px auto;
  color: #FFF;
  font-size: 14px;
  text-align: center;
  z-index: 10; }
  @media screen and (max-width: 768px) {
    footer {
      position: relative;
      margin: 0 auto;
      padding: 0 0;
      top: auto;
      bottom: auto;
      left: auto;
      right: auto; } }
  @media screen and (max-width: 700px) {
    footer {
      height: 100px;
      margin: 0 auto;
      padding: 0 0; } }

footer .copyright {
  position: absolute;
  display: inline-block;
  margin: 0 0;
  padding: 0 0;
  top: 0;
  left: auto;
  left: 15px;
  bottom: auto;
  width: 100px;
  height: 40px;
  font-size: 13px;
  line-height: 40px;
  text-align: left;
  vertical-align: bottom; }
  @media screen and (max-width: 700px) {
    footer .copyright {
      width: 100%;
      text-align: center;
      height: 24px;
      line-height: 24px;
      padding: 0 auto;
      top: auto;
      bottom: 5px;
      left: auto;
      right: auto; } }
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
**********************************/
.container .nm-section {
  margin-left: -15px;
  margin-right: -15px; }

h3 {
  position: relative;
  font-weight: 600;
  font-size: 26px;
  color: #333; }
  @media screen and (max-width: 328px) {
    h3 {
      font-size: 20px; } }
  h3 .num {
    display: inline-block;
    font-size: 28px;
    font-weight: 600;
    letter-spacing: 0.16em;
    padding-bottom: 2px; }
    @media screen and (max-width: 328px) {
      h3 .num {
        font-size: 22px;
        letter-spacing: 0.03em; } }
  h3 .text-small {
    font-size: 16px;
    font-weight: 400;
    letter-spacing: 0.06em;
    line-height: 2; }
  h3 .un-line {
    padding-bottom: 3px;
    border-bottom: 1px #4c2d13 solid; }
  h3 .title-img {
    display: block;
    height: auto; }

h3.title-img {
  width: 320px;
  margin: 40px auto 80px auto;
  font-size: 35px;
  font-weight: bold;
  letter-spacing: 0.1em; }
  @media screen and (max-width: 768px) {
    h3.title-img {
      margin: 20px auto 40px auto; } }
  @media screen and (max-width: 420px) {
    h3.title-img {
      font-size: 24px;
      width: 100%;
      margin: 20px auto 40px auto;
      padding: 0 10px; } }

h3.title-img-sub {
  /* width: 320px; */
  margin: 0 auto 30px auto;
  font-size: 34px;
  font-weight: bold;
  letter-spacing: 0.05em; }
  h3.title-img-sub.title-img-sub-02 {
    margin: 70px auto 60px auto; }
  h3.title-img-sub img {
    text-align: center;
    margin: 0 auto;
    width: 100%;
    max-width: 768px; }
  @media screen and (max-width: 768px) {
    h3.title-img-sub {
      margin: 0 auto 20px auto; } }
  @media screen and (max-width: 420px) {
    h3.title-img-sub {
      width: 100%;
      margin: 0 auto 20px auto;
      padding: 0 0;
      font-size: 24px; } }

h3.logo-mark-img {
  width: 43px;
  height: 42px;
  margin: 40px auto 20px auto;
  font-size: 35px;
  font-weight: bold;
  letter-spacing: 0.1em; }
  @media screen and (max-width: 768px) {
    h3.logo-mark-img {
      margin: 20px auto 20px auto; } }
  @media screen and (max-width: 420px) {
    h3.logo-mark-img {
      font-size: 24px;
      margin: 20px auto 20px auto; } }

h3.foot-title-img {
  width: 320px;
  margin: 80px auto 80px auto; }
  @media screen and (max-width: 768px) {
    h3.foot-title-img {
      width: 75%;
      margin: 50px auto 50px auto; } }
  @media screen and (max-width: 420px) {
    h3.foot-title-img {
      margin: 30px auto 30px auto; } }

h4.conttitle {
  font-size: 26px;
  font-weight: 600;
  padding-bottom: 13px;
  letter-spacing: 0.01em; }
h4.page-conttitle {
  font-size: 26px;
  font-weight: 600;
  padding-bottom: 40px;
  letter-spacing: 0.01em; }
h4 .num {
  font-size: 19px;
  font-weight: 300;
  letter-spacing: 0.1em; }

h4.title-copy {
  font-size: 44px;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 1.88;
  padding-bottom: 40px;
  color: #1a1a1a; }
  h4.title-copy img {
    text-align: center;
    margin: 0 auto;
    width: 100%;
    max-width: 768px; }
  @media screen and (max-width: 768px) {
    h4.title-copy {
      font-size: 35px;
      padding-left: 10px;
      padding-right: 10px; } }
  @media screen and (max-width: 420px) {
    h4.title-copy {
      font-size: 24px;
      letter-spacing: 0.05em;
      margin-left: -15px;
      margin-right: -15px;
      padding-left: 0;
      padding-right: 0; } }
  h4.title-copy.title-copy-topmgn {
    padding-top: 50px; }

h5.subtitle {
  font-size: 14px;
  color: #0068b7;
  padding-bottom: 13px; }

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; }

/**********************************
hero1
**********************************/
#hero1 {
  /* margin-top: 60px; */ }

@media screen and (max-width: 768px) {
  #hero1 {
    /* margin-top: 60px; */ } }
.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; }
  @media screen and (max-width: 768px) {
    .home #hero1 {
      /* height: 84.8vw; */ } }

.page #hero1 {
  position: relative; }

.page #hero1-main {
  position: relative;
  width: 100%;
  /* 
  min-height: 400px;
  height: auto !important;
  height: 400px; 
  */
  min-height: 300px;
  height: auto !important;
  height: 300px;
  text-align: center; }
  @media screen and (min-width: 1400px) {
    .page #hero1-main {
      /* 
      min-height: 450px;
      height: auto !important;
      height: 450px;
      */ } }
  @media screen and (max-width: 960px) {
    .page #hero1-main {
      /*
      min-height: 350px;
      height: auto !important;
      height: 350px;
      */ } }
  @media screen and (max-width: 768px) {
    .page #hero1-main {
      /*
      min-height: 240px;
      height: auto !important;
      height: 240px;
      */
      min-height: 200px;
      height: auto !important;
      height: 200px; } }
  @media screen and (max-width: 420px) {
    .page #hero1-main {
      /*
      min-height: 200px;
      height: auto !important;
      height: 200px;
      */
      min-height: 200px;
      height: auto !important;
      height: 200px; } }
  .page #hero1-main.company {
    /*
    background: url("images/company/img-main-01@2x.jpg") center/cover no-repeat;
    -webkit-background-size: cover;
    background-size: cover;
    */
    background-color: #0068B7; }
  .page #hero1-main.facilities {
    /* 
    background: url("images/facilities/img-main-01@2x.jpg") center/cover no-repeat;
    -webkit-background-size: cover;
    background-size: cover;
    */
    background-color: #0068B7; }
  .page #hero1-main.product {
    /* 
    background: url("images/product/img-main-01@2x.jpg") center/cover no-repeat;
    -webkit-background-size: cover;
    background-size: cover;
    */
    background-color: #0068B7; }
  .page #hero1-main.contact {
    /* background: rgba(02,132,132,1); */
    background-color: #0068B7;
    min-height: 300px;
    height: auto !important;
    height: 300px; }
    @media screen and (max-width: 420px) {
      .page #hero1-main.contact {
        min-height: 200px;
        height: auto !important;
        height: 200px; } }

.bg-paper {
  background: url("images/bg-paper.jpg") center top repeat-y;
  background-size: 100%; }

.bg-parts {
  background: url("images/bg-parts@2x.jpg") center top repeat-y;
  background-size: 100%; }

/* #0068B7 */
.bg-theme {
  background: #0068b7; }

.bg-white {
  background: white; }

.bg-gray {
  background: whitesmoke; }

.bg-blue {
  background: #bad7e0; }

.bg-green {
  background: #028484; }

.cont-wrap {
  padding-top: 50px;
  /* padding-bottom: 50px; */
  height: auto;
  text-align: center; }
  @media screen and (max-width: 768px) {
    .cont-wrap {
      padding-top: 30px; } }
  @media screen and (max-width: 420px) {
    .cont-wrap {
      padding-bottom: 30px; } }
  .cont-wrap.cont-wrap-long {
    padding-top: 120px;
    padding-bottom: 120px; }
    @media screen and (max-width: 768px) {
      .cont-wrap.cont-wrap-long {
        padding-top: 50px;
        padding-bottom: 50px; } }
  .cont-wrap.np-cont {
    padding-top: 0; }
    @media screen and (max-width: 768px) {
      .cont-wrap.np-cont {
        padding-top: 0; } }

.page #conINST {
  padding-bottom: 14em; }
  @media screen and (max-width: 1280px) {
    .page #conINST {
      padding-bottom: 14em; } }
  @media screen and (max-width: 960px) {
    .page #conINST {
      padding-bottom: 10em; } }

/**********************************
main-image
**********************************/
.home #hero1-main {
  position: relative;
  border: 0;
  width: 100%;
  height: 100%;
  /* height: calc(100% - 60px) !important; */
  margin-bottom: 0; }
  .home #hero1-main.bg-main {
    background: url("images/main@2x.jpg") center/cover no-repeat;
    -webkit-background-size: cover;
    background-size: cover; }
    @media screen and (max-width: 768px) {
      .home #hero1-main.bg-main {
        /* background: url("images/main_tb@2x.jpg") center/cover no-repeat; */ } }
    @media screen and (max-width: 420px) {
      .home #hero1-main.bg-main {
        /* background: url("images/main_sp@2x.jpg") center/cover no-repeat; */ } }

#hero1-main-inner {
  position: absolute;
  display: block;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 500px;
  height: 160px;
  margin: auto auto;
  padding: 0 0;
  z-index: 30;
  -webkit-transform: translateY(20%);
  -ms-transform: translateY(20%);
  transform: translateY(20%); }
  @media screen and (max-width: 768px) {
    #hero1-main-inner {
      width: 70vw;
      height: 33.04vw; } }
  #hero1-main-inner .logo-02 {
    width: 100%;
    height: auto; }

@keyframes animebefore {
  0% {
    opacity: 1; }
  100% {
    opacity: 0; } }
@keyframes animeafter {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
.page #hero1 .copy-main {
  position: absolute;
  display: block;
  width: 100%;
  height: auto;
  left: 0;
  right: 0;
  top: 50%;
  bottom: auto;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  margin: auto;
  padding: auto;
  z-index: 1;
  text-align: center; }

.page.contact #hero1 .copy-main {
  top: 57%; }

.page #hero1 .copy-main h1 {
  text-align: center;
  font-size: 39px;
  letter-spacing: 0.1em;
  line-height: 1.2;
  color: #FFF;
  font-weight: 600; }
  @media screen and (max-width: 420px) {
    .page #hero1 .copy-main h1 {
      font-size: 28px; } }

.page.normal #hero1 .copy-main h1 {
  margin-top: auto;
  margin-bottom: auto; }
  @media screen and (max-width: 360px) {
    .page.normal #hero1 .copy-main h1 {
      font-size: 30px; } }

/* ****************************************
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%; } }

/**********************************
company-cont
**********************************/
.company-cont {
  height: auto; }
  .company-cont .left {
    width: 50%;
    position: relative;
    overflow: hidden;
    text-align: center;
    position: relative;
    height: 35.9375vw;
    padding: 0 0;
    /* height resp */
    vertical-align: top; }
    .company-cont .left.company-img-01 {
      background: url(images/company/img-com-01@2x.jpg) no-repeat center center;
      background-size: cover; }
    .company-cont .left.company-img-02 {
      background: url(images/company/img-com-02@2x.jpg) no-repeat center center;
      background-size: cover; }
    .company-cont .left.company-img-03 {
      background: url(images/company/img-com-03@2x.jpg) no-repeat center center;
      background-size: cover; }
    @media screen and (max-width: 900px) {
      .company-cont .left {
        height: 45vw; } }
    @media screen and (max-width: 768px) {
      .company-cont .left {
        height: 55vw; } }
    @media screen and (max-width: 700px) {
      .company-cont .left {
        width: 100%;
        height: 71.875vw; } }
    @media screen and (max-width: 420px) {
      .company-cont .left {
        width: 100%;
        height: 71.875vw; } }
  .company-cont .right {
    width: 50%;
    padding: 60px 60px;
    /* padding-top: 40px; */
    vertical-align: top;
    height: 35.9375vw; }
    @media screen and (max-width: 900px) {
      .company-cont .right {
        height: 45vw;
        padding: 30px 30px; } }
    @media screen and (max-width: 768px) {
      .company-cont .right {
        height: 55vw;
        padding: 30px 30px; } }
    @media screen and (max-width: 700px) {
      .company-cont .right {
        width: 100%;
        height: auto;
        padding: 30px 15px;
        padding-top: 20px; } }
    @media screen and (max-width: 420px) {
      .company-cont .right {
        padding: 30px 15px;
        padding-top: 20px; } }
    .company-cont .right h4 {
      color: #FFF !important; }
    .company-cont .right p {
      color: #FFF !important;
      line-height: 2.1; }
      @media screen and (max-width: 900px) {
        .company-cont .right p {
          font-size: 14px;
          line-height: 1.8; } }

/**********************************
fa-cont
**********************************/
.container-fluid.fa-cont-wrapper,
.container.fa-cont-wrapper {
  padding-left: 24px;
  padding-right: 24px;
  padding-bottom: 100px; }

.row.fa-cont {
  margin: 0 auto;
  padding-top: 40px;
  padding-left: 24px;
  padding-right: 24px;
  padding-bottom: 24px; }
  @media screen and (max-width: 700px) {
    .row.fa-cont {
      padding-top: 24px;
      padding-left: 15px;
      padding-right: 15px;
      padding-bottom: 24px; } }

.fa-cont {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: auto;
  margin: 0 auto;
  background: #FFF;
  /* padding: 40px; */ }
  @media screen and (max-width: 700px) {
    .fa-cont {
      display: inherit;
      display: relative;
      padding: 15px; } }
  .fa-cont .left {
    /* width: 50%; */
    width: 60%;
    position: relative;
    overflow: hidden;
    text-align: center;
    position: relative;
    /* height: 35.9375vw; */
    padding: 0 0;
    /* height resp */
    vertical-align: top; }
    .fa-cont .left.fa-img-01 {
      	    /*
      	    background: url(images/facilities/img-fa-01@2x.jpg) no-repeat center center;
              background-size: cover;
              */ }
    .fa-cont .left.fa-img-02 {
      	    /*
      	    background: url(images/facilities/img-fa-02@2x.jpg) no-repeat center center;
              background-size: cover;
              */ }
      .fa-cont .left.fa-img-02 img {
        margin-bottom: 3px; }
      .fa-cont .left.fa-img-02 img:last-child {
        margin-bottom: 0; }
    .fa-cont .left.fa-img-03 {
      	    /*
      	    background: url(images/facilities/img-fa-03@2x.jpg) no-repeat center center;
              background-size: cover;
              */
      /* 
      .last-item {
          
          position: relative;
          display: block;
          margin-bottom: 0;
          z-index: 1;
          &::after {
              content: '';
              position: absolute;
              display: block;
              width: 3px;
              height: 100%;
              top: 0;
              left: 0;
              right: 0;
              bottom: 0;
              margin: 0 auto;
              padding: 0 0 0 0;
              z-index: 3;
              background: #FFF;   
          }
          
      }
      */ }
      .fa-cont .left.fa-img-03 img {
        margin-bottom: 3px; }
      .fa-cont .left.fa-img-03 img:last-child {
        margin-bottom: 0; }
    .fa-cont .left.fa-img-04 {
      	    /*
      	    background: url(images/facilities/img-fa-04@2x.jpg) no-repeat center center;
              background-size: cover;
              */ }
    @media screen and (max-width: 900px) {
      .fa-cont .left {
        /* height: 45vw; */ } }
    @media screen and (max-width: 768px) {
      .fa-cont .left {
        /* height: 55vw; */ } }
    @media screen and (max-width: 700px) {
      .fa-cont .left {
        width: 100%;
        /* height: 71.875vw; */ } }
    @media screen and (max-width: 420px) {
      .fa-cont .left {
        width: 100%;
        /* height: 71.875vw; */ } }
    .fa-cont .left.fa-pc {
      display: block; }
      @media screen and (max-width: 700px) {
        .fa-cont .left.fa-pc {
          display: none; } }
    .fa-cont .left.fa-sp {
      display: none; }
      @media screen and (max-width: 700px) {
        .fa-cont .left.fa-sp {
          display: block; } }
  .fa-cont .right {
    width: 40%;
    /* padding: 50px 60px; */
    padding: 0 0 0 30px;
    /* padding-top: 40px; */
    vertical-align: top;
    /* height: 35.9375vw; */ }
    @media screen and (max-width: 900px) {
      .fa-cont .right {
        /* height: 45vw; */
        /* padding: 30px 30px; */ } }
    @media screen and (max-width: 768px) {
      .fa-cont .right {
        /* height: 55vw; */
        /* padding: 30px 30px; */ } }
    @media screen and (max-width: 700px) {
      .fa-cont .right {
        width: 100%;
        height: auto;
        padding: 15px 0;
        padding-top: 24px; } }
    @media screen and (max-width: 420px) {
      .fa-cont .right {
        padding: 15px 0;
        padding-top: 24px; } }
    .fa-cont .right p {
      line-height: 2.1; }
      @media screen and (max-width: 900px) {
        .fa-cont .right p {
          font-size: 14px;
          line-height: 1.8; } }

.fa-cont table {
  width: 100%;
  border-collapse: collapse; }
.fa-cont tr {
  width: 100%; }
  .fa-cont tr.trs1 {
    height: 32px; }
.fa-cont th {
  color: #FFF;
  font-size: 14px;
  border-bottom: 1px solid #DDD;
  background: #0068b7;
  line-height: 23pt;
  padding: 6px auto; }
  .fa-cont th.s1 {
    width: 50%;
    padding-left: 15pt;
    text-align: left; }
  .fa-cont th.s2 {
    width: 30%;
    padding-left: auto;
    padding-right: auto;
    text-align: center;
    background: #BAD7E0;
    color: #555; }
  .fa-cont th.s3 {
    width: 20%;
    padding-left: auto;
    padding-right: auto;
    text-align: center; }
.fa-cont td {
  color: #333;
  font-size: 14px;
  border-bottom: 1px solid #DDD;
  line-height: 1.6;
  padding-top: 8px;
  padding-bottom: 8px; }
  .fa-cont td.s1 {
    width: 50%;
    padding-left: 15px;
    text-align: left; }
  .fa-cont td.s2 {
    width: 30%;
    padding-left: auto;
    padding-right: auto;
    text-align: center; }
  .fa-cont td.s3 {
    width: 20%;
    padding-left: auto;
    padding-right: auto;
    text-align: center; }
.fa-cont tr.trs3 th.s2 {
  background: #0068b7; }

/**********************************
pr-cont
**********************************/
.container-fluid.product-cont-wrapper,
.container.product-cont-wrapper {
  padding-left: 24px;
  padding-right: 24px;
  padding-bottom: 100px; }

.row.product-cont {
  margin: 0 auto;
  padding-top: 40px;
  padding-left: 24px;
  padding-right: 24px;
  padding-bottom: 24px;
  background: #FFF; }
  @media screen and (max-width: 700px) {
    .row.product-cont {
      padding-top: 24px;
      padding-left: 15px;
      padding-right: 15px;
      padding-bottom: 24px; } }

h4.pr-title {
  display: inline-block;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  margin-bottom: 30px;
  line-height: 2em;
  font-size: calc(14 / 440 * 100vw);
  color: #333;
  font-weight: normal;
  font-weight: 400;
  text-align: center; }
  @media screen and (min-width: 440px) {
    h4.pr-title {
      font-size: calc(14 / 700 * 100vw); } }
  @media screen and (min-width: 700px) {
    h4.pr-title {
      height: 2em;
      line-height: 2em;
      font-size: 16px; } }
  h4.pr-title span {
    display: inline-block;
    width: 100%;
    height: 2em;
    font-size: 1rem;
    color: #333;
    font-weight: normal;
    font-weight: 400;
    font-size: calc(14 / 440 * 100vw);
    margin-left: 0.5em;
    margin-right: 0.5em;
    border-top: 1px solid #333;
    border-bottom: 1px solid #333; }
    @media screen and (min-width: 440px) {
      h4.pr-title span {
        font-size: calc(14 / 700 * 100vw); } }
    @media screen and (min-width: 700px) {
      h4.pr-title span {
        width: auto;
        height: 2em;
        line-height: 2em;
        font-size: 16px; } }
    h4.pr-title span:last-child {
      border-top: none; }
      @media screen and (min-width: 700px) {
        h4.pr-title span:last-child {
          border-top: 1px solid #333; } }

.product-cont-inner img.hidden-sp {
  display: block; }
  @media (max-width: 700px) {
    .product-cont-inner img.hidden-sp {
      display: none; } }
.product-cont-inner img.visible-sp {
  display: none; }
  @media (max-width: 700px) {
    .product-cont-inner img.visible-sp {
      display: block; } }

.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: 700px;
  margin: 0 auto;
  color: #333;
  line-height: 1; }
  #formWrap table.formTable {
    width: 100%;
    margin: 0 auto;
    margin-bottom: 30px;
    border-collapse: collapse; }
  #formWrap table.formTable td, #formWrap table.formTable th {
    border-top: 1px solid #ccc;
    padding: 20px;
    vertical-align: middle; }
  #formWrap table.formTable th {
    width: 30%;
    font-weight: normal;
    background: #efefef;
    text-align: left; }
    #formWrap table.formTable th span {
      padding-left: 15px;
      color: #D4145A; }
  #formWrap table.formTable tr:last-child th, #formWrap table.formTable tr:last-child td {
    border-bottom: 1px solid #ccc; }

/*　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;
      border-bottom: 0; }
    #formWrap input[type="text"], #formWrap textarea {
      width: 80%;
      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; */ }
  #formWrap textarea {
    width: 100%;
    max-width: 600px;
    margin-bottom: 10px; }
  #formWrap 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; }
  #formWrap 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; }
  #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%;
  max-width: 700px;
  margin: 0 auto;
  padding: 30px 30px;
  text-align: left; }
  .contact-cont p {
    font-size: 15px !important;
    text-align: left;
    padding-bottom: 20px; }
    .contact-cont p a {
      color: #0068b7; }

/**************************
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 */
