/*!
Theme Name: ada garden hotel
Theme URI: 
Author: 
Author URI: 
Description: Description
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: ada-garden-hotel
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned with others.

ada garden hotel is based on Underscores https://underscores.me/, (C) 2012-2017 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/
/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Normalize
# Typography
# Elements
# Forms
# Navigation
  ## Links
  ## Menus
# Accessibility
# Alignments
# Clearings
# Widgets
# Content
  ## Posts and pages
  ## Comments
# Infinite scroll
# Media
  ## Captions
  ## Galleries
--------------------------------------------------------------*/
/*--------------------------------------------------------------
# Normalize
--------------------------------------------------------------*/
@charset "UTF-8";
/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: bottom;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
  display: block;
}
body {
  line-height: 1;
}
ol, ul {
  list-style: none;
}
blockquote, q {
  quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}

body, html {
  overflow-x: hidden
}

body {
  font-family: utsukushiregular, ヒラギノ明朝 Pro W3, Hiragino mincho Pro, HiraMinProN-W3, 游明朝, Yu mincho, 游明朝体, YuMincho, HGS明朝E, HG明朝E, ＭＳ Ｐ明朝, MS PMincho, serif;
  color: #000;
  font-size: 15px;
  font-weight: 400;
  font-style: normal;
  line-height: 1.8;
  letter-spacing: .5px;
  height: 100%;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -o-text-size-adjust: 100%;
  text-size-adjust: 100%
}

a, address, blockquote, body, button, code, dd, dfn, div, dl, dt, em, form, h1, h2, h3, h4, h5, h6, html, input, kbd, mark, ol, p, pre, samp, select, span, table, textarea, ul {
  -webkit-margin-before: 0;
  -webkit-margin-after: 0;
  -webkit-margin-start: 0;
  -webkit-margin-end: 0;
  margin: 0;
  padding: 0
}

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

/* iOSでのデフォルトスタイルをリセット */
input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: 1px solid #000;
  box-sizing: border-box;
  cursor: pointer;
  background-color: #ccc
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}

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

.fa {
  vertical-align: baseline
}

.only-pc {
  display: block
}

.only-sp {
  display: none
}

@media only screen and (max-width:768px) {
  .only-pc {
    display: none!important
  }
  .only-sp {
    display: block
  }
}

@media only screen and (max-width:1050px) {
  .only-tablet-sp {
    display: block
  }
  .only-pc {
    display: none!important
  }
}

@media only screen and (min-width:1051px) {
  .only-tablet-sp {
    display: none!important
  }
}

.txt-cmn-mincho {
  font-family: utsukushiregular, ヒラギノ明朝 Pro W3, Hiragino mincho Pro, HiraMinProN-W3, 游明朝, Yu mincho, 游明朝体, YuMincho, HGS明朝E, HG明朝E, ＭＳ Ｐ明朝, MS PMincho, serif
}

.txt-cmn-mincho-w6 {
  font-family: utsukushiregular, ヒラギノ明朝 Pro W6, Hiragino mincho Pro, HiraMinProN-W3, 游明朝, Yu mincho, 游明朝体, YuMincho, HGS明朝E, HG明朝E, ＭＳ Ｐ明朝, MS PMincho, serif
}

.txt-cmn-yugothic {
  font-family: Yu Gothic Medium, 游ゴシック Medium, YuGothic, 游ゴシック体, ヒラギノ角ゴ Pro W3, メイリオ, sans-serif
}

.txt-cmn-lineheight2 {
  line-height: 2.4
}

.ease-cmn, .ease-cmn * {
  -webkit-transition: .2s all ease;
  -moz-transition: .2s all ease;
  -ms-transition: .2s all ease;
  -o-transition: .2s all ease;
  transition: .2s all ease
}

.container {
  width: 100%;
  max-width: 1060pt;
  margin: 0 auto;
  position: relative
}

.flex-cmn {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between
}

.flex-cmn-wrap {
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}

.flex-center-cmn {
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center
}

.flex-around-cmn {
  -webkit-justify-content: space-around;
  justify-content: space-around
}

.clearfix {
  *zoom: 1
}

.clearfix:after, .clearfix:before {
  display: table;
  line-height: 0;
  content: ""
}

.clearfix:after {
  clear: both
}

.gray-cmn {
  -webkit-filter: grayscale(0);
  -moz-filter: grayscale(0);
  -o-filter: grayscale(0);
  -ms-filter: grayscale(0);
  filter: grayscale(0);
  transition: .3s
}

.gray-cmn:hover {
  -webkit-filter: grayscale(60%);
  -moz-filter: grayscale(60%);
  -o-filter: grayscale(60%);
  -ms-filter: grayscale(60%);
  filter: grayscale(60%)
}

.btn-cmn {
  max-width: 300px;
  height: 50px;
  margin: auto;
  text-align: center
}

.btn-cmn a:after {
  content: '→';
  position: absolute;
  right: 20px;
  top: 17px
}

.btn-cmn.btn-bk a {
  background: #000;
  color: #fff
}

.btn-cmn.btn-bk a:before {
  background: #fff
}

.btn-cmn.btn-bk a:active, .btn-cmn.btn-bk a:focus, .btn-cmn.btn-bk a:hover {
  color: #000
}

.btn-cmn.btn-wh a {
  background: #fff
}

.btn-cmn.btn-wh a:before {
  background: #1978a5
}

.btn-cmn.btn-bg a, .btn-cmn.btn-wh a:active, .btn-cmn.btn-wh a:focus, .btn-cmn.btn-wh a:hover {
  color: #fff;
  border: 1px solid #fff
}

.btn-cmn.btn-bg a {
  background: transparent
}

.btn-cmn.btn-bg a:before {
  background: #fff
}

.btn-cmn.btn-bg a:active, .btn-cmn.btn-bg a:focus, .btn-cmn.btn-bg a:hover {
  color: #1978a5;
  border: 1px solid #1978a5
}

.btn-cmn a {
  height: 50px;
  padding-top: 17px;
  line-height: 1;
  border: 1px solid #000;
  cursor: pointer;
  text-decoration: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  display: block;
  vertical-align: middle;
  -webkit-transform: perspective(1px) translateZ(0);
  transform: perspective(1px) translateZ(0);
  box-shadow: 0 0 1px transparent;
  position: relative;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: .3s;
  transition-duration: .3s
}

.btn-cmn a:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: 0 50%;
  transform-origin: 0 50%;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: .2s;
  transition-duration: .2s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out
}

.btn-cmn a:active:before, .btn-cmn a:focus:before, .btn-cmn a:hover:before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1)
}

/* ------------------------------------------------------ */


.btn-cmn-small {
  max-width: 300px;
  height: 50px;
  text-align: center;
  margin: auto;
}

.btn-cmn-small a:after {
  content: '→';
  position: absolute;
  right: 20px;
  top: 9px
}

.btn-cmn-small.btn-bk a {
  background: #000;
  color: #fff
}

.btn-cmn-small.btn-bk a:before {
  background: #fff
}

.btn-cmn-small.btn-bk a:active, .btn-cmn.btn-bk a:focus, .btn-cmn.btn-bk a:hover {
  color: #000
}

.btn-cmn-small.btn-wh-small a {
  background: #fff
}

.btn-cmn-small.btn-wh-small a:before {
  background: #1978a5
}

.btn-cmn-small.btn-bg a, .btn-cmn-small.btn-wh-small a:active, .btn-cmn-small.btn-wh-small a:focus, .btn-cmn-small.btn-wh-small a:hover {
  color: #fff;
  border: 1px solid #fff
}

.btn-cmn-small.btn-bg a {
  background: transparent
}

.btn-cmn-small.btn-bg a:before {
  background: #fff
}

.btn-cmn-small.btn-bg a:active, .btn-cmn-small.btn-bg a:focus, .btn-cmn-small.btn-bg a:hover {
  color: #1978a5;
  border: 1px solid #1978a5
}

.btn-cmn-small a {
  height: 30px;
  padding-top: 9px;
  line-height: 1;
  border: 1px solid #000;
  cursor: pointer;
  text-decoration: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  display: block;
  vertical-align: middle;
  -webkit-transform: perspective(1px) translateZ(0);
  transform: perspective(1px) translateZ(0);
  box-shadow: 0 0 1px transparent;
  position: relative;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: .3s;
  transition-duration: .3s
}

.btn-cmn-small a:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: 0 50%;
  transform-origin: 0 50%;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: .2s;
  transition-duration: .2s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out
}

.btn-cmn-small a:active:before, .btn-cmn-small a:focus:before, .btn-cmn-small a:hover:before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1)
}


#header .header-text {
  padding: 7px 10px 10px 0
}

#header .header-btn {
  width: 345px
}

#header .header-btn li a {
  color: #fff;
  background: #000;
  display: block;
  text-align: center;
  width: 170px;
  height: 35px;
  padding-top: 10px;
  line-height: 1
}

#header .header-btn li a:hover {
  opacity: .7
}

#header .header-btn li span {
  line-height: 1;
  margin-left: 7px
}

@media all and (-ms-high-contrast:none) {
  #header .header-btn li img {
    vertical-align: baseline
  }
  #header .header-btn li span {
    line-height: 1.3
  }
}

#header-nav {
  padding-bottom: 10px
}

#header #logo {
  padding: 10px 0
}

#header #nav-global {
  width: 65%;
  padding-top: 9pt
}

#header #nav-global li {
  text-align: center;
  width: 16.66667%
}

#header #nav-global li a {
  color: #000;
  display: block
}

#header #nav-global li a .ja, #header #nav-global li a:hover .en {
  display: none
}

#header #nav-global li a:hover .ja {
  display: block
}

#header #nav-global li img {
  margin-bottom: 5px
}

.globalnav .navbtn {
  position: fixed;
  z-index: 6;
  transition: all .6s;
  background-color: #fff;
  border-radius: 100%;
  padding: .5em 1em 1em .5em
}

@supports(-ms-ime-align:auto) {
  .globalnav .navbtn {
    padding: 1em 1em 1em .5em
  }
}

.globalnav a {
  color: #fff
}

.navbtn {
  float: right;
  cursor: pointer;
  padding: 5px 0;
  left: 15px;
  top: 20px;
  letter-spacing: 4px;
  font-size: 13px
}

.humberger {
  position: relative;
  width: 17px;
  height: 15px;
  display: inline-block;
  margin-left: 8px
}

.humberger>span {
  display: block;
  width: 17px;
  height: 3px;
  position: absolute;
  left: 0;
  background: #434a4f;
  transition: all .3s
}

.humberger .l1 {
  top: 0
}

.humberger .l2 {
  top: 6px
}

.humberger .l3 {
  top: 9pt
}

.navbtn:hover .humberger .l1 {
  top: -1px
}

.navbtn:hover .humberger .l3 {
  top: 13px
}

.navbtn.on {
  left: 50%;
  margin-left: -17px
}

.navbtn.on .humberger>span {
  background: #000
}

.navbtn.on .humberger .l1, .navbtn.on .humberger .l3 {
  top: 6px
}

.navbtn.on .humberger .l2 {
  opacity: 0
}

.navbtn.on:hover .humberger .l1 {
  transform: rotate(45deg)
}

.navbtn.on:hover .humberger .l3 {
  transform: rotate(-45deg)
}

#g_menu {
  width: 100%;
  height: 100%;
  left: -100%;
  opacity: 0;
  filter: alpha(opacity=0);
  transition: all .6s;
  position: fixed;
  z-index: 5
}

#g_menu.show {
  opacity: 1;
  filter: alpha(opacity=100);
  left: 0
}

#g_menu .nav, #g_menu .share {
  color: #282828;
  position: fixed;
  left: -80%;
  width: 80%;
  letter-spacing: 2px;
  opacity: 0;
  filter: alpha(opacity=0);
  transition: all .6s ease
}

#g_menu.show .nav, #g_menu.show .share {
  left: 10%;
  opacity: 1;
  filter: alpha(opacity=100)
}

#g_menu .nav {
  margin: 20px 0 0;
  padding-top: 20px;
  top: 65px;
  border-top: 1px solid #687178
}

#g_menu .nav li {
  font-size: 9pt;
  text-align: center
}

#g_menu .nav a {
  display: block;
  padding: 6px
}

#g_menu .share {
  margin: 0;
  padding-bottom: 20px;
  bottom: 65px;
  border-bottom: 1px solid #687178
}

#g_menu .share li {
  padding: 6px 0;
  text-align: center;
  height: 28px;
  position: relative;
  cursor: pointer
}

#g_menu .share .share_icon {
  height: 28px;
  display: none
}

#g_menu .share .share_icon img {
  width: 18px;
  vertical-align: middle
}

#g_menu .share .share_body {
  text-align: center;
  padding-top: 3px;
  padding-left: 20px;
  height: 28px;
  position: absolute;
  left: 0;
  top: 0
}

.globalnav.show .logo, .globalnav.show .navbtn {
  opacity: 1;
  filter: alpha(opacity=100);
  z-index: 3
}

.globalnav.show .logo {
  left: 60px
}

.globalnav.show .navbtn {
  right: 60px
}

.overlay {
  position: fixed;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, .7);
  z-index: 3;
  transition: all .6s ease .1s
}

.overlay.show {
  left: 0
}

@media all and (min-width:768px) {
  .navbtn {
    left: 40px;
    top: 40px
  }
  .navbtn.on {
    left: 135px
  }
  #g_menu {
    background: #434a4f;
    width: 280px;
    left: -280px;
  }
  #g_menu .nav, #g_menu .share {
    left: -12pc;
    width: 12pc
  }
  #g_menu.show .nav {
    left: 45px
  }
}

.reserve .reservebtn {
  position: fixed;
  z-index: 7;
  transition: all .6s;
  background-color: #fff;
  border-radius: 2%;
  padding: 1.5em 2em;
  border: 1px solid #000;
  bottom: 0
}

@supports(-ms-ime-align:auto) {
  .reserve .reservebtn {
    padding: 1em
  }
}

.reserve a {
  color: #fff
}

.reservebtn {
  float: right;
  cursor: pointer;
  padding: 5px 0;
  right: 15px;
  bottom: 50px;
  letter-spacing: 4px;
  font-size: 13px
}

.reserve-txt {
  position: relative;
  width: 100%;
  height: auto;
  display: inline-block;
  margin-right: 20px
}

.reserve-txt>span {
  display: block;
  width: 17px;
  height: 3px;
  position: absolute;
  right: 0;
  background: #434a4f;
  transition: all .3s
}

.reserve-txt .l1 {
  top: 4px
}

.reserve-txt .l2 {
  top: 10px
}

.reserve-txt .l3 {
  top: 1pc
}

.reservebtn.on {
  right: 50%;
  margin-right: -25%
}

.reservebtn.on .reserve-txt>span {
  background: #000
}

.reservebtn.on .reserve-txt>span:first-of-type, .reservebtn.on .reserve-txt>span:last-of-type {
  top: 11px
}

.reservebtn.on .reserve-txt>span:nth-of-type(2) {
  opacity: 0
}

.reservebtn.on:hover .reserve-txt>span:first-of-type {
  transform: rotate(45deg)
}

.reservebtn.on:hover .reserve-txt>span:last-of-type {
  transform: rotate(-45deg)
}

#header_languages {
  position: relative;
  display: inline-block;
  width: 140px;
  position: fixed;
  right: 15px;
  top: 20px;
  z-index: 7;
  transition: all .6s;
  color: #ffffff;
  border: 1px solid #e5e5e5;
  border-bottom: none;
  cursor: pointer;
  text-align: center;
  background-color: rgba(0, 0, 0, 0.7);
}

#header_languages.lower-z-index {
  z-index: 2;
}

#header_languages a {
  color: #ffffff;
  display: block;
  padding: 8px 16px;
  text-decoration: none;
}

#header_languages .icon {
  margin-left: 8px;
}

#header_languages .icon.open {
  display: none;
}

#header_languages.active .icon.open {
  display: inline;
}

#header_languages .icon.close {
  display: inline;
}

#header_languages.active .icon.close {
  display: none;
}

#header_lang {
  left: -1px;
  width: 140px;
  transition: all .6s;
  padding: 0;
  margin: 0;
  position: absolute;
  border: 1px solid #e5e5e5;
  border-bottom: none;
  cursor: pointer;
  background-color: rgba(0, 0, 0, 0.7);
  list-style: none;
}

#header_languages.active #header_lang {
  border-bottom: 1px solid #e5e5e5;
}

#header_lang li {
  text-align: center;
  border-bottom: 1px solid #e5e5e5;
}

#header_lang li a {
  display: block;
  padding: 8px 16px;
  text-decoration: none;
}

#header_lang li:last-of-type {
    border-bottom: none;
}

#header_lang li:hover {
  background-color: #f0f0f0;
}

#header_lang li:hover a {
  color: #000;
}

@media all and (min-width:768px) {
  #header_languages {
    right: 40px;
    top: 40px;
  }
}

#form {
  width: 100%;
  height: 100%;
  right: -100%;
  opacity: 0;
  filter: alpha(opacity=0);
  transition: all .6s;
  position: fixed;
  z-index: 6
}

#form.show {
  opacity: 1;
  filter: alpha(opacity=100);
  right: 0;
  bottom: 0
}

#form .nav {
  color: #282828;
  position: fixed;
  right: -80%;
  width: 85%;
  letter-spacing: 2px;
  opacity: 0;
  filter: alpha(opacity=0);
  transition: all .6s ease
}

#form.show .nav {
  right: 10%;
  opacity: 1;
  filter: alpha(opacity=100)
}

#form .nav {
  margin: 20px 0 0;
  padding-top: 20px;
  top: 2%;
  border-top: 1px solid #687178
}

#form .nav li {
  font-size: 9pt;
  text-align: center
}

#form .nav li p {
  margin: 2em 0 0;
}

#form .nav a {
  display: block;
  padding: 6px
}

.reserve.show .logo, reserve.show .reservebtn {
  opacity: 1;
  filter: alpha(opacity=100);
  z-index: 3
}

.reserve.show .logo, .reserve.show .reservebtn {
  right: 60px
}

.reserve-overlay {
  position: fixed;
  bottom: 0;
  right: -100%;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, .7);
  z-index: 5;
  transition: all .6s ease .1s
}

.reserve-overlay.show {
  right: 0
}

@media all and (min-width:768px) {
  .reservebtn {
    right: 40px;
    bottom: 40px
  }
  .reservebtn.on {
    right: 125px;
    margin-right: 0
  }
  #form {
    background: #434a4f;
    width: 440px;
    right: -440px
  }
  #form .nav {
    right: -10pc;
    width: 360px
  }
  #form.show .nav {
    right: 45px
  }
}

form {
  transition: all .6s ease .1s
}

form input, form select {
  font-size: 1pc
}

.cont {
  color: #fff
}

.Unnecessary, .checkin, .checkout, .child, .grownup, .necessary {
  margin-bottom: 1em
}

#searchForm .search input {
  padding: .3em 1.5em;
  cursor: pointer
}

footer {
  margin-top: 10em
}

footer .footer_link {
  background: #fff;
  padding: 10px 0;
  border-top: 1px solid #ccc;
  padding: 15px 0
}

footer .footer_link li {
  width: 25%;
  float: left
}

footer .footer_link li a {
  color: #000;
  font-size: 14px;
  text-align: center;
  padding: 0 30px
}

footer .footer_link li a:hover {
  color: #70b3d1
}

footer .footer_link li:last-child {
  display: flex
}

footer .footer_link li:last-child a {
  padding: 0 10px
}

footer .footer_link li a img {
  max-width: 100%;
  width: auto;
  height: auto
}

#footer-logo {
  background-color: #1978a5
}

#footer-logo #copyright {
  font-size: 14px;
  color: #fff;
  text-align: center;
  padding: 2em 0
}

#footer-logo #copyright li:first-child {
  margin: 5px 0 10px
}

#footer-logo #copyright li:first-child img {
  width: auto;
  height: auto;
  max-width: 100%;
  margin: 0 auto
}

@media only screen and (max-width:1050px) {
  #header-nav {
    display: block;
    padding: 0
  }
  #header #logo {
    width: 50%;
    padding-left: 2%;
    max-width: 249px
  }
  #header #logo img {
    width: 100%
  }
  #header #nav-global {
    width: 100%;
    padding: 0;
    background: #000;
    position: absolute;
    z-index: 1;
    display: none
  }
  #header #nav-global ul {
    display: block
  }
  #header #nav-global li {
    width: 100%;
    text-align: left
  }
  #header #nav-global li a {
    display: block;
    padding: 3% 2%;
    color: #fff;
    border-top: 1px solid #333
  }
  #header #nav-global li a .icon_img {
    width: 40px;
    display: inline-block;
    text-align: center
  }
  #header #nav-global li a .en {
    display: none
  }
  #header #nav-global li a .ja {
    display: inline-block
  }
  #header #nav-global li a:hover .en {
    display: none
  }
  #header #nav-global li a:hover .ja {
    display: inline-block
  }
  #header #menu-btn {
    position: absolute;
    right: 15px;
    top: 10px
  }
  #header #menu-btn, #header .menu-button {
    width: 50px;
    height: 50px;
    display: block
  }
  #header .menu-button i {
    display: block;
    width: 30px;
    height: 2px;
    border-radius: 3px;
    background: #000;
    transition: background .5s;
    position: relative;
    left: 10px;
    top: 22px
  }
  #header .menu-button i:after, #header .menu-button i:before {
    content: "";
    display: block;
    width: 30px;
    height: 2px;
    border-radius: 3px;
    background: #000;
    position: absolute;
    transform: rotate(0);
    transition: all .3s!important;
    line-height: 1
  }
  #header .menu-button i:before {
    transform: translateY(10px)
  }
  #header .menu-button i:after {
    transform: translateY(-10px)
  }
  .is-open #header .menu-button i {
    background: #fff
  }
  .is-open #header .menu-button i:after {
    transform: translateY(0) rotate(-225deg)
  }
  .is-open #header .menu-button i:before {
    transform: translateY(0) rotate(225deg)
  }
  #footer-link {
    margin: 0;
    display: block
  }
  #footer-link ul {
    width: 100%;
    overflow: hidden
  }
  #footer-link ul li {
    width: 50%;
    float: left;
    margin: 0
  }
  #footer-link ul li a {
    display: block;
    border-top: 1px solid #ccc;
    padding: 10px
  }
  #footer-link ul li:nth-child(odd) a, #footer-link ul.footer-nav li:nth-child(even) a {
    border-left: 1px solid #ccc
  }
  #footer-link ul li.onecol {
    width: 100%
  }
}

@media only screen and (max-width:768px) {
  body {
    color: #333
  }
  #header #logo {
    width: 150px
  }
  #header #menu-btn {
    right: 0;
    top: 0
  }
  #header .menu-button i {
    left: 10px;
    top: 24px
  }
  #header .menu-button i:before {
    transform: translateY(8px)
  }
  #header .menu-button i:after {
    transform: translateY(-8px)
  }
  footer .footer_link, footer .footer_link ul {
    padding: 0
  }
  footer .footer_link ul li {
    display: block;
    border: 0;
    margin-bottom: 0;
    width: 100%;
    float: none
  }
  footer .footer_link ul li:first-child {
    border: 0
  }
  footer .footer_link ul li a {
    display: block;
    text-align: left;
    border-bottom: 1px solid #ccc;
    padding: 15px 3%;
    position: relative
  }
  footer .footer_link ul li a:after {
    content: ">";
    position: absolute;
    top: 14px;
    right: 10px
  }
  footer .footer_link ul li:last-child a {
    padding: 0 10px;
    width: 33.33333%;
    margin-top: 1em;
    margin-bottom: 1em
  }
  footer .footer_link ul li:last-child a:after {
    content: ""
  }
  footer .footer_link ul li a img {
    margin: auto
  }
  #footer-logo #copyright {
    padding: 5px 3% 100px;
    font-size: 11px;
    background: #1978a5
  }
}


#pagetop .pagetop_btn {
  position: fixed;
  z-index: 4;
  transition: all .6s;
  background-color: #fff;
  border-radius: 100%;
  padding: .5em 1em 1em .5em;
  border: 1px solid #000;
  bottom: 70px;
}

@supports(-ms-ime-align:auto) {
  #pagetop .pagetop_btn {
    padding: 1em 1em 1em .5em
  }
}

.pagetop_btn {
  float: right;
  cursor: pointer;
  padding: 5px 0;
  right: 15px;
  bottom: 60px;
  letter-spacing: 4px;
  font-size: 13px
}


@media all and (min-width:768px) {
  .pagetop_btn {
    right: 40px;
    bottom: 80px
  }
  .pagetop_btn.on {
    right: 125px
  }
}

.pagetop_line {
  position: relative;
  width: 100%;
  height: auto;
  display: inline-block;
  margin-left: 8px
}

.pagetop_line .l1 {
  top: 0
}

.pagetop_line .l2 {
  top: 6px
}

.pagetop_line .l3 {
  top: 9pt
}

.pagetop_btn:hover .pagetop_line .l1 {
  top: -1px
}

.pagetop_btn:hover .pagetop_line .l3 {
  top: 13px
}

.pagetop_btn.on {
  right: 50%;
  margin-left: -17px
}

.pagetop_btn.on .pagetop_line>span {
  background: #000
}

.pagetop_btn.on .pagetop_line .l1, .pagetop_btn.on .pagetop_line .l3 {
  top: 6px
}

.pagetop_btn.on .pagetop_line .l2 {
  opacity: 0
}

.pagetop_btn.on:hover .pagetop_line .l1 {
  transform: rotate(45deg)
}

.pagetop_btn.on:hover .pagetop_line .l3 {
  transform: rotate(-45deg)
}

.slider-nav .slick-slide{
  padding-right: 3px;
  padding-left: 3px;
}

.slider-nav .slick-slide img {
  width: 100%;
  cursor: pointer;
}

/* Contact Form 
-----------------------------------*/
.mail-notice{
  padding: 30px;
  max-width: 850px;
  margin: 3% auto 0;
  background: #FAFAFA;
  text-align: left;
}
.mail-notice h2{
  font-size: 20px !important;
  margin-bottom: 14px !important;
}
.wpcf7 {
  font-size: 14px;
}

form.wpcf7-form {
  padding: 0 20px;
}

.wpcf7 dl {
  width: 100%;
  margin-bottom: 20px;
}
.wpcf7 dt {
  position: relative;
  margin-bottom: 5px;
  vertical-align: middle;
  box-sizing: border-box;
  padding: 10px 0;
/*   background-color: #efefef; */
}
.wpcf7 dt .label {
  display: inline-block;
/*   padding: 1.6%; */
    padding-left: 1em;
  color: #fff;
  font-size: 12px;
  font-weight: normal;
  margin-right: 10px;
  border-radius: 2px;
}
.wpcf7 dt .hissu {
/*   background-color: #e11619; */
  color: #e11619;
}
.wpcf7 dt .ninni {
/*   background-color: #ccc; */
  color: #999;
}
.wpcf7 dd {
  box-sizing: border-box;
}
.wpcf7 dd .wpcf7-radio .wpcf7-list-item {
  display: block;
}
.wpcf7 .wpcf7-text {
  width: 100%;
  box-sizing: border-box;
  padding: 10px;
  background-color: #f7f7f7;
  border: none;
  border-bottom: 1px solid #aaa;
  transition: 0.3s ease-out;
}
.wpcf7 .wpcf7-text:focus {
  background-color: #fff;
  border: 1px solid #fff;
  border-bottom: 1px solid #f00;
}
.wpcf7 .wpcf7-textarea {
  width: 100%;
  box-sizing: border-box;
  padding: 10px;
  background-color: #f7f7f7;
  border: 1px solid #f7f7f7;
  transition: 0.3s ease-out;
}
.wpcf7 .wpcf7-textarea:focus {
  background-color: #fff;
  border: 1px solid #fff;
  border-bottom: 1px solid #dddddd;
}
.wpcf7 .wpcf7-submit {
  display: block;
  width: 40%;
  margin: 60px auto 40px;
  padding: 20px;
  background-color: #1978a5;
  color: #fff;
  border: none;
  text-align: center;
  font-size: 16px;
  border-radius: 4px;
  transition: 0.3s ease-out;
}

.wpcf7 .wpcf7-submit:hover {
  cursor: pointer;
  opacity: 0.6;
}

@media screen and (min-width: 768px) {
  .wpcf7 dl {
    display: table;
    width: 70%;
/*     border-top: 1px solid #EFEFEF; */
    margin-bottom: 0;
    margin: auto;
    border-bottom: 1px solid #898989;
  }
  .wpcf7 dl:last-of-type {
    border-bottom: 1px solid #898989;
  }
  .wpcf7 dt {
    display: table-cell;
    width: 35%;
    margin-bottom: 0;
/*     background-color: #eee; */
    padding: 20px;
/*     border: 1px solid #ccc; */
  }
  .wpcf7 dt .label {
/*     position: absolute;
    right: 20px; */
    margin-right: 0;
  }
  .wpcf7 dd {
    display: table-cell;
    width: 65%;
    padding: 20px;
/*     border: 1px solid #ccc;
    background-color: #fff; */
  }
  .wpcf7 .wpcf7-text {
    padding: 10px;
  }
}

body .wpcf7 .sent dl,div.wpcf7-mail-sent-ok,.complete-display,body .wpcf7 .sent .btn-submit {
    display: none !important;
} 

.sent .complete-display{
    display: block !important;
    border: 1px solid #7c2325 !important;
    padding: 1em !important;
    margin-bottom: 50px !important;
}
@media screen and (min-width:320px) {
  .lnav-inner {
    display: block
  }
  .lnav-inner, .text-block-sq {
    position: relative
  }
  .text-block-sq h3 span {
    display: none
  }
}

@media screen and (min-width:768px) {
  .archive_list{
    display: flex;
    justify-content: center;
  }
  .archive_list,
  .lnav {
    padding: 20px
  }
  .lnav {
    width: 25%
  }
  .lnav-inner {
    background-color: #000;
    display: block;
    position: relative;
    width: 100%;
    height: 0;
    padding: 0 0 100%;
    margin-bottom: 20px;
    overflow: hidden
  }
  .lnav .lnav-inner:before {
      content: "";
      display: block;
      padding-top: 100%;
  }

  .lnav .lnav-inner a {
      position: absolute;
      z-index: 3;
      width: 100%;
      height: 100%;
  }
  .lnav .text-block-sq {
    width: 90%;
    height: 90%;
    left: 5%;
    top: 5%;
    border: 1px solid hsla(0, 0%, 100%, .5)
  }
  .text-block-sq h3 span {
    display: inline-block
  }
  .lnav p {
    padding: 0
  }
  .lnav:before {
    content: '';
    z-index: 2;
    position: absolute;
    left: 1%;
    top: 1%;
    width: 90%;
    height: 90%;
    border: 1 solid #fff;
    transition: border .45s cubic-bezier(0.645, 0.045, 0.355, 1.000);
    box-sizing: border-box
  }
  .lnav:hover img {
    -webkit-transform: scale3d(1.05, 1.05, 1);
    transform: scale3d(1.05, 1.05, 1);
    opacity: .6;
    filter: alpha(opacity=60)
  }
  .lnav.off:hover img {
    opacity: 1;
    filter: alpha(opacity=100)
  }
}

.archive_list {
  padding: 10px;
  width: 100%
}

.lnav {
  width: 50%;
  margin: 0;
  padding: 10px;
  float: left;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  transition: background .45s
}
.lnav .lnav-inner {
  background-color: #000
}
.lnav .lnav-inner:before {
    content: "";
    display: block;
    padding-top: 100%;
}

.lnav .lnav-inner a {
    position: absolute;
    z-index: 3;
    width: 100%;
    height: 100%;
    display: block;
    left: 0;
    top: 0;
}

.lnav img {
  opacity: .4;
  filter: alpha(opacity=40);
  transition: all .45s cubic-bezier(0.645, 0.045, 0.355, 1.000);
  position: absolute;
  display: block;
  width: 100%;
  left: 0;
  top: 0;
}

.lnav p {
  padding: 10px 0
}
.lnav .text-block-sq {
    width: 90%;
    height: 90%;
    left: 5%;
    top: 5%;
    border: 1px solid hsla(0, 0%, 100%, .5);

  position: absolute;
  display: block;
  color: #fff;
  transition: opacity .45s cubic-bezier(0.645, 0.045, 0.355, 1.000)
}

.lnav.on img {
  opacity: 1;
  filter: alpha(opacity=100)
}

.lnav.on .text-block-sq {
  opacity: 0;
  filter: alpha(opacity=0)
}

.lnav.off img {
  opacity: .4;
  filter: alpha(opacity=40)
}

@media screen and (min-width:320px) {
  .table {
    width: 100%;
    height: 100%;
    display: table
  }
  .table-cell {
    text-align: center;
    vertical-align: middle;
    display: table-cell
  }
  .table-cell p {
    text-align: left;
    max-width: 25pc;
    margin: 10px auto
  }
}
@media screen and (max-width:1024px) {
  .text-block-sq h3 {
    font-size: 11px !important;
    letter-spacing: 0
  }
  .text-block-sq h4 {
    font-size: 10px !important;
    letter-spacing: 0
  }
}

/*
@media screen and (min-width:320px) {
  .lnav-inner {
    display: block
  }
  .lnav-inner, .text-block-sq {
    position: relative
  }
  .text-block-sq h4 {
    font-size: 11px;
    letter-spacing: 0
  }
  .text-block-sq h3 span {
    display: none
  }
}

@media screen and (min-width:768px) {
  .lnav-inner {
    display: block;
    position: relative;
    width: 100%;
    height: 0;
    padding: 0 0 100%;
    margin-bottom: 20px;
    overflow: hidden
  }
  .text-block-sq {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    display: block
  }
  .text-block-sq h3 span {
    display: inline-block
  }
}

@media screen and (min-width:768px) {
  .lnav {
    width: 25%
  }
}
*/

/*
.lnav {
  width: 50%;
  margin: 0;
  padding: 10px;
  float: left;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  transition: background .45s
}

.lnav .lnav-inner {
  background-color: #000
}

.lnav .lnav-inner:before {
    content: "";
    display: block;
    padding-top: 100%;
}

.lnav .lnav-inner a {
    position: absolute;
    z-index: 3;
    width: 100%;
    height: 100%;
}

.lnav img {
  opacity: .4;
  filter: alpha(opacity=40);
  transition: all .45s cubic-bezier(0.645, 0.045, 0.355, 1.000);
  position: relative;
  display: block;
  width: 100%;
  top: -100%;
}

.lnav p {
  padding: 10px 0
}

.lnav .text-block-sq {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  display: block;
  color: #fff;
  transition: opacity .45s cubic-bezier(0.645, 0.045, 0.355, 1.000)
}

.lnav.on img {
  opacity: 1;
  filter: alpha(opacity=100)
}

.lnav.on .text-block-sq {
  opacity: 0;
  filter: alpha(opacity=0)
}

.lnav.off img {
  opacity: .4;
  filter: alpha(opacity=40)
}
*/
/*
@media screen and (min-width:768px) {
  .archive_list, .lnav {
    padding: 20px
  }
  .lnav {
    width: 25%
  }
  .lnav .text-block-sq {
    width: 90%;
    height: 90%;
    left: 5%;
    top: 5%;
    border: 1px solid hsla(0, 0%, 100%, .5)
  }
  .lnav p {
    padding: 0
  }
  .lnav:before {
    content: '';
    z-index: 2;
    position: absolute;
    left: -1%;
    top: -1%;
    width: 102%;
    height: 102%;
    border: 0 solid #fff;
    transition: border .45s cubic-bezier(0.645, 0.045, 0.355, 1.000);
    box-sizing: border-box
  }
  .lnav:hover img {
    -webkit-transform: scale3d(1.05, 1.05, 1);
    transform: scale3d(1.05, 1.05, 1);
    opacity: .6;
    filter: alpha(opacity=60)
  }
  .lnav.off:hover img {
    opacity: 1;
    filter: alpha(opacity=100)
  }
  .plan_list{
    display: flex;
  }
}

@media screen and (min-width:320px) {
  .table {
    width: 100%;
    height: 100%;
    display: table
  }
  .table-cell {
    text-align: center;
    vertical-align: middle;
    display: table-cell
  }
  .table-cell p {
    text-align: left;
    max-width: 25pc;
    margin: 10px auto
  }
}
*/

@media screen and (min-width:320px) {
  .plan-inner {
    display: block;
    position: relative
  }
}



.sec-ttl h1 img {
    margin-bottom: 1em;
}

.sec-ttl h2 {
    padding: 0 10%;
    width: 100%;
    text-align: center;
    margin: 0 auto;
}

.sec-ttl {
    position: relative;
    padding: 30px 0 0;
    margin-bottom: 50px;
    text-align: center;
}
.sec-ttl .txt-ttl {
    text-align: center;
    display: inline-block;
    font-size: 36px;
    letter-spacing: 1px;
    background: transparent;
    line-height: 1;
    padding: 10px 0 15px;
    position: relative;
}
.sec-ttl .txt-ttl span {
    text-align: center;
    font-size: 1pc;
    font-weight: 400;
    display: block;
    margin-top: 10px;
}
/*------*/
.plan_list{
    width: 55%;
    margin: 0 auto;
}
.plan {
  width: 100%;
  margin: 0;
  padding: 10px;
  float: left;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  transition: background .45s
}

.plan .plan-inner {
  background-color: #000;
  display: block;
  position: relative;
  width: 100%;
  height: 0;
  padding: 0 0 100%;
  margin-bottom: 20px;
  overflow: hidden;
}

.plan .plan-inner a {
  position: absolute;
  z-index: 3;
  display: block;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
}

.plan img {
  opacity: .4;
  filter: alpha(opacity=40);
  transition: all .45s cubic-bezier(0.645, 0.045, 0.355, 1.000);
  position: relative;
  display: block;
  width: 100%;
}

.plan p {
  padding: 10px 0
}

.plan .text-block-sq {
  position: absolute;
    width: 90%;
    height: 90%;
    left: 5%;
    top: 5%;
    color: #FFF;
    border: 1px solid hsla(0, 0%, 100%, .5);
}

.plan.on img {
  opacity: 1;
  filter: alpha(opacity=100)
}

.plan.on .text-block-sq {
  opacity: 0;
  filter: alpha(opacity=0)
}

.plan.off img {
  opacity: .4;
  filter: alpha(opacity=40)
}

@media screen and (min-width:768px) {
  .plan_list{
    display: flex;
  }
  .plan {
    width: 50%;
    padding: 20px
  }
  .plan-inner {
    display: block;
    position: relative;
    width: 100%;
    height: 0;
    padding: 0 0 100%;
    margin-bottom: 20px;
    overflow: hidden
  }
  .plan .text-block-sq {
    width: 90%;
    height: 90%;
    left: 5%;
    top: 5%;
    border: 1px solid hsla(0, 0%, 100%, .5)
  }
  .plan p {
    padding: 0
  }
  .plan:before {
    content: '';
    z-index: 2;
    position: absolute;
    left: -1%;
    top: -1%;
    width: 102%;
    height: 102%;
    border: 0 solid #fff;
    transition: border .45s cubic-bezier(0.645, 0.045, 0.355, 1.000);
    box-sizing: border-box
  }
  .plan:hover img {
    -webkit-transform: scale3d(1.05, 1.05, 1);
    transform: scale3d(1.05, 1.05, 1);
    opacity: .6;
    filter: alpha(opacity=60)
  }
  .plan.off:hover img {
    opacity: 1;
    filter: alpha(opacity=100)
  }
}
@media screen and (max-width:380px) {
  .plan_list{
    width: 95%;
    display: flex;
    justify-content: space-around;
    }
 }


/* ----------------------------------------------------------- */
.plan_list.recom01{
    width: 90%;
    margin: 0 auto;
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
}
 .plan_list.recom01 .plan {
  width: 25%;
  margin: 0;
  padding: 10px;
  position: relative;
  cursor: pointer;
  transition: background .45s
}

 .plan_list.recom01 .plan .plan-inner {
  background-color: #000;
  display: block;
  position: relative;
  width: 100%;
  height: 0;
  padding: 0 0 100%;
  margin-bottom: 20px;
  overflow: hidden;
}

.plan_list.recom01 .plan .plan-inner a {
  position: absolute;
  z-index: 3;
  display: block;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
}

.plan_list.recom01 .plan img {
  opacity: .4;
  filter: alpha(opacity=40);
  transition: all .45s cubic-bezier(0.645, 0.045, 0.355, 1.000);
  position: relative;
  display: block;
  width: 100%;
}

.plan_list.recom01 .plan p {
  padding: 10px 0
}

.plan_list.recom01 .plan .text-block-sq {
  position: absolute;
  width: 90%;
  height: 90%;
  left: 5%;
  top: 5%;
  color: #FFF;
  border: 1px solid hsla(0, 0%, 100%, .5);
}
.text-block-sq h4{
  font-size: 11px;
}
 .plan_list.recom01 .plan.on img {
  opacity: 1;
  filter: alpha(opacity=100)
}

.plan_list.recom01 .plan.on .text-block-sq {
  opacity: 0;
  filter: alpha(opacity=0)
}

 .plan_list.recom01 .plan.off img {
  opacity: .4;
  filter: alpha(opacity=40)
}
 .plan_list.recom01 .break-incl{
  width: 100%;
  margin-bottom: 2%;
}
 .plan_list.recom01 .break-incl p{
  text-align: center;
  font-size: 22px;
  margin-bottom: 2%;
}
 .plan_list.recom01 .break-incl p span{
    font-size: 1pc;
    font-weight: 400;
    display: block;
    margin-top: 0px;
}
 .plan_list.recom01 .half-board{
  width: 100%;
}
 .plan_list.recom01 .half-board p{
   text-align: center;
  font-size: 22px;
  margin-bottom: 2%;
}

 .plan_list.recom01 .half-board p span{
    font-size: 1pc;
    font-weight: 400;
    display: block;
    margin-top: 0px;
}

.plan_list.recom01 .half-board .plan.coso{
  cursor: auto;
}
.plan_list.recom01 .break-incl .plan.coso{
  cursor: auto;
}


@media screen and (max-width:768px) {
    .plan_list.recom01{
      width: 95%;
    }
    .plan_list.recom01 .plan{
      width: 50%;
    padding: 10px;
}
 .plan_list.recom01 .plan-inner {
    display: block;
    position: relative;
    width: 100%;
    height: 0;
    padding: 0 0 100%;
    margin-bottom: 20px;
    overflow: hidden
  }
 .plan_list.recom01 .plan .text-block-sq {
    width: 90%;
    height: 90%;
    left: 5%;
    top: 5%;
    border: 1px solid hsla(0, 0%, 100%, .5)
  }
 .plan_list.recom01 .plan p {
    padding: 0
  }
 .plan_list.recom01 .plan:before {
    content: '';
    z-index: 2;
    position: absolute;
    left: -1%;
    top: -1%;
    width: 102%;
    height: 102%;
    border: 0 solid #fff;
    transition: border .45s cubic-bezier(0.645, 0.045, 0.355, 1.000);
    box-sizing: border-box
  }
 .plan_list.recom01 .plan:hover img {
    -webkit-transform: scale3d(1.05, 1.05, 1);
    transform: scale3d(1.05, 1.05, 1);
    opacity: .6;
    filter: alpha(opacity=60)
  }
 .plan_list.recom01 .plan.off:hover img {
    opacity: 1;
    filter: alpha(opacity=100)
  }
}
/*-------------------------------------*/

@media screen and (min-width:320px) {
  .info-inner {
    display: block;
    position: relative
  }
}

@media screen and (min-width:768px) {
  .info-inner {
    display: block;
    position: relative;
    width: 100%;
    height: 0;
    padding: 0 0 100%;
    margin-bottom: 20px;
    overflow: hidden
  }
}

@media screen and (min-width:768px) {
  .info {
    width: 50%
  }
}

.info {
  width: 100%;
  margin: 0;
  padding: 10px;
  float: left;
  position: relative;
  overflow: hidden;
  transition: background .45s
}

.info .info-inner {
  background-color: #000
}

.info img {
  transition: all .45s cubic-bezier(0.645, 0.045, 0.355, 1.000);
  position: relative;
  display: block;
  width: 100%
}

.info p {
  padding: 10px 0
}

.info dl {
  border-bottom: 1px solid #898989;
  padding-bottom: 0.5rem;
  margin-bottom: 0.5rem;
}

.info dt {
  vertical-align: top;
}

@media screen and (min-width: 768px) {
  .info {
    width: 50%;
    padding: 20px
  }
  .info p {
    padding: 0
  }
  .info dl {
    display: table;
    width: 100%;
  }
  .info dt {
    display: table-cell;
    width: 35%;
  }
  .info dd {
    display: table-cell;
    width: 65%;
  }
}

.cancel {
    background: #ffffff;
    padding: 0 3% 3%;
    box-sizing: border-box;
    overflow: hidden;
    margin: 0 auto 5%;
    width: 95%;
}
.cancel ul.matter {
  overflow: hidden;
  margin-top: 3%;
}
.cancel ul.matter li {
  float: left;
  width: 22%;
  margin-right: 4%;
  border-top: solid 1px #898989;
  border-bottom: solid 1px #898989;
  padding: 2% 0;
}
.cancel ul.matter li:last-child {
  margin-right: 0;
}
.cancel ul.matter li span {
  display: block;
  color: #034a3b;
  font-weight: bold;
  font-size: 1.5rem;
}
.cancel .caution {
  text-align: left;
  font-size: .8rem;
  width: 80%;
  margin: 3% auto 0;
}

@media screen and (max-width: 789px) {
  .cancel ul.matter li {
    width: 48%;
    margin-bottom: 2%;
  }
  .cancel ul.matter li:nth-child(even) {
    margin-right: 0;
  }
  .cancel .caution {
    width: 100%;
  }
}
@media screen and (max-width:414px) {
  .cancel ul.matter li {
    width: 100%;
    float: none;
    margin-right: 0;
    border-bottom: 0;
  }
  .cancel ul.matter li:last-child {
    border-bottom: solid 1px #898989;
  }
}

/* --------------------------------- */
#bnr ul {
  display: flex
}

#bnr li {
  color: #fff;
  text-align: center;
  width: 33.33333%;
  padding: 0 10px
}

#bnr li img {
  width: 100%
}

#bnr li span {
  display: block;
  font-size: 14px;
  font-weight: 400
}

#bnr li a:hover {
  background: rgba(0, 0, 0, .2)
}

#bnr li.facebook a {
  background: 0
}

#bnr li.facebook a:hover {
  background: hsla(0, 0%, 100%, .2)
}

#bnr dl {
  text-align: center;
  margin: 3em auto 1em;
  font-size: 18px;
  font-weight: 700;
  background-color: #ccc;
  display: table;
  padding: 1em
}

@media(max-width:640px) {
  #bnr ul {
    display: block;
    margin: 0 auto;
    text-align: center
  }
  #bnr li {
    width: 100%;
    padding: 10px;
    margin: auto;
    text-align: center
  }
}

/* --------------------------------- */

#bnr .colum2 li {
  color: #fff;
  text-align: center;
  width: 50%;
  padding: 0 10px
}

#bnr .colum2 li img {
  width: 100%
}

#bnr .colum2 li span {
  display: block;
  font-size: 14px;
  font-weight: 400
}

#bnr .colum2 li a:hover {
  background: rgba(0, 0, 0, .2)
}

#bnr .colum2 li .facebook a {
  background: 0
}

#bnr .colum2 li .facebook a:hover {
  background: hsla(0, 0%, 100%, .2)
}

#bnr .colum2 li:first-child .btn-cmn {
    margin: auto 0 auto auto;
}
#bnr .colum2 li:last-child .btn-cmn {
    margin: auto auto auto 0;
}

/* 2019-0731追加 */
.check-out{
  line-height: 1.5;
  border: 1px solid #b9b9b9;
  width: 636px;
  margin:0 auto 30px;
}
.check-out span p{
  font-size: 1.5em;
  color: red;
  font-weight: bold;
}
.check-out p{
  font-size: 18px;
}

@media(max-width:480px) {
.check-out {
  line-height: 1.5;
  border: 1px solid #b9b9b9;
  width: 90%;
  margin: 0 auto 30px;
  padding: 0 5%;
}
}

/* recruit
-----------------------------------*/

.recruit-inner{
  display: flex;
  padding: 4%
}
.recruit-image{
  width: 48%;
  margin-right: 4%;
}
.recruit-image p img {
  width: 100%;
}
.recruit-image p.recruit-sp {
  display: none !important;
}
.recruit-image p.recruit-pc {
  display: block !important;
}
.recruit-inner table tr th{
  vertical-align: middle;
}
.recruit-inner table tr td{
  vertical-align: middle;
}
.recruit-about{
  width:48%;
}
.recruit-about table tr th{
  width: 23%;
  text-align: left;
}
.recruit-about table tr td{
  padding: 7px 10px;
}
.recruit-about table tr.tex-bg td{
  font-size: 20px;
  font-weight: bold;
}
.recruit-about table {
  width: 100%;
  border-top: 3px solid #000000;
  margin-bottom: 80px;
}
.recruit-about table tr th,
.recruit-about table tr td{
border-bottom: 1px solid #000000;
}

.recruit-about table tr:nth-of-type(1) th,
.recruit-about table tr:nth-of-type(1) td{
border-bottom: 1px solid #000000;
}

/***************************************
       20210720 Recruit追加と修正 
***************************************/
p.recruit-sp {
  display: none !important;
}
p.recruit-pc {
  display: block !important;
}
.sec-ttl h2 span{
  display: block;
  font-size: 1pc;
}
.recruit2021 h2{
  margin-bottom: 20px;
  font-size: 30px;
}
.recruit2021 h3{
  margin-bottom: 20px;
  font-size: 20px;
  font-weight: 700;
}
.recruit2021 h4{
  margin-bottom: 20px;
  font-size: 20px;
  font-weight: 700;
}
.recruit2021 h4 span{
  display: inline-block;
  margin-bottom: 10px;
  padding: 2px 10px;
  border: 1px solid #000;
  font-size: 18px;  
}
.recruit2021 h5{
  margin-bottom: 10px;
  font-size: 16px;
}
.recruit-inner{
  padding: 2% 4%;
}
.stage-wrap .recruit-inner:nth-of-type(odd){
  flex-direction: row-reverse;
}
.stage-wrap .recruit-inner:nth-of-type(odd) .recruit-image{
  margin-left: 4%;
  margin-right:0;
}
.stage-wrap .recruit-inner:last-child{
  margin-bottom: 30px;
}
.workstyle-wrap .recruit-inner:nth-of-type(odd){
  flex-direction: row-reverse;
}
.workstyle-wrap .recruit-inner:nth-of-type(odd) .recruit-image{
  margin-left: 4%;
  margin-right:0;
}
.recruit-main{
  position: relative;
  width: 100%;
  margin-bottom: 50px;
  padding: 2% 4%;
}
p.catchcopy{
  position: absolute;
  left: 50%;
  top: 50%;
  width: 70%;
  text-align: center;
  color: #FFF;
  font-size: 30px;
  transform: translate(-50%, -50%);
}
p.catchcopy span{
  display: inline-block;
}
.recruit-main img{
  width: 100%;
}
.sec2{
  margin-bottom: 50px;
  padding: 2% 4%;
}
.sec2 img{
  width: 100%;
}
p.rec-txt{
  margin-bottom: 50px;
}
.recruit2021 .recruite-table{
  margin: 30px 0;
}
.recruit2021 .recruit-about table{
  margin-bottom: 20px;
  border-top: 1px solid #a3a3a3;
}
.recruit2021 .recruit-about table tr th{
  padding: 7px 0;
}
.recruit2021 .recruit-about table tr th, .recruit-about table tr td{
  border-bottom: 1px solid #a3a3a3;
}
.recruit2021 .recruit-about table tr:nth-of-type(1) th, .recruit-about table tr:nth-of-type(1) td{
  border-bottom: 1px solid #a3a3a3;
}
.recruit2021 .btn-cmn{
  margin: 50px auto 0;
}
/*
.sec2 ul{
  width: 70%;
  margin: 0 auto;
}
.sec2 ul li{
  margin-bottom: 10px;
  padding-left: 1em;
  text-indent: -1em;
}
.sec2 ul li a{
  text-decoration: underline;
}
*/

/*
.recruit-about table tr:nth-child(1){
border-top: none;
}
.recruit-about table tr:nth-child(2){
border-top: none;
}
.recruit-about table tr:nth-child(1){
border-top: 3px solid #000000;
}
.recruit-about table tr:nth-child(2){
border-top: 3px solid #000000;
}
.recruit-about table tr:nth-child(8){
border-bottom: 1px solid #000000;
}
.recruit-about td {
  padding: 10px 0 ; 
}/*
.recruit-about .sec2{
  width: 100%;
  margin-bottom: 100px;
}
.recruit-about .sec2 table tr th{
  width: 23%;
  text-align: left;
}
.recruit-about .sec2 table tr td{
  width: 77%;
  height: 46px;
}
.recruit-about .sec2 table tr.tex-bg td{
font-size: 20px;
font-weight: bold;
}
.recruit-about .sec2 table tr{
border-top: 1px solid #000000;
}
.recruit-about .sec2 table tr:nth-child(1){
border-top: none;
}
.recruit-about .sec2 table tr:nth-child(2){
border-top: none;
}
.recruit-about .sec2 table tr:nth-child(1){
border-top: 3px solid #000000;
}
.recruit-about .sec2 table tr:nth-child(2){
border-top: 3px solid #000000;
}
.recruit-about .sec2 table tr:nth-child(7){
border-bottom: 1px solid #000000;
}
*/



@media(max-width:1024px){
  p.catchcopy{
    font-size: 24px;
  }
}


@media(max-width:760px) {
.recruit-inner{
  display: block;
  padding:5%;
}
.recruit-image p.recruit-sp{
  display:block  !important;
}
.recruit-image p.recruit-pc{
  display:none !important;
}
.recruit-image{
  width: 100%;
}
.recruit-about{
  width: 100%;
  margin-top: 80px;
}
p.recruit-sp{
  display:block  !important;
}
p.recruit-pc{
  display:none !important;
}
/* 20210726 修正 */
.recruit-about{
  margin-top: 50px;
}
.recruit2021 h2{
  font-size: 26px;
}
.recruit2021 h3{
  font-size: 22px;
  text-align: center;
}
.recruit2021 h4{
  font-size: 17px;
}
.recruit2021 h4 span{
  font-size: 14px;
}
p.rec-txt{
  margin-bottom: 0;
}
.sec2 ul{
  width: 100%;
}
.workstyle-wrap .recruit-inner:nth-of-type(odd) .recruit-image{
  margin-left:0;
}
.stage-wrap .recruit-inner:nth-of-type(odd) .recruit-image{
  margin-left:0;
}
}


@media(max-width:480px){
  p.catchcopy{
    width: 90%;
    font-size: 22px;
  }
  .recruit2021 .container h2{
    font-size: 24px;
  }
  .recruit2021 .container h3{
    font-size: 20px;
  }
  .recruit-inner{
    margin-bottom: 30px;
  }
  .recruit-about{
    margin-top: 30px;
  }
  .sec2{
    margin-bottom: 30px;
  }
  .sec-ttl{
    margin-bottom: 30px;
  }
  .recruit2021 .recruite-table{
    margin-bottom: 0;
  }
}



/* 2020-08/17--コロナウィルス対策　追加 */
.Corona{
  max-width: 620px;
  width: 40%;
  text-align: center;
  margin: 30px auto 0;
  padding: 10px;
}
.Corona a{
  display: block;
  color: #000;
  padding: 10px;
  text-align: center;
  font-size: 20px;
  border: double 7px #1978A5;
}
.Corona a:hover{
  background: #1978A5;
  color: #FFF;
  border: double 7px #1978A5;
}
@media(max-width:1130px) {
    .Corona{
  width: 60%;
  }
}
@media(max-width:780px) {
  .Corona{
  width: 70%;
  }
}
@media(max-width:480px) {
  .Corona{
  width: 90%;
  padding: 0;
  }
  .Corona a{
    font-size: 16px;

  }
}
/* 2020-08/17--goto　追加 */
.goto{
  max-width: 920px;
  margin: 40px auto 20px;
  padding: 0 20px;
}
.goto img{
  width: 100%;
}

#sb_instagram #sbi_images .sbi_item.sbi_transition {
    opacity: 1 !important;
    max-height: 100% !important;
}
#sb_instagram .sbi_photo{
  max-height:20vW !important;
}
#sb_instagram .sbi_photo img{
  width:160% !important;
  max-width:auto !important;
}
/* 2021-08/06--やんばるバナー　追加 */
.yanbaru__staynavi {
  max-width: 920px;
  height: auto;
  margin: 0 auto;
  width: 100%;
  margin-bottom: 30px;
}
.yanbaru__staynavi img {
  height: auto;
  width: 100%;
}
.yanbaru {
  max-width: 600px;
  margin: 0 auto;
  width: 100%;
}
.yanbaru a{
  display: block;
  width: 100%;
}
.yanbaru a img{ 
  width: 100%;
}
.yanbaru a:hover{
  opacity: 0.5;
}
@media(max-width:920px) {
  .yanbaru__staynavi {
    padding: 0 5%;
  }
}
@media(max-width:780px) {
  .yanbaru{
    padding: 0 3%;
  }
}
@media(max-width:480px) {
  .yanbaru{
    padding: 0 5%;
  }
}
/* 2022-01/17--まん延防止等重点措置　追加 */
.manbo {
    width: 37.5%;
    text-align: center;
    margin: 30px auto;
    padding: 10px;
    max-width: 620px;
    background: #FFF;
    border: solid 2px red;
    color: red;
    font-size: 20px;
    font-weight: 500;
}
@media(max-width:1130px) {
    .manbo{
  width: 60%;
  }
}
@media(max-width:780px) {
  .manbo{
  width: 70%;
  }
}
@media(max-width:480px) {
  .manbo{
  width: 90%;
  font-size: 16px;
  }
}