@charset "UTF-8";
/*! normalize.css v4.1.1 | MIT License | github.com/necolas/normalize.css */
/**
 * 1. Change the default font family in all browsers (opinionated).
 * 2. Prevent adjustments of font size after orientation changes in IE and iOS.
 */
html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
  font-size: 62.5%;
  /*10px*/
}
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, font, 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 {
  border: 0;
  font-style: inherit;
  font-weight: inherit;
  margin: 0;
  outline: 0;
  padding: 0;
}
/**
 * Remove the margin in all browsers (opinionated).
 */
body {
  margin: 0;
}
/* HTML5 display definitions
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 * 2. Add the correct display in IE.
 */
article, aside, details,
/* 1 */
figcaption, figure, footer, header, main,
/* 2 */
menu, nav, section, summary {
  /* 1 */
  display: block;
}
/**
 * Add the correct display in IE 9-.
 */
audio, canvas, progress, video {
  display: inline-block;
}
/**
 * Add the correct display in iOS 4-7.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}
/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}
/**
 * Add the correct display in IE 10-.
 * 1. Add the correct display in IE.
 */
template,
/* 1 */
[hidden] {
  display: none;
}
/* Links
   ========================================================================== */
/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */
a {
  background-color: transparent;
  /* 1 */
  -webkit-text-decoration-skip: objects;
  /* 2 */
}
/**
 * Remove the outline on focused links when they are also active or hovered
 * in all browsers (opinionated).
 */
a:active, a:hover {
  outline-width: 0;
}
/* Text-level semantics
   ========================================================================== */
/**
 * 1. Remove the bottom border in Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  text-decoration: underline dotted;
  /* 2 */
}
/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */
b, strong {
  font-weight: inherit;
}
/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b, strong {
  font-weight: bolder;
}
/**
 * Add the correct font style in Android 4.3-.
 */
dfn {
  font-style: italic;
}
li {
  list-style: none;
}
/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
/**
 * Add the correct background and color in IE 9-.
 */
mark {
  background-color: #ff0;
  color: #000;
}
/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}
/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}
/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10-.
 */
img {
  border-style: none;
}
/**
 * Hide the overflow in IE.
 */
svg:not(:root) {
  overflow: hidden;
}
/* Grouping content
   ========================================================================== */
/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code, kbd, pre, samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}
/**
 * Add the correct margin in IE 8.
 */
figure {
  margin: 0;
}
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */
}
/* Forms
   ========================================================================== */
/**
 * 1. Change font properties to `inherit` in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */
button, input, optgroup, select, textarea {
  font: inherit;
  /* 1 */
  margin: 0;
  /* 2 */
  padding: 0;
  border: 0;
  background-color: transparent;
}
/**
 * Restore the font weight unset by the previous rule.
 */
optgroup {
  font-weight: bold;
}
/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button, input {
  /* 1 */
  overflow: visible;
}
/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button, select {
  /* 1 */
  text-transform: none;
}
/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *    controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */
button, html [type="button"],
/* 1 */
[type="reset"], [type="submit"] {
  -webkit-appearance: button;
  /* 2 */
}
/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner, [type="button"]::-moz-focus-inner, [type="reset"]::-moz-focus-inner, [type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}
/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring, [type="button"]:-moz-focusring, [type="reset"]:-moz-focusring, [type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}
/**
 * Change the border, margin, and padding in all browsers (opinionated).
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}
/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */
}
/**
 * Remove the default vertical scrollbar in IE.
 */
textarea {
  overflow: auto;
}
/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */
[type="checkbox"], [type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}
/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button, [type="number"]::-webkit-outer-spin-button {
  height: auto;
}
/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */
}
/**
 * Remove the inner padding and cancel buttons in Chrome and Safari on OS X.
 */
[type="search"]::-webkit-search-cancel-button, [type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}
/**
 * Correct the text style of placeholders in Chrome, Edge, and Safari.
 */
::-webkit-input-placeholder {
  color: inherit;
  opacity: 0.54;
}
/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */
}
.clearfix {
  *zoom: 1;
}
.clearfix:after {
  content: "";
  display: table;
  clear: both;
}
/*!
  Modaal - accessible modals - v0.4.3
  by Humaan, for all humans.
  http://humaan.com
 */
.modaal-noscroll {
  overflow: hidden;
}
.modaal-accessible-hide {
  position: absolute!important;
  clip: rect(1px 1px 1px 1px);
  clip: rect(1px, 1px, 1px, 1px);
  padding: 0!important;
  border: 0!important;
  height: 1px!important;
  width: 1px!important;
  overflow: hidden
}
.modaal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 999;
  opacity: 0
}
.modaal-wrapper {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  overflow: auto;
  opacity: 1;
  box-sizing: border-box;
  -webkit-overflow-scrolling: touch;
  -webkit-transition: all .3s ease-in-out;
  transition: all .3s ease-in-out
}
.modaal-wrapper * {
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-backface-visibility: hidden
}
.modaal-wrapper .modaal-close {
  border: none;
  background: 0 0;
  padding: 0;
  -webkit-appearance: none
}
.modaal-wrapper.modaal-start_none {
  display: none;
  opacity: 1
}
.modaal-wrapper.modaal-start_fade {
  opacity: 0
}
.modaal-wrapper [tabindex="0"] {
  outline: 0!important
}
.modaal-wrapper.modaal-fullscreen {
  overflow: hidden
}
.modaal-outer-wrapper {
  display: table;
  position: relative;
  width: 100%;
  height: 100%
}
.modaal-fullscreen .modaal-outer-wrapper {
  display: block
}
.modaal-inner-wrapper {
  display: table-cell;
  width: 100%;
  height: 100%;
  position: relative;
  vertical-align: middle;
  text-align: center;
  padding: 80px 25px
}
.modaal-fullscreen .modaal-inner-wrapper {
  padding: 0;
  display: block;
  vertical-align: top
}
.modaal-container {
  position: relative;
  display: inline-block;
  width: 100%;
  margin: auto;
  text-align: left;
  color: #000;
  max-width: 1000px;
  border-radius: 0;
  background: #fff;
  box-shadow: 0 4px 15px rgba(0, 0, 0, .2);
  cursor: auto
}
.modaal-container.is_loading {
  height: 100px;
  width: 100px;
  overflow: hidden
}
.modaal-fullscreen .modaal-container {
  max-width: none;
  height: 100%;
  overflow: auto
}
.modaal-close {
  position: fixed;
  right: 20px;
  top: 20px;
  color: #fff;
  cursor: pointer;
  opacity: 1;
  width: 50px;
  height: 50px;
  background: rgba(0, 0, 0, 0);
  border-radius: 100%;
  -webkit-transition: all .2s ease-in-out;
  transition: all .2s ease-in-out
}
.modaal-close:focus, .modaal-close:hover {
  outline: 0;
  background: #fff
}
.modaal-close:focus:after, .modaal-close:focus:before, .modaal-close:hover:after, .modaal-close:hover:before {
  background: #b93d0c
}
.modaal-close span {
  position: absolute!important;
  clip: rect(1px 1px 1px 1px);
  clip: rect(1px, 1px, 1px, 1px);
  padding: 0!important;
  border: 0!important;
  height: 1px!important;
  width: 1px!important;
  overflow: hidden
}
.modaal-close:after, .modaal-close:before {
  display: block;
  content: " ";
  position: absolute;
  top: 14px;
  left: 23px;
  width: 4px;
  height: 22px;
  border-radius: 4px;
  background: #fff;
  -webkit-transition: background .2s ease-in-out;
  transition: background .2s ease-in-out
}
.modaal-close:before {
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg)
}
.modaal-close:after {
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg)
}
.modaal-fullscreen .modaal-close {
  background: #afb7bc;
  right: 10px;
  top: 10px
}
.modaal-content-container {
  padding: 30px
}
.modaal-confirm-wrap {
  padding: 30px 0 0;
  text-align: center;
  font-size: 0
}
.modaal-confirm-btn {
  font-size: 14px;
  display: inline-block;
  margin: 0 10px;
  vertical-align: middle;
  cursor: pointer;
  border: none;
  background: 0 0
}
.modaal-confirm-btn.modaal-ok {
  padding: 10px 15px;
  color: #fff;
  background: #555;
  border-radius: 3px;
  -webkit-transition: background .2s ease-in-out;
  transition: background .2s ease-in-out
}
.modaal-confirm-btn.modaal-ok:hover {
  background: #2f2f2f
}
.modaal-confirm-btn.modaal-cancel {
  text-decoration: underline
}
.modaal-confirm-btn.modaal-cancel:hover {
  text-decoration: none;
  color: #2f2f2f
}
.modaal-instagram .modaal-container {
  width: auto;
  background: 0 0;
  box-shadow: none!important
}
.modaal-instagram .modaal-content-container {
  padding: 0;
  background: 0 0
}
.modaal-instagram .modaal-content-container>blockquote {
  width: 1px!important;
  height: 1px!important;
  opacity: 0!important
}
.modaal-instagram iframe {
  opacity: 0;
  margin: -6px!important;
  border-radius: 0!important;
  width: 1000px!important;
  max-width: 800px!important;
  box-shadow: none!important;
  -webkit-animation: instaReveal 1s linear forwards;
  animation: instaReveal 1s linear forwards
}
.modaal-image .modaal-inner-wrapper {
  padding-left: 140px;
  padding-right: 140px
}
.modaal-image .modaal-container {
  width: auto;
  max-width: 100%
}
.modaal-gallery-wrap {
  position: relative;
  color: #fff
}
.modaal-gallery-item {
  display: none
}
.modaal-gallery-item img {
  display: block
}
.modaal-gallery-item.is_active {
  display: block
}
.modaal-gallery-label {
  position: absolute;
  left: 0;
  width: 100%;
  margin: 20px 0 0;
  font-size: 18px;
  text-align: center;
  color: #fff
}
.modaal-gallery-label:focus {
  outline: 0
}
.modaal-gallery-control {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  opacity: 1;
  cursor: pointer;
  color: #fff;
  width: 50px;
  height: 50px;
  background: rgba(0, 0, 0, 0);
  border: none;
  border-radius: 100%;
  -webkit-transition: all .2s ease-in-out;
  transition: all .2s ease-in-out
}
.modaal-gallery-control.is_hidden {
  opacity: 0;
  cursor: default
}
.modaal-gallery-control:focus, .modaal-gallery-control:hover {
  outline: 0;
  background: #fff
}
.modaal-gallery-control:focus:after, .modaal-gallery-control:focus:before, .modaal-gallery-control:hover:after, .modaal-gallery-control:hover:before {
  background: #afb7bc
}
.modaal-gallery-control span {
  position: absolute!important;
  clip: rect(1px 1px 1px 1px);
  clip: rect(1px, 1px, 1px, 1px);
  padding: 0!important;
  border: 0!important;
  height: 1px!important;
  width: 1px!important;
  overflow: hidden
}
.modaal-gallery-control:after, .modaal-gallery-control:before {
  display: block;
  content: " ";
  position: absolute;
  top: 16px;
  left: 25px;
  width: 4px;
  height: 18px;
  border-radius: 4px;
  background: #fff;
  -webkit-transition: background .2s ease-in-out;
  transition: background .2s ease-in-out
}
.modaal-gallery-control:before {
  margin: -5px 0 0;
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg)
}
.modaal-gallery-control:after {
  margin: 5px 0 0;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg)
}
.modaal-gallery-next-inner {
  left: 100%;
  margin-left: 40px
}
.modaal-gallery-next-outer {
  right: 45px
}
.modaal-gallery-prev:after, .modaal-gallery-prev:before {
  left: 22px
}
.modaal-gallery-prev:before {
  margin: 5px 0 0;
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg)
}
.modaal-gallery-prev:after {
  margin: -5px 0 0;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg)
}
.modaal-gallery-prev-inner {
  right: 100%;
  margin-right: 40px
}
.modaal-gallery-prev-outer {
  left: 45px
}
.modaal-video-wrap {
  margin: auto 50px;
  position: relative
}
.modaal-video-container {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  max-width: 100%;
  box-shadow: 0 0 10px rgba(0, 0, 0, .3);
  background: #000;
  max-width: 1300px;
  margin-left: auto;
  margin-right: auto
}
.modaal-video-container embed, .modaal-video-container iframe, .modaal-video-container object {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}
.modaal-iframe .modaal-content {
  width: 100%;
  height: 100%
}
.modaal-iframe-elem {
  width: 100%;
  height: 100%;
  display: block
}
.modaal-loading-spinner {
  background: 0 0;
  position: absolute;
  width: 200px;
  height: 200px;
  top: 50%;
  left: 50%;
  margin: -100px 0 0 -100px;
  -webkit-transform: scale(.25);
  -ms-transform: scale(.25);
  transform: scale(.25)
}
.modaal-loading-spinner>div {
  width: 24px;
  height: 24px;
  margin-left: 4px;
  margin-top: 4px;
  position: absolute
}
.modaal-loading-spinner>div>div {
  width: 100%;
  height: 100%;
  border-radius: 15px;
  background: #fff
}
.modaal-loading-spinner>div:nth-of-type(1)>div {
  -webkit-animation: modaal-loading-spinner 1s linear infinite;
  animation: modaal-loading-spinner 1s linear infinite;
  -webkit-animation-delay: 0s;
  animation-delay: 0s
}
.modaal-loading-spinner>div:nth-of-type(2)>div, .modaal-loading-spinner>div:nth-of-type(3)>div {
  -ms-animation: modaal-loading-spinner 1s linear infinite;
  -moz-animation: modaal-loading-spinner 1s linear infinite;
  -webkit-animation: modaal-loading-spinner 1s linear infinite;
  -o-animation: modaal-loading-spinner 1s linear infinite
}
.modaal-loading-spinner>div:nth-of-type(1) {
  -ms-transform: translate(84px, 84px) rotate(45deg) translate(70px, 0);
  -webkit-transform: translate(84px, 84px) rotate(45deg) translate(70px, 0);
  transform: translate(84px, 84px) rotate(45deg) translate(70px, 0)
}
.modaal-loading-spinner>div:nth-of-type(2)>div {
  -webkit-animation: modaal-loading-spinner 1s linear infinite;
  animation: modaal-loading-spinner 1s linear infinite;
  -webkit-animation-delay: .12s;
  animation-delay: .12s
}
.modaal-loading-spinner>div:nth-of-type(2) {
  -ms-transform: translate(84px, 84px) rotate(90deg) translate(70px, 0);
  -webkit-transform: translate(84px, 84px) rotate(90deg) translate(70px, 0);
  transform: translate(84px, 84px) rotate(90deg) translate(70px, 0)
}
.modaal-loading-spinner>div:nth-of-type(3)>div {
  -webkit-animation: modaal-loading-spinner 1s linear infinite;
  animation: modaal-loading-spinner 1s linear infinite;
  -webkit-animation-delay: .25s;
  animation-delay: .25s
}
.modaal-loading-spinner>div:nth-of-type(4)>div, .modaal-loading-spinner>div:nth-of-type(5)>div {
  -ms-animation: modaal-loading-spinner 1s linear infinite;
  -moz-animation: modaal-loading-spinner 1s linear infinite;
  -webkit-animation: modaal-loading-spinner 1s linear infinite;
  -o-animation: modaal-loading-spinner 1s linear infinite
}
.modaal-loading-spinner>div:nth-of-type(3) {
  -ms-transform: translate(84px, 84px) rotate(135deg) translate(70px, 0);
  -webkit-transform: translate(84px, 84px) rotate(135deg) translate(70px, 0);
  transform: translate(84px, 84px) rotate(135deg) translate(70px, 0)
}
.modaal-loading-spinner>div:nth-of-type(4)>div {
  -webkit-animation: modaal-loading-spinner 1s linear infinite;
  animation: modaal-loading-spinner 1s linear infinite;
  -webkit-animation-delay: .37s;
  animation-delay: .37s
}
.modaal-loading-spinner>div:nth-of-type(4) {
  -ms-transform: translate(84px, 84px) rotate(180deg) translate(70px, 0);
  -webkit-transform: translate(84px, 84px) rotate(180deg) translate(70px, 0);
  transform: translate(84px, 84px) rotate(180deg) translate(70px, 0)
}
.modaal-loading-spinner>div:nth-of-type(5)>div {
  -webkit-animation: modaal-loading-spinner 1s linear infinite;
  animation: modaal-loading-spinner 1s linear infinite;
  -webkit-animation-delay: .5s;
  animation-delay: .5s
}
.modaal-loading-spinner>div:nth-of-type(6)>div, .modaal-loading-spinner>div:nth-of-type(7)>div {
  -ms-animation: modaal-loading-spinner 1s linear infinite;
  -moz-animation: modaal-loading-spinner 1s linear infinite;
  -webkit-animation: modaal-loading-spinner 1s linear infinite;
  -o-animation: modaal-loading-spinner 1s linear infinite
}
.modaal-loading-spinner>div:nth-of-type(5) {
  -ms-transform: translate(84px, 84px) rotate(225deg) translate(70px, 0);
  -webkit-transform: translate(84px, 84px) rotate(225deg) translate(70px, 0);
  transform: translate(84px, 84px) rotate(225deg) translate(70px, 0)
}
.modaal-loading-spinner>div:nth-of-type(6)>div {
  -webkit-animation: modaal-loading-spinner 1s linear infinite;
  animation: modaal-loading-spinner 1s linear infinite;
  -webkit-animation-delay: .62s;
  animation-delay: .62s
}
.modaal-loading-spinner>div:nth-of-type(6) {
  -ms-transform: translate(84px, 84px) rotate(270deg) translate(70px, 0);
  -webkit-transform: translate(84px, 84px) rotate(270deg) translate(70px, 0);
  transform: translate(84px, 84px) rotate(270deg) translate(70px, 0)
}
.modaal-loading-spinner>div:nth-of-type(7)>div {
  -webkit-animation: modaal-loading-spinner 1s linear infinite;
  animation: modaal-loading-spinner 1s linear infinite;
  -webkit-animation-delay: .75s;
  animation-delay: .75s
}
.modaal-loading-spinner>div:nth-of-type(7) {
  -ms-transform: translate(84px, 84px) rotate(315deg) translate(70px, 0);
  -webkit-transform: translate(84px, 84px) rotate(315deg) translate(70px, 0);
  transform: translate(84px, 84px) rotate(315deg) translate(70px, 0)
}
.modaal-loading-spinner>div:nth-of-type(8)>div {
  -webkit-animation: modaal-loading-spinner 1s linear infinite;
  animation: modaal-loading-spinner 1s linear infinite;
  -webkit-animation-delay: .87s;
  animation-delay: .87s
}
.modaal-loading-spinner>div:nth-of-type(8) {
  -ms-transform: translate(84px, 84px) rotate(360deg) translate(70px, 0);
  -webkit-transform: translate(84px, 84px) rotate(360deg) translate(70px, 0);
  transform: translate(84px, 84px) rotate(360deg) translate(70px, 0)
}
@media only screen and (min-width:1400px) {
  .modaal-video-container {
    padding-bottom: 0;
    height: 731px
  }
}
@media only screen and (max-width:1140px) {
  .modaal-image .modaal-inner-wrapper {
    padding-left: 25px;
    padding-right: 25px
  }
  .modaal-gallery-control {
    top: auto;
    bottom: 20px;
    -webkit-transform: none;
    -ms-transform: none;
    transform: none;
    background: rgba(0, 0, 0, .7)
  }
  .modaal-gallery-control:after, .modaal-gallery-control:before {
    background: #fff
  }
  .modaal-gallery-next {
    left: auto;
    right: 20px
  }
  .modaal-gallery-prev {
    left: 20px;
    right: auto
  }
}
@media screen and (max-width:900px) {
  .modaal-instagram iframe {
    width: 500px!important
  }
}
@media only screen and (max-width:600px) {
  .modaal-instagram iframe {
    width: 280px!important
  }
}
@media screen and (max-height:1100px) {
  .modaal-instagram iframe {
    width: 700px!important
  }
}
@media screen and (max-height:1000px) {
  .modaal-inner-wrapper {
    padding-top: 60px;
    padding-bottom: 60px
  }
  .modaal-instagram iframe {
    width: 600px!important
  }
}
@media screen and (max-height:900px) {
  .modaal-instagram iframe {
    width: 500px!important
  }
  .modaal-video-container {
    max-width: 900px;
    max-height: 510px
  }
}
@media only screen and (max-height:820px) {
  .modaal-gallery-label {
    display: none
  }
}
@keyframes instaReveal {
  0% {
    opacity: 0
  }
  100% {
    opacity: 1
  }
}
@-webkit-keyframes instaReveal {
  0% {
    opacity: 0
  }
  100% {
    opacity: 1
  }
}
@-webkit-keyframes modaal-loading-spinner {
  0% {
    opacity: 1;
    -ms-transform: scale(1.5);
    -webkit-transform: scale(1.5);
    transform: scale(1.5)
  }
  100% {
    opacity: .1;
    -ms-transform: scale(1);
    -webkit-transform: scale(1);
    transform: scale(1)
  }
}
@keyframes modaal-loading-spinner {
  0% {
    opacity: 1;
    -ms-transform: scale(1.5);
    -webkit-transform: scale(1.5);
    transform: scale(1.5)
  }
  100% {
    opacity: .1;
    -ms-transform: scale(1);
    -webkit-transform: scale(1);
    transform: scale(1)
  }
}
/* Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -khtml-user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}
.slick-list {
  position: relative;
  display: block;
  overflow: hidden;
  margin: 0;
  padding: 0;
}
.slick-list:focus {
  outline: none;
}
.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}
.slick-slider .slick-track, .slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
.slick-track {
  position: relative;
  top: 0;
  left: 0;
  margin-left: auto;
  margin-right: auto;
  display: block;
}
.slick-track:before, .slick-track:after {
  display: table;
  content: '';
}
.slick-track:after {
  clear: both;
}
.slick-loading .slick-track {
  visibility: hidden;
}
.slick-slide {
  display: none;
  float: left;
  height: 100%;
  min-height: 1px;
}
[dir='rtl'] .slick-slide {
  float: right;
}
.slick-slide img {
  display: block;
}
.slick-slide.slick-loading img {
  display: none;
}
.slick-slide.dragging img {
  pointer-events: none;
}
.slick-initialized .slick-slide {
  display: block;
}
.slick-loading .slick-slide {
  visibility: hidden;
}
.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
  display: none;
}
/* Slider */
.slick-loading .slick-list {}
/* Icons */
@font-face {
  font-family: 'slick';
  font-weight: normal;
  font-style: normal;
  src: url('./fonts/slick.eot');
  src: url('./fonts/slick.eot?#iefix') format('embedded-opentype'), url('./fonts/slick.woff') format('woff'), url('./fonts/slick.ttf') format('truetype'), url('./fonts/slick.svg#slick') format('svg');
}
/* Arrows */
.slick-prev, .slick-next {
  font-size: 0;
  line-height: 0;
  position: absolute;
  top: 50%;
  display: block;
  width: 20px;
  height: 20px;
  padding: 0;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  cursor: pointer;
  color: transparent;
  border: none;
  outline: none;
  background: transparent;
}
.slick-prev:hover, .slick-prev:focus, .slick-next:hover, .slick-next:focus {
  color: transparent;
  outline: none;
  background: transparent;
}
.slick-prev:hover:before, .slick-prev:focus:before, .slick-next:hover:before, .slick-next:focus:before {
  opacity: 1;
}
.slick-prev.slick-disabled:before, .slick-next.slick-disabled:before {
  opacity: .25;
}
.slick-prev:before, .slick-next:before {
  font-size: 20px;
  line-height: 1;
  opacity: .75;
  color: #151515;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.slick-prev {
  left: -10px;
}
[dir='rtl'] .slick-prev {
  right: -10px;
  left: auto;
}
.slick-prev:before {
  content: '←';
}
[dir='rtl'] .slick-prev:before {
  content: '→';
}
.slick-next {
  right: -10px;
}
[dir='rtl'] .slick-next {
  right: auto;
  left: -10px;
}
.slick-next:before {
  content: '→';
}
[dir='rtl'] .slick-next:before {
  content: '←';
}
/* Dots */
.slick-dotted.slick-slider {
  margin-bottom: 30px;
}
.slick-dots {
  position: absolute;
  bottom: -25px;
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
}
.slick-dots li {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}
.slick-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: 20px;
  height: 20px;
  padding: 5px;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: none;
  background: transparent;
}
.slick-dots li button:hover, .slick-dots li button:focus {
  outline: none;
}
.slick-dots li button:hover:before, .slick-dots li button:focus:before {
  opacity: 1;
}
.slick-dots li button:before {
  font-family: 'slick';
  font-size: 6px;
  line-height: 20px;
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  content: '•';
  text-align: center;
  opacity: .25;
  color: black;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.slick-dots li.slick-active button:before {
  opacity: .75;
  color: black;
}
/*common*/
/*
  main-color : #005B31;
  main-color-rgb: rgb(0,105,140):
*/
* {
  box-sizing: border-box;
}
input::-webkit-input-placeholder, input::-moz-placeholder, input::-ms-input-placeholder {
  color: #aaa;
}
input:-ms-input-placeholder {
  color: #aaa;
}
html {
  overflow-x: hidden;
  overflow-y: auto;
}
body {
  font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", 'メイリオ', Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: 1.4rem;
  word-break: normal;
  overflow-wrap: break-word;
  word-wrap: break-word;
  line-height: 1.7;
  color: #151515;
  background: #fff;
  overflow-x: hidden;
  overflow-y: auto;
}
.sp {
  display: none !important;
}
.pc {
  display: block;
}
a {
  text-decoration: none;
  color: #151515;
}
.imgWrap .wp-post-image, .reImg {
  width: 100%;
  height: auto;
  vertical-align: top;
}
.bgGlay {
  background: #f5f5f5;
}
.cntInner {
  padding: 0 50px;
}
.inner {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
}
/*pgTop*/
.pageTop {
  display: none;
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 7;
}
.pageTop a {
  background: #151515;
  width: 40px;
  height: 40px;
  display: block;
  text-align: center;
  padding-top: 5px;
}
.pageTop a:hover img {
  opacity: 0.7;
}
/*margin*/
.mt20 {
  margin-top: 20px;
}
.mb100 {
  margin-bottom: 100px;
}
/*font ttl*/
.en {
  font-family: 'Roboto', "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", 'メイリオ', Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
.ttlA {
  font-size: 6rem;
  letter-spacing: 5px;
  margin-left: -50px;
  line-height: 1.4;
  margin-bottom: 30px;
}
.ttlA:after {
  content: "";
  background: #005B31;
  display: block;
  width: 180px;
  height: 5px;
  position: relative;
}
.imgRight .ttlA {
  margin-left: -25px;
}
.ttlB {
  font-size: 6rem;
  letter-spacing: 5px;
  line-height: 1.4;
  text-align: center;
  position: relative;
  top: -50px;
}
.ttlB:after {
  content: "";
  background: #005B31;
  display: block;
  width: 180px;
  height: 5px;
  margin: 0 auto;
}
.ttlC {
  font-size: 3rem;
  letter-spacing: 5px;
  line-height: 2;
  text-align: center;
  position: relative;
  font-weight: bold;
}
.ttlC:after {
  content: "";
  background: #005B31;
  display: block;
  width: 120px;
  height: 5px;
  margin: 0 auto 50px;
}
.subTtlA {
  font-size: 2.5rem;
  font-weight: bold;
  margin-bottom: 10px;
}
.subTtlB {
  font-size: 2.5rem;
  font-weight: bold;
  margin-bottom: 10px;
}
.subTtlB:after {
  content: "";
  background: #005B31;
  display: block;
  width: 120px;
  height: 5px;
  margin: 10px 0 20px 0;
}
.oneModP {
  text-align: center;
  border-bottom: 1px solid #ddd;
  padding: 30px 0;
}
.modPCenter {
  text-align: center;
  margin-bottom: 50px;
}
/*.btn*/
.btn a, .btn a::after {
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s;
}
.btn a {
  border: 1px solid #fff;
  color: #fff;
  display: block;
  position: relative;
  width: 200px;
  height: 50px;
  text-align: center;
  line-height: 50px;
}
.btn a:hover {
  background: #005B31;
  border: 1px solid #005B31;
}
.btn.blue a {
  border: 1px solid #005B31;
  color: #005B31;
}
.btn.blue a:hover {
  color: #fff;
}
/***** topMain *******/
/*header*/
@media screen and (min-width: 771px) {
  #change {
    display: none !important;
  }
}
#topmainVisual {
  position: relative;
  overflow: hidden;
}
.siteHeader {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  width: 100%;
  min-width: 1400px;
  padding: 50px;
  visibility: hidden;
}
.siteHeaderInner {
  position: relative;
  display: block;
}
.siteHeader .logo a {
  font-size: 1rem;
  color: #fff;
  line-height: 19px;
  height: 19px;
  display: table;
}
.siteHeader .logo a img {
  display: table-cell;
  padding-right: 10px;
}
.siteHeader .logo a span {
  display: table-cell;
  vertical-align: middle;
  border-left: 1px solid #fff;
  padding-left: 10px;
}
.mainNav {
  position: relative;
  right: 0px;
}
.mainNav ul {
  display: table-cell;
  padding-right: 20px;
}
.mainNav ul li {
  display: table-cell;
  padding-right: 15px;
}
.mainNav ul li a {
  color: #fff;
  padding-bottom: 15px;
}
nav ul li a, nav ul li a:after, nav ul li a:before {
  transition: all .2s;
}
nav.stroke ul li a {
  position: relative;
}
nav.stroke ul li a:after {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 0%;
  content: '.';
  color: transparent;
  background: #fff;
  height: 1px;
}
nav.stroke ul li a:hover:after {
  width: 100%;
}
.siteHeader .btn {
  display: table-cell;
}
.Opening {
  position: relative;
  background-color: #FFF;
  overflow: hidden;
}
.Opening ul li {
  position: relative;
  overflow: hidden;
  width: 100%;
  text-align: center;
}
.Opening ul li span img.Opening__img {
  max-width: inherit;
  width: 100%;
  height: auto;
}
.pageMainFullImg {
  width: 100%;
  position: relative;
}
.topMainTxt {
  position: absolute;
  z-index: 1;
  color: #fff;
  width: 100%;
  height: 100%;
}
.topMainTxt .lead {
  text-align: center;
  line-height: 1.5;
}
.topMainTxt .lead .en {
  font-size: 6rem;
  letter-spacing: 7px;
  /*   text-transform:uppercase; */
}
.topMainTxt .lead .jpTxt {
  display: block;
  font-size: 2.6rem;
  font-weight: bold;
}
.mainNews {
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
  width: 800px;
  margin: 40px auto 0 auto;
}
.mainNews a {
  display: block;
  color: #fff;
  padding: 20px 0;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s;
}
.mainNews a:hover {
  background: rgba(255, 255, 255, 0.3);
}
.mainNews span {
  display: table-cell;
  vertical-align: middle;
}
.mainNews time {
  font-size: 1.6rem;
  padding-right: 20px;
}
.mainNews .category {
  font-size: 1.2rem;
  border: 1px solid #fff;
  padding: 5px 10px;
}
.mainNews .ttl {
  font-size: 1.4rem;
  padding-left: 20px;
  color: #fff;
}
.scrollBt {
  position: absolute;
  width: 100%;
  text-align: center;
  z-index: 2;
  bottom: 30px;
  left: 0%;
}
.scrollBt a:hover img {
  opacity: 0.6;
}
.flow.mb100, .about.mb100 {
  margin-bottom: 120px;
}
.imgLeft, .imgRight {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-end;
  -ms-flex-align: end;
  align-items: flex-end;
}
.home .imgLeft, .home .imgRight {
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
}
.imgLeft .image, .imgRight .image {
  width: 60%;
  min-height: 0%;
}
.imgRight .txtBox {
  order: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: flex-start;
  -ms-flex-pack: flex-start;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
}
.imgRight .image {
  order: 2;
}
.txtBox {
  width: 40%;
  min-height: 0%;
  vertical-align: middle;
}
.txtBox .modP {
  margin-bottom: 20px;
}
.txtBox .txtBoxInner {
  position: relative;
  padding-left: 25px;
  padding-right: 25px;
}
.pages .txtBox .txtBoxInner {
  padding: 50px;
  background: #fff;
  width: calc(100% + 100px);
}
.pages.imgLeft .txtBox .txtBoxInner {
  left: -50px;
}
.pages.imgRight .txtBox .txtBoxInner {
  right: -50px;
  margin-left: -100px;
}
.sentenceBox {
  width: 800px;
  margin: -50px auto 100px auto;
}
.sentenceBox:before {
  content: "";
  background: #005B31;
  display: block;
  width: 120px;
  height: 5px;
  margin: 10px 0 20px 0;
}
.sentenceBox p:nth-child(n+1) {
  margin-top: 30px;
}
/***** imgFourColumn *******/
.imgCenter {
  padding-bottom: 50px;
}
.work .cntInner {
  padding-left: calc(50px - 1.5vw);
  padding-right: calc(50px - 1.5vw);
}
.workList .imgFourColumn {
  padding: 0 1.5%;
}
.imgFourColumn {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: flex-start;
  text-align: center;
  gap: 25px 0;
}
.imgFourColumn.slick-slider {
  justify-content: center;
}
.imgFourColumn li, .imgFourColumn .slick-slide {
  width: 25%;
  margin-right: 0;
  padding: 0 1.5%;
}
.imgFourColumn li:nth-child(4n), .imgFourColumn li:last-child, .imgFourColumn .slick-slide:last-child {
  margin-right: 0;
}
.imgFourColumn .slick-slide a:hover img {
  opacity: 0.6;
}
.imgFourColumn .ico_dot {
  position: relative;
  top: -30px;
}
.imgFourColumn .ico_dot img {
  margin-left: auto;
  margin-right: auto;
}
.imgFourColumn .ttl {
  font-size: 1.5rem;
  font-weight: bold;
  margin-top: -20px;
  margin-bottom: 20px;
}
.imgFourColumn .txt {
  font-size: 1.4rem;
}
.imgCenter .btn a {
  margin: 50px auto 0;
}
/***** imgThreeColumn *******/
.imgThreeColumn {
  display: flex;
  flex-wrap: wrap;
  gap: 20px 3%;
  max-width: 1000px;
  width: 100%;
  margin: 0 auto;
}
.imgThreeColumn li {
  width: 31.333%;
  text-align: left;
}
.imgThreeColumn li .imgWrap {
  position: relative;
  display: block;
}

.imgThreeColumn li a:hover img {
  opacity: 0.6;
}
.imgThreeColumn .category {
  background: #005B31;
  color: #fff;
  font-size: 1.2rem;
  display: block;
  font-style: normal;
  padding: 5px;
  display: inline-block;
  position: absolute;
  left: 0;
  bottom: 0;
}
.imgThreeColumn .ttl {
  font-size: 1.5rem;
}
.imgThreeColumn .date {
  font-size: 1.5rem;
}
/*****.siteFooter*******/
.siteFooterOuterA {
  background: #f5f5f5;
  padding: 50px 0;
}
.contactUl {
  display: table;
  width: 100%;
  border: 1px solid #ddd;
}
.contactUl li {
  display: table-cell;
  width: 50%;
  text-align: center;
  vertical-align: middle;
  background: #fff;
  padding: 30px 0;
}
.contactUl li:nth-child(1) {
  border-right: 1px solid #ddd;
}
.contactUl .btn a {
  margin: 0 auto;
}
.contactUl .heading {
  font-size: 1.5rem;
  margin-bottom: 10px;
}
.contactUl .tel {
  font-size: 3rem;
  line-height: 1;
}
.footInfo {
  padding-top: 50px;
  text-align: center;
}
.footInfo .footLogo {
  margin-bottom: 20px;
}
.footInfo .address {
  margin-bottom: 20px;
  font-size: 1.3rem;
}
.footInfo .footNav {
  font-size: 0;
  border-bottom: 1px solid #ddd;
  border-top: 1px solid #ddd;
  padding: 15px 0;
}
.footInfo .footNav li {
  display: inline-block;
  font-size: 1.3rem;
  border-right: 1px solid #151515;
  padding-right: 10px;
  margin-right: 10px;
  line-height: 1;
}
.footInfo .footNav li:last-child {
  border: none;
  margin-right: 0;
}
.footInfo .footNav li a:hover {
  text-decoration: underline;
}
.siteFooterOuterB {
  background: #151515;
  text-align: center;
  padding: 30px 0;
}
.footSns {
  font-size: 0;
}
.footSns li {
  display: inline-block;
  margin-right: 20px;
  margin-bottom: 20px;
}
.footSns li:last-child {
  margin-right: 0;
}
.siteFooterOuterB address {
  color: #fff;
  font-size: 1.2rem;
}
/*****pageMV*******/
.pageVisual {
  position: relative;
  width: 100%;
  height: 400px;
}
/*****form*******/
.formWrap {
  background: #f5f5f5;
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
  padding: 50px 0;
}
.formWrap dl {
  width: 600px;
  margin: 0 auto;
}
.formWrap dt {
  font-size: 1.6rem;
  font-weight: bold;
}
.formWrap dd {
  margin: 15px 0 30px 0;
  word-break: break-all;
}
.formWrap .required {
  background: #cc391f;
  font-size: 1.2rem;
  color: #fff;
  font-weight: normal;
  height: 25px;
  line-height: 25px;
  display: inline-block;
  padding: 0 15px;
  margin-right: 10px;
  position: relative;
  top: -2px;
}
.formWrap .any {
  background: #999;
  font-size: 1.2rem;
  color: #fff;
  font-weight: normal;
  height: 25px;
  line-height: 25px;
  display: inline-block;
  padding: 0 15px;
  margin-right: 10px;
  position: relative;
  top: -2px;
}
.formWrap textarea,
.formWrap select,
.formWrap input[type="tel"],
.formWrap input[type="date"],
.formWrap input[type="email"],
.formWrap input[type="text"] {
  border: 1px solid #ddd;
  background: #fff;
  height: 40px;
  padding-left: 15px;
  width: 100%;
  color: #151515;
}
.formWrap textarea {
  height: 15em;
}
.formWrap .formBtn input[type="submit"] {
  display: block;
  position: relative;
  width: 200px;
  height: 50px;
  text-align: center;
  line-height: 50px;
  border: 1px solid #005B31;
  color: #005B31;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s;
  cursor: pointer;
  margin: 0 auto;
}
@media screen and (max-width: 770px) {
  .formWrap .formBtn input[type="submit"] {
    width:100%;
  }
}
.formWrap .formBtn input[type="submit"]:hover {
  background: #005B31;
  color: #fff;
}
/*****work_detail*******/
.workSIngleMeta figcaption {
  text-align: center;
  padding: 0 0 30px 0;
  border-bottom: 1px solid #ddd;
  margin-bottom: 50px;
}
.workSIngleMeta .category {
  background: #005B31;
  color: #fff;
  font-size: 1.2rem;
  font-style: normal;
  height: 50px;
  line-height: 50px;
  padding: 0 20px;
  display: inline-block;
  position: relative;
  top: -30px;
  font-weight: bold;
}
.workSIngleMeta .ttl {
  font-size: 3rem;
  margin-bottom: 20px;
  font-weight: bold;
  line-height: 1.3;
}
.workSingle .btn a {
  margin: 30px auto 100px auto;
}
/*****menu_detail*******/
.menu_detail .btn a {
  margin: 30px auto 100px auto;
}
/*****blogSingle*******/
.singleContent img, .blogSingle img {
  max-width: 100%;
  height: auto;
  margin-bottom: 30px;
}
.singleContent p img, .blogSingle p img {
  margin-bottom: 0;
}
.singleContent p {
  margin-bottom: 30px;
}
.blogSingle .btn a {
  margin: 30px auto 50px auto;
}
.meta {
  margin-bottom: 20px;
}
.meta .category {
  background: #005B31;
  color: #fff;
  font-size: 1.5rem;
  display: inline-block;
  height: 40px;
  line-height: 40px;
  text-align: center;
  padding: 0 10px;
  margin-right: 15px;
}
.articleTtl {
  font-size: 3rem;
  font-weight: bold;
  border-bottom: 2px solid #005B31;
  padding-bottom: 10px;
  margin-bottom: 30px;
}
/*****menu_detail*******/
.menu_detail .image img {
  max-width: 100%;
  height: auto;
  margin-bottom: 40px;
}
.workTtl {
  font-size: 3rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 15px;
}
.workTtl span {
  font-size: 1.8rem;
}
.upperBox {
  text-align: center;
  margin: 2em auto 50px auto;
}
.upperBox .upperTitle {
  font-size: 3rem;
  font-weight: bold;
}
.upperBox dl {}
.upperBox dt {
  font-size: 2.2rem;
  color: #333333;
  font-weight: bold;
  margin: 1em auto 0 auto;
}
.upperBox .content {
  text-align: left;
}
.recBox {
  max-width: 800px;
  text-align: center;
  background: #f5f5f5;
  padding: 30px 0;
  border-top: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
  margin: 2em auto 50px auto;
}
.recBox .recTitle {
  font-size: 2.4rem;
  color: #005B31;
  font-weight: bold;
}
.recBox dl {}
.recBox dt {
  font-size: 2.2rem;
  color: #333333;
  font-weight: bold;
  margin: 1em auto 0.5em auto;
}
.recBox .content {
  text-align: left;
  padding: 0 30px;
}
.twoImgList {
  font-size: 0;
}
.twoImgList li {
  width: 48%;
  margin-right: 4%;
  vertical-align: top;
  display: inline-block;
  margin-bottom: 4%;
}
.twoImgList li figure a {
  display: block;
  width: 100%;
  padding-top: 66%;
  position: relative;
}
.twoImgList li figure a img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  object-fit: cover;
  font-family: 'object-fit: cover;'
}
.twoImgList li a:hover img {
  opacity: 0.7;
}
.twoImgList li:nth-child(2n) {
  margin-right: 0;
}
.twoImgList li figcaption {
  font-size: 1.6rem;
  border: 1px solid #ddd;
  text-align: center;
  padding: 20px 0;
}
/*****categoryDl*******/
.categoryDl {
  max-width: 1000px;
  width: 100%;
  display: table;
  margin: 0 auto 50px auto;
}
.categoryDl dt {
  background: #005B31;
  color: #fff;
  display: table-cell;
  vertical-align: middle;
  width: 200px;
  text-align: center;
  font-size: 1.8rem;
}
.categoryDl dd {
  display: table-cell;
  border-right: 2px solid #f5f5f5;
  border-top: 2px solid #f5f5f5;
  border-bottom: 2px solid #f5f5f5;
  vertical-align: middle;
  padding: 20px;
}
.categoryDl dd li {
  display: inline-block;
  padding-right: 10px;
  margin-right: 10px;
  border-right: 1px solid #ddd;
}
.categoryDl dd li:last-child {
  margin-right: 0;
  padding-right: 0;
  border-right: none;
}
.categoryDl dd a:hover {
  text-decoration: underline;
}
/*****workList*******/
.workList .bgGlay {
  padding: 50px 0;
}
.workList .bgGlay .imgFourColumn li:nth-child(n+5) {
  margin-top: 50px;
}
/*****voice*******/
.voiceBox {
  font-size: 0;
  margin-top: 80px;
}
.voiceBox li {
  font-size: 1.4rem;
  background: #f5f5f5;
  padding: 20px;
  display: inline-block;
  width: 48%;
  vertical-align: top;
  margin-bottom: 6%;
}
.voiceBox li:only-child {
  margin-right: auto;
  margin-left: auto;
}
.voiceBox .name {
  background: #005B31;
  color: #fff;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  padding: 10px;
  position: relative;
  top: -40px;
}
.voiceBox .txt {
  margin-top: -20px;
}
/*****dlA*******/
.dlA {
  width: 800px;
  margin: 0 auto 50px auto;
}
.dlA dt {
  font-size: 1.8rem;
  font-weight: bold;
  border-bottom: 1px solid #ddd;
  padding-bottom: 10px;
  margin-bottom: 15px;
}
.dlA li {
  margin-bottom: 15px;
}
.dlA li li {
  margin: 15px 0 15px 1.5em;
}
.dlA .num {
  font-style: normal;
  font-weight: bold;
  display: table-cell;
  padding-right: 10px;
  white-space: nowrap;
}
.dlA .content {
  display: table-cell;
}
.dlA .one {
  margin-bottom: 15px;
  display: block;
  word-break: break-all;
}
/*****c-breadcrumbs*******/
.c-breadcrumbs {
  background: #f5f5f5;
  font-size: 1.2rem;
  padding: 20px 50px;
  margin-bottom: 100px;
  position: relative;
  z-index: 1;
  text-align: left;
}
@media screen and (max-width: 770px) {
  .c-breadcrumbs {
    margin-bottom: 50px;
    padding: 10px 5%;
    font-size: 1rem;
  }
}
.c-breadcrumbs__list {
  overflow-x: auto;
  max-width: 100%;
  padding: 0;
  white-space: nowrap;
  display: flex;
  justify-content: flex-start;
}
.c-breadcrumbs__list-item {
}
.c-breadcrumbs__list-item:not(:last-child)::after {
  display: inline-block;
  margin: 0 5px 0 3px;
  content: "//";
}
.c-breadcrumbs__list-item-link {
  display: inline-block;
}
@media screen and (min-width: 1024.1px) {
  .c-breadcrumbs__list-item-link:hover {
    text-decoration: underline;
  }
}
.c-breadcrumbs__list-item-link.-current {
  pointer-events: none;
  cursor: text;
}
@media screen and (min-width: 1024.1px) {
  .c-breadcrumbs__list-item-link.-current:hover {
    text-decoration: none;
  }
}
/*****reasonOl*******/
.reasonOl {
  margin-top: 80px;
}
.reasonOl li {
  border: 4px solid #005B31;
  margin-bottom: 100px;
}
.reasonOl li .wrap {
  display: table;
  width: 100%;
  max-width: 1000px;
  padding: 30px;
}
.reasonOl li .image {
  display: table-cell;
  width: 450px;
}
.reasonOl li .txt {
  display: table-cell;
  vertical-align: middle;
  padding-left: 30px;
}
.reasonOl li .ttl {
  background: #005B31;
  color: #fff;
  font-size: 2.4rem;
  font-weight: bold;
  text-align: center;
  display: block;
  width: 600px;
  padding: 20px;
  margin: -40px auto 0;
}
/*****tbl*******/
.tblA {
  font-size: 0;
  width: 800px;
  margin: 0 auto 100px;
}
.tblA dt {
  display: inline-block;
  font-size: 1.5rem;
  font-weight: bold;
  width: 200px;
  border-top: 1px solid #ddd;
  padding: 15px 0;
  vertical-align: top;
  margin-right: 50px;
}
.tblA dt:last-of-type {
  border-bottom: 1px solid #ddd;
}
.tblA dd {
  display: inline-block;
  font-size: 1.5rem;
  width: 550px;
  border-top: 1px solid #ddd;
  padding: 15px 0;
  vertical-align: top;
}
.tblA dd:last-of-type {
  border-bottom: 1px solid #ddd;
}
/*****map*******/
.ggmapSize {
  width: 800px;
  margin: 0 auto;
}
.ggmap {
  position: relative;
  padding-bottom: 56.25%;
  padding-top: 30px;
  height: 0;
  overflow: hidden;
}
.ggmap iframe, .ggmap object, .ggmap embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.access .oneModP {
  width: 800px;
  margin: 0 auto;
}
/*****staff flow*******/
.staffBox {
  margin-bottom: 50px;
}
.staffBox figure {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: center;
  justify-content: center;
  background: #f5f5f5;
}
.staffBox figure .image {
  width: 45%;
  vertical-align: top;
  line-height: 0;
}
.staffBox figure figcaption {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  background: #f5f5f5;
  vertical-align: middle;
  padding-left: 30px;
  padding-right: 30px;
}
.staffBox figure figcaption .name {
  font-size: 2.4rem;
  font-weight: bold;
  color: #005B31;
  margin-bottom: 10px;
}
.step {
  background: #005B31;
  border-radius: 20px;
  display: inline-block;
  color: #fff;
  font-style: normal;
  font-size: 1.8rem;
  padding: 5px 15px;
  position: relative;
  top: -5px;
  margin-right: 10px;
  white-space: nowrap;
}
.flowArrow {
  text-align: center;
  margin-bottom: 50px;
}
.areaTbl {
  width: 800px;
  margin: 0 auto;
  border: 2px solid #f5f5f5;
  padding: 30px 0;
}
.areaTbl.typeB {
  margin: 0 auto 50px auto;
}
.areaTbl dt {
  display: table-cell;
  text-align: center;
  vertical-align: middle;
  width: 200px;
}
.areaTbl dt .en {
  display: block;
  color: #005B31;
  font-size: 4rem;
  line-height: 1.4;
}
.areaTbl.typeB dt .en {
  font-size: 2.6rem;
}
.areaTbl dd {
  display: table-cell;
  vertical-align: middle;
  padding-right: 20px;
}
.areaTbl dd strong {
  color: #005B31;
}
.areaTbl.typeB dd strong {
  display: block;
}
.faqDl dt {
  display: table;
}
.faqDl dt img {
  display: table-cell;
}
.faqDl dt span {
  color: #005B31;
  font-weight: bold;
  font-size: 2rem;
  display: table-cell;
  vertical-align: middle;
  padding-left: 10px;
}
.faqDl dd {
  margin-top: 20px;
  background: #f5f5f5;
  padding: 30px;
}
.faqDl {
  margin-bottom: 50px;
}
.faqDl:last-of-type {
  margin-bottom: 0;
}
/********menu ブレイクポイント***************/
@media screen and (min-width:1401px) {
  .siteHeaderInner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
  }
}
@media screen and (max-width: 1400px) {
  /*header*/
  .siteHeader {
    min-width: 100%;
  }
  .siteHeader .logo {
    display: table;
    margin: 0 auto;
  }
  .siteHeader .logo a span {
    display: none;
  }
  .siteHeader .logo a img {
    padding-right: 0;
  }
  .mainNav.pc {
    position: static;
    right: auto;
    top: auto;
    margin-top: 20px;
    margin-left: auto;
    margin-right: auto;
    display: table;
  }
  .mainNav.pc ul {
    padding-right: 0;
  }
  .siteHeader .btn {
    display: table-cell;
    position: absolute;
    right: -30px;
    top: -30px;
  }
  .siteHeader .btn a {
    width: 140px;
    background: #005B31;
    border: none;
    font-size: 1.3rem;
  }
}
@media screen and (max-width: 1024px) {
  /*imgThreeColumn*/
  .imgThreeColumn {
    width: 100%;
  }
  /*about*/
  .imgRight .image {
    order: 1;
  }
  .imgRight .txtBox {
    order: 2;
  }
  .imgRight .ttlA {
    margin-left: -50px;
  }
  .pages.imgLeft, .pages.imgRight {
    -webkit-align-items: flex-start;
    -ms-flex-align: flex-start;
    align-items: flex-start;
  }
  .pages .txtBox .txtBoxInner {
    padding: 0 0 0 50px;
  }
  .pages.imgLeft .txtBox .txtBoxInner {
    width: 100%;
    left: auto;
  }
  .pages.imgRight .txtBox .txtBoxInner {
    width: 100%;
    right: auto;
    margin-left: auto;
  }
  .sentenceBox {
    width: 89%;
  }
}
/********sp***************/
@media screen and (max-width: 770px) {
  .siteHeaderInner {
    min-height: 70px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
  }
  /*common*/
  body {
    font-size: 1.3rem;
  }
  .pc {
    display: none !important;
  }
  .sp {
    display: block !important;
  }
  .cntInner {
    padding: 0 5%;
  }
  .inner {
    width: 90%;
    max-width: none;
  }
  .pageTop {
    position: fixed;
    right: 0px;
    bottom: 0px;
  }
  .pageTop a {
    background: rgba(21, 21, 21, 0.9);
    width: 50px;
    height: 50px;
    display: block;
    text-align: center;
    padding-top: 13px;
  }
  /*margin*/
  .flow.mb100, .about.mb100 {
    margin-bottom: 50px;
  }
  .mb100 {
    margin-bottom: 50px;
  }
  /*header*/
  #change {
    display: none;
    width: 100%;
    height: 50px;
    position: fixed;
    top: 0;
    left: 0;
    background: rgba(0, 91, 49, 0.6);
    z-index: 99;
  }
  .changeInner {
    position: relative;
    height: inherit;
    padding: 0 0 0 5%;
  }
  .changeInner .logo {
    margin: 0;
  }
  .changeInner .hum a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    width: 50px;
    height: 50px;
  }
  .siteHeader {
    min-width: 100%;
    padding: 0 0 0 5%;
  }
  .logo {
    line-height: 1;
    margin-top: -5px;
  }
  .siteHeader .logo {
    width: calc(100% - 110px);
    margin: 0;
  }
  .mainNav .hum a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    width: 60px;
    height: 70px;
  }
  .mainNav .phone {
    position: absolute;
    top: 0;
    right: 60px;
  }
  .mainNav .phone a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    width: 50px;
    height: 70px;
  }
  #change .phone a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    width: 40px;
    height: 50px;
  }
  #change .phone img {
    width: 26px;
  }
  .topMainTxt, .topMainTxt>div {
    width: 100%;
  }
  .topMainTxt .lead .en {
    font-size: 3.6rem;
    letter-spacing: 2px;
    display: block;
    line-height: 1.3;
  }
  .topMainTxt .lead .jpTxt {
    font-size: 1.6rem;
    margin-top: 0.5em;
  }
  .mainNews a {
    padding: 10px 0;
  }
  .mainNews {
    width: 90%;
  }
  .mainNews .ttl {
    display: block;
    padding-left: 0;
    margin-top: 10px;
  }
  .mainNews .category {
    padding: 2px 5px;
  }
  .mainNews time {
    font-size: 1.4rem;
    padding-right: 10px;
  }
  .scrollBt {
    bottom: 10px;
  }
  /*hamburger*/
  .closeBT {
    width: 60px;
    height: 60px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 999;
  }
  .humNavi {
    padding-top: 10%;
  }
  .humNavi li {}
  .humNavi li a {
    display: block;
    padding: 10px 0;
  }
  #hum {
    display: none;
  }
  .modaal-inline.modaal-fullscreen .modaal-container {
    background: rgba(255, 255, 255, 0.7);
  }
  /*btn*/
  .btn a {
    width: 100%;
  }
  /*ttl*/
  .ttlA {
    font-size: 4rem;
    letter-spacing: 3px;
    margin-left: 0;
    margin-top: -30px;
    margin-bottom: 20px;
  }
  .imgRight .ttlA {
    margin-left: 0;
  }
  .ttlB:after, .ttlA:after {
    width: 100px;
    height: 5px;
  }
  .ttlB {
    font-size: 4rem;
    letter-spacing: 3px;
    top: -30px;
  }
  .ttlC {
    font-size: 2rem;
    letter-spacing: 0px;
  }
  .ttlC:after {
    width: 80px;
    height: 3px;
    margin: 0 auto 30px;
  }
  .subTtlB:after {
    width: 80px;
    height: 3px;
  }
  .subTtlA {
    font-size: 1.8rem;
  }
  .subTtlB {
    font-size: 1.6rem;
  }
  .imgLeft, .imgRight {
    -ms-flex-direction: column;
    flex-direction: column;
  }
  .imgLeft .image, .imgRight .image {
    width: 100%;
    display: block;
  }
  .imgLeft .txtBox, .imgRight .txtBox {
    width: 100%;
    display: block;
    position: relative;
    z-index: 5;
  }
  .txtBox .txtBoxInner {
    position: relative;
    left: auto;
    right: auto;
    width: 100%;
    padding: 5%;
  }
  .home .txtBox .txtBoxInner {
    padding-top: 0;
  }
  .pages.imgLeft .txtBox .txtBoxInner, .pages.imgRight .txtBox .txtBoxInner {
    padding: 5%;
  }
  /*imgFourColumn*/
  .work .cntInner {
    padding: 0 5%;
  }
  .workList .imgFourColumn, .imgFourColumn {
    padding: 0 5%;
  }
  .imgFourColumn {
    gap: 0;
  }
  .imgFourColumn .slick-slide, .imgFourColumn li {
    width: 100%;
    margin-right: 0;
    padding: 0;
  }
  .imgFourColumn .ttl {
    font-size: 1.4rem;
    margin-bottom: 10px;
  }
  .imgFourColumn .txt {
    font-size: 1.2rem;
  }
  .imgCenter .btn a {
    margin: 30px auto 0;
  }
  /*threeCnt*/
  .threeCnt .cntInner {
    padding: 0;
  }
  /*imgThreeColumn*/
  .imgThreeColumn {
    width: 100%;
  }
  .imgThreeColumn li {
    width: 100%;
  }
  .imgThreeColumn li .imgWrap {
    display: table-cell;
    width: 40%;
  }
  .imgThreeColumn li figcaption {
    display: table-cell;
    vertical-align: top;
    padding-left: 10px;
    padding-right: 10px;
  }
  .imgThreeColumn .category.sp {
    position: inherit;
    display: inline-block !important;
    font-size: 1rem;
    margin-bottom: 10px;
  }
  .imgThreeColumn .date {
    font-size: 1.2rem;
  }
  .imgThreeColumn .ttl {
    font-size: 1.3rem;
  }
  /*footer*/
  .siteFooterOuterA .inner {
    width: 100%;
  }
  .siteFooterOuterA {
    padding: 30px 0 0;
  }
  .contactUl {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
  }
  .contactUl li {
    display: block;
    width: 100%;
    padding: 15px 0;
  }
  .contactUl li:nth-child(1) {
    border-right: none;
    border-bottom: 1px solid #ddd;
  }
  .contactUl .heading {
    font-size: 1.4rem;
  }
  .contactUl li .btn a {
    width: 90%;
  }
  .contactUl .tel {
    font-size: 2.4rem;
  }
  .footInfo .address {
    font-size: 1.2rem;
    padding: 0 5%;
  }
  .footInfo .footLogo {
    margin-bottom: 10px;
  }
  .footInfo {
    padding-top: 30px;
  }
  .footInfo .footNav {
    text-align: left;
    border: none;
    padding: 0;
    border-top: 1px solid #ddd;
  }
  .footInfo .footNav li {
    width: 50%;
    margin-right: 0;
    padding: 0;
    font-size: 1.1rem;
    text-align: center;
    border-right: none;
    border-bottom: 1px solid #ddd;
  }
  .footInfo .footNav li a {
    height: 40px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .footInfo .footNav li:nth-child(odd) {
    border-right: 1px solid #ddd;
  }
  .footInfo .footNav li:last-child {
    border-bottom: 1px solid #ddd;
  }
  .siteFooterOuterB address {
    font-size: 1rem;
  }
  .siteFooterOuterB {
    padding: 20px 0;
  }
  /*pageMv*/
  .pageVisual {
    height: 50vh;
  }
  /*bred*/
  .bred {
    margin-bottom: 50px;
    padding: 10px 0;
    font-size: 1rem;
  }
  /*about*/
  .pages.imgLeft .txtBox {
    display: block;
    left: 0;
    padding-right: 0;
  }
  .txtBoxInner {
    padding: 5%;
  }
  .sentenceBox {
    width: 90%;
    margin: -30px auto 50px auto;
  }
  .sentenceBox:before {
    width: 80px;
    height: 3px;
  }
  .pages.imgRight .txtBox {
    display: block;
    right: 0;
    padding-right: 0;
  }
  .reasonOl {
    margin-top: 0px;
  }
  .reasonOl li .ttl {
    width: 100%;
    font-size: 1.3rem;
    padding: 6px 0 10px 0;
    margin: 0;
  }
  .reasonOl li .wrap {
    width: 100%;
    display: block;
    padding: 10px;
  }
  .reasonOl li .image {
    display: block;
    width: 100%;
  }
  .reasonOl li .txt {
    display: block;
    padding: 5%;
  }
  .reasonOl li {
    margin-bottom: 30px;
  }
  /*map*/
  .access .oneModP, .ggmapSize {
    width: 100%;
  }
  .oneModP {
    padding: 15px 0;
  }
  /*tbl*/
  .tblA {
    width: 100%;
    margin: 0 auto 50px;
  }
  .tblA dt {
    display: block;
    width: 100%;
    margin-right: 0;
    font-size: 1.3rem;
    border-top: none;
    padding: 10px 0;
  }
  .tblA dd {
    display: block;
    width: 100%;
    font-size: 1.4rem;
  }
  .tblA dt:last-of-type, .tblA dd:last-of-type {
    border-bottom: none;
  }
  /*staffbox*/
  .staff {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
  }
  .staffBox figure {
    display: block;
    background-color: transparent;
  }
  .staffBox figure figcaption, .staffBox figure .image {
    display: block;
    width: 100%;
  }
  .staffBox figure figcaption {
    padding: 20px;
  }
  .staffBox figure figcaption .name {
    margin-bottom: 0;
    font-size: 1.8rem;
  }
  /*workList*/
  .workList {
    padding: 0 5%;
  }
  .modPCenter {
    margin-bottom: 30px;
    text-align: left;
  }
  .workList .bgGlay {
    padding: 30px 0;
  }
  .workList .imgFourColumn li {
    margin-bottom: 15%;
  }
  .workList .imgFourColumn li:last-child {
    margin-bottom: 0;
  }
  .workList .bgGlay .imgFourColumn li:nth-child(n+5) {
    margin-top: 0;
  }
  /*.categoryDl*/
  .categoryDl {
    width: 100%;
    word-break: keep-all;
    margin: 0 auto 30px auto;
  }
  .categoryDl dt {
    width: 100%;
    display: block;
    font-size: 1.5rem;
  }
  .categoryDl dd li {
    padding-right: 5px;
    margin-right: 5px;
  }
  .categoryDl dd {
    display: block;
    border-top: none;
    border-left: 2px solid #f5f5f5;
    padding: 10px;
    text-align: center;
  }
  /*workdetail*/
  .workSIngleMeta .category {
    height: 30px;
    line-height: 30px;
    font-size: 1rem;
    top: -25px;
  }
  .workSIngleMeta .ttl {
    font-size: 2rem;
  }
  .workSIngleMeta figcaption {
    margin-bottom: 30px;
  }
  .areaTbl {
    width: 100%;
    padding: 15px;
  }
  .areaTbl.typeB {
    margin: 0 auto 30px auto;
  }
  .areaTbl dt {
    width: 100%;
    display: block;
    margin-bottom: 15px;
  }
  .areaTbl dd {
    padding-right: 0;
  }
  .areaTbl.typeB dt .en {
    font-size: 2rem;
  }
  .workSingle .btn a {
    margin: 30px auto 50px auto;
  }
  /*flow*/
  .flow .staffBox {
    margin-bottom: 20px;
  }
  .flowArrow {
    width: 25px;
    margin: 0 auto 20px auto;
  }
  .flowArrow img {
    width: 100%;
    height: auto;
  }
  .step {
    display: block;
    text-align: center;
    font-size: 1.4rem;
    margin-right: 0;
    margin-bottom: 5px;
  }
  .flow .staffBox figure figcaption .name {
    font-size: 1.6rem;
    margin-bottom: 10px;
  }
  .areaTbl dt .en {
    font-size: 3rem;
  }
  .faqDl {
    margin-bottom: 30px;
  }
  .faqDl dt span {
    font-size: 1.6rem;
  }
  .faqDl dd {
    font-size: 1.2rem;
    padding: 15px;
  }
  /*menu_detail*/
  .menu_detail .image img {
    margin-bottom: 20px;
  }
  .workTtl {
    font-size: 2rem;
  }
  .recBox {
    padding: 15px 0;
    margin-bottom: 30px;
  }
  .recBox .recTitle {
    font-size: 2.0rem;
  }
  .recBox dt {
    font-size: 1.8rem;
  }
  .recBox .content {
    padding: 0 15px;
  }
  .twoImgList li figcaption {
    font-size: 1.3rem;
    padding: 10px;
  }
  /*voice*/
  .voiceBox {
    margin-top: 40px;
  }
  .voiceBox li {
    display: block;
    width: 100%;
    margin-right: 0;
    margin-bottom: 50px;
  }
  .voiceBox .name {
    width: 100%;
    font-size: 1.5rem;
  }
  .voiceBox .txt {
    font-size: 1.3rem;
  }
  /*blog*/
  .blogList .categoryDl {
    width: 90%;
  }
  .blogList .imgThreeColumn {
    border-top: 1px solid #ddd;
  }
  .blogList .imgThreeColumn li {
    padding: 5%;
    border-bottom: 1px solid #ddd;
    margin-bottom: 0;
    margin-top: 0 !important;
  }
  .meta {
    margin-bottom: 10px;
  }
  .meta .category {
    font-size: 1.3rem;
    height: 30px;
    line-height: 30px;
    margin-right: 10px;
  }
  .articleTtl {
    font-size: 2rem;
    padding-bottom: 5px;
    margin-bottom: 20px;
  }
  .blogSingle img {
    margin-bottom: 20px;
  }
  .blogSingle .btn a {
    width: 90%;
  }
  /*contact*/
  .formWrap {
    width: 100%;
    padding: 50px 5%;
  }
  .formWrap dl {
    width: 100%;
  }
  .formWrap .formBtn {
    width: 100%;
  }
  .formWrap textarea, .formWrap input[type="email"], .formWrap input[type="text"] {
    border-radius: 0;
    box-shadow: none;
    -webkit-appearance: none;
  }
  /*privacy policy*/
  .dlA {
    width: 100%;
  }
  .dlA dt {
    font-size: 1.5rem;
  }
  .dlA .num {
    width: 12%;
    letter-spacing: 0em;
    font-size: 1.3rem;
  }
}
/*pager*/
.pageLoader {
  position: relative;
  margin-top: 4rem;
  display: none;
}
.pageLoaderSpinner2 {
  position: relative;
  width: 40px;
  height: 40px;
  margin: auto;
}
.pageLoaderSpinner2 .spinner-container {
  position: absolute;
  width: 100%;
  height: 100%;
}
.pageLoader .container1>div, .pageLoader .container2>div, .pageLoader .container3>div {
  background-color: rgba(0, 91, 49, 1);
}
.wow {
  visibility: hidden;
}
/*
  add setting
*/
span.red {
  color: #ff3333;
}
span.blue {
  color: #3333ff;
}
.staffBox figure figcaption .name {
  line-height: 1.2;
  font-size: 20px;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center;
}
.step {
  top: 0;
}
@media screen and (max-width: 770px) {
  .staffBox figure figcaption .name {
    display: block;
  }
  .step {
    top: 0;
    margin-bottom: 10px;
  }
}
/*****************************************************************************
  Flex Box
*****************************************************************************/
/***********
horizon
************/
.f_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
}
.f_item {
  -webkit-flex: 1 0 auto;
  -ms-flex: 1 0 auto;
  flex: 1 0 auto;
}
.f_h_start {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
}
.f_h_center {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: center;
  justify-content: center;
}
.f_h_end {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
}
.f_h_sb {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
.f_h_sa {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-around;
  justify-content: space-around;
}
.f_wrap {
  -webkit-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
/***********
vertical
************/
.f_column {
  -webkit-box-direction: column;
  -webkit-flex-direction: column;
  flex-direction: column;
}
.f_start {
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
}
.f_end {
  -webkit-align-items: flex-end;
  -ms-flex-align: end;
  align-items: flex-end;
}
.f_center {
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
}
.f_baseline {
  -webkit-align-items: baseline;
  -ms-flex-align: baseline;
  align-items: baseline;
}
.f_stretch {
  -webkit-align-items: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
}
/*****************************************************************************
  common media
*****************************************************************************/
.col {
  width: 100%;
}
@media screen and (max-width:770px) {
  /* for Mobile */
  .f_res {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  div.blank {
    height: 25px;
  }
  div.blankx2 {
    height: 50px;
  }
  .pc {
    display: none;
  }
  .order_top {
    -webkit-order: -1;
    -ms-order: -1;
    order: -1;
  }
  .order_1 {
    -webkit-order: 1;
    -ms-order: 1;
    order: 1;
  }
  address {}
}
@media screen and (min-width:771px) {
  /* for Tablet and PC */
  .f_res {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
  }
  div.blank {
    height: 50px;
  }
  div.blankx2 {
    height: 100px;
  }
  div.blankx3 {
    height: 150px;
  }
  .sp {
    display: none;
  }
  .w10 {
    width: 10%;
    min-width: 10%;
  }
  .w15 {
    width: 15%;
    min-width: 15%;
  }
  .w20 {
    width: 20%;
    min-width: 20%;
  }
  .w20s {
    width: calc(20% - 1em);
    min-width: calc(20% - 1em);
  }
  .w20l {
    width: calc(20% + 1em);
    min-width: calc(20% + 1em);
  }
  .w25 {
    width: 25%;
    min-width: 25%;
  }
  .w25s {
    width: calc(25% - 1em);
  }
  .w33 {
    width: calc(100% / 3);
  }
  .w33s {
    width: calc(100% / 3 - 0.5em);
  }
  .w30 {
    width: 30%;
    min-width: 30%;
  }
  .w30s {
    width: calc(30% - 1em);
    min-width: calc(30% - 1em);
  }
  .w30l {
    width: calc(30% + 1em);
  }
  .w35 {
    width: 35%;
    min-width: 35%;
  }
  .w35s {
    width: calc(35% - 1em);
    min-width: calc(35% - 1em);
  }
  .w40 {
    width: 40%;
    min-width: 40%;
  }
  .w40s {
    width: calc(40% - 1em);
    min-width: calc(40% - 1em);
  }
  .w45 {
    width: 45%;
  }
  .w45s {
    width: calc(45% - 1em);
    min-width: calc(45% - 1em);
  }
  .w45l {
    width: calc(45% + 1em);
    min-width: calc(45% + 1em);
  }
  .w60 {
    width: 60%;
    min-width: 60%;
  }
  .w60s {
    width: calc(60% - 1em);
  }
  .w60l {
    width: calc(60% + 1em);
  }
  .w66 {
    width: 66%;
  }
  .w50s {
    width: calc(50% - 1em);
  }
  .w50 {
    width: 50%;
    min-width: 50%;
  }
  .w50l {
    width: calc(50% + 1em);
  }
  .w55 {
    width: calc(55%);
    min-width: calc(55%);
  }
  .w55s {
    width: calc(55% - 1em);
    min-width: calc(55% - 1em);
  }
  .w65 {
    width: 65%;
    min-width: 65%;
  }
  .w65s {
    width: calc(65% - 1em);
    min-width: calc(65% - 1em);
  }
  .w75 {
    width: 75%;
  }
  .w75s {
    width: calc(75% - 1em);
  }
  .w70 {
    width: 70%;
  }
  .w70s {
    width: calc(70% - 1em);
  }
  .w70l {
    width: calc(70% + 1em);
  }
  .w80 {
    width: 80%;
  }
  .w80s {
    width: calc(80% - 1em);
  }
  .w80l {
    width: calc(80% + 1em);
  }
  .w85 {
    width: 85%;
  }
  .w90 {
    width: 90%;
  }
  .w95 {
    width: 95%;
  }
}
.f_cc {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
}
/*blog対策*/
.single-post .blogList .btn.blue {
  margin-top: 5em;
}
.meta time {
  font-size: 1.6rem;
  padding-right: 10px;
}
.meta br {
  display: none;
}
.articleTtl {
  font-size: 3rem;
}
.singleContent, .seoText, .tableContents li a, .blogDetail {
  font-size: 1.6rem;
  font-size: 16px !important;
  line-height: 2 !important;
}
.seoTtl02 {
  margin-top: 4em !important;
}
.seoTtl01 {
  margin-top: 2em !important;
  font-size: 2.8rem !important;
  font-size: 28px !important;
}
@media screen and (max-width:770px) {
  .meta br {
    display: block;
  }
  .articleTtl {
    font-size: 2.6rem;
  }
  .seoTtl01 {
    font-size: 2.4rem !important;
    font-size: 24px !important;
  }
  .seoTtl02 {
    margin-top: 2em !important;
  }
}
/******************************
  Radio Button Layout (Smart Phone)
*******************************/
@media screen and (max-width: 770px) {
  input[type="radio"] {
    position: relative;
    -webkit-appearance: button;
    appearance: button;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 24px;
    height: 24px;
    content: "";
    background-color: #FFFFFF;
    border: 1px solid #999999;
    -webkit-border-radius: 24px;
    border-radius: 24px;
    vertical-align: middle;
    cursor: pointer;
  }
  input[type="radio"]:checked:after {
    display: block;
    position: absolute;
    top: 5px;
    left: 5px;
    content: "";
    width: 12px;
    height: 12px;
    background: #005B31;
    -webkit-border-radius: 12px;
    border-radius: 12px;
  }
  .mw_wp_form .horizontal-item, .horizontal-item {
    margin: 0 10px 0 0 !important;
    display: inline-block;
  }
  .mwform-radio-field.horizontal-item label {
    white-space: nowrap;
    margin: 0 10px 10px 0 !important;
    display: inline-block;
  }
}
/***************
  Logo Size
****************/
@media screen and (max-width: 770px) {
  .siteHeader .logo a img, .changeInner .logo img {
    width: auto;
    height: auto;
    max-width: 200px;
    max-height: 40px;
  }
  .footInfo .footLogo img {
    width: auto;
    height: auto;
    max-width: 200px;
    max-height: 70px;
  }
}
@media screen and (min-width: 771px) {
  .siteHeader .logo a img {
    width: auto;
    height: auto;
    max-width: 200px;
    max-height: 60px;
  }
  .footInfo .footLogo img {
    width: auto;
    height: auto;
    max-width: 300px;
    max-height: 70px;
  }
}
/***** SNS Share Button *****/
.snsWrap {
  display: none;
  padding: 30px;
  background: #f2f2f2;
  margin-top: 40px;
  margin-bottom: 40px;
  text-align: center;
}
.snsWrap .snsWrapTtl {
  font-size: 14px;
  text-align: center;
  line-height: 1.4;
  margin-bottom: 2em;
}
.snsWrap .snsWrapTtl span {
  font-size: 30px;
  font-weight: bold;
}
@media screen and (max-width: 770px) {
  .snsWrap {
    padding: 15px;
    margin-top: 20px;
    margin-bottom: 20px;
  }
  .snsWrap .snsWrapTtl {
    font-size: 13px;
    margin-bottom: 0.6em;
  }
  .snsWrap .snsWrapTtl span {
    font-size: 16px;
  }
}
/***** refusal *****/
.refusal {
  text-align: right;
  margin-top: 30px;
}
.refusal img {
  width: 100%;
  max-width: 300px;
  margin-left: auto;
}
@media screen and (max-width: 770px) {
  .refusal {
    margin-top: 15px;
  }
  .refusal img {
    max-width: 270px;
  }
}
.modoruBtn {
  margin-top: 1em !important;
}
.mw_wp_form_input .c-form-lead__confirm, .mw_wp_form_confirm .c-form-lead {
  display: none;
}
.formWrap select {
  padding: .6em;
  padding-left: 15px;
  width: 100%;
  display: block;
  line-height: 1.3;
  box-sizing: border-box;
  margin: 0;
  border-radius: 0;
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  border: 1px solid #ddd;
  background-color: #ffffff;
  background-image: url('data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23000000%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E');
  background-repeat: no-repeat;
  background-position: right .7em top 50%;
  background-size: .65em auto;
}
.formWrap select::-ms-expand {
  display: none;
}
.formWrap select:focus {
  outline: none;
}
.formWrap select option {
  font-weight: normal;
}
@media screen and (max-width: 770px) {
  .formWrap select {
    padding: .5em;
  }
}
.a2a_kit .a2a_label {
  display: none !important;
}
/***** 20210927 refusal *****/
.refusal {
  line-height: 1;
}
.refusal img {
  width: 100%;
  max-width: 285px;
  max-height: 14px;
  vertical-align: top;
}
@media screen and (max-width: 770px) {
  .refusal img {
    max-width: 285px;
  }
}
/***** 20210111 *****/
.formWrap textarea {
  vertical-align: top;
}
.itemEmpty {
  text-align: center;
}
.areaTbl-text {
  display: block;
}
.areaTbl-text:not(:last-child) {
  margin-bottom: 1em;
}
.tags {
  margin-bottom: 20px;
}
@media screen and (max-width: 770px) {
  .tags {
    margin-bottom: 10px;
  }
}
.tags a {
  color: #005B31;
  text-decoration: underline;
  display: inline-block;
}
.tags .category:not(:last-child) {
  margin-right: 0.5em;
}
@media screen and (min-width: 771px) {
  .tags a:hover {
    text-decoration: none;
  }
}
/***** blogConent *****/
.blogContent a:not([class]) {
  color: #1a0dab;
  text-decoration: underline;
}
@media screen and (min-width: 771px) {
  .blogContent a:not([class]):hover {
    text-decoration: none;
  }
}
.blogContent {
  line-height: 1.8;
}
.blogContent h1 {
  font-size: 2.44em;
}
.blogContent h2 {
  font-size: 1.95em;
}
.blogContent h3 {
  font-size: 1.56em;
}
.blogContent h4 {
  font-size: 1.25em;
}
.blogContent h5 {
  font-size: 1em;
}
.blogContent h6 {
  font-size: 0.8em;
}
.blogContent h1, .blogContent h2, .blogContent h3 {
  line-height: 1.4;
}
.blogContent h4 {
  line-height: 1.5;
}
.blogContent h1 {
  margin-top: 0.67em;
  margin-bottom: 0.67em;
}
.blogContent h2 {
  margin-top: 0.83em;
  margin-bottom: 0.83em;
  border-bottom: 1px solid #ccc;
}
.blogContent h3 {
  margin-top: 1em;
  margin-bottom: 1em;
  padding: 10px;
  background: #eee;
}
.blogContent h4 {
  margin-top: 1.33em;
  margin-bottom: 1.33em;
}
.blogContent h5 {
  margin-top: 1.67em;
  margin-bottom: 1.67em;
}
.blogContent h6 {
  margin-top: 2.33em;
  margin-bottom: 2.33em;
}
.blogContent h1, .blogContent h2, .blogContent h3, .blogContent h4, .blogContent h5, .blogContent h6 {
  color: inherit;
  font-weight: bold;
}
.blogContent p {
  font-size: inherit;
  line-height: inherit;
  margin-top: 28px;
  margin-bottom: 28px;
}
.blogContent ul, .blogContent ol {
  margin-bottom: 28px;
  padding: inherit;
  padding-left: 1.3em;
  margin-left: 1.3em;
}
.blogContent ul ul, .blogContent ul ol, .blogContent ol ul, .blogContent ol ol {
  margin-bottom: 0;
}
.blogContent ul li, .blogContent ol li {
  margin-bottom: initial;
}
.blogContent ul ,
.blogContent ul li {
  list-style-type: disc;
}
.blogContent ol ,
.blogContent ol li {
  list-style-type: decimal;
}
.blogContent ul ul,
.blogContent ol ul ,
.blogContent ul ul li,
.blogContent ol ul li {
  list-style-type: circle;
}
.blogContent #toc_container {
  display: block;
  padding: 15px;
  background: #eee;
  margin-bottom: 30px;
  border: none;
  font-size: 1.6rem;
  ;
}
.blogContent .wp-block-audio {
  margin-left: 0px;
  margin-right: 0px;
}
.blogContent .blogContent .wp-block-audio audio {
  width: 100%;
}
.blogContent blockquote,
.blogContent blockquote.wp-block-quote {
  font-size: 115%;
  line-height: 1.5;
  margin: 32px 0px;
  padding: 12px 18px;
  border-left: 2px solid rgba(0, 0, 0, 0.12);
}
.blogContent .wp-block-quote:not(.is-large):not(.is-style-large) {
  padding-left: 18px;
  border-left: 2px solid rgba(0, 0, 0, 0.12);
}
.blogContent .wp-block-quote__citation,
.blogContent .wp-block-quote cite,
.blogContent .wp-block-quote footer {
  display: block;
  color: rgba(0, 0, 0, 0.4);
  font-size: 0.85rem;
  margin-top: 12px;
}
.blogContent .wp-block-quote cite::before,
.blogContent .wp-block-quote footer::before {
  content: '— '
}

.blogContent .wp-block-button {
  position: relative;
  box-sizing: border-box;
}
.blogContent .wp-block-button.alignwide a {
  display: block;
}
.blogContent code, .blogContent pre, .blogContent .wp-block-code {
  color: #666666;
  font-family: Courier, sans-serif;
  line-height: 1.4;
  margin: 32px 0px;
  padding: 12px;
  border: 2px solid rgba(0, 0, 0, 0.24);
  box-shadow: inset 0px 0px 6px rgba(0, 0, 0, 0.12);
  box-sizing: border-box;
  border-radius: 3px;
}
.blogContent .wp-block-cover,
.blogContent .wp-block-cover-image {
  margin-top: 32px;
  margin-bottom: 32px;
}
.blogContent .wp-block-cover-image.has-background-dim,
.blogContent .wp-block-cover-image.has-background-dim h2 {
  color: #ffffff;
}
.blogContent .wp-block-gallery .blocks-gallery-item {
  margin-left: 0px;
  margin-right: 0px;
  padding: 0px;
}
.blogContent .wp-block-gallery .blocks-gallery-image {
  margin-left: 0px;
  margin-right: 0px;
}
.blogContent .wp-block-gallery .blocks-gallery-image figcaption,
.blogContent .wp-block-gallery .blocks-gallery-item figcaption {
  box-sizing: border-box;
}
.blogContent .wp-block-image {
  max-width: none;
  margin: 32px auto;
  padding: 0px;
}
.blogContent img {
  margin-bottom: auto;
}
.blogContent img.aligncenter,
.blogContent .wp-block-image.aligncenter {
  display: block;
  margin: 12px auto;
  padding: 0px;
}
.blogContent img.alignnone,
.blogContent .wp-block-image.alignnone {
  display: inline;
  margin: 12px 0px;
  padding: 0px;
}
.blogContent img.alignright,
.blogContent .wp-block-image.alignright {
  display: inline;
  margin: 16px 0px 16px 24px;
  padding: 0px;
}
.blogContent img.alignleft,
.blogContent .wp-block-image.alignleft {
  display: inline;
  margin: 16px 24px 16px 0px;
  padding: 0px;
}
.blogContent table,
.blogContent table.wp-block-table {
  width: 100%;
  text-align: left;
  margin: 32px 0px;
  padding: 0px;
  border: 1px solid #dddddd;
  border-spacing: 0;
  border-collapse: collapse;
}
.blogContent table p,
.blogContent table form,
.blogContent table ul,
.blogContent table li {
  margin: 6px 0px;
  padding: 0px;
}
.blogContent table thead,
.blogContent table tfoot,
.blogContent table.wp-block-table thead,
.blogContent table.wp-block-table tfoot {
  border: 1px solid #dddddd;
}
.blogContent table tbody tr:nth-child(odd) {
  background: rgba(0, 0, 0, 0.04);
}
.blogContent table th,
.blogContent table.wp-block-table th {
  font-size: 1.1rem;
  text-transform: uppercase;
  margin: 0px;
  padding: 12px;
  border: 1px solid #dddddd;
  box-sizing: border-box;
  background: rgba(0, 0, 0, 0.04);
}
.blogContent table td,
.blogContent table.wp-block-table td {
  padding: 12px;
  margin: 0px;
  border: 1px solid #dddddd;
  box-sizing: border-box;
}
.blogContent table.wp-block-table.is-style-stripes {
  border-collapse: collapse;
}
.blogContent table.wp-block-table.is-style-stripes td {
  border: 1px solid #dddddd;
}

.blogContent .wp-block-embed.wp-embed-aspect-1-1 .wp-block-embed__wrapper, .blogContent .wp-block-embed.wp-embed-aspect-1-2 .wp-block-embed__wrapper, .blogContent .wp-block-embed.wp-embed-aspect-4-3 .wp-block-embed__wrapper, .blogContent .wp-block-embed.wp-embed-aspect-9-16 .wp-block-embed__wrapper, .blogContent .wp-block-embed.wp-embed-aspect-16-9 .wp-block-embed__wrapper, .blogContent .wp-block-embed.wp-embed-aspect-18-9 .wp-block-embed__wrapper, .blogContent .wp-block-embed.wp-embed-aspect-21-9 .wp-block-embed__wrapper {
  position: relative
}

.blogContent .wp-block-embed.wp-embed-aspect-1-1 .wp-block-embed__wrapper:before, .blogContent .wp-block-embed.wp-embed-aspect-1-2 .wp-block-embed__wrapper:before, .blogContent .wp-block-embed.wp-embed-aspect-4-3 .wp-block-embed__wrapper:before, .blogContent .wp-block-embed.wp-embed-aspect-9-16 .wp-block-embed__wrapper:before, .blogContent .wp-block-embed.wp-embed-aspect-16-9 .wp-block-embed__wrapper:before, .blogContent .wp-block-embed.wp-embed-aspect-18-9 .wp-block-embed__wrapper:before, .blogContent .wp-block-embed.wp-embed-aspect-21-9 .wp-block-embed__wrapper:before {
  content: "";
  display: block;
  padding-top: 50%
}

.blogContent .wp-block-embed.wp-embed-aspect-1-1 .wp-block-embed__wrapper iframe, .blogContent .wp-block-embed.wp-embed-aspect-1-2 .wp-block-embed__wrapper iframe, .blogContent .wp-block-embed.wp-embed-aspect-4-3 .wp-block-embed__wrapper iframe, .blogContent .wp-block-embed.wp-embed-aspect-9-16 .wp-block-embed__wrapper iframe, .blogContent .wp-block-embed.wp-embed-aspect-16-9 .wp-block-embed__wrapper iframe, .blogContent .wp-block-embed.wp-embed-aspect-18-9 .wp-block-embed__wrapper iframe, .blogContent .wp-block-embed.wp-embed-aspect-21-9 .wp-block-embed__wrapper iframe {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.blogContent .wp-block-embed.wp-embed-aspect-21-9 .wp-block-embed__wrapper:before {
  padding-top: 42.85%
}

.blogContent .wp-block-embed.wp-embed-aspect-18-9 .wp-block-embed__wrapper:before {
  padding-top: 50%
}

.blogContent .wp-block-embed.wp-embed-aspect-16-9 .wp-block-embed__wrapper:before {
  padding-top: 56.25%
}

.blogContent .wp-block-embed.wp-embed-aspect-4-3 .wp-block-embed__wrapper:before {
  padding-top: 75%
}

.blogContent .wp-block-embed.wp-embed-aspect-1-1 .wp-block-embed__wrapper:before {
  padding-top: 100%
}

.blogContent .wp-block-embed.wp-embed-aspect-9-16 .wp-block-embed__wrapper:before {
  padding-top: 177.78%
}

.blogContent .wp-block-embed.wp-embed-aspect-1-2 .wp-block-embed__wrapper:before {
  padding-top: 200%
}
.blogContent #toc_container a:link {
  text-decoration: underline;
}
.blogContent #toc_container a:hover {
  text-decoration: none;
}
.blogContent #toc_container p.toc_title {
  text-align: left;
}
.blogContent #toc_container li:not(:first-child) {
  margin-top: 15px;
}
.blogContent #toc_container li ul {
  margin-top: 15px;
}
.blogContent #toc_container li a::before {
  content: "○  ";
}
.blogContent #toc_container li ul li a::before {
  content: "・  ";
}
/*** h1 ***/
.page-title {
  font-size: 1.5rem;
  line-height: 1.6;
  background-color: #151515;
  color: #fff;
  padding: 13px 50px;
  min-height: 50px;
}
.page-title h1 ,
.page-title p {
  font-size: 1.5rem;
  line-height: 1.6;
  width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media screen and (max-width: 770px) {
  .page-title {
    padding: 8px 5%;
    min-height: 40px;
    white-space: nowrap;
  }
  .page-title h1 ,
  .page-title p {
    font-size: 1.2rem;
    line-height: 2;
  }
}

/***** profile *****/
.p-single__writer{
}
.p-single__writer-container{
  border-top: 2px solid #005B31;
  border-bottom: 2px solid #005B31;
  padding: 40px 32px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
@media screen and (max-width: 770px) {
  .p-single__writer-container{
    display: block;
  }
}
.p-single__writer-fig{
  width: 100%;
  max-width: 260px;
  margin-right: 22px;
}
@media screen and (max-width: 770px) {
  .p-single__writer-fig{
    margin: 0;
    max-width: none;
  }
}
.p-single__writer-fig img {
  margin-bottom: 0;
  vertical-align: top;
}
.p-single__writer-profile{
  flex: 1;
}

@media screen and (max-width: 770px) {
  .p-single__writer-profile{
    margin-top: 15px;
  }
}
.p-single__writer-label {
  line-height: 1;
}
.p-single__writer-label-inner {
  font-size: 1.8rem;
  line-height: 1.5;
  padding: 1px 12px 2px;
  display: inline-block;
  background-color: #000;
  color: #fff;
}
.p-single__writer-name{
  line-height: 1;
  font-weight: bold;
  margin-top: 15px;
}
.p-single__writer-name-ruby {
  display: block;
  font-size: 1.2rem;
  line-height: 1.5;
  letter-spacing: 0.2rem;
}
.p-single__writer-name-inner {
  display: block;
  font-size: 2.5rem;
  line-height: 1.5;
}
.p-single__writer-desc{
  margin-top: 15px;
  font-size: 1.6rem;
  line-height: 1.5;
}
@media screen and (max-width: 770px) {
  .p-single__writer-desc{
    font-size: 1.4rem;
  }
}
.p-single__writer-link{
  margin-top: 8px;
}
.c-text-link{
  display: inline-block;
  color: #a9a9a9;
  border: 1px solid #a9a9a9;
  border-radius: 5px;
  padding: 1px 14px 2px;
  text-decoration: underline;
  margin-top: 7px;
}
@media screen and (min-width: 1025px) {
  .c-text-link:hover {
    text-decoration: none;
  }
}
.c-text-link:not(:last-child) {
  margin-right: 15px;
}
.c-text-link::before {
  content: "";
  display: inline-block;
  width: 7px;
  height: 7px;
  background-color: #a9a9a9;
  vertical-align: middle;
  margin-right: 5px;
}
.p-single__writer-sns{
  margin-top: 25px;
}
.p-single__writer-sns-inner{
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
.p-single__writer-sns__item:not(:first-child) {
  margin-left: 1em;
}
.c-sns-link{
  display: flex;
  justify-content: center;
  align-items: center;
  width: 30px;
  height: 30px;
  font-size: 3rem;
  vertical-align: middle;
}
.is-twitter .c-sns-link{
  font-size: 1.6rem;
  position: relative;
  color: #fff;
}

.is-twitter .c-sns-link::after {
  position: absolute;
  content: "";
  display: block;
  width: 30px;
  height: 30px;
  background-color: #000;
  border-radius: 15px;
  z-index: -1;
}
/* Privacy Update */
.c-form-consent {
    margin: 0 auto 20px;
    text-align: center;
}
.c-form-consent a {
    text-decoration: underline;
}
input[type=checkbox] {
	display: none;
}
.mwform-checkbox-field-text {
	box-sizing: border-box;
	position: relative;
	display: inline-block;
	vertical-align: middle;
	cursor: pointer;
	padding: 0 0 0 24px;
}
.mwform-checkbox-field-text:after {
	position: absolute;
	top: 50%;
	left: 6px;
	display: block;
	margin-top: -7px;
	width: 5px;
	height: 9px;
	border-right: 3px solid #de0029;
	border-bottom: 3px solid #de0029;
	content: '';
	opacity: 0;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
}
.mwform-checkbox-field-text:before {
	position: absolute;
	top: 50%;
	left: 0;
	display: block;
	margin-top: -9px;
	width: 18px;
	height: 18px;
	border: 1px solid #999999;
	background-color: #fff;
	content: '';
}
input[type=checkbox]:checked + .mwform-checkbox-field-text:after {
	opacity: 1;
}

/*----------------------------------------
20220705 privacy
----------------------------------------*/
.p-privacy__read {
  margin: 2em 0 3em;
}
.p-privacy__ttl {
  margin-bottom: 30px;
  padding-bottom: 20px;
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: 700;
  text-align: left;
  border-bottom: 1px solid #ddd;
}
@media screen and (max-width: 767px) {
  .p-privacy__ttl {
    margin-bottom: 15px;
    padding-bottom: 10px;
    font-size: 13px;
    font-size: 1.3rem;
  }
}
/*----- c-section -----*/
.c-section {
  position: relative;
}
.c-section:not(:last-child) {
  margin-bottom: 120px;
}
@media screen and (max-width: 767px) {
  .c-section:not(:last-child) {
    margin-bottom: 60px;
  }
}
.c-section.is-contact {
  margin-bottom: 0;
}
.c-section__container {
  position: relative;
  margin: 0 80px;
}
@media screen and (max-width: 767px) {
  .c-section__container {
    margin: 0 20px;
  }
}
.c-section__container.is-middle {
  margin: 0 160px;
}
@media screen and (max-width: 1199px) {
  .c-section__container.is-middle {
    margin: 0 80px;
  }
}
@media screen and (max-width: 767px) {
  .c-section__container.is-middle {
    margin: 0 10px;
  }
}
@media screen and (max-width: 767px) {
  .c-section__container.is-middle.is-sp-middle {
    margin: 0 20px;
  }
}
.c-section__container.is-small {
  margin: 0 300px;
}
@media screen and (max-width: 1600px) {
  .c-section__container.is-small {
    margin: 0 200px;
  }
}
@media screen and (max-width: 1199px) {
  .c-section__container.is-small {
    margin: 0 80px;
  }
}
@media screen and (max-width: 767px) {
  .c-section__container.is-small {
    margin: 0 20px;
  }
}
.p-privacy-block {
  font-size: 14px;
  font-size: 1.4rem;
}
@media screen and (max-width: 767px) {
  .p-privacy-block {
    font-size: 12px;
    font-size: 1.2rem;
  }
}
/*----- c-o-list-child -----*/
.c-o-list-child {
  position: relative;
  text-align: justify;
}
.c-o-list-child:not(:first-child) {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .c-o-list-child:not(:first-child) {
    margin-top: 10px;
  }
}
.c-o-list-child__item {
  position: relative;
  z-index: 1;
  margin: 0 0 10px;
  padding: 0 0 0 25px;
  counter-increment: c-o-list-child-number;
}
.c-o-list-child__item::before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.8;
  text-align: center;
  content: "(" counter(c-o-list-child-number) ")";
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .c-o-list-child__item::before {
    font-size: 12px;
    font-size: 1.2rem;
  }
}
.c-o-list-child__item-txt {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  .c-o-list-child__item-txt {
    font-size: 12px;
    font-size: 1.2rem;
  }
}
/*----- c-guid-desc -----*/
.c-guid-desc {
  margin: 0 0 20px;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  .c-guid-desc {
    font-size: 12px;
    font-size: 1.2rem;
  }
}
.p-privacy-block .c-guid-desc,
.p-shopping-guide-block .c-guid-desc {
  text-align: left;
}
.c-section.is-guide .c-guid-desc {
  padding-left: 10px;
  text-align: left;
}
@media screen and (max-width: 1024px) {
  .c-section.is-guide .c-guid-desc {
    padding-right: 5px;
    padding-left: 5px;
  }
}
:not(:last-child) > .c-guid-desc:last-child {
  margin-bottom: 60px;
}
@media screen and (max-width: 767px) {
  :not(:last-child) > .c-guid-desc:last-child {
    margin-bottom: 40px;
  }
}
/*----- c-o-list -----*/
.c-o-list {
  position: relative;
  text-align: justify;
}
.c-o-list:not(:last-child) {
  margin-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .c-o-list:not(:last-child) {
    margin-bottom: 40px;
  }
}
.c-o-list__item {
  position: relative;
  z-index: 1;
  margin: 0 0 15px;
  padding: 0 10px 0 35px;
  counter-increment: c-o-list-number;
}
@media screen and (max-width: 767px) {
  .c-o-list__item {
    margin-bottom: 10px;
    padding-left: 23px;
  }
}
.c-o-list__item:last-child {
  margin-bottom: 3em;
}
.c-o-list__item::before {
  position: absolute;
  top: 0;
  left: 3px;
  display: block;
  line-height: 1.8;
  content: counter(c-o-list-number) ".";
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .c-o-list__item::before {
    left: 1px;
  }
}
.c-o-list__item-txt {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  .c-o-list__item-txt {
    font-size: 12px;
    font-size: 1.2rem;
  }
}
.c-u-list-child__item {
    position: relative;
    padding: 0 0 0 10px;
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.8;
    color: #151515;
}
@media screen and (max-width: 767px) {
  .c-u-list-child__item {
      font-size: 12px;
      font-size: 1.2rem;
  }
}
.c-u-list-child__item::before {
    position: absolute;
    top: 10px;
    left: 2px;
    display: block;
    width: 3px;
    height: 3px;
    border-radius: 50px;
    background: #151515;
    content: "";
}
.p-privacy-block a:not([class]) {
  text-decoration: underline;
}
.p-privacy-block a:not([class]):hover {
  opacity: .8;
}
/*----------------------------------------
footer-sub-link
----------------------------------------*/
.p-footer-sub-link {
  text-align: center;
  margin: 0 auto;
  padding: 5px 0 20px;
}
@media screen and (max-width: 767px) {
  .p-footer-sub-link {
    padding: 0 0 20px;
  }
}
.p-footer-sub-link-list {
  display: flex;
  justify-content: center;
  max-width: 1600px;
  flex-wrap: wrap;
  margin: auto;
}
.p-footer-sub-link-item {
  padding: 0 10px;
  line-height: 1.65em;
  position: relative;
  letter-spacing: 0.1em;
  font-size: 1.5rem;
}
.p-footer-sub-link-item + .p-footer-sub-link-item:before {
  position: absolute;
  left: 0;
  top: calc(50% - .5em);
  height: 1em;
  width: 1px;
  content: "";
  background: #fff;
}
.p-footer-sub-link-link {
  display: inline-block;
  transition: .2s;
  font-size: 1.3rem;
  color: #fff;
}
.p-footer-sub-link-link:hover {
  text-decoration: underline;
}
/****** 20220928 *****/
.imgRight .txtBox {
	position: relative;
	z-index: 2;
}
.imgRight .image {
	position: relative;
	z-index: 1;
}

/****** 20240520 *****/
.wpcf7-form {
  padding: 0 20px 100px;
}
@media screen and (max-width: 770px) {
  .wpcf7-form {
    padding: 0 0 50px;
  }
}
.wpcf7-list-item {
  margin: 6px 1.6em 6px 0;
}
.wpcf7-list-item:last-child {
  margin-right: 0;
}
input::placeholder{
  color: #a5a5a5;
}
:-ms-input-placeholder {
  color: #a5a5a5 !important;
}
select,
input,
textarea {
  border-radius: 0;
  -webkit-appearance: none;
    -moz-appearance: none;
          appearance: none;
}
@media screen and (max-width: 770px) {
  .wpcf7-form input[type="text"],
  .wpcf7-form input[type="email"],
  .wpcf7-form input[type="tel"],
  .wpcf7-form select,
  .wpcf7-form input[type="date"],
  .wpcf7-form input[type="number"] {
    font-size: 16px;
    font-size: 1.6rem;
    min-height: 40px;
  }
}
@media screen and (max-width: 767px) {
  .wpcf7-form textarea {
    font-size: 16px;
    font-size: 1.6rem;
  }
}
input::-webkit-date-and-time-value{
  text-align: left;
}
.wpcf7-form input[type="file"]::file-selector-button {
  min-height: auto;
  background-color: transparent;
  border-radius: 0;
  appearance: none;
  border: 1px solid #666;
  cursor: pointer;
  color: #151515;
}
.wpcf7-form input[type='checkbox'] {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  display: none;
}
.wpcf7-form input[type="radio"] {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  display: none;
}
.wpcf7-form input[type="checkbox"] + span {
  position: relative;
  display: inline-block;
  padding: 0 0 0 32px;
  cursor: pointer;
}
.wpcf7-form input[type="checkbox"] + span::before {
  position: absolute;
  top: 50%;
  left: 0;
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 1px solid #666;
  border-radius: 0;
  background: #fff;
  content: "";
  box-sizing: border-box;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.wpcf7-form input[type="checkbox"] + span::after {
  position: absolute;
  top: 3px;
  left: 6px;
  display: inline-block;
  width: 6px;
  height: 11px;
  border-right: 2px solid #005B31;
  border-bottom: 2px solid #005B31;
  content: "";
  opacity: 0;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.wpcf7-form input[type="radio"] + span {
  position: relative;
  display: inline-block;
  padding-left: 32px;
  line-height: 1.5;
  cursor: pointer;
}
.wpcf7-form input[type="radio"] + span::before {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: 24px;
  height: 24px;
  border: 1px solid #666;
  border-radius: 50%;
  background: #fff;
  content: "";
  box-sizing: border-box;
}
.wpcf7-form input[type="radio"] + span::after {
  position: absolute;
  top: 12px;
  left: 12px;
  display: inline-block;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #005B31;
  content: "";
  opacity: 0;
  -webkit-transition: opacity 0.5s cubic-bezier(0.19, 1, 0.22, 1), -webkit-transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: opacity 0.5s cubic-bezier(0.19, 1, 0.22, 1), -webkit-transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: opacity 0.5s cubic-bezier(0.19, 1, 0.22, 1), transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: opacity 0.5s cubic-bezier(0.19, 1, 0.22, 1), transform 0.5s cubic-bezier(0.19, 1, 0.22, 1), -webkit-transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  -webkit-transform: translateX(-50%) translateY(-50%) scale3d(0.8, 0.8, 1);
          transform: translateX(-50%) translateY(-50%) scale3d(0.8, 0.8, 1);
}
.wpcf7-form input[type="radio"]:checked + span::after {
  opacity: 1;
  -webkit-transform: translateX(-50%) translateY(-50%) scale3d(1, 1, 1);
          transform: translateX(-50%) translateY(-50%) scale3d(1, 1, 1);
}
.wpcf7-form input[type="checkbox"]:checked + span::before {
  opacity: 1;
}
.wpcf7-form input[type="checkbox"]:checked + span::after {
  opacity: 1;
}
@media screen and (max-width: 770px) {
  .wpcf7-form .formWrap .modPCenter {
    text-align: center;
  }
}
.wpcf7-form .wpcf7-acceptance {
  display: inline-block;
  margin-top: 1em;
}

.wpcf7-form .formBtn {
  position: relative;
  text-align: center;
}
.wpcf7-form.submitting .wpcf7-submit {
  pointer-events: none;
  cursor: auto;
}
span.wpcf7-spinner {
  position: absolute;
  top: 120%;
  left: 50%;
  transform: translateX(-50%);
  margin: 0;
}
.wpcf7 form .wpcf7-response-output {
  max-width: 800px;
  margin: 2em auto 0 !important;
}

.footSns a {
	color: #ffffff;
} 
.footSns .-facebook svg {
	width: 13px;
	height: 25px;
}
.footSns .-twitter svg {
	width: 25px;
	height: 26px;
}
.footSns .-instagram svg {
	width: 26px;
	height: 25px;
}
.footSns .-line svg {
	width: 25px;
	height: 25px;
}
.footSns .-youtube svg {
	width: 23px;
	height: 22px;
}
.footSns .-tiktok svg {
	width: 21px;
	height: 24px;
}
.footSns .-pinterest svg {
	width: 24px;
	height: 23px;
}
.flow .flowBox:last-of-type .flowArrow {
  display: none;
}
.c-sns-link span,.c-sns-link svg{
	width: 30px;
  height: 30px;
}
.error {
	font-size:1.4rem;
	text-align:center;
}
.work .noimage ,.workList .noimage ,.workSingle .noimage{
  aspect-ratio: 512 / 307;
  object-fit: cover;
}

.aboutCnt .noimage ,.menu_detail .noimage{
  aspect-ratio: 5 / 3;
  object-fit: cover;
}

.ttlA.en {
text-shadow: 
    rgba(255, 255, 255, 0.5) 1px 1px 15px, rgba(255, 255, 255, 0.5) -1px 1px 15px,
    rgba(255, 255, 255, 0.5) 1px -1px 15px, rgba(255, 255, 255, 0.5) -1px -1px 15px;
}

@media screen and (min-width: 771px){
.siteHeader .logo a img {
  max-width: 280px;
  max-height: 60px;
    }
}
.p-index-label {
  margin-top: 160px;
}
@media screen and (max-width: 770px){
  .p-index-label {
    margin-top: 80px;
  }
  .ttlB {
    font-size: 3rem;
  }
}

.modPR {
  text-align: right;
}

.home .imgLeft,
.home .imgRight {
  justify-content: space-between;
}

@media screen and (max-width: 1330px) {
  .home .imgLeft .image,
  .home .imgRight .image {
    width: calc(100% - 510px);
  }
}


@media screen and (max-width: 1024px) {
  .home .imgLeft .image,
  .home .imgRight .image {
    width: 60%;
  }
}

@media screen and (max-width: 770px) {
  .home .imgLeft .image,
  .home .imgRight .image {
    width: 100%;
  }
}