/*
Theme Name: respr
*/

ul{margin-left:0;list-style: none;padding: 0;}.text50{ font-size: 50%;}.text60{ font-size: 60%;}.text70{ font-size: 70%;}.text80{ font-size: 80%;}.text90{font-size:90%;}.text100{font-size:100%;}.text110{font-size: 110%;}.text120{font-size: 120%; }.text130 {font-size:130%;}.text140 {font-size:140%;}.text150{font-size:150%;}.text160{font-size:160%;}.text170{font-size: 170%;}.text180 {font-size:180%;}.text190{font-size:190%;}.text200{font-size:200%; }.text250{font-size: 250%;}.text300{font-size: 300%;}.text350 {font-size: 350%;}.text400{font-size:400%;}.alpha7,.alpha8,.alpha9{transition:0.15s ease-in-out;}.alpha7:hover{filter:alpha(opacity=70);opacity:.7!important;}.alpha8:hover{filter:alpha(opacity=80);opacity:.8!important;}.alpha9:hover{filter:alpha(opacity=90);opacity:.9!important;}.scale img{transition:transform 0.2s ease-out;}.scale:hover img{transform:scale(1.02);}.scale-m img{transition:transform 0.25s ease-out;}.scale-m:hover img{transform:scale(1.07);}.scale-l img{transition:transform 0.3s ease-out;}.scale-l:hover img{transform:scale(1.12);}.cf:after{content:".";display: block;clear:both;height: 0;visibility:hidden;}.cf{min-height:1px;}* html .cf {height: 1px;/*��*//*/height:auto;overflow:hidden;/**/}.clear{clear:both;}.fw400{font-weight:400;}.fw500{font-weight:500;}.fw600{font-weight:600;}.fw700{font-weight:700;}.kome,.maru,.kaku,.hishi{display: block;position:relative;padding-left:1.3em;line-height:1.3;}.kome:before,.maru:before,.kaku:before,.hishi:before {position:absolute;left: 0;}.kome:before{content:"※";}.maru:before{content:"●";}.kaku:before{content:"■";}.hishi:before{content:"◆";}@media (-webkit-device-pixel-ratio: 2){.alpha7,.alpha8,.alpha9{transition:none !important;}.scale img,.scale-m img,.scale-l img{transition:none !important;}}
.w-space-s {letter-spacing: .15em;text-indent: .15em;}.w-space-m {letter-spacing: .3em;text-indent: .3em;}.w-space-l {letter-spacing: .5em;text-indent: .5em;}
body {
  font-size: 1.3vw;
  line-height: 2.3vw;
  font-family: 'Pridi', "メイリオ", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  color: #222;
  background-color: #fff;
  font-weight: 400;
}
section {
  overflow: hidden;
}
.lh-small {
  line-height: 1.8vw;
}
.bg-kon {
  background-color: #143991;
}
.bg-kon2 {
  background-color: #040e53;
}
.text-kon {
  color: #143991;
}
.text-kon2 {
  color: #040e53;
}
.text-orange {
  color: orangered;
}
.text-jp {
  font-size: 60%;
}
.no-underline {
  text-decoration: none !important;
}
.arrow-down {
  margin-top: 6vw;
}
.arrow-down span {
  border-style: solid;
  border-width: 5vw 15vw 0 15vw;
  border-bottom-color: transparent !important;
  border-left-color: transparent !important;
  border-right-color: transparent !important;
}
@media (min-width: 768px){
  #main-nav li {
    margin: 0;
    padding-bottom: .2vw;
  }
  #main-nav a {
    color: #135;
    padding: 1vw .5vw;
    text-decoration: none;
  }
  a.h-privacy {
    width: 12.5vw;
  }
  #header .mnav::after {
    position: absolute;
    bottom: 0;
    left: 0;
    content: '';
    width: 100%;
    height: 5px;
    background: #00b0fe;
    transform: scale(0);
    transition: transform .2s;
  }
  #header #main-nav > li:hover .mnav::after,
  #header .mnav.active::after {
    transform: scale(1);
  }
  .sub-nav {
    display: none;
    background-color: rgba(255,255,255,.7);
    position: absolute;
    left: 0;
    top: 4.5vw;
    width: 100%;
    z-index: 12345;
    box-shadow: 1px 1px 2px rgba(0,0,0,.5);
    text-align: center;
  }
  #header a.snav {
    text-decoration: none !important;
    color: #333;
    padding: .5vw;
    display: block;
    font-size: 80%;
  }
  #header a.snav:hover {
    color: #6792f7;
  }
  #header .nav-etc {
    display: none;
  }
  
  .lower-h {
    padding: 5.5vw 0 3vw;
    font-size: 3vw;
  }
}
#header-nav {
  position: absolute;
  width: 100%;
  top: 0;
  left: 0;
}
#corporate #header-nav {
  background: linear-gradient(to bottom, rgba(255,255,255,1) 0%, rgba(255,255,255,.9) 35%, rgba(255,255,255,0) 100%);
}
.logo-link img {
  width: 15vw;
}
#header {
  position: relative;
}
#language {
  position: absolute;
  right: 1vw;
  top: 8vw;
  width: 11vw;
}
#corporate #language {
  position: absolute;
  right: 1vw;
  top: 1vw;
  width: 11vw;
}
#language li {
  font-size: 80%;
}
#language ul {
  display: none;
  background-color: rgba(20, 57, 145,.6);
  padding: 0 5px 5px;
}
#language img {
  width: 2vw;
}
#mv,
#header {
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}

#logo-respr img {
  width: 30vw;
}
#respr #footer {
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
}
#respr #footer::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(60,150,60,.5);
}
#footer > * {
  position: relative;
}
#instration2 {
  background-color: rgba(60,150,60,.6);
}
#f-company {
  text-shadow: 1px 1px 2px rgba(0,0,0,.5), -1px 1px 2px rgba(0,0,0,.5), 1px -1px 2px rgba(0,0,0,.5), -1px -1px 2px rgba(0,0,0,.5);
  line-height: 1.5;
}
.f-logo-link {
  max-width: 250px;
}
#footer .btn {
  background-color: rgba(34,63,139,.8);
}
#footer .btn:hover {
  color: #FFC008 !important;
}


#Pagetop {
  position:fixed;
  bottom: 20px;
  right: 2%;  
  cursor:pointer;
  z-index: 12345;
  opacity: .8;
}

#Pagetop p {
  background-color: rgba(5,15,85,.8);
  color: #fff;
  font-size: 250%;
  text-align: center;
  line-height: 45px;
  height: 50px;
  width: 50px;
  padding: 0;
  margin: 0;
  box-shadow: 1px 1px 2px rgba(255,255,255,.5), -1px -1px 2px rgba(255,255,255,.5);
}

@media (min-width: 768px){
  a.tel-link {
    cursor: text;
    text-decoration: none;
    pointer-events: none;
  }
}

@media (max-width: 1199px){
  .container {
    max-width: none;
  }
}

@media (min-width: 1200px){
  .container {
    font-size: 16.5px;
  }
}


@media (max-width: 991px) and (min-width: 768px){
  .container {
    max-width: none;
  }
  #header {
    font-size: 1.3vw;
  }

  #nav-info .sub-nav,
  #nav-location .sub-nav {
    width: 19.5vw;
  }
  #header a.snav {
    padding: 1vw;
  }
  .h-contact {
    width: 20vw;
  }
  .h-contact a {
    height: 3.5vw;
    line-height: 3.5vw;
  }
}

@media (max-width: 767px){
  body {
    font-size: 3vw;
    line-height: 4.5vw;
  }
  .arrow-down {
    margin-top: 9vw;
  }
  .arrow-down span {
    border-width: 7vw 30vw 0 30vw;
  }
  .logo-link {
    padding-top: 4vw;
  }
  .logo-link img {
    width: 35vw;
  }
  .lh-small {
    line-height: 3.5vw;
  }
  #language {
    font-size: 110%;
    top: 5vw !important;
    right: 75px!important;
    width: 35vw !important;
  }
  #language ul {
    padding: 1.5vw 2vw;
    font-size: 110%;
  }
  #language li {
    padding: 1.5vw 0;
  }
  #language img {
    width: 6vw;
  }
  #main-nav li {
    padding: 0;
    border-bottom: solid 1px #3964cc;
  }
  #main-nav li:last-child {
    border: none;
  }
  #main-nav a {
    color: #fff;
    text-align: center;
    padding: 5vw 0;
    background-color: rgba(0,0,0,.3);
    text-decoration: none;
    font-size: 4vw;
  }
  #main-nav {
    display: none;
    width: 280px;
    position: fixed;
    border-width: 2px 0 2px 2px;
    top: 75px;
    right: -60vw;
    bottom: auto;
    overflow: auto;
    white-space: nowrap;
    height: 100vh !important;
    z-index: 123456;
    padding: 0 0 150px !important;
    background-color: rgba(20, 57, 145, .9);
  }
  #header .mnav::after {
    display: none;
  }
  #header .sub-nav {
    display: block;
    background-color: transparent;
    color: #fff;
    position: static;
    text-align: center;
    font-size: 90%;
  }
  #header a.snav {
    color: #fff;
    padding: 5vw 0;
    display: block;
    background-color: rgba(0,0,0,0);
  }
  .navbar-toggle {
    border: none;
    z-index: 123456;
    font-size: .8rem;
    background-color: rgba(20, 57, 145, .9);
    position: fixed;
    top: 12px;
    right: 2%;
    color: #fff;
    border-radius: 50%;
    box-shadow: 0 0 5px rgba(255,255,255,1);
    margin-top: 0;
    padding: 15px 10px;
    line-height: 1;
  }
  .navbar-toggle:focus {
    outline: none;
  }
  .navbar-toggle .icon-bar {
    background-color: #fff;
    width: 32px;
    height: 4px;
    display: block;
    border-radius: 1px;
  }
  .navbar-toggle span {
    transition: all 0.5s;
    transform: rotate(0deg);
  }
  .navbar-toggle .top {
    transform: translateY(0px);
  }
  .navbar-toggle .bottom {
    transform: translateY(0px);
    margin-bottom: 1px;
  }
  .navbar-toggle .icon-bar+.icon-bar {
      margin-top: 4px;
  }
  .navbar-toggle.is-open .middle {
    background: rgba(0, 0, 0, 0);
  }
  .navbar-toggle.is-open .top {
    background: #fff;
    transform: rotate(-45deg) translateY(5px) translateX(-6px);
  }
  .navbar-toggle.is-open .bottom {
    background: #fff;
    transform: rotate(45deg) translateY(-5px) translateX(-6px);
  }
  .lower-h {
    padding: 6vw 0 3vw;
    font-size: 6.5vw;
  }
  .f-logo-link {
    max-width: 50vw;
  }
}
@media (max-width: 575px){
  #footer {
    font-size: 4vw;
  }
  #Pagetop p {
    font-size: 200%;
    line-height: 35px;
    height: 40px;
    width: 40px;
  }
}


