@charset "UTF-8";
/* Common Style
-----------------------------------*/
/* window size
-----------------*/
/* font
-----------------*/
/* color
-----------------*/
/* window size
-----------------*/
/* font
-----------------*/
/* color
-----------------*/
/* Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0;
}

.slick-list img {
  margin: 0 auto auto auto;
}

.slick-list:focus {
  outline: none;
}

.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
}

.slick-track:before, .slick-track:after {
  content: "";
  display: table;
}

.slick-track:after {
  clear: both;
}

.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none;
}

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

@media screen and (max-width: 768px) {
  .slick-list img {
    margin: 0 auto auto auto;
    width: 80%;
  }
}

@media screen and (max-width: 414px) {
  .slick-list img {
    margin: 0 auto auto auto;
  }
}

/* Slider */
.slick-loading .slick-list {
  background: #fff url("./ajax-loader.gif") center center no-repeat;
}

/* Icons */
@font-face {
  font-family: "slick";
  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");
  font-weight: normal;
  font-style: normal;
}

/* Arrows */
.slick-prev,
.slick-next {
  z-index: 5;
  position: absolute;
  display: block;
  height: 20px;
  width: 20px;
  line-height: 0px;
  font-size: 0px;
  cursor: pointer;
  background: transparent;
  color: transparent;
  top: 50%;
  transform: translate(0, -50%);
  padding: 0;
  border: none;
  outline: none;
}

.slick-prev:hover, .slick-prev:focus,
.slick-next:hover,
.slick-next:focus {
  outline: none;
  background: transparent;
  color: 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: 0.25;
}

.slick-prev:before,
.slick-next:before {
  font-family: "slick";
  font-size: 20px;
  line-height: 1;
  color: white;
  opacity: 0.75;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-prev {
  left: -25px;
}

[dir="rtl"] .slick-prev {
  left: auto;
  right: -25px;
}

.slick-next {
  right: -25px;
}

[dir="rtl"] .slick-next {
  left: -25px;
  right: auto;
}

/* Dots */
.slick-dots {
  position: absolute;
  bottom: 4%;
  list-style: none;
  display: block;
  text-align: center;
  padding: 0;
  margin: 0;
  width: 100%;
}

.slick-dots li {
  position: relative;
  display: inline-block;
  height: 20px;
  width: 20px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}

.slick-dots li button {
  border: 0;
  background: transparent;
  display: block;
  height: 10px;
  width: 10px;
  outline: none;
  line-height: 0px;
  font-size: 0px;
  color: transparent;
  padding: 5px;
  cursor: pointer;
}

.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 {
  position: absolute;
  top: 0;
  left: 0;
  content: "•";
  width: 20px;
  height: 20px;
  font-family: "slick";
  font-size: 8px;
  line-height: 20px;
  text-align: center;
  color: black;
  opacity: 0.25;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-dots li.slick-active button:before {
  color: black;
  opacity: 0.75;
}

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, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, figure, footer, header,
menu, nav, section, audio, video, canvas {
  border: 0;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}

article, aside, figure, figcaption, footer,
header, menu, nav, section, main {
  display: block;
}

body {
  color: #333;
  text-align: left;
}

h1, h2, h3, h4, h5, h6 {
  clear: both;
  font-weight: normal;
}

ol, ul {
  list-style: none;
}

blockquote {
  quotes: none;
}

blockquote:before, blockquote:after {
  content: none;
}

del {
  text-decoration: line-through;
}

/* tables still need 'cellspacing="0"' in the markup */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

a img {
  border: none;
  vertical-align: middle;
}

* {
  position: relative;
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
}

*::selection {
  background: rgba(51, 153, 153, .6);
}

*::-moz-selection {
  background: rgba(51, 153, 153, .6);
}

a, input[type=submit] {
  transition: all 0.2s ease;
}

/* Main global 'theme' and typographic styles */
body {
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  font-family: "Noto Serif JP", serif, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝";
  font-weight: 400;
  font-size: 16px;
  position: relative;
  letter-spacing: .05em;
  animation: fade-in 2s linear;
  animation-fill-mode: both;
}

body,
input,
textarea {
  color: #111;
  line-height: 1.8;
}

a:link,
a:visited {
  color: #2a85c0;
  cursor: hand;
  cursor: pointer;
  outline: none;
  text-decoration: none;
  -webkit-text-decoration-skip: objects;
}

a:active,
a:hover {
  opacity: 0.7;
  text-decoration: underline;
  outline-width: 0;
  transition: all 0.5s ease;
}

hr {
  background-color: #ccc;
  border: 0;
  clear: both;
  width: 100%;
  height: 1px;
}

svg,
img {
  width: auto;
  height: auto;
  max-width: 100%;
}

h1, h2, h3, h4, h5, h6 {
  font-size: 1em;
}

p {
  margin-bottom: 1.5em;
}

ul {
  list-style: square;
  margin: 0 0 1.5em 2em;
}

ol {
  list-style: decimal;
  margin: 0 0 1.5em 2em;
}

ol ol {
  list-style: upper-alpha;
}

ol ol ol {
  list-style: lower-roman;
}

ol ol ol ol {
  list-style: lower-alpha;
}

ul ul,
ol ol,
ul ol,
ol ul {
  margin-bottom: 0;
}

dl {
  margin: 0 0 1.8em 0;
}

dt {
  font-weight: bold;
}

dt:last-child {
  margin-bottom: 0;
}

dd {
  margin-bottom: 1.5em;
}

dd:last-child {
  margin-bottom: 0;
}

strong, b {
  font-weight: bold;
}

cite,
em,
i {
  font-style: italic;
}

big {
  font-size: 131.25%;
}

ins {
  background: #ffc;
  text-decoration: none;
}

blockquote {
  font-style: italic;
  padding: 0 2em;
}

blockquote cite,
blockquote em,
blockquote i {
  font-style: normal;
}

pre {
  background: #f7f7f7;
  color: #222;
  line-height: 1.5;
  margin-bottom: 1.5em;
  overflow: auto;
  padding: 1.5em;
}

blockquote {
  quotes: "" "";
}

blockquote:before, blockquote:after {
  content: "";
}

q {
  quotes: "“" "”" "‘" "’";
}

:focus {
  outline: none;
}

abbr,
acronym {
  border-bottom: 1px dotted #666;
  cursor: help;
}

sup,
sub {
  height: 0;
  line-height: 1;
  position: relative;
  vertical-align: baseline;
}

sup {
  bottom: 1ex;
}

sub {
  top: .5ex;
}

small {
  font-size: .8em;
}

table {
  border-collapse: separate;
  border-spacing: 1px;
  width: 100%;
  margin-bottom: 1.5em;
}

th, td {
  padding: .5em .8em;
  vertical-align: top;
  border-bottom: none;
  text-align: left;
  background: #fff;
}

th {
  font-weight: normal;
}

.material-icons-outlined {
  display: -ms-inline-flexbox !important;
  display: inline-flex !important;
  vertical-align: middle !important;
  font-size: 20px !important;
}

/* window size
-----------------*/
/* font
-----------------*/
/* color
-----------------*/
/* window size
-----------------*/
/* font
-----------------*/
/* color
-----------------*/
/* Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0;
}

.slick-list img {
  margin: 0 auto auto auto;
}

.slick-list:focus {
  outline: none;
}

.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
}

.slick-track:before, .slick-track:after {
  content: "";
  display: table;
}

.slick-track:after {
  clear: both;
}

.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none;
}

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

@media screen and (max-width: 768px) {
  .slick-list img {
    margin: 0 auto auto auto;
    width: 80%;
  }
}

@media screen and (max-width: 414px) {
  .slick-list img {
    margin: 0 auto auto auto;
  }
}

/* Slider */
.slick-loading .slick-list {
  background: #fff url("./ajax-loader.gif") center center no-repeat;
}

/* Icons */
@font-face {
  font-family: "slick";
  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");
  font-weight: normal;
  font-style: normal;
}

/* Arrows */
.slick-prev,
.slick-next {
  z-index: 5;
  position: absolute;
  display: block;
  height: 20px;
  width: 20px;
  line-height: 0px;
  font-size: 0px;
  cursor: pointer;
  background: transparent;
  color: transparent;
  top: 50%;
  transform: translate(0, -50%);
  padding: 0;
  border: none;
  outline: none;
}

.slick-prev:hover, .slick-prev:focus,
.slick-next:hover,
.slick-next:focus {
  outline: none;
  background: transparent;
  color: 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: 0.25;
}

.slick-prev:before,
.slick-next:before {
  font-family: "slick";
  font-size: 20px;
  line-height: 1;
  color: white;
  opacity: 0.75;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-prev {
  left: -25px;
}

[dir="rtl"] .slick-prev {
  left: auto;
  right: -25px;
}

.slick-next {
  right: -25px;
}

[dir="rtl"] .slick-next {
  left: -25px;
  right: auto;
}

/* Dots */
.slick-dots {
  position: absolute;
  bottom: 4%;
  list-style: none;
  display: block;
  text-align: center;
  padding: 0;
  margin: 0;
  width: 100%;
}

.slick-dots li {
  position: relative;
  display: inline-block;
  height: 20px;
  width: 20px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}

.slick-dots li button {
  border: 0;
  background: transparent;
  display: block;
  height: 10px;
  width: 10px;
  outline: none;
  line-height: 0px;
  font-size: 0px;
  color: transparent;
  padding: 5px;
  cursor: pointer;
}

.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 {
  position: absolute;
  top: 0;
  left: 0;
  content: "•";
  width: 20px;
  height: 20px;
  font-family: "slick";
  font-size: 8px;
  line-height: 20px;
  text-align: center;
  color: black;
  opacity: 0.25;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-dots li.slick-active button:before {
  color: black;
  opacity: 0.75;
}

/* エフェクトで使う keyframes */
@keyframes blink {
  50% {
    opacity: .3;
  }
  0%, 100% {
    opacity: .9;
  }
}

/* フェードイン */
@keyframes fade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

/* フェードアウト */
@keyframes fade-out {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}

/* スプリング(拡大してバウンド) */
@keyframes spring {
  0% {
    transform: scale(0.2);
  }
  75% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}

/* 上に移動しながらフェードイン */
@keyframes fade-up {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* 下に移動しながらフェードイン */
@keyframes fade-down {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* 左に移動しながらフェードイン */
@keyframes fade-left {
  from {
    opacity: 0;
    transform: translateX(10px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

/* 右に移動しながらフェードイン */
@keyframes fade-right {
  from {
    opacity: 0;
    transform: translateX(-10px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes slide-right {
  from {
    position: absolute;
    left: -100vw;
  }
  to {
    position: relative;
    left: 0;
  }
}

/* X方向スケールアップ */
@keyframes scale-up-x {
  from {
    transform: scaleX(0);
  }
  to {
    transform: scaleX(1);
  }
}

/* Y方向スケールアップ */
@keyframes scale-up-y {
  from {
    transform: scaleY(0);
  }
  to {
    transform: scaleY(1);
  }
}

/* Y方向スケールダウン */
@keyframes scale-down-y {
  from {
    transform: scaleY(1);
  }
  to {
    transform: scaleY(0);
  }
}

/* Y方向に拡大しながらフェードイン */
@keyframes scale-y-fade-in {
  from {
    transform: scaleY(0);
    opacity: 0;
  }
  to {
    transform: scaleY(1);
    opacity: 1;
  }
}

/* 拡大しながらフェードイン */
@keyframes scale-fade-in {
  from {
    transform: scale(0);
    opacity: 0;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}

/* 拡大しながらフェードアウト */
@keyframes scale-fade-out {
  from {
    transform: scale(1);
    opacity: 1;
  }
  to {
    transform: scale(1.2);
    opacity: 0;
  }
}

button,
html [type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}

button::-moz-focus-inner,
html [type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
html [type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

input[type="text"],
input[type="password"],
input[type="tel"],
input[type="email"],
input[type="url"],
input[type="search"],
input[type="number"],
textarea {
  -webkit-appearance: none;
}

input[type="text"],
input[type="password"],
input[type="tel"],
input[type="email"],
input[type="url"],
input[type="search"],
input[type="number"],
textarea {
  background: #fff;
  border: 1px solid #ccc;
  box-shadow: none;
  -moz-box-shadow: none;
  -webkit-box-shadow: none;
  vertical-align: middle;
  font-size: 1em;
  padding: 0.2em 0.5em;
  border-radius: 0;
  color: #111;
}

input[disabled][readonly],
select[disabled][readonly],
textarea[disabled][readonly] {
  background-color: #fff;
  border-color: #a6a6a6;
}

[type="checkbox"],
[type="radio"] {
  box-sizing: border-box;
  padding: 0;
}

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

[type="search"] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

@media screen and (max-width: 736px) {
  input[type="text"],
  input[type="password"],
  input[type="tel"],
  input[type="email"],
  input[type="url"],
  input[type="search"],
  input[type="number"],
  textarea {
    width: 100%;
  }
}

#header {
  position: fixed;
  top: 0;
  right: 0;
  bottom: auto;
  left: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row nowrap;
      flex-flow: row nowrap;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: justify;
      justify-content: space-between;
  margin: 0 auto;
  width: 100%;
  height: 80px;
  padding: 0 20px;
  z-index: 100;
  background: rgba(255, 255, 255, .9);
  border-bottom: 1px solid #f0e5d8;
  transition: all 0.4s ease;
}

#header img {
  vertical-align: bottom;
  transition: all 0.4s ease;
}

#header a {
  transition: all 0.4s ease;
}

#header .headerFlex {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row nowrap;
      flex-flow: row nowrap;
}

.headerTelIcon {
  display: none;
}

.siteLogo {
  width: 260px;
  margin: 0;
}

.siteLogo a {
  display: block;
}

.siteLogo a:hover {
  opacity: .7;
}

@media screen and (max-width: 1024px) {
  #header {
    height: 60px;
    padding: 0 0 0 15px;
    background: white;
  }
  #header:before {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    display: block;
    content: '';
    z-index: 100;
  }
  .headerTelIcon {
    z-index: 101;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
        justify-content: center;
    -ms-flex-align: center;
        align-items: center;
    width: 60px;
    height: 60px;
  }
  .headerTelIcon a {
    display: block;
    padding: 5px;
    border: 1px solid #ba9d77;
    border-radius: 50%;
    background: #faf9f6;
  }
  .headerTelIcon a:hover {
    text-decoration: none;
  }
  .headerTelIcon .material-icons-outlined {
    color: #ba9d77 !important;
    font-size: 28px !important;
    transform: rotate(15deg);
  }
  .siteLogo {
    width: 208px;
    z-index: 101;
  }
}

@media screen and (max-width: 500px) {
  #header {
    padding: 0 0 0 3.14vw;
  }
}

.navTrigger {
  display: none;
  -ms-flex-flow: row nowrap;
      flex-flow: row nowrap;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  width: 60px;
  height: 60px;
  margin: 0;
  font-size: 30px;
  line-height: 1;
  color: #fff;
  background: #ba9d77;
  z-index: 5;
}

.navTrigger img {
  width: 40px;
  margin: 0 auto;
}

.navTrigger .icon-close {
  display: none;
}

.navTrigger.is-current .icon-close {
  display: block;
}

.navTrigger.is-current .icon-more {
  display: none;
}

.navTrigger.is-current + #spNav {
  display: block;
}

#spNav {
  z-index: 5;
  line-height: 1.2;
}

#spNav > ul {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row nowrap;
      flex-flow: row nowrap;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: end;
      justify-content: flex-end;
  width: 100%;
  list-style: none;
  margin: 0;
  padding: 0;
}

#spNav > ul a:hover {
  opacity: 1;
}

#spNav > ul > li {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row nowrap;
      flex-flow: row nowrap;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: justify;
      justify-content: space-between;
}

#spNav > ul > li > span,
#spNav > ul > li > a {
  display: -ms-inline-flexbox;
  display: inline-flex;
  padding: 0 1.5em;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  cursor: pointer;
  color: #111;
  transition: all 0.4s ease;
}

#spNav > ul > li > span .fa,
#spNav > ul > li > a .fa {
  display: none;
}

#spNav > ul > li > span:hover {
  color: #2a85c0;
}

#spNav > ul > li > a:hover {
  color: #2a85c0;
  text-decoration: none;
}

#spNav > ul > li.spNav00, #spNav > ul > li.spNav01, #spNav > ul > li.spNav02, #spNav > ul > li.spNav03, #spNav > ul > li.spNav04, #spNav > ul > li.spNav05, #spNav > ul > li.spNav06, #spNav > ul > li.spNav07, #spNav > ul > li.spNav08, #spNav > ul > li.spNav09, #spNav > ul > li.spNav10 {
  display: none;
}

#spNav > ul > li:last-child {
  margin: 0 -1.5em 0 0;
}

#spNav > ul > li:after {
  content: " / ";
}

#spNav > ul > li:last-child:after {
  content: none;
}

#spNav #headerTel {
  padding: 0;
  text-align: right;
}

#spNav #headerTel .telNumber {
  font-size: 1.8em;
}

#spNav #headerTel .telNumber a {
  color: #111;
}

#spNav #headerTel .telTime {
  font-size: .8em;
}

#spNav #headerTel .material-icons-outlined {
  margin-top: -5px !important;
  color: #ba9d77 !important;
  font-size: 28px !important;
  transform: rotate(15deg);
}

#spNav #loginSp {
  display: none;
  -ms-flex-pack: center;
      justify-content: center;
  margin: 0 auto;
  padding: 1em;
  text-align: center;
  border-bottom: 1px solid #f0e5d8;
  background: #fff;
}

#spNav #loginSp .material-icons-outlined {
  margin-top: -5px !important;
  color: #111 !important;
  font-size: 24px !important;
}

#spNav #loginSp a {
  margin: 0 1em;
  color: #111;
}

#gNav {
  position: fixed;
  top: 80px;
  right: 0;
  bottom: auto;
  left: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row nowrap;
      flex-flow: row nowrap;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: end;
      justify-content: flex-end;
  width: 100%;
  height: 40px;
  padding: 0 20px;
  transition: all 0.4s ease;
  background: rgba(255, 255, 255, .9);
  border-bottom: 1px solid #f0e5d8;
  z-index: 5;
}

#gNav > ul {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row nowrap;
      flex-flow: row nowrap;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: start;
      justify-content: flex-start;
  width: 100%;
  margin: 0 auto;
  list-style: none;
}

#gNav > ul a:hover {
  opacity: 1;
}

#gNav > ul > li {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row nowrap;
      flex-flow: row nowrap;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: justify;
      justify-content: space-between;
}

#gNav > ul > li > span,
#gNav > ul > li > a {
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  padding: 0 1.2em;
  height: 40px;
  font-size: 15px;
  cursor: pointer;
  color: #111;
  transition: all 0.4s ease;
}

#gNav > ul > li > span .fa,
#gNav > ul > li > a .fa {
  display: none;
}

#gNav > ul > li > span:hover,
#gNav > ul > li > a:hover {
  color: #111;
  text-decoration: none;
  background: #f0e5d8;
}

#gNav > ul > li > span:after {
  position: absolute;
  top: auto;
  right: 40%;
  bottom: 0;
  left: auto;
  display: block;
  content: '';
  width: 15px;
  height: 8px;
  box-sizing: border-box;
  border: 0 solid transparent;
  border-width: 0 8px 8px;
  border-bottom-color: #ba9d77;
  transform: translate(-50%, 0);
  opacity: 0;
  transition: all 0.4s ease;
}

#gNav > ul > li.is-current .navChild,
#gNav > ul > li.is-current > span:after {
  opacity: 1;
}

#gNav > ul > li.is-current .navChild {
  pointer-events: auto;
}

.is-edge #gNav > ul > li.is-current .navChild,
.is-ie #gNav > ul > li.is-current .navChild {
  display: -ms-flexbox;
  display: flex;
}

#gNav > ul > li:last-child {
  margin-left: auto;
}

#gNav > ul > li.gNav06 ul {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row nowrap;
      flex-flow: row nowrap;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: end;
      justify-content: flex-end;
  width: 100%;
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: .9em;
}

#gNav > ul > li.gNav06 ul > li a {
  padding: 0 1.5em;
  color: #111;
  border-right: 1px solid #ba9d77;
}

#gNav > ul > li.gNav06 ul > li a:hover {
  text-decoration: none;
  color: #ba9d77;
}

#gNav > ul .navChild {
  position: fixed;
  top: 120px;
  right: 0;
  bottom: auto;
  left: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  width: 100vw;
  padding: 5px 20px;
  margin: 0 auto;
  list-style: none;
  background: #ba9d77;
  text-align: center;
  pointer-events: none;
  transition: all 0.4s ease;
  opacity: 0;
  z-index: 1;
}

.is-edge #gNav > ul .navChild,
.is-ie #gNav > ul .navChild {
  display: none;
}

#gNav > ul .navChild a {
  display: block;
  color: #111;
}

#gNav > ul .navChild a:hover {
  text-decoration: none;
  opacity: .7;
}

#gNav > ul .navChild li {
  line-height: 1.2;
  padding: .5em 1em;
  margin: 5px 20px 5px 0;
  background: #faf9f6;
}

#gNav > ul .navChild li i.fa {
  margin-right: 5px;
}

#gNav > ul .navChild li i.fas {
  margin-right: 5px;
}

@media screen and (max-width: 1024px) {
  .navTrigger {
    display: -ms-flexbox;
    display: flex;
    z-index: 101;
  }
  .navTrigger.is-current + #spNav {
    right: 0;
    opacity: 1;
  }
  #spNav {
    position: fixed;
    top: 60px;
    right: -100%;
    width: 100%;
    height: auto;
    max-height: calc(100vh - 100px);
    background: #f0e5d8;
    overflow: auto;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    transition: all 0.3s ease;
    z-index: 99;
    opacity: 0;
  }
  #spNav > ul {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -ms-flex-pack: start;
        justify-content: flex-start;
    padding: 0;
  }
  #spNav > ul > li {
    -ms-flex-direction: column;
        flex-direction: column;
    width: 100%;
    height: auto;
    padding: 0;
  }
  #spNav > ul > li > span,
  #spNav > ul > li > a {
    -ms-flex-pack: justify;
        justify-content: space-between;
    width: 100%;
    height: auto;
    padding: 1em;
    text-align: left;
    border-bottom: 1px solid #faf9f6;
    font-size: 14px;
  }
  #spNav > ul > li > span:after,
  #spNav > ul > li > a:after {
    content: "";
    display: block;
    width: 5px;
    height: 5px;
    border-bottom: 2px solid #ba9d77;
    border-right: 2px solid #ba9d77;
    position: absolute;
    right: 15px;
    top: 50%;
    margin-top: -4px;
  }
  #spNav > ul > li > span:after {
    transform: rotate(45deg);
  }
  #spNav > ul > li > a:after {
    transform: rotate(-45deg);
  }
  #spNav > ul > li > span:hover,
  #spNav > ul > li > a:hover {
    color: #111;
    background: #ba9d77;
    color: #fff;
  }
  #spNav > ul > li > span:hover:after,
  #spNav > ul > li > a:hover:after {
    border-bottom: 2px solid #fff;
    border-right: 2px solid #fff;
  }
  #spNav > ul > li > span.is-current > .fa {
    transform: rotate(-90deg);
  }
  #spNav > ul > li > span.is-current + .navChild {
    display: block;
  }
  #spNav > ul > li.is-current .navChild {
    pointer-events: auto;
  }
  #spNav > ul > li.spNav00, #spNav > ul > li.spNav01, #spNav > ul > li.spNav02, #spNav > ul > li.spNav03, #spNav > ul > li.spNav04, #spNav > ul > li.spNav05, #spNav > ul > li.spNav06, #spNav > ul > li.spNav07, #spNav > ul > li.spNav08, #spNav > ul > li.spNav09, #spNav > ul > li.spNav10 {
    display: -ms-flexbox;
    display: flex;
  }
  #spNav > ul > li:last-child {
    margin: 0;
  }
  #spNav > ul > li:after {
    content: none;
  }
  #spNav > ul .navChild {
    position: relative;
    top: auto;
    right: auto;
    bottom: auto;
    left: auto;
    -ms-flex-direction: column;
        flex-direction: column;
    width: 100%;
    padding: 0;
    margin: 0;
    background: #faf9f6;
    text-align: left;
    pointer-events: auto;
    opacity: 1;
    display: none;
  }
  #spNav > ul .navChild li {
    width: 100%;
    padding: 0;
  }
  #spNav > ul .navChild li > a {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-flow: row nowrap;
        flex-flow: row nowrap;
    -ms-flex-align: center;
        align-items: center;
    -ms-flex-pack: justify;
        justify-content: space-between;
    width: 100%;
    padding: .8em 1em .8em 2em;
    border-bottom: 1px solid #f0e5d8;
    color: #111;
  }
  #spNav > ul .navChild li > a > span {
    -ms-flex-order: 1;
        order: 1;
  }
  #spNav > ul .navChild li > a > .fa {
    -ms-flex-order: 2;
        order: 2;
    margin: 0;
  }
  #spNav > ul .navChild li > a:after {
    content: "";
    display: block;
    width: 5px;
    height: 5px;
    border-bottom: 2px solid #ba9d77;
    border-right: 2px solid #ba9d77;
    transform: rotate(-45deg);
    position: absolute;
    right: 15px;
    top: 50%;
    margin-top: -4px;
  }
  #spNav #headerTel {
    padding: 1em 0;
    text-align: center;
  }
  #spNav #headerTel .telNumber {
    font-size: 26px;
  }
  #spNav #loginSp {
    display: -ms-flexbox;
    display: flex;
  }
  #gNav {
    display: none;
  }
}

#footerBox {
  width: 100%;
  background: #faf9f6;
  padding: 50px;
  margin: 0;
}

#footerBox #footer {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
  width: 100%;
  max-width: 1300px;
  margin: 0 auto;
  font-size: 14px;
}

#footerBox #footer a:hover {
  opacity: .7;
}

#footerBox #footer img {
  vertical-align: bottom;
}

#footerBox #footer .footerLogo {
  margin: 0 auto 1.3em;
}

#footerBox #footer .footerLogo img {
  width: 220px;
}

#footerBox #footer .footerGuide {
  width: 35%;
}

#footerBox #footer .footerFaq {
  width: 20%;
}

#footerBox #footer .footerInfo {
  width: 45%;
}

#footerBox #footer h6 {
  font-size: 1.3em;
  margin-bottom: .5em;
}

#footerBox #footer ul {
  margin: 0 0 1em;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: column;
      flex-flow: column;
  list-style: none;
}

#footerBox #footer ul li {
  width: 100%;
  line-height: 2em;
}

#footerBox #footer ul li a {
  color: #111;
}

#footerBox #footer ul li a:before {
  content: "∟";
  display: inline-block;
  padding: 0;
  margin-right: .5em;
}

#footerBox #footer .sNav span {
  display: block;
  font-size: 14px;
}

#footerBox #footer .sNav span a {
  color: #111;
}

#footerBox #footer .sNav span a:before {
  content: "・";
  display: inline-block;
  padding: 0;
  margin-right: .5em;
}

#footerBox .footAddress {
  margin: 0 0;
  text-align: left;
}

#footerBox .footAddress p {
  margin: .1em;
}

#footerBox .footAddress a {
  color: #111;
}

#footerBox .footAddress span {
  margin: 0 10px;
}

#footerBox .footAddressTel {
  font-size: 1.5em;
}

#footerBox .footAddressTel a {
  color: #111;
}

#footerBox .footAddressTel span {
  font-size: 13px;
}

#footerBox .footAddressTel i {
  font-size: 1.1em;
  color: #ba9d77;
}

#footerBox .footAddressMail a {
  color: #111;
}

#footerBox .footAddressMail span {
  font-size: 13px;
}

#footerBox .footAddressMail i {
  margin-right: 5px;
  font-size: 1.1em;
  color: #ba9d77;
}

.footCopyright {
  width: 100%;
  padding: .5em;
  text-align: center;
  font-size: .9em;
  background: #ba9d77;
  color: #fff;
}

.pagetop {
  position: fixed;
  top: auto;
  right: 20px;
  bottom: -800px;
  left: auto;
  margin: 0;
  text-align: right;
  transition: all 0.3s ease;
  z-index: 80;
}

.pagetop.is-view {
  bottom: 150px;
}

.pagetop a {
  display: inline-block;
  width: 60px;
  height: 60px;
  border-radius: 30px;
  background: #ba9d77;
  color: #fff;
  font-size: 40px;
  line-height: 50px;
  text-align: center;
}

.pagetop a:hover {
  background: rgba(186, 157, 119, .6);
  text-decoration: none;
}

.footerLinkBg {
  width: 100%;
  padding: 100px 20px 20px;
}

.footerLink {
  width: 100%;
  max-width: 1300px;
  margin: 0 auto;
}

.footerLink ul {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: center;
      justify-content: center;
  margin: 0;
  list-style: none;
  gap: 10px 20px;
}

.footerLink li {
  width: 32%;
  margin-bottom: 20px;
}

.footerLink li:hover {
  opacity: .7;
}

@media screen and (max-width: 1024px) {
  #footerBox #footer {
    -ms-flex-pack: justify;
        justify-content: space-between;
  }
  #footerBox #footer .footerLogo {
    margin: 2em auto;
    text-align: center;
  }
  #footerBox #footer .footerLogo img {
    width: 220px;
  }
  #footerBox #footer .footerGuide {
    -ms-flex-order: 1;
        order: 1;
    width: 50%;
    margin-bottom: 2em;
  }
  #footerBox #footer .footerFaq {
    -ms-flex-order: 2;
        order: 2;
    width: 50%;
    margin-bottom: 2em;
  }
  #footerBox #footer .footerInfo {
    -ms-flex-order: 3;
        order: 3;
    width: 100%;
    text-align: center;
    border-top: 1px solid #f0e5d8;
  }
  #footerBox #footer h6 {
    font-size: 1.2em;
  }
  #footerBox .footAddress {
    text-align: center;
  }
  .pagetop {
    position: relative;
    right: auto;
    bottom: auto;
    width: 100%;
    margin-bottom: 0;
    text-align: center;
    background: #ba9d77;
  }
  .pagetop.is-view {
    bottom: auto;
  }
  .pagetop a {
    width: 100%;
    height: auto;
    color: #fff;
    font-size: 20px;
    line-height: 40px;
    text-align: center;
  }
  .footerLinkBg {
    padding: 30px 20px 10px;
  }
}

@media screen and (max-width: 768px) {
  #footerBox {
    padding: 30px 3.14vw 30px;
  }
  #footerBox #footer {
    font-size: 14px;
  }
  #footerBox #footer .footerGuide {
    width: 49%;
  }
  #footerBox #footer .footerFaq {
    width: 49%;
  }
  #footerBox #footer h6 {
    font-size: 1.1em;
    margin-bottom: .5em;
  }
  #footerBox .footAddressTel {
    font-size: 1.5em;
  }
  #footerBox .footAddressTel span {
    display: block;
  }
  #footerBox .footAddress span {
    margin: 0;
    display: block;
  }
  .footerLinkBg {
    padding: 10px 3.14vw 0;
  }
  .footerLink ul {
    -ms-flex-flow: row wrap;
        flex-flow: row wrap;
  }
  .footerLink li {
    width: 49%;
    margin-bottom: 10px;
  }
}

@media screen and (max-width: 414px) {
  #footerBox #footer {
    -ms-flex-flow: column;
        flex-flow: column;
  }
  #footerBox #footer .footerGuide {
    width: 100%;
    margin-bottom: 1em;
  }
  #footerBox #footer .footerFaq {
    width: 100%;
  }
  .footerLink li {
    width: 100%;
  }
}

@media screen and (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}

body {
  padding-top: 120px;
}

.noscript {
  display: none;
}

.fa {
  vertical-align: baseline;
}

.is-sp {
  display: none;
}

@media screen and (max-width: 1024px) {
  body {
    padding-top: 60px;
  }
}

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

@media screen and (max-width: 500px) {
  body {
    font-size: 15px;
  }
}

/* Components style
-----------------------------------*/
.column {
  -ms-flex-preferred-size: 0;
      flex-basis: 0;
  -ms-flex-positive: 1;
      flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  padding: 10px;
}

.column.is-narrow {
  -ms-flex: none;
      flex: none;
}

.column.is-full {
  -ms-flex: none;
      flex: none;
  width: 100%;
}

.column.is-three-quarters {
  -ms-flex: none;
      flex: none;
  width: 75%;
}

.column.is-two-thirds {
  -ms-flex: none;
      flex: none;
  width: 66.6666%;
}

.column.is-half {
  -ms-flex: none;
      flex: none;
  width: 50%;
}

.column.is-one-third {
  -ms-flex: none;
      flex: none;
  width: 33.3333%;
}

.column.is-one-quarter {
  -ms-flex: none;
      flex: none;
  width: 25%;
}

.column.is-offset-three-quarters {
  margin-left: 75%;
}

.column.is-offset-two-thirds {
  margin-left: 66.6666%;
}

.column.is-offset-half {
  margin-left: 50%;
}

.column.is-offset-one-third {
  margin-left: 33.3333%;
}

.column.is-offset-one-quarter {
  margin-left: 25%;
}

.column.is-1 {
  -ms-flex: none;
      flex: none;
  width: 8.33333%;
}

.column.is-offset-1 {
  margin-left: 8.33333%;
}

.column.is-2 {
  -ms-flex: none;
      flex: none;
  width: 16.66667%;
}

.column.is-offset-2 {
  margin-left: 16.66667%;
}

.column.is-3 {
  -ms-flex: none;
      flex: none;
  width: 25%;
}

.column.is-offset-3 {
  margin-left: 25%;
}

.column.is-4 {
  -ms-flex: none;
      flex: none;
  width: 33.33333%;
}

.column.is-offset-4 {
  margin-left: 33.33333%;
}

.column.is-5 {
  -ms-flex: none;
      flex: none;
  width: 41.66667%;
}

.column.is-offset-5 {
  margin-left: 41.66667%;
}

.column.is-6 {
  -ms-flex: none;
      flex: none;
  width: 50%;
}

.column.is-offset-6 {
  margin-left: 50%;
}

.column.is-7 {
  -ms-flex: none;
      flex: none;
  width: 58.33333%;
}

.column.is-offset-7 {
  margin-left: 58.33333%;
}

.column.is-8 {
  -ms-flex: none;
      flex: none;
  width: 66.66667%;
}

.column.is-offset-8 {
  margin-left: 66.66667%;
}

.column.is-9 {
  -ms-flex: none;
      flex: none;
  width: 75%;
}

.column.is-offset-9 {
  margin-left: 75%;
}

.column.is-10 {
  -ms-flex: none;
      flex: none;
  width: 83.33333%;
}

.column.is-offset-10 {
  margin-left: 83.33333%;
}

.column.is-11 {
  -ms-flex: none;
      flex: none;
  width: 91.66667%;
}

.column.is-offset-11 {
  margin-left: 91.66667%;
}

.column.is-12 {
  -ms-flex: none;
      flex: none;
  width: 100%;
}

.column.is-offset-12 {
  margin-left: 100%;
}

.column.is-order1 {
  -ms-flex-order: 1;
      order: 1;
}

.column.is-order2 {
  -ms-flex-order: 2;
      order: 2;
}

.column.is-order3 {
  -ms-flex-order: 3;
      order: 3;
}

.column.is-order4 {
  -ms-flex-order: 4;
      order: 4;
}

.column.is-order5 {
  -ms-flex-order: 5;
      order: 5;
}

.column.is-order6 {
  -ms-flex-order: 6;
      order: 6;
}

.column.is-order7 {
  -ms-flex-order: 7;
      order: 7;
}

.column.is-order8 {
  -ms-flex-order: 8;
      order: 8;
}

.column.is-order9 {
  -ms-flex-order: 9;
      order: 9;
}

.column.is-order10 {
  -ms-flex-order: 10;
      order: 10;
}

.column.is-order11 {
  -ms-flex-order: 11;
      order: 11;
}

.column.is-order12 {
  -ms-flex-order: 12;
      order: 12;
}

.columns {
  display: -ms-flexbox;
  display: flex;
  margin-left: -10px;
  margin-right: -10px;
}

.columns:last-child {
  margin-bottom: -10px;
}

.columns:not(:last-child) {
  margin-bottom: 10px;
}

.columns.is-centered {
  -ms-flex-pack: center;
      justify-content: center;
}

.columns.is-gapless {
  margin-left: 0;
  margin-right: 0;
  margin-top: 0;
}

.columns.is-gapless:last-child {
  margin-bottom: 0;
}

.columns.is-gapless:not(:last-child) {
  margin-bottom: 20px;
}

.columns.is-gapless > .column {
  margin: 0;
  padding: 0;
}

.columns.is-multiline {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.tile {
  -ms-flex-align: stretch;
      align-items: stretch;
  -ms-flex-preferred-size: auto;
      flex-basis: auto;
  -ms-flex-positive: 1;
      flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  min-height: -webkit-min-content;
  min-height: min-content;
}

.tile.is-ancestor {
  margin-left: -10px;
  margin-right: -10px;
  margin-top: -10px;
}

.tile.is-ancestor:last-child {
  margin-bottom: -10px;
}

.tile.is-ancestor:not(:last-child) {
  margin-bottom: 10px;
}

.tile.is-child {
  margin: 0 !important;
}

.tile.is-parent {
  padding: 10px;
}

.tile.is-vertical {
  -ms-flex-direction: column;
      flex-direction: column;
}

.tile.is-vertical > .tile.is-child:not(:last-child) {
  margin-bottom: 20px !important;
}

.tile:not(.is-child) {
  display: -ms-flexbox;
  display: flex;
}

.tile.is-1 {
  -ms-flex: none;
      flex: none;
  width: 8.33333%;
}

.tile.is-2 {
  -ms-flex: none;
      flex: none;
  width: 16.66667%;
}

.tile.is-3 {
  -ms-flex: none;
      flex: none;
  width: 25%;
}

.tile.is-4 {
  -ms-flex: none;
      flex: none;
  width: 33.33333%;
}

.tile.is-5 {
  -ms-flex: none;
      flex: none;
  width: 41.66667%;
}

.tile.is-6 {
  -ms-flex: none;
      flex: none;
  width: 50%;
}

.tile.is-7 {
  -ms-flex: none;
      flex: none;
  width: 58.33333%;
}

.tile.is-8 {
  -ms-flex: none;
      flex: none;
  width: 66.66667%;
}

.tile.is-9 {
  -ms-flex: none;
      flex: none;
  width: 75%;
}

.tile.is-10 {
  -ms-flex: none;
      flex: none;
  width: 83.33333%;
}

.tile.is-11 {
  -ms-flex: none;
      flex: none;
  width: 91.66667%;
}

.tile.is-12 {
  -ms-flex: none;
      flex: none;
  width: 100%;
}

/* @ breadcrumbs
// ------------------------------------------------------------ */
.breadcrumbs,
.breadcrumbsItem {
  width: 100%;
  margin: 0 auto 0;
  padding: 5px 30px;
}

.breadcrumbs ul,
.breadcrumbsItem ul {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  -ms-flex-direction: row;
      flex-direction: row;
  -ms-flex-pack: start;
      justify-content: flex-start;
  width: 100%;
  margin: 0 auto;
}

.breadcrumbs ul li,
.breadcrumbsItem ul li {
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-align: center;
      align-items: center;
  height: 30px;
  list-style: none;
  font-size: 13px;
  line-height: 1.2;
  font-family: "Noto Sans JP", sans-serif, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic";
  font-weight: 300;
  color: #333;
}

.breadcrumbs ul li a,
.breadcrumbsItem ul li a {
  text-decoration: none;
  color: #666;
}

.breadcrumbs ul li .material-icons-outlined,
.breadcrumbsItem ul li .material-icons-outlined {
  font-size: 10px;
  margin-top: -3px;
  color: #666;
}

.breadcrumbs ul li:not(:first-child):before,
.breadcrumbsItem ul li:not(:first-child):before {
  display: inline-block;
  content: '>';
  margin: 0 .7em;
}

.breadcrumbs {
  border-top: 1px solid #f0e5d8;
}

@media screen and (max-width: 768px) {
  .breadcrumbs,
  .breadcrumbsItem {
    margin: 0 auto;
    padding: 0 3.14vw;
    font-size: 11px;
  }
  .breadcrumbs ul,
  .breadcrumbsItem ul {
    display: block;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    overflow-scrolling: touch;
    overflow: auto;
    white-space: nowrap;
  }
  .breadcrumbs li,
  .breadcrumbsItem li {
    display: inline;
    -ms-flex: 0 0 40%;
        flex: 0 0 40%;
  }
}

.modal {
  bottom: 0;
  left: 0;
  right: 0;
  top: 0;
  -ms-flex-align: center;
      align-items: center;
  display: none;
  -ms-flex-pack: center;
      justify-content: center;
  overflow: hidden;
  position: fixed;
  z-index: 100000;
  padding: 0 5.867%;
  /**
	 * Movieモーダル
	 */
}

.modal.is-active {
  display: -ms-flexbox;
  display: flex;
}

.modal .delete {
  position: absolute;
  right: -22px;
  top: -22px;
  display: inline-block;
  width: 44px;
  height: 44px;
  vertical-align: top;
  background-color: #111;
  border: 2px solid #fff;
  border-radius: 50%;
  cursor: pointer;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -moz-appearance: none;
  -webkit-appearance: none;
  z-index: 100;
}

.modal .delete:before, .modal .delete:after {
  background-color: #fff;
  content: "";
  display: block;
  height: 2px;
  left: 50%;
  margin-left: -25%;
  margin-top: -1px;
  position: absolute;
  top: 50%;
  width: 50%;
}

.modal .delete:before {
  transform: rotate(45deg);
}

.modal .delete:after {
  transform: rotate(-45deg);
}

.modal-background {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  top: 0;
  background-color: rgba(17, 17, 17, .75);
}

.modal-container {
  width: 100%;
}

.modal-content {
  position: relative;
  margin: 0 auto;
  width: 100%;
  max-width: 600px;
  background: #fff;
}

.modal-content .message {
  width: 100%;
  max-height: calc(100vh - 100px);
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

.modal-content .message-body {
  padding: 30px;
}

.modal-content .message-body > *:last-child {
  margin-bottom: 0 !important;
}

.modal-content .message-header {
  padding: 20px 30px 0;
}

.modal.modalMovie .modal-content .message-body {
  padding: 0;
  border: 1px solid #fff;
}

.modal.modalComment {
  color: #311b00;
}

.modal.modalComment p:last-child {
  margin-bottom: 0 !important;
}

.modal.modalComment hr {
  margin-bottom: 25px;
}

.modal.modalComment .message-body {
  padding: 10px 30px 30px;
}

.modal.modalComment .message-header {
  text-align: center;
  font-weight: bold;
  font-size: 1.2em;
}

.modal.modalComment h5 {
  display: block;
  width: 100%;
  margin-bottom: 10px;
  padding: 5px;
  color: #fff;
  background: #311b00;
}

.modal.modalComment .prev,
.modal.modalComment .next {
  position: absolute;
  top: 50%;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  width: 44px;
  height: 44px;
  margin-top: -22px;
  font-size: 25px;
  line-height: 1;
  color: #311b00;
  background: #fff;
  border: 2px solid #311b00;
  border-radius: 22px;
  -webkit-appearance: none;
  z-index: 100;
  cursor: pointer;
}

.modal.modalComment .prev {
  left: -1em;
}

.modal.modalComment .next {
  right: -1em;
}

.modalMovie .modal-content {
  max-width: 900px;
}

.modalMovie .modal-content .message-body {
  padding: 0;
}

.modalMovie .modal-content .message-body .video-container {
  border: none;
  padding-bottom: 55.25%;
  margin: 0;
}

@media screen and (max-width: 667px) {
  .modal .delete {
    width: 38px;
    height: 38px;
    position: absolute;
    right: -16px;
    top: -16px;
  }
}

/* @ pagination
// ------------------------------------------------------------ */
.pagination {
  margin: 0;
  padding-top: 50px;
  text-align: center;
}

.pagination ul {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  -ms-flex-direction: row;
      flex-direction: row;
  -ms-flex-pack: center;
      justify-content: center;
  margin: 0;
  padding: 0;
}

.pagination ul li {
  display: inline-block;
  list-style: none;
  padding: 0 4px;
}

.pagination ul li span,
.pagination ul li a {
  display: inline-block;
  min-width: 2.2em;
  height: 2.2em;
  line-height: 2.1;
  outline: none;
  padding: 0;
  text-align: center;
  border: solid 1px #ddd;
  color: #111;
  background: #fff;
  text-decoration: none;
}

.pagination ul li span.is-current,
.pagination ul li a.is-current {
  color: #fff !important;
  background: #2a85c0;
}

.pagination ul li span.is-current:hover,
.pagination ul li a.is-current:hover {
  opacity: 1;
}

.pagination ul li.prev a,
.pagination ul li.next a {
  padding: 0 1em;
}

.pagination.single ul {
  width: 100%;
  -ms-flex-pack: justify;
      justify-content: space-between;
}

.pagination.single ul .list a {
  padding: 0 1em;
  color: #fff;
  background: #2a85c0;
}

@media screen and (max-width: 767px) {
  .pagination {
    padding-top: 30px;
  }
  .pagination ul li {
    padding: 0 2px;
  }
}

@media screen and (max-width: 414px) {
  .pagination {
    padding-top: 0;
  }
  .pagination ul li {
    font-size: 13px;
  }
  .pagination.single ul {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -ms-flex-pack: justify;
        justify-content: space-between;
  }
  .pagination.single ul li {
    width: 49%;
  }
  .pagination.single ul li a {
    width: 100%;
  }
  .pagination.single ul .prev {
    -ms-flex-order: 1;
        order: 1;
  }
  .pagination.single ul .next {
    -ms-flex-order: 2;
        order: 2;
  }
  .pagination.single ul .list {
    -ms-flex-order: 3;
        order: 3;
    width: 100%;
    padding-top: 2%;
  }
}

@media screen and (max-width: 374px) {
  .pagination ul li {
    padding: 0 1px;
  }
  .pagination ul li.prev a,
  .pagination ul li.next a {
    padding: 0 .7em;
  }
}

.touchlink {
  cursor: pointer;
}

/* Bnr
-----------------------------------------*/
.Bnr {
  position: fixed;
  top: auto;
  right: 20px;
  bottom: 20px;
  left: auto;
  margin: 0 auto;
  width: 370px;
  display: none;
  z-index: 111;
}

.Bnr img {
  vertical-align: bottom !important;
}

.Bnr .Bnr__img {
  box-shadow: 0 0 10px 3px rgba(0, 0, 0, .1);
}

.Bnr__img__inner {
  width: 370px;
  height: 100px;
  box-sizing: border-box;
}

.Bnr .Bnr__img__inner a {
  display: block;
  text-decoration: none;
}

.Bnr .Bnr__img__inner a:hover {
  opacity: .8;
}

.Bnr .Bnr__img p.close {
  position: absolute;
  right: -10px;
  top: -10px;
}

.Bnr .Bnr__img p.close {
  display: block;
  width: 30px;
  height: 30px;
  text-align: center;
  border-radius: 50%;
  background: #fff;
  border: 1px solid #ba9d77;
  text-decoration: none;
  cursor: hand;
  cursor: pointer;
  opacity: 1.2 !important;
  color: #ba9d77;
}

.Bnr .Bnr__img p {
  margin-bottom: 0 !important;
}

.Bnr .Bnr__img p.close i {
  font-size: 20px;
  z-index: 888;
  color: #ba9d77;
}

.sample {
  pointer-events: none;
}

/* Bnr
-----------------------------------------*/
.BnrC {
  position: relative;
  margin: 0 auto;
  width: 1200px;
  display: none;
  font-family: "メイリオ","Meiryo","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","ＭＳ Ｐゴシック",Osaka,sans-serif !important;
}

.BnrC .BnrC__img {
  position: fixed;
  bottom: 0;
  box-shadow: 0 4px 5px 0 rgba(0, 0, 0, .14), 0 1px 10px 0 rgba(0, 0, 0, .12), 0 2px 4px -1px rgba(0, 0, 0, .2);
  z-index: 88;
}

.BnrC__img__inner {
  width: 1200px;
  height: 80px;
  box-sizing: border-box;
  padding: 10px;
  background-color: #fafafa;
}

.BnrC .BnrC__img__inner a {
  display: block;
}

.BnrC .BnrC__img p.close {
  position: absolute;
  right: 10px;
  top: 10px;
}

.BnrC .BnrC__img p.close a {
  display: block;
  width: 20px;
  height: 25px;
  text-align: center;
}

.BnrC .BnrC__img p.close a span {
  display: block;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.BnrC .BnrC__img p.close a i {
  font-size: 20px;
  z-index: 888;
  color: #222;
}

@media screen and (max-width: 600px) {
  .Bnr {
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
  }
}

@media screen and (max-width: 414px) {
  .Bnr {
    width: 80%;
    text-align: center;
  }
  .Bnr__img__inner {
    width: 100%;
    height: auto;
  }
}

/* View style
-----------------------------------*/
/* window size
-----------------*/
/* font
-----------------*/
/* color
-----------------*/
.indexKv {
  width: 100%;
  height: 100%;
  margin: 0 auto;
}

.indexKv .pcOnly {
  display: block;
}

.indexKv .spOnly {
  display: none;
}

.indexSlide img {
  width: 100%;
}

.indexMv {
  margin: 100px auto;
  padding: 0 20px;
  text-align: center;
}

.indexMv video {
  margin: 0 auto;
  width: 100%;
  max-width: 1000px;
  height: auto;
  aspect-ratio: 16 / 9;
  display: block;
}

.slick-dots {
  position: absolute;
}

.slick-dots li button:before {
  color: #ba9d77;
  opacity: .7;
}

.slick-dots li button:before {
  font-size: 24px !important;
}

.slick-dots li.slick-active button:before {
  color: #d60320;
  opacity: 1;
}

.slick-prev,
.slick-next {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-line-pack: center;
      align-content: center;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  z-index: 101 !important;
  height: 60px !important;
  width: 30px !important;
  font-size: 1em  !important;
  color: #fff  !important;
  background: #000  !important;
  opacity: .8;
  text-align: center;
}

.slick-prev {
  left: 0;
}

.slick-next {
  right: 0;
}

.indexTitle h2 {
  font-size: 2.5em;
  padding: 1em;
  text-align: center;
  font-weight: 200;
  margin-bottom: 1.5em;
}

.indexTitle h2:before {
  position: absolute;
  bottom: -10px;
  left: calc(50% - 30px);
  width: 50px;
  height: 1px;
  content: '';
  background: #111;
}

.indexProduct {
  margin: 100px auto;
}

.indexProduct a {
  color: #111;
  text-decoration: none;
}

.indexProduct a:hover {
  color: #ba9d77;
}

.indexProductEn {
  font-size: .9em;
  margin-bottom: 0 !important;
}

.indexProductJp {
  font-size: 2em;
  margin-bottom: 0 !important;
}

.indexProduct img {
  transition: 1s all;
}

.indexProduct img:hover {
  transform: scale(1.1, 1.1);
  transition: 1s all;
}

.indexProduct img:hover :before {
  background: #000;
}

.indexSlide_products {
  text-align: center;
  overflow: hidden;
}

.indexSlide_products .slick-slide img {
  padding: 0 10px;
}

.indexNews {
  margin: 100px auto 50px;
  padding: 0 20px;
  width: 100%;
  max-width: 800px;
}

.indexNewsBox .accordion_one {
  line-height: 1.8;
}

.indexNewsBox .accordion_one .accordion_header {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row;
      flex-flow: row;
  -ms-flex-pack: start;
      justify-content: start;
  border-bottom: 1px solid #f0e5d8;
  font-size: 15px;
  line-height: 1.6;
  padding: 1em;
  text-align: left;
  position: relative;
  z-index: +1;
  cursor: pointer;
  transition-duration: 0.2s;
}

.indexNewsBox .accordion_one .accordion_header .newsDate {
  width: 18%;
}

.indexNewsBox .accordion_one .accordion_header .newsTit {
  width: 72%;
}

.indexNewsBox .accordion_one .accordion_header:hover {
  opacity: .8;
}

.indexNewsBox .accordion_one .accordion_header .i_box {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  position: absolute;
  top: 50%;
  right: 2%;
  width: 40px;
  height: 40px;
  margin-top: -20px;
  box-sizing: border-box;
  transform: rotate(45deg);
  transform-origin: center center;
  transition-duration: 0.2s;
}

.indexNewsBox .accordion_one .accordion_header.stay .i_box {
  transform: rotate(0deg);
}

.indexNewsBox .accordion_one .accordion_header .i_box .one_i {
  display: block;
  width: 10px;
  height: 10px;
  transform: rotate(45deg);
  transform-origin: center center;
  transition-duration: 0.2s;
  position: relative;
}

.indexNewsBox .accordion_one .accordion_header.stay .i_box .one_i {
  transform: rotate(0deg);
}

.indexNewsBox .accordion_one .accordion_header.stay.open .i_box .one_i {
  transform: rotate(45deg);
}

.indexNewsBox .accordion_one .accordion_header.open .i_box {
  transform: rotate(-360deg);
}

.indexNewsBox .accordion_one .accordion_header.stay.open .i_box {
  transform: rotate(315deg);
}

.indexNewsBox .accordion_one .accordion_header .i_box .one_i:before, .indexNewsBox .accordion_one .accordion_header .i_box .one_i:after {
  display: -ms-flexbox;
  display: flex;
  content: '';
  background-color: #ba9d77;
  border-radius: 10px;
  width: 10px;
  height: 2px;
  position: absolute;
  top: 4px;
  left: 0;
  transform: rotate(0deg);
  transform-origin: center center;
}

.indexNewsBox .accordion_one .accordion_header .i_box .one_i:before {
  width: 2px;
  height: 10px;
  top: 0;
  left: 4px;
}

.indexNewsBox .accordion_one .accordion_header.stay .i_box .one_i:before {
  content: none;
}

.indexNewsBox .accordion_one .accordion_header.open .i_box .one_i:before {
  content: none;
}

.indexNewsBox .accordion_one .accordion_header.stay.open .i_box .one_i:before {
  content: "";
}

.indexNewsBox .accordion_one .accordion_header.open .i_box .one_i:after {
  transform: rotate(-45deg);
}

.indexNewsBox .accordion_one .accordion_header.stay.open .i_box .one_i:after {
  transform: rotate(0deg);
}

.indexNewsBox .accordion_one .accordion_inner {
  display: none;
  padding: 2em;
  margin: 20px 0;
  box-sizing: border-box;
  background: #faf9f6;
  font-size: 14px;
}

.indexNewsBox .accordion_one .accordion_inner.stay {
  display: block;
}

.indexNewsBox .accordion_one .accordion_inner p.txt_a_ac {
  margin: 0;
}

#indexAbout .buttonSingle {
  margin-bottom: 0 !important;
}

@media screen and (max-width: 1024px) {
  .indexTitle h2 {
    font-size: 2em;
  }
  .indexNews {
    margin: 50px auto 30px;
  }
  .indexMv {
    margin: 50px auto 0;
  }
  .indexMv video {
    max-width: 100%;
  }
  .indexProduct {
    margin: 50px auto 0;
  }
  .indexProduct p {
    padding: 0 20px;
  }
  .indexProductJp {
    font-size: 1.6em;
    margin-bottom: 0 !important;
  }
}

@media screen and (max-width: 768px) {
  .indexTitle h2 {
    font-size: 1.7em;
  }
  .indexProduct {
    margin: 30px auto 0;
  }
  .indexProductEn {
    font-size: .85em;
    margin-bottom: 0 !important;
  }
  .indexProductJp {
    font-size: 1.5em;
    margin-bottom: 0 !important;
  }
  .indexNewsBox .accordion_one .accordion_header {
    padding: 1em .5em;
  }
  .indexNewsBox .accordion_one .accordion_header::after {
    width: 25px;
  }
  .indexNewsBox .accordion_one .accordion_inner {
    padding: 20px 3.14vw;
  }
  .indexNewsBox .accordion_one .accordion_header .newsDate {
    width: 25%;
  }
  .indexNewsBox .accordion_one .accordion_header .newsTit {
    width: 65%;
  }
}

@media screen and (max-width: 667px) {
  .indexKv .pcOnly {
    display: none;
  }
  .indexKv .spOnly {
    display: block;
  }
  .slick-prev,
  .slick-next {
    height: 50px !important;
    width: 20px !important;
  }
}

@media screen and (max-width: 568px) {
  .indexSlide_products {
    text-align: center;
    overflow: hidden;
  }
  .indexSlide_products .slick-slide img {
    padding: 0 10px;
  }
  .indexNewsBox .accordion_one .accordion_header {
    -ms-flex-flow: column;
        flex-flow: column;
  }
  .indexNewsBox .accordion_one .accordion_header .newsDate {
    width: 100%;
  }
  .indexNewsBox .accordion_one .accordion_header .newsTit {
    width: 90%;
  }
}

body.is-eventNone * {
  pointer-events: none !important;
}

.inview {
  opacity: 0;
  transition: all 1s ease;
  transform: translate(0, 70px);
}

.inview.is-view {
  opacity: 1;
  transform: translate(0, 0);
}

.inner {
  width: 100%;
  max-width: 1360px;
  padding: 100px 30px 0;
  margin: 0 auto;
}

.backGold {
  width: 100%;
  margin: 0 auto;
  padding: 100px 0;
  background: #faf9f6;
}

.ffSunsSerif {
  font-family: "Noto Sans JP", sans-serif, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic";
}

.pageKv {
  width: 100%;
  margin: 0 auto 0;
  padding: 0 30px;
  text-align: center;
}

.pageTitle h2 {
  width: 100%;
  margin: 0 auto;
  padding: 70px 30px;
  max-width: 1360px;
  font-family: "Noto Serif JP", serif, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝";
  font-weight: 200;
  font-size: 2.2em;
  line-height: 1.2em;
}

.pageTitle h2 span {
  display: block;
  font-size: 13px;
  margin: 0;
}

.pageTitle h3 {
  font-size: 2.2em;
  padding: 0 0 1em;
  margin-bottom: 1.5em;
  line-height: 1.6;
}

.pageTitle h3:before {
  position: absolute;
  bottom: -10px;
  left: 0;
  width: 50px;
  height: 1px;
  content: '';
  background: #111;
}

.pageTitle h4 {
  position: relative;
  padding: .6em 2em;
  margin-bottom: 1.5em;
  border: 1px solid #f0e5d8;
  font-size: 1.6em;
  background: #faf9f6;
  line-height: 1.6;
}

.pageTitle h4::after {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  content: '';
  width: 25px;
  height: 5px;
  background-color: #ba9d77;
}

.pageTitle h5 {
  margin-bottom: 1em;
  font-size: 1.4em;
  line-height: 1.6;
}

.pageTitle p {
  margin-bottom: 1em;
  text-align: center;
}

.pageTitleEn {
  font-size: .7em;
  color: #71797e;
  text-align: center;
}

.pageTitleMark {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
}

.pageTitleMark img {
  width: 30px;
  height: 100%;
}

.section50 {
  padding: 0 0 50px;
}

.section100 {
  padding: 0 0 100px;
}

.pageNav2column ul {
  width: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  list-style: none;
  margin: 0;
}

.pageNav2column ul li {
  width: 50%;
  border-left: 1px solid #f0e5d8;
  border-top: 1px solid #f0e5d8;
  border-bottom: 1px solid #f0e5d8;
  padding: .8em 0 .8em 1em;
  font-size: 1.2em;
  text-align: center;
}

.pageNav2column ul li:nth-child(2n) {
  border-right: 1px solid #f0e5d8;
}

.pageNav2column ul li:nth-child(n+3) {
  border-top: 0;
}

.pageNav2column ul li a {
  display: block;
  width: 100%;
  color: #111;
}

.pageNav2column ul li a:hover {
  text-decoration: none;
}

.pageNav2column ul li a:after {
  position: absolute;
  display: inline-block;
  font-family: 'Material Icons';
  content: '\e5df';
  color: #ba9d77;
  right: 0;
  top: 0;
  bottom: 0;
  font-size: 26px;
  line-height: 1.4;
}

.pageNav2column ul li:hover {
  background: #f5eee5;
  transition: all 0.5s ease;
}

.pageNav3column {
  margin: 0 auto 2em;
}

.pageNav3column ul {
  width: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  list-style: none;
  margin: 0;
}

.pageNav3column ul li {
  width: 33.3333%;
  border-left: 1px solid #f0e5d8;
  border-top: 1px solid #f0e5d8;
  border-bottom: 1px solid #f0e5d8;
  padding: .8em 1em;
  font-size: 1.2em;
  text-align: center;
}

.pageNav3column ul li:nth-child(3n) {
  border-right: 1px solid #f0e5d8;
}

.pageNav3column ul li:nth-child(n+4) {
  border-top: 0;
}

.pageNav3column ul li a {
  display: block;
  width: 100%;
  color: #111;
}

.pageNav3column ul li a:hover {
  text-decoration: none;
}

.pageNav3column ul li a:after {
  position: absolute;
  display: inline-block;
  font-family: 'Material Icons';
  content: '\e5df';
  color: #ba9d77;
  right: 0;
  top: 0;
  bottom: 0;
}

.pageNav3column ul li:hover {
  background: #f5eee5;
  transition: all 0.5s ease;
}

.layoutBox {
  position: relative;
  width: 100%;
  padding: 0;
  margin: 0 auto;
}

.layoutBox p br {
  display: inline-block;
}

.layoutBox .flex {
  display: -ms-flexbox;
  display: flex;
}

.layoutBox .boxImg {
  width: 50%;
  height: 100%;
  overflow: hidden;
}

.layoutBox .boxImg img {
  vertical-align: bottom;
}

.layoutBox .boxImg video {
  width: 100% !important;
  height: 100% !important;
}

.layoutBox .boxText {
  width: 60%;
  height: 100%;
  padding: 80px;
  margin-top: 100px;
  margin-left: -60px;
  z-index: 1;
  text-align: left;
  background: #fff;
  opacity: .9;
}

.layoutBox .boxTextLeft {
  width: 60%;
  height: 100%;
  padding: 80px;
  margin-top: 100px;
  margin-right: -60px;
  z-index: 1;
  text-align: left;
  background: #fff;
  opacity: .9;
}

.layoutBox .boxText h3,
.layoutBox .boxTextLeft h3 {
  font-size: 2.2em;
  padding: 0 0 1em;
  margin-bottom: 1.5em;
  line-height: 1.6;
}

.layoutBox .boxText .subCopy,
.layoutBox .boxTextLeft .subCopy {
  font-size: 1.5em;
}

.layoutBox .boxText h3:before,
.layoutBox .boxTextLeft h3:before {
  position: absolute;
  bottom: -10px;
  left: 0;
  width: 50px;
  height: 1px;
  content: '';
  background: #111;
}

.layoutBox .subCopy {
  font-size: 1.5em;
}

.layoutBox .iconCom {
  display: inline-block;
  margin: 0 0 1em;
  padding: .2em .5em;
  background: #ba9d77;
  color: #fff;
  font-size: 1.1em;
  font-weight: 500;
}

.read2column {
  display: -ms-flexbox;
  display: flex;
  margin: 0;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-align: center;
      align-items: center;
}

.read2column .copy {
  width: 35%;
  font-size: 2.2em;
  font-weight: 200;
}

.read2column .text {
  width: 60%;
}

.page2column {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
}

.page2column img {
  vertical-align: bottom;
}

.page2columnImg {
  width: 47%;
}

.page2columnImg img {
  height: auto;
}

.page2columnText {
  width: 47%;
}

.page3column {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
}

.page3column img {
  vertical-align: bottom;
}

.page3column div {
  width: 30%;
}

.button {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

.buttonSingle {
  display: inline-block;
  padding: 0;
  margin: 2em auto 0em;
}

.buttonSingle a {
  width: 100%;
  display: inline-block;
  padding: .8em 4em;
  margin: 0 auto;
  overflow: hidden;
  text-align: center;
  font-size: 1.1em;
  border: 1px solid #ba9d77;
  color: #111;
}

.buttonSingle a:hover {
  transition: all 2s ease;
  text-decoration: none;
  background: #f0e5d8;
  opacity: 1;
}

.buttonSingle::before {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 30px 30px 0 0;
  border-color: #ba9d77 transparent transparent transparent;
  z-index: 1;
}

.buttonSingle100 {
  width: 100%;
  padding: 0;
  margin: 2em auto;
}

.buttonSingle100 a {
  width: 100%;
  display: inline-block;
  border-radius: 100px;
  padding: .5em 1em;
  margin: 0 auto;
  overflow: hidden;
  text-align: center;
  background: #004181;
  background: linear-gradient(to right, #0072e2 0%, #004181 100%);
  color: #fff;
  font-size: 26px;
}

.buttonSingle100 a:after {
  content: "";
  display: block;
  width: 5px;
  height: 5px;
  border-bottom: 3px solid #fff;
  border-right: 3px solid #fff;
  transform: rotate(-45deg);
  position: absolute;
  right: 15px;
  top: 50%;
  margin-top: -4px;
  transition: border 300ms;
}

.buttonSingle100 a:hover {
  opacity: .7;
  transition: all 0.5s ease;
  text-decoration: none;
}

.button2Column {
  width: 100%;
  padding: 0;
  margin: 2em auto;
}

.button2Column ul {
  width: 100%;
  margin: 0;
  list-style: none;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-align: stretch;
      align-items: stretch;
  -ms-flex-line-pack: end;
      align-content: end;
}

.button2Column li {
  width: 48%;
}

.button2Column li a {
  width: 100%;
  display: inline-block;
  border: solid 1px #49c3b3;
  border-radius: 100px;
  padding: .7em 2em;
  margin: 0 auto;
  overflow: hidden;
  transition: color 300ms;
  transform: perspective(1px) translateZ(0);
  text-align: center;
  color: #0b4c8d;
  font-size: 18px;
  font-weight: 500;
}

.button2Column li a:after {
  content: "";
  display: block;
  width: 4px;
  height: 4px;
  border-bottom: 2px solid #0b4c8d;
  border-right: 2px solid #0b4c8d;
  transform: rotate(-45deg);
  position: absolute;
  right: 15px;
  top: 50%;
  margin-top: -4px;
  transition: border 300ms;
}

.button2Column li a::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #0b4c8d;
  transform: scaleX(0);
  transform-origin: 0 50%;
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease-out;
}

.button2Column li a:hover {
  color: #fff !important;
}

.button2Column li a:hover::after {
  border-bottom: 2px solid #fff;
  border-right: 2px solid #fff;
}

.button2Column li a:hover::before {
  transform: scaleX(1);
}

.table {
  width: 100%;
  background: #f0e5d8;
  margin: 0 auto 2em;
}

.table td {
  background: #fff;
  vertical-align: middle;
}

.table thead th {
  text-align: center;
  vertical-align: middle;
}

.table th {
  text-align: left;
  background: #faf9f6;
  width: 25%;
  vertical-align: middle;
}

.table02 {
  margin: 0 auto;
  border-bottom: 1px solid #f0e5d8;
}

.table02 table {
  margin-bottom: 0 !important;
}

.table02 td {
  border-top: 1px solid #f0e5d8;
  padding: .8em 1em;
}

.table02 thead th {
  text-align: center;
  vertical-align: middle;
}

.table02 th {
  border-top: 1px solid #f0e5d8;
  background-color: #faf9f6;
  padding: .8em 1em;
  text-align: left;
  width: 25%;
}

.check ul {
  list-style: none;
  margin: 0;
  list-style-position: outside;
}

.check li {
  position: relative;
  padding-left: 1.5em;
  margin-bottom: .5em;
}

.check li:before {
  position: absolute;
  font-family: 'Material Icons';
  content: '\e92d';
  color: #ba9d77;
  top: 0;
  /* 要素によって要調整 */
  left: 0;
  display: inline-block;
}

.contactTel {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row nowrap;
      flex-flow: row nowrap;
  -ms-flex-pack: start;
      justify-content: start;
  -ms-flex-align: center;
      align-items: center;
  padding: 2em 3em;
  border: 1px solid #ba9d77;
  border-radius: 10px;
}

.contactTelLeft {
  padding-right: 2em;
  border-right: 1px solid #ba9d77;
  white-space: nowrap;
  font-size: 1.4em;
}

.contactTelRight {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row;
      flex-flow: row;
  -ms-flex-align: center;
      align-items: center;
  padding-left: 2em;
}

.contactTelRightNo {
  font-size: 1.8em;
}

.contactTelRightNo a {
  color: #111;
}

.contactTelRightTime {
  line-height: 1.6em;
  padding-left: 1em;
}

.contactTel .material-icons-outlined {
  margin-top: -5px !important;
  color: #ba9d77 !important;
  font-size: 28px !important;
  transform: rotate(15deg);
}

.accordion .accordion_one {
  line-height: 1.8;
}

.accordion .accordion_one .accordion_header {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row;
      flex-flow: row;
  -ms-flex-pack: start;
      justify-content: start;
  border-bottom: 1px solid #f0e5d8;
  font-size: 1.1em;
  line-height: 1.6;
  padding: 1em;
  text-align: left;
  position: relative;
  z-index: +1;
  cursor: pointer;
  transition-duration: 0.2s;
}

.accordion .accordion_one .accordion_header:hover {
  opacity: .8;
}

.accordion .accordion_one .accordion_header .i_box {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  position: absolute;
  top: 50%;
  right: 2%;
  width: 40px;
  height: 40px;
  margin-top: -20px;
  box-sizing: border-box;
  transform: rotate(45deg);
  transform-origin: center center;
  transition-duration: 0.2s;
}

.accordion .accordion_one .accordion_header.stay .i_box {
  transform: rotate(0deg);
}

.accordion .accordion_one .accordion_header .i_box .one_i {
  display: block;
  width: 10px;
  height: 10px;
  transform: rotate(45deg);
  transform-origin: center center;
  transition-duration: 0.2s;
  position: relative;
}

.accordion .accordion_one .accordion_header.stay .i_box .one_i {
  transform: rotate(0deg);
}

.accordion .accordion_one .accordion_header.stay.open .i_box .one_i {
  transform: rotate(45deg);
}

.accordion .accordion_one .accordion_header.open .i_box {
  transform: rotate(-360deg);
}

.accordion .accordion_one .accordion_header.stay.open .i_box {
  transform: rotate(315deg);
}

.accordion .accordion_one .accordion_header .i_box .one_i:before, .accordion .accordion_one .accordion_header .i_box .one_i:after {
  display: -ms-flexbox;
  display: flex;
  content: '';
  background-color: #ba9d77;
  border-radius: 10px;
  width: 12px;
  height: 2px;
  position: absolute;
  top: 5px;
  left: 0;
  transform: rotate(0deg);
  transform-origin: center center;
}

.accordion .accordion_one .accordion_header .i_box .one_i:before {
  width: 2px;
  height: 12px;
  top: 0;
  left: 5px;
}

.accordion .accordion_one .accordion_header.stay .i_box .one_i:before {
  content: none;
}

.accordion .accordion_one .accordion_header.open .i_box .one_i:before {
  content: none;
}

.accordion .accordion_one .accordion_header.stay.open .i_box .one_i:before {
  content: "";
}

.accordion .accordion_one .accordion_header.open .i_box .one_i:after {
  transform: rotate(-45deg);
}

.accordion .accordion_one .accordion_header.stay.open .i_box .one_i:after {
  transform: rotate(0deg);
}

.accordion .accordion_one .accordion_inner {
  font-size: 1em;
  display: none;
  padding: 1em 2em;
  margin: 20px 0;
  box-sizing: border-box;
}

.accordion .accordion_one .accordion_inner.stay {
  display: block;
}

.accordion .accordion_one .accordion_inner p.txt_a_ac {
  margin: 0;
}

@media screen and (max-width: 1200px) {
  .layoutBox .boxImg {
    width: 40%;
  }
  .layoutBox .boxText,
  .layoutBox .boxTextLeft {
    width: 70%;
    padding: 30px;
  }
  .layoutBox .boxText h3 br,
  .layoutBox .boxTextLeft h3 br {
    display: none;
  }
  .read2column .copy {
    width: 35%;
    font-size: 2em;
  }
  .read2column .text {
    width: 60%;
  }
}

@media screen and (max-width: 1024px) {
  .inner {
    max-width: 100%;
    padding: 50px 30px 0;
  }
  .backGold {
    padding: 50px 0;
  }
  .pageTitle h2 {
    padding: 50px 30px;
    font-size: 1.8em;
  }
  .pageTitle h2 span {
    display: inline-block;
    margin-left: 1em;
  }
  .pageTitle h3 {
    font-size: 1.8em;
  }
  .layoutBox .flex {
    -ms-flex-flow: column wrap;
        flex-flow: column wrap;
  }
  .layoutBox .boxImg {
    -ms-flex-order: 1;
        order: 1;
    width: 100%;
    height: 350px;
    overflow: hidden;
  }
  .layoutBox .boxText h3,
  .layoutBox .boxTextLeft h3 {
    font-size: 2em;
    padding: 0 0 .8em;
    margin-bottom: 1.5em;
  }
  .layoutBox .boxText,
  .layoutBox .boxTextLeft {
    -ms-flex-order: 2;
        order: 2;
    width: 90%;
    height: 100%;
    margin: -50px auto 0;
    opacity: 1;
  }
  .read2column {
    -ms-flex-flow: column;
        flex-flow: column;
  }
  .read2column .copy {
    width: 100%;
    font-size: 2em;
    margin-bottom: 1em;
  }
  .read2column .copy br {
    display: none;
  }
  .read2column .text {
    width: 100%;
  }
  .pageNav3column {
    margin: 0 auto 2em;
  }
  .pageNav3column ul li {
    width: 50%;
    border-left: 1px solid #f0e5d8;
    border-top: 1px solid #f0e5d8;
    border-bottom: 1px solid #f0e5d8;
  }
  .pageNav3column ul li:nth-child(2n) {
    border-right: 1px solid #f0e5d8;
  }
  .pageNav3column ul li:nth-child(3n) {
    border-right: 0;
  }
  .pageNav3column ul li:nth-child(n+3) {
    border-top: 0;
  }
  .pageNav3column ul li:last-child {
    border-right: 1px solid #f0e5d8;
  }
  .contactTel {
    padding: 1.5em 2em;
  }
  .contactTelLeft {
    padding-right: 1em;
    font-size: 1.2em;
  }
  .contactTelRight {
    padding-left: 1em;
  }
  .contactTelRightNo {
    font-size: 1.6em;
  }
  .contactTelRightTime {
    padding-left: .5em;
    font-size: .9em;
  }
  .contactTel .material-icons-outlined {
    margin-top: -5px !important;
    font-size: 26px !important;
  }
}

@media screen and (max-width: 900px) {
  .page2column {
    -ms-flex-flow: column;
        flex-flow: column;
  }
  .page2columnImg {
    width: 70%;
    margin: 0 auto 1em;
  }
  .page2columnText {
    width: 100%;
  }
  .page3column div {
    width: 47%;
  }
  .section50 {
    padding: 0 0 30px;
  }
  .section100 {
    padding: 0 0 50px;
  }
  .pageNav2column ul li, .pageNav3column ul li {
    font-size: 1.1em;
    padding: .6em 0 .6em 1em;
  }
  .pageNav2column ul li a:after, .pageNav3column ul li a:after {
    line-height: 1.2;
  }
  .buttonSingle, .buttonSingle100 {
    width: 100%;
  }
  .button2Column ul {
    -ms-flex-flow: column;
        flex-flow: column;
  }
  .button2Column li {
    width: 100%;
    margin: 0 auto 10px;
  }
  .contactTel {
    padding: 1em 2em;
  }
  .contactTelRight {
    -ms-flex-flow: column;
        flex-flow: column;
    -ms-flex-pack: left;
        justify-content: left;
  }
}

@media screen and (max-width: 768px) {
  .backGold {
    padding: 30px 0;
  }
  .inner {
    padding: 20px 3.14vw;
  }
  .pageTitle h2 {
    padding: 30px 3.14vw;
    font-size: 1.7em;
  }
  .pageTitle h2 span {
    font-size: 12px;
  }
  .pageTitle h3 {
    font-size: 1.6em;
  }
  .pageTitle h4 {
    font-size: 1.4em;
  }
  .pageTitle h4::after {
    width: 25px;
  }
  .pageTitle h5 {
    font-size: 1.2em;
  }
  .pageTitle p p {
    margin-bottom: .5em;
  }
  .pageTitleMark img {
    width: 20px;
  }
  .section50 {
    padding: 0 0 20px;
  }
  .section100 {
    padding: 0 0 30px;
  }
  .pageKv {
    padding: 0 3.14vw;
  }
  .page3column {
    -ms-flex-flow: column;
        flex-flow: column;
    -ms-flex-pack: justify;
        justify-content: space-between;
  }
  .page3column div {
    width: 100%;
  }
  .layoutBox {
    padding: 30px 0;
  }
  .layoutBox .boxText h3,
  .layoutBox .boxTextLeft h3 {
    font-size: 1.6em;
  }
  .layoutBox .boxText .subCopy,
  .layoutBox .boxTextLeft .subCopy {
    font-size: 1.2em;
  }
  .read2column .copy {
    font-size: 1.5em;
  }
  .table {
    width: 100%;
  }
  .table tbody, .table tr, .table th, .table td {
    display: block;
    width: 100%;
  }
  .table thead th {
    text-align: center;
    width: 100%;
  }
  .table th, .table td {
    padding: 6px 10px;
  }
  .table th {
    font-weight: 500;
    text-align: left;
  }
  .table th.th1 {
    width: 100%;
  }
  .table th.th2 {
    width: 100%;
  }
  .table02 tbody, .table02 tr, .table02 th, .table02 td {
    display: block;
    width: 100%;
  }
  .table02 thead th {
    text-align: center;
    width: 100%;
  }
  .table02 th, .table02 td {
    padding: 6px 10px;
  }
  .table02 th {
    font-weight: 500;
    text-align: left;
  }
  .table02 th.th1 {
    width: 100%;
  }
  .table02 th.th2 {
    width: 100%;
  }
  .buttonSingle, .buttonSingle100 {
    width: 100%;
  }
  .buttonSingle a, .buttonSingle100 a {
    padding: .5em 2em;
    font-size: 1.1;
  }
  .button2Column ul {
    -ms-flex-flow: column;
        flex-flow: column;
  }
  .button2Column li {
    width: 100%;
    margin: 0 auto 10px;
  }
  .accordion .accordion_one .accordion_header {
    padding: 1em .5em;
  }
  .accordion .accordion_one .accordion_header::after {
    width: 25px;
  }
  .accordion .accordion_one .accordion_inner {
    margin: 10px;
  }
}

@media screen and (max-width: 667px) {
  .pageMainTitle {
    margin-bottom: 20px;
  }
  .pageNav2column, .pageNav3column {
    margin: 0 auto 2em;
  }
  .pageNav2column ul, .pageNav3column ul {
    -ms-flex-flow: column;
        flex-flow: column;
  }
  .pageNav2column ul li, .pageNav3column ul li {
    font-size: 1.1;
    width: 100%;
    border: 1px solid #f0e5d8;
    border-left: 1px solid #f0e5d8;
    border-top: 1px solid #f0e5d8;
    border-bottom: 1px solid #f0e5d8;
  }
  .pageNav2column ul li:nth-child(2n), .pageNav3column ul li:nth-child(2n) {
    border-right: 1px solid #f0e5d8;
  }
  .pageNav2column ul li:nth-child(3n), .pageNav3column ul li:nth-child(3n) {
    border-right: 1px solid #f0e5d8;
  }
  .pageNav2column ul li:nth-child(n+2), .pageNav3column ul li:nth-child(n+2) {
    border-top: 0;
  }
  .pageNav2column ul li:last-child, .pageNav3column ul li:last-child {
    border-right: 1px solid #f0e5d8;
  }
}

@media screen and (max-width: 568px) {
  .pageTitle h2 {
    font-size: 1.4em;
  }
  .pageTitle h3 {
    font-size: 1.3em;
  }
  .pageTitle h4 {
    font-size: 1.2em;
  }
  .pageTitle h4::after {
    width: 20px;
  }
  .pageTitle h5 {
    font-size: 1.1em;
  }
  .section50 {
    padding: 0 0 10px;
  }
  .section100 {
    padding: 0 0 20px;
  }
  .layoutBox .boxImg {
    height: auto;
  }
  .layoutBox .boxText h3,
  .layoutBox .boxTextLeft h3 {
    font-size: 1.3em;
    padding: 0 0 .8em;
    margin-bottom: 1.5em;
  }
  .pageNav2column ul li, .pageNav3column ul li {
    font-size: 1em;
  }
  .accordion .accordion_one .accordion_header {
    -ms-flex-flow: column;
        flex-flow: column;
    font-size: 1em;
  }
  .accordion .accordion_one .accordion_inner {
    font-size: .9em;
  }
}

@media screen and (max-width: 500px) {
  .pageTitle h2 {
    padding: 20px 3.14vw;
  }
  .pageTitle h2 span {
    display: block;
    font-size: 11px;
    margin-left: 0;
  }
  .contactTel {
    padding: 1em;
    -ms-flex-flow: column;
        flex-flow: column;
  }
  .contactTelLeft {
    padding-right: 0;
    border-right: 0;
    border-bottom: 1px solid #ba9d77;
    font-size: 1.2em;
  }
  .contactTelRight {
    padding-left: 0;
    padding-top: .5em;
    -ms-flex-flow: column;
        flex-flow: column;
    -ms-flex-pack: center;
        justify-content: center;
    text-align: center;
  }
  .contactTelRightNo {
    font-size: 1.4em;
  }
  .contactTel .material-icons-outlined {
    margin-top: -3px;
    font-size: 20px !important;
  }
}

@media screen and (max-width: 414px) {
  .pageNav3column {
    margin: 0 auto 2em;
  }
  .pageNav3column ul {
    width: 100%;
    -ms-flex-flow: column;
        flex-flow: column;
  }
  .pageNav3column ul li {
    -ms-flex: auto;
        flex: auto;
    width: 100%;
    border-right: 2px solid #eee;
  }
  .pageNav3column ul li:nth-child(3n) {
    border-right: 2px solid #eee;
  }
  .pageNav3column ul li:nth-child(n+2) {
    border-top: 0px;
  }
  .page2columnImg {
    width: 100%;
  }
}

@media screen and (max-width: 375px) {
  .pageMainTitleH1 {
    font-size: 1.1em;
  }
  .buttonSingle a, .buttonSingle100 a {
    padding: .3em 1em;
    font-size: 18px;
  }
}

.has-sidebar .sidebarSection {
  width: 100%;
  margin-bottom: 25px;
  border: 1px solid #ddd;
}

.has-sidebar .sidebarSection .title {
  width: 100%;
  padding: 10px 20px;
  font-size: 20px;
  background: #e9e9e9;
  border-bottom: 1px solid #ddd;
}

.has-sidebar .sidebarSection .content {
  padding: 20px 10px;
}

.has-sidebar .sidebarSection .content > *:last-child {
  margin-bottom: 0;
}

.has-sidebar .sidebarSection .searchForm button {
  height: 30px;
}

.has-sidebar .sidebarCatList {
  width: 100%;
  margin: 0;
  list-style: none;
}

.has-sidebar .sidebarCatList li {
  width: 100%;
}

.has-sidebar .sidebarCatList li:not(:last-child) {
  border-bottom: 1px solid #ddd;
}

.has-sidebar .sidebarCatList li a {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row nowrap;
      flex-flow: row nowrap;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: justify;
      justify-content: space-between;
  padding: 10px 10px 10px 20px;
}

@media screen and (max-width: 767px) {
  .has-sidebar .sidebar {
    padding-top: 20px;
  }
  .has-sidebar .sidebarSection:last-child {
    margin-bottom: 0;
  }
  .has-sidebar .sidebarSection .title {
    font-size: 18px;
    padding: 10px 3.5%;
  }
  .has-sidebar .sidebarCatList li a {
    padding: 10px 1.75% 10px 3.5%;
  }
}

.news {
  width: 100%;
  max-width: 1280px;
  padding: 0 40px;
  margin: 100px auto;
}

.newsBox ul {
  border: 3px solid #eee;
  padding: 20px 30px;
  margin: 0;
  list-style: none;
}

.newsBox .newsList {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: column nowrap;
      flex-flow: column nowrap;
  margin-bottom: 2em;
}

.newsBox .newsList li {
  display: block;
  margin: 0;
  padding: .8em;
  border-bottom: 1px solid #ddd;
}

.newsBox .newsList li a {
  color: #111;
}

.newsBox .newsListItem a {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row nowrap;
      flex-flow: row nowrap;
}

.newsBox .newsListDate {
  display: inline-block;
  width: 120px;
}

.newsBox .newsList i {
  display: inline-block;
  width: 100px;
  margin: 0 20px;
  padding: .3em 1em;
  color: #fff;
  font-size: 14px;
  font-style: normal;
  line-height: 1;
  text-align: center;
}

.newsBox .newsListText {
  width: calc(100% - 300px);
  margin: 0;
}

.newsBox .newsList a:hover {
  opacity: .7;
}

.newsBox .moreLink {
  margin-top: -10px 0 10px;
  text-align: right;
  font-size: 14px;
}

.newsBox .moreLink a {
  display: inline-block;
  border-radius: 100px;
  padding: .3em 2em;
  margin: -10px auto 10px;
  overflow: hidden;
  transition: color 300ms;
  transform: perspective(1px) translateZ(0);
  text-align: center;
  background: #004181;
  background: linear-gradient(to right, #0072e2 0%, #004181 100%);
  color: #fff;
}

.newsBox .moreLink a::after {
  content: "";
  display: block;
  width: 4px;
  height: 4px;
  border-bottom: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(-45deg);
  position: absolute;
  right: 15px;
  top: 50%;
  margin-top: -4px;
  transition: border 300ms;
}

.newsBox .moreLink a:hover {
  color: #fff !important;
  opacity: .7;
  transition: all 0.5s ease;
  text-decoration: none;
}

.newsDetail img {
  margin-bottom: 1em;
}

.newsDetail .newsListItem {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row nowrap;
      flex-flow: row nowrap;
  margin-bottom: 2em;
}

.newsDetail .newsListItem i {
  display: inline-block;
  width: 100px;
  margin: 0 20px;
  padding: .1em 1em;
  color: #fff;
  font-size: 14px;
  font-style: normal;
  text-align: center;
}

.cat-recruit {
  background: #e94600;
}

.cat-company {
  background: #2a85c0;
}

.newsNew {
  margin-top: 5px;
  font-size: 12px;
  color: #d60320;
  font-weight: 600;
}

@media screen and (max-width: 768px) {
  .news {
    padding: 0 3.14vw;
    margin: 50px auto;
  }
  .newsBox ul {
    padding: 20px;
  }
  .newsBox .newsList li {
    padding: .5em 0;
  }
  .newsBox .newsListItem a {
    -ms-flex-flow: column;
        flex-flow: column;
  }
  .newsBox .newsListDate {
    display: inline-block;
    width: 120px;
  }
  .newsBox .newsList i {
    margin: 0;
    font-size: 12px;
  }
  .newsBox .newsListText {
    width: 100%;
  }
  .newsBox .moreLink {
    font-size: 12px;
  }
  .newsBox .moreLink a {
    padding: .2em 2em;
  }
}

#about .about2column {
  display: -ms-flexbox;
  display: flex;
  margin: 0;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-align: center;
      align-items: center;
}

#about .about2column .copy {
  width: 35%;
  font-size: 2.2em;
  font-weight: 200;
}

#about .about2column .text {
  width: 60%;
}

#about .aboutCompanyTable {
  width: 90%;
  margin: 0 auto;
  border-bottom: 1px solid #f0e5d8;
}

#about .aboutCompanyTable table {
  margin-bottom: 0 !important;
}

#about .aboutCompanyTable td {
  border-top: 1px solid #f0e5d8;
  padding: .8em 1em;
}

#about .aboutCompanyTable thead th {
  text-align: center;
  vertical-align: middle;
}

#about .aboutCompanyTable th {
  border-top: 1px solid #f0e5d8;
  background-color: #faf9f6;
  padding: .8em 1em;
  text-align: left;
  width: 25%;
}

#about .aboutHistory ul {
  margin: 0;
  list-style: none;
}

#about .aboutHistory .timeline {
  border-left: 1px solid #ba9d77;
  padding: 50px 0 50px 30px;
}

#about .aboutHistory .timeline > li {
  position: relative;
  margin: 0;
  margin-bottom: 100px;
}

#about .aboutHistory .timeline > li:last-child {
  margin-bottom: 0 !important;
}

#about .aboutHistory .timelineCont {
  width: 100%;
}

#about .aboutHistory .timelineCont h2 {
  font-size: 1.6em;
  line-height: 1.5em;
  margin-bottom: 1.2em;
}

#about .aboutHistory .timelineCont2Column {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row nowrap;
      flex-flow: row nowrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
  padding: 1em;
}

#about .aboutHistory .timelineCont2Column .historyText {
  width: 65%;
  font-size: 15px;
}

#about .aboutHistory .timelineCont2Column .historyImg {
  width: 30%;
}

#about .aboutHistory .timelineCont:before {
  content: '';
  position: absolute;
  width: 15px;
  height: 15px;
  background: #ba9d77;
  left: -38px;
  top: 10px;
  border-radius: 100%;
}

@media screen and (max-width: 1200px) {
  #about .about2column .copy {
    width: 35%;
    font-size: 2em;
  }
  #about .about2column .text {
    width: 60%;
  }
}

@media screen and (max-width: 1024px) {
  #about .about2column {
    -ms-flex-flow: column;
        flex-flow: column;
  }
  #about .about2column .copy {
    width: 100%;
    font-size: 2em;
    margin-bottom: 1em;
  }
  #about .about2column .copy br {
    display: none;
  }
  #about .about2column .text {
    width: 100%;
  }
  #about .aboutCompanyTable {
    width: 100%;
  }
  #about .aboutHistory .timeline > li {
    margin-bottom: 50px;
  }
}

@media screen and (max-width: 900px) {
  #about .aboutHistory .timeline {
    border-left: 1px solid #ba9d77;
    padding: 20px 0 50px 30px;
  }
  #about .aboutHistory .timeline > li {
    margin-bottom: 50px;
  }
  #about .aboutHistory .timelineCont2Column {
    -ms-flex-flow: column;
        flex-flow: column;
    -ms-flex-pack: center;
        justify-content: center;
    padding: .5em;
  }
  #about .aboutHistory .timelineCont2Column .historyText {
    width: 100%;
  }
  #about .aboutHistory .timelineCont2Column .historyImg {
    width: 50%;
    margin: 0 auto;
  }
}

@media screen and (max-width: 768px) {
  #about .about2column .copy {
    font-size: 1.5em;
  }
  #about .aboutCompanyTable {
    width: 100%;
  }
  #about .aboutCompanyTable tbody, #about .aboutCompanyTable tr, #about .aboutCompanyTable th, #about .aboutCompanyTable td {
    display: block;
    width: 100%;
  }
  #about .aboutCompanyTable thead th {
    text-align: center;
    width: 100%;
  }
  #about .aboutCompanyTable th, #about .aboutCompanyTable td {
    padding: 6px 10px;
  }
  #about .aboutCompanyTable th {
    font-weight: 500;
    text-align: left;
  }
  #about .aboutCompanyTable th.th1 {
    width: 100%;
  }
  #about .aboutCompanyTable th.th2 {
    width: 100%;
  }
  #about .aboutHistory .timeline {
    padding: 20px 0 50px 30px;
  }
  #about .aboutHistory .timelineCont h2 {
    font-size: 1.4em;
  }
  #about .aboutHistory .timelineCont2Column {
    padding: .5em;
  }
  #about .aboutHistory .timelineCont2Column .historyImg {
    width: 70%;
  }
}

@media screen and (max-width: 414px) {
  #about .aboutHistory .timelineCont h2 {
    font-size: 1.3em;
  }
  #about .aboutHistory .timelineCont2Column .historyImg {
    width: 80%;
  }
}

.bunshi,
.bitamin,
.amino {
  width: 100%;
  background: #f0e5d8;
  margin: 0 auto 1em;
  font-size: .9em;
}

.mtFlex {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  font-size: 13px;
}

.bunshi th,
.bitamin th,
.amino th,
.bunshi td,
.bitamin td,
.amino td {
  background: #fff;
  vertical-align: middle;
  text-align: center;
}

.bunshi td,
.bitamin td,
.amino td {
  text-align: center;
}

.bunshi td.three,
.bitamin td.three,
.amino td.three,
.bunshi td.point,
.bitamin td.point,
.amino td.point {
  background: #faf9f6;
}

.bunshi td.point,
.bitamin td.point,
.amino td.point {
  color: #d60320;
  font-weight: 500;
}

#material .caseBio {
  padding: .5em 1em;
  text-align: center;
  font-size: 1.2em;
  color: #fff;
  background: #d95346;
  font-weight: bold;
}

#material .caseGeneral {
  padding: .5em 1em;
  text-align: center;
  font-size: 1.2em;
  color: #fff;
  background: #ba9d77;
  font-weight: bold;
}

#material .imgLine {
  border: 1px solid #f0e5d8;
}

#material .effect ul {
  list-style: none;
  margin: 0;
  list-style-position: outside;
}

#material .effect li {
  font-size: 1.5em;
  position: relative;
  padding-left: 1.5em;
  margin-bottom: .8em;
  line-height: 1.5em;
}

#material .effect li span {
  font-size: 16px;
}

#material .effect li:before {
  position: absolute;
  font-family: 'Material Icons';
  content: '\e92d';
  color: #ba9d77;
  top: 0;
  /* 要素によって要調整 */
  left: 0;
  display: inline-block;
}

#material .box-text-point1,
#material .box-text-point2,
#material .box-text-point3 {
  position: relative;
  border: 1px solid #f0e5d8;
  margin: 2em 0;
  padding: 1em 1em;
}

#material .box-text-point1 h5,
#material .box-text-point2 h5,
#material .box-text-point3 h5 {
  margin: 1em auto;
  font-size: 1.4em;
  line-height: 1.6;
  text-align: center;
  border-bottom: 3px solid #d95346;
}

#material .box-text-point1::before,
#material .box-text-point2::before,
#material .box-text-point3::before {
  position: absolute;
  background-color: #d60320;
  border: 1px solid #f0e5d8;
  color: #fff;
  left: 50%;
  transform: translateX(-50%);
  top: -23px;
  padding: .3em 1em;
}

#material .box-text-point1::before {
  content: "POINT.1";
}

#material .box-text-point2::before {
  content: "POINT.2";
}

#material .box-text-point3::before {
  content: "POINT.3";
}

#material .materialRead {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row nowrap;
      flex-flow: row nowrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-line-pack: center;
      align-content: center;
  -ms-flex-align: center;
      align-items: center;
}

#material .materialReadText {
  width: 60%;
}

#material .materialReadImg {
  width: 35%;
}

@media screen and (max-width: 1024px) {
  #material .box-text-point1 h5,
  #material .box-text-point2 h5,
  #material .box-text-point3 h5 {
    font-size: 1.3em;
  }
}

@media screen and (max-width: 768px) {
  #material .caseBio,
  #material .caseGeneral {
    font-size: 1.1em;
  }
  #material .box-text-point1,
  #material .box-text-point2,
  #material .box-text-point3 {
    margin: 1.5em 0;
    padding: 1em 1em 0;
  }
  #material .box-text-point1 h5,
  #material .box-text-point2 h5,
  #material .box-text-point3 h5 {
    font-size: 1.2em;
    text-align: left;
    border-bottom: 3px solid #d95346;
  }
}

@media screen and (max-width: 900px) {
  #material .materialRead {
    -ms-flex-flow: column;
        flex-flow: column;
    -ms-flex-pack: center;
        justify-content: center;
  }
  #material .materialReadText {
    -ms-flex-order: 1;
        order: 1;
    width: 100%;
  }
  #material .materialReadImg {
    -ms-flex-order: 2;
        order: 2;
    width: 70%;
    margin: 0 auto;
    text-align: center;
  }
}

@media screen and (max-width: 768px) {
  #material .effect li {
    font-size: 1.2em;
    padding-left: 1.2em;
    margin-bottom: .8em;
    line-height: 1.2em;
  }
  #material .effect li span {
    font-size: 14px;
  }
}

@media screen and (max-width: 414px) {
  #material .effect li {
    font-size: 1em;
  }
  #material .materialReadImg {
    width: 100%;
  }
}

#subscription .page2column {
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-align: stretch;
      align-items: stretch;
}

#subscription .page2columnText {
  width: 49%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: stretch;
      align-items: stretch;
}

#subscription .subscBenefits {
  width: 100%;
  max-width: 1360px;
  margin: 0 auto;
  padding: 0 30px;
}

#subscription h3.subscTit {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  font-size: 2.2em;
  text-align: center;
  line-height: 1.6;
  margin-bottom: 1em;
}

#subscription h3.subscTit::before,
#subscription h3.subscTit::after {
  content: '';
  width: 3px;
  height: 40px;
  background-color: #ba9d77;
}

#subscription h3.subscTit::before {
  margin-right: 30px;
  transform: rotate(-35deg);
}

#subscription h3.subscTit::after {
  margin-left: 30px;
  transform: rotate(35deg);
}

#subscription .benefits1,
#subscription .benefits2 {
  width: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row;
      flex-flow: row;
  -ms-flex-pack: start;
      justify-content: start;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-line-pack: stretch;
      align-content: stretch;
  border: 1px solid #f0e5d8;
  margin-bottom: 2em;
  padding: 2em;
  background: #fff;
}

#subscription .benefits2:nth-child(n+3) {
  margin-bottom: 0;
}

#subscription .benefitsIcon {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: column;
      flex-flow: column;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  width: 100px;
  height: 100px;
  background-color: #ba9d77;
  border-radius: 50%;
  text-align: center;
  font-size: 1.2em;
  line-height: 1;
  color: #fff;
  font-weight: 500;
  margin-right: 30px;
}

#subscription .benefitsIcon > span {
  font-size: 2em;
  font-weight: 300;
}

#subscription .benefitsCont {
  width: calc(100% - 130px);
}

#subscription .benefitsTit {
  font-size: 1.8em;
  color: #d95346;
  font-weight: 500;
  line-height: 1.6;
  margin-bottom: .5em;
}

#subscription .benefitsCont p {
  margin: 0;
}

@media screen and (max-width: 1024px) {
  #subscription .benefitsTit {
    font-size: 1.6em;
  }
}

@media screen and (max-width: 900px) {
  #subscription .page2columnText {
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  #subscription .subscBenefits {
    padding: 0 3.14vw;
  }
  #subscription h3.subscTit {
    font-size: 1.8em;
  }
  #subscription h3.subscTit::before,
  #subscription h3.subscTit::after {
    height: 30px;
  }
  #subscription h3.subscTit::before {
    margin-right: 20px;
  }
  #subscription h3.subscTit::after {
    margin-left: 20px;
  }
  #subscription .benefits1,
  #subscription .benefits2 {
    margin-bottom: 1em;
    padding: 1.5em;
  }
  #subscription .benefitsIcon {
    width: 80px;
    height: 80px;
    font-size: 1.1em;
    margin-right: 20px;
  }
  #subscription .benefitsIcon > span {
    font-size: 1.6em;
  }
  #subscription .benefitsCont {
    width: calc(100% - 100px);
  }
  #subscription .benefitsTit {
    font-size: 1.4em;
  }
}

@media screen and (max-width: 568px) {
  #subscription h3.subscTit {
    font-size: 1.5em;
  }
  #subscription h3.subscTit::before {
    margin-right: 10px;
  }
  #subscription h3.subscTit::after {
    margin-left: 10px;
  }
  #subscription .benefits1,
  #subscription .benefits2 {
    padding: 2em 1em;
  }
  #subscription .benefitsIcon {
    width: 70px;
    height: 70px;
    font-size: 1em;
    margin-right: 20px;
  }
  #subscription .benefitsIcon > span {
    font-size: 1.2em;
  }
  #subscription .benefitsCont {
    width: calc(100% - 90px);
  }
  #subscription .benefitsTit {
    font-size: 1.3em;
    margin-bottom: .2em;
  }
}

@media screen and (max-width: 375px) {
  #subscription h3.subscTit {
    font-size: 1.2em;
  }
  #subscription h3.subscTit::before,
  #subscription h3.subscTit::after {
    height: 20px;
  }
  #subscription .benefits1,
  #subscription .benefits2 {
    -ms-flex-flow: column;
        flex-flow: column;
  }
  #subscription .benefitsIcon {
    margin-bottom: 1em;
    margin-right: 0;
  }
  #subscription .benefitsCont {
    width: 100%;
  }
}

#help .table {
  width: auto !important;
  display: inline-block;
  margin-bottom: 1em;
}

#help .table th {
  font-weight: bold;
  width: auto !important;
}

#help .table td {
  color: #d60320;
  width: auto !important;
}

#help table {
  margin-bottom: 0;
}

#help .pageNav2column li:nth-child(3n) {
  width: 100%;
  border-top: 0;
  border-right: 1px solid #f0e5d8;
}

#help .flowArrow {
  margin: 0 0 2em 30px;
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 10px solid #ba9d77;
}

#help h5.helpH5 {
  padding: .2em .5em;
  border-left: 3px solid #ba9d77;
  line-height: 1.6;
}

#help .flow {
  width: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row;
      flex-flow: row;
  -ms-flex-pack: start;
      justify-content: start;
  margin-bottom: 2em;
  background: #fff;
}

#help .flowIcon {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: column;
      flex-flow: column;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  width: 80px;
  height: 80px;
  background-color: #ba9d77;
  border-radius: 50%;
  text-align: center;
  font-size: .9em;
  line-height: 1.2;
  color: #fff;
  font-weight: 500;
  margin-right: 30px;
}

#help .flowIcon > span {
  font-size: 1.4em;
  font-weight: 300;
}

#help .flowCont {
  width: calc(100% - 110px);
}

#help .flowTit {
  font-size: 1.4em;
  font-weight: 500;
  line-height: 1.6;
  margin-bottom: .3em;
}

#help .flowCont p {
  margin: 0;
}

@media screen and (max-width: 768px) {
  #help .table {
    width: 100% !important;
    display: inline-block;
  }
  #help .table tbody, #help .table tr, #help .table th, #help .table td {
    display: revert;
    width: auto !important;
  }
  #help .table thead th {
    width: auto !important;
  }
  #help .table th, #help .table td {
    padding: 6px 10px;
  }
  #help .subscBenefits {
    padding: 0 3.14vw;
  }
  #help .flow {
    margin-bottom: 1em;
  }
  #help .flowIcon {
    margin-right: 20px;
  }
  #help .flowIcon > span {
    font-size: 1.2em;
  }
  #help .flowCont {
    width: calc(100% - 100px);
  }
  #help .flowTit {
    font-size: 1.2em;
  }
}

@media screen and (max-width: 568px) {
  #help .flowArrow {
    margin: 0 0 1em 26px;
    border-left: 8px solid transparent;
    border-right: 8px solid transparent;
    border-top: 8px solid #ba9d77;
  }
  #help .flowIcon {
    width: 70px;
    height: 70px;
    font-size: .8em;
    margin-right: 20px;
  }
  #help .flowIcon > span {
    font-size: 1.2em;
  }
  #help .flowCont {
    width: calc(100% - 90px);
  }
  #help .flowTit {
    font-size: 1.3em;
    margin-bottom: .2em;
  }
}

@media screen and (max-width: 375px) {
  #help .flowArrow {
    margin: 0 auto 1em;
  }
  #help .flow {
    -ms-flex-flow: column;
        flex-flow: column;
    -ms-flex-align: center;
        align-items: center;
  }
  #help .flowIcon {
    margin-bottom: 1em;
    margin-right: 0;
  }
  #help .flowCont {
    width: 100%;
  }
}

/*====================================================================
.s_03 .accordion_one
====================================================================*/
#itemDetail .itemDetailCopy {
  font-size: 2em;
  margin-bottom: 1em;
  line-height: 1.6;
}

#itemDetail .itemDetailBox {
  padding: 2em;
  margin-bottom: 2em;
  border: 1px solid #f0e5d8;
}

#itemDetail .itemDetail ul {
  margin: 0;
  list-style: none;
}

#itemDetail .pcOnly {
  display: block;
}

#itemDetail .spOnly {
  display: none;
}

#itemDetail figure {
  width: 80%;
}

.s_03 .accordion_one {
  margin: 0 auto 2em;
  line-height: 1.8;
}

.s_03 .accordion_one .accordion_header {
  border-bottom: 1px solid #f0e5d8;
  font-size: 1.6em;
  line-height: 1.6;
  padding: 1em 50px;
  text-align: left;
  position: relative;
  z-index: +1;
  cursor: pointer;
  transition-duration: 0.2s;
}

.s_03 .accordion_one .accordion_header::after {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  content: '';
  width: 30px;
  height: 3px;
  background-color: #ba9d77;
}

.s_03 .accordion_one .accordion_header:hover {
  opacity: .8;
}

.s_03 .accordion_one .accordion_header .i_box {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  position: absolute;
  top: 50%;
  right: 2%;
  width: 40px;
  height: 40px;
  margin-top: -20px;
  box-sizing: border-box;
  transform: rotate(45deg);
  transform-origin: center center;
  transition-duration: 0.2s;
}

.s_03 .accordion_one .accordion_header.stay .i_box {
  transform: rotate(0deg);
}

.s_03 .accordion_one .accordion_header .i_box .one_i {
  display: block;
  width: 18px;
  height: 18px;
  transform: rotate(45deg);
  transform-origin: center center;
  transition-duration: 0.2s;
  position: relative;
}

.s_03 .accordion_one .accordion_header.stay .i_box .one_i {
  transform: rotate(0deg);
}

.s_03 .accordion_one .accordion_header.stay.open .i_box .one_i {
  transform: rotate(45deg);
}

.s_03 .accordion_one .accordion_header.open .i_box {
  transform: rotate(-360deg);
}

.s_03 .accordion_one .accordion_header.stay.open .i_box {
  transform: rotate(315deg);
}

.s_03 .accordion_one .accordion_header .i_box .one_i:before, .s_03 .accordion_one .accordion_header .i_box .one_i:after {
  display: -ms-flexbox;
  display: flex;
  content: '';
  background-color: #ba9d77;
  border-radius: 10px;
  width: 17px;
  height: 3px;
  position: absolute;
  top: 7px;
  left: 0;
  transform: rotate(0deg);
  transform-origin: center center;
}

.s_03 .accordion_one .accordion_header .i_box .one_i:before {
  width: 3px;
  height: 17px;
  top: 0;
  left: 7px;
}

.s_03 .accordion_one .accordion_header.stay .i_box .one_i:before {
  content: none;
}

.s_03 .accordion_one .accordion_header.open .i_box .one_i:before {
  content: none;
}

.s_03 .accordion_one .accordion_header.stay.open .i_box .one_i:before {
  content: "";
}

.s_03 .accordion_one .accordion_header.open .i_box .one_i:after {
  transform: rotate(-45deg);
}

.s_03 .accordion_one .accordion_header.stay.open .i_box .one_i:after {
  transform: rotate(0deg);
}

.s_03 .accordion_one .accordion_inner {
  display: none;
  padding: 30px 50px;
  box-sizing: border-box;
}

.s_03 .accordion_one .accordion_inner.stay {
  display: block;
}

.s_03 .accordion_one .accordion_inner p.txt_a_ac {
  margin: 0;
}

@media screen and (max-width: 1024px) {
  .s_03 .accordion_one .accordion_header {
    font-size: 1.5em;
  }
  .s_03 .accordion_one .accordion_header .i_box {
    width: 30px;
    height: 30px;
    margin-top: -15px;
  }
}

@media screen and (max-width: 768px) {
  #itemDetail .itemDetailCopy {
    font-size: 1.4em;
    margin-bottom: .5em;
  }
  #itemDetail .itemDetailBox {
    padding: 1em;
    margin-bottom: 1em;
  }
  #itemDetail .pcOnly {
    display: none;
  }
  #itemDetail .spOnly {
    display: block;
  }
  #itemDetail figure {
    width: 100%;
  }
  .s_03 .accordion_one .accordion_header {
    font-size: 1.2em;
    padding: 1em 30px;
  }
  .s_03 .accordion_one .accordion_header::after {
    width: 20px;
  }
  .s_03 .accordion_one .accordion_inner {
    padding: 20px 3.14vw;
  }
}

#shopch .shopchBox {
  margin: 0 auto 50px;
  padding: 0;
  width: 100%;
}

#shopch .shopchBox ul {
  margin: 0;
  padding: 0;
}

#shopch .shopchBox li {
  list-style: circle;
  margin-bottom: .5em;
  padding-left: 5px;
}

#shopch .material-icons-outlined {
  font-size: 16px;
  margin-top: -3px;
}

#shopch .onAirBox {
  padding: 0 2em;
  margin-bottom: 2em;
}

#shopch .onAirBox .onAirCont {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row;
      flex-flow: row;
  -ms-flex-align: center;
      align-items: center;
  gap: 24px;
  margin-bottom: 40px;
}

#shopch .onAirBox .onAirTitle {
  margin-bottom: 1em;
}

#shopch .onAirBox .shopchCopy {
  font-size: 1em;
}

#shopch .onAirBox h5.shopchTitle {
  font-size: 1.4em;
  font-weight: bold;
}

#shopch .onAirBox .onAir {
  font-size: 1.1em;
  color: #e9008b;
}

@media screen and (max-width: 768px) {
  #shopch .onAirBox {
    padding: 0 1em;
    margin-bottom: 2em;
  }
  #shopch .onAirBox .onAirTitle {
    margin-bottom: .5em;
  }
  #shopch .onAirBox .shopchCopy {
    font-size: 1em;
  }
  #shopch .onAirBox h5.shopchTitle {
    font-size: 1.1em;
  }
  #shopch .onAirBox .onAir {
    font-size: 1em;
  }
  #shopch .onAirBox p {
    padding-left: 0;
  }
}

.eventKv {
  width: 100%;
  margin: 0 auto 0;
  padding: 0 30px;
  text-align: center;
}

.eventKv .pcOnly {
  display: block;
}

.eventKv .spOnly {
  display: none;
}

#event .eventCopy {
  font-size: 1.1em;
}

#event .event2column {
  display: -ms-flexbox;
  display: flex;
  margin: 0;
  -ms-flex-flow: row nowrap;
      flex-flow: row nowrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-align: center;
      align-items: center;
}

#event .event2column .copy {
  width: 35%;
  font-size: 2.2em;
  font-weight: 200;
}

#event .event2column .text {
  width: 60%;
}

#event .eventItemBox {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
}

#event .eventItemBox:after {
  content: " ";
  width: 28%;
  display: block;
}

#event .eventItemList {
  width: 30%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  margin-bottom: 50px;
}

#event .eventItemList .button {
  text-align: center;
  width: 100%;
  margin-top: auto;
}

#event .eventItemList .buttonSingle {
  width: 100% !important;
}

#event .eventItemRate {
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 2;
}

#event .eventItemRate .dRate {
  display: -ms-inline-grid;
  display: inline-grid;
  color: #fff;
  background-color: #d60320;
  width: 100px;
  height: 100px;
  border-radius: 50%;
  text-align: center;
  -ms-flex-line-pack: center;
      align-content: center;
  line-height: 1.3;
}

#event .eventItemRate .dRate span {
  font-size: 1.6em;
  font-weight: 500;
}

#event .eventItemTag {
  display: -ms-flexbox;
  display: flex;
  color: #fff;
  margin-top: 20px;
}

#event .eventItemTag .eventItemLimit {
  display: table-cell;
  height: 40px;
  margin: 0 .5em .5em 0;
  padding: 0 1em;
  border: 1px solid #d60320;
  color: #d60320;
  font-size: 1.4em;
  vertical-align: middle;
}

#event .eventItemTag .eventItemLimit span {
  font-size: 0.8em;
}

#event .eventItemTag .eventItemCat {
  display: table-cell;
  height: 40px;
  margin: 0 .5em .5em 0;
  padding: 0 1em;
  border: 1px solid #111;
  color: #111;
  font-size: 1em;
  vertical-align: middle;
  line-height: 40px;
}

#event .eventItemTagS {
  display: inline-block;
  background: #49351d;
  padding: 5px 10px;
  margin: 0 0 1em;
  color: #fff;
  font-size: .9em;
}

#event .eventItemTagC {
  display: inline-block;
  background: #6e487d;
  padding: 5px 10px;
  margin: 0 0 1em;
  color: #fff;
  font-size: .9em;
}

#event .eventItemName {
  font-size: 1.1em;
  margin-bottom: 10px;
}

#event .eventItemPrice {
  text-align: right;
  margin-bottom: 10px;
}

#event .eventItemPrice .under_line {
  font-size: 1.5em;
  color: #111;
  text-decoration: line-through;
}

#event .eventItemPrice span {
  font-size: 2em;
  color: #d60320;
}

#event .eventItemDetail {
  font-size: .9em;
  margin-bottom: 1em;
}

#event .contactTel {
  margin-bottom: 100px !important;
}

@media screen and (max-width: 1200px) {
  #event .event2column .copy {
    width: 35%;
    font-size: 2em;
  }
  #event .event2column .text {
    width: 60%;
  }
}

@media screen and (max-width: 1024px) {
  #event .event2column {
    -ms-flex-flow: column;
        flex-flow: column;
  }
  #event .event2column .copy {
    width: 100%;
    font-size: 2em;
    margin-bottom: 1em;
  }
  #event .event2column .copy br {
    display: none;
  }
  #event .event2column .text {
    width: 100%;
  }
  #event .eventItemBox:after {
    width: 45%;
  }
  #event .eventItemList {
    width: 45%;
    margin-bottom: 30px;
  }
}

@media screen and (max-width: 768px) {
  .eventKv {
    padding: 0 3.14vw;
  }
  #event .event2column .copy {
    font-size: 1.5em;
  }
  #event .contactTel {
    margin-bottom: 50px !important;
  }
}

@media screen and (max-width: 667px) {
  .eventKv .pcOnly {
    display: none;
  }
  .eventKv .spOnly {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  #event .eventItemList {
    width: 100%;
  }
  #event .eventItemName {
    font-size: 1.2em;
  }
  #event .eventItemName br {
    display: none;
    margin-left: 10px;
  }
  #event .eventItemPrice span {
    font-size: 1.8em;
  }
}

/* extension style
-----------------------------------*/
.white {
  color: #fff !important;
}

.black {
  color: #111 !important;
}

.blue {
  color: #0b4c8d !important;
}

.green {
  color: #008170 !important;
}

.orange {
  color: #e94600 !important;
}

.red {
  color: #d60320 !important;
}

.yellow {
  color: #fad00d !important;
}

.purple {
  color: #847bb9 !important;
}

.pink {
  color: #ff82a1 !important;
}

.grey {
  color: #acadad !important;
}

.bg-white {
  background-color: #fff !important;
}

.bg-black {
  background-color: #111 !important;
}

.bg-blue {
  background-color: #0b4c8d !important;
}

.bg-blue-light {
  background-color: #2a85c0 !important;
}

.bg-green-light {
  background-color: #02aa94 !important;
}

.bg-orange {
  background-color: #e94600 !important;
}

.bg-red {
  background-color: #d60320 !important;
}

.bg-yellow {
  background-color: #fad00d !important;
}

.bg-purple {
  background-color: #847bb9 !important;
}

.bg-pink {
  background-color: #ff82a1 !important;
}

.bg-sec-sub {
  background-color: #f4f4f4 !important;
}

.w5p {
  width: 5% !important;
}

.w10p {
  width: 10% !important;
}

.w15p {
  width: 15% !important;
}

.w20p {
  width: 20% !important;
}

.w25p {
  width: 25% !important;
}

.w30p {
  width: 30% !important;
}

.w35p {
  width: 35% !important;
}

.w40p {
  width: 40% !important;
}

.w45p {
  width: 45% !important;
}

.w50p {
  width: 50% !important;
}

.w55p {
  width: 55% !important;
}

.w60p {
  width: 60% !important;
}

.w65p {
  width: 65% !important;
}

.w70p {
  width: 70% !important;
}

.w75p {
  width: 75% !important;
}

.w80p {
  width: 80% !important;
}

.w85p {
  width: 85% !important;
}

.w90p {
  width: 90% !important;
}

.w95p {
  width: 95% !important;
}

.w100p {
  width: 100% !important;
}

.w5em {
  width: 5em !important;
}

.w6em {
  width: 6em !important;
}

.w7em {
  width: 7em !important;
}

.w8em {
  width: 8em !important;
}

.w9em {
  width: 9em !important;
}

.w10em {
  width: 10em !important;
}

.flr {
  float: right !important;
}

.fll {
  float: left !important;
}

.fln {
  float: none !important;
}

.clb {
  clear: both !important;
}

.cln {
  clear: none !important;
}

.is-left {
  text-align: left !important;
}

.is-center {
  text-align: center !important;
}

.is-right {
  text-align: right !important;
}

.is-bold {
  font-weight: 700 !important;
}

.nowrap {
  white-space: nowrap !important;
}

/* 文字サイズ */
.fs08 {
  font-size: .8em !important;
}

.fs0875 {
  font-size: .875em !important;
}

.fs09 {
  font-size: .9em !important;
}

.fs0937 {
  font-size: .9375em !important;
}

.fs11 {
  font-size: 1.1em !important;
}

.fs12 {
  font-size: 1.2em !important;
}

.fs1125 {
  font-size: 1.125em !important;
}

.fs125 {
  font-size: 1.25em !important;
}

.fs13 {
  font-size: 1.3em !important;
}

.fs14 {
  font-size: 1.4em !important;
}

.fs15 {
  font-size: 1.5em !important;
}

.fs16 {
  font-size: 1.6em !important;
}

.fs17 {
  font-size: 1.7em !important;
}

.fs18 {
  font-size: 1.8em !important;
}

.fs19 {
  font-size: 1.9em !important;
}

.fs20 {
  font-size: 2.0em !important;
}

.lh1 {
  line-height: 1 !important;
}

.lh12 {
  line-height: 1.2 !important;
}

.lh14 {
  line-height: 1.4 !important;
}

.lh16 {
  line-height: 1.6 !important;
}

.lh18 {
  line-height: 1.8 !important;
}

.lh20 {
  line-height: 2 !important;
}

/* margin */
.m0 {
  margin: 0 !important;
}

.m5 {
  margin: 5px !important;
}

.m10 {
  margin: 10px !important;
}

.m15 {
  margin: 15px !important;
}

.m20 {
  margin: 20px !important;
}

.m30 {
  margin: 30px !important;
}

.m40 {
  margin: 40px !important;
}

.m50 {
  margin: 50px !important;
}

.mt0 {
  margin-top: 0 !important;
}

.mt5 {
  margin-top: 5px !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mt15 {
  margin-top: 15px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mb0 {
  margin-bottom: 0 !important;
}

.mb5 {
  margin-bottom: 5px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mb25 {
  margin-bottom: 25px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.mb35 {
  margin-bottom: 35px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.mb45 {
  margin-bottom: 45px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.mb55 {
  margin-bottom: 55px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.mb65 {
  margin-bottom: 65px !important;
}

.mb70 {
  margin-bottom: 70px !important;
}

.mb75 {
  margin-bottom: 75px !important;
}

.mb80 {
  margin-bottom: 80px !important;
}

.mb85 {
  margin-bottom: 85px !important;
}

.mb90 {
  margin-bottom: 90px !important;
}

.mb95 {
  margin-bottom: 95px !important;
}

.mb100 {
  margin-bottom: 100px !important;
}

.mb200 {
  margin-bottom: 200px !important;
}

.ml0 {
  margin-left: 0 !important;
}

.ml5 {
  margin-left: 5px !important;
}

.ml10 {
  margin-left: 10px !important;
}

.ml20 {
  margin-left: 20px !important;
}

.ml30 {
  margin-left: 30px !important;
}

.ml40 {
  margin-left: 40px !important;
}

.ml50 {
  margin-left: 50px !important;
}

.mr0 {
  margin-right: 0 !important;
}

.mr5 {
  margin-right: 5px !important;
}

.mr10 {
  margin-right: 10px !important;
}

.mr20 {
  margin-right: 20px !important;
}

.mr30 {
  margin-right: 30px !important;
}

.mr40 {
  margin-right: 40px !important;
}

.mr50 {
  margin-right: 50px !important;
}

.mlr5 {
  margin-right: 5px !important;
  margin-left: 5px !important;
}

.mlr10 {
  margin-right: 10px !important;
  margin-left: 10px !important;
}

/* padding */
.p0 {
  padding: 0 !important;
}

.p5 {
  padding: 5px !important;
}

.p10 {
  padding: 10px !important;
}

.p15 {
  padding: 15px !important;
}

.p20 {
  padding: 20px !important;
}

.p25 {
  padding: 25px !important;
}

.p30 {
  padding: 30px !important;
}

.p35 {
  padding: 35px !important;
}

.p40 {
  padding: 40px !important;
}

.p45 {
  padding: 45px !important;
}

.p50 {
  padding: 50px !important;
}

.pb0 {
  padding-bottom: 0 !important;
}

.pb5 {
  padding-bottom: 5px !important;
}

.pb10 {
  padding-bottom: 10px !important;
}

.pb15 {
  padding-bottom: 15px !important;
}

.pb20 {
  padding-bottom: 20px !important;
}

.pb25 {
  padding-bottom: 25px !important;
}

.pb30 {
  padding-bottom: 30px !important;
}

.pb35 {
  padding-bottom: 35px !important;
}

.pb40 {
  padding-bottom: 40px !important;
}

.pb45 {
  padding-bottom: 45px !important;
}

.pb50 {
  padding-bottom: 50px !important;
}

.pb80 {
  padding-bottom: 50px !important;
}

.pt0 {
  padding-top: 0 !important;
}

.pt5 {
  padding-top: 5px !important;
}

.pt10 {
  padding-top: 10px !important;
}

.pt15 {
  padding-top: 15px !important;
}

.pt20 {
  padding-top: 20px !important;
}

.pt25 {
  padding-top: 25px !important;
}

.pt30 {
  padding-top: 30px !important;
}

.pt35 {
  padding-top: 35px !important;
}

.pt40 {
  padding-top: 40px !important;
}

.pt45 {
  padding-top: 45px !important;
}

.pt50 {
  padding-top: 50px !important;
}

.pl0 {
  padding-left: 0 !important;
}

.pl10 {
  padding-left: 10px !important;
}

.pl20 {
  padding-left: 20px !important;
}

.pl30 {
  padding-left: 30px !important;
}

.pl40 {
  padding-left: 40px !important;
}

.pl50 {
  padding-left: 50px !important;
}

.pr0 {
  padding-right: 0 !important;
}

.pr10 {
  padding-right: 10px !important;
}

.pr20 {
  padding-right: 20px !important;
}

.pr30 {
  padding-right: 30px !important;
}

.pr40 {
  padding-right: 40px !important;
}

.pr50 {
  padding-right: 50px !important;
}

.plr5 {
  padding-left: 5px !important;
  padding-right: 5px !important;
}

.plr10 {
  padding-left: 10px !important;
  padding-right: 10px !important;
}

.plr15 {
  padding-left: 15px !important;
  padding-right: 15px !important;
}

.plr20 {
  padding-left: 20px !important;
  padding-right: 20px !important;
}

.plr25 {
  padding-left: 25px !important;
  padding-right: 25px !important;
}

.indent {
  text-indent: -1em;
  padding-left: 1em;
}

.ofx {
  width: 100% !important;
  overflow-x: auto;
}

.video-container {
  position: relative;
  display: block;
  width: 100%;
  height: 0;
  padding-bottom: 53%;
  padding-top: 30px;
  margin-bottom: 20px;
  overflow: hidden;
  background: center center no-repeat;
  background-size: cover;
}

.video-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 50;
}

hr.dot {
  background: transparent;
  border-bottom: 1px dotted #ccc;
  margin: 0 0 1.5em;
}

hr.clearHr {
  background: transparent;
  border-bottom: none;
  margin: 0 0 30px;
}

.op01 {
  opacity: .1;
}

.op02 {
  opacity: .2;
}

.op03 {
  opacity: .3;
}

.op04 {
  opacity: .4;
}

.op05 {
  opacity: .5;
}

.op06 {
  opacity: .6;
}

.op07 {
  opacity: .7;
}

.op08 {
  opacity: .8;
}

.op09 {
  opacity: .9;
}

.op10 {
  opacity: 10;
}

.cf:after {
  display: table;
  content: '';
  width: 100%;
}

.fs14Red {
  font-size: 1.4em;
  color: #d60320;
}

@media screen and (max-width: 768px) {
  .fs14Red {
    font-size: 1.2em !important;
  }
}
