/*
Theme Name: wp1
*/

ul,ol{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.2s ease-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;
  font-family: "Noto Sans JP", "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", Roboto, MotoyaLCedar, sans-serif;
  line-height: 2vw;
  color: #112;
  background-color: #ffffff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow: auto;
}
.font-latin {
  font-family: 'Alata','Righteous', "Noto Sans JP", "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", Roboto, MotoyaLCedar, sans-serif;
  font-weight: 600;
}
.title-en {
  position: absolute;
  /*top: -1vw;
  left: -3.5vw;
  transform: rotate(-9deg);*/
  top: 0vw;
  left: -3.5vw;
  z-index: 12345678;
}
.lower .title-en {
  text-shadow: 1px 1px 2px #ffffff, -1px 1px 2px #ffffff, 1px -1px 2px #ffffff, -1px -1px 2px #ffffff;
}
.tel-link {
  cursor: text;
  text-decoration: none;
  pointer-events: none;
}
.w-space {
  letter-spacing: .6vw;
  text-indent: .6vw;
}
.w-space-s {
  letter-spacing: .3vw;
  text-indent: .3vw;
}
.no-shadow {
  text-shadow: none !important;
}
.no-line {
  text-decoration: none !important;
}
.bg-green {
  background-color: #40a798;
}
.bg-blue {
  background-color: #1b3482;
}
.border-blue {
  border-color: #1b3482 !important;
}
.text-green {
  color: #2b8a78;
}
.text-blue {
  color: #1b3482;
}

#header-wrap {
  color: #1e73be;
  background: linear-gradient(to bottom, rgba(255,255,255,.9) 0%, rgba(255,255,255,0) 100%);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1240;
  height: 25vw;
}

.logo-area a {
  font-size: 100%;
  width: 30vw;
}
.logo-area img {
}
#fix-nav {
  top: -6vw;
  left: 0;
  z-index: 2345;
}
#header .main-nav,
#fix-nav {
  text-align: center;
  background-color: rgba(64, 167, 152,.8);
  text-shadow: 1px 1px 2px #40a798, -1px 1px 2px #40a798, 1px -1px 2px #40a798, -1px -1px 2px #40a798; 
}
#header .main-nav {
  position: absolute;
  left: 0;
  top: 10vw; 
  width: 100%;
  z-index: 1250;
}
#header .nav-link {
  text-decoration: none;
  color: #ffffff;
  font-size: 100%;
  display: block;
  text-align: center;
  padding: 1.7vw 2.5vw 1.5vw;
  transition: 0.2s ease-in-out;
  position: relative;
  z-index: 1;
  line-height: 1;
  font-weight: 300;
}
#header .sns-link {
  font-size: 94%;
  padding: 1.7vw 1.9vw 1.5vw;
}
#header .fb-link {
  font-size: 94%;
  padding: 1.7vw 2.1vw 1.5vw;
}
#header .nav-link:hover,
#header .nav-link.active {
  color: #FFC600;
}
#header .nav-link::after {
  position: absolute;
  bottom: 0;
  left: 0;
  content: '';
  width: 100%;
  height: .25vw;
  background-color: rgba(255,200,0,.8);
  transform: scale(0);
  transition: transform .3s;
  z-index: -1;
}
#header .nav-link:hover::after,
#header .nav-link.active::after {
  transform: scale(1);
}
#mv, #sv {
  height: 35vw;
  background-position: center center;
  background-size: cover;
}

.tel-text {
  display: block;
  text-decoration: none;
  font-size: 165%;
}
.add-text {
  font-size: 85%;
}
.youtube,
.iframe-wrap {
  position: relative;
  width: 100%;
  margin: 10px 0;
}
.youtube iframe,
.iframe-wrap iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  max-width: 800px;
  height: 100%;
}
.youtube {
  padding-top: 56.25%;
}
.iframe-wrap {
  padding-top: 65%;
}

@media (min-width: 768px){
  #btn-inquiry {
    height: 80%;
    font-size: 120%;
    padding-top: .2vw;
    margin-top: 8%
  }
  #btn-inquiry .far {
    margin-top: 0;
  }
  a.btn-effect,
  .btn-effect {
    position: relative;
    box-sizing: border-box;
    display: inline-block;
    margin: 0px 3px 6px;
    text-align: center;
    text-decoration: none;
    white-space: nowrap;
    z-index: 0;
    transition: 0.5s ease-in-out;
    overflow: visible;
    border: none;
    padding: 0 2.5vw;
  }
  .btn-effect::after {
    box-sizing: border-box;
    position: absolute;
    width: 100%;
    height: 100%;
    content: "";
    border: 2px solid #40a798;
    z-index: 2;
    margin: 0px;
    left: 0px;
    bottom: 0px;
    border-top-width: 2px;
    transition: border-top-width 0.1s 0.2s, height 0.2s 0.1s, width 0.2s 0s, margin 0.2s 0s;
  } 
  .btn-effect:hover::after {
    width: 68%;
    height: 0px;
    border-width: 0px 2px 2px;
    margin: 0px 17%;
    transition: border-top-width 0.1s 0s, height 0.2s 0.1s, width 0.2s 0.2s, margin 0.2s 0.2s;
  }
}

#main > section,
#main > article {
  background-color: #fff;
  position: relative;
  z-index: 1234;
}
#lower-header-wrap {
  padding: 14vw 0 6vw;
}
#lower-header {
  color: #094880;
}


#lower-comment {
  padding: 0 4vw;
}
#lower-comment p {
  margin: .5vw 0;
}
#lower-comment h2,
#lower-comment h3,
#lower-comment h4 {
  color: #1e73be;
  opacity: .7;
  margin-bottom: 1vw;
}
#lower-comment h2 {
  font-size: 125%;
}
#lower-comment h3 {
  font-size: 115%;
}
#lower-comment h4 {
  font-size: 105%;
}

#footer {
  background-color: #ffffff;
}
#f-contact {
  overflow: hidden;
  line-height: 2.2vw;
  padding: 4vw 0;
  min-height: 25vw;
}
#f-rellax {
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  position: absolute;
  top: -7vw;
  left: 0;
  height: 180%;
}
#bg-contact {
  min-height: 25vw;
  text-shadow: 1px 1px 2px #ffffff, -1px 1px 2px #ffffff, 1px -1px 2px #ffffff, -1px -1px 2px #ffffff;
}
#bg-contact .btn-effect {
  background-color: rgba(255,255,255,.6);
}
#bg-contact .btn-effect:hover {
  background-color: rgba(255,255,255,0);
}
#fb-pp {
  height: 500px;
}
#footer-nav .nav-link {
  color: #ffffff;
}
.copy {
  color: #212121;
}
#footer-nav .nav-link {
  font-weight: 400 !important;
  padding: 1vw 1.5vw;
  font-size: 80%;
}
#footer-nav .nav-link:hover {
  text-decoration: underline;
}
#f-add {
  line-height: 1.3;
}
.wp-pagenavi {
  margin: 3vw 0;
  text-align: center;
  font-family: 'Comfortaa', "Noto Sans Japanese", "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", Roboto, MotoyaLCedar, sans-serif;
}
.wp-pagenavi > span,
.wp-pagenavi > a {
  display: inline-block;
  line-height: 1.1;
  padding: 4px 9px 1px;
  border: solid 1px #123;
  border-radius: 3px;
  margin: 0 3px;
  color: #345;
  text-decoration: none;
  font-size: 105%;
  font-weight: 600;
}
.wp-pagenavi span.current,
.wp-pagenavi > a:hover {
  background-color: #567;
  color: #fff;
  border: solid 1px #123;
}

@media (min-width: 768px){
  /*page-top*/
  #Pagetop {
    position:fixed;
    bottom: 5vw;
    right: 3vw;  
    cursor:pointer;
    z-index: 1234567;
    opacity: 1;
  }

  #Pagetop p {
    font-size: 250%;
    text-align: center;
    line-height: 3.7vw;
    height: 4vw;
    width: 4vw;
    padding: 0;
    margin: 0;
    box-shadow: 1px 1px 2px rgba(255,255,255,.3), 1px -1px 2px rgba(255,255,255,.3), -1px 1px 2px rgba(255,255,255,.3), -1px -1px 2px rgba(255,255,255,.3);
    color: #ffffff;
    opacity: .8;
  }
}

@media (min-width: 1200px){
  #header .main-nav,
  #fix-nav {
    font-size: 1rem;
  }
  #lower-header-wrap,
  #footer {
    font-size: 1rem;
  }
  #lower-header-wrap {
    padding: 60px 0;
  }
  .lower {
    font-size: 1rem;
    line-height: 1.6;
  }
}
@media (max-width: 1199px){
  #header .main-nav {
    top: 11vw;
  }
  #fb-pp {
    height: 400px;
  }
  .title-en {
    position: absolute;
    top: 1vw;
    left: .5vw;
  }
  #f-rellax {
    top: -8vw;
    height: 190%;
  }
}
@media (max-width: 991px){
  .container {
    max-width: none;
  }
  #f-rellax {
    top: -8vw;
    height: 200%;
  }
}
@media (max-width: 767px){
  body {
    font-size: 3vw;
    line-height: 4.5vw;
  }
  .tel-link {
    pointer-events: auto;
    text-decoration: underline;
  }
  .title-en {
    top: -1vw;
    left: 0vw;
  }
  .logo-area a {
    width: 70vw;
  }
  #header-wrap {
    height: 45vw;
  }
  #inquiry-area {
    position: fixed;
    width: 100%;
    bottom: 0;
    left: 0;
    font-size: 160%;
    color: #ffffff;
    background-color: rgba(64, 167, 152,.9);
    z-index: 123456;
    height: 14vw;
  }
  #inquiry-area > div {
    height: 100%;
  }
  #inquiry-area a,
  .navbar-toggle {
    color: #ffffff;
    text-decoration: none;
    position: relative;
    display: block;
    height: 100%;
    line-height: 1;
  }
  .bm-text {
    font-size: 30%;
    position: absolute;
    top: 8.5vw;
    left: 0;
    width: 100%;
  }
  .tel-text {
    font-size: 100%;
  }
  #inquiry-area .btn-effect .fa-envelope {
    color: #fff !important;
  }
  .navbar-toggle {
    border: none;
    margin-top: 0;
    outline: none !important;
    color: #ffffff;
    background-color: transparent;
    text-align: center;
    display: inline-block;
    width: 100%;
    padding-top: .7vw;
  }
  .navbar-toggle .icon-bar {
    background-color: #ffffff;
    width: 7vw;
    height: .7vw;
    display: block;
    border-radius: 1px;
    margin-left: auto;
    margin-right: auto;
  }
  .navbar-toggle span {
    transition: all 0.5s;
    transform: rotate(0deg);
  }
  .navbar-toggle .top {
    transform: translateY(0px);
  }
  .navbar-toggle .bottom {
    transform: translateY(0px);
  }

  .navbar-toggle .icon-bar+.icon-bar {
      margin-top: 1.2vw;
  }
  .navbar-toggle.is-open .middle {
    background: rgba(0, 0, 0, 0);
  }
  .navbar-toggle.is-open .top {
    transform: rotate(-45deg) translateY(1.4vw) translateX(-1.3vw);
  }
  .navbar-toggle.is-open .bottom {
    transform: rotate(45deg) translateY(-1.4vw) translateX(-1.3vw);
  }
  
  #header .main-nav {
    display: none;
    width: 100%;
    position: fixed;
    bottom: -14vw;
    top:auto;
    white-space: nowrap;
    max-height: 100%;
    height: auto;
    z-index: 12345;
    padding: 3vw;
    opacity: 0;
    overflow: auto;
    background-color: rgba(64, 167, 152,.9);
  }
  #header .main-nav li {
    margin: 1.5vw 0;
    padding: 0 2vw;
  }
  #header .nav-link {
    padding: 3vw 0;
    text-align: center;
    width: 100%;
    font-size: 105%;
  }
  #sv {
    height: 55vw;
  }
  .en-ttl::after {
    bottom: 1.9vw;
  }
  #lower-header {
    font-size: 100%;
  }
  #footer {
    padding-bottom: 13.5vw;
  }
  #f-contact p {
    line-height: 6vw;
    font-size: 4vw;
  }
  #f-contact .btn-effect {
    border: solid 2px #00a473;
    background-color: rgba(255,255,255,.3);
    display: block;
    width: 100%;
  }
  #bg-greeting {
    line-height: 5.5vw;
    min-height: 65vw;
  }
  .gr-rellax {
    top: -25vw;
    left: 0;
    height: 180%;
  }
  #f-rellax {
    top: -25vw;
    left: 0;
    height: 180%;
  }
  #footer-nav a.nav-link {
    padding: .8rem 2.5vw;
  }
  #Pagetop {
    background-color: #111;
  }
  #Pagetop p {
    color: #ffffff;
    background-color: #111;
  }
}

@media (max-width: 575px){
  body {
    font-size: 3.7vw;
    line-height: 5vw;
  }
}

