@charset "UTF-8";
/* variables
-----------------------------*/
/* functions
-----------------------------*/
/* mixins
-----------------------------*/
/* pages
-----------------------------*/
/*! destyle.css v2.0.2 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model and set borders */
/* ============================================ */
*,
::before,
::after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
}

/* Document */
/* ============================================ */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 * 3. Remove gray overlay on links for iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -webkit-tap-highlight-color: transparent; /* 3*/
}

/* Sections */
/* ============================================ */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

/* Vertical rhythm */
/* ============================================ */
p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

/* Headings */
/* ============================================ */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  margin: 0;
}

/* Lists (enumeration) */
/* ============================================ */
ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Lists (definition) */
/* ============================================ */
dt {
  font-weight: bold;
}

dd {
  margin-left: 0;
}

/* Grouping content */
/* ============================================ */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}

address {
  font-style: inherit;
}

/* Text-level semantics */
/* ============================================ */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  text-decoration: underline; /* 2 */
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content */
/* ============================================ */
/**
 * Prevent vertical alignment issues.
 */
img,
embed,
object,
iframe {
  vertical-align: bottom;
}

/* Forms */
/* ============================================ */
/**
 * Reset form fields to make them styleable
 */
button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  outline: 0;
  border-radius: 0;
  text-align: inherit;
}

/**
 * Reset radio and checkbox appearance to preserve their look in iOS.
 */
[type=checkbox] {
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
       appearance: checkbox;
}

[type=radio] {
  -webkit-appearance: radio;
  -moz-appearance: radio;
       appearance: radio;
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}

button[disabled],
[type=button][disabled],
[type=reset][disabled],
[type=submit][disabled] {
  cursor: default;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Remove arrow in IE10 & IE11
 */
select::-ms-expand {
  display: none;
}

/**
 * Remove padding
 */
option {
  padding: 0;
}

/**
 * Reset to invisible
 */
fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the outline style in Safari.
 */
[type=search] {
  outline-offset: -2px; /* 1 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/**
 * Clickable labels
 */
label[for] {
  cursor: pointer;
}

/* Interactive */
/* ============================================ */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/*
 * Remove outline for editable content.
 */
[contenteditable] {
  outline: none;
}

/* Table */
/* ============================================ */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption {
  text-align: left;
}

td,
th {
  vertical-align: top;
  padding: 0;
}

th {
  text-align: left;
  font-weight: bold;
}

/* Misc */
/* ============================================ */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none;
}

.ff-min {
  font-family: 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", HGS明朝E, メイリオ, Meiryo, serif;
}

body .cate-btn, body .btn.btn05 .cap, body .btn, body main.page.contact section.content-section .wpcf7 .contact-area .conf-area p, body main.page.contact section.content-section .wpcf7 .contact-area .item-box span.note, body main.page.page-award section.award-section .item-box .flex .group .item .text .txt, .ff-go {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "Droid Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

body main section .pagination-area .wp-pagenavi .previouspostslink,
body main section .pagination-area .wp-pagenavi .nextpostslink, .ff-robo {
  font-family: "Roboto", sans-serif;
}

body main.page.download section.content-section .inner .link-area .item .link-txt03, body main section .pagination-area .wp-pagenavi .page,
body main section .pagination-area .wp-pagenavi .current,
body main section .pagination-area .wp-pagenavi .last, body main.page section.page-header .link-area .item .link-txt03, body #breadcrumb section.breadcrumb-block .inner ol li, .ff-en {
  font-family: "EB Garamond", serif;
}

body .btn.btn05 .btn-ttl, body .btn.btn05 .min-txt, body {
  font-family: 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", HGS明朝E, メイリオ, Meiryo, serif;
}

.ff-en .cap-bold {
  font-weight: 500;
}
.ff-en .demi-bold {
  font-weight: 600;
}
.ff-en .bold {
  font-weight: bold;
}

body main article .txt {
  font-size: 13px;
  line-height: 2;
  letter-spacing: 0.2em;
}
@media screen and (max-width: 850px) {
  body main article .txt {
    font-size: 14px;
  }
}

body.home main section.hero-section .swiper-container .hero-btn-area {
  margin-left: auto;
  margin-right: auto;
  max-width: 1357px;
  padding-left: 23px;
  padding-right: 23px;
}

body .swiper-pagination, #nav .inner, #top-nav-area .inner, body.home main section.hero-section .news-area .inner, body #breadcrumb section.breadcrumb-block .inner, footer .inner-main, #cookie-notice .cookie-notice-container {
  margin-left: auto;
  margin-right: auto;
  max-width: 1322px;
  padding-left: 23px;
  padding-right: 23px;
}

body main.page section .inner, body.home main section.idty-section .ttl-area, body.home main section .inner {
  margin-left: auto;
  margin-right: auto;
  max-width: 1162px;
  padding-left: 23px;
  padding-right: 23px;
}

body main.page.archive section .inner.ver02, body main.page section .inner.ver02 {
  margin-left: auto;
  margin-right: auto;
  max-width: 1070px;
  padding-left: 23px;
  padding-right: 23px;
}

body main.page.single.single-discovery section .inner {
  margin-left: auto;
  margin-right: auto;
  max-width: 1006px;
  padding-left: 23px;
  padding-right: 23px;
}

*:focus {
  outline: none;
}

a {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  transition: all 0.6s;
  cursor: pointer;
}
a:hover {
  opacity: 0.4;
}

html {
  font-size: 62.5%;
}

body {
  position: relative;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: antialiased;
  font-size: 1.4rem;
}
body #wrap {
  position: relative;
  background-color: #fff;
  overflow: hidden;
}
body * {
  backface-visibility: hidden;
}
body h1, body h2, body h3, body h4, body h5, body h6 {
  letter-spacing: 0.15em;
}
body p {
  word-break: break-all;
}
body main {
  position: relative;
  z-index: 0;
  background-color: #fff;
  overflow-x: hidden;
}
body main img {
  height: auto;
}
body main article .txt {
  text-align: justify;
}
body main article .txt.ff-go {
  letter-spacing: 0.1em;
}
body main:not(.single) img {
  width: 100%;
  max-width: none;
}
@media screen and (max-width: 576px) {
  body main {
    overflow: hidden;
  }
}

#cookie-notice {
  border-top: 1px solid #000;
}
#cookie-notice .cookie-notice-container {
  padding-top: 35px;
  padding-bottom: 40px;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-wrap: nowrap;
}
#cookie-notice .cookie-notice-container .cn-text-container {
  text-align: left;
  font-size: 13px;
  line-height: 2;
  letter-spacing: 0.05em;
  margin-bottom: 0;
}
#cookie-notice .cookie-notice-container .cn-buttons-container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
  width: 340px;
  margin-bottom: 15px;
}
#cookie-notice .cookie-notice-container .cn-buttons-container .btn {
  margin: 0;
  margin-right: 10px;
  max-width: 160px;
}
#cookie-notice .cookie-notice-container .cn-buttons-container .btn + .btn {
  margin-left: 10px;
  margin-right: 0px;
}
#cookie-notice .cookie-notice-container .cn-close-icon {
  top: 14%;
}
@media screen and (max-width: 850px) {
  #cookie-notice .cookie-notice-container .cn-close-icon {
    top: 5.2%;
    right: 20px;
  }
}
@media screen and (max-width: 850px) {
  #cookie-notice .cookie-notice-container {
    display: block;
  }
  #cookie-notice .cookie-notice-container .cn-buttons-container {
    margin-top: 35px;
    margin-bottom: 0px;
    width: 340px;
  }
}

footer {
  background-color: #F2F1EF;
}
footer .inner-main {
  padding-top: 70px;
  padding-bottom: 54px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: nowrap;
}
footer .inner-main .logo {
  width: 124px;
  margin-right: 30px;
}
footer .inner-main .link-area {
  margin-right: 30px;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: nowrap;
  width: 47%;
}
footer .inner-main .link-area .link-box {
  margin-right: 7.5%;
}
footer .inner-main .link-area .link-box + .link-box {
  margin-left: 7.5%;
  margin-right: 0;
}
footer .inner-main .link-area .link-box .link-txt02 {
  font-size: 13px;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 1.6;
  display: block;
}
footer .inner-main .link-area .link-box .link-txt02 + .link-txt02 {
  margin-top: 18px;
}
footer .inner-main .sns-area {
  max-width: 342px;
  width: 100%;
}
footer .inner-main .sns-area .icn-box {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
}
footer .inner-main .sns-area .icn-box .icn {
  margin-left: 15px;
  margin-right: 15px;
}
footer .inner-main .sns-area .icn-box .icn.icn01 {
  font-size: 14px;
  letter-spacing: 0.05em;
}
footer .inner-main .sns-area .icn-box .icn.icn02 {
  width: 24px;
}
footer .inner-main .sns-area .icn-box .icn.icn03 {
  width: 24px;
}
footer .inner-main .sns-area .icn-box .icn.icn04 {
  width: 24px;
}
footer .inner-main .sns-area .icn-box .icn.icn05 {
  width: 30px;
}
footer .inner-main .sns-area .icn-box .icn:first-child {
  margin-left: 0;
}
footer .inner-main .sns-area .icn-box .icn:last-child {
  margin-right: 0;
}
footer .inner-main .sns-area .btn {
  margin-top: 50px;
}
footer .inner-main .sns-area .btn + .btn {
  margin-top: 30px;
}
footer .inner-footer {
  padding: 12px 0 22px;
  text-align: center;
  border-top: 1px solid #CBCBCB;
}
footer .inner-footer small {
  font-size: 10px;
  letter-spacing: 0.05em;
}
footer.bg-black {
  background-color: #000;
}
footer.bg-black .inner-main .link-area .link-box {
  color: #fff;
}
footer.bg-black .inner-main .link-area .link-box .link-txt02 {
  color: #fff;
}
footer.bg-black .inner-main .sns-area .icn-box .icn.icn01 {
  color: #fff;
}
footer.bg-black .inner-main .sns-area .btn.btn02 {
  color: #000;
  border-color: #fff;
  background-color: #fff;
}
footer.bg-black .inner-main .sns-area .btn.btn02:hover {
  background-color: #AFAFAF;
  border-color: #AFAFAF;
  color: #fff;
  opacity: 1;
}
footer.bg-black .inner-footer {
  border-top: 1px solid #F2F1EF;
}
footer.bg-black .inner-footer small {
  color: #fff;
}
@media screen and (max-width: 850px) {
  footer .inner-main {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    padding-top: 56px;
    padding-bottom: 48px;
  }
  footer .inner-main .logo {
    display: none;
  }
  footer .inner-main .link-area {
    width: 100%;
    order: 1;
    display: block;
    margin: 45px 0 0;
  }
  footer .inner-main .link-area .link-box {
    margin: 0;
  }
  footer .inner-main .link-area .link-box + .link-box {
    margin: 20px 0 0;
  }
  footer .inner-main .link-area .link-box .link-txt02 {
    display: inline-block;
  }
  footer .inner-main .link-area .link-box .link-txt02:nth-of-type(n + 3) {
    margin-top: 20px;
  }
  footer .inner-main .sns-area {
    width: 100%;
    order: 0;
    max-width: none;
  }
  footer .inner-main .sns-area .icn-box {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
  }
  footer .inner-main .sns-area .icn-box .icn {
    margin-left: 6.2%;
    margin-right: 6.2%;
  }
  footer .inner-main .sns-area .icn-box .icn.icn01 {
    order: 5;
    width: 100%;
    text-align: center;
    margin: 26px 0 0;
    font-size: 20px;
  }
  footer .inner-main .sns-area .icn-box .icn.icn02 {
    margin-left: 0;
  }
  footer .inner-main .sns-area .btn {
    margin-top: 56px;
    margin-left: auto;
    margin-right: auto;
  }
}

body #breadcrumb section.breadcrumb-block {
  padding: 16px 0 18px;
}
body #breadcrumb section.breadcrumb-block .inner {
  background-color: #fff;
}
body #breadcrumb section.breadcrumb-block .inner ol li {
  display: inline-block;
  font-size: 12px;
  letter-spacing: 0.1em;
  color: #585858;
}
body #breadcrumb section.breadcrumb-block .inner ol li:after {
  content: ">";
  display: inline-block;
  margin-right: 12px;
  margin-left: 12px;
}
body #breadcrumb section.breadcrumb-block .inner ol li:last-of-type a {
  pointer-events: none;
}
body #breadcrumb section.breadcrumb-block .inner ol li:last-of-type:after {
  display: none;
}
@media screen and (max-width: 850px) {
  body #breadcrumb {
    display: none;
  }
}

body.home {
  position: relative;
}
body.home img {
  width: 100%;
}
body.home header #nav {
  opacity: 0;
  transform: translate(0px, -200px);
  transition: all 0.6s;
}
@media screen and (max-width: 1135px) {
  body.home header #nav {
    opacity: 1;
    transform: translate(0px, 0px);
    background-color: rgba(255, 255, 255, 0);
  }
}
body.home.scroll header #nav {
  opacity: 1;
  transform: translate(0px, 0px);
  background-color: white;
}
body.home main section {
  position: relative;
}
body.home main section + section {
  margin-top: 160px;
}
body.home main section .inner {
  margin-left: auto;
  margin-right: auto;
}
body.home main section h1.ttl {
  font-size: 28px;
  letter-spacing: 0.05em;
  line-height: 1.8;
  margin-bottom: 40px;
}
body.home main section h1.ttl.ff-go {
  font-weight: bold;
  font-size: 26px;
}
body.home main section h1.ttl.ff-en {
  font-size: 35px;
  letter-spacing: 0.15em;
}
body.home main section h1.ttl.ff-robo {
  font-size: 30px;
  font-weight: bold;
  letter-spacing: 0.15em;
}
@media screen and (max-width: 850px) {
  body.home main section h1.ttl h1.ttl {
    font-size: 28px;
    letter-spacing: 0.05em;
    line-height: 1.7;
    margin-bottom: 25px;
  }
  body.home main section h1.ttl h1.ttl.ff-go {
    font-weight: bold;
    font-size: 20px;
  }
  body.home main section h1.ttl h1.ttl.ff-en {
    font-size: 30px;
    letter-spacing: 0.15em;
  }
  body.home main section h1.ttl h1.ttl.ff-robo {
    font-size: 25px;
    font-weight: bold;
    letter-spacing: 0.15em;
  }
}
body.home main section h2.ttl {
  color: #000;
  font-size: 35px;
  line-height: 1.4;
  letter-spacing: 0.2em;
  margin-bottom: 38px;
}
body.home main section h3.ttl {
  color: #000;
  font-size: 25px;
  line-height: 1.6;
  letter-spacing: 0.3em;
  margin-bottom: 35px;
}
body.home main section h4.ttl {
  font-weight: bold;
  color: #000;
  font-size: 18px;
  line-height: 1.6;
  letter-spacing: 0.22em;
  margin-bottom: 25px;
}
body.home main section .txt {
  text-align: justify;
}
body.home main section .btn-area {
  margin-top: 45px;
}
body.home main section.hero-section {
  height: 100vh;
  position: relative;
  padding: 0;
}
body.home main section.hero-section .swiper-container {
  height: 100vh;
}
body.home main section.hero-section .swiper-container .swiper-wrapper .swiper-slide .image {
  transform: scale(1.2);
}
body.home main section.hero-section .swiper-container .swiper-wrapper .swiper-slide .image.visible-md {
  display: none;
}
@media screen and (max-width: 850px) {
  body.home main section.hero-section .swiper-container .swiper-wrapper .swiper-slide .image.hidden-md {
    display: none;
  }
  body.home main section.hero-section .swiper-container .swiper-wrapper .swiper-slide .image.visible-md {
    display: block;
  }
}
body.home main section.hero-section .swiper-container .swiper-wrapper .swiper-slide.swiper-slide-active .image, body.home main section.hero-section .swiper-container .swiper-wrapper .swiper-slide.swiper-slide-duplicate-active .image, body.home main section.hero-section .swiper-container .swiper-wrapper .swiper-slide.swiper-slide-prev .image {
  animation: zoomOut 10s linear 0s 1 normal both;
}
body.home main section.hero-section .swiper-container .swiper-pagination {
  bottom: 104px;
  left: 0;
  right: 0;
  text-align: right;
}
@media screen and (max-width: 850px) {
  body.home main section.hero-section .swiper-container .swiper-pagination {
    text-align: left;
    bottom: 85px;
    right: inherit;
    width: 220px;
  }
}
body.home main section.hero-section .swiper-container .hero-btn-area {
  position: absolute;
  box-sizing: border-box;
  bottom: 152px;
  left: 0;
  right: 0;
  text-align: right;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  flex-wrap: nowrap;
}
@media screen and (max-width: 850px) {
  body.home main section.hero-section .swiper-container .hero-btn-area {
    width: 50%;
    bottom: 85px;
    right: 0;
    left: inherit;
  }
}
body.home main section.hero-section .news-area {
  background-color: #fff;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  padding: 24px 0;
}
body.home main section.hero-section .news-area .inner .news-posts {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
}
body.home main section.hero-section .news-area .inner .news-posts .news-card {
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: nowrap;
  color: #000;
  font-size: 12px;
  letter-spacing: 0.1em;
  line-height: 1.6;
  width: 90%;
}
body.home main section.hero-section .news-area .inner .news-posts .news-card .type, body.home main section.hero-section .news-area .inner .news-posts .news-card .date, body.home main section.hero-section .news-area .inner .news-posts .news-card .cate, body.home main section.hero-section .news-area .inner .news-posts .news-card .spec {
  padding-right: 2.82%;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: nowrap;
  padding-top: 2px;
  padding-bottom: 2px;
}
body.home main section.hero-section .news-area .inner .news-posts .news-card .type {
  border-right: 1px solid #707070;
  font-weight: bold;
  margin-right: 2.82%;
}
body.home main section.hero-section .news-area .inner .news-posts .news-card .date {
  border-right: 1px solid #707070;
  margin-right: 2.82%;
}
body.home main section.hero-section .news-area .inner .news-posts .news-card .cate {
  font-weight: bold;
}
body.home main section.hero-section .news-area .inner .news-posts .btn01 {
  width: 132px;
  font-weight: normal;
}
body.home main section.idty-section {
  padding-top: 0px;
  margin-top: 0;
  position: relative;
}
body.home main section.idty-section .ttl-area {
  position: absolute;
  right: 0;
  left: 0;
  bottom: 60px;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  z-index: 1;
}
body.home main section.idty-section .ttl-area h2.ttl {
  color: #fff;
}
body.home main section.idty-section .ttl-area .btn {
  display: block;
}
body.home main section.idty-section .bg-movie {
  text-align: center;
  font-size: 0;
  overflow: hidden;
}
body.home main section.idty-section .bg-movie .bg-movie-box {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
body.home main section.prdt-section .item-area {
  margin-top: 45px;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: nowrap;
}
body.home main section.prdt-section .item-area .item {
  width: 25%;
  text-align: center;
}
body.home main section.prdt-section .item-area .item .txt {
  padding: 5px 0 2px 30px;
  border-left: 1px solid #707070;
  letter-spacing: 0.1em;
  display: inline-block;
  margin-left: auto;
  margin-right: auto;
  font-weight: bold;
  margin-top: 22px;
}
body.home main section.prdt-section .btn-area {
  margin-top: 72px;
}
body.home main section.prdt-section .btn-area .btn01 {
  margin-left: auto;
  margin-right: auto;
}
body.home main section.slon-section {
  background-color: #000;
  margin-top: 0;
}
body.home main section.slon-section .two-clm .inner .item-box01 .note {
  position: absolute;
  right: 14px;
  bottom: 20px;
  font-size: 12px;
  letter-spacing: 0.12em;
  color: #CECECE;
}
body.home main section.slon-section .two-clm .inner .item-box02 .icn {
  width: 150px;
  display: block;
  margin-bottom: 35px;
}
body.home main section.slon-section .two-clm .inner .item-box02 .btn {
  margin-top: 45px;
}
body.home main section.slon-section .two-clm .inner:before {
  background: url(../img/top/slon-section_bg_01.jpg) no-repeat center;
  background-size: cover;
}
body.home main section.sprt-section .inner .pict-area {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
}
body.home main section.sprt-section .inner .pict-area .item {
  max-width: 328px;
  width: calc(33.3333333333% - 24px);
  display: block;
  margin-top: 50px;
}
body.home main section.sprt-section .inner .pict-area .item .txt {
  display: block;
  font-size: 13px;
  letter-spacing: 0.22em;
  margin-top: 25px;
}
body.home main section.sprt-section .inner .btn-area {
  margin-top: 80px;
}
body.home main section.sprt-section .inner .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
body.home main section.bnr-section {
  margin-top: 0;
}
body.home main section.bnr-section .two-clm .inner .item-box.item-box01 {
  padding-top: 65px;
  padding-bottom: 62px;
}
body.home main section.bnr-section .two-clm .inner .item-box.item-box01 h2.ttl {
  color: #000;
  margin-bottom: 20px;
}
body.home main section.bnr-section .two-clm .inner .item-box.item-box01 .txt {
  color: #000;
  letter-spacing: 0.12em;
}
body.home main section.bnr-section .two-clm .inner .item-box.item-box01 .btn {
  margin-top: 40px;
}
body.home main section.bnr-section .two-clm .inner .item-box.item-box02 .btn {
  display: none;
}
body.home main section.bnr-section .two-clm .inner:before {
  background: url(../img/top/bnr-section_bg_01.jpg) no-repeat center;
  background-size: cover;
}
body.home main section.bnr-section .two-clm .inner:after {
  background: url(../img/top/bnr-section_bg_02.jpg) no-repeat center;
  background-size: cover;
}
body.home main section.press-section {
  background-color: #F2F1EF;
  padding-top: 65px;
  padding-bottom: 62px;
  margin-top: 0;
}
body.home main section.press-section .inner .press-posts .press-card {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: nowrap;
  padding-bottom: 16px;
  border-bottom: 1px solid #707070;
}
body.home main section.press-section .inner .press-posts .press-card + .press-card {
  margin-top: 26px;
}
body.home main section.press-section .inner .press-posts .press-card span {
  display: inline-block;
}
body.home main section.press-section .inner .press-posts .press-card .date {
  margin-right: 45px;
  font-size: 14px;
  letter-spacing: 0.1em;
}
body.home main section.press-section .inner .press-posts .press-card .cate {
  border: 1px solid #000;
  font-size: 11px;
  padding-left: 16px;
  padding-right: 14px;
  text-align: center;
  margin-right: 18px;
  letter-spacing: 0.2em;
  line-height: 21px;
}
body.home main section.press-section .inner .press-posts .press-card .spec {
  font-size: 14px;
  letter-spacing: 0.1em;
  line-height: 1.6;
}
body.home main section.press-section .inner .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
body.home main section.leter-section {
  margin-top: 0;
}
body.home main section.leter-section .info-area {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
  background-color: #000;
}
body.home main section.leter-section .info-area .item-box {
  height: 136px;
}
body.home main section.leter-section .info-area .item-box.item-box01 {
  width: 24%;
  border-right: 1px solid #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: nowrap;
}
body.home main section.leter-section .info-area .item-box.item-box01 .logo {
  width: 100%;
  max-width: 128px;
  margin-left: auto;
  margin-right: auto;
}
body.home main section.leter-section .info-area .item-box.item-box02 {
  width: 76%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
}
body.home main section.leter-section .info-area .item-box.item-box02 .txt {
  font-size: 16px;
  letter-spacing: 0.12em;
  color: #CECECE;
  font-weight: bold;
  margin-left: 14%;
  margin-right: 8%;
}
body.home main section.leter-section .info-area .item-box.item-box02 .btn {
  margin-right: auto;
  margin-left: auto;
}
body.home main section.leter-section .info-area .item-box.item-box02 .btn-area-box {
  padding-right: 10%;
}
body.home main section.leter-section .info-area .item-box.item-box02 .btn-area-box .text-link {
  color: #fff;
  text-decoration: underline;
  font-size: 12px;
  padding-top: 10px;
  display: block;
}
@media screen and (max-width: 850px) {
  body.home main section + section {
    margin-top: 90px;
  }
  body.home main section h2.ttl {
    font-size: 30px;
    margin-bottom: 35px;
    text-align: center;
    letter-spacing: 0.1em;
    line-height: 1.3;
  }
  body.home main section h3.ttl {
    font-size: 25px;
    margin-bottom: 25px;
  }
  body.home main section h4.ttl {
    text-align: center;
    font-size: 16px;
    margin-bottom: 20px;
  }
  body.home main section.hero-section {
    height: 100%;
  }
  body.home main section.hero-section .news-area {
    position: relative;
    top: 0px;
    padding: 18px 0 27px;
    margin-top: -50px;
  }
  body.home main section.hero-section .news-area .inner .news-posts {
    display: block;
  }
  body.home main section.hero-section .news-area .inner .news-posts .news-card {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
  }
  body.home main section.hero-section .news-area .inner .news-posts .news-card .type, body.home main section.hero-section .news-area .inner .news-posts .news-card .date, body.home main section.hero-section .news-area .inner .news-posts .news-card .cate, body.home main section.hero-section .news-area .inner .news-posts .news-card .spec {
    padding-right: 0;
    margin-right: 0;
    line-height: 1;
  }
  body.home main section.hero-section .news-area .inner .news-posts .news-card .type {
    width: 20%;
  }
  body.home main section.hero-section .news-area .inner .news-posts .news-card .date {
    width: 30%;
  }
  body.home main section.hero-section .news-area .inner .news-posts .news-card .cate {
    width: 31%;
  }
  body.home main section.hero-section .news-area .inner .news-posts .news-card .spec {
    width: 100%;
    margin-top: 18px;
    padding-right: 0;
    font-size: 14px;
    margin-right: 0;
    padding-top: 14px;
    border-top: 1px solid #CBCBCB;
    line-height: 2;
  }
  body.home main section.hero-section .news-area .inner .news-posts .btn01 {
    width: 142px;
    margin-top: 20px;
    padding: 5px 10px;
  }
  body.home main section.idty-section .inner {
    display: block;
  }
  body.home main section.idty-section .inner .text-area {
    padding-left: 0;
  }
  body.home main section.idty-section .ttl-area .btn {
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-top: 40px;
  }
  body.home main section.idty-section .bg-movie {
    height: 60vh;
  }
  body.home main section.prdt-section .item-area {
    margin-top: 15px;
    margin-left: auto;
    margin-right: auto;
    max-width: 1162px;
    padding-left: 23px;
    padding-right: 23px;
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    flex-wrap: wrap;
  }
  body.home main section.prdt-section .item-area .item {
    width: 100%;
    margin-top: 35px;
  }
  body.home main section.prdt-section .item-area .item.item02, body.home main section.prdt-section .item-area .item.item03 {
    width: calc((100% - 33px) / 2);
  }
  body.home main section.prdt-section .item-area .item .txt {
    display: block;
    padding: 2px 0 0px 16px;
    line-height: 1;
    margin-top: 20px;
  }
  body.home main section.slon-section .two-clm .inner .item-box01 {
    padding: 0;
    position: relative;
    height: 260px;
  }
  body.home main section.slon-section .two-clm .inner .item-box01 .icn {
    display: block;
    width: 80px;
    position: absolute;
    top: 14px;
    right: -10px;
  }
  body.home main section.slon-section .two-clm .inner .item-box01 .note {
    position: absolute;
    bottom: 14px;
    right: -10px;
  }
  body.home main section.slon-section .two-clm .inner .item-box02 {
    padding: 60px 0 100px;
  }
  body.home main section.slon-section .two-clm .inner .item-box02 .icn {
    display: none;
  }
  body.home main section.slon-section .two-clm .inner .item-box02 .txt {
    text-align: center;
  }
  body.home main section.slon-section .two-clm .inner .item-box02 .btn {
    margin-top: 34px;
    margin-left: auto;
    margin-right: auto;
  }
  body.home main section.slon-section .two-clm .inner:before {
    height: 260px;
  }
  body.home main section.slon-section .two-clm .inner:after {
    display: none;
  }
  body.home main section.sprt-section .inner .pict-area {
    display: block;
    margin-left: -23px;
    margin-right: -23px;
    margin-top: 30px;
  }
  body.home main section.sprt-section .inner .pict-area .item {
    max-width: none;
    margin-top: 0px;
    width: 100%;
  }
  body.home main section.sprt-section .inner .pict-area .item + .item {
    margin-top: 35px;
  }
  body.home main section.sprt-section .inner .pict-area .item .txt {
    font-size: 14px;
    text-align: center;
    margin-top: 20px;
  }
  body.home main section.bnr-section .two-clm .inner .item-box.item-box01 {
    text-align: center;
    padding: 42px 0;
  }
  body.home main section.bnr-section .two-clm .inner .item-box.item-box01 h2.ttl {
    line-height: 1.2;
    margin-bottom: 15px;
  }
  body.home main section.bnr-section .two-clm .inner .item-box.item-box01 .txt {
    text-align: center;
  }
  body.home main section.bnr-section .two-clm .inner .item-box.item-box01 .btn {
    display: none;
  }
  body.home main section.bnr-section .two-clm .inner .item-box.item-box02 {
    height: 215px;
    position: relative;
    padding: 80px 0;
  }
  body.home main section.bnr-section .two-clm .inner .item-box.item-box02 .btn {
    display: block;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
  }
  body.home main section.bnr-section .two-clm .inner:before {
    height: 291px;
  }
  body.home main section.bnr-section .two-clm .inner:after {
    height: 215px;
    top: 291px;
  }
  body.home main section.press-section {
    padding-top: 55px;
    padding-bottom: 60px;
  }
  body.home main section.press-section .inner h2.ttl {
    text-align: left;
  }
  body.home main section.press-section .inner .press-posts .press-card {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: wrap;
  }
  body.home main section.press-section .inner .press-posts .press-card .date {
    margin-right: 30px;
  }
  body.home main section.press-section .inner .press-posts .press-card .cate {
    line-height: 20px;
  }
  body.home main section.press-section .inner .press-posts .press-card .spec {
    width: 100%;
    margin-top: 18px;
    line-height: 1.8;
  }
  body.home main section.leter-section .info-area {
    display: block;
  }
  body.home main section.leter-section .info-area .item-box {
    height: auto;
    width: 100%;
    display: block;
  }
  body.home main section.leter-section .info-area .item-box.item-box01 {
    border-right: none;
    border-bottom: 1px solid #fff;
    padding: 20px 0;
    width: 100%;
  }
  body.home main section.leter-section .info-area .item-box.item-box01 .logo {
    width: 115px;
  }
  body.home main section.leter-section .info-area .item-box.item-box02 {
    width: 100%;
    display: block;
    padding: 25px 0 42px;
  }
  body.home main section.leter-section .info-area .item-box.item-box02 .txt {
    text-align: center;
    margin: 0;
  }
  body.home main section.leter-section .info-area .item-box.item-box02 .btn {
    margin-left: auto;
    margin-right: auto;
    margin-top: 18px;
  }
  body.home main section.leter-section .info-area .item-box.item-box02 .btn-area-box {
    padding-right: 0;
  }
  body.home main section.leter-section .info-area .item-box.item-box02 .btn-area-box .text-link {
    text-align: center;
    padding-top: 25px;
  }
}

#top-nav-area {
  position: absolute;
  top: 0px;
  left: 0;
  right: 0;
  z-index: 1;
  padding-top: 32px;
  transition: transform 0.6s;
}
#top-nav-area img {
  width: 100%;
}
@media screen and (max-width: 1135px) {
  #top-nav-area {
    display: none;
  }
}
#top-nav-area .inner .inner-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: nowrap;
  position: relative;
  margin-bottom: 30px;
}
#top-nav-area .inner .inner-header .logo {
  max-width: 124px;
  height: 18px;
  position: absolute;
  left: 0;
  right: 0;
  top: 6px;
  margin: auto;
}
#top-nav-area .inner .inner-header .logo img {
  width: 100%;
}
#top-nav-area .inner .inner-header .btn-area {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: nowrap;
  width: 334px;
}
#top-nav-area .inner .inner-header .btn-area .btn01 {
  width: 160px;
  letter-spacing: 0.15em;
}
#top-nav-area .inner .inner-main {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: nowrap;
}
#top-nav-area .inner .inner-main .nav-box {
  margin: 0 2%;
}
#top-nav-area .inner .inner-main .nav-box:first-of-type {
  margin-left: 0;
}
#top-nav-area .inner .inner-main .nav-box:last-of-type {
  margin-right: 0;
}
#top-nav-area .inner .inner-main .nav-box .link-item {
  color: #000;
  font-weight: bold;
  font-size: 13px;
  letter-spacing: 0.1em;
  line-height: 1.6;
  cursor: pointer;
  transition: transform 0.6s;
}
#top-nav-area .inner .inner-main .nav-box .link-item span {
  display: inline-block;
  border-bottom: 1px solid rgba(0, 0, 0, 0);
}
#top-nav-area .inner .inner-main .nav-box .link-item:hover {
  opacity: 0.4;
}
#top-nav-area .inner .inner-main .nav-box .link-item:hover span {
  border-bottom: 1px solid rgb(0, 0, 0);
}
#top-nav-area .inner .inner-main .nav-box.ani-nav {
  transition: transform 0.6s;
}
#top-nav-area .inner .inner-main .nav-box.ani-nav .sub-nav {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: nowrap;
  visibility: hidden;
  position: absolute;
  opacity: 0;
  padding-top: 35px;
  padding-bottom: 35px;
  width: 100%;
  transition: transform 0.6s;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  z-index: -2;
}
#top-nav-area .inner .inner-main .nav-box.ani-nav .sub-nav:after {
  content: "";
  width: 100vw;
  height: calc(100% + 133px);
  background-color: rgba(255, 255, 255, 0);
  z-index: -4;
  position: absolute;
  top: -133px;
}
#top-nav-area .inner .inner-main .nav-box.ani-nav .sub-nav .sub-box {
  margin: 0 1%;
  display: inline-block;
}
#top-nav-area .inner .inner-main .nav-box.ani-nav .sub-nav .sub-box:first-of-type {
  margin-left: 0;
}
#top-nav-area .inner .inner-main .nav-box.ani-nav .sub-nav .sub-box:last-of-type {
  margin-right: 0;
}
#top-nav-area .inner .inner-main .nav-box.ani-nav .sub-nav .sub-box .link-item {
  display: block;
}
#top-nav-area .inner .inner-main .nav-box.ani-nav .sub-nav .sub-box .link-item + .link-item {
  margin-top: 10px;
}
#top-nav-area .inner .inner-main .nav-box.ani-nav.open .icn-arw {
  opacity: 0.4;
  background-image: url(../img/common/arw_up.svg);
}
#top-nav-area .inner .inner-main .nav-box.ani-nav.open .icn-arw span {
  border-bottom: 1px solid rgb(0, 0, 0);
}
#top-nav-area .inner .inner-main .nav-box.ani-nav.open .sub-nav {
  visibility: visible;
  opacity: 1;
}
#top-nav-area .inner .inner-main .nav-box.ani-nav.open .sub-nav:after {
  background-color: rgba(255, 255, 255, 0.6);
}

#nav {
  background-color: #fff;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 20;
  padding-top: 24px;
  padding-bottom: 25px;
}
#nav img {
  width: 100%;
}
#nav .inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
  position: relative;
}
#nav .inner .logo {
  min-width: 95px;
  width: 95px;
  margin-right: 3.5%;
  margin-top: -15px;
}
@media screen and (max-width: 1135px) {
  #nav .inner .logo {
    min-width: 114px;
    width: 114px;
    margin-right: 15px;
    margin-top: -2px;
  }
}
#nav .inner .inner-content {
  width: calc(96.5% - 95px);
}
@media screen and (max-width: 1135px) {
  #nav .inner .inner-content {
    display: none;
  }
}
#nav .inner .nav-area {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  flex-wrap: nowrap;
  margin-right: 8px;
}
@media screen and (max-width: 1135px) {
  #nav .inner .nav-area {
    display: none;
  }
}
#nav .inner .nav-area .nav-box {
  margin: 0 1.4%;
}
#nav .inner .nav-area .nav-box:first-of-type {
  margin-left: 0;
}
#nav .inner .nav-area .nav-box:last-of-type {
  margin-right: 0;
}
#nav .inner .nav-area .nav-box .link-item {
  color: #000;
  font-weight: bold;
  font-size: 13px;
  letter-spacing: 0.1em;
  line-height: 1.6;
  cursor: pointer;
  transition: transform 0.6s;
}
#nav .inner .nav-area .nav-box .link-item span {
  display: inline-block;
  border-bottom: 1px solid rgba(0, 0, 0, 0);
}
#nav .inner .nav-area .nav-box .link-item:hover {
  opacity: 0.4;
}
#nav .inner .nav-area .nav-box .link-item:hover span {
  border-bottom: 1px solid rgb(0, 0, 0);
}
#nav .inner .nav-area .nav-box.ani-nav {
  transition: transform 0.6s;
}
#nav .inner .nav-area .nav-box.ani-nav .sub-nav {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: nowrap;
  visibility: hidden;
  position: absolute;
  opacity: 0;
  padding: 45px 0;
  width: 100%;
  transition: transform 0.6s;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
}
#nav .inner .nav-area .nav-box.ani-nav .sub-nav .sub-box {
  margin: 0 1%;
  display: inline-block;
}
#nav .inner .nav-area .nav-box.ani-nav .sub-nav .sub-box:first-of-type {
  margin-left: 0;
}
#nav .inner .nav-area .nav-box.ani-nav .sub-nav .sub-box:last-of-type {
  margin-right: 0;
}
#nav .inner .nav-area .nav-box.ani-nav .sub-nav .sub-box .link-item {
  display: block;
}
#nav .inner .nav-area .nav-box.ani-nav .sub-nav .sub-box .link-item + .link-item {
  margin-top: 10px;
}
#nav .inner .nav-area .nav-box.ani-nav .sub-nav:after {
  content: "";
  position: absolute;
  left: 0;
  background-color: #fff;
  width: 200%;
  height: 100%;
  z-index: -1;
  left: -50%;
  top: 0;
}
#nav .inner .nav-area .nav-box.ani-nav.open .icn-arw {
  opacity: 0.4;
  background-image: url(../img/common/arw_up.svg);
}
#nav .inner .nav-area .nav-box.ani-nav.open .icn-arw span {
  border-bottom: 1px solid rgb(0, 0, 0);
}
#nav .inner .nav-area .nav-box.ani-nav.open .sub-nav {
  visibility: visible;
  opacity: 1;
}
#nav .inner .btn-area {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  flex-wrap: nowrap;
  position: relative;
  z-index: 2;
  margin-bottom: 28px;
}
@media screen and (max-width: 1135px) {
  #nav .inner .btn-area {
    display: none;
  }
}
#nav .inner .btn-area .btn {
  width: 140px;
  letter-spacing: 0.12em;
  margin: 0 7px;
  padding: 5px 8px;
}
#nav .inner .btn-area .online-btn {
  width: 62px;
  margin-left: 20px;
}
#nav .sp-nav {
  position: fixed;
  top: 0;
  right: 0;
  height: 100vh;
  width: 90.67%;
  background-color: #fff;
  padding: 30px 54px 65px;
  visibility: visible;
  opacity: 0;
  transform: translate(0%, 100%) matrix(1, 0, 0, 1, 0, 0);
  transition: transform 0.8s;
  overflow: scroll;
  max-width: 380px;
}
#nav .sp-nav .lrg .link-txt {
  font-weight: normal;
}
#nav .sp-nav .nav-area {
  margin-top: 20px;
}
#nav .sp-nav .nav-area .link-item {
  font-size: 17px;
  line-height: 1.6;
  letter-spacing: 0.1em;
  display: inline-block;
}
#nav .sp-nav .nav-area .link-item:nth-of-type(n + 2) {
  margin-top: 8%;
}
#nav .sp-nav .btn-area {
  margin-top: 38px;
}
#nav .sp-nav .btn-area .btn {
  max-width: 228px;
}
#nav .sp-nav .btn-area .btn + .btn {
  margin-top: 23px;
}
#nav .sp-nav .sns-area {
  margin-top: 40px;
}
#nav .sp-nav .sns-area p {
  font-size: 18px;
  line-height: 1.6;
  letter-spacing: 0.1em;
}
#nav .sp-nav .sns-area .icn-area {
  margin-top: 22px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
}
#nav .sp-nav .sns-area .icn-area .icn {
  margin-left: 10px;
  margin-right: 10px;
}
#nav .sp-nav .sns-area .icn-area .icn.icn01 {
  width: 24px;
}
#nav .sp-nav .sns-area .icn-area .icn.icn02 {
  width: 24px;
}
#nav .sp-nav .sns-area .icn-area .icn.icn03 {
  width: 24px;
}
#nav .sp-nav .sns-area .icn-area .icn.icn04 {
  width: 30px;
}
#nav .sp-nav .sns-area .icn-area .icn:first-child {
  margin-left: 0;
}
#nav .sp-nav .sns-area .icn-area .icn:last-child {
  margin-right: 0;
}
#nav .sp-close {
  width: 36px;
  height: 100%;
  z-index: 10;
}
#nav .sp-close .line {
  height: 2px;
  width: 100%;
  background-color: #000;
  transition: transform 0.8s;
  display: block;
  border-radius: 5px;
}
#nav .sp-close .line.line01 {
  transform: translate(0px, -5px) scale(1, 1);
}
#nav .sp-close .line.line02 {
  transform: translate(-7px, 4px) scale(0.6111, 1);
}
#nav.open .sp-nav {
  opacity: 1;
  transform: matrix(1, 0, 0, 1, 0, 0);
}
#nav.open .sp-close .line.line01 {
  transform: translate(0px, 6px) scale(1, 1) rotate(45deg);
}
#nav.open .sp-close .line.line02 {
  transform: translate(0px, 3px) scale(1, 1) rotate(-45deg);
}
@media screen and (max-width: 1135px) {
  #nav {
    padding-top: 0px;
    padding-bottom: 0px;
  }
  #nav .inner {
    padding-top: 25px;
    padding-bottom: 22px;
  }
  #nav .inner .logo {
    min-width: 114px;
    width: 114px;
  }
}

body main.page section {
  padding-top: 160px;
  padding-bottom: 160px;
}
body main.page section h1 {
  font-size: 28px;
  letter-spacing: 0.05em;
  line-height: 1.8;
  margin-bottom: 40px;
}
body main.page section h1.ff-go {
  font-weight: bold;
  font-size: 26px;
}
body main.page section h1.ff-en {
  font-size: 35px;
  letter-spacing: 0.15em;
}
body main.page section h1.ff-robo {
  font-size: 30px;
  font-weight: bold;
  letter-spacing: 0.15em;
}
body main.page section h1 .min-txt {
  font-size: 82%;
  /* letter-spacing: 0.08em; */
  /* display: inline-block; */
  position: relative;
  top: -1px;
}
body main.page section h2 {
  font-size: 23px;
  letter-spacing: 0.05em;
  line-height: 1.8;
  margin-bottom: 40px;
}
body main.page section h2.ff-go {
  font-weight: bold;
  font-size: 20px;
}
body main.page section h2.ff-en {
  font-size: 30px;
  letter-spacing: 0.15em;
}
body main.page section h2.ff-robo {
  font-size: 25px;
  font-weight: bold;
  letter-spacing: 0.15em;
}
body main.page section h3 {
  font-size: 18px;
  letter-spacing: 0.05em;
  line-height: 1.8;
  margin-bottom: 40px;
  font-weight: 600;
}
body main.page section h3.ff-go {
  font-weight: bold;
  font-size: 18px;
}
body main.page section h3.ff-en {
  font-size: 25px;
  letter-spacing: 0.15em;
  font-weight: normal;
}
body main.page section h3.ff-robo {
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.15em;
}
body main.page section h4 {
  font-size: 14px;
  letter-spacing: 0.05em;
  line-height: 1.8;
  margin-bottom: 40px;
  font-weight: 600;
}
body main.page section h4.ff-go {
  font-weight: bold;
  font-size: 15px;
}
body main.page section h4.ff-en {
  font-size: 17px;
  letter-spacing: 0.15em;
  font-weight: normal;
}
body main.page section h4.ff-robo {
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.15em;
}
body main.page section h5 {
  font-size: 12px;
  letter-spacing: 0.05em;
  line-height: 1.8;
  margin-bottom: 40px;
  font-weight: 600;
}
body main.page section h5.ff-go {
  font-weight: bold;
  font-size: 13px;
}
body main.page section h5.ff-en {
  font-size: 13px;
  letter-spacing: 0.15em;
  font-weight: normal;
}
body main.page section h5.ff-robo {
  font-size: 13px;
  letter-spacing: 0.15em;
}
body main.page section p {
  font-size: 13px;
  line-height: 2.3;
  letter-spacing: 0.08em;
}
body main.page section p:not(main.single) p {
  text-align: justify;
}
body main.page section .sub-txt {
  font-size: 16px;
  text-align: center;
  letter-spacing: 0.2em;
  line-height: 2;
  margin-top: 42px;
}
body main.page section h1.center, body main.page section h2.center, body main.page section h3.center, body main.page section h4.center, body main.page section h5.center, body main.page section p.center {
  text-align: center;
}
body main.page section .ttl-line {
  padding-top: 20px;
  padding-bottom: 20px;
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
  text-align: center;
}
body main.page section .ttl .fs-min {
  font-size: 84%;
}
@media screen and (max-width: 850px) {
  body main.page section h1 {
    font-size: 26px;
    letter-spacing: 0.05em;
    line-height: 1.8;
  }
  body main.page section h1.ff-go {
    font-weight: bold;
    font-size: 20px;
  }
  body main.page section h1.ff-en {
    font-size: 30px;
    letter-spacing: 0.15em;
    line-height: 1.3;
  }
  body main.page section h1.ff-en.ja {
    line-height: 1.6;
  }
  body main.page section h1.ff-robo {
    font-size: 25px;
    font-weight: bold;
    letter-spacing: 0.15em;
    line-height: 1.6;
  }
  body main.page section h2 {
    font-size: 20px;
    letter-spacing: 0.05em;
    line-height: 1.9;
  }
  body main.page section h2.ff-go {
    font-weight: bold;
    font-size: 18px;
    line-height: 2.1;
  }
  body main.page section h2.ff-en {
    font-size: 25px;
    letter-spacing: 0.15em;
    line-height: 1.6;
  }
  body main.page section h2.ff-robo {
    font-size: 20px;
    font-weight: bold;
    letter-spacing: 0.15em;
    line-height: 2;
  }
  body main.page section h3 {
    font-size: 16px;
    letter-spacing: 0.05em;
    line-height: 2;
  }
  body main.page section h3.ff-go {
    font-weight: bold;
    font-size: 16px;
    line-height: 2;
  }
  body main.page section h3.ff-en {
    font-size: 17px;
    letter-spacing: 0.15em;
    line-height: 1.8;
    font-weight: normal;
  }
  body main.page section h3.ff-robo {
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.15em;
    line-height: 2;
  }
  body main.page section h4 {
    font-size: 14px;
    letter-spacing: 0.05em;
    line-height: 2;
  }
  body main.page section h4.ff-go {
    font-weight: bold;
    font-size: 13px;
  }
  body main.page section h4.ff-en {
    font-size: 13px;
    letter-spacing: 0.15em;
    line-height: 1.8;
    font-weight: normal;
  }
  body main.page section h4.ff-robo {
    font-size: 13px;
    font-weight: bold;
    letter-spacing: 0.15em;
    line-height: 1.8;
  }
  body main.page section h5 {
    font-size: 12px;
    letter-spacing: 0.05em;
    line-height: 2.1;
  }
  body main.page section h5.ff-robo {
    font-size: 11px;
    letter-spacing: 0.15em;
    font-weight: normal;
    line-height: 2;
  }
  body main.page section p {
    font-size: 14px;
    line-height: 2;
    letter-spacing: 0.05em;
  }
  body main.page section .sub-txt {
    font-size: 14px;
    text-align: justify !important;
    letter-spacing: 0.15em;
    line-height: 2;
    margin-top: 30px;
  }
}
@media screen and (max-width: 850px) {
  body main.page section {
    padding-top: 90px;
    padding-bottom: 90px;
  }
}
body main.page section:last-of-type {
  padding-bottom: 150px;
}
@media screen and (max-width: 850px) {
  body main.page section:last-of-type {
    padding-bottom: 90px;
  }
}
body main.page section.page-header {
  padding-top: 210px;
  padding-bottom: 130px;
}
body main.page section.page-header + section {
  padding-top: 0;
}
@media screen and (max-width: 850px) {
  body main.page section.page-header {
    padding-top: 150px;
    padding-bottom: 50px;
  }
  body main.page section.page-header + section {
    padding-top: 0;
  }
}
body main.page section.page-header .ttl {
  text-align: center;
  margin-bottom: 0;
}
@media screen and (max-width: 850px) {
  body main.page section.page-header .ttl {
    margin-bottom: 40px;
  }
}
body main.page section.page-header p.txt {
  font-size: 16px;
  text-align: center;
  letter-spacing: 0.2em;
  line-height: 2;
  margin-top: 40px;
}
body main.page section.page-header p.txt .note {
  font-size: 13px;
  display: block;
  margin-top: 15px;
  letter-spacing: 0.12em;
}
@media screen and (max-width: 850px) {
  body main.page section.page-header p.txt {
    text-align: justify;
    letter-spacing: 0.05em;
  }
}
body main.page section.page-header h2.sub-ttl {
  margin-top: 35px;
  margin-bottom: 20px;
  text-align: center;
}
body main.page section.page-header h2.sub-ttl + .txt {
  margin-top: 32px;
}
@media screen and (max-width: 850px) {
  body main.page section.page-header h2.sub-ttl h2.sub-ttl {
    text-align: justify;
    margin-top: 36px;
  }
  body main.page section.page-header h2.sub-ttl h2.sub-ttl + .txt {
    margin-top: 24px;
  }
}
body main.page section.page-header .inner.flex {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
}
body main.page section.page-header .inner.flex .ttl {
  width: 32%;
  text-align: justify;
}
body main.page section.page-header .inner.flex p.txt {
  width: 66%;
  margin: 0;
  text-align: justify;
  letter-spacing: 0.08em;
  font-size: 13px;
}
@media screen and (max-width: 850px) {
  body main.page section.page-header .inner.flex {
    display: block;
  }
  body main.page section.page-header .inner.flex .ttl {
    width: 100%;
    text-align: center;
  }
  body main.page section.page-header .inner.flex p.txt {
    width: 100%;
    letter-spacing: 0.05em;
  }
}
body main.page section.page-header .btn-area .btn.on {
  background-color: #AFAFAF;
  border-color: #AFAFAF;
  color: #fff;
  pointer-events: none;
}
body main.page section.page-header .link-area {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: nowrap;
  margin-top: 60px;
  z-index: 0;
  position: relative;
}
body main.page section.page-header .link-area .item .link-txt03 {
  margin-left: 13px;
  margin-right: 13px;
  padding-right: 16px;
  background: url(../img/common/arw_down.svg) no-repeat center right;
  background-size: 8px;
  display: inline-block;
  color: #000;
  font-weight: bold;
  font-size: 13px;
  letter-spacing: 0.1em;
  line-height: 1.8;
}
@media screen and (max-width: 850px) {
  body main.page section.page-header .link-area {
    display: block;
    margin-top: 40px;
  }
  body main.page section.page-header .link-area .item {
    text-align: center;
  }
  body main.page section.page-header .link-area .item + .item {
    margin-top: 20px;
  }
  body main.page section.page-header .link-area .item .link-txt03 {
    font-size: 14x;
    background-size: 7px;
    padding-right: 20px;
  }
}
body main.page section.page-header .list-box {
  display: block;
  margin-left: auto;
  margin-right: auto;
  margin-top: 30px;
  width: -moz-fit-content;
  width: fit-content;
}
body main.page section.page-header .list-box .li {
  display: table;
  font-size: 13px;
  letter-spacing: 0.12em;
  line-height: 2;
}
body main.page section.page-header .list-box .li + .li {
  margin-top: 5px;
}
body main.page section.page-header .list-box .li .mark {
  display: table-cell;
}
body main.page section.page-header .list-box .li .mark:nth-of-type(1) {
  width: 1.5em;
}
@media screen and (max-width: 850px) {
  body main.page section.page-header .list-box .li {
    font-size: 12px;
  }
}
body main.page section.pageNav-section {
  padding-top: 160px;
  padding-bottom: 160px;
  position: relative;
}
@media screen and (max-width: 850px) {
  body main.page section.pageNav-section {
    padding-top: 80px;
    padding-bottom: 80px;
  }
}
body main.page section.pageNav-section:before {
  content: "";
  height: 1px;
  max-width: 1116px;
  width: 100%;
  background-color: #707070;
  top: 0;
  right: 0;
  left: 0;
  margin: 0 auto;
  display: block;
  position: absolute;
}
body main.page section.pageNav-section.bg-g:before {
  display: none;
}
body main.page section.pageNav-section .ttl {
  margin-bottom: 80px;
  text-align: center;
}
body main.page section.pageNav-section .ttl .line {
  display: inline-block;
  position: relative;
  padding-bottom: 5px;
}
body main.page section.pageNav-section .ttl .line:after {
  content: "";
  height: 1px;
  width: 100%;
  max-width: 94px;
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
  margin: 0 auto;
  background-color: #707070;
}
body main.page section.pageNav-section .ttl.ver02:before {
  display: none;
}
@media screen and (max-width: 850px) {
  body main.page section.pageNav-section .ttl {
    margin-bottom: 70px;
  }
  body main.page section.pageNav-section .ttl .line:after {
    max-width: 70px;
  }
}
body main.page section.pageNav-section .item-area {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}
body main.page section.pageNav-section .item-area .item {
  width: 44.7%;
  display: block;
}
body main.page section.pageNav-section .item-area .item:nth-of-type(n + 3) {
  margin-top: 50px;
}
body main.page section.pageNav-section .item-area .item .pict {
  width: 100%;
}
body main.page section.pageNav-section .item-area .item .txt {
  font-size: 14px;
  letter-spacing: 0.12em;
  margin-top: 25px;
  background: url(../img/common/arw_r.svg) no-repeat right center;
  background-size: auto;
  padding-right: 12px;
  font-weight: 600;
}
@media screen and (max-width: 850px) {
  body main.page section.pageNav-section .item-area .item {
    width: 100%;
  }
  body main.page section.pageNav-section .item-area .item .pict {
    width: calc(100% + 46px);
    margin-left: -23px;
    margin-right: -23px;
  }
  body main.page section.pageNav-section .item-area .item .txt {
    font-size: 13px;
    margin-top: 18px;
  }
  body main.page section.pageNav-section .item-area .item:nth-of-type(n + 3) {
    margin-top: 0px;
  }
  body main.page section.pageNav-section .item-area .item:nth-of-type(n + 2) {
    margin-top: 50px;
  }
}
body main.page section.pageNav-section.ver02:before {
  display: none;
}
body main.page section.bnr-section {
  padding-top: 0;
  padding-bottom: 0;
}
body main.page section.movie-section {
  padding-top: 0;
}
body main.page section.hero-section {
  padding-top: 0;
  padding-bottom: 0;
  height: 100vh;
  position: relative;
}
body main.page section.slide-section {
  padding-top: 0;
  padding-bottom: 0;
}

body main.page.archive section.page-header, body main.page.archive section.text-section.ver02 {
  position: relative;
  padding-bottom: 60px;
}
body main.page.archive section.page-header .btn-area, body main.page.archive section.text-section.ver02 .btn-area {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 40px;
  position: relative;
  height: 40px;
}
body main.page.archive section.page-header .btn-area .cate-btn, body main.page.archive section.text-section.ver02 .btn-area .cate-btn {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto;
}
@media screen and (max-width: 850px) {
  body main.page.archive section.page-header .btn-area .cate-btn, body main.page.archive section.text-section.ver02 .btn-area .cate-btn {
    left: 0;
  }
}
@media screen and (max-width: 850px) {
  body main.page.archive section.page-header .ttl, body main.page.archive section.text-section.ver02 .ttl {
    margin-bottom: 0;
  }
}
@media screen and (max-width: 850px) {
  body main.page.archive section.text-section.ver02 {
    padding-top: 50px;
  }
}
body main.page.archive section.content-section {
  padding-top: 0px;
}
body main.page.archive section.content-section .inner .news-posts .news-card {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  padding-bottom: 16px;
  border-bottom: 1px solid #707070;
  color: #000;
  font-size: 12px;
  letter-spacing: 0.12em;
  line-height: 1.2;
  width: 100%;
}
body main.page.archive section.content-section .inner .news-posts .news-card + .news-card {
  margin-top: 30px;
}
body main.page.archive section.content-section .inner .news-posts .news-card .date {
  border-right: 1px solid #707070;
  margin-right: 18px;
  padding-right: 20px;
}
body main.page.archive section.content-section .inner .news-posts .news-card .cate {
  font-weight: bold;
}
body main.page.archive section.content-section .inner .news-posts .news-card .spec {
  width: 100%;
  font-size: 16px;
  letter-spacing: 0.16em;
  line-height: 1.6;
  display: block;
  margin-top: 16px;
}
body main.page.archive section.content-section .inner .news-posts .btn01 {
  width: 132px;
  font-weight: normal;
}
body main.page.archive-catalog section.content-section .inner .item-area {
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: wrap;
  margin-left: auto;
  margin-right: auto;
  max-width: 940px;
}
body main.page.archive-catalog section.content-section .inner .item-area .item {
  width: 39.4%;
  margin-left: 5.3%;
  margin-right: 5.3%;
}
body main.page.archive-catalog section.content-section .inner .item-area .item:nth-of-type(n + 3) {
  margin-top: 100px;
}
body main.page.archive-catalog section.content-section .inner .item-area .item .pict-box {
  display: block;
  overflow: hidden;
  height: 480px;
}
body main.page.archive-catalog section.content-section .inner .item-area .item .pict-box img {
  height: 100%;
  width: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
body main.page.archive-catalog section.content-section .inner .item-area .item .text-box {
  display: block;
  margin-top: 35px;
}
body main.page.archive-catalog section.content-section .inner .item-area .item .text-box .ttl {
  display: block;
  width: 100%;
  margin-bottom: 42px;
  font-size: 20px;
  text-align: center;
}
body main.page.archive-catalog section.content-section .inner .item-area .item .text-box .btn-box {
  width: 100%;
  display: block;
}
body main.page.archive-catalog section.content-section .inner .item-area .item .text-box .btn-box .btn {
  margin-left: auto;
  margin-right: auto;
}
body main.page.archive-catalog section.content-section .inner .item-area .item .text-box .btn-box .btn + .btn {
  margin-top: 35px;
}
body main.page.archive-catalog section.content-section .inner .item-area .item .text-box .btn-box .btn#en-pdf {
  display: none !important;
}
@media screen and (max-width: 850px) {
  body main.page.archive-catalog section.content-section .inner .item-area .item {
    display: block;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
  body main.page.archive-catalog section.content-section .inner .item-area .item + .item {
    margin-top: 70px;
  }
  body main.page.archive-catalog section.content-section .inner .item-area .item .pict-box {
    max-width: 220px;
    margin-left: auto;
    margin-right: auto;
    height: auto;
  }
  body main.page.archive-catalog section.content-section .inner .item-area .item .pict-box img {
    height: auto;
    width: 100%;
  }
  body main.page.archive-catalog section.content-section .inner .item-area .item .text-box {
    display: block;
    width: 100%;
    margin-top: 45px;
  }
  body main.page.archive-catalog section.content-section .inner .item-area .item .text-box .ttl {
    margin-bottom: 30px;
    font-size: 18px;
  }
  body main.page.archive-catalog section.content-section .inner .item-area .item .text-box .btn-box .btn {
    max-width: 260px;
  }
  body main.page.archive-catalog section.content-section .inner .item-area .item .text-box .btn-box .btn + .btn {
    margin-top: 25px;
  }
}
body main.page.archive-catalog:not(.Japan) section.content-section .inner .item-area .item .text-box .btn-box .btn#ja-pdf {
  display: none !important;
}
body main.page.archive-catalog:not(.Japan) section.content-section .inner .item-area .item .text-box .btn-box .btn#en-pdf {
  display: block !important;
}
body main.page.archive-catalog:not(.Japan) section.content-section .inner .item-area .item .text-box .btn-box .btn#book-pdf {
  display: none !important;
}
body main.page.archive-discovery section.page-header .ttl {
  margin-left: auto;
  margin-right: auto;
  max-width: 180px;
}
body main.page.archive-discovery section #Discovery {
  margin-bottom: 0;
}
body main.page.archive-discovery section .discovery-wrap {
  position: relative;
  margin-top: 30px;
}

body main.page.page-error section.page-header .inner .txt {
  font-size: 16px;
  line-height: 2;
  letter-spacing: 0.2em;
  text-align: center;
}
body main.page.page-error section.page-header .inner .btn-area {
  margin-top: 70px;
}
body main.page.page-error section.page-header .inner .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 850px) {
  body main.page.page-error section.page-header {
    padding-bottom: 70px;
  }
  body main.page.page-error section.page-header .inner .txt {
    font-size: 14px;
    letter-spacing: 0.05em;
    text-align: justify;
  }
  body main.page.page-error section.page-header .inner .btn-area {
    margin-top: 80px;
  }
}

body main.page.page-identity section.page-header {
  background: url(../img/page/identity/hero_pc.jpg) no-repeat center bottom;
  background-size: contain;
  background-color: #000;
}
@media screen and (max-width: 1366px) {
  body main.page.page-identity section.page-header {
    background-size: cover;
  }
}
body main.page.page-identity section.page-header .inner .text-area {
  margin-left: auto;
  margin-right: auto;
  writing-mode: vertical-rl;
  text-align: left;
  max-width: 851px;
  padding-left: 23px;
  padding-right: 23px;
  width: 100%;
}
body main.page.page-identity section.page-header .inner .text-area .ttl {
  font-weight: normal;
  margin-left: 7%;
  letter-spacing: 0.8em;
  line-height: 1.8;
  text-align: left;
  color: #fff;
}
body main.page.page-identity section.page-header .inner .text-area .ttl span.row {
  display: block;
  word-break: keep-all;
  opacity: 0;
}
body main.page.page-identity section.page-header .inner .text-area .ttl span.row:nth-of-type(n + 2) {
  margin-right: 3%;
}
body main.page.page-identity section.page-header .inner .text-area .ttl span.row:nth-of-type(2) {
  margin-top: 3em;
}
body main.page.page-identity section.page-header .inner .text-area .ttl span.row:nth-of-type(3) {
  margin-top: 9.4em;
}
body main.page.page-identity section.page-header .inner .text-area .txt {
  font-size: 13px;
  line-height: 3;
  letter-spacing: 0.38em;
  margin: 17px 0 0;
  text-align: left;
  color: #fff;
}
body main.page.page-identity section.page-header .inner .text-area .txt span {
  display: block;
  word-break: keep-all;
}
body main.page.page-identity section.page-header .inner .text-area .txt span.row {
  opacity: 0;
}
body main.page.page-identity section.page-header .inner .text-area .txt span + span {
  margin-right: 6%;
}
body main.page.page-identity section.pageNav-section {
  padding-top: 160px;
}
@media screen and (max-width: 850px) {
  body main.page.page-identity section.pageNav-section {
    padding-top: 80px;
  }
}
@media screen and (max-width: 850px) {
  body main.page.page-identity section.page-header {
    background-image: url(../img/page/identity/hero_pc.jpg);
  }
  body main.page.page-identity section.page-header .inner .text-area {
    writing-mode: inherit;
    padding-left: 0px;
    padding-right: 0px;
    max-width: 100%;
  }
  body main.page.page-identity section.page-header .inner .text-area .ttl {
    letter-spacing: 0.05em;
    line-height: 1.7;
    margin-bottom: 90px;
    margin-left: 0;
    text-align: center;
  }
  body main.page.page-identity section.page-header .inner .text-area .ttl span.row {
    display: inline-block;
    opacity: 1;
  }
  body main.page.page-identity section.page-header .inner .text-area .ttl span.row:nth-of-type(n + 2) {
    margin-right: 0;
  }
  body main.page.page-identity section.page-header .inner .text-area .ttl span.row:nth-of-type(2) {
    margin-top: 0;
  }
  body main.page.page-identity section.page-header .inner .text-area .ttl span.row:nth-of-type(3) {
    margin-top: 0;
  }
  body main.page.page-identity section.page-header .inner .text-area .txt {
    font-size: 14px;
    line-height: 2;
    letter-spacing: 0.2em;
    text-align: justify;
  }
  body main.page.page-identity section.page-header .inner .text-area .txt span {
    word-break: break-all;
  }
  body main.page.page-identity section.page-header .inner .text-area .txt span.row {
    opacity: 1;
  }
  body main.page.page-identity section.page-header .inner .text-area .txt span + span {
    margin-right: 0;
    margin-top: 20px;
  }
}

body main.page.page-mono section.page-header .txt {
  line-height: 2.3;
}
@media screen and (max-width: 850px) {
  body main.page.page-mono section.page-header .ttl {
    margin-bottom: 90px;
  }
  body main.page.page-mono section.page-header .txt {
    line-height: 2;
  }
}
body main.page.page-mono section.menu-section .inner .modal-area {
  margin-left: -3.4%;
  margin-right: -3.4%;
}
body main.page.page-mono section.menu-section .inner .modal-area .modal-item {
  display: block;
  border-bottom: 1px solid #B9B9B9;
  color: #000;
  width: 26.5333333333%;
  margin: 0 3.4% 66px;
}
body main.page.page-mono section.menu-section .inner .modal-area .modal-item.dummy-item {
  border: none;
  height: 75px;
}
body main.page.page-mono section.menu-section .inner .modal-area .modal-item .pict-box {
  overflow: hidden;
}
body main.page.page-mono section.menu-section .inner .modal-area .modal-item .text-box {
  display: block;
  margin: 30px 0 28px;
  line-height: 1.6;
  background: url(../img/common/arw_r.svg) no-repeat top 8px right;
  background-size: 7px;
  padding-right: 35px;
}
body main.page.page-mono section.menu-section .inner .modal-area .modal-item .text-box .inner-ttl {
  display: block;
  font-size: 17px;
  letter-spacing: 0.12em;
  font-weight: 600;
}
@media screen and (max-width: 850px) {
  body main.page.page-mono section.menu-section .inner .modal-area .modal-item .text-box .inner-ttl {
    font-size: 16px;
  }
}
body main.page.page-mono section.menu-section .inner .modal-area .modal-item .text-box .txt {
  display: block;
  font-size: 13px;
  letter-spacing: 0.1em;
  margin-top: 8px;
  font-weight: 600;
}
body main.page.page-mono section.menu-section .inner .modal-content-area {
  display: none;
}
@media screen and (max-width: 850px) {
  body main.page.page-mono section.menu-section .inner .modal-area {
    margin-left: 0;
    margin-right: 0;
  }
  body main.page.page-mono section.menu-section .inner .modal-area .modal-item {
    width: 100%;
    margin: 0;
    border-bottom: none;
  }
  body main.page.page-mono section.menu-section .inner .modal-area .modal-item + .modal-item {
    margin-top: 60px;
  }
  body main.page.page-mono section.menu-section .inner .modal-area .modal-item.dummy-item {
    display: none;
  }
  body main.page.page-mono section.menu-section .inner .modal-area .modal-item .text-box {
    display: block;
    margin: 20px 0 0px;
    line-height: 1.6;
    padding-right: 30px;
  }
  body main.page.page-mono section.menu-section .inner .modal-area .modal-item .text-box .inner-ttl {
    display: block;
    font-size: 16px;
    letter-spacing: 0.2em;
  }
  body main.page.page-mono section.menu-section .inner .modal-area .modal-item .text-box .txt {
    margin-top: 5px;
  }
}
body .featherlight {
  overflow: scroll;
}
body .featherlight .featherlight-content {
  padding: 5.857%;
  border-bottom: none !important;
  max-width: 1214px;
  position: relative;
}
body .featherlight .featherlight-content .featherlight-close-icon.featherlight-close {
  width: 25px;
  line-height: 25px;
  font-size: 0;
  background: url(../img/common/close_icn.svg) no-repeat center;
  background-size: cover;
  top: 4.75%;
  right: 2.48%;
}
@media screen and (max-width: 850px) {
  body .featherlight .featherlight-content .featherlight-close-icon.featherlight-close {
    width: 23px;
    line-height: 23px;
    background-size: 22px;
  }
}
@media screen and (max-width: 576px) {
  body .featherlight .featherlight-content .featherlight-close-icon.featherlight-close {
    width: 88%;
    margin: 0 auto;
    background-color: #BCBCBC;
    border-radius: 30px;
    top: inherit;
    right: 0;
    left: 0;
    bottom: 0px;
    background-image: none;
    height: 40px;
    position: relative;
    display: block;
    margin-top: 22px;
  }
  body .featherlight .featherlight-content .featherlight-close-icon.featherlight-close:after {
    content: "× CLOSE";
    font-size: 12px;
    color: #fff;
    line-height: 39px;
    position: absolute;
    bottom: inherit;
    right: 0;
    left: 0;
    top: 0;
    margin: 0 auto;
    letter-spacing: 0.22em;
    font-weight: bold;
  }
}
body .featherlight .featherlight-content .modal-box {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: nowrap;
}
body .featherlight .featherlight-content .modal-box .text-box {
  display: flex;
  align-items: stretch;
  flex-wrap: wrap;
  align-content: space-between;
  order: 1;
  width: 39%;
}
body .featherlight .featherlight-content .modal-box .text-box h3.inner-ttl {
  font-size: 30px;
  letter-spacing: 0.2em;
  margin-bottom: 40px;
  line-height: 1.7;
}
body .featherlight .featherlight-content .modal-box .text-box h3.inner-ttl .sub-ttl {
  display: block;
  font-size: 15px;
  letter-spacing: 0.1em;
  margin-top: 30px;
  font-weight: 600;
}
body .featherlight .featherlight-content .modal-box .text-box .txt {
  font-size: 13px;
  line-height: 2;
  letter-spacing: 0.05em;
  text-align: justify;
  align-items: flex-end;
  margin-bottom: 25%;
  width: 100%;
  position: relative;
}
body .featherlight .featherlight-content .modal-box .text-box .link-txt {
  display: inline-block;
  margin-top: 12px;
}
body .featherlight .featherlight-content .modal-box .pict-box {
  order: 2;
  width: 54%;
  padding-left: 7%;
  border-left: 1px solid #707070;
}
body .featherlight .featherlight-content .modal-box .pict-box img {
  width: 100%;
}
@media screen and (max-width: 1135px) {
  body .featherlight .featherlight-content .modal-box .text-box h3.inner-ttl {
    font-size: 35px;
    margin-bottom: 35px;
    letter-spacing: 0.2em;
  }
  body .featherlight .featherlight-content .modal-box .text-box h3.inner-ttl .sub-ttl {
    font-size: 18px;
  }
  body .featherlight .featherlight-content .modal-box .text-box .txt {
    font-size: 13px;
    margin-bottom: 18%;
  }
}
@media screen and (max-width: 850px) {
  body .featherlight .featherlight-content .modal-box .text-box h3.inner-ttl {
    font-size: 22px;
    margin-bottom: 25px;
    letter-spacing: 0.15em;
  }
  body .featherlight .featherlight-content .modal-box .text-box h3.inner-ttl .sub-ttl {
    font-size: 14px;
    letter-spacing: 0.1em;
    margin-top: 12px;
  }
  body .featherlight .featherlight-content .modal-box .text-box .txt {
    margin-bottom: 20%;
  }
}
@media screen and (max-width: 576px) {
  body .featherlight .featherlight-content {
    height: 100%;
    padding: 0;
    max-height: 100%;
    width: 100%;
    padding-bottom: 25px;
  }
  body .featherlight .featherlight-content .modal-box {
    display: block;
  }
  body .featherlight .featherlight-content .modal-box .text-box {
    width: 100%;
    padding: 5% 6%;
    padding-bottom: 35px;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    flex-wrap: nowrap;
    flex-direction: column;
  }
  body .featherlight .featherlight-content .modal-box .text-box h3.inner-ttl {
    width: 100%;
    margin-bottom: 12px;
  }
  body .featherlight .featherlight-content .modal-box .text-box h3.inner-ttl .sub-ttl {
    margin-top: 2px;
  }
  body .featherlight .featherlight-content .modal-box .text-box .txt {
    margin-bottom: 0;
    display: block;
    letter-spacing: 0;
    line-height: 1.7;
    width: 100%;
    flex-grow: 1;
  }
  body .featherlight .featherlight-content .modal-box .pict-box {
    width: 100%;
    padding-left: 0;
    border-left: none;
    height: 250px;
  }
  body .featherlight .featherlight-content .modal-box .pict-box img {
    -o-object-fit: cover;
       object-fit: cover;
    height: 100%;
  }
}
body .featherlight .Nav-area {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 33.2%;
  display: table;
  margin: 6.8%;
  border-collapse: collapse;
  cursor: pointer;
  background-color: #fff;
}
body .featherlight .Nav-area span.featherlight-previous,
body .featherlight .Nav-area span.featherlight-next {
  display: table-cell;
  width: 50%;
  font-size: 12px;
  letter-spacing: 0.2em;
  font-weight: bold;
  vertical-align: middle;
  font-family: "Roboto", sans-serif;
  text-align: center;
  padding: 13px 20px;
  border: 1px solid #707070;
  transition: all 0.4s;
}
body .featherlight .Nav-area span.featherlight-previous:hover,
body .featherlight .Nav-area span.featherlight-next:hover {
  opacity: 0.4;
}
body .featherlight .Nav-area span.featherlight-previous {
  background: url(../img/common/arw_l.svg) no-repeat center left 20px;
  background-size: 4px;
}
body .featherlight .Nav-area span.featherlight-next {
  background: url(../img/common/arw_r.svg) no-repeat center right 20px;
  background-size: 4px;
}
@media screen and (max-width: 576px) {
  body .featherlight .Nav-area {
    width: 88%;
    margin: 0 auto;
    left: 0;
    right: 0;
    bottom: 0px;
    position: relative;
  }
  body .featherlight .Nav-area span.featherlight-previous,
  body .featherlight .Nav-area span.featherlight-next {
    font-size: 12px;
    padding: 12px;
  }
  body .featherlight .Nav-area span.featherlight-previous {
    background-position: center left 18px;
  }
  body .featherlight .Nav-area span.featherlight-next {
    background-position: center right 18px;
  }
}

body main.page.page-materials section.content-section {
  padding: 0;
}
body main.page.page-materials section.content-section:nth-of-type(even) {
  background-color: #F2F1EF;
}
body main.page.page-materials section.content-section .two-clm {
  background-color: inherit;
}
body main.page.page-materials section.content-section .two-clm .inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
  height: 712px;
}
body main.page.page-materials section.content-section .two-clm .inner:before {
  width: 36.2%;
  background-color: #000;
}
body main.page.page-materials section.content-section .two-clm .inner:after {
  width: 63.8%;
}
body main.page.page-materials section.content-section .two-clm .inner .item-box {
  padding: 30px 0;
}
body main.page.page-materials section.content-section .two-clm .inner .item-box.item-box01 {
  width: 34.4%;
}
body main.page.page-materials section.content-section .two-clm .inner .item-box.item-box02 {
  width: 83%;
  padding-left: 10.5%;
}
body main.page.page-materials section.content-section .two-clm .inner .item-box h2.ttl {
  color: #000;
  margin-bottom: 35px;
}
body main.page.page-materials section.content-section .two-clm .inner .item-box h3.ttl {
  color: #000;
}
body main.page.page-materials section.content-section .two-clm .inner .item-box h4.ttl {
  color: #000;
}
body main.page.page-materials section.content-section .two-clm .inner .item-box p.txt {
  color: #000;
  text-align: justify;
}
body main.page.page-materials section.content-section .two-clm .inner .item-box .btn-area {
  margin-top: 45px;
  max-width: 445px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
}
body main.page.page-materials section.content-section .two-clm .inner .item-box .btn-area .btn:nth-of-type(n + 3) {
  margin-top: 30px;
}
body main.page.page-materials section.content-section .two-clm .inner .item-box .btn-area .btn:nth-of-type(odd) {
  margin-right: 10px;
}
body main.page.page-materials section.content-section .two-clm .inner .item-box .btn-area .btn:nth-of-type(even) {
  margin-left: 10px;
}
body main.page.page-materials section.content-section.content-section01 .two-clm .inner:before {
  background: url(../../asset/img/page/mate/content-section_bg_01.jpg) no-repeat center;
  background-size: cover;
}
body main.page.page-materials section.content-section.content-section02 .two-clm .inner:before {
  background: url(../../asset/img/page/mate/content-section_bg_02.jpg) no-repeat center;
  background-size: cover;
}
body main.page.page-materials section.content-section.content-section03 .two-clm .inner:before {
  background: url(../../asset/img/page/mate/content-section_bg_03.jpg) no-repeat center;
  background-size: cover;
}
body main.page.page-materials section.content-section.content-section04 .two-clm .inner:before {
  background: url(../../asset/img/page/mate/content-section_bg_04.jpg) no-repeat center;
  background-size: cover;
}
body main.page.page-materials section.content-section.content-section05 .two-clm .inner:before {
  background: url(../../asset/img/page/mate/content-section_bg_05.jpg) no-repeat center;
  background-size: cover;
}
@media screen and (max-width: 850px) {
  body main.page.page-materials section.content-section .two-clm {
    background-color: inherit;
  }
  body main.page.page-materials section.content-section .two-clm .inner {
    display: block;
    height: 100%;
  }
  body main.page.page-materials section.content-section .two-clm .inner:before {
    width: 100%;
    background-color: #000;
    height: 334px;
  }
  body main.page.page-materials section.content-section .two-clm .inner:after {
    width: 100%;
  }
  body main.page.page-materials section.content-section .two-clm .inner .item-box {
    padding: 50px 0 90px;
  }
  body main.page.page-materials section.content-section .two-clm .inner .item-box.item-box01 {
    height: 334px;
    padding: 0;
    width: 100%;
  }
  body main.page.page-materials section.content-section .two-clm .inner .item-box.item-box02 {
    width: 100%;
    padding-left: 0%;
  }
  body main.page.page-materials section.content-section .two-clm .inner .item-box h2.ttl {
    color: #000;
    margin-bottom: 35px;
  }
  body main.page.page-materials section.content-section .two-clm .inner .item-box h3.ttl {
    color: #000;
  }
  body main.page.page-materials section.content-section .two-clm .inner .item-box h4.ttl {
    color: #000;
  }
  body main.page.page-materials section.content-section .two-clm .inner .item-box p.txt {
    color: #000;
    text-align: justify;
  }
  body main.page.page-materials section.content-section .two-clm .inner .item-box .btn-area {
    margin-top: 75px;
    max-width: 100%;
    display: block;
  }
  body main.page.page-materials section.content-section .two-clm .inner .item-box .btn-area .btn:nth-of-type(n + 3) {
    margin-top: 0px;
  }
  body main.page.page-materials section.content-section .two-clm .inner .item-box .btn-area .btn:nth-of-type(odd) {
    margin-right: auto;
    margin-left: auto;
  }
  body main.page.page-materials section.content-section .two-clm .inner .item-box .btn-area .btn:nth-of-type(even) {
    margin-left: auto;
    margin-right: auto;
  }
  body main.page.page-materials section.content-section .two-clm .inner .item-box .btn-area .btn:nth-of-type(n + 2) {
    margin-top: 35px;
  }
}
body main.page.materials-child section.page-header .btn-area {
  margin-top: 40px;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  flex-wrap: wrap;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.page-header .btn-area {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
  }
}
body main.page.materials-child section.btn-section {
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.btn-section {
    padding-top: 90px;
    padding-bottom: 90px;
  }
}
body main.page.materials-child section.btn-section .inner .btn {
  margin-left: auto;
  margin-right: auto;
}
body main.page.materials-child section.content-section + .content-section {
  padding-top: 0;
}
body main.page.materials-child section.content-section + .btn-section {
  padding-top: 0;
}
body main.page.materials-child section.content-section .inner .ttl-area + div {
  margin-top: 110px;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.content-section .inner .ttl-area + div {
    margin-top: 70px;
  }
}
body main.page.materials-child section.content-section .inner .ttl-area .ttl-line {
  margin-bottom: 0;
}
body main.page.materials-child section.content-section .inner .ttl-area .lead-txt {
  text-align: center;
  margin-top: 60px;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.content-section .inner .ttl-area .lead-txt {
    text-align: left;
    margin-top: 50px;
  }
}
body main.page.materials-child section.content-section .inner .border-box {
  margin-top: 100px;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.content-section .inner .border-box {
    margin-top: 70px;
  }
}
body main.page.materials-child section.content-section .inner .item-two-clm .item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
}
body main.page.materials-child section.content-section .inner .item-two-clm .item + .item {
  margin-top: 35px;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.content-section .inner .item-two-clm .item + .item {
    margin-top: 70px;
  }
}
body main.page.materials-child section.content-section .inner .item-two-clm .item .pict {
  width: 22%;
  height: 226px;
  overflow: hidden;
}
body main.page.materials-child section.content-section .inner .item-two-clm .item .pict img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  height: 100%;
  width: auto;
}
body main.page.materials-child section.content-section .inner .item-two-clm .item .text {
  width: 73.5%;
  margin-top: -10px;
}
body main.page.materials-child section.content-section .inner .item-two-clm .item .text .ttl {
  margin-bottom: 20px;
}
body main.page.materials-child section.content-section .inner .item-two-clm .item .text .ttl.ver02 {
  margin-bottom: 2px;
}
body main.page.materials-child section.content-section .inner .item-two-clm .item .text .name-jp {
  margin-bottom: 20px;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.content-section .inner .item-two-clm .item .pict {
    width: 226px;
    height: 226px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 35px;
  }
  body main.page.materials-child section.content-section .inner .item-two-clm .item .pict img {
    width: 100%;
    height: auto;
  }
  body main.page.materials-child section.content-section .inner .item-two-clm .item .text {
    width: 100%;
    margin-top: 0px;
  }
  body main.page.materials-child section.content-section .inner .item-two-clm .item .text .ttl {
    text-align: center;
    margin-bottom: 30px;
  }
  body main.page.materials-child section.content-section .inner .item-two-clm .item .text .name-jp {
    margin-bottom: 30px;
    text-align: center;
  }
}
body main.page.materials-child section.content-section .inner .item-two-clm + .note {
  margin-top: 32px;
}
body main.page.materials-child section.content-section .inner .item-third-clm {
  display: flex;
  justify-content: center;
  align-items: stretch;
  flex-wrap: wrap;
  margin-left: auto;
  margin-right: auto;
  max-width: 700px;
  margin-top: 80px;
}
body main.page.materials-child section.content-section .inner .item-third-clm .item {
  display: block;
  width: 23.3333333333%;
  margin-left: 5%;
  margin-right: 5%;
}
body main.page.materials-child section.content-section .inner .item-third-clm .item:nth-of-type(n + 4) {
  margin-top: 60px;
}
body main.page.materials-child section.content-section .inner .item-third-clm .item .pict {
  display: block;
  overflow: hidden;
  width: 100%;
  text-align: center;
}
body main.page.materials-child section.content-section .inner .item-third-clm .item .pict img {
  -o-object-position: center;
     object-position: center;
  -o-object-fit: cover;
     object-fit: cover;
}
body main.page.materials-child section.content-section .inner .item-third-clm .item .text {
  margin-top: 20px;
  display: block;
}
body main.page.materials-child section.content-section .inner .item-third-clm .item .text .name-jp {
  font-size: 13px;
  letter-spacing: 0em;
  display: block;
  line-height: 1.8;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.content-section .inner .item-third-clm {
    margin-top: 60px;
    margin-left: -3%;
    margin-right: -3%;
  }
  body main.page.materials-child section.content-section .inner .item-third-clm .item {
    width: 27.3333333333%;
    margin-left: 3%;
    margin-right: 3%;
  }
  body main.page.materials-child section.content-section .inner .item-third-clm .item:nth-of-type(n + 4) {
    margin-top: 20px;
  }
  body main.page.materials-child section.content-section .inner .item-third-clm .item .text {
    display: block;
    margin-top: 12px;
  }
  body main.page.materials-child section.content-section .inner .item-third-clm .item .text .name-jp {
    font-size: 11px;
  }
}
body main.page.materials-child section.content-section .inner .item-four-clm {
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: wrap;
  margin-left: -1.8%;
  margin-right: -1.8%;
}
body main.page.materials-child section.content-section .inner .item-four-clm h3.ttl {
  width: 100%;
}
body main.page.materials-child section.content-section .inner .item-four-clm + .item-four-clm {
  margin-top: 100px;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.content-section .inner .item-four-clm + .item-four-clm {
    margin-top: 70px;
  }
}
body main.page.materials-child section.content-section .inner .item-four-clm .item {
  display: block;
  width: 21.4%;
  margin-left: 1.8%;
  margin-right: 1.8%;
}
body main.page.materials-child section.content-section .inner .item-four-clm .item:nth-of-type(n + 5) {
  margin-top: 60px;
}
body main.page.materials-child section.content-section .inner .item-four-clm .item .pict {
  display: block;
  overflow: hidden;
  width: 100%;
  text-align: center;
}
body main.page.materials-child section.content-section .inner .item-four-clm .item .pict img {
  -o-object-position: center;
     object-position: center;
  -o-object-fit: cover;
     object-fit: cover;
}
body main.page.materials-child section.content-section .inner .item-four-clm .item .text {
  display: block;
  padding: 2px 20px;
  padding-right: 0;
  margin-top: 32px;
  border-left: 1px solid #707070;
}
body main.page.materials-child section.content-section .inner .item-four-clm .item .text .name-en {
  font-size: 16px;
  letter-spacing: 0.15em;
  font-weight: bold;
  display: block;
  line-height: 1.8;
  margin-bottom: 5px;
}
body main.page.materials-child section.content-section .inner .item-four-clm .item .text .name-made {
  font-size: 13px;
  letter-spacing: 0em;
  display: block;
  line-height: 1.8;
}
body main.page.materials-child section.content-section .inner .item-four-clm .item .text .name-style {
  font-size: 13px;
  letter-spacing: 0em;
  display: block;
  line-height: 1.8;
}
body main.page.materials-child section.content-section .inner .item-four-clm .item .text .name-jp {
  font-size: 13px;
  letter-spacing: 0em;
  display: block;
  line-height: 1.8;
}
body main.page.materials-child section.content-section .inner .item-four-clm .item .note {
  font-size: 12px;
  line-height: 1.7;
  margin-top: 15px;
  display: block;
}
body main.page.materials-child section.content-section .inner .item-four-clm + .note {
  margin-top: 65px;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.content-section .inner .item-four-clm + .note {
    margin-top: 32px;
  }
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.content-section .inner .item-four-clm {
    margin-left: 0%;
    margin-right: 0%;
  }
  body main.page.materials-child section.content-section .inner .item-four-clm .item {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    flex-wrap: wrap;
    width: 100%;
    margin-left: 0%;
    margin-right: 0%;
  }
  body main.page.materials-child section.content-section .inner .item-four-clm .item:nth-of-type(n + 5) {
    margin-top: 0px;
  }
  body main.page.materials-child section.content-section .inner .item-four-clm .item:nth-of-type(n + 2) {
    margin-top: 32px;
  }
  body main.page.materials-child section.content-section .inner .item-four-clm .item .pict {
    width: 34%;
  }
  body main.page.materials-child section.content-section .inner .item-four-clm .item .text {
    display: block;
    padding: 0px;
    padding-right: 0;
    margin-top: -5px;
    width: 61%;
    border: none;
  }
  body main.page.materials-child section.content-section .inner .item-four-clm .item .text .name-en {
    font-size: 15px;
    margin-bottom: 0px;
  }
  body main.page.materials-child section.content-section .inner .item-four-clm .item .note {
    margin-top: 12px;
  }
}
body main.page.materials-child section.content-section .inner .item-five-clm {
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: wrap;
  margin-left: -1.8%;
  margin-right: -1.8%;
}
body main.page.materials-child section.content-section .inner .item-five-clm .item {
  display: block;
  width: 16.4%;
  margin-left: 1.8%;
  margin-right: 1.8%;
}
body main.page.materials-child section.content-section .inner .item-five-clm .item:nth-of-type(n + 6) {
  margin-top: 60px;
}
body main.page.materials-child section.content-section .inner .item-five-clm .item .pict {
  display: block;
  overflow: hidden;
  width: 100%;
  text-align: center;
}
body main.page.materials-child section.content-section .inner .item-five-clm .item .pict img {
  -o-object-position: center;
     object-position: center;
  -o-object-fit: cover;
     object-fit: cover;
}
body main.page.materials-child section.content-section .inner .item-five-clm .item .text {
  display: block;
  padding: 2px 20px;
  padding-right: 0;
  margin-top: 32px;
  border-left: 1px solid #707070;
}
body main.page.materials-child section.content-section .inner .item-five-clm .item .text .name-en {
  font-size: 16px;
  letter-spacing: 0.15em;
  font-weight: bold;
  display: block;
  line-height: 1.8;
  margin-bottom: 5px;
}
body main.page.materials-child section.content-section .inner .item-five-clm .item .text .name-made {
  font-size: 13px;
  letter-spacing: 0em;
  display: block;
  line-height: 1.8;
}
body main.page.materials-child section.content-section .inner .item-five-clm .item .text .name-style {
  font-size: 13px;
  letter-spacing: 0em;
  display: block;
  line-height: 1.8;
}
body main.page.materials-child section.content-section .inner .item-five-clm .item .text .name-jp {
  font-size: 13px;
  letter-spacing: 0em;
  display: block;
  line-height: 1.8;
}
body main.page.materials-child section.content-section .inner .item-five-clm .item .note {
  font-size: 12px;
  line-height: 1.7;
  margin-top: 12px;
}
body main.page.materials-child section.content-section .inner .item-five-clm + .note {
  margin-top: 32px;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.content-section .inner .item-five-clm {
    margin-left: 0%;
    margin-right: 0%;
  }
  body main.page.materials-child section.content-section .inner .item-five-clm .item {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    flex-wrap: wrap;
    width: 100%;
    margin-left: 0%;
    margin-right: 0%;
  }
  body main.page.materials-child section.content-section .inner .item-five-clm .item:nth-of-type(n + 6) {
    margin-top: 0px;
  }
  body main.page.materials-child section.content-section .inner .item-five-clm .item:nth-of-type(n + 2) {
    margin-top: 32px;
  }
  body main.page.materials-child section.content-section .inner .item-five-clm .item .pict {
    width: 34%;
  }
  body main.page.materials-child section.content-section .inner .item-five-clm .item .text {
    display: block;
    padding: 0px;
    padding-right: 0;
    margin-top: -5px;
    width: 61%;
    border: none;
  }
  body main.page.materials-child section.content-section .inner .item-five-clm .item .text .name-en {
    font-size: 15px;
    margin-bottom: 0px;
    display: inline-block;
  }
  body main.page.materials-child section.content-section .inner .item-five-clm .item .text .name-made {
    display: inline-block;
    margin-left: 0.2em;
    font-size: 13px;
    position: relative;
    top: -1px;
  }
  body main.page.materials-child section.content-section .inner .item-five-clm .item .note {
    margin-top: 12px;
  }
}
body main.page.materials-child section.content-section .inner .spec-area + .spec-area {
  margin-top: 100px;
}
body main.page.materials-child section.content-section .inner .spec-area + .note {
  text-align: center;
  margin-top: 50px;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.content-section .inner .spec-area + .note {
    text-align: left;
    margin-top: 50px;
  }
}
body main.page.materials-child section.content-section .inner .spec-area .cate-ttl {
  text-align: center;
}
body main.page.materials-child section.content-section .inner .spec-area .spec-ttl {
  text-align: center;
  margin-bottom: 20px;
}
body main.page.materials-child section.content-section .inner .spec-area .txt {
  text-align: center;
}
body main.page.materials-child section.content-section .inner .spec-area .txt .min-txt {
  font-size: 11px;
}
body main.page.materials-child section.content-section .inner .spec-area .txt + .spec-ttl {
  margin-top: 40px;
}
body main.page.materials-child section.content-section .inner .spec-area .txt + .item-four-clm {
  margin-top: 80px;
}
body main.page.materials-child section.content-section .inner .spec-area .txt + .item-four-clm + .note {
  text-align: left;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.content-section .inner .spec-area .txt + .item-four-clm {
    margin-top: 60px;
  }
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.content-section .inner .spec-area + .spec-area {
    margin-top: 80px;
  }
  body main.page.materials-child section.content-section .inner .spec-area .cate-ttl {
    text-align: center;
  }
  body main.page.materials-child section.content-section .inner .spec-area .spec-ttl {
    text-align: center;
    margin-bottom: 20px;
  }
  body main.page.materials-child section.content-section .inner .spec-area .txt {
    text-align: justify;
  }
  body main.page.materials-child section.content-section .inner .spec-area .txt + .spec-ttl {
    margin-top: 30px;
  }
}
body main.page.materials-child section.atten-section .inner .inner-header {
  display: flex;
  justify-content: flex-start;
  align-items: flex-end;
  flex-wrap: nowrap;
  margin-bottom: 40px;
}
body main.page.materials-child section.atten-section .inner .inner-header .ttl {
  margin-bottom: 0;
}
body main.page.materials-child section.atten-section .inner .inner-header .ttl-cap {
  font-weight: bold;
  margin-bottom: 6px;
  margin-left: 20px;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.atten-section .inner .inner-header {
    margin-bottom: 25px;
  }
  body main.page.materials-child section.atten-section .inner .inner-header .ttl {
    margin-bottom: 0px;
  }
}
body main.page.materials-child section.atten-section .inner .item-area .item + .item {
  margin-top: 35px;
}
body main.page.materials-child section.atten-section .inner .item-area .item .ttl-cap {
  font-weight: bold;
  margin-bottom: 10px;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.atten-section .inner .item-area .item .ttl-cap {
    display: block;
    margin-bottom: 12px;
  }
}
body main.page.materials-child section.atten-section .inner .item-area .item .txt {
  margin-top: 10px;
}
body main.page.materials-child section.atten-section .inner .item-area .item .txt + ul.list {
  margin-top: 10px;
}
body main.page.materials-child section.atten-section .inner .item-area .item ul.list li {
  font-size: 13px;
  letter-spacing: 0.03em;
  line-height: 1.7;
}
body main.page.materials-child section.atten-section .inner .item-area .item ul.list li + li {
  margin-top: 4px;
}
body main.page.materials-child section.atten-section .inner .item-area .item ul.list li + .th {
  margin-top: 10px;
}
body main.page.materials-child section.atten-section .inner .item-area .item .pict-box {
  margin-top: 50px;
}
body main.page.materials-child section.atten-section .inner .item-area .item .pict-box + .pict-box {
  margin-top: 35px;
}
body main.page.materials-child section.atten-section .inner .item-area .item .pict-box .pict {
  width: 247px;
  margin-bottom: 10px;
}
body main.page.materials-child section.atten-section .inner .item-area .item .pict-box .pict.wide {
  width: 100%;
}
body main.page.materials-child section.atten-section .inner .item-area .item .pict-box .pict.min {
  max-width: 120px;
  width: 100%;
  margin-right: 0;
  margin-left: 0;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.atten-section .inner .item-area .item .pict-box .pict {
    margin-bottom: 22px;
    margin-left: auto;
    margin-right: auto;
  }
}
body main.page.materials-child section.atten-section .inner .item-area .item .pict-box .cap {
  font-size: 13px;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.atten-section .inner .item-area .item .pict-box {
    margin-top: 45px;
  }
}
body main.page.materials-child section.atten-section .inner .item-area.flex {
  display: flex;
  justify-content: space-between;
  flex-wrap: nowrap;
}
body main.page.materials-child section.atten-section .inner .item-area.flex .item {
  margin-top: 0;
}
body main.page.materials-child section.atten-section .inner .item-area.flex .item:nth-of-type(1) {
  width: 60%;
}
body main.page.materials-child section.atten-section .inner .item-area.flex .item:nth-of-type(2) {
  width: 40%;
}
body main.page.materials-child section.atten-section .inner .item-area.flex .item .pict-box:first-of-type {
  margin-top: 0;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child section.atten-section .inner .item-area.flex {
    display: block;
  }
  body main.page.materials-child section.atten-section .inner .item-area.flex .item + .item {
    margin-top: 45px;
  }
  body main.page.materials-child section.atten-section .inner .item-area.flex .item:nth-of-type(1) {
    width: 100%;
  }
  body main.page.materials-child section.atten-section .inner .item-area.flex .item:nth-of-type(2) {
    width: 100%;
  }
}
body main.page.materials-child section.pageNav-section {
  background-color: #F2F1EF;
}
body main.page.materials-child.leather-property section.content-section01 .inner .ttl-area + div {
  margin-top: 110px;
}
@media screen and (max-width: 850px) {
  body main.page.materials-child.leather-property section.content-section01 .inner .ttl-area + div {
    margin-top: 36px;
  }
}

body main.page.page-product section.slide-section .swiper-container03 {
  height: 562px;
  position: relative;
}
body main.page.page-product section.slide-section .swiper-container03 .swiper-wrapper {
  height: 500px;
}
body main.page.page-product section.slide-section .swiper-container03 .swiper-pagination {
  bottom: 0px;
  left: 0;
  right: 0;
  margin: auto !important;
  text-align: center;
  max-width: 1070px;
}
@media screen and (max-width: 850px) {
  body main.page.page-product section.slide-section .swiper-container03 {
    height: 334px;
  }
  body main.page.page-product section.slide-section .swiper-container03 .swiper-wrapper {
    height: 274px;
  }
}
body main.page.page-product section.item-section .inner .item-area {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  max-width: 847px;
  margin-left: auto;
  margin-right: auto;
}
body main.page.page-product section.item-section .inner .item-area .item {
  display: block;
  max-width: 342px;
  width: 100%;
}
body main.page.page-product section.item-section .inner .item-area .item:nth-of-type(n + 3) {
  margin-top: 100px;
}
body main.page.page-product section.item-section .inner .item-area .item:nth-of-type(odd) {
  margin-right: 5.3%;
}
body main.page.page-product section.item-section .inner .item-area .item:nth-of-type(even) {
  margin-left: 5.3%;
}
body main.page.page-product section.item-section .inner .item-area .item .txt {
  padding: 5px 0 2px 30px;
  border-left: 1px solid #707070;
  letter-spacing: 0.1em;
  font-weight: bold;
  margin-top: 22px;
  display: block;
}
@media screen and (max-width: 850px) {
  body main.page.page-product section.item-section .inner .item-area .item {
    display: block;
    max-width: 342px;
    width: 100%;
  }
  body main.page.page-product section.item-section .inner .item-area .item:nth-of-type(n + 3) {
    margin-top: 0px;
  }
  body main.page.page-product section.item-section .inner .item-area .item:nth-of-type(odd) {
    margin-right: 0%;
  }
  body main.page.page-product section.item-section .inner .item-area .item:nth-of-type(even) {
    margin-left: 0%;
  }
  body main.page.page-product section.item-section .inner .item-area .item.item02, body main.page.page-product section.item-section .inner .item-area .item.item03 {
    width: calc((100% - 33px) / 2);
    margin-top: 35px;
    margin-bottom: 35px;
  }
  body main.page.page-product section.item-section .inner .item-area .item .txt {
    display: block;
    padding: 2px 0 0px 16px;
    line-height: 1;
    margin-top: 20px;
  }
}
body main.page.page-product.child section.page-header {
  padding-bottom: 80px;
}
body main.page.page-product.child section.page-header .ttl {
  margin-bottom: 0;
}
@media screen and (max-width: 850px) {
  body main.page.page-product.child section.page-header {
    padding-bottom: 50px;
  }
}
body main.page.page-product.child section .swiper-container02 {
  height: 584px;
  overflow: hidden;
}
body main.page.page-product.child section .swiper-container02 .swiper-wrapper {
  height: 520px;
}
body main.page.page-product.child section .swiper-container02 .swiper-wrapper .swiper-slide .image {
  width: auto;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
  margin: auto;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  position: absolute;
}
@media screen and (max-width: 850px) {
  body main.page.page-product.child section .swiper-container02 .swiper-wrapper .swiper-slide .image {
    width: 100%;
    height: auto;
    -o-object-fit: cover;
    object-fit: cover;
  }
}
body main.page.page-product.child section .swiper-container02 .swiper-pagination {
  bottom: 0px;
  left: 0;
  right: 0;
}
@media screen and (max-width: 850px) {
  body main.page.page-product.child section .swiper-container02 {
    height: 456px;
    width: calc(100% + 46px);
    margin-left: -23px;
    margin-right: -23px;
  }
  body main.page.page-product.child section .swiper-container02 .swiper-wrapper {
    height: 396px;
  }
  body main.page.page-product.child section .swiper-container02 .swiper-pagination {
    padding-left: 0;
    padding-right: 0;
  }
  body main.page.page-product.child section .swiper-container02 .swiper-pagination .swiper-pagination-bullet {
    margin-left: 5px !important;
    margin-right: 5px !important;
  }
}
body main.page.page-product.child section.spec-section {
  padding-top: 75px;
  padding-bottom: 95px;
}
body main.page.page-product.child section.spec-section .inner h2.ttl {
  text-align: center;
  margin-bottom: 45px;
}
body main.page.page-product.child section.spec-section .inner .info-area .txt {
  text-align: center;
}
body main.page.page-product.child section.spec-section .inner .info-area .txt.txt + .txt {
  margin-top: 10px;
}
body main.page.page-product.child section.spec-section .inner .info-area .txt.disign span.mark + .mark:before {
  content: " , ";
}
body main.page.page-product.child section.spec-section .inner .lead-area {
  margin-top: 45px;
}
body main.page.page-product.child section.spec-section .inner .lead-area .txt {
  text-align: justify;
}
body main.page.page-product.child section.spec-section .inner .award-area {
  margin-top: 50px;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
}
body main.page.page-product.child section.spec-section .inner .award-area .item {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: nowrap;
  margin-bottom: 0px;
  width: 100%;
}
body main.page.page-product.child section.spec-section .inner .award-area .item p.txt {
  font-size: 13px;
  letter-spacing: 0.08em;
  line-height: 1.6;
  margin-right: 5%;
}
body main.page.page-product.child section.spec-section .inner .award-area .item .pict {
  height: 60px;
}
body main.page.page-product.child section.spec-section .inner .award-area .item .pict img {
  width: auto;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
body main.page.page-product.child section.spec-section .inner .award-area + .award-area {
  margin-top: 30px;
}
body main.page.page-product.child section.spec-section .inner .dl-area {
  margin-top: 78px;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
}
body main.page.page-product.child section.spec-section .inner .dl-area .dl-box {
  width: 50%;
}
body main.page.page-product.child section.spec-section .inner .dl-area .dl-box h3.ttl {
  padding-bottom: 20px;
  border-bottom: 1px solid #CBCBCB;
  font-weight: normal;
}
body main.page.page-product.child section.spec-section .inner .dl-area .dl-box .dl-outer dl {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
}
body main.page.page-product.child section.spec-section .inner .dl-area .dl-box .dl-outer dl + dl {
  padding-top: 26px;
}
body main.page.page-product.child section.spec-section .inner .dl-area .dl-box .dl-outer dl dt {
  width: 33.5%;
  line-height: 1.9;
  font-size: 13px;
  letter-spacing: 0.05em;
}
body main.page.page-product.child section.spec-section .inner .dl-area .dl-box .dl-outer dl dt span {
  display: block;
}
body main.page.page-product.child section.spec-section .inner .dl-area .dl-box .dl-outer dl dt span :nth-of-type(n + 2) {
  margin-top: 10px;
}
body main.page.page-product.child section.spec-section .inner .dl-area .dl-box .dl-outer dl dd {
  width: 66.5%;
  line-height: 1.8;
  font-size: 13px;
  letter-spacing: 0.05em;
}
body main.page.page-product.child section.spec-section .inner .dl-area .dl-box .dl-outer dl dd span {
  display: block;
}
body main.page.page-product.child section.spec-section .inner .dl-area .dl-box .dl-outer dl dd span :nth-of-type(n + 2) {
  margin-top: 10px;
}
body main.page.page-product.child section.spec-section .inner .dl-area .dl-box.dl-box02 dl dt {
  width: 27.5%;
}
body main.page.page-product.child section.spec-section .inner .dl-area .dl-box.dl-box02 dl dd {
  width: 72.5%;
}
body main.page.page-product.child section.spec-section .inner .dl-area .dl-box:nth-of-type(odd) h3.ttl,
body main.page.page-product.child section.spec-section .inner .dl-area .dl-box:nth-of-type(odd) dl {
  padding-right: 5.3%;
}
body main.page.page-product.child section.spec-section .inner .dl-area .dl-box:nth-of-type(even) h3.ttl,
body main.page.page-product.child section.spec-section .inner .dl-area .dl-box:nth-of-type(even) dl {
  padding-left: 5.3%;
}
body main.page.page-product.child section.spec-section .inner .dl-area .link-box {
  width: 100%;
  margin-top: 25px;
}
@media screen and (max-width: 850px) {
  body main.page.page-product.child section.spec-section {
    padding-top: 55px;
    padding-bottom: 35px;
  }
  body main.page.page-product.child section.spec-section .inner h2.ttl {
    text-align: left;
    margin-bottom: 15px;
  }
  body main.page.page-product.child section.spec-section .inner .info-area .txt {
    text-align: left;
  }
  body main.page.page-product.child section.spec-section .inner .info-area .txt.txt + .txt {
    margin-top: 0px;
  }
  body main.page.page-product.child section.spec-section .inner .lead-area {
    margin-top: 30px;
  }
  body main.page.page-product.child section.spec-section .inner .lead-area .txt {
    text-align: justify;
  }
  body main.page.page-product.child section.spec-section .inner .award-area {
    margin-top: 30px;
    display: block;
    width: 100%;
  }
  body main.page.page-product.child section.spec-section .inner .award-area .item {
    display: block;
    max-width: 100%;
    width: 100%;
    margin-right: 20%;
    margin-bottom: 20px;
  }
  body main.page.page-product.child section.spec-section .inner .award-area .item p.txt {
    font-size: 14px;
    letter-spacing: 0.05em;
    line-height: 1.6;
    margin-right: 0%;
    min-width: auto;
  }
  body main.page.page-product.child section.spec-section .inner .award-area .item .pict {
    max-width: 100%;
    min-width: 250px;
    width: auto;
    margin-top: 15px;
    height: 44px;
  }
  body main.page.page-product.child section.spec-section .inner .award-area .item .pict img {
    width: auto;
    height: 100%;
    -o-object-fit: contain;
       object-fit: contain;
  }
  body main.page.page-product.child section.spec-section .inner .award-area .item + .item {
    margin-top: 30px;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area {
    margin-top: 60px;
    display: block;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box {
    width: 100%;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box h3.ttl {
    padding: 0 10px 10px 0;
    font-size: 25px;
    margin-bottom: 0;
    background: url(../../asset/img/common/arw_down.svg) no-repeat center right;
    background-size: 10px;
    transition: all 0.6s;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box .dl-outer {
    display: none;
    height: 0;
    visibility: hidden;
    opacity: 0;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box .dl-outer dl:nth-of-type(1) {
    padding-top: 30px;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box .dl-outer dl + dl {
    padding-top: 15px;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box .dl-outer dl dt {
    width: 100%;
    line-height: 1.9;
    font-size: 13px;
    letter-spacing: 0.05em;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box .dl-outer dl dt span {
    display: block;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box .dl-outer dl dt span :nth-of-type(n + 2) {
    margin-top: 0px;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box .dl-outer dl dd {
    width: 100%;
    line-height: 1.8;
    font-size: 13px;
    letter-spacing: 0.05em;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box .dl-outer dl dd span {
    display: block;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box .dl-outer dl dd span :nth-of-type(n + 2) {
    margin-top: 10px;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box.dl-box02 {
    margin-top: 35px;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box.dl-box02 dl dt {
    width: 100%;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box.dl-box02 dl dd {
    width: 100%;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box:nth-of-type(odd) h3.ttl,
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box:nth-of-type(odd) dl {
    padding-right: 0%;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box:nth-of-type(even) h3.ttl,
  body main.page.page-product.child section.spec-section .inner .dl-area .dl-box:nth-of-type(even) dl {
    padding-left: 0%;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .link-box {
    width: 100%;
    margin-top: 25px;
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .open h3.ttl {
    background-image: url(../../asset/img/common/arw_up.svg);
  }
  body main.page.page-product.child section.spec-section .inner .dl-area .open .dl-outer {
    height: 100%;
    visibility: visible;
    opacity: 1;
    display: block;
  }
}
body main.page.page-product.child section.pdf-section {
  padding-top: 0px;
  padding-bottom: 100px;
}
body main.page.page-product.child section.pdf-section .inner h3.ttl {
  padding-bottom: 20px;
  border-bottom: 1px solid #CBCBCB;
  font-weight: normal;
}
body main.page.page-product.child section.pdf-section .inner .btn-area {
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: wrap;
  margin-left: -1.8%;
  margin-right: -1.8%;
}
body main.page.page-product.child section.pdf-section .inner .btn-area .btn-box {
  display: block;
  width: 21.4%;
  margin-left: 1.8%;
  margin-right: 1.8%;
}
body main.page.page-product.child section.pdf-section .inner .btn-area .btn-box:nth-of-type(n + 5) {
  margin-top: 40px;
}
body main.page.page-product.child section.pdf-section .inner .btn-area .btn-box #en-pdf {
  display: none !important;
}
@media screen and (max-width: 850px) {
  body main.page.page-product.child section.pdf-section {
    padding-top: 0px;
    padding-bottom: 80px;
  }
  body main.page.page-product.child section.pdf-section .inner h3.ttl {
    padding-bottom: 10px;
    font-size: 25px;
    margin-bottom: 0;
    background: url(../../asset/img/common/arw_down.svg) no-repeat center right;
    background-size: 10px;
    transition: all 0.6s;
  }
  body main.page.page-product.child section.pdf-section .inner .btn-area {
    display: block;
    width: 100%;
    margin-left: 0%;
    margin-right: 0%;
    display: none;
    height: 0;
    visibility: hidden;
    opacity: 0;
    padding-top: 30px;
  }
  body main.page.page-product.child section.pdf-section .inner .btn-area .btn-box {
    width: 100%;
    margin-left: 0%;
    margin-right: 0%;
  }
  body main.page.page-product.child section.pdf-section .inner .btn-area .btn-box:nth-of-type(n + 5) {
    margin-top: 0px;
  }
  body main.page.page-product.child section.pdf-section .inner .btn-area .btn-box:nth-of-type(n + 2) {
    margin-top: 30px;
  }
  body main.page.page-product.child section.pdf-section .inner .btn-area .btn-box .btn04 {
    max-width: 100%;
  }
  body main.page.page-product.child section.pdf-section .inner.open h3.ttl {
    background-image: url(../../asset/img/common/arw_up.svg);
  }
  body main.page.page-product.child section.pdf-section .inner.open .btn-area {
    height: 100%;
    visibility: visible;
    opacity: 1;
    display: block;
  }
}
body main.page.page-product.child section.info-section {
  padding-top: 0;
}
body main.page.page-product.child section.info-section .inner h1.ttl {
  margin-bottom: 0;
  text-align: center;
}
body main.page.page-product.child section.info-section .inner .item-area {
  margin-top: 95px;
}
body main.page.page-product.child section.info-section .inner .item-area figure {
  margin-bottom: 42px;
}
body main.page.page-product.child section.info-section .inner .item-area figcaption {
  margin-top: 10px;
}
body main.page.page-product.child section.info-section .inner .item-area .wp-block-group {
  margin-bottom: 100px;
}
body main.page.page-product.child section.info-section .inner .item-area h1 {
  margin-bottom: 75px;
}
body main.page.page-product.child section.info-section .inner .item-area h2, body main.page.page-product.child section.info-section .inner .item-area h3, body main.page.page-product.child section.info-section .inner .item-area h4 {
  margin-bottom: 25px;
}
body main.page.page-product.child section.info-section .inner .item-area .wp-block-columns {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
  margin-bottom: 0;
}
body main.page.page-product.child section.info-section .inner .item-area .wp-block-columns .wp-block-column {
  max-width: 512px;
}
body main.page.page-product.child section.info-section .inner .item-area .wp-block-columns .wp-block-column iframe {
  max-width: 100%;
}
body main.page.page-product.child section.info-section .inner .item-area .item .pict.ver02 {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
}
body main.page.page-product.child section.info-section .inner .item-area .item .pict.ver02 img {
  width: 44.7%;
}
body main.page.page-product.child section.info-section .inner .item-area .item .txt {
  margin-top: 48px;
}
body main.page.page-product.child section.info-section .inner .item-area .item.item + .item {
  margin-top: 95px;
}
body main.page.page-product.child section.info-section .inner .item-area .item.item + .ttl.sub {
  margin-top: 142px;
}
body main.page.page-product.child section.info-section .inner .item-area .ttl.sub {
  margin-bottom: 75px;
}
body main.page.page-product.child section.info-section .inner .btn-area {
  margin-top: 100px;
}
body main.page.page-product.child section.info-section .inner .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 850px) {
  body main.page.page-product.child section.info-section .inner .item-area {
    margin-top: 38px;
  }
  body main.page.page-product.child section.info-section .inner .item-area figure {
    margin-bottom: 42px;
  }
  body main.page.page-product.child section.info-section .inner .item-area figcaption {
    margin-top: 10px;
  }
  body main.page.page-product.child section.info-section .inner .item-area .wp-block-group {
    margin-bottom: 68px;
  }
  body main.page.page-product.child section.info-section .inner .item-area h1 {
    margin-bottom: 40px;
  }
  body main.page.page-product.child section.info-section .inner .item-area h2, body main.page.page-product.child section.info-section .inner .item-area h3, body main.page.page-product.child section.info-section .inner .item-area h4 {
    margin-bottom: 25px;
  }
  body main.page.page-product.child section.info-section .inner .item-area p {
    margin-bottom: 25px;
  }
  body main.page.page-product.child section.info-section .inner .item-area .wp-block-columns {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    flex-wrap: wrap;
    margin-bottom: 0;
  }
  body main.page.page-product.child section.info-section .inner .item-area .wp-block-columns .wp-block-column {
    max-width: 512px;
  }
  body main.page.page-product.child section.info-section .inner .btn-area {
    margin-top: 60px;
  }
}
body main.page.page-product.child:not(.Japan) section.pdf-section .inner .btn-area .btn-box #ja-pdf {
  display: none !important;
}
body main.page.page-product.child:not(.Japan) section.pdf-section .inner .btn-area .btn-box #en-pdf {
  display: block !important;
}
body main.page.page-product.cate section.content-section {
  position: relative;
}
body main.page.page-product.cate section.content-section + .content-section {
  margin-top: -100px;
  padding-top: 100px;
}
body main.page.page-product.cate section.content-section.content-section01 {
  margin-top: -100px;
  padding-top: 100px;
}
body main.page.page-product.cate section.content-section .inner .ttl {
  text-align: center;
}
body main.page.page-product.cate section.content-section .inner .item-area {
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: wrap;
  margin-left: -2.5%;
  margin-right: -2.5%;
}
body main.page.page-product.cate section.content-section .inner .item-area .item {
  display: block;
  width: 28.3333333333%;
  margin-left: 2.5%;
  margin-right: 2.5%;
}
body main.page.page-product.cate section.content-section .inner .item-area .item:nth-of-type(n + 4) {
  margin-top: 60px;
}
body main.page.page-product.cate section.content-section .inner .item-area .item .pict {
  display: block;
  overflow: hidden;
  width: 100%;
  text-align: center;
}
body main.page.page-product.cate section.content-section .inner .item-area .item .pict img {
  -o-object-position: center;
     object-position: center;
  -o-object-fit: cover;
     object-fit: cover;
  height: auto;
  width: 100%;
}
body main.page.page-product.cate section.content-section .inner .item-area .item .text {
  display: block;
  padding: 8px 26px;
  margin-top: 40px;
  border-left: 1px solid #707070;
}
body main.page.page-product.cate section.content-section .inner .item-area .item .text .cate {
  font-size: 13px;
  letter-spacing: 0.08em;
  font-weight: bold;
  display: block;
  line-height: 1.8;
}
body main.page.page-product.cate section.content-section .inner .item-area .item .text .cate + .name-en {
  margin-top: 10px;
}
body main.page.page-product.cate section.content-section .inner .item-area .item .text .name-en {
  font-size: 16px;
  letter-spacing: 0.15em;
  font-weight: bold;
  display: block;
  line-height: 1.8;
  margin-bottom: 0px;
}
body main.page.page-product.cate section.content-section .inner .item-area .item .text .name-jp {
  font-size: 12px;
  letter-spacing: 0em;
  display: block;
  line-height: 1.8;
}
@media screen and (max-width: 850px) {
  body main.page.page-product.cate section.content-section .inner .item-area {
    margin-left: 0;
    margin-right: 0;
  }
  body main.page.page-product.cate section.content-section .inner .item-area .item {
    display: block;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
  body main.page.page-product.cate section.content-section .inner .item-area .item:nth-of-type(n + 4) {
    margin-top: 0px;
  }
  body main.page.page-product.cate section.content-section .inner .item-area .item:nth-of-type(n + 2) {
    margin-top: 40px;
  }
  body main.page.page-product.cate section.content-section .inner .item-area .item .text {
    display: block;
    padding: 0px 15px;
    margin-top: 20px;
  }
  body main.page.page-product.cate section.content-section .inner .item-area .item .text .cate {
    font-size: 14px;
  }
  body main.page.page-product.cate section.content-section .inner .item-area .item .text .cate + .name-en {
    margin-top: 4px;
  }
  body main.page.page-product.cate section.content-section .inner .item-area .item .text .name-en {
    font-size: 16px;
    margin-bottom: 0px;
  }
  body main.page.page-product.cate section.content-section .inner .item-area .item .text .name-jp {
    font-size: 13px;
  }
}
body main.page.page-product.cate section.content-section .inner .pagination-area .wp-pagenavi {
  margin-top: 140px;
}
body main.page.page-product.cate section.cateNav {
  padding-top: 0;
}
body main.page.page-product.cate section.cateNav .inner h2.ttl {
  margin-bottom: 80px;
  text-align: center;
}
body main.page.page-product.cate section.cateNav .inner h2.ttl .line {
  display: inline-block;
  position: relative;
  padding-bottom: 5px;
}
body main.page.page-product.cate section.cateNav .inner h2.ttl .line:after {
  content: "";
  height: 1px;
  width: calc(100% - 14px);
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
  margin: 0 auto;
  background-color: #707070;
}
body main.page.page-product.cate section.cateNav .inner h2.ttl.ver02:before {
  display: none;
}
@media screen and (max-width: 850px) {
  body main.page.page-product.cate section.cateNav .inner h2.ttl {
    margin-bottom: 70px;
  }
}
body main.page.page-product.cate section.cateNav .inner .item-area {
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: wrap;
  margin-left: -2.5%;
  margin-right: -2.5%;
}
body main.page.page-product.cate section.cateNav .inner .item-area .item {
  display: block;
  width: 28.3333333333%;
  margin-left: 2.5%;
  margin-right: 2.5%;
}
body main.page.page-product.cate section.cateNav .inner .item-area .item:nth-of-type(n + 4) {
  margin-top: 60px;
}
body main.page.page-product.cate section.cateNav .inner .item-area .item .pict {
  display: block;
  overflow: hidden;
  width: 100%;
  text-align: center;
}
body main.page.page-product.cate section.cateNav .inner .item-area .item .pict img {
  -o-object-position: center;
     object-position: center;
  -o-object-fit: cover;
     object-fit: cover;
  height: auto;
  width: 100%;
}
body main.page.page-product.cate section.cateNav .inner .item-area .item .text {
  display: block;
  padding: 8px 26px;
  margin-top: 40px;
  border-left: 1px solid #707070;
}
body main.page.page-product.cate section.cateNav .inner .item-area .item .text .cate {
  font-size: 13px;
  letter-spacing: 0.08em;
  font-weight: bold;
  display: block;
  line-height: 1.8;
}
body main.page.page-product.cate section.cateNav .inner .item-area .item .text .cate + .name-en {
  margin-top: 10px;
}
body main.page.page-product.cate section.cateNav .inner .item-area .item .text .name-en {
  font-size: 16px;
  letter-spacing: 0.15em;
  font-weight: bold;
  display: block;
  line-height: 1.8;
  margin-bottom: 0px;
}
body main.page.page-product.cate section.cateNav .inner .item-area .item .text .name-jp {
  font-size: 12px;
  letter-spacing: 0em;
  display: block;
  line-height: 1.8;
}
@media screen and (max-width: 850px) {
  body main.page.page-product.cate section.cateNav .inner .item-area {
    margin-left: 0;
    margin-right: 0;
  }
  body main.page.page-product.cate section.cateNav .inner .item-area .item {
    display: block;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
  body main.page.page-product.cate section.cateNav .inner .item-area .item:nth-of-type(n + 4) {
    margin-top: 0px;
  }
  body main.page.page-product.cate section.cateNav .inner .item-area .item:nth-of-type(n + 2) {
    margin-top: 40px;
  }
  body main.page.page-product.cate section.cateNav .inner .item-area .item .text {
    display: block;
    padding: 0px 15px;
    margin-top: 20px;
  }
  body main.page.page-product.cate section.cateNav .inner .item-area .item .text .cate {
    font-size: 14px;
  }
  body main.page.page-product.cate section.cateNav .inner .item-area .item .text .cate + .name-en {
    margin-top: 4px;
  }
  body main.page.page-product.cate section.cateNav .inner .item-area .item .text .name-en {
    font-size: 16px;
    margin-bottom: 0px;
  }
  body main.page.page-product.cate section.cateNav .inner .item-area .item .text .name-jp {
    font-size: 13px;
  }
}

body main.page.page-award section.page-header {
  padding-bottom: 86px;
}
@media screen and (max-width: 850px) {
  body main.page.page-award section.page-header {
    padding-bottom: 38px;
  }
}
body main.page.page-award section.award-section .item-box + .item-box {
  margin-top: 138px;
}
@media screen and (max-width: 850px) {
  body main.page.page-award section.award-section .item-box + .item-box {
    margin-top: 60px;
  }
}
body main.page.page-award section.award-section .item-box h1.ttl {
  position: relative;
  margin-bottom: 0;
  padding-bottom: 50px;
  text-align: center;
}
body main.page.page-award section.award-section .item-box h1.ttl:after {
  content: "";
  position: absolute;
  bottom: -34px;
  left: 0;
  right: 0;
  display: block;
  height: 68px;
  width: 1px;
  background-color: #707070;
  margin: auto;
  z-index: 1;
}
@media screen and (max-width: 850px) {
  body main.page.page-award section.award-section .item-box h1.ttl {
    padding-bottom: 40px;
  }
  body main.page.page-award section.award-section .item-box h1.ttl:after {
    height: 60px;
    bottom: -30px;
  }
}
body main.page.page-award section.award-section .item-box .flex {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
  position: relative;
}
@media screen and (max-width: 850px) {
  body main.page.page-award section.award-section .item-box .flex .group + .group {
    margin-top: 50px;
  }
}
body main.page.page-award section.award-section .item-box .flex .group.min {
  width: 28%;
}
body main.page.page-award section.award-section .item-box .flex .group.min + .group {
  margin-top: 50px;
}
body main.page.page-award section.award-section .item-box .flex .group.min .item + .item {
  margin-top: 52px;
}
@media screen and (max-width: 850px) {
  body main.page.page-award section.award-section .item-box .flex .group.min {
    width: 100%;
  }
  body main.page.page-award section.award-section .item-box .flex .group.min .item + .item {
    margin-top: 50px;
  }
}
body main.page.page-award section.award-section .item-box .flex .group.wide {
  width: 64.5%;
}
body main.page.page-award section.award-section .item-box .flex .group.wide:nth-of-type(2) {
  margin-top: 0;
}
@media screen and (max-width: 850px) {
  body main.page.page-award section.award-section .item-box .flex .group.wide {
    width: 100%;
  }
  body main.page.page-award section.award-section .item-box .flex .group.wide:nth-of-type(2) {
    margin-top: 50px;
  }
}
body main.page.page-award section.award-section .item-box .flex .group .item {
  width: 100%;
  display: block;
}
body main.page.page-award section.award-section .item-box .flex .group .item .pict {
  margin-bottom: 20px;
}
@media screen and (max-width: 850px) {
  body main.page.page-award section.award-section .item-box .flex .group .item .pict {
    width: calc(100% + 46px);
    margin-left: -23px;
    margin-right: -23px;
  }
}
body main.page.page-award section.award-section .item-box .flex .group .item .text .ttl {
  margin-bottom: 8px;
  font-weight: bold;
}
body main.page.page-award section.award-section .item-box .flex .group .item .text .txt {
  font-size: 11px;
  letter-spacing: 0.05em;
  line-height: 1.6;
}
@media screen and (max-width: 850px) {
  body main.page.page-award section.award-section .item-box .flex .group .item .text .txt {
    font-size: 13px;
  }
}
body main.page.page-villa section.hero-section {
  background: url(../img/page/villa/hero-section_bg.jpg) no-repeat center;
  background-size: cover;
}
body main.page.page-villa section.hero-section .inner .text-area {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  height: 130px;
}
body main.page.page-villa section.hero-section .inner .text-area .ttl {
  color: #fff;
  margin-bottom: 12px;
  text-align: center;
}
body main.page.page-villa section.hero-section .inner .text-area .note {
  color: #fff;
  font-size: 20px;
  letter-spacing: 0.08em;
  line-height: 1.8;
  text-align: center;
}
@media screen and (max-width: 850px) {
  body main.page.page-villa section.hero-section {
    height: 210px;
    padding-top: 60px;
  }
}
body main.page.page-villa section.lead-section {
  padding-top: 112px;
}
@media screen and (max-width: 850px) {
  body main.page.page-villa section.lead-section {
    padding-top: 90px;
  }
}
body main.page.page-villa section.lead-section .inner .sp-text-area {
  margin-bottom: 40px;
  text-align: center;
}
body main.page.page-villa section.lead-section .inner .sp-text-area .ttl {
  margin-bottom: 0;
}
body main.page.page-villa section.lead-section .inner .sp-text-area .note {
  font-size: 15px;
  letter-spacing: 0.1em;
  line-height: 2;
  margin-top: 5px;
}
@media screen and (max-width: 850px) {
  body main.page.page-villa section.lead-section .inner .sp-text-area {
    display: block;
  }
}
body main.page.page-villa section.lead-section .inner .btn {
  margin-top: 100px;
}
@media screen and (max-width: 850px) {
  body main.page.page-villa section.lead-section .inner .btn {
    margin-top: 90px;
    margin-left: auto;
    margin-right: auto;
  }
}
body main.page.page-villa section.movie-section {
  padding-bottom: 0;
}
@media screen and (max-width: 850px) {
  body main.page.page-villa section.movie-section {
    padding-bottom: 32px;
  }
}
@media screen and (max-width: 850px) {
  body main.page.page-villa section.text-section {
    padding-top: 52px;
    padding-bottom: 52px;
  }
  body main.page.page-villa section.text-section:last-of-type {
    margin-bottom: 90px;
  }
}
@media screen and (max-width: 850px) {
  body main.page.page-villa section.text-section .inner {
    overflow: hidden;
  }
}
body main.page.page-villa section.text-section .inner p.txt {
  font-size: 15px;
  letter-spacing: 0.3em;
  line-height: 4.6;
}
body main.page.page-villa section.text-section .inner p.txt.center {
  text-align: center;
}
body main.page.page-villa section.text-section .inner p.txt.right {
  text-align: right;
}
@media screen and (max-width: 850px) {
  body main.page.page-villa section.text-section .inner p.txt {
    font-size: 14px;
    letter-spacing: 0.05em;
    line-height: 2;
    overflow: hidden;
  }
  body main.page.page-villa section.text-section .inner p.txt.center {
    text-align: justify;
  }
  body main.page.page-villa section.text-section .inner p.txt.right {
    text-align: justify;
  }
}
body main.page.page-villa section.text-section .inner p.txt .text-line {
  display: block;
  overflow: hidden;
}
body main.page.page-villa section.text-section .inner p.txt .text-line .ani-fade {
  display: block;
}
@media screen and (max-width: 850px) {
  body main.page.page-villa section.text-section .inner p.txt .text-line {
    display: inline;
    overflow: hidden;
  }
  body main.page.page-villa section.text-section .inner p.txt .text-line .ani-fade {
    display: inline;
  }
}
body main.page.page-villa section.text-section .inner .info {
  font-size: 13px;
  letter-spacing: 0.1em;
  line-height: 1.8;
}
body main.page.page-villa section.text-section .inner .info .text-line {
  display: block;
  overflow: hidden;
}
body main.page.page-villa section.text-section .inner .info .text-line .ani-fade {
  display: block;
}
body main.page.page-villa section.pict-section {
  padding-top: 0;
  padding-bottom: 0;
}
body main.page.page-villa section.pict-section .inner .pict-area {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
}
body main.page.page-villa section.pict-section .inner .pict-area .pict {
  display: block;
  width: 100%;
  height: auto;
  overflow: hidden;
}
body main.page.page-villa section.pict-section .inner .pict-area .pict.min {
  width: 46.2%;
}
body main.page.page-villa section.pict-section .inner .pict-area .pict:nth-of-type(n + 3) {
  margin-top: 72px;
}
body main.page.page-villa section.pict-section .inner .pict-area .pict.wide + .min {
  margin-top: 72px;
}
body main.page.page-villa section.pict-section .inner .pict-area .pict.mid {
  max-width: 726px;
  margin: 0 auto;
}
@media screen and (max-width: 850px) {
  body main.page.page-villa section.pict-section .inner .pict-area {
    width: calc(100% + 46px);
    margin-left: -23px;
    margin-right: -23px;
  }
  body main.page.page-villa section.pict-section .inner .pict-area .pict.min {
    width: 100%;
  }
  body main.page.page-villa section.pict-section .inner .pict-area .pict:nth-of-type(n + 3) {
    margin-top: 0px;
  }
  body main.page.page-villa section.pict-section .inner .pict-area .pict + .min {
    margin-top: 0;
  }
  body main.page.page-villa section.pict-section .inner .pict-area .pict.wide + .min {
    margin-top: 0px;
  }
}

body main.page.page-milan section .bg-movie {
  text-align: center;
  font-size: 0;
  overflow: hidden;
}
body main.page.page-milan section .bg-movie .bg-movie-box {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  margin-top: -3px;
}
body main.page.page-milan section.slide-section {
  padding-top: 148px;
  position: relative;
}
body main.page.page-milan section.slide-section .slider-area {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-wrap: nowrap;
}
body main.page.page-milan section.slide-section .slider-area .logo {
  width: 265px;
  height: auto;
  display: block;
  position: absolute;
  top: 0;
  left: 62%;
}
body main.page.page-milan section.slide-section .slider-area .swiper-container {
  overflow: hidden;
}
body main.page.page-milan section.slide-section .slider-area .swiper-container04 {
  width: 57%;
  height: 478px;
}
body main.page.page-milan section.slide-section .slider-area .swiper-container04 .swiper-wrapper .swiper-slide .image {
  transition: all 0.3s;
  transform: scale(1.2);
}
body main.page.page-milan section.slide-section .slider-area .swiper-container04 .swiper-wrapper .swiper-slide.swiper-slide-next .image {
  width: 40%;
}
body main.page.page-milan section.slide-section .slider-area .swiper-container04 .swiper-wrapper .swiper-slide.swiper-slide-active .image {
  width: 100%;
}
body main.page.page-milan section.slide-section .slider-area .swiper-container04 .swiper-wrapper .swiper-slide.swiper-slide-active .image, body main.page.page-milan section.slide-section .slider-area .swiper-container04 .swiper-wrapper .swiper-slide.swiper-slide-duplicate-active .image, body main.page.page-milan section.slide-section .slider-area .swiper-container04 .swiper-wrapper .swiper-slide.swiper-slide-prev .image {
  animation: zoomOut 10s linear 0s 1 normal both;
}
body main.page.page-milan section.slide-section .slider-area .thum {
  width: 16.65%;
  height: 200px;
}
body main.page.page-milan section.slide-section .slider-area .swiper-pagination {
  top: 0;
  right: 0;
  text-align: right;
  display: flex;
  justify-content: flex-start;
  align-items: flex-end;
  flex-wrap: wrap;
  flex-direction: column;
}
body main.page.page-milan section.slide-section .slider-area .swiper-pagination .swiper-pagination-bullet + .swiper-pagination-bullet {
  margin-top: 12px !important;
}
body main.page.page-milan section.slide-section p.note {
  margin-top: 20px;
  position: relative;
  left: 74%;
}
@media screen and (max-width: 850px) {
  body main.page.page-milan section.slide-section {
    padding-top: 100px;
    width: 100%;
    height: 100vh;
  }
  body main.page.page-milan section.slide-section .bg-movie {
    height: 60vh;
  }
  body main.page.page-milan section.slide-section .slider-area {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    padding-top: 125px;
  }
  body main.page.page-milan section.slide-section .slider-area .logo {
    width: 174px;
    top: 0;
    left: 23px;
  }
  body main.page.page-milan section.slide-section .slider-area .swiper-container04 {
    width: 100%;
    height: 50vh;
    margin-bottom: 4.5vh;
  }
  body main.page.page-milan section.slide-section .slider-area .swiper-container04 .swiper-wrapper .swiper-slide .image {
    transform: scale(1.2);
  }
  body main.page.page-milan section.slide-section .slider-area .swiper-container04 .swiper-wrapper .swiper-slide.swiper-slide-active .image, body main.page.page-milan section.slide-section .slider-area .swiper-container04 .swiper-wrapper .swiper-slide.swiper-slide-duplicate-active .image, body main.page.page-milan section.slide-section .slider-area .swiper-container04 .swiper-wrapper .swiper-slide.swiper-slide-prev .image {
    animation: zoomOut 10s linear 0s 1 normal both;
  }
  body main.page.page-milan section.slide-section .slider-area .thum {
    width: 45%;
    height: 17.5vh;
  }
  body main.page.page-milan section.slide-section .slider-area .swiper-pagination {
    top: 0;
    right: 23px;
    text-align: right;
  }
  body main.page.page-milan section.slide-section p.note {
    left: 0;
    text-align: center;
  }
}
body main.page.page-milan section.lead-section {
  padding-top: 120px;
  padding-bottom: 0;
}
body main.page.page-milan section.slide-section02 {
  padding-top: 100px;
  padding-bottom: 100px;
}
body main.page.page-milan section.slide-section02 .swiper-container {
  margin-top: 0px;
}
body main.page.page-milan section.slide-section02 .swiper-container + .swiper-container {
  margin-top: 8px;
}
@media screen and (max-width: 850px) {
  body main.page.page-milan section.slide-section02 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}
body main.page.page-milan section.archive-section {
  padding-top: 0;
  padding-bottom: 156px;
}
body main.page.page-milan section.archive-section .inner .ttl {
  margin-bottom: 80px;
  text-align: center;
}
body main.page.page-milan section.archive-section .inner .ttl .line {
  display: inline-block;
  position: relative;
  padding-bottom: 5px;
}
body main.page.page-milan section.archive-section .inner .ttl .line:after {
  content: "";
  height: 1px;
  width: 60%;
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
  margin: 0 auto;
  background-color: #707070;
}
@media screen and (max-width: 850px) {
  body main.page.page-milan section.archive-section .inner .ttl {
    margin-bottom: 75px;
  }
}
body main.page.page-milan section.archive-section .inner .item-area {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}
body main.page.page-milan section.archive-section .inner .item-area .item {
  width: 42.85%;
  display: block;
}
body main.page.page-milan section.archive-section .inner .item-area .item:nth-of-type(n + 3) {
  margin-top: 82px;
}
body main.page.page-milan section.archive-section .inner .item-area .item .pict {
  width: 100%;
}
body main.page.page-milan section.archive-section .inner .item-area .item .txt {
  font-size: 16px;
  letter-spacing: 0.22em;
  margin-top: 28px;
  background: url(../img/common/arw_r.svg) no-repeat right center;
  background-size: auto;
  font-weight: 600;
  text-align: center;
}
@media screen and (max-width: 850px) {
  body main.page.page-milan section.archive-section .inner .item-area .item {
    width: 100%;
  }
  body main.page.page-milan section.archive-section .inner .item-area .item:nth-of-type(n + 3) {
    margin-top: 0px;
  }
  body main.page.page-milan section.archive-section .inner .item-area .item:nth-of-type(n + 2) {
    margin-top: 40px;
  }
  body main.page.page-milan section.archive-section .inner .item-area .item .txt {
    font-size: 16px;
    margin-top: 18px;
  }
}
body main.page.page-milan.child section.page-header .inner p.sub {
  font-size: 25px;
  letter-spacing: 0.2em;
  line-height: 1.8;
  text-align: center;
  margin-top: 35px;
}
@media screen and (max-width: 850px) {
  body main.page.page-milan.child section.page-header .inner p.sub {
    margin-top: 30px;
    font-size: 20px;
    letter-spacing: 0.15em;
    text-align: center;
  }
}
body main.page.page-milan.child section.field-section {
  padding-top: 0;
}
body main.page.page-milan.child section.field-section .inner img {
  max-width: 100%;
  width: auto;
  height: auto;
}
body main.page.page-milan.child section.field-section .inner p + figure {
  margin-top: 70px;
}
@media screen and (max-width: 850px) {
  body main.page.page-milan.child section.field-section .inner p + figure {
    margin-top: 40px;
  }
}
body main.page.page-milan.child section.field-section .inner figure.wp-block-embed {
  text-align: center;
}
body main.page.page-milan.child section.field-section .inner figure + figure {
  margin-top: 116px;
}
body main.page.page-milan.child section.field-section .inner figure + p {
  margin-top: 70px;
}
body main.page.page-milan.child section.field-section .inner figure.wp-block-image + .wp-block-embed {
  margin-top: 160px;
}
body main.page.page-milan.child section.field-section .inner figure.wp-block-embed + .wp-block-embed {
  margin-top: 116px;
}
@media screen and (max-width: 850px) {
  body main.page.page-milan.child section.field-section .inner figure + p {
    margin-top: 70px;
  }
  body main.page.page-milan.child section.field-section .inner figure.wp-block-image {
    width: calc(100% + 46px);
    margin-left: -23px;
    margin-right: -23px;
    margin-bottom: 0;
  }
  body main.page.page-milan.child section.field-section .inner figure.wp-block-image + .wp-block-embed {
    margin-top: 90px;
  }
  body main.page.page-milan.child section.field-section .inner figure + figure {
    margin-top: 30px;
  }
  body main.page.page-milan.child section.field-section .inner figure.wp-block-embed + .wp-block-embed {
    margin-top: 90px;
  }
}
body main.page.page-milan.child section.archive-section {
  padding-top: 160px;
  padding-bottom: 160px;
  position: relative;
}
body main.page.page-milan.child section.archive-section:before {
  content: "";
  height: 1px;
  max-width: 1116px;
  width: 100%;
  background-color: #707070;
  top: 0;
  right: 0;
  left: 0;
  margin: 0 auto;
  display: block;
  position: absolute;
}
@media screen and (max-width: 850px) {
  body main.page.page-milan.child section.archive-section {
    padding-top: 90px;
    padding-bottom: 90px;
  }
}

body main.page.page-works section.slide-section {
  padding-top: 64px;
}
body main.page.page-works section.slide-section .swiper-container03 {
  height: 562px;
  position: relative;
}
body main.page.page-works section.slide-section .swiper-container03 .swiper-wrapper {
  height: 500px;
}
body main.page.page-works section.slide-section .swiper-container03 .swiper-pagination {
  bottom: 0px;
  left: 0;
  right: 0;
  margin: auto !important;
  text-align: center;
}
@media screen and (max-width: 850px) {
  body main.page.page-works section.slide-section {
    padding-top: 78px;
  }
  body main.page.page-works section.slide-section .swiper-container03 {
    height: 198px;
    width: 93.5%;
    margin-left: auto;
    margin-right: auto;
  }
  body main.page.page-works section.slide-section .swiper-container03 .swiper-wrapper {
    height: 137px;
  }
  body main.page.page-works section.slide-section .swiper-container03 .swiper-wrapper .swiper-slide h2 {
    font-size: 16px;
    bottom: 10px;
  }
}
body main.page.page-works section.text-section {
  padding-top: 100px;
}
body main.page.page-works section.content-section .inner .works-posts .item {
  display: block;
}
body main.page.page-works section.content-section .inner .works-posts .item img {
  height: 520px;
  -o-object-fit: cover;
     object-fit: cover;
}
body main.page.page-works section.content-section .inner .works-posts .item p.txt {
  margin-top: 45px;
  margin-bottom: 10px;
  letter-spacing: 0.1em;
  text-align: center;
}
body main.page.page-works section.content-section .inner .works-posts .item p.txt span.mark + .mark:before {
  content: " , ";
}
body main.page.page-works section.content-section .inner .works-posts .item h2 {
  margin-top: 10px;
  margin-bottom: 0;
  text-align: center;
}
body main.page.page-works section.content-section .inner .works-posts .item + .item {
  margin-top: 145px;
}
@media screen and (max-width: 850px) {
  body main.page.page-works section.content-section.content-section .inner .works-posts .item {
    display: block;
  }
  body main.page.page-works section.content-section.content-section .inner .works-posts .item img {
    height: 153px;
  }
  body main.page.page-works section.content-section.content-section .inner .works-posts .item + .item {
    margin-top: 58px;
  }
  body main.page.page-works section.content-section.content-section .inner .works-posts .item p.txt {
    margin-top: 25px;
    font-size: 10px;
  }
}
body main.page.page-shop section.content-section {
  padding-top: 160px;
}
@media screen and (max-width: 850px) {
  body main.page.page-shop section.content-section {
    padding-top: 80px;
    padding-bottom: 80px;
  }
}
body main.page.page-shop section.content-section:nth-of-type(even) {
  background-color: #F2F1EF;
}
body main.page.page-shop section.content-section .info-area {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: nowrap;
}
@media screen and (max-width: 850px) {
  body main.page.page-shop section.content-section .info-area .ttl {
    margin-bottom: 35px;
  }
}
body main.page.page-shop section.content-section .info-area .text-box .txt {
  line-height: 1.9;
  letter-spacing: 0.1em;
}
body main.page.page-shop section.content-section .info-area .text-box .txt + .txt {
  margin-top: 42px;
}
@media screen and (max-width: 850px) {
  body main.page.page-shop section.content-section .info-area .text-box .txt {
    font-size: 12px;
    letter-spacing: 0.05em;
  }
}
body main.page.page-shop section.content-section .info-area .btn-box {
  width: 250px;
}
body main.page.page-shop section.content-section .info-area .btn-box .btn + .btn {
  margin-top: 15px;
}
body main.page.page-shop section.content-section .info-area .btn-box.visivle-md {
  display: none;
}
@media screen and (max-width: 850px) {
  body main.page.page-shop section.content-section .info-area {
    display: block;
  }
  body main.page.page-shop section.content-section .info-area .btn-box {
    width: calc(100% + 10px);
    margin: 35px -10px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
  }
  body main.page.page-shop section.content-section .info-area .btn-box.hidden-md {
    display: none;
  }
  body main.page.page-shop section.content-section .info-area .btn-box .btn {
    width: calc(50% - 20px);
    max-width: none;
    padding: 5px 10px;
    font-size: 12px;
    margin: 0 10px;
  }
  body main.page.page-shop section.content-section .info-area .btn-box .btn + .btn {
    margin-top: 0px;
  }
  body main.page.page-shop section.content-section .info-area .btn-box .btn:nth-of-type(n + 3) {
    margin-top: 22px;
  }
}
body main.page.page-shop section.content-section .inner-footer {
  margin-top: 55px;
}
body main.page.page-shop section.content-section .inner-footer .map-container {
  position: relative;
  padding-bottom: 56.25%; /* 16:9の比率（必要に応じて調整） */
  height: 0;
  overflow: hidden;
  width: 100%;
}
body main.page.page-shop section.content-section .inner-footer .map-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
body main.page.page-shop section.content-section .inner-footer .swiper-container {
  height: 582px;
  z-index: 0;
}
body main.page.page-shop section.content-section .inner-footer .swiper-container .swiper-wrapper {
  height: 520px;
}
body main.page.page-shop section.content-section .inner-footer .swiper-container .swiper-wrapper .swiper-slide .image {
  transform: scale(1.2);
}
body main.page.page-shop section.content-section .inner-footer .swiper-container .swiper-wrapper .swiper-slide.swiper-slide-active .image, body main.page.page-shop section.content-section .inner-footer .swiper-container .swiper-wrapper .swiper-slide.swiper-slide-duplicate-active .image, body main.page.page-shop section.content-section .inner-footer .swiper-container .swiper-wrapper .swiper-slide.swiper-slide-prev .image {
  animation: zoomOut 10s linear 0s 1 normal both;
}
body main.page.page-shop section.content-section .inner-footer .swiper-container .swiper-pagination {
  bottom: 0px;
  left: 0;
  right: 0;
  margin: auto !important;
  text-align: center;
}
body main.page.page-shop section.content-section .inner-footer .movie-box + .movie-box, body main.page.page-shop section.content-section .inner-footer .movie-box + .swiper-container {
  margin-top: 40px;
}
@media screen and (max-width: 850px) {
  body main.page.page-shop section.content-section .inner-footer {
    margin-top: 30px;
  }
  body main.page.page-shop section.content-section .inner-footer .movie-box + .movie-box, body main.page.page-shop section.content-section .inner-footer .movie-box + .swiper-container {
    margin-top: 30px;
  }
  body main.page.page-shop section.content-section .inner-footer .swiper-container {
    height: 235px;
    width: calc(100% + 46px);
    margin-left: -23px;
    margin-right: -23px;
    z-index: 0;
  }
  body main.page.page-shop section.content-section .inner-footer .swiper-container .swiper-wrapper {
    height: 175px;
  }
  body main.page.page-shop section.content-section .inner-footer .swiper-container .swiper-wrapper .swiper-slide .image {
    transform: scale(1.2);
  }
  body main.page.page-shop section.content-section .inner-footer .swiper-container .swiper-wrapper .swiper-slide.swiper-slide-active .image, body main.page.page-shop section.content-section .inner-footer .swiper-container .swiper-wrapper .swiper-slide.swiper-slide-duplicate-active .image, body main.page.page-shop section.content-section .inner-footer .swiper-container .swiper-wrapper .swiper-slide.swiper-slide-prev .image {
    animation: zoomOut 10s linear 0s 1 normal both;
  }
  body main.page.page-shop section.content-section .inner-footer .swiper-container .swiper-pagination {
    bottom: 0px;
    left: 0;
    right: 0;
    margin: auto !important;
    text-align: center;
  }
}
body main.page.page-shop section.content-section .note.right {
  text-align: right;
}
body main.page.page-shop section.link-section {
  background-color: #F2F1EF;
}
body main.page.page-shop section.link-section .inner .link-area {
  overflow: hidden;
}
body main.page.page-shop section.link-section .inner .link-area .item + .item {
  margin-top: 52px;
}
body main.page.page-shop section.link-section .inner .link-area .item h3.ttl {
  margin-bottom: 20px;
}
body main.page.page-shop section.link-section .inner .link-area .item .group {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: nowrap;
}
body main.page.page-shop section.link-section .inner .link-area .item .group p {
  font-size: 13px;
  letter-spacing: 0.1em;
  line-height: 1.9;
  margin-right: 10%;
  width: 24%;
}
body main.page.page-shop section.link-section .inner .link-area .item .group p:nth-of-type(n + 3) {
  margin-right: 0;
}
body main.page.page-shop section.link-section .inner .link-area .item .group + .group {
  margin-top: 28px;
}
body main.page.page-shop section.link-section .inner .link-area .modal-item {
  transition: all 1.2s;
  visibility: hidden;
  opacity: 0;
  height: 0;
}
body main.page.page-shop section.link-section .inner .link-area .modal-item .item {
  visibility: hidden;
  opacity: 0;
  height: 0;
}
body main.page.page-shop section.link-section .inner .link-area.open .modal-item {
  visibility: visible;
  opacity: 1;
  height: 100%;
  margin-top: 52px;
}
body main.page.page-shop section.link-section .inner .link-area.open .modal-item .item {
  visibility: visible;
  opacity: 1;
  height: 100%;
}
body main.page.page-shop section.link-section .inner .link-area.open + .ani-nav {
  opacity: 0;
}
body main.page.page-shop section.link-section .inner .ani-nav {
  cursor: pointer;
  font-weight: bold;
  font-size: 13px;
  letter-spacing: 0.01em;
  position: relative;
  padding-right: 22px;
  display: inline-block;
  margin-top: 90px;
  opacity: 1;
}
body main.page.page-shop section.link-section .inner .ani-nav .icn {
  position: absolute;
  width: 12px;
  height: 12px;
  right: 0;
  bottom: 0;
  top: 0;
  margin: auto;
}
body main.page.page-shop section.link-section .inner .ani-nav .icn:before, body main.page.page-shop section.link-section .inner .ani-nav .icn:after {
  content: "";
  height: 13px;
  width: 2px;
  background-color: #000;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
}
body main.page.page-shop section.link-section .inner .ani-nav .icn:after {
  transform: rotate(-90deg);
}
@media screen and (max-width: 850px) {
  body main.page.page-shop section.link-section .inner .link-area {
    overflow: hidden;
  }
  body main.page.page-shop section.link-section .inner .link-area .item + .item {
    margin-top: 32px;
  }
  body main.page.page-shop section.link-section .inner .link-area .item h3.ttl {
    margin-bottom: 8px;
  }
  body main.page.page-shop section.link-section .inner .link-area .item .group {
    display: block;
  }
  body main.page.page-shop section.link-section .inner .link-area .item .group p {
    font-size: 13px;
    letter-spacing: 0.1em;
    line-height: 1.9;
    margin-right: 0%;
    width: 100%;
  }
  body main.page.page-shop section.link-section .inner .link-area .item .group p:nth-of-type(n + 3) {
    margin-right: 0;
  }
  body main.page.page-shop section.link-section .inner .link-area .item .group p + p {
    margin-top: 18px;
  }
  body main.page.page-shop section.link-section .inner .link-area .item .group + .group {
    margin-top: 18px;
  }
  body main.page.page-shop section.link-section .inner .link-area.open .modal-item {
    margin-top: 32px;
  }
  body main.page.page-shop section.link-section .inner .link-area.open + .ani-nav {
    opacity: 0;
  }
  body main.page.page-shop section.link-section .inner .ani-nav {
    margin-top: 50px;
  }
}

body main.page.single img {
  max-width: 100%;
}
body main.page.single section.footerNav-section {
  padding-top: 0;
}
body main.page.single section.footerNav-section .inner .item-area {
  display: table;
  width: 100%;
  position: relative;
}
body main.page.single section.footerNav-section .inner .item-area:before {
  content: "";
  height: 100%;
  width: 1px;
  background-color: #707070;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}
body main.page.single section.footerNav-section .inner .item-area .page-nav {
  display: table-cell;
  width: 50%;
}
body main.page.single section.footerNav-section .inner .item-area .page-nav a {
  display: block;
}
body main.page.single section.footerNav-section .inner .item-area .page-nav a .txt {
  display: block;
  line-height: 40px;
  font-weight: bold;
  font-size: 15px;
  letter-spacing: 0.15em;
}
body main.page.single section.footerNav-section .inner .item-area .page-nav a .txt .icn {
  width: 40px;
  display: inline-block;
}
body main.page.single section.footerNav-section .inner .item-area .page-nav a .txt span {
  display: inline-block;
  position: relative;
  top: 2px;
}
body main.page.single section.footerNav-section .inner .item-area .page-nav a .content {
  display: block;
  margin-top: 38px;
}
body main.page.single section.footerNav-section .inner .item-area .page-nav a .content .text {
  font-size: 16px;
  letter-spacing: 0.15em;
  line-height: 2;
  text-align: justify;
  display: block;
}
@media screen and (max-width: 850px) {
  body main.page.single section.footerNav-section .inner .item-area .page-nav a .content {
    display: none;
  }
}
body main.page.single section.footerNav-section .inner .item-area .page-nav.prev {
  text-align: left;
  padding-right: 5.5%;
}
body main.page.single section.footerNav-section .inner .item-area .page-nav.prev a .txt {
  text-align: left;
}
body main.page.single section.footerNav-section .inner .item-area .page-nav.prev a .txt span {
  margin-left: 20px;
}
body main.page.single section.footerNav-section .inner .item-area .page-nav.next {
  text-align: right;
  padding-left: 5.5%;
}
body main.page.single section.footerNav-section .inner .item-area .page-nav.next a .txt {
  text-align: right;
}
body main.page.single section.footerNav-section .inner .item-area .page-nav.next a .txt span {
  margin-right: 20px;
}
body main.page.single.single-news section.page-header {
  padding-bottom: 40px;
}
body main.page.single.single-news section.page-header .ttl {
  text-align: left;
  margin-bottom: 35px;
  letter-spacing: 0;
}
body main.page.single.single-news section.page-header .info-data {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: nowrap;
}
body main.page.single.single-news section.page-header .info-data .date,
body main.page.single.single-news section.page-header .info-data .cate {
  font-size: 12px;
  letter-spacing: 0.1em;
  line-height: 1.2;
}
body main.page.single.single-news section.page-header .info-data .date {
  font-weight: 600;
  border-right: 1px solid #707070;
  margin-right: 18px;
  padding-right: 20px;
}
body main.page.single.single-news section.page-header .info-data .cate {
  font-size: 12px;
  font-weight: bold;
}
body main.page.single.single-news section.pict-section {
  padding-top: 0;
  padding-bottom: 0;
}
body main.page.single.single-news section.content-section {
  padding-top: 0px;
}
body main.page.single.single-news section.content-section img {
  max-width: 100%;
}
body main.page.single.single-news section.content-section .inner h3 {
  margin-bottom: 25px;
}
body main.page.single.single-news section.content-section .inner p {
  margin-bottom: 15px;
}
body main.page.single.single-news section.content-section .inner .btn-area {
  margin-top: 75px;
}
body main.page.single.single-news section.content-section .inner .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
body main.page.single.single-works section.page-header p.txt {
  font-size: 13px;
  letter-spacing: 0.1em;
  margin-top: 0;
  margin-bottom: 20px;
}
body main.page.single.single-works section.page-header p.txt span.mark + .mark:before {
  content: " , ";
}
@media screen and (max-width: 850px) {
  body main.page.single.single-works section.page-header .ttl {
    text-align: left;
    margin-bottom: 0;
  }
}
body main.page.single.single-works section.conetnt-section {
  padding-top: 0;
}
body main.page.single.single-works section.conetnt-section .inner .content-area img {
  max-width: 100%;
}
body main.page.single.single-works section.conetnt-section .inner .content-area figure {
  margin-bottom: 60px;
}
body main.page.single.single-works section.conetnt-section .inner .content-area p {
  margin-bottom: 50px;
}
body main.page.single.single-works section.conetnt-section .inner .content-area figcaption {
  margin-top: 10px;
}
body main.page.single.single-works section.conetnt-section .inner .content-area .wp-block-group {
  margin-bottom: 100px;
}
body main.page.single.single-works section.conetnt-section .inner .content-area h1 {
  margin-bottom: 75px;
}
body main.page.single.single-works section.conetnt-section .inner .content-area h2, body main.page.single.single-works section.conetnt-section .inner .content-area h3, body main.page.single.single-works section.conetnt-section .inner .content-area h4 {
  margin-bottom: 25px;
}
body main.page.single.single-works section.conetnt-section .inner .content-area .wp-block-columns {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
  margin-bottom: 0;
}
body main.page.single.single-works section.conetnt-section .inner .content-area .wp-block-columns .wp-block-column {
  max-width: 512px;
}
@media screen and (max-width: 850px) {
  body main.page.single.single-works section.conetnt-section .inner .content-area figure {
    margin-bottom: 0px;
    width: calc(100% + 46px);
    margin-left: -23px;
    margin-right: -23px;
  }
  body main.page.single.single-works section.conetnt-section .inner .content-area figure + figure {
    margin-top: 30px;
  }
  body main.page.single.single-works section.conetnt-section .inner .content-area p {
    margin-top: 40px;
    margin-bottom: 40px;
  }
  body main.page.single.single-works section.conetnt-section .inner .content-area .wp-block-group {
    margin-bottom: 0px;
  }
  body main.page.single.single-works section.conetnt-section .inner .content-area h1 {
    margin-bottom: 40px;
  }
}
body main.page.single.single-works section.conetnt-section .inner .credit-area {
  margin-top: 80px;
}
body main.page.single.single-works section.conetnt-section .inner .credit-area h2 {
  margin-bottom: 28px;
  padding-bottom: 10px;
  text-align: left;
  border-bottom: 1px solid #CBCBCB;
}
body main.page.single.single-works section.conetnt-section .inner .credit-area .txt {
  font-size: 13px;
  letter-spacing: 0.1em;
  line-height: 1.8;
}
body main.page.single.single-works section.conetnt-section .inner .btn-area {
  margin-top: 100px;
}
body main.page.single.single-works section.conetnt-section .inner .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 850px) {
  body main.page.single.single-works section.conetnt-section .inner .btn-area {
    margin-top: 60px;
  }
}
body main.page.single.single-works section.item-section {
  background-color: #F2F1EF;
}
body main.page.single.single-works section.item-section .inner .ttl {
  margin-bottom: 80px;
  text-align: center;
}
body main.page.single.single-works section.item-section .inner .ttl .line {
  display: inline-block;
  position: relative;
  padding-bottom: 5px;
}
body main.page.single.single-works section.item-section .inner .ttl .line:after {
  content: "";
  height: 1px;
  width: 94px;
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
  margin: 0 auto;
  background-color: #707070;
}
@media screen and (max-width: 850px) {
  body main.page.single.single-works section.item-section .inner .ttl {
    margin-bottom: 75px;
  }
}
body main.page.single.single-works section.item-section .inner .item-area {
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: wrap;
  margin-left: -2.5%;
  margin-right: -2.5%;
}
body main.page.single.single-works section.item-section .inner .item-area .item {
  display: block;
  width: 28.3333333333%;
  margin-left: 2.5%;
  margin-right: 2.5%;
}
body main.page.single.single-works section.item-section .inner .item-area .item:nth-of-type(n + 4) {
  margin-top: 60px;
}
body main.page.single.single-works section.item-section .inner .item-area .item .pict {
  display: block;
  overflow: hidden;
  width: 100%;
}
body main.page.single.single-works section.item-section .inner .item-area .item .pict img {
  -o-object-position: center;
     object-position: center;
  -o-object-fit: cover;
  object-fit: cover;
  height: auto;
  width: 100%;
}
body main.page.single.single-works section.item-section .inner .item-area .item .text {
  display: block;
  padding: 8px 26px;
  margin-top: 40px;
  border-left: 1px solid #707070;
}
body main.page.single.single-works section.item-section .inner .item-area .item .text .cate {
  font-size: 13px;
  letter-spacing: 0.08em;
  font-weight: bold;
  display: block;
  line-height: 1.8;
  margin-bottom: 10px;
}
body main.page.single.single-works section.item-section .inner .item-area .item .text .name-en {
  font-size: 16px;
  letter-spacing: 0.15em;
  font-weight: bold;
  display: block;
  line-height: 1.8;
  margin-bottom: 0px;
}
body main.page.single.single-works section.item-section .inner .item-area .item .text .name-jp {
  font-size: 12px;
  letter-spacing: 0em;
  display: block;
  line-height: 1.8;
}
@media screen and (max-width: 850px) {
  body main.page.single.single-works section.item-section .inner .item-area {
    margin-left: 0;
    margin-right: 0;
  }
  body main.page.single.single-works section.item-section .inner .item-area .item {
    display: block;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
  body main.page.single.single-works section.item-section .inner .item-area .item:nth-of-type(n + 4) {
    margin-top: 0px;
  }
  body main.page.single.single-works section.item-section .inner .item-area .item:nth-of-type(n + 2) {
    margin-top: 40px;
  }
  body main.page.single.single-works section.item-section .inner .item-area .item .text {
    display: block;
    padding: 0px 15px;
    margin-top: 20px;
  }
  body main.page.single.single-works section.item-section .inner .item-area .item .text .cate {
    font-size: 14px;
    margin-bottom: 4px;
  }
  body main.page.single.single-works section.item-section .inner .item-area .item .text .name-en {
    font-size: 16px;
    margin-bottom: 0px;
  }
  body main.page.single.single-works section.item-section .inner .item-area .item .text .name-jp {
    font-size: 13px;
  }
}
body main.page.single.single-works section.footerNav-section {
  padding-top: 160px;
}
body main.page.single.single-works section.footerNav-section .inner .item-area:before {
  display: none;
}
body main.page.single.single-works section.footerNav-section .inner .item-area .page-nav.prev {
  padding-right: 6%;
}
body main.page.single.single-works section.footerNav-section .inner .item-area .page-nav.left {
  padding-left: 6%;
}
body main.page.single.single-works section.footerNav-section .inner .item-area .page-nav a .content {
  margin-top: 50px;
}
body main.page.single.single-works section.footerNav-section .inner .item-area .page-nav a .content .pict {
  display: block;
  height: 254px;
  width: 100%;
  margin-bottom: 28px;
}
body main.page.single.single-works section.footerNav-section .inner .item-area .page-nav a .content .pict img {
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 850px) {
  body main.page.single.single-works section.footerNav-section .inner .item-area .page-nav a .content .pict {
    display: none;
  }
}
body main.page.single.single-works section.footerNav-section .inner .item-area .page-nav a .content .txt {
  text-align: center;
  font-size: 12px;
  letter-spacing: 0.1em;
  font-weight: normal;
  line-height: 1.6;
  margin-bottom: 8px;
}
body main.page.single.single-works section.footerNav-section .inner .item-area .page-nav a .content .txt span {
  margin: 0;
}
body main.page.single.single-works section.footerNav-section .inner .item-area .page-nav a .content .txt span.mark {
  display: inline-block;
}
body main.page.single.single-works section.footerNav-section .inner .item-area .page-nav a .content .txt span.mark + .mark:before {
  content: " , ";
}
body main.page.single.single-works section.footerNav-section .inner .item-area .page-nav a .content .text {
  text-align: center;
}
@media screen and (max-width: 850px) {
  body main.page.single.single-works section.footerNav-section {
    padding-top: 13px;
    padding-bottom: 13px;
  }
  body main.page.single.single-works section.footerNav-section .inner .item-area:before {
    display: block;
  }
}
body main.page.single.single-discovery section.page-header {
  padding-bottom: 40px;
}
body main.page.single.single-discovery section.page-header .ttl {
  text-align: left;
  margin-bottom: 35px;
  letter-spacing: 0;
}
body main.page.single.single-discovery section.page-header .info-data {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: nowrap;
}
body main.page.single.single-discovery section.page-header .info-data .date,
body main.page.single.single-discovery section.page-header .info-data .cate {
  font-size: 12px;
  letter-spacing: 0.1em;
  line-height: 1.2;
}
body main.page.single.single-discovery section.page-header .info-data .date {
  font-weight: 600;
  margin-right: 18px;
  padding-right: 20px;
}
body main.page.single.single-discovery section.page-header .info-data .cate {
  font-size: 12px;
  font-weight: bold;
}
body main.page.single.single-discovery section.pict-section {
  padding-top: 0;
  padding-bottom: 0;
}
body main.page.single.single-discovery section.content-section {
  padding-top: 0px;
}
body main.page.single.single-discovery section.content-section img {
  max-width: 100%;
}
body main.page.single.single-discovery section.content-section .inner h3 {
  margin-bottom: 25px;
}
body main.page.single.single-discovery section.content-section .inner p {
  margin-bottom: 15px;
}
body main.page.single.single-discovery section.content-section .inner .wp-block-image {
  margin-top: 35px;
  margin-bottom: 35px;
}
@media screen and (max-width: 850px) {
  body main.page.single.single-discovery section.content-section .inner .wp-block-image .alignleft {
    margin-left: 0;
    margin-right: 0;
  }
  body main.page.single.single-discovery section.content-section .inner .wp-block-image .alignright {
    margin-left: 0;
    margin-right: 0;
  }
}
body main.page.single.single-discovery section.content-section .inner figure figcaption {
  font-size: 12px;
  line-height: 1.9;
  text-align: justify;
  letter-spacing: 0.06em;
  margin-top: 20px;
}
body main.page.single.single-discovery section.content-section .inner .underline {
  text-decoration: underline;
}
body main.page.single.single-discovery section.content-section .inner .btn-area {
  margin-top: 75px;
}
body main.page.single.single-discovery section.content-section .inner .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
body main.page.single.single-discovery section.footerNav-section .inner .item-area:before {
  display: none;
}
body main.page.single.single-discovery section.footerNav-section .inner .item-area .page-nav.prev {
  padding-right: 6%;
}
body main.page.single.single-discovery section.footerNav-section .inner .item-area .page-nav.left {
  padding-left: 6%;
}
body main.page.single.single-discovery section.footerNav-section .inner .item-area .page-nav a .content {
  margin-top: 50px;
}
body main.page.single.single-discovery section.footerNav-section .inner .item-area .page-nav a .content .pict {
  display: block;
  height: 254px;
  width: 100%;
  margin-bottom: 28px;
}
body main.page.single.single-discovery section.footerNav-section .inner .item-area .page-nav a .content .pict img {
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 850px) {
  body main.page.single.single-discovery section.footerNav-section .inner .item-area .page-nav a .content .pict {
    display: none;
  }
}
body main.page.single.single-discovery section.footerNav-section .inner .item-area .page-nav a .content .date {
  display: block;
  font-size: 13px;
  letter-spacing: 0.08em;
  display: block;
  line-height: 1.8;
  margin-bottom: 6px;
}
body main.page.single.single-discovery section.footerNav-section .inner .item-area .page-nav a .content .text {
  text-align: center;
}
@media screen and (max-width: 850px) {
  body main.page.single.single-discovery section.footerNav-section .inner .item-area:before {
    display: block;
  }
}

body main.page.contact section.page-header {
  padding-bottom: 60px;
}
body main.page.contact section.page-header h1 + .txt .btn06 {
  margin: 20px auto 25px;
}
body main.page.contact section.page-header .cap-area {
  border: 1px solid #000000;
  padding: 42px 40px;
  margin-top: 55px;
}
body main.page.contact section.page-header .cap-area .ttl {
  margin-bottom: 5px;
  text-align: left;
}
body main.page.contact section.page-header .cap-area .txt {
  font-size: 14px;
  text-align: justify;
  margin: 0;
}
body main.page.contact section.page-header .cap-area .inner-footer {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
  margin-top: 25px;
}
body main.page.contact section.page-header .cap-area .inner-footer .link {
  max-width: 360px;
  display: block;
  margin-right: 4%;
  width: 100%;
}
body main.page.contact section.page-header .cap-area .inner-footer .link img {
  width: 100%;
}
body main.page.contact section.page-header .cap-area .inner-footer .txt {
  display: block;
  font-size: 15px;
  letter-spacing: 0.05em;
  font-weight: bold;
  margin-top: 20px;
  line-height: 1.7;
}
@media screen and (max-width: 850px) {
  body main.page.contact section.page-header .cap-area .inner-footer {
    display: block;
  }
  body main.page.contact section.page-header .cap-area .inner-footer .link {
    max-width: 248px;
    display: block;
    margin-right: 0;
  }
  body main.page.contact section.page-header .cap-area .inner-footer .link img {
    width: 100%;
  }
  body main.page.contact section.page-header .cap-area .inner-footer .txt {
    letter-spacing: 0em;
    font-weight: bold;
    margin-top: 12px;
    font-size: 14px;
  }
}
@media screen and (max-width: 850px) {
  body main.page.contact section.page-header .cap-area {
    padding: 30px 20px;
  }
}
body main.page.contact section.page-header .btn-area {
  margin-top: 60px;
  display: flex;
  justify-content: center;
  align-items: stretch;
  flex-wrap: wrap;
}
body main.page.contact section.page-header .btn-area .btn {
  width: calc(100% - 22px);
}
body main.page.contact section.page-header .btn-area .btn:nth-of-type(n + 2) {
  margin-left: 33px;
}
@media screen and (max-width: 850px) {
  body main.page.contact section.page-header .btn-area .btn {
    width: 100%;
  }
  body main.page.contact section.page-header .btn-area .btn:nth-of-type(n + 2) {
    margin-left: 0px;
    margin-top: 20px;
  }
}
body main.page.contact section.page-header .btn-area02 {
  margin-top: 60px;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
}
body main.page.contact section.page-header .btn-area02 .btn {
  width: calc(100% - 33px);
}
@media screen and (max-width: 850px) {
  body main.page.contact section.page-header .btn-area02 .btn {
    width: 100%;
  }
  body main.page.contact section.page-header .btn-area02 .btn:nth-of-type(n + 2) {
    margin-left: 0px;
    margin-top: 20px;
  }
}
body main.page.contact section.content-section {
  padding-bottom: 90px;
}
@media screen and (max-width: 850px) {
  body main.page.contact section.content-section {
    padding-bottom: 85px;
  }
}
body main.page.contact section.content-section .wpcf7 .status-area .pict {
  height: 60px;
  background: url(../img/page/contact/status_befo_pc.jpg) no-repeat center;
  background-size: auto 100%;
}
@media screen and (max-width: 850px) {
  body main.page.contact section.content-section .wpcf7 .status-area .pict {
    height: 60px;
    background: url(../img/page/contact/status_befo_sp.jpg) no-repeat center;
    background-size: auto 100%;
  }
}
body main.page.contact section.content-section .wpcf7 .wpcf7-response-output {
  border-color: #FF7E7E;
  text-align: center;
  padding: 40px 45px;
  font-size: 16px;
  letter-spacing: 0.12em;
  color: #FF7E7E;
}
body main.page.contact section.content-section .wpcf7 .contact-area {
  margin-top: 60px;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box {
  padding: 30px 0;
  border-top: 1px solid #707070;
  display: table;
  width: 100%;
  font-size: 14px;
  letter-spacing: 0.05em;
  line-height: 2;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box:last-of-type {
  border-bottom: 1px solid #707070;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box span.note {
  font-size: 12px;
  margin-top: 10px;
  letter-spacing: 0;
  display: block;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .wpcf7-not-valid-tip {
  color: #FF7E7E;
  letter-spacing: 0.1em;
  margin-top: 10px;
  font-weight: bold;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-text {
  display: table-cell;
  width: 254px;
  padding-right: 33px;
  vertical-align: middle;
}
@media screen and (max-width: 850px) {
  body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-text {
    display: block;
    width: 100%;
  }
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-text.vr-t {
  vertical-align: top;
  padding-top: 9px;
}
@media screen and (max-width: 850px) {
  body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-text.vr-t {
    vertical-align: middle;
    margin-top: 0;
  }
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-text.vr-t02 {
  vertical-align: top;
}
@media screen and (max-width: 850px) {
  body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-text.vr-t02 {
    vertical-align: middle;
    margin-top: 0;
  }
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-text .txt {
  font-size: 14px;
  letter-spacing: 0.06em;
  line-height: 2;
  text-align: justify;
  font-weight: 600;
  display: block;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-text .txt .requir {
  color: #FF7E7E;
  letter-spacing: 0.1em;
  display: inline-block;
  margin-left: 14px;
}
@media screen and (max-width: 850px) {
  body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-text .txt {
    font-size: 16px;
    transform: scale(0.875);
    margin-left: -20px;
  }
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-text .txt + .txt {
  margin-top: 10px;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field {
  display: table-cell;
  width: calc(100% - 254px);
  vertical-align: middle;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field.vr-t {
  vertical-align: top;
}
@media screen and (max-width: 850px) {
  body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field.vr-t {
    vertical-align: middle;
  }
}
@media screen and (max-width: 850px) {
  body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field {
    width: 100%;
    display: block;
    margin-top: 15px;
  }
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row {
  display: block;
  width: 100%;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row + .row {
  margin-top: 30px;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .name-file {
  margin-top: 5px;
  display: inline-block;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row.ani-visible, body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row.ani-visible02, body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row.ani-visible03, body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row.ani-visible03 {
  transition: all 0.4s;
  visibility: hidden;
  opacity: 0;
  height: 0;
  margin-top: 0;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row.ani-visible.open, body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row.ani-visible02.open, body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row.ani-visible03.open, body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row.ani-visible03.open {
  visibility: visible;
  opacity: 1;
  height: 100%;
  margin-top: 30px;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row select.menu-drop {
  max-width: 257px;
  width: 100%;
  padding: 10px 20px 11px;
  border: 1px solid #000;
  background: url(../img/common/arw_down.svg) no-repeat center right 20px;
  background-size: 10px;
  letter-spacing: 0;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row select.menu-drop.ver02 {
  max-width: 414px;
}
@media screen and (max-width: 850px) {
  body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row select {
    max-width: 100%;
    padding: 16px 20px 17px;
  }
  body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row select.ver02 {
    max-width: 100%;
  }
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row input.text {
  border: 1px solid #000;
  padding: 10px 20px 11px;
  max-width: 524px;
  width: 100%;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row input.text.ver02 {
  max-width: 258px;
}
@media screen and (max-width: 850px) {
  body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row input.text.ver02 {
    max-width: 300px;
  }
}
@media screen and (max-width: 850px) {
  body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row input {
    max-width: 100%;
  }
  body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row input.text {
    font-size: 16px;
    transform: scale(0.875);
    margin-left: -20px;
  }
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row textarea {
  width: 100%;
  max-width: 778px;
  min-height: 93px;
  height: 100%;
  padding: 10px 20px 11px;
  border: 1px solid #000;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row textarea.ver02 {
  min-height: 231px;
  max-height: 100%;
}
@media screen and (max-width: 850px) {
  body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row textarea {
    padding: 25px 20px;
    font-size: 16px;
    transform: scale(0.875);
    margin-left: -20px;
    width: calc(100% + 40px);
  }
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row.media-check {
  width: 100%;
  width: calc(100% + 2.6em);
  margin-left: -1.3em;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row.media-check .wpcf7-checkbox {
  display: block;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row.media-check .wpcf7-checkbox .wpcf7-list-item {
  margin: 0 0 0 1.3em;
  position: relative;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row.media-check .wpcf7-checkbox .wpcf7-list-item input[type=checkbox] {
  position: relative;
  top: -2px;
  display: inline-block;
  margin-right: 0.1em;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .radio {
  width: 100%;
  width: calc(100% + 2.6em);
  margin-left: -1.3em;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .radio .wpcf7-list-item {
  position: relative;
  margin: 0 0 0 1.3em;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .radio .wpcf7-list-item input[type=radio] {
  display: none;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .radio .wpcf7-list-item input[type=radio]:checked + .wpcf7-list-item-label:after {
  opacity: 1;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .radio .wpcf7-list-item .wpcf7-list-item-label {
  box-sizing: border-box;
  cursor: pointer;
  display: inline-block;
  padding-left: 28px;
  position: relative;
  width: auto;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .radio .wpcf7-list-item .wpcf7-list-item-label:before {
  border: 1px solid #2f271b;
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  border-radius: 50%;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .radio .wpcf7-list-item .wpcf7-list-item-label:after {
  background-color: #000;
  border-radius: 50%;
  content: "";
  display: block;
  height: 10px;
  width: 10px;
  left: 5px;
  opacity: 0;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .wpcf7-form-control-wrap .codedropz-upload-wrapper .codedropz-upload-handler {
  border: 1px solid #000;
  border-radius: 0;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .wpcf7-form-control-wrap .codedropz-upload-wrapper .codedropz-upload-handler .dnd-upload-counter {
  display: none;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .wpcf7-form-control-wrap .codedropz-upload-wrapper .codedropz-upload-handler .codedropz-upload-container {
  padding: 0;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .wpcf7-form-control-wrap .codedropz-upload-wrapper .codedropz-upload-handler .codedropz-upload-container .codedropz-upload-inner span:nth-of-type(1), body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .wpcf7-form-control-wrap .codedropz-upload-wrapper .codedropz-upload-handler .codedropz-upload-container .codedropz-upload-inner span:nth-of-type(2) {
  display: none;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .wpcf7-form-control-wrap .codedropz-upload-wrapper .codedropz-upload-handler .codedropz-upload-container .codedropz-upload-inner .codedropz-btn-wrap {
  text-align: left;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .wpcf7-form-control-wrap .codedropz-upload-wrapper .codedropz-upload-handler .codedropz-upload-container .codedropz-upload-inner .codedropz-btn-wrap .cd-upload-btn {
  text-align: left;
  text-decoration: underline;
  display: block;
  width: 100%;
  height: 100%;
  padding: 10px 20px 11px;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .wpcf7-form-control-wrap .codedropz-upload-wrapper .dnd-upload-status .dnd-upload-image {
  border-radius: 0;
  top: 6px;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .wpcf7-form-control-wrap .codedropz-upload-wrapper .dnd-upload-status .dnd-upload-details .name {
  color: #000;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .wpcf7-form-control-wrap .codedropz-upload-wrapper .dnd-upload-status .dnd-upload-details .dnd-progress-bar {
  background-color: #F2F1EF;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .wpcf7-form-control-wrap .codedropz-upload-wrapper .dnd-upload-status .dnd-upload-details .dnd-progress-bar span {
  background-color: #525252;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .wpcf7-form-control-wrap .codedropz-upload-wrapper .span.has-error-msg {
  color: #FF7E7E;
}
body main.page.contact section.content-section .wpcf7 .contact-area .item-box .input-field .row .sub {
  font-size: 14px;
  letter-spacing: 0.05em;
  display: block;
  margin-bottom: 6px;
}
body main.page.contact section.content-section .wpcf7 .contact-area .conf-area {
  margin-top: 50px;
  padding: 40px 45px;
  background-color: #F2F1EF;
}
body main.page.contact section.content-section .wpcf7 .contact-area .conf-area p {
  text-align: left;
}
body main.page.contact section.content-section .wpcf7 .contact-area .conf-area .switch {
  margin-top: 25px;
}
body main.page.contact section.content-section .wpcf7 .contact-area .conf-area .switch .wpcf7-recaptcha {
  display: inline-block;
}
@media screen and (max-width: 850px) {
  body main.page.contact section.content-section .wpcf7 .contact-area .conf-area .switch .g-recaptcha {
    transform-origin: 0% 0%;
    transform: scale(0.85);
  }
}
@media screen and (max-width: 850px) {
  body main.page.contact section.content-section .wpcf7 .contact-area .conf-area {
    padding: 25px 20px;
  }
}
body main.page.contact section.content-section .wpcf7 .btn-area {
  margin-top: 90px;
}
body main.page.contact section.content-section .wpcf7 .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 850px) {
  body main.page.contact section.content-section .wpcf7 .btn-area {
    margin-top: 87px;
  }
}
body main.page.contact section.content-section .digi-area {
  margin-top: 30px;
}
body main.page.contact section.tel-section {
  padding-top: 90px;
  padding-bottom: 90px;
}
@media screen and (max-width: 850px) {
  body main.page.contact section.tel-section {
    padding-top: 80px;
  }
}
body main.page.contact section.tel-section .inner h2 {
  margin-bottom: 25px;
  text-align: center;
}
body main.page.contact section.tel-section .inner .txt {
  text-align: center;
  margin-bottom: 52px;
}
@media screen and (max-width: 850px) {
  body main.page.contact section.tel-section .inner .txt {
    text-align: justify;
    margin-bottom: 55px;
  }
}
body main.page.contact section.tel-section .inner .tel-area {
  background-color: #fff;
  max-width: 740px;
  margin-left: auto;
  margin-right: auto;
  display: block;
  padding: 35px;
  text-align: center;
}
body main.page.contact section.tel-section .inner .tel-area .outer {
  text-align: center;
  display: inline-block;
  margin-left: auto;
  margin-right: auto;
}
body main.page.contact section.tel-section .inner .tel-area .outer .shop {
  font-size: 16px;
  letter-spacing: 0.15em;
  display: block;
  line-height: 2;
}
body main.page.contact section.tel-section .inner .tel-area .outer .shop + .shop {
  margin-top: 12px;
}
@media screen and (max-width: 850px) {
  body main.page.contact section.tel-section .inner .tel-area {
    padding: 40px 25px;
  }
  body main.page.contact section.tel-section .inner .tel-area .outer {
    padding-left: 9px;
  }
  body main.page.contact section.tel-section .inner .tel-area .outer .shop {
    line-height: 2;
  }
  body main.page.contact section.tel-section .inner .tel-area .outer .shop + .shop {
    margin-top: 15px;
  }
  body main.page.contact section.tel-section .inner .tel-area .outer .shop a {
    position: relative;
    left: -10px;
  }
}
@media screen and (max-width: 850px) {
  body main.page.contact.thanks section.content-section {
    padding-bottom: 60px;
  }
}
body main.page.contact.thanks section.content-section .inner .status-area .pict {
  height: 60px;
  background: url(../img/page/contact/status_aft_pc.jpg) no-repeat center;
  background-size: auto 100%;
}
@media screen and (max-width: 850px) {
  body main.page.contact.thanks section.content-section .inner .status-area .pict {
    height: 60px;
    background: url(../img/page/contact/status_aft_sp.jpg) no-repeat center;
    background-size: auto 100%;
  }
}
body main.page.contact.thanks section.content-section .inner .lead {
  font-size: 16px;
  text-align: center;
  letter-spacing: 0.05em;
  line-height: 2;
}
@media screen and (max-width: 850px) {
  body main.page.contact.thanks section.content-section .inner .lead {
    letter-spacing: 0.05em;
    text-align: justify;
  }
}
body main.page.contact.thanks section.tel-section {
  padding-top: 27px;
  padding-bottom: 26px;
}
@media screen and (max-width: 850px) {
  body main.page.contact.thanks section.tel-section {
    padding-top: 27px;
    padding-bottom: 29px;
  }
}
@media screen and (max-width: 850px) {
  body main.page.contact.thanks section.tel-section .inner .tel-area {
    padding: 32px 25px 46px;
  }
}
body main.page.contact.thanks section.btn-section {
  padding-top: 0;
}
body main.page.contact.thanks section.btn-section .inner .btn-area {
  margin-top: 80px;
}
body main.page.contact.thanks section.btn-section .inner .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 850px) {
  body main.page.contact.thanks section.btn-section .inner .btn-area {
    margin-top: 90px;
  }
  body main.page.contact.thanks section.btn-section .inner .btn-area .btn {
    width: 100%;
  }
}

body main.page.page02 section.content-section .inner .text-area h2 {
  margin-bottom: 40px;
}
body main.page.page02 section.content-section .inner .text-area .item + .item {
  margin-top: 60px;
}
body main.page.page02 section.content-section .inner .text-area .item h4 {
  margin-bottom: 10px;
}
body main.page.page02 section.content-section .inner .text-area .item .txt {
  text-align: justify;
}
body main.page.page02 section.content-section .inner .text-area .item .txt b {
  display: block;
}
body main.page.page02 section.content-section .inner .text-area .item .txt .min-txt {
  display: table;
  padding-left: 26px;
}
body main.page.page02 section.content-section .inner .text-area .item .txt .min-txt + b {
  margin-top: 10px;
}
body main.page.page02 section.content-section .inner .text-area .item .txt .min-txt.ver02 {
  padding-left: 0;
}
body main.page.page02 section.content-section .inner .text-area .item .txt .min-txt .box {
  display: table-cell;
}
body main.page.page02 section.content-section .inner .text-area .item .txt .min-txt .box:first-of-type {
  width: 1.8em;
}
@media screen and (max-width: 850px) {
  body main.page.page02 section.content-section .inner .text-area .item .txt .min-txt {
    padding-left: 0;
  }
}
body main.page.page02 section.content-section .inner .text-area .item .txt + .txt {
  margin-top: 20px;
}
body main.page.page02 section.content-section .inner .text-area .item .txt + .note {
  margin-top: 10px;
}
@media screen and (max-width: 850px) {
  body main.page.page02 section.content-section .inner .text-area {
    margin-bottom: 30px;
  }
  body main.page.page02 section.content-section .inner .text-area h2 {
    margin-bottom: 30px;
  }
  body main.page.page02 section.content-section .inner .text-area .item + .item {
    margin-top: 25px;
  }
  body main.page.page02 section.content-section .inner .text-area .item h4 {
    font-size: 16px;
    margin-bottom: 10px;
  }
  body main.page.page02 section.content-section .inner .text-area .item .txt {
    font-size: 13px;
  }
  body main.page.page02 section.content-section .inner .text-area .item .txt + .txt {
    margin-top: 15px;
  }
  body main.page.page02 section.content-section .inner .text-area .item .txt .min-txt {
    line-height: 1.8;
  }
  body main.page.page02 section.content-section .inner .text-area .item .txt .min-txt + b {
    margin-top: 15px;
  }
  body main.page.page02 section.content-section .inner .text-area .item .txt b {
    margin-bottom: 5px;
  }
}
body main.page.page02 section.content-section .inner .inner-footer {
  margin-top: 80px;
  text-align: right;
}
body main.page.page02 section.content-section .inner .inner-footer p {
  text-align: right;
  line-height: 1.8;
  margin-bottom: 12px;
}
body main.page.page02 section.content-section .inner .inner-footer h4 {
  margin: 0;
  text-align: right;
  margin-bottom: 2px;
  font-size: 13px;
  font-weight: normal;
}
body main.page.page02 section.content-section .inner .inner-footer h3 {
  margin: 0;
  text-align: right;
  font-size: 14px;
  font-weight: normal;
}
@media screen and (max-width: 850px) {
  body main.page.page02 section.content-section .inner .inner-footer {
    margin-top: 60px;
  }
}

body main.page.page-company section h2.ttl {
  text-align: center;
}
body main.page.page-company section h2.ttl .line {
  display: inline-block;
  position: relative;
  padding-bottom: 5px;
}
body main.page.page-company section h2.ttl .line:after {
  content: "";
  height: 1px;
  width: calc(100% - 14px);
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
  margin: 0 auto;
  background-color: #707070;
}
body main.page.page-company section h2.ttl.ver02:before {
  display: none;
}
@media screen and (max-width: 850px) {
  body main.page.page-company section h2.ttl {
    margin-bottom: 70px;
  }
}
body main.page.page-company section.content-section {
  padding-top: 0;
}
body main.page.page-company section.content-section + .content-section {
  padding-bottom: 0;
}
body main.page.page-company section.content-section .inner .ttl-area {
  margin-bottom: 0px;
}
body main.page.page-company section.content-section .map-area .ttl {
  text-align: center;
}
body main.page.page-company section.content-section .map-area + .map-area {
  margin-top: 140px;
}
@media screen and (max-width: 850px) {
  body main.page.page-company section.content-section .map-area .ttl {
    text-align: center;
    margin-bottom: 35px;
  }
  body main.page.page-company section.content-section .map-area + .map-area {
    margin-top: 80px;
  }
}

body main.page.page-support section.page-header-zero {
  padding-top: 0;
}
body main.page.page-support section.item-section .inner .item-area {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
  width: 100%;
  margin-top: -60px;
}
body main.page.page-support section.item-section .inner .item-area .item {
  max-width: 328px;
  width: calc(33.3333333333% - 24px);
  display: block;
  margin-top: 60px;
}
body main.page.page-support section.item-section .inner .item-area .item .txt {
  display: block;
  font-size: 16px;
  letter-spacing: 0.22em;
  margin-top: 25px;
  padding: 0px 26px;
  margin-top: 40px;
  border-left: 1px solid #707070;
}
@media screen and (max-width: 850px) {
  body main.page.page-support section.item-section .inner .item-area {
    display: block;
    width: calc(100% + 46px);
    margin-left: -23px;
    margin-right: -23px;
    margin-top: 30px;
  }
  body main.page.page-support section.item-section .inner .item-area .item {
    max-width: none;
    margin-top: 0px;
    margin-left: 0px;
    margin-right: 0px;
    width: 100%;
  }
  body main.page.page-support section.item-section .inner .item-area .item + .item {
    margin-top: 35px;
  }
  body main.page.page-support section.item-section .inner .item-area .item .txt {
    margin-top: 20px;
  }
}
body main.page.page-support section.video-section {
  padding-top: 0;
  padding-bottom: 80px;
  margin-top: 0;
  position: relative;
}
body main.page.page-support section.video-section .video-section-inner {
  position: relative;
}
body main.page.page-support section.video-section .video-section-inner > .inner {
  position: relative;
}
body main.page.page-support section.video-section .video-section-inner .ttl-area {
  position: absolute;
  right: 0;
  left: 0;
  bottom: 60px;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  z-index: 1;
  padding-left: 23px;
  padding-right: 23px;
  color: #FFF;
}
body main.page.page-support section.video-section .video-section-inner .ttl-area h2 {
  font-size: 35px;
  line-height: 1.4;
  letter-spacing: 0.2em;
}
body main.page.page-support section.video-section > .inner .ttl-area {
  text-align: right;
  width: 100%;
  z-index: 1;
}
body main.page.page-support section.video-section > .inner .ttl-area a {
  font-size: 14px;
  letter-spacing: 0.2em;
  line-height: 2;
  color: #000;
  text-align: right !important;
  font-weight: normal !important;
  display: block;
  padding: 10px;
  font-family: 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", HGS明朝E, メイリオ, Meiryo, serif;
}
body main.page.page-support section.video-section .bg-movie {
  text-align: center;
  font-size: 0;
  overflow: hidden;
}
body main.page.page-support section.video-section .bg-movie .bg-movie-box {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 850px) {
  body main.page.page-support section.video-section {
    padding-top: 0;
    padding-bottom: 0;
  }
  body main.page.page-support section.video-section .video-section-inner .ttl-area h2 {
    text-align: center;
  }
  body main.page.page-support section.video-section .bg-movie {
    height: 60vh;
  }
}
body main.page.page-support section.info-section {
  position: relative;
  padding-top: 0;
}
body main.page.page-support section.info-section .inner h2.ttl {
  text-align: center;
}
body main.page.page-support section.info-section .inner h2.ttl.ver02:before {
  display: none;
}
@media screen and (max-width: 850px) {
  body main.page.page-support section.info-section .inner h2.ttl {
    margin-bottom: 70px;
  }
}
body main.page.page-support section.info-section .inner .txt.lead {
  text-align: center;
  margin-bottom: 55px;
  font-size: 14px;
  letter-spacing: 0.2em;
  line-height: 2;
}
@media screen and (max-width: 850px) {
  body main.page.page-support section.info-section .inner .txt.lead {
    text-align: left;
    letter-spacing: 0.05em;
  }
}
body main.page.page-support section.info-section .inner .tel-area {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
}
body main.page.page-support section.info-section .inner .tel-area .btn {
  width: 49%;
  display: block;
}
body main.page.page-support section.info-section .inner .tel-area .btn.ver02 {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  padding-top: 20px;
}
@media screen and (max-width: 850px) {
  body main.page.page-support section.info-section .inner .tel-area {
    display: block;
  }
  body main.page.page-support section.info-section .inner .tel-area .btn {
    width: 100%;
  }
  body main.page.page-support section.info-section .inner .tel-area .btn + .btn {
    margin-top: 30px;
  }
}
body main.page.page-support.child section.page-header + .content-section {
  margin-top: -100px;
  padding-top: 100px;
}
body main.page.page-support.child section.content-section + .content-section {
  margin-top: -100px;
  padding-top: 100px;
}
body main.page.page-support.child section.content-section h2.ttl {
  text-align: center;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child section.content-section h2.ttl {
    margin-bottom: 40px;
  }
}
body main.page.page-support.child section.content-section .btn {
  margin-top: 70px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child section.content-section .btn {
    margin-top: 50px;
  }
}
body main.page.page-support.child section.content-section .pict-area {
  overflow: hidden;
  margin-bottom: 70px;
}
body main.page.page-support.child section.content-section .pict-area img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child section.content-section .pict-area {
    height: auto;
    margin-bottom: 50px;
  }
}
body main.page.page-support.child section.content-section .cate-area:nth-of-type(n + 2) {
  margin-top: 90px;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child section.content-section .cate-area:nth-of-type(n + 2) {
    margin-top: 55px;
  }
}
body main.page.page-support.child section.content-section .cate-area .cate-ttl {
  margin-top: -100px;
  padding-top: 100px;
}
body main.page.page-support.child section.content-section .cate-area .cate-ttl.center {
  text-align: center;
}
body main.page.page-support.child section.content-section .cate-area .cate-ttl + .txt {
  margin-bottom: 35px;
}
body main.page.page-support.child section.content-section .cate-area .sub-ttl {
  margin-bottom: 20px;
}
body main.page.page-support.child section.content-section .cate-area .sub-ttl:nth-of-type(n + 2) {
  margin-top: 60px;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child section.content-section .cate-area .sub-ttl:nth-of-type(n + 2) {
    margin-top: 45px;
  }
}
body main.page.page-support.child section.content-section .cate-area p.th {
  margin-bottom: 8px;
  font-size: 15px;
  font-weight: bold;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child section.content-section .cate-area p.th {
    font-size: 14px;
  }
}
body main.page.page-support.child section.content-section .cate-area p.th .note {
  font-weight: normal;
  margin: 0;
  font-size: 13px;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child section.content-section .cate-area p.th .note {
    font-size: 14px;
  }
}
body main.page.page-support.child section.content-section .cate-area .pict-box {
  overflow: hidden;
  margin-left: auto;
  margin-right: auto;
  margin: 40px 0;
}
body main.page.page-support.child section.content-section .cate-area .pict-box img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child section.content-section .cate-area .pict-box {
    margin: 25px 0;
  }
}
body main.page.page-support.child section.content-section .cate-area .note-box {
  background-color: #F2F1EF;
  padding: 20px 40px 24px;
  margin-top: 30px;
}
body main.page.page-support.child section.content-section .cate-area .note-box .txt {
  margin-bottom: 5px;
}
body main.page.page-support.child section.content-section .cate-area .note-box .txt b {
  font-size: 14px;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child section.content-section .cate-area .note-box {
    padding: 30px 20px;
  }
}
body main.page.page-support.child section.content-section .cate-area .table-area02 {
  margin-top: 80px;
  margin-bottom: 120px;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child section.content-section .cate-area .table-area02 {
    margin-top: 50px;
    margin-bottom: 60px;
  }
}
body main.page.page-support.child section.content-section .cate-area .kit-box {
  position: relative;
}
body main.page.page-support.child section.content-section .cate-area .kit-box-border-top:before {
  content: "";
  height: 1px;
  max-width: 1116px;
  width: 100%;
  background-color: #707070;
  display: block;
  margin: 80px 0;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child section.content-section .cate-area .kit-box-border-top:before {
    margin: 40px 0;
  }
}
body main.page.page-support.child section.content-section .cate-area .kit-box-border-bottom:after {
  content: "";
  height: 1px;
  max-width: 1116px;
  width: 100%;
  background-color: #707070;
  display: block;
  margin: 80px 0;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child section.content-section .cate-area .kit-box-border-bottom:after {
    margin: 40px 0;
  }
}
body main.page.page-support.child section.content-section .cate-area .kit-box .kit-ttl {
  margin-top: 50px;
  margin-bottom: 30px;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child section.content-section .cate-area .kit-box .kit-ttl {
    margin-bottom: 20px;
  }
}
body main.page.page-support.child section.content-section .cate-area .kit-box .flex-box {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
}
body main.page.page-support.child section.content-section .cate-area .kit-box .flex-box .pict-box {
  width: calc(100% - 490px - 50px);
  order: 1;
  margin: 0;
  margin-top: 9px;
  height: 340px;
}
body main.page.page-support.child section.content-section .cate-area .kit-box .flex-box .pict-box img {
  height: 100%;
}
body main.page.page-support.child section.content-section .cate-area .kit-box .flex-box .pict-box2 {
  width: 49%;
  margin: 0;
}
body main.page.page-support.child section.content-section .cate-area .kit-box .flex-box .text-box {
  max-width: 490px;
  width: 100%;
  order: 2;
}
body main.page.page-support.child section.content-section .cate-area .kit-box .flex-box .text-box .txt {
  margin-bottom: 0px;
  text-align: justify;
}
body main.page.page-support.child section.content-section .cate-area .kit-box .flex-box .text-box .btn {
  margin-top: 59px;
  margin-left: 0;
  margin-right: 0;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child section.content-section .cate-area .kit-box .flex-box .pict-box {
    width: 100%;
    height: auto;
  }
  body main.page.page-support.child section.content-section .cate-area .kit-box .flex-box .pict-box2 {
    width: 100%;
    height: auto;
    margin-top: 10px;
  }
  body main.page.page-support.child section.content-section .cate-area .kit-box .flex-box .pict-box2 iframe {
    width: 100%;
  }
  body main.page.page-support.child section.content-section .cate-area .kit-box .flex-box .text-box {
    width: 100%;
    margin-top: 25px;
  }
  body main.page.page-support.child section.content-section .cate-area .kit-box .flex-box .text-box .btn {
    margin: 35px auto 0;
  }
}
body main.page.page-support.child section.content-section .cate-area .pull-down-box {
  padding: 28px 20px;
  border-top: 1px solid #707070;
  border-bottom: 1px solid #707070;
  overflow: hidden;
}
body main.page.page-support.child section.content-section .cate-area .pull-down-box + .pull-down-box {
  margin-top: -1px;
}
body main.page.page-support.child section.content-section .cate-area .pull-down-box .item-ttl {
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.05em;
  line-height: 1.8;
  cursor: pointer;
}
body main.page.page-support.child section.content-section .cate-area .pull-down-box .item-ttl span {
  padding-right: 25px;
  display: block;
  background-size: 10px;
  transition: all 0.6s;
}
body main.page.page-support.child section.content-section .cate-area .pull-down-box .item-ttl span:hover {
  opacity: 0.4;
}
body main.page.page-support.child section.content-section .cate-area .pull-down-box .item-ttl.open span {
  opacity: 0.4;
  background-image: url(../img/common/arw_up.svg);
}
body main.page.page-support.child section.content-section .cate-area .pull-down-box .item-ttl.open + .item {
  height: auto;
  margin-top: 15px;
  margin-bottom: 10px;
  opacity: 1;
  visibility: visible;
}
body main.page.page-support.child section.content-section .cate-area .pull-down-box .item-ttl.open + .item .list + .list {
  margin-top: 10px;
}
body main.page.page-support.child section.content-section .cate-area .pull-down-box .item-ttl.open + .item > * {
  opacity: 1;
  visibility: visible;
}
body main.page.page-support.child section.content-section .cate-area .pull-down-box .item {
  transition: all 0.6s;
  height: 1px;
  overflow: hidden;
  box-sizing: content-box;
  background-color: #fff;
  z-index: 1;
  opacity: 0;
  visibility: hidden;
}
body main.page.page-support.child section.content-section .cate-area .pull-down-box .item > * {
  opacity: 0;
  visibility: hidden;
  transition: all 0.6s;
}
body main.page.page-support.child section.content-section .cate-area .pull-down-box .item .list + .list {
  margin-top: 0;
}
body main.page.page-support.child section.content-section .cate-area .pull-down-box .item .list li + li {
  margin-top: 0;
}
body main.page.page-support.child section.content-section .cate-area .pull-down-box .item .pict {
  max-width: 800px;
  margin: 65px auto 0;
}
body main.page.page-support.child section.content-section .cate-area .pull-down-box .item .pict img {
  width: 100%;
}
body main.page.page-support.child section.content-section .cate-area .pull-down-box .item .pict .link-pdf {
  display: block;
  margin-top: 35px;
}
body main.page.page-support.child section.content-section .cate-area .pull-down-box .item .pict .link-pdf + .link-pdf {
  margin-top: 20px;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child section.content-section .cate-area .pull-down-box .item .pict {
    margin-top: 40px;
  }
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child section.content-section .cate-area .pull-down-box {
    padding-left: 0;
    padding-right: 0;
  }
  body main.page.page-support.child section.content-section .cate-area .pull-down-box .item-ttl {
    margin-right: 10px;
  }
  body main.page.page-support.child section.content-section .cate-area .pull-down-box .item .list li {
    text-align: justify;
  }
}
body main.page.page-support.child section.content-section .cap-area {
  margin-top: 100px;
}
body main.page.page-support.child section.content-section .cap-area h2.ttl {
  text-align: left;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child section.content-section .cap-area {
    margin-top: 70px;
  }
  body main.page.page-support.child section.content-section .cap-area h2.ttl {
    margin-bottom: 20px;
  }
}
body main.page.page-support.child.save section.content-section .inner .flex-box {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
}
body main.page.page-support.child.save section.content-section .inner .flex-box .list {
  width: calc(100% - 380px - 30px);
  order: 1;
}
body main.page.page-support.child.save section.content-section .inner .flex-box .table-area03 {
  max-width: 380px;
  width: 100%;
  order: 2;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child.save section.content-section .inner .flex-box .list {
    width: 100%;
    order: 2;
  }
  body main.page.page-support.child.save section.content-section .inner .flex-box .table-area03 {
    max-width: 380px;
    width: 100%;
    order: 1;
    padding-top: 5px;
    margin-bottom: 25px;
  }
}
body main.page.page-support.child.care section.content-section .inner .cate-area .sub-ttl {
  margin-bottom: 35px;
}
@media screen and (max-width: 850px) {
  body main.page.page-support.child.care section.content-section .inner .cate-area .sub-ttl {
    margin-bottom: 25px;
  }
}

body main.page.page-recruit section.content-section .image-set, body main.page.page-recruit section.content-section .sofa-image-area .row, body main.page.page-recruit section.content-section .sofa-image-area, body main.page.page-recruit section.content-section .step-area, body main.page.page-recruit section.content-section .card-area, body main.page.page-recruit section.content-section .feature-parson-area, body main.page.page-recruit section.content-section .image-area, body main.page.page-recruit section.content-section .inner-wrap {
  max-width: 1176px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 30px;
  padding-right: 30px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .image-set, body main.page.page-recruit section.content-section .sofa-image-area .row, body main.page.page-recruit section.content-section .sofa-image-area, body main.page.page-recruit section.content-section .step-area, body main.page.page-recruit section.content-section .card-area, body main.page.page-recruit section.content-section .feature-parson-area, body main.page.page-recruit section.content-section .image-area, body main.page.page-recruit section.content-section .inner-wrap {
    padding-left: 0;
    padding-right: 0;
  }
}

@keyframes moveEffect {
  0% {
    transform: scaleY(0);
    transform-origin: top;
  }
  50% {
    transform: scaleY(1);
    transform-origin: top;
  }
  50.1% {
    transform: scaleY(1);
    transform-origin: bottom;
  }
  100% {
    transform: scaleY(0);
    transform-origin: bottom;
  }
}
body main.page.page-recruit .pb0 {
  padding-bottom: 0 !important;
}
body main.page.page-recruit section.page-header .ttl {
  position: relative;
}
body main.page.page-recruit section.page-header .ttl.ttl-middle {
  font-size: 29px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.page-header .ttl.ttl-middle {
    font-size: 23px;
    letter-spacing: 0;
    line-height: 40px;
  }
}
body main.page.page-recruit section.page-header .ttl.underline:after {
  margin-top: 17px;
  width: 90px;
  height: 1px;
  background-color: #000;
  display: block;
  content: "";
  margin-left: auto;
  margin-right: auto;
}
body main.page.page-recruit section.page-header .sub-txt {
  font-size: 15px;
  line-height: 38px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.page-header .sub-txt {
    font-size: 14px;
    line-height: 2;
  }
  body main.page.page-recruit section.page-header .sub-txt.sp-center {
    text-align: center !important;
  }
}
body main.page.page-recruit section.content-section {
  margin-top: -110px;
  padding-top: 110px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section {
    padding-left: 23px;
    padding-right: 23px;
  }
}
body main.page.page-recruit section.content-section .multiply {
  mix-blend-mode: multiply;
  margin-top: 53px;
  margin-bottom: 80px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .multiply {
    margin-left: -23px;
    margin-right: -23px;
    width: calc(100% + 23px + 23px);
    margin-top: 59px;
    margin-bottom: 62px;
  }
}
body main.page.page-recruit section.content-section .inner h2.ttl {
  margin-bottom: 100px;
  text-align: center;
  position: relative;
}
body main.page.page-recruit section.content-section .inner h2.ttl .line {
  display: inline-block;
  position: relative;
  padding-bottom: 5px;
}
body main.page.page-recruit section.content-section .inner h2.ttl .line:after {
  content: "";
  height: 1px;
  width: calc(100% - 14px);
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
  margin: 0 auto;
  background-color: #707070;
}
body main.page.page-recruit section.content-section .inner h2.ttl.ver02:before {
  display: none;
}
body main.page.page-recruit section.content-section .inner h2.ttl .info {
  display: block;
  position: absolute;
  bottom: -75%;
  left: 0;
  right: 0;
  margin: auto;
  font-size: 15px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .inner h2.ttl .info {
    font-size: 14px;
  }
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .inner h2.ttl {
    margin-bottom: 70px;
  }
}
body main.page.page-recruit section.content-section .inner .pict-area + .table-area {
  margin-top: 120px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .inner .pict-area + .table-area {
    margin-top: 60px;
  }
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .wide-image-sp {
    width: calc(100% + 46px);
    margin-left: -23px;
    margin-right: -23px;
  }
}
body main.page.page-recruit section.content-section .sub-txt {
  font-size: 15px;
  line-height: 38px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .sub-txt {
    font-size: 14px;
    line-height: 28px;
  }
  body main.page.page-recruit section.content-section .sub-txt.sp-center {
    text-align: center !important;
  }
}
body main.page.page-recruit section.content-section .pt160 {
  padding-top: 160px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .pt160 {
    padding-top: 80px;
  }
}
body main.page.page-recruit section.content-section .pt150 {
  padding-top: 150px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .pt150 {
    padding-top: 90px;
  }
}
body main.page.page-recruit section.content-section .pt95 {
  padding-top: 95px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .pt95 {
    padding-top: 73px;
    padding-bottom: 10px;
  }
}
body main.page.page-recruit section.content-section .pt50 {
  padding-top: 50px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .pt50 {
    padding-top: 73px;
  }
}
body main.page.page-recruit section.content-section .pb160 {
  padding-bottom: 160px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .pb160 {
    padding-bottom: 80px;
  }
}
body main.page.page-recruit section.content-section .pb150 {
  padding-bottom: 150px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .pb150 {
    padding-bottom: 80px;
  }
}
body main.page.page-recruit section.content-section .mb150 {
  margin-bottom: 150px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .mb150 {
    margin-bottom: 80px;
  }
}
body main.page.page-recruit section.content-section .pb130 {
  padding-bottom: 130px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .pb130 {
    padding-bottom: 80px;
  }
}
body main.page.page-recruit section.content-section .pb110 {
  padding-bottom: 110px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .pb110 {
    padding-bottom: 80px;
  }
}
body main.page.page-recruit section.content-section .pb90 {
  padding-bottom: 90px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .pb90 {
    padding-bottom: 45px;
  }
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .pb0-sp {
    padding-bottom: 0 !important;
  }
}
body main.page.page-recruit section.content-section .table-area .ttl {
  font-size: 14px !important;
  text-align: left !important;
}
body main.page.page-recruit section.content-section .ttl {
  position: relative;
  text-align: center;
  font-size: 35px;
}
body main.page.page-recruit section.content-section .ttl.ttl-middle {
  font-size: 29px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .ttl.ttl-middle {
    font-size: 23px;
    margin-bottom: 27px;
  }
}
body main.page.page-recruit section.content-section .ttl.underline span {
  display: block;
}
body main.page.page-recruit section.content-section .ttl.underline span + span {
  padding-top: 10px;
  font-size: 21px;
}
body main.page.page-recruit section.content-section .ttl.underline:after {
  margin-top: 17px;
  width: 90px;
  height: 1px;
  background-color: #000;
  display: block;
  content: "";
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .ttl {
    font-size: 30px;
  }
  body main.page.page-recruit section.content-section .ttl.underline span {
    display: block;
  }
  body main.page.page-recruit section.content-section .ttl.underline span + span {
    padding-top: 6px;
    font-size: 16px;
  }
  body main.page.page-recruit section.content-section .ttl.underline:after {
    margin-top: 24px;
    width: 70px;
  }
}
body main.page.page-recruit section.content-section .image-area {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 62px;
}
body main.page.page-recruit section.content-section .image-area img {
  width: calc(50% - 31px);
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .image-area {
    flex-direction: column;
    gap: 0;
  }
  body main.page.page-recruit section.content-section .image-area img {
    width: 100%;
  }
}
body main.page.page-recruit section.content-section .btn-area {
  text-align: center;
}
body main.page.page-recruit section.content-section .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
body main.page.page-recruit section.content-section .bg-gray {
  background-color: #F2F1EF;
}
body main.page.page-recruit section.content-section .bg-gray .rules {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 27px;
}
body main.page.page-recruit section.content-section .bg-gray .rules span {
  font-size: 20px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .bg-gray {
    padding-left: 23px;
    padding-right: 23px;
  }
  body main.page.page-recruit section.content-section .bg-gray .rules span {
    font-size: 17px;
  }
}
body main.page.page-recruit section.content-section .bg-white {
  background-color: #fff;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .bg-white {
    padding-left: 23px;
    padding-right: 23px;
  }
}
body main.page.page-recruit section.content-section .bg-brawn {
  background-color: #CCCAC7;
}
body main.page.page-recruit section.content-section .bg-brawn .ttl.ff-en {
  text-align: left;
}
body main.page.page-recruit section.content-section .bg-brawn .sub-txt {
  text-align: left;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .bg-brawn {
    padding-left: 23px;
    padding-right: 23px;
  }
}
body main.page.page-recruit section.content-section .bg-brawn .image-area {
  margin-bottom: 123px;
  padding-left: 0;
  padding-right: 0;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .bg-brawn .image-area {
    margin-bottom: 50px;
  }
}
body main.page.page-recruit section.content-section .feature-parson-area {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 64px;
  flex-wrap: wrap;
}
body main.page.page-recruit section.content-section .feature-parson-area a {
  display: block;
  width: calc(33.3333333333% - 42.6666666667px);
}
body main.page.page-recruit section.content-section .feature-parson-area img {
  width: 100%;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .feature-parson-area {
    flex-direction: column;
    gap: 0;
  }
  body main.page.page-recruit section.content-section .feature-parson-area a {
    width: 100%;
  }
}
body main.page.page-recruit section.content-section .card-area {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  gap: 62px;
  flex-wrap: wrap;
}
body main.page.page-recruit section.content-section .card-area .card {
  width: calc(50% - 31px);
  background-color: #F3F1EE;
}
body main.page.page-recruit section.content-section .card-area .card .inner-header {
  padding-top: 53px;
  padding-left: 34px;
  padding-right: 34px;
  padding-bottom: 15px;
  border-bottom: 3px solid #fff;
  font-size: 20px;
}
body main.page.page-recruit section.content-section .card-area .card .inner-content {
  padding-top: 53px;
  padding-left: 34px;
  padding-right: 34px;
  padding-bottom: 48px;
  font-size: 15px;
  line-height: 28px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .card-area {
    flex-direction: column;
    gap: 23px;
  }
  body main.page.page-recruit section.content-section .card-area .card {
    width: 100%;
  }
  body main.page.page-recruit section.content-section .card-area .card .inner-content {
    padding-top: 23px;
  }
}
body main.page.page-recruit section.content-section .step-area {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #000;
  width: 100%;
  height: 60px;
  border-radius: 30px;
  color: #fff;
  gap: 30px;
}
body main.page.page-recruit section.content-section .step-area .arw {
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .step-area {
    display: none;
  }
}
body main.page.page-recruit section.content-section .sofa-image-area {
  padding-bottom: 58px;
}
body main.page.page-recruit section.content-section .sofa-image-area .row {
  padding-top: 62px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 62px;
}
body main.page.page-recruit section.content-section .sofa-image-area .row .col {
  width: calc(50% - 31px);
}
body main.page.page-recruit section.content-section .sofa-image-area .row .col img {
  width: 100%;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .sofa-image-area .row {
    flex-direction: column;
    gap: 0;
  }
  body main.page.page-recruit section.content-section .sofa-image-area .row .col {
    width: 100%;
  }
}
body main.page.page-recruit section.content-section .sofa-image-area + .sub-txt {
  margin-bottom: 70px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .sofa-image-area {
    margin-left: -23px;
    margin-right: -23px;
    padding-bottom: 0;
  }
  body main.page.page-recruit section.content-section .sofa-image-area .row {
    padding-top: 42px;
    flex-wrap: wrap;
    gap: 0;
  }
  body main.page.page-recruit section.content-section .sofa-image-area .row .col {
    width: 100%;
  }
  body main.page.page-recruit section.content-section .sofa-image-area .row .col img {
    width: 100%;
  }
  body main.page.page-recruit section.content-section .sofa-image-area + .sub-txt {
    margin-bottom: 113px;
  }
}
body main.page.page-recruit section.content-section .effect-bar {
  position: relative;
  width: 2px; /* 縦線の幅 */
  height: 150px; /* 縦線の高さ */
  background: #ddd; /* 縦線の色（背景） */
  margin: 0 auto; /* 中央配置 */
  overflow: hidden;
  top: -45px;
  z-index: 2;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .effect-bar {
    height: 90px;
  }
}
body main.page.page-recruit section.content-section .effect-bar::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 2px;
  height: 150px;
  background: #000; /* 黒色の動く縦線 */
  animation: moveEffect 1.5s cubic-bezier(1, 0, 0, 1) infinite;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .effect-bar::after {
    height: 90px;
  }
}
body main.page.page-recruit section.content-section .image-set .pict-sign {
  position: relative;
}
body main.page.page-recruit section.content-section .image-set .pict-sign .sign {
  position: absolute;
  bottom: 15px;
  right: 15px;
  color: #fff;
  font-size: 12px;
}
body main.page.page-recruit section.content-section .image-set .caption {
  font-size: 13px;
  padding-top: 11px;
}
@media screen and (max-width: 850px) {
  body main.page.page-recruit section.content-section .image-set {
    margin-left: -23px;
    margin-right: -23px;
  }
  body main.page.page-recruit section.content-section .image-set .caption {
    text-align: center;
    font-size: 11px;
    padding-top: 7px;
  }
}
body main.page.page-factory section.hero-section {
  background: url(../img/page/factory/itoshima-mv.jpg) no-repeat center;
  background-size: cover;
}
body main.page.page-factory section.hero-section .inner .text-area {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  height: 130px;
}
body main.page.page-factory section.hero-section .inner .text-area .ttl {
  margin-bottom: 12px;
  text-align: center;
}
body main.page.page-factory section.content-section .inner .info-area .ttl {
  text-align: center;
}
body main.page.page-factory section.content-section .inner .info-area .info-txt {
  margin-top: 25px;
  margin-bottom: 0;
}
body main.page.page-factory section.content-section .inner .info-area p.txt {
  font-size: 14px;
  text-align: center;
}
body main.page.page-factory section.content-section .inner .info-area p.txt.center {
  text-align: center;
}
body main.page.page-factory section.content-section .inner .info-area .link-box {
  text-align: center;
  max-width: 500px;
  margin: 50px auto 0;
  border: 1px solid #000;
  font-weight: bold;
  padding: 15px 0;
}
body main.page.page-factory section.content-section .inner .info-area .addr {
  margin-top: 20px;
  text-align: center;
}
@media screen and (max-width: 850px) {
  body main.page.page-factory section.content-section .inner .info-area .info-txt {
    margin-top: 20px;
    margin-bottom: 0;
  }
  body main.page.page-factory section.content-section .inner .info-area p.txt {
    text-align: justify;
  }
}
body main.page.page-factory section.content-section .inner .inner-footer {
  margin-top: 80px;
}
@media screen and (max-width: 850px) {
  body main.page.page-factory section.content-section .inner .inner-footer {
    margin-top: 60px;
  }
}
body main.page.page-factory section.content-section .inner .inner-footer .pict-area {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
  margin-top: 140px;
}
body main.page.page-factory section.content-section .inner .inner-footer .pict-area .pict {
  display: block;
  width: 100%;
  height: auto;
}
body main.page.page-factory section.content-section .inner .inner-footer .pict-area .pict.min {
  width: 46.2%;
}
body main.page.page-factory section.content-section .inner .inner-footer .pict-area .pict:nth-of-type(n + 3) {
  margin-top: 72px;
}
body main.page.page-factory section.content-section .inner .inner-footer .pict-area .pict.wide + .min {
  margin-top: 72px;
}
@media screen and (max-width: 850px) {
  body main.page.page-factory section.content-section .inner .inner-footer .pict-area {
    width: calc(100% + 46px);
    margin-left: -23px;
    margin-right: -23px;
    margin-top: 60px;
  }
  body main.page.page-factory section.content-section .inner .inner-footer .pict-area .pict.min {
    width: 100%;
  }
  body main.page.page-factory section.content-section .inner .inner-footer .pict-area .pict:nth-of-type(n + 3) {
    margin-top: 30px;
  }
  body main.page.page-factory section.content-section .inner .inner-footer .pict-area .pict + .min {
    margin-top: 30px;
  }
  body main.page.page-factory section.content-section .inner .inner-footer .pict-area .pict.wide + .min {
    margin-top: 30px;
  }
}

body .bg-w {
  background-color: #fff;
}
body .bg-g {
  background-color: #F2F1EF;
}
body .lrg {
  display: inline-block;
}
body .lrg .link-txt {
  font-weight: bold;
  font-size: 12px;
  letter-spacing: 0.1em;
  color: #000;
  line-height: 1.6;
  text-decoration: none;
  display: block;
  cursor: pointer;
}
body .lrg .link-txt span {
  border-bottom: 1px solid rgb(0, 0, 0);
  padding-bottom: 3px;
  transition: all 0.4s;
}
body .lrg .link-txt span:hover {
  border-bottom: 1px solid rgba(0, 0, 0, 0);
  opacity: 0.4;
}
body .lrg .link-txt.jap {
  margin-bottom: 10px;
}
body .lrg .link-txt.eng {
  visibility: hidden;
  opacity: 0;
}
body .lrg.open .jap {
  opacity: 0.4;
  background-image: url(../img/common/arw_up.svg);
}
body .lrg.open .jap span {
  border-bottom: 1px solid rgba(0, 0, 0, 0);
}
body .lrg.open .eng {
  visibility: visible;
  opacity: 1;
}
body span.btn-note {
  font-size: 12px;
  letter-spacing: 0.05em;
  display: block;
  margin-top: 18px;
  line-height: 1.7;
}
body .ui-datepicker .ui-datepicker-title {
  margin-right: 2.8em;
}
body .ui-datepicker select.ui-datepicker-month,
body .ui-datepicker select.ui-datepicker-year {
  margin-top: -3px;
}
body .ui-datepicker select.ui-datepicker-year {
  width: 28%;
}
body .ui-datepicker select.ui-datepicker-month {
  width: 24%;
}
body .ui-datepicker .ui-datepicker-header {
  background: #fff;
}
body .ui-datepicker .ui-state-default,
body .ui-datepicker .ui-state-default,
body .ui-datepicker .ui-state-default,
body .ui-datepicker .ui-button,
body .ui-datepicker .ui-button.ui-state-disabled:hover,
body .ui-datepicker .ui-button.ui-state-disabled:active {
  color: #000;
}
@media screen and (max-width: 850px) {
  body .ui-datepicker {
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    height: 234px;
    z-index: 2;
  }
  body .ui-datepicker select.ui-datepicker-year {
    width: 22%;
  }
}
body .rotate-90 {
  transform: rotate(90deg);
}
body .btn {
  text-align: center;
  font-size: 13px;
  line-height: 1.8;
  letter-spacing: 0.2em;
  font-weight: bold;
  display: block;
  width: 100%;
  transition: all 0.6s;
  word-break: break-all;
}
body .btn.btn01 {
  max-width: 200px;
  color: #000;
  border: 1px solid #000;
  padding: 5px 10px;
}
body .btn.btn01.ver02 {
  color: #fff;
  border: 1px solid #fff;
}
body .btn.btn01.ver03 {
  color: #000;
  background-color: #fff;
  border-color: inherit;
}
body .btn.btn01.ver03 {
  letter-spacing: 0.1em;
}
body .btn.btn01:hover {
  background-color: #AFAFAF;
  border-color: #AFAFAF;
  color: #fff;
  opacity: 1;
}
@media screen and (max-width: 850px) {
  body .btn.btn01 {
    padding: 11px 10px;
    max-width: 240px;
  }
}
body .btn.btn02 {
  color: #000;
  border: 1px solid #000;
  padding: 9px 12px;
  max-width: 342px;
  border-radius: 20px;
  letter-spacing: 0.1em;
}
body .btn.btn02:hover {
  background-color: #AFAFAF;
  border-color: #AFAFAF;
  color: #fff;
  opacity: 1;
}
body .btn.btn02 .btn-icn {
  width: 16px;
  display: inline-block;
  position: relative;
  top: -5px;
  margin-right: 5px;
}
body .btn.btn03 {
  max-width: 498px;
  font-size: 13px;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 1.6;
  padding: 30px 12px;
  background-color: #fff;
}
body .btn.btn03.ver02 {
  border: 1px solid #000;
  max-width: 340px;
  padding: 18px 12px;
}
body .btn.btn03.ver02:hover {
  background-color: #AFAFAF;
  border: 1px solid #AFAFAF;
  color: #fff;
  opacity: 1;
}
body .btn.btn03:hover {
  background-color: #AFAFAF;
  color: #fff;
  opacity: 1;
}
body .btn.btn04 {
  max-width: 313px;
  font-size: 14px;
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.2em;
  line-height: 1.6;
  padding: 14px 12px;
  background-color: #000;
}
body .btn.btn04.ver01 {
  background-color: #fff;
  border: 1px solid #000;
  color: #000;
  letter-spacing: 0.18em;
  font-size: 13px;
}
body .btn.btn04.ver02 {
  background-color: #fff;
  border: 1px solid #000;
  color: #000;
  letter-spacing: 0.1em;
  font-size: 12px;
  max-width: 350px;
}
body .btn.btn04:hover {
  background-color: #AFAFAF;
  color: #fff;
  opacity: 1;
  border-color: rgba(0, 0, 0, 0);
}
body .btn.btn05 {
  max-width: 530px;
  color: #000;
  border: 1px solid #000;
  text-align: center;
  padding: 24px 40px 30px;
  min-width: 390px;
}
body .btn.btn05 .min-txt {
  display: block;
  font-size: 18px;
  letter-spacing: 0.05em;
  margin-bottom: 14px;
  font-weight: normal;
}
body .btn.btn05 .btn-ttl {
  font-size: 25px;
  font-weight: normal;
  letter-spacing: 0.15em;
  display: block;
}
body .btn.btn05 .cap {
  display: block;
  font-size: 15px;
  letter-spacing: 0.05em;
  margin-top: 20px;
  line-height: 1.7;
  margin-top: 20px;
}
body .btn.btn05 .pict {
  width: 83%;
}
@media screen and (max-width: 850px) {
  body .btn.btn05 {
    min-width: auto;
    width: 100%;
    padding: 28px 25px;
    height: 188px;
  }
  body .btn.btn05 .min-txt {
    font-size: 16px;
    margin-bottom: 10px;
  }
  body .btn.btn05 .btn-ttl {
    font-size: 20px;
    font-weight: bold;
    letter-spacing: 0.15em;
    line-height: 1.8;
  }
  body .btn.btn05 .cap {
    font-size: 13px;
    margin-top: 15px;
  }
}
body .btn.btn06 {
  max-width: 500px;
  font-size: 13px;
  font-weight: bold;
  background-color: #fff;
  border: 1px solid #000;
  color: #000;
  letter-spacing: 0.18em;
  line-height: 1.6;
  padding: 14px 12px;
}
body .btn.btn06:hover {
  background-color: #AFAFAF;
  color: #fff;
  opacity: 1;
  border-color: rgba(0, 0, 0, 0);
}
body .btn.btn07 {
  max-width: 195px;
  font-size: 12px;
  font-weight: bold;
  background-color: #000;
  border: 1px solid #fff;
  color: #fff;
  letter-spacing: 0.35em;
  line-height: 1.6;
  padding: 15px 32px;
  border-radius: 0px;
}
body .btn.btn07:hover {
  background-color: #AFAFAF;
  color: #fff;
  opacity: 1;
  border-color: rgba(0, 0, 0, 0);
}
body .btn.btn07 img {
  max-width: 80px;
}
body .cate-btn {
  text-align: center;
  font-size: 13px;
  line-height: 1.8;
  letter-spacing: 0.2em;
  font-weight: bold;
  display: inline-block;
  transition: all 0.6s;
  word-break: break-all;
  color: #000;
  cursor: pointer;
  position: relative;
  z-index: 1;
  min-width: 150px;
}
@media screen and (max-width: 850px) {
  body .cate-btn {
    margin-left: auto;
    margin-right: auto;
    max-width: 240px;
    font-size: 12px;
  }
}
body .cate-btn .top-btn {
  border: 1px solid #000;
  border-bottom: none;
}
body .cate-btn .top-btn span {
  display: block;
  transition: all 0.6s;
  background-position: center right 14px;
  background-size: 8px;
  padding: 0px 35px;
  line-height: 36px;
  background-color: #fff;
}
body .cate-btn .top-btn span:hover {
  opacity: 0.4;
}
body .cate-btn .top-btn.open span {
  opacity: 0.4;
  background-image: url(../img/common/arw_up.svg);
}
body .cate-btn .top-btn.open + .sub-area {
  height: auto;
  padding-bottom: 25px;
}
body .cate-btn .top-btn.open + .sub-area li {
  opacity: 1;
  margin-top: 5px;
}
body .cate-btn .top-btn.open + .sub-area li + li {
  margin-top: 10px;
}
@media screen and (max-width: 850px) {
  body .cate-btn .top-btn span {
    line-height: 42px;
  }
}
body .cate-btn .sub-area {
  transition: all 0.6s;
  border: 1px solid #000;
  border-top: none;
  padding: 0px 25px;
  height: 1px;
  overflow: hidden;
  box-sizing: content-box;
  background-color: #fff;
  z-index: 1;
}
body .cate-btn .sub-area li {
  position: relative;
  text-align: left;
  opacity: 0;
  transition: all 0.6s;
}
body .cate-btn .sub-area li.on {
  display: none;
}
body .link-txt {
  text-decoration: underline;
  transition: all 0.4s;
}
body .link-txt:hover {
  text-decoration: none;
  opacity: 0.4;
}
body .link-txt02 {
  transition: all 0.4s;
}
body .link-txt02:hover {
  text-decoration: underline;
  opacity: 0.4;
}
body .link-icn {
  padding-right: 18px;
  background: url(../img/common/icn_gaibulink.svg) no-repeat center right;
  background-size: 10px;
}
body .icn-arw {
  padding-right: 12px;
  background-image: url(../img/common/arw_down.svg);
  background-repeat: no-repeat;
  background-size: auto;
  background-position: right center;
}
body .icn-arw:hover {
  background-image: url(../img/common/arw_up.svg);
}
body .gmap {
  height: 0;
  overflow: hidden;
  padding-bottom: 32%;
  position: relative;
}
body .gmap iframe {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 850px) {
  body .gmap {
    padding-bottom: 69.5%;
  }
}
body ul.list + .list {
  margin-top: 20px;
}
body ul.list li {
  padding-left: 0.9em;
  position: relative;
  font-size: 14px;
  line-height: 2;
  letter-spacing: 0.08em;
  text-align: justify;
}
body ul.list li:before {
  content: "・";
  position: absolute;
  left: -2px;
  top: 0;
  bottom: 0;
  display: block;
  margin: auto;
}
body ul.list li.th {
  font-weight: bold;
  padding-left: 0;
}
body ul.list li.th:before {
  display: none;
}
body ul.list li + li {
  margin-top: 8px;
}
body ul.list li + .th {
  margin-top: 10px;
}
@media screen and (max-width: 850px) {
  body ul.list li {
    font-size: 14px;
    line-height: 2;
    letter-spacing: 0.05em;
  }
}
body ul.list.ver02 li {
  padding-left: 0;
}
body ul.list.ver02 li:before {
  display: none;
}
body ul.list.ver02 li.th {
  padding-left: 0;
}
body .table-item {
  padding: 40px 0;
  border-top: 1px solid #707070;
  display: table;
  width: 100%;
  font-size: 14px;
  letter-spacing: 0.05em;
  line-height: 2;
}
@media screen and (max-width: 850px) {
  body .table-item {
    padding: 30px 0;
  }
}
body .table-item:last-of-type {
  border-bottom: 1px solid #707070;
}
body .table-item .ttl-item {
  display: table-cell;
  width: 216px;
  vertical-align: top;
}
@media screen and (max-width: 850px) {
  body .table-item .ttl-item {
    width: 85px;
    padding-right: 20px;
  }
}
body .table-item .ttl-item .ttl {
  font-size: 14px;
  letter-spacing: 0.05em;
  line-height: 2;
  display: block;
  margin-bottom: 0;
  font-weight: normal;
}
body .table-item .spec-item {
  display: table-cell;
  width: calc(100% - 216px);
  vertical-align: middle;
}
body .table-item .spec-item .row {
  display: block;
  width: 100%;
}
body .table-item .spec-item .row + .row {
  margin-top: 25px;
}
body .table-item .spec-item .row .txt {
  font-size: 14px;
  line-height: 2;
  letter-spacing: 0.05em;
}
body .table-item .spec-item .row .txt + .btn-area {
  margin-top: 12px;
  padding-bottom: 10px;
}
@media screen and (max-width: 850px) {
  body .table-item .spec-item {
    width: calc(100% - 105px);
  }
}
body .table-area02 {
  overflow: hidden;
  border-top: 1px solid #707070;
}
body .table-area02 .table-box .item {
  width: 1116px;
  display: table;
  text-align: left;
  padding: 30px 32px;
}
body .table-area02 .table-box .item .txt {
  display: table-cell;
  font-size: 13px;
  line-height: 2;
  letter-spacing: 0.05em;
  vertical-align: middle;
  white-space: nowrap;
}
body .table-area02 .table-box .item .txt:nth-of-type(1) {
  width: 124px;
}
body .table-area02 .table-box .item .txt:nth-of-type(2) {
  width: 440px;
}
body .table-area02 .table-box .item.th {
  background-color: #F2F1EF;
  font-weight: bold;
  padding: 15px 32px;
}
body .table-area02 .table-box .item:last-of-type {
  border-bottom: 1px solid #707070;
}
body .table-area02 .table-box .item + .item {
  border-top: 1px solid #707070;
}
@media screen and (max-width: 1135px) {
  body .table-area02 .table-box {
    overflow: scroll;
  }
}
body .table-area03 .table-box {
  border-top: 1px solid #707070;
  display: flex;
  justify-content: center;
  align-items: stretch;
  flex-wrap: nowrap;
  width: 100%;
  max-width: 380px;
}
body .table-area03 .table-box .item {
  text-align: center;
  width: 50%;
}
body .table-area03 .table-box .item .cell {
  display: block;
  font-size: 13px;
  line-height: 2;
  letter-spacing: 0.05em;
  vertical-align: middle;
  padding: 8px 32px;
  border-bottom: 1px solid #707070;
}
body .table-area03 .table-box .item .cell.th {
  background-color: #F2F1EF;
  font-weight: bold;
}
body .progress {
  background-color: #fff;
  color: rgb(255, 255, 255);
  height: 100%;
  position: fixed;
  width: 100%;
  top: 0;
  z-index: 99999;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: nowrap;
}
body .progress img {
  width: 160px;
  animation: Nowloading 2s infinite;
}
@keyframes Nowloading {
  0% {
    opacity: 0.2;
  }
  50% {
    filter: blur(0px);
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
body .movie-box,
body .wp-block-embed__wrapper {
  width: 57.617%;
  padding-top: 31.6044%;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  max-width: 680px;
}
body .movie-box iframe,
body .wp-block-embed__wrapper iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 850px) {
  body .movie-box,
  body .wp-block-embed__wrapper {
    width: 100%;
    padding-top: 54.381%;
  }
}
body .movie-box.wide,
body .wp-block-embed__wrapper.wide {
  width: 100%;
  max-width: 100%;
  padding-top: 51.5%;
}
@keyframes zoomOut {
  0% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes line_move {
  0% {
    stroke-dashoffset: 72px;
  }
  100% {
    stroke-dashoffset: 0px;
  }
}
body .swiper-container {
  position: relative;
  width: 100%;
}
body .swiper-container .swiper-wrapper {
  z-index: 0;
}
body .swiper-container .swiper-wrapper .swiper-slide {
  overflow: hidden;
  position: relative;
}
body .swiper-container .swiper-wrapper .swiper-slide .image {
  -o-object-fit: cover;
  object-fit: cover;
  display: block;
  height: 100%;
}
body .swiper-container02 {
  position: relative;
  width: 100%;
}
body .swiper-container02 .swiper-wrapper {
  z-index: 0;
}
body .swiper-container02 .swiper-wrapper .swiper-slide {
  overflow: hidden;
}
body .swiper-container03 {
  position: relative;
  width: 100%;
}
body .swiper-container03 .swiper-wrapper {
  z-index: 0;
}
body .swiper-container03 .swiper-wrapper .swiper-slide {
  overflow: hidden;
  position: relative;
}
body .swiper-container03 .swiper-wrapper .swiper-slide .image {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  height: 100%;
}
body .swiper-container03 .swiper-wrapper .swiper-slide h2 {
  color: #fff;
  position: absolute;
  bottom: 40px;
  left: 0;
  right: 0;
  margin: auto;
  text-align: center;
  line-height: 1.6;
}
body .swiper-pagination {
  padding-top: 5px;
  padding-bottom: 5px;
  box-sizing: border-box;
}
body .swiper-pagination .swiper-pagination-bullet {
  width: 23px;
  height: 23px;
  border-radius: 50%;
  position: relative;
  transition: all 0.2s;
  opacity: 1;
  border: 1px solid rgba(255, 255, 255, 0);
  box-sizing: border-box;
  margin-left: 8px !important;
  margin-right: 8px !important;
  background-color: rgba(255, 255, 255, 0);
}
body .swiper-pagination .swiper-pagination-bullet:after {
  content: "";
  width: 21px;
  height: 21px;
  border: 1px solid rgba(255, 255, 255, 0);
  position: absolute;
  left: 0px;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  border-radius: 50%;
}
body .swiper-pagination .swiper-pagination-bullet svg {
  position: absolute;
  left: 0px;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  opacity: 0;
  width: 22px;
  box-sizing: border-box;
}
body .swiper-pagination .swiper-pagination-bullet svg .circle-ani {
  stroke-dasharray: 72px;
}
body .swiper-pagination .swiper-pagination-bullet .circle {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  border: 1px solid #fff;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  box-sizing: border-box;
}
body .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active:after {
  border: 1px solid rgb(255, 255, 255);
}
body .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active svg {
  transition: all 0.2s;
  opacity: 1;
}
body .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active svg .circle-ani {
  animation: line_move 5s infinite;
}
body .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active .circle {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: #fff;
}
body .swiper-pagination.black .swiper-pagination-bullet .circle {
  border: 1px solid #000;
}
body .swiper-pagination.black .swiper-pagination-bullet.swiper-pagination-bullet-active:after {
  border: 1px solid rgb(0, 0, 0);
}
body .swiper-pagination.black .swiper-pagination-bullet.swiper-pagination-bullet-active .circle {
  background-color: #000;
}
body .swiper-container05 .swiper-wrapper,
body .swiper-container06 .swiper-wrapper {
  transition-timing-function: linear;
}
body .swiper-container05 .swiper-wrapper .swiper-slide,
body .swiper-container06 .swiper-wrapper .swiper-slide {
  margin-right: 8px;
  width: auto !important;
  box-sizing: content-box;
}
body .swiper-container05 .swiper-wrapper .swiper-slide .image,
body .swiper-container06 .swiper-wrapper .swiper-slide .image {
  height: 240px;
  width: auto;
}
body .visible-sm {
  display: none;
}
@media screen and (max-width: 576px) {
  body .visible-sm {
    display: inline;
  }
}
body .hidden-sm {
  display: inline;
}
@media screen and (max-width: 576px) {
  body .hidden-sm {
    display: none;
  }
}
body .visible-md {
  display: none;
}
@media screen and (max-width: 850px) {
  body .visible-md {
    display: inline;
  }
}
body .hidden-md {
  display: inline;
}
@media screen and (max-width: 850px) {
  body .hidden-md {
    display: none;
  }
}
body .visible-lg {
  display: none;
}
@media screen and (max-width: 990px) {
  body .visible-lg {
    display: inline;
  }
}
body .hidden-lg {
  display: inline;
}
@media screen and (max-width: 990px) {
  body .hidden-lg {
    display: none;
  }
}
body .visible-xl {
  display: none;
}
@media screen and (max-width: 1135px) {
  body .visible-xl {
    display: inline;
  }
}
body .hidden-xl {
  display: inline;
}
@media screen and (max-width: 1135px) {
  body .hidden-xl {
    display: none;
  }
}
body main section .pagination-area {
  position: relative;
}
body main section .pagination-area img {
  width: 100%;
}
body main section .pagination-area .wp-pagenavi {
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: nowrap;
  max-width: 810px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  margin-top: 160px;
}
body main section .pagination-area .wp-pagenavi .page,
body main section .pagination-area .wp-pagenavi .current,
body main section .pagination-area .wp-pagenavi .last {
  font-size: 17px;
  color: #A2A2A2;
  line-height: 38px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid;
  margin-left: 1.8%;
  margin-right: 1.8%;
}
body main section .pagination-area .wp-pagenavi .current {
  color: #000;
  border: 1px solid;
}
body main section .pagination-area .wp-pagenavi .extend {
  color: #000;
  border-radius: 0;
  border: none;
  font-size: 12px;
  position: relative;
  letter-spacing: 0.6em;
  text-align: center;
  display: block;
  left: 5px;
}
body main section .pagination-area .wp-pagenavi .previouspostslink,
body main section .pagination-area .wp-pagenavi .nextpostslink {
  font-weight: bold;
  font-size: 15px;
  width: auto;
  height: 40px;
  border: none;
  color: #000;
  letter-spacing: 0.15em;
  border-radius: 0;
  padding-top: 3px;
  position: absolute;
  margin: auto;
  bottom: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: nowrap;
}
body main section .pagination-area .wp-pagenavi .previouspostslink {
  padding-left: 65px;
  background: url(../img/common/icn_prev.svg) no-repeat left center;
  background-size: 40px;
  margin-left: 0px;
  margin-right: 40px;
  text-align: right;
  left: 0;
}
body main section .pagination-area .wp-pagenavi .nextpostslink {
  padding-right: 65px;
  background: url(../img/common/icn_next.svg) no-repeat right center;
  background-size: 40px;
  margin-left: 40px;
  margin-right: 0px;
  text-align: left;
  right: 0;
}
@media screen and (max-width: 850px) {
  body main section .pagination-area .wp-pagenavi {
    margin-top: 80px;
    padding-bottom: 80px;
  }
  body main section .pagination-area .wp-pagenavi:before {
    content: "";
    width: 1px;
    height: 17px;
    background-color: #707070;
    position: absolute;
    bottom: 10px;
    left: 0;
    right: 0;
    margin: auto;
  }
  body main section .pagination-area .wp-pagenavi .page,
  body main section .pagination-area .wp-pagenavi .current,
  body main section .pagination-area .wp-pagenavi .last {
    width: 38px;
    height: 38px;
    line-height: 34px;
    margin-left: 1.6%;
    margin-right: 1.6%;
  }
  body main section .pagination-area .wp-pagenavi .current {
    color: #000;
    border: 1px solid;
  }
  body main section .pagination-area .wp-pagenavi .previouspostslink,
  body main section .pagination-area .wp-pagenavi .nextpostslink {
    height: 42px;
  }
  body main section .pagination-area .wp-pagenavi .extend {
    font-size: 10px;
    letter-spacing: 0.2em;
    left: 1px;
  }
  body main section .pagination-area .wp-pagenavi .previouspostslink {
    left: 28px;
    padding-left: 60px;
  }
  body main section .pagination-area .wp-pagenavi .nextpostslink {
    right: 28px;
    padding-right: 60px;
  }
}
body main section .two-clm {
  position: relative;
  background-color: #000;
}
body main section .two-clm img {
  width: 100%;
}
body main section .two-clm .inner {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: nowrap;
}
body main section .two-clm .inner:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 50%;
  height: 100%;
  z-index: 0;
}
body main section .two-clm .inner:after {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  width: 50%;
  height: 100%;
  z-index: 0;
}
body main section .two-clm .inner .item-box {
  width: 50%;
  padding: 80px 0 70px;
  position: relative;
  z-index: 1;
}
body main section .two-clm .inner .item-box.item-box01 {
  padding-right: 85px;
}
body main section .two-clm .inner .item-box.item-box02 {
  padding-left: 85px;
}
body main section .two-clm .inner .item-box h2.ttl {
  color: #CECECE;
}
body main section .two-clm .inner .item-box h3.ttl {
  color: #CECECE;
}
body main section .two-clm .inner .item-box h4.ttl {
  color: #CECECE;
}
body main section .two-clm .inner .item-box .txt {
  color: #CECECE;
}
body main section.work-section {
  margin-top: 0px;
  padding: 40px;
  margin-top: 0 !important;
  background-color: #F2F1EF;
}
body main section.work-section img {
  width: 100%;
}
body main section.work-section .bg-w {
  background-color: #fff;
  padding-top: 120px;
  padding-bottom: 160px;
}
body main section.work-section .inner img {
  width: 100%;
}
body main section.work-section .inner .pict-area {
  margin-top: 45px;
}
body main section.work-section .inner .pict-area .item-box {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: nowrap;
}
body main section.work-section .inner .pict-area .item-box .item {
  display: block;
}
body main section.work-section .inner .pict-area .item-box span {
  display: block;
  text-align: center;
}
body main section.work-section .inner .pict-area .item-box span.cate {
  margin-top: 30px;
  font-size: 9px;
  letter-spacing: 0.12em;
}
body main section.work-section .inner .pict-area .item-box span.ttl {
  margin-top: 24px;
  letter-spacing: 0.2em;
  font-size: 22px;
  line-height: 1.6;
}
body main section.work-section .inner .pict-area .item-box.item-box01 .item {
  max-width: 490px;
  width: 100%;
}
body main section.work-section .inner .pict-area .item-box.item-box02 {
  margin-top: 64px;
}
body main section.work-section .inner .pict-area .item-box.item-box02 .item {
  max-width: 282px;
  width: 100%;
}
body main section.work-section .inner .btn-area {
  margin-top: 45px;
}
body main section.work-section .inner .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
body main section.shop-section {
  background-color: #F2F1EF;
  padding-top: 160px;
  padding-bottom: 160px;
}
body main section.shop-section img {
  width: 100%;
}
body main section.shop-section .inner .pict-area {
  margin-top: 114px;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: nowrap;
}
body main section.shop-section .inner .pict-area .item {
  max-width: 328px;
  width: 100%;
}
body main section.shop-section .inner .pict-area .item .cate {
  margin-top: 30px;
  font-weight: bold;
  letter-spacing: 0.22em;
  font-size: 13px;
}
body main section.shop-section .inner .pict-area .item .txt {
  color: #393939;
  margin-top: 18px;
  min-height: 130px;
}
body main section.shop-section .inner .pict-area .item .btn-area {
  margin-top: 25px;
}
body main section.shop-section .inner .pict-area .item .btn-area .btn {
  margin-left: 0;
  margin-right: 0;
}
body main section.shop-section .inner .pict-area .item .btn-area .btn + .btn {
  margin-top: 15px;
}
body main section.shop-section .two-clm {
  margin-top: 65px;
}
body main section.shop-section .two-clm .inner:before {
  background: url(../img/top/shop-section_bg_01.jpg) no-repeat center;
  background-size: cover;
}
body main section.shop-section .two-clm .inner .item-box02 .txt .link-txt {
  font-weight: bold;
}
body main section.shop-section .two-clm .inner .item-box02 .btn {
  margin-top: 35px;
}
body main section.shop-section .btn-area {
  margin-top: 65px;
}
body main section.shop-section .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
body main section.discovery-section {
  padding-top: 160px;
  padding-bottom: 160px;
}
body main section.discovery-section .inner #Discovery {
  margin-bottom: 0;
}
body main section .cap-area {
  border: 1px solid #000000;
  padding: 42px 40px;
  margin-top: 55px;
}
body main section .cap-area img {
  width: 100%;
}
body main section .cap-area .ttl {
  margin-bottom: 5px;
  text-align: left;
}
body main section .cap-area .txt {
  font-size: 14px;
  text-align: justify;
  margin: 0;
}
body main section .cap-area .inner-footer {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
  margin-top: 25px;
}
body main section .cap-area .inner-footer .link {
  max-width: 360px;
  display: block;
  margin-right: 4%;
  width: 100%;
}
body main section .cap-area .inner-footer .link img {
  width: 100%;
}
body main section .cap-area .inner-footer .txt {
  display: block;
  font-size: 15px;
  letter-spacing: 0.05em;
  font-weight: bold;
  margin-top: 20px;
  line-height: 1.7;
}
@media screen and (max-width: 850px) {
  body main section .cap-area .inner-footer {
    display: block;
  }
  body main section .cap-area .inner-footer .link {
    max-width: 248px;
    display: block;
    margin-right: 0;
  }
  body main section .cap-area .inner-footer .link img {
    width: 100%;
  }
  body main section .cap-area .inner-footer .txt {
    letter-spacing: 0em;
    font-weight: bold;
    margin-top: 12px;
    font-size: 14px;
  }
}
@media screen and (max-width: 850px) {
  body main section .cap-area {
    padding: 30px 20px;
  }
}
body main section .border-box {
  border: 1px solid #000000;
  padding: 42px 40px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: nowrap;
}
body main section .border-box .text {
  max-width: 76%;
  position: relative;
  top: -10px;
}
body main section .border-box .text .ttl {
  margin-bottom: 10px;
  text-align: left;
}
@media screen and (max-width: 850px) {
  body main section .border-box .text {
    max-width: 100%;
    top: 0;
  }
}
body main section .border-box .pict {
  max-width: 140px;
}
@media screen and (max-width: 850px) {
  body main section .border-box .pict {
    display: block;
    margin-top: 20px;
    max-width: 140px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media screen and (max-width: 850px) {
  body main section .border-box {
    padding: 30px 20px;
    display: block;
  }
}
body main .mono-bnr {
  background: url(../img/top/bnr-section_bg_03.jpg) no-repeat center;
  background-size: cover;
  padding-top: 95px;
  padding-bottom: 85px;
}
body main .mono-bnr .inner {
  text-align: center;
}
body main .mono-bnr .inner h3.ttl {
  color: #fff;
  margin-bottom: 20px;
  font-size: 25px;
  line-height: 1.6;
  letter-spacing: 0.3em;
}
body main .mono-bnr .inner .txt {
  color: #fff;
  text-align: center;
}
body main .mono-bnr .inner .btn-area {
  margin-top: 45px;
}
body main .mono-bnr .inner .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
body main .shop-bnr {
  background: url(../img/common/bnr_bg_shop.jpg) no-repeat center;
  background-size: cover;
  padding-top: 95px;
  padding-bottom: 85px;
}
body main .shop-bnr .inner {
  text-align: center;
}
body main .shop-bnr .inner h3.ttl {
  color: #fff;
  margin-bottom: 20px;
  font-size: 25px;
  line-height: 1.6;
  letter-spacing: 0.3em;
}
body main .shop-bnr .inner .txt {
  color: #fff;
  text-align: center;
}
body main .shop-bnr .inner .btn-area {
  margin-top: 45px;
}
body main .shop-bnr .inner .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
body main .mainte-bnr {
  background: url(../img/common/bnr_bg_minte.jpg) no-repeat center;
  background-size: cover;
  padding-top: 30px;
  padding-bottom: 30px;
  height: 343px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  flex-direction: column;
}
body main .mainte-bnr .inner {
  text-align: center;
}
body main .mainte-bnr .inner h3.ttl {
  color: #fff;
  margin-bottom: 22px;
  font-size: 25px;
  line-height: 1.6;
  letter-spacing: 0.3em;
}
body main .mainte-bnr .inner .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
body main .shiage-bnr {
  background: url(../img/common/bnr_bg_shiage.jpg) no-repeat center;
  background-size: cover;
  padding-top: 30px;
  padding-bottom: 30px;
  height: 343px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  flex-direction: column;
}
body main .shiage-bnr .inner {
  text-align: center;
}
body main .shiage-bnr .inner h3.ttl {
  color: #fff;
  margin-bottom: 22px;
  font-size: 25px;
  line-height: 1.6;
  letter-spacing: 0.3em;
}
body main .shiage-bnr .inner .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
body main .hishi-bnr {
  background: url(../img/common/bnr_bg_hishi.jpg) no-repeat center;
  background-size: cover;
  padding-top: 30px;
  padding-bottom: 30px;
  height: 343px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  flex-direction: column;
}
body main .hishi-bnr .inner {
  text-align: center;
}
body main .hishi-bnr .inner h3.ttl {
  color: #fff;
  margin-bottom: 22px;
  font-size: 25px;
  line-height: 1.6;
  letter-spacing: 0.3em;
}
body main .hishi-bnr .inner .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
body main .rec-bnr {
  background: url(../img/page/recruit/index_recruit_bg.png) no-repeat center;
  background-size: cover;
  padding-top: 95px;
  padding-bottom: 85px;
}
body main .rec-bnr .inner {
  text-align: center;
}
body main .rec-bnr .inner h3.ttl {
  color: #fff;
  margin-bottom: 20px;
  font-size: 25px;
  line-height: 1.6;
  letter-spacing: 0.3em;
}
body main .rec-bnr .inner .txt {
  color: #fff;
  text-align: center;
}
body main .rec-bnr .inner .btn-area {
  margin-top: 45px;
}
body main .rec-bnr .inner .btn-area .btn {
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 850px) {
  body main section .two-clm .inner {
    display: block;
  }
  body main section .two-clm .inner:before {
    width: 100%;
    height: 242px;
  }
  body main section .two-clm .inner:after {
    width: 100%;
    height: calc(100% - 242px);
    top: 242px;
  }
  body main section .two-clm .inner .item-box {
    width: 100%;
    padding: 40px 0 80px;
    width: 100%;
  }
  body main section .two-clm .inner .item-box.item-box01 {
    padding-right: 0px;
  }
  body main section .two-clm .inner .item-box.item-box02 {
    padding-left: 0px;
  }
  body main section.work-section {
    padding: 13px;
  }
  body main section.work-section .bg-w {
    padding: 80px 17px 90px;
  }
  body main section.work-section .inner {
    padding-left: 0;
    padding-right: 0;
  }
  body main section.work-section .inner .pict-area {
    margin-top: 40px;
  }
  body main section.work-section .inner .pict-area .item-box {
    display: block;
  }
  body main section.work-section .inner .pict-area .item-box .item {
    margin-left: auto;
    margin-right: auto;
  }
  body main section.work-section .inner .pict-area .item-box .item + .item {
    margin-top: 70px;
  }
  body main section.work-section .inner .pict-area .item-box span.cate {
    margin-top: 20px;
    font-size: 10px;
  }
  body main section.work-section .inner .pict-area .item-box span.ttl {
    font-size: 20px;
    letter-spacing: 0.1em;
    margin-top: 18px;
  }
  body main section.work-section .inner .pict-area .item-box.item-box01 .item {
    width: 100%;
  }
  body main section.work-section .inner .pict-area .item-box.item-box02 {
    margin-top: 70px;
  }
  body main section.work-section .inner .pict-area .item-box.item-box02 .item {
    max-width: 255px;
    width: 90%;
  }
  body main section.work-section .inner .btn-area {
    margin-top: 85px;
  }
  body main section.work-section .inner .btn-area .btn {
    max-width: 260px;
  }
  body main section.shop-section {
    padding-top: 80px;
    padding-bottom: 90px;
  }
  body main section.shop-section .inner h1.ttl {
    text-align: center;
    line-height: 1.3;
  }
  body main section.shop-section .inner h2.ttl {
    text-align: center;
  }
  body main section.shop-section .inner h4.ttl {
    text-align: center;
  }
  body main section.shop-section .inner .pict-area {
    margin-top: 0;
    display: block;
  }
  body main section.shop-section .inner .pict-area .item {
    width: 100%;
    text-align: center;
    max-width: none;
  }
  body main section.shop-section .inner .pict-area .item + .item {
    margin-top: 80px;
  }
  body main section.shop-section .inner .pict-area .item .pict {
    display: block;
    margin-left: -23px;
    margin-right: -23px;
    width: calc(100% + 46px);
  }
  body main section.shop-section .inner .pict-area .item .cate {
    margin-top: 45px;
    text-align: center;
    font-size: 16px;
  }
  body main section.shop-section .inner .pict-area .item .txt {
    text-align: center;
    font-size: 12px;
    margin-top: 25px;
    min-height: auto;
  }
  body main section.shop-section .inner .pict-area .item .btn-area {
    margin-top: 20px;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    flex-wrap: nowrap;
  }
  body main section.shop-section .inner .pict-area .item .btn-area .btn {
    max-width: 142px;
    padding: 5px 10px;
    font-size: 12px;
    margin: 0 5px;
  }
  body main section.shop-section .inner .pict-area .item .btn-area .btn + .btn {
    margin-top: 0;
  }
  body main section.shop-section .two-clm {
    margin-top: 35px;
  }
  body main section.shop-section .two-clm .inner .item-box.item-box01 {
    height: 242px;
  }
  body main section.shop-section .two-clm .inner .item-box.item-box02 .txt {
    text-align: center;
    font-size: 12px;
    letter-spacing: 0.05em;
  }
  body main section.shop-section .two-clm .inner .item-box.item-box02 .btn {
    max-width: 142px;
    margin-left: auto;
    margin-right: auto;
    padding: 5px 10px;
    font-size: 12px;
  }
  body main section.shop-section .btn-area {
    margin-top: 90px;
  }
  body main section.discovery-section {
    padding-top: 80px;
    padding-bottom: 90px;
  }
  body main .mono-bnr {
    padding: 50px 0 55px;
  }
  body main .mono-bnr .inner h3.ttl {
    font-size: 25px;
    margin-bottom: 15px;
  }
  body main .mono-bnr .inner .txt {
    font-size: 14px;
  }
  body main .mono-bnr .inner .btn-area {
    margin-top: 35px;
  }
  body main .shop-bnr {
    padding: 50px 0 55px;
  }
  body main .shop-bnr .inner h3.ttl {
    font-size: 25px;
    margin-bottom: 15px;
  }
  body main .shop-bnr .inner .txt {
    font-size: 14px;
  }
  body main .shop-bnr .inner .btn-area {
    margin-top: 35px;
  }
  body main .mainte-bnr {
    padding: 0px;
    height: 208px;
  }
  body main .mainte-bnr .inner h3.ttl {
    font-size: 25px;
    margin-bottom: 20px;
  }
  body main .mainte-bnr .inner .txt {
    font-size: 14px;
  }
  body main .hishi-bnr {
    padding: 0px;
    height: 208px;
  }
  body main .hishi-bnr .inner h3.ttl {
    font-size: 25px;
    margin-bottom: 20px;
  }
  body main .hishi-bnr .inner .txt {
    font-size: 14px;
  }
  body main .shiage-bnr {
    padding: 0px;
    height: 208px;
  }
  body main .shiage-bnr .inner h3.ttl {
    font-size: 25px;
    margin-bottom: 20px;
  }
  body main .shiage-bnr .inner .txt {
    font-size: 14px;
  }
  body main .rec-bnr {
    padding: 50px 0 55px;
    background-image: url(../img/page/recruit/index_recruit_bg_sp.png);
  }
  body main .rec-bnr .inner h3.ttl {
    font-size: 25px;
    margin-bottom: 15px;
  }
  body main .rec-bnr .inner .txt {
    font-size: 14px;
  }
  body main .rec-bnr .inner .btn-area {
    margin-top: 35px;
  }
}
body main #Discovery {
  margin-bottom: 160px;
}
@media screen and (max-width: 850px) {
  body main #Discovery {
    margin-bottom: 90px;
  }
}
body main #Discovery h3 {
  margin-left: auto;
  margin-right: auto;
  max-width: 180px;
  margin-bottom: 70px;
  padding-top: 80px;
  margin-top: -80px;
}
@media screen and (max-width: 850px) {
  body main #Discovery h3 {
    max-width: 140px;
    margin-bottom: 50px;
  }
}
body main #Discovery .discovery-subtitle {
  font-size: 13px;
  text-align: center;
  letter-spacing: 0.2em;
  line-height: 2;
  margin: 0 0 45px;
}
@media screen and (max-width: 850px) {
  body main #Discovery .discovery-subtitle {
    font-size: 14px;
    text-align: left;
  }
}
body main #Discovery .discovery-posts {
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: wrap;
  width: calc(100% + 32px);
  margin-left: -16px;
  margin-right: -16px;
}
body main #Discovery .discovery-posts .item {
  display: block;
  width: calc(33.3333333333% - 32px);
  margin-left: 16px;
  margin-right: 16px;
}
body main #Discovery .discovery-posts .item:nth-of-type(n + 4) {
  margin-top: 60px;
}
body main #Discovery .discovery-posts .item .pict {
  display: block;
  height: 260px;
  margin-bottom: 18px;
}
body main #Discovery .discovery-posts .item .pict img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
body main #Discovery .discovery-posts .item .date {
  display: block;
  font-size: 13px;
  letter-spacing: 0.08em;
  display: block;
  line-height: 1.8;
  margin-bottom: 8px;
}
body main #Discovery .discovery-posts .item .post-ttl {
  display: block;
  text-align: left;
  font-size: 16px;
  letter-spacing: 0.15em;
  font-weight: bold;
  line-height: 1.8;
  margin-bottom: 0px;
}
body main #Discovery .discovery-posts .item .cate {
  display: block;
  margin-top: 2px;
}
body main #Discovery .discovery-posts .item .cate .mark {
  font-size: 13px;
  line-height: 2.3;
  letter-spacing: 0.08em;
  display: inline-block;
  margin-right: 1em;
}
@media screen and (max-width: 850px) {
  body main #Discovery .discovery-posts .item {
    width: 100%;
  }
  body main #Discovery .discovery-posts .item:nth-of-type(n + 4) {
    margin-top: 0px;
  }
  body main #Discovery .discovery-posts .item:nth-of-type(n + 2) {
    margin-top: 40px;
  }
  body main #Discovery .discovery-posts .item .pict {
    height: 200px;
    margin-bottom: 20px;
  }
  body main #Discovery .discovery-posts .item .date {
    margin-bottom: 5px;
  }
}
body main #Discovery .pagination-area .wp-pagenavi {
  margin-top: 95px;
}
@media screen and (max-width: 850px) {
  body main #Discovery .pagination-area .wp-pagenavi {
    margin-top: 80px;
  }
}
body main #Discovery .btn-area {
  margin-top: 80px;
}
@media screen and (max-width: 850px) {
  body main #Discovery .btn-area {
    margin-top: 70px;
  }
}
body main #Discovery .btn-area .btn01 {
  margin-left: auto;
  margin-right: auto;
}

body main.page.download section.content-section .inner .lead {
  font-size: 16px;
  text-align: center;
  letter-spacing: 0.2em;
  line-height: 2;
  margin-bottom: 45px;
}
@media screen and (max-width: 850px) {
  body main.page.download section.content-section .inner .lead {
    letter-spacing: 0.05em;
    margin-bottom: 30px;
  }
}
body main.page.download section.content-section .inner .cate-ttl {
  padding-bottom: 20px;
  border-bottom: 1px solid #CBCBCB;
  font-weight: normal;
}
body main.page.download section.content-section .inner .back-btn {
  margin-top: 90px;
}
body main.page.download section.content-section .inner .back-btn .btn {
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 850px) {
  body main.page.download section.content-section .inner .back-btn {
    margin-top: 87px;
  }
}
body main.page.download section.content-section .inner .note-area .note-box {
  background-color: #F2F1EF;
  padding: 20px 40px 24px;
  margin-top: 80px;
}
@media screen and (max-width: 850px) {
  body main.page.download section.content-section .inner .note-area .note-box {
    padding: 30px 20px;
    margin-top: 50px;
  }
}
body main.page.download section.content-section .inner .btn-area.third-flex {
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: wrap;
  margin-left: -1.5%;
  margin-right: -1.5%;
}
body main.page.download section.content-section .inner .btn-area.third-flex .btn-box {
  display: block;
  width: 30.3333333333%;
  margin-left: 1.5%;
  margin-right: 1.5%;
}
body main.page.download section.content-section .inner .btn-area.third-flex .btn-box:nth-of-type(n + 4) {
  margin-top: 32px;
}
@media screen and (max-width: 850px) {
  body main.page.download section.content-section .inner .btn-area.third-flex {
    display: block;
    width: 100%;
    margin-left: 0%;
    margin-right: 0%;
    padding-top: 30px;
  }
  body main.page.download section.content-section .inner .btn-area.third-flex .btn-box {
    width: 100%;
    margin-left: 0%;
    margin-right: 0%;
  }
  body main.page.download section.content-section .inner .btn-area.third-flex .btn-box:nth-of-type(n + 4) {
    margin-top: 0px;
  }
  body main.page.download section.content-section .inner .btn-area.third-flex .btn-box:nth-of-type(n + 2) {
    margin-top: 30px;
  }
  body main.page.download section.content-section .inner .btn-area.third-flex .btn-box .btn04 {
    margin-left: auto;
    margin-right: auto;
  }
}
body main.page.download section.content-section .inner .btn-area.forth-flex {
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: wrap;
  margin-left: -1.5%;
  margin-right: -1.5%;
}
body main.page.download section.content-section .inner .btn-area.forth-flex .btn-box {
  display: block;
  width: 22%;
  margin-left: 1.5%;
  margin-right: 1.5%;
}
body main.page.download section.content-section .inner .btn-area.forth-flex .btn-box:nth-of-type(n + 5) {
  margin-top: 32px;
}
@media screen and (max-width: 850px) {
  body main.page.download section.content-section .inner .btn-area.forth-flex {
    display: block;
    width: 100%;
    margin-left: 0%;
    margin-right: 0%;
    padding-top: 30px;
  }
  body main.page.download section.content-section .inner .btn-area.forth-flex .btn-box {
    width: 100%;
    margin-left: 0%;
    margin-right: 0%;
  }
  body main.page.download section.content-section .inner .btn-area.forth-flex .btn-box:nth-of-type(n + 5) {
    margin-top: 0px;
  }
  body main.page.download section.content-section .inner .btn-area.forth-flex .btn-box:nth-of-type(n + 2) {
    margin-top: 30px;
  }
  body main.page.download section.content-section .inner .btn-area.forth-flex .btn-box .btn04 {
    margin-left: auto;
    margin-right: auto;
  }
}
body main.page.download section.content-section .inner .item-area {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  max-width: 630px;
  margin-left: auto;
  margin-right: auto;
}
body main.page.download section.content-section .inner .item-area .item {
  display: block;
  max-width: 280px;
  width: 100%;
}
body main.page.download section.content-section .inner .item-area .item:nth-of-type(n + 3) {
  margin-top: 65px;
}
body main.page.download section.content-section .inner .item-area .item:nth-of-type(odd) {
  margin-right: 5%;
}
body main.page.download section.content-section .inner .item-area .item:nth-of-type(even) {
  margin-left: 5%;
}
body main.page.download section.content-section .inner .item-area .item .txt {
  padding: 5px 0 2px 30px;
  border-left: 1px solid #707070;
  letter-spacing: 0.1em;
  font-weight: bold;
  margin-top: 22px;
  display: block;
}
@media screen and (max-width: 850px) {
  body main.page.download section.content-section .inner .item-area .item {
    display: block;
    max-width: 342px;
    width: 100%;
  }
  body main.page.download section.content-section .inner .item-area .item:nth-of-type(n + 3) {
    margin-top: 0px;
  }
  body main.page.download section.content-section .inner .item-area .item:nth-of-type(odd) {
    margin-right: 0%;
  }
  body main.page.download section.content-section .inner .item-area .item:nth-of-type(even) {
    margin-left: 0%;
  }
  body main.page.download section.content-section .inner .item-area .item.item02, body main.page.download section.content-section .inner .item-area .item.item03 {
    width: calc((100% - 33px) / 2);
    margin-top: 35px;
    margin-bottom: 35px;
  }
  body main.page.download section.content-section .inner .item-area .item .txt {
    display: block;
    padding: 2px 0 0px 16px;
    line-height: 1;
    margin-top: 20px;
  }
}
body main.page.download section.content-section .inner .link-area {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: nowrap;
  z-index: 0;
  position: relative;
}
body main.page.download section.content-section .inner .link-area .item .link-txt03 {
  margin-left: 25px;
  margin-right: 25px;
  padding-right: 20px;
  background: url(../img/common/arw_r.svg) no-repeat right center;
  background-size: 4px;
  display: inline-block;
  color: #000;
  font-weight: bold;
  font-size: 13px;
  letter-spacing: 0.1em;
  line-height: 1.8;
}
@media screen and (max-width: 850px) {
  body main.page.download section.content-section .inner .link-area {
    display: block;
  }
  body main.page.download section.content-section .inner .link-area .item {
    text-align: center;
  }
  body main.page.download section.content-section .inner .link-area .item + .item {
    margin-top: 20px;
  }
  body main.page.download section.content-section .inner .link-area .item .link-txt03 {
    font-size: 14x;
    background-size: 7px;
    padding-right: 20px;
  }
}

body main.club:not(.single) .banner-area p.txt {
  padding-top: 15px;
  margin-bottom: 10px;
}
body main.club:not(.single) .banner-area a {
  display: block;
  margin-bottom: 20px;
}
body main.club:not(.single) .banner-area a img {
  max-width: 780px;
  margin-bottom: 20px;
  border: 1px solid;
}
body main.club:not(.single) p.txt.m30b {
  margin-bottom: 30px;
}
body main.club:not(.single) iframe {
  margin-top: 20px;
}

body main.page.page-history .history-text {
  text-align: center;
  font-size: 13px;
  font-weight: 500;
  line-height: 2.3076923077;
}
body main.page.page-history .history-link {
  position: fixed;
  left: 50%;
  bottom: 60px;
  transform: translateX(-50%);
  width: 100%;
  max-width: 1118px;
  height: 58px;
  background-color: #000000;
  border-radius: 50px;
  display: flex;
  align-items: center;
  gap: 100px;
  justify-content: center;
  color: #fff;
  z-index: 1000;
}
body main.page.page-history .history-link .history-item a {
  font-size: 13px;
  letter-spacing: 0.05em;
}
body main.page.page-history .history-link .history-item a:hover {
  opacity: 1;
  color: #fff;
}
body main.page.page-history .history-table {
  margin-top: 310px;
  max-width: 904px;
  margin-inline: auto;
}
body main.page.page-history .history-table .history-table-box {
  position: relative;
}
body main.page.page-history .history-table .history-table-box::after {
  content: "";
  width: 0.5px;
  height: calc(100% - 220px);
  background-color: #707070;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
body main.page.page-history .history-table .history-table-box .history-year {
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background-color: #000000;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 25px;
  font-weight: 500;
  letter-spacing: 0.22em;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 10;
}
body main.page.page-history .history-table .history-table-box .history-wrap {
  display: flex;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left {
  width: 50%;
  background-color: #F2F1EF;
  position: relative;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left::before {
  content: "";
  width: 100vw;
  height: 100%;
  background-color: #F2F1EF;
  position: absolute;
  top: 0;
  left: 0;
  transform: translateX(-100%);
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner {
  padding: 170px 0;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner .history-time {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 22px;
  font-weight: 800;
  line-height: 0.1em;
  line-height: 1.8181818182;
  position: relative;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner .history-time::after {
  content: "";
  width: 104px;
  height: 1px;
  background-color: #707070;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  z-index: 5;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner .history-time span {
  width: 43px;
  height: 43px;
  border-radius: 50%;
  background-color: #fff;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  transform: translateX(50%);
  z-index: 10;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner .history-time span::after {
  content: "";
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background-color: #707070;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner .history-time:nth-of-type(n+2) {
  margin-top: 105px;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner.pt0 {
  padding-top: 0;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .history-text-box {
  padding-right: 138px;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .history-text-box .history-table-text {
  font-size: 22px;
  font-weight: 600;
  letter-spacing: 0.1em;
  line-height: 1.8181818182;
  white-space: nowrap;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .history-text-box .history-left-img {
  margin-top: 20px;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .history-text-box .history-left-img img {
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .history-text-box .history-left-img .caption {
  margin-top: 20px;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.8461538462;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .history-text-box .btn {
  margin-top: 40px;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .history-text-box .btn a {
  width: 200px;
  height: 36px;
  border: 0.5px solid #000;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right {
  width: 50%;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner {
  padding: 170px 0;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner .blocks .block {
  display: flex;
  flex-direction: column;
  align-items: center;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner .blocks .block .name {
  text-align: center;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: 0.05em;
  line-height: 1.5909090909;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner .blocks .block .name span {
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0.1em;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner .blocks .block .img {
  margin-top: 32px;
  max-width: 383px;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner .blocks .block .btn {
  margin-top: 50px;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner .blocks .block .btn a {
  width: 200px;
  height: 36px;
  border: 0.5px solid #000;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: bold;
  letter-spacing: 0.2em;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner .blocks .block:nth-child(n+2) {
  margin-top: 60px;
}
body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner.pt0 {
  padding-top: 0;
}
@media screen and (max-width: 850px) {
  body main.page.page-history .history-text {
    font-size: 14px;
    line-height: 2;
    text-align: left;
  }
  body main.page.page-history .history-text br.pc-only {
    display: none;
  }
  body main.page.page-history .history-link {
    bottom: 40px;
    gap: 40px;
    width: 90%;
  }
  body main.page.page-history .history-table {
    margin-top: 160px;
  }
  body main.page.page-history .history-table .history-table-box::after {
    content: none;
  }
  body main.page.page-history .history-table .history-table-box .history-year {
    width: 120px;
    height: 120px;
    font-size: 22px;
  }
  body main.page.page-history .history-table .history-table-box .history-year::after {
    content: "";
    width: 0.5px;
    height: 70px;
    background-color: #707070;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translate(-50%, 100%);
  }
  body main.page.page-history .history-table .history-table-box:not(:first-child) .history-year::before {
    content: "";
    width: 0.5px;
    height: 70px;
    background-color: #707070;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, -100%);
  }
  body main.page.page-history .history-table .history-table-box .history-wrap {
    flex-direction: column;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner {
    padding: 150px 30px;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner::before {
    content: none;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner .history-time {
    flex-direction: column-reverse;
    align-items: center;
    font-size: 17px;
    gap: 16px;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner .history-time::after {
    content: none;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner .history-time span {
    transform: translateX(0);
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner .history-time:nth-of-type(n+2) {
    margin-top: 130px;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner .history-time:nth-of-type(n+2) span {
    position: relative;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner .history-time:nth-of-type(n+2) span::before {
    content: "";
    width: 0.5px;
    height: 70px;
    background-color: #707070;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, calc(-100% - 30px));
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner .history-text-box {
    padding-right: 0;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner .history-text-box .history-table-text {
    font-size: 17px;
    text-align: center;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner .history-text-box .history-left-img {
    margin-top: 24px;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner .history-text-box .history-left-img img {
    width: 100%;
    -o-object-fit: contain;
       object-fit: contain;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner .history-text-box .history-left-img .caption {
    margin-top: 24px;
    font-size: 14px;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner .history-text-box .history-left-img .btn a {
    width: 260px;
    height: 48px;
    font-size: 12px;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner.pt0 {
    padding-top: 150px;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-left .inner.pt {
    padding: 150px 30px 90px;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right {
    width: 100%;
    position: relative;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner {
    padding: 100px 0 160px;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner::before {
    content: "";
    width: 0.5px;
    height: 140px;
    background-color: #707070;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner .blocks .block .name {
    font-size: 17px;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner .blocks .block .name span {
    font-size: 14px;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner .blocks .block .img {
    margin-top: 20px;
    max-width: 314px;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner .blocks .block .btn {
    margin-top: 40px;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner .blocks .block .btn a {
    width: 260px;
    height: 48px;
    font-size: 12px;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner .blocks .block:nth-child(n+2) {
    margin-top: 50px;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner.pt160 {
    padding-top: 160px;
  }
  body main.page.page-history .history-table .history-table-box .history-wrap .history-table-right .inner.pt0 {
    padding-top: 160px;
  }
}
/*# sourceMappingURL=style.css.map */
