@charset "UTF-8";
* {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

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

table {
  border-collapse: collapse;
  border-spacing: 0;
}

.color-white {
  color: #fff;
}

.color-black {
  color: #000;
}

.color-orange {
  color: #FE7D28;
}

.color-gray5 {
  color: #F2F2F2;
}

.bg-orange-light {
  background-color: #FDF5F2;
}

.bg-orange-light2 {
  background-color: #FFFAF7;
}

.bg-orange-gradient {
  background: rgb(254, 125, 40);
  background: -webkit-gradient(left top, right bottom, color-stop(0%, rgb(254, 125, 40)), color-stop(100%, rgb(255, 184, 0)));
  background: linear-gradient(135deg, rgb(254, 125, 40) 0%, rgb(255, 184, 0) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#fe7d28", endColorstr="#ffb800", GradientType=1 );
}

.fw-bold {
  font-weight: bold !important;
}

.center {
  text-align: center;
}

.show1180 {
  display: none !important;
}
@media only screen and (max-width: 1180px) {
  .show1180 {
    display: block !important;
  }
}

.show850 {
  display: none !important;
}
@media only screen and (max-width: 850px) {
  .show850 {
    display: block !important;
  }
}

.show750 {
  display: none !important;
}
@media only screen and (max-width: 750px) {
  .show750 {
    display: block !important;
  }
}

@media only screen and (max-width: 1180px) {
  .hide1180 {
    display: none !important;
  }
}

@media only screen and (max-width: 850px) {
  .hide850 {
    display: none !important;
  }
}

@media only screen and (max-width: 750px) {
  .hide750 {
    display: none !important;
  }
}

/* Stylesheet */
html {
  width: 100%;
  height: auto;
  font-size: 62.5%;
  scroll-behavior: smooth;
}

body {
  width: 100%;
  font-family: YuGothic, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif;
  font-size: 1.6rem;
  line-height: 3rem;
  font-weight: normal;
  color: #000;
  -webkit-font-smoothing: subpixel-antialiased;
  -moz-osx-font-smoothing: unset;
  -webkit-text-size-adjust: 100%;
  position: relative;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
  vertical-align: top;
  outline: none;
}

div {
  margin: 0;
  padding: 0;
}

h1, h2, h3, h4, h5, h6 {
  -webkit-font-smoothing: antialiased;
  font-weight: normal;
}

h1, h2, h3, h4, h5, h6, p, ul, ol, li {
  margin: 0;
  padding: 0;
  list-style: none;
}

a {
  text-decoration: none;
  outline: none;
  color: #000;
  -webkit-transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
  transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
}

a img {
  display: block;
  outline: none;
  -webkit-transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
  transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
}

a:hover img {
  opacity: 1 !important;
}

a:focus, a:active, input, textarea {
  outline: none;
}

a:hover, a:hover img, a:hover {
  opacity: 0.85;
}

a path, button path {
  -webkit-transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
  transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
}

button {
  -webkit-transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
  transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
}
button:hover {
  cursor: pointer;
}

.anchor {
  display: block;
  position: relative;
  top: -60px;
  visibility: hidden;
}
@media only screen and (max-width: 1180px) {
  .anchor {
    top: -120px;
  }
}

.link-unerline {
  text-decoration: underline;
}

/* Wrapper */
#wrapper {
  position: relative;
}
@media only screen and (max-width: 1180px) {
  #wrapper {
    padding-top: 90px;
  }
}
@media only screen and (max-width: 750px) {
  #wrapper {
    padding-top: 80px;
  }
}

#mask {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99999;
  width: 100vw;
  height: 100vh;
  background-color: #fff;
}

/* Main */
main {
  overflow: hidden;
}

.content-1440 {
  width: 100%;
  max-width: 1440px;
  margin-left: auto;
  margin-right: auto;
}

.content-1420 {
  width: 90%;
  max-width: 1420px;
  margin-left: auto;
  margin-right: auto;
}

.content-1154 {
  width: 90%;
  max-width: 1154px;
  margin-left: auto;
  margin-right: auto;
}

.content-1024 {
  width: 90%;
  max-width: 1024px;
  margin-left: auto;
  margin-right: auto;
}

.content-900 {
  width: 90%;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}

.content-848 {
  width: 90%;
  max-width: 848px;
  margin-left: auto;
  margin-right: auto;
}

.content-724 {
  width: 90%;
  max-width: 724px;
  margin-left: auto;
  margin-right: auto;
}

.pad100160 {
  padding-top: 100px;
  padding-bottom: 160px;
}

.pad100 {
  padding-top: 100px;
  padding-bottom: 100px;
}
@media only screen and (max-width: 1180px) {
  .pad100 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
}
@media only screen and (max-width: 750px) {
  .pad100 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}

.pad80 {
  padding-top: 80px;
  padding-bottom: 80px;
}
@media only screen and (max-width: 750px) {
  .pad80 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}

.pad60 {
  padding-top: 60px;
  padding-bottom: 60px;
}

.pad60100 {
  padding-top: 60px;
  padding-bottom: 100px;
}
@media only screen and (max-width: 1180px) {
  .pad60100 {
    padding-bottom: 80px;
  }
}
@media only screen and (max-width: 750px) {
  .pad60100 {
    padding-bottom: 60px;
  }
}

.pt100 {
  padding-top: 100px;
}
@media only screen and (max-width: 1180px) {
  .pt100 {
    padding-top: 80px;
  }
}
@media only screen and (max-width: 750px) {
  .pt100 {
    padding-top: 60px;
  }
}

.pb100 {
  padding-bottom: 100px;
}
@media only screen and (max-width: 1180px) {
  .pb100 {
    padding-bottom: 80px;
  }
}
@media only screen and (max-width: 750px) {
  .pb100 {
    padding-bottom: 60px;
  }
}

/* Txthead */
.txthead-box {
  position: relative;
}
.txthead-box.mb40 {
  margin-bottom: 40px;
}
@media only screen and (max-width: 750px) {
  .txthead-box.mb40 {
    margin-bottom: 25px;
  }
}
.txthead-box.mb30 {
  margin-bottom: 30px;
}
@media only screen and (max-width: 750px) {
  .txthead-box.mb30 {
    margin-bottom: 25px;
  }
}
.txthead-box.mb25 {
  margin-bottom: 25px;
}
@media only screen and (max-width: 750px) {
  .txthead-box.mb25 {
    margin-bottom: 20px;
  }
}
.txthead-box.with-line-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}
.txthead-box.with-line-button.white > *:first-child {
  background-color: #fff;
}
.txthead-box.with-line-button.white .btn-box {
  background-color: #fff;
}
.txthead-box.with-line-button::after {
  content: "";
  position: absolute;
  z-index: -1;
  display: table;
  width: 100%;
  height: 1px;
  background-color: #CCCCCC;
}
.txthead-box.with-line-button > *:first-child {
  padding-right: 20px;
  background-color: #F6F6F6;
}
.txthead-box.with-line-button > *:first-child span {
  display: block;
  font-family: Helvetica Neue, Helvetica, serif;
  font-size: 1.4rem;
  line-height: 1.4rem;
  font-weight: bold;
  color: #FFB800;
  text-transform: uppercase;
}
@media only screen and (max-width: 1180px) {
  .txthead-box.with-line-button > *:first-child span {
    font-size: 1.2rem;
    line-height: 1.2rem;
  }
}
.txthead-box.with-line-button .btn-box {
  padding-left: 20px;
  background-color: #F6F6F6;
}
.txthead-box .fz48 {
  position: relative;
  z-index: 1;
  font-size: 4.8rem;
  line-height: 5.8rem;
}
@media only screen and (max-width: 1180px) {
  .txthead-box .fz48 {
    font-size: 3.8rem;
    line-height: 4.8rem;
  }
}
@media only screen and (max-width: 750px) {
  .txthead-box .fz48 {
    font-size: 2.8rem;
    line-height: 3.8rem;
  }
}
.txthead-box .fz36 {
  position: relative;
  z-index: 1;
  font-size: 3.6rem;
  line-height: 4.6rem;
}
@media only screen and (max-width: 1180px) {
  .txthead-box .fz36 {
    font-size: 2.6rem;
    line-height: 3.6rem;
  }
}
.txthead-box .fz36.with-hilight {
  line-height: 5.6rem;
}
@media only screen and (max-width: 1180px) {
  .txthead-box .fz36.with-hilight {
    line-height: 4.6rem;
  }
}
.txthead-box .fz36.with-hilight span {
  display: inline;
  position: relative;
  padding: 0 10px 8px 10px;
  background-image: url("/assets/images/commons/text-hilight.jpg");
  background-repeat: repeat-x;
  background-position: bottom left;
  background-size: 1px 22px;
}
@media only screen and (max-width: 1180px) {
  .txthead-box .fz36.with-hilight span {
    background-size: 1px 15px;
  }
}
.txthead-box .en-abs {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  z-index: -1;
  font-family: Helvetica Neue, Helvetica, serif;
  font-size: 12.8rem;
  line-height: 5rem;
  font-weight: bold;
  text-transform: uppercase;
  opacity: 0.2;
  mix-blend-mode: screen;
}
@media only screen and (max-width: 850px) {
  .txthead-box .en-abs {
    font-size: 9rem;
    line-height: 4rem;
  }
}
@media only screen and (max-width: 750px) {
  .txthead-box .en-abs {
    font-size: 5.5rem;
    line-height: 3.5rem;
  }
}
.txthead-box .en-abs-gray5 {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  z-index: -1;
  font-family: Helvetica Neue, Helvetica, serif;
  font-size: 12.8rem;
  line-height: 5rem;
  font-weight: bold;
  color: #F2F2F2;
  text-transform: uppercase;
}
@media only screen and (max-width: 850px) {
  .txthead-box .en-abs-gray5 {
    font-size: 9rem;
    line-height: 4rem;
  }
}
@media only screen and (max-width: 750px) {
  .txthead-box .en-abs-gray5 {
    font-size: 5.5rem;
    line-height: 3.5rem;
  }
}
.txthead-box .center {
  text-align: center;
}

/* Button */
.btn-box.mt60 {
  margin-top: 60px;
}
@media only screen and (max-width: 1180px) {
  .btn-box.mt60 {
    margin-top: 40px;
  }
}
@media only screen and (max-width: 750px) {
  .btn-box.mt60 {
    margin-top: 30px;
  }
}
.btn-box.mt40 {
  margin-top: 40px;
}
@media only screen and (max-width: 750px) {
  .btn-box.mt40 {
    margin-top: 30px;
  }
}
.btn-box.mt30 {
  margin-top: 30px;
}

.btn {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.btn .text.medium {
  font-size: 2rem;
  line-height: 3rem;
}
@media only screen and (max-width: 1180px) {
  .btn .text.medium {
    font-size: 1.8rem;
    line-height: 2.8rem;
  }
}
@media only screen and (max-width: 750px) {
  .btn .text.medium {
    font-size: 1.6rem;
    line-height: 2.6rem;
  }
}
.btn.square-radius {
  font-weight: bold;
  height: 60px;
  border-radius: 60px;
}
.btn.square {
  height: 50px;
  border-radius: 10px;
}
.btn.orange {
  color: #fff;
  background-color: #FE7D28;
}
.btn.white {
  color: #000;
  background-color: #fff;
}
.btn.white:hover {
  opacity: 1;
  color: #fff;
  background-color: #FE7D28;
}
.btn.white:hover .icon svg path {
  fill: #fff;
}
.btn.white-orange {
  color: #000;
  background-color: #fff;
}
.btn.white-orange:hover {
  opacity: 1;
  color: #FE7D28;
}
.btn.white-orange:hover .icon svg path {
  fill: #FE7D28;
}
.btn.black-border {
  color: #000;
  background-color: #fff;
  border: 1px solid #000;
}
.btn.black-border:hover {
  opacity: 1;
  color: #fff;
  background-color: #FE7D28;
  border-color: #FE7D28;
}
.btn.black-border:hover .icon svg path {
  fill: #fff;
}
.btn.black:hover {
  opacity: 1;
  color: #FE7D28;
  text-decoration: underline;
}
.btn.black:hover .icon svg path {
  fill: #FE7D28;
}
.btn.gray-border {
  border: 1px solid #ccc;
}
.btn.gray-border:hover {
  opacity: 1;
  color: #fff;
  border-color: #FE7D28;
  background-color: #FE7D28;
}
.btn.icon-left .icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.btn.icon-left .text {
  padding-left: 8px;
}
.btn.icon-right .icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.btn.icon-right .text {
  padding-right: 8px;
}
.btn.icon-right-abs .icon {
  position: absolute;
  right: 25px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.btn.icon-right-abs .text.medium {
  padding-right: 20px;
}
.btn.w-360 {
  width: 100%;
  max-width: 360px;
}
.btn.w-320 {
  width: 100%;
  max-width: 320px;
}
.btn.w-240 {
  width: 100%;
  max-width: 240px;
}
.btn.w-auto {
  padding-left: 25px;
  padding-right: 25px;
}
.btn.center {
  margin-left: auto;
  margin-right: auto;
}

.btn-page {
  margin-top: 60px;
}
.btn-page ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 100%;
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
}
.btn-page ul li.arrow {
  width: 50px;
  min-width: 50px;
}
.btn-page ul li.arrow a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 50px;
  height: 50px;
  border: 1px solid #000;
  border-radius: 100%;
}
.btn-page ul li.arrow a:hover {
  opacity: 1;
  border-color: #FE7D28;
}
.btn-page ul li.button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 100%;
}

/* Banner */
#banner .banner ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: -10px;
}
@media only screen and (max-width: 750px) {
  #banner .banner ul {
    display: block;
  }
}
#banner .banner ul li {
  margin: 10px 10px 0 10px;
  width: 30%;
  max-width: 241px;
}
@media only screen and (max-width: 750px) {
  #banner .banner ul li {
    margin: 0;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}
@media only screen and (max-width: 750px) {
  #banner .banner ul li + li {
    margin-top: 10px;
  }
}
#banner .banner ul li a {
  display: table;
}

/* Contact */
#contact {
  color: #fff;
  background-image: url("/assets/images/commons/contact-bg.jpg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
@media only screen and (max-width: 750px) {
  #contact .contact .content p {
    text-align: left;
  }
}

/* Breadcrumb */
#breadcrumb {
  border-top: 1px solid #E6E6E6;
}
#breadcrumb .breadcrumb {
  padding: 25px 40px;
}
@media only screen and (max-width: 1180px) {
  #breadcrumb .breadcrumb {
    padding: 20px 5%;
  }
}
#breadcrumb .breadcrumb ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
#breadcrumb .breadcrumb ul li {
  font-size: 1.4rem;
  line-height: 2rem;
  position: relative;
  padding-right: 20px;
  margin-right: 15px;
}
#breadcrumb .breadcrumb ul li::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  z-index: 1;
  display: table;
  margin-top: auto;
  margin-bottom: auto;
  width: 5px;
  height: 8px;
  background-image: url("/assets/images/commons/breadcrumb-arrow.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 5px;
}
#breadcrumb .breadcrumb ul li:last-child {
  padding-right: 0;
  margin-right: 0;
}
#breadcrumb .breadcrumb ul li:last-child::after {
  display: none;
}
#breadcrumb .breadcrumb ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-weight: 700;
}
#breadcrumb .breadcrumb ul li a:hover {
  text-decoration: underline;
}
#breadcrumb .breadcrumb ul li a .icon {
  margin-right: 5px;
}

/* MV Inner */
#mv-inner .mv-inner {
  position: relative;
}
#mv-inner .mv-inner .text {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 180px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (max-width: 750px) {
  #mv-inner .mv-inner .text {
    position: static;
    height: auto;
    padding-top: 30px;
    padding-bottom: 30px;
    margin-bottom: -30px;
  }
}
#mv-inner .mv-inner .text::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  display: table;
  margin-left: auto;
  margin-right: auto;
  width: 20px;
  height: 10px;
  background-color: #FE7D28;
  clip-path: polygon(50% 100%, 0 0, 100% 0);
}
#mv-inner .mv-inner .text h1 {
  font-size: 5.6rem;
  line-height: 6rem;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 1180px) {
  #mv-inner .mv-inner .text h1 {
    font-size: 4.6rem;
    line-height: 5rem;
  }
}
@media only screen and (max-width: 750px) {
  #mv-inner .mv-inner .text h1 {
    font-size: 3rem;
    line-height: 4rem;
  }
}
#mv-inner .mv-inner .text h1 .en {
  display: table;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 10px;
  font-size: 1.4rem;
  line-height: 1.6rem;
  font-weight: bold;
  text-align: center;
  color: #FFB800;
}
@media only screen and (max-width: 750px) {
  #mv-inner .mv-inner .text h1 .en {
    font-size: 1.2rem;
    line-height: 1.4rem;
  }
}
#mv-inner .mv-inner .img img {
  display: table;
  margin-left: auto;
  margin-right: auto;
  width: auto;
  min-height: 400px;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
}
@media only screen and (max-width: 750px) {
  #mv-inner .mv-inner .img img {
    min-height: auto;
  }
}

/* Submn Btm */
#submn-btm {
  padding: 40px 0;
  background-color: #FDF5F2;
}
#submn-btm .submn-btm ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
@media only screen and (max-width: 850px) {
  #submn-btm .submn-btm ul {
    margin-top: -2%;
  }
}
@media only screen and (max-width: 750px) {
  #submn-btm .submn-btm ul {
    display: block;
    margin-top: 0;
  }
}
#submn-btm .submn-btm ul li {
  width: 19%;
  margin: 0 0.5%;
}
@media only screen and (max-width: 850px) {
  #submn-btm .submn-btm ul li {
    width: 31.33%;
    margin: 2% 1% 0 1%;
  }
}
@media only screen and (max-width: 750px) {
  #submn-btm .submn-btm ul li {
    width: 100%;
    margin: 0;
  }
}
@media only screen and (max-width: 750px) {
  #submn-btm .submn-btm ul li + li {
    margin-top: 10px;
  }
}
#submn-btm .submn-btm ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 100%;
  height: 60px;
  border-radius: 30px;
  font-weight: 700;
  padding: 0 20px;
  line-height: 2rem;
  background-color: #fff;
  background-image: url("/assets/images/commons/submn-btm-arrow.svg");
  background-repeat: no-repeat;
  background-position: center right 20px;
  background-size: 11px 9px;
  text-align: center;
}
@media only screen and (max-width: 1180px) {
  #submn-btm .submn-btm ul li a {
    padding: 0 15px;
    background-position: center right 15px;
  }
}
#submn-btm .submn-btm ul li a:hover {
  opacity: 1;
  color: #FE7D28;
  background-image: url("/assets/images/commons/submn-btm-arrow-active.svg");
}

.active-submn-btm-01 .submn-btm-01,
.active-submn-btm-02 .submn-btm-02,
.active-submn-btm-03 .submn-btm-03,
.active-submn-btm-04 .submn-btm-04,
.active-submn-btm-05 .submn-btm-05 {
  color: #FE7D28 !important;
  background-image: url("/assets/images/commons/submn-btm-arrow-active.svg") !important;
}

/* Btn Scroll */
.btn-scroll.mb60 {
  margin-bottom: 60px;
}
.btn-scroll ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
@media only screen and (max-width: 850px) {
  .btn-scroll ul {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-top: -2%;
  }
}
@media only screen and (max-width: 750px) {
  .btn-scroll ul {
    display: block;
    margin-top: 0;
  }
}
@media only screen and (max-width: 850px) {
  .btn-scroll ul.col5 {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-top: -2%;
  }
}
@media only screen and (max-width: 750px) {
  .btn-scroll ul.col5 {
    display: block;
    margin-top: 0;
  }
}
.btn-scroll ul.col5 li {
  width: 18%;
}
@media only screen and (max-width: 850px) {
  .btn-scroll ul.col5 li {
    width: 49%;
    margin-top: 2%;
    margin-left: 0;
    margin-right: 0;
  }
}
@media only screen and (max-width: 750px) {
  .btn-scroll ul.col5 li {
    width: 100%;
    margin: 0;
  }
}
@media only screen and (max-width: 750px) {
  .btn-scroll ul.col5 li + li {
    margin-top: 10px;
  }
}
.btn-scroll ul.col-auto li {
  margin: 0 1%;
  width: auto;
  min-width: 240px;
}
.btn-scroll ul.col-auto li a {
  padding-left: 40px;
  padding-right: 20px;
}
@media only screen and (max-width: 850px) {
  .btn-scroll ul.col-auto li {
    width: 49%;
    margin-top: 2%;
    margin-left: 0;
    margin-right: 0;
  }
}
@media only screen and (max-width: 750px) {
  .btn-scroll ul.col-auto li {
    width: 100%;
    margin: 0;
  }
}
@media only screen and (max-width: 750px) {
  .btn-scroll ul.col-auto li + li {
    margin-top: 10px;
  }
}
.btn-scroll ul li {
  width: 23%;
  margin: 0 1%;
}
@media only screen and (max-width: 850px) {
  .btn-scroll ul li {
    width: 49%;
    margin-top: 2%;
    margin-left: 0;
    margin-right: 0;
  }
}
@media only screen and (max-width: 750px) {
  .btn-scroll ul li {
    width: 100%;
    margin: 0;
  }
}
@media only screen and (max-width: 750px) {
  .btn-scroll ul li + li {
    margin-top: 10px;
  }
}
.btn-scroll ul li a {
  padding-left: 20px;
  width: 100%;
  height: 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  border: 1px solid #000;
  font-weight: bold;
  background-image: url("/assets/images/commons/btn-scroll-arrow.svg");
  background-repeat: no-repeat;
  background-position: center left 15px;
  background-size: 10px 13px;
}
.btn-scroll ul li a:hover {
  opacity: 1;
  color: #FE7D28;
  background-image: url("/assets/images/commons/btn-scroll-arrow-orange.svg");
}

/* Subcat */
.subcat {
  margin-bottom: 60px;
}
@media only screen and (max-width: 750px) {
  .subcat {
    margin-bottom: 40px;
  }
}
.subcat ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media only screen and (max-width: 750px) {
  .subcat ul {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
.subcat ul li {
  width: 16.25%;
  margin: 0 3%;
}
@media only screen and (max-width: 750px) {
  .subcat ul li {
    width: 47.5%;
    margin: 0;
  }
}
.subcat ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 50px;
  font-weight: bold;
  border-bottom: 2px solid #ccc;
}
.subcat ul li a.current {
  color: #FE7D28;
  border-bottom-color: #FE7D28;
}

/* Header */
header {
  position: relative;
  top: 0;
  left: 0;
  z-index: 16;
  width: 100%;
  background-color: #fff;
}
@media only screen and (max-width: 1180px) {
  header {
    position: fixed;
    -webkit-box-shadow: 0px 0px 10px 5px rgba(0, 0, 0, 0.05);
    box-shadow: 0px 0px 10px 5px rgba(0, 0, 0, 0.05);
  }
}
header .header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 118px;
  padding: 0 40px;
}
@media only screen and (max-width: 1180px) {
  header .header {
    height: 90px;
    padding: 0 5%;
  }
}
@media only screen and (max-width: 750px) {
  header .header {
    height: 80px;
  }
}
@media only screen and (max-width: 1180px) {
  header .header .header-left {
    width: 240px;
  }
}
@media only screen and (max-width: 750px) {
  header .header .header-left {
    width: 200px;
  }
}
header .header .header-left .logo {
  display: block;
}
header .header .header-right .top {
  margin-bottom: 15px;
}
@media only screen and (max-width: 1180px) {
  header .header .header-right .top {
    display: none;
  }
}
header .header .header-right .top .link ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
header .header .header-right .top .link ul li + li {
  margin-left: 30px;
}
header .header .header-right .top .link ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
header .header .header-right .top .link ul li a:hover .icon svg path {
  fill: #FE7D28;
}
header .header .header-right .top .link ul li a:hover .text {
  color: #FE7D28;
}
header .header .header-right .top .link ul li a .icon {
  margin-right: 5px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
header .header .header-right .top .link ul li a .text {
  font-size: 1.3rem;
  line-height: 1.3rem;
  font-weight: 500;
  -webkit-transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
  transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
}
header .header .header-right .btm {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 45px;
}
header .header .header-right .btm .banner {
  margin-right: 40px;
  overflow: hidden;
}
@media only screen and (max-width: 1180px) {
  header .header .header-right .btm .banner {
    display: none;
  }
}
header .header .header-right .btm .banner a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 45px;
  padding-left: 15px;
  padding-right: 15px;
  background: rgb(158, 229, 255);
  background: -webkit-gradient(left top, right top, color-stop(0%, rgb(158, 229, 255)), color-stop(100%, rgb(205, 241, 255)));
  background: -webkit-gradient(linear, left top, right top, from(rgb(158, 229, 255)), to(rgb(205, 241, 255)));
  background: linear-gradient(to right, rgb(158, 229, 255) 0%, rgb(205, 241, 255) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#9ee5ff", endColorstr="#cdf1ff", GradientType=1 );
}
header .header .header-right .btm .banner a .cover {
  width: 47px;
}
header .header .header-right .btm .banner a .brief {
  padding-left: 5px;
  padding-right: 10px;
  background-image: url("/assets/images/commons/header-icon-arrow.svg");
  background-repeat: no-repeat;
  background-position: center right;
  background-size: 5px;
}
header .header .header-right .btm .banner a .brief p {
  font-size: 1.3rem;
  line-height: 1.6rem;
  font-weight: bold;
  color: #002740;
}
header .header .header-right .btm .banner a .brief p span {
  display: block;
  font-size: 0.9rem;
  line-height: 1.6rem;
}
@media only screen and (max-width: 1180px) {
  header .header .header-right .btm .mn {
    display: none;
  }
}
header .header .header-right .btm .mn ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
header .header .header-right .btm .mn ul li {
  position: relative;
}
header .header .header-right .btm .mn ul li + li {
  margin-left: 40px;
}
@media only screen and (max-width: 1280px) {
  header .header .header-right .btm .mn ul li + li {
    margin-left: 20px;
  }
}
header .header .header-right .btm .mn ul li a {
  position: relative;
  font-weight: bold;
  padding-bottom: 10px;
  /*&::after {
      content: '';
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      z-index: 1;
      display: table;
      margin-left: auto;
      margin-right: auto;
      width: 0px;
      height: 2px;
      background-color: $orange;
      -webkit-transition: all .2s cubic-bezier(.75, .30, .25, 1);
      -o-transition: all .2s cubic-bezier(.75, .30, .25, 1);
      transition: all .2s cubic-bezier(.75, .30, .25, 1);
  }*/
}
header .header .header-right .btm .mn ul li a:hover {
  opacity: 1;
  color: #FE7D28;
}
header .header .header-right .btm .mn ul li a:hover::after {
  width: 100%;
}
header .header .header-right .btm .mn ul li a.active {
  opacity: 1;
  color: #FE7D28;
}
header .header .header-right .btm .btn-burger {
  display: none;
}
@media only screen and (max-width: 1180px) {
  header .header .header-right .btm .btn-burger {
    display: block;
  }
}
header .header .header-right .btm .btn-burger .bar-icon {
  position: relative;
}
header .header .header-right .btm .btn-burger .bar-icon:hover {
  opacity: 1;
}
header .header .header-right .btm .btn-burger .bar-icon .bar1, header .header .header-right .btm .btn-burger .bar-icon .bar2, header .header .header-right .btm .btn-burger .bar-icon .bar3 {
  width: 30px;
  height: 1px;
  background-color: #000;
  margin: 9px 0;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}
header .header .header-right .btm .btn-burger .open .bar1 {
  background-color: #000;
  -webkit-transform: rotate(-45deg) translate(-7px, 7px);
  transform: rotate(-45deg) translate(-7px, 7px);
}
header .header .header-right .btm .btn-burger .open .bar2 {
  opacity: 0;
  background-color: #000;
}
header .header .header-right .btm .btn-burger .open .bar3 {
  background-color: #000;
  -webkit-transform: rotate(45deg) translate(-7px, -7px);
  transform: rotate(45deg) translate(-7px, -7px);
}

.active-mn-01 .mn-01,
.active-mn-02 .mn-02,
.active-mn-03 .mn-03,
.active-mn-04 .mn-04,
.active-mn-05 .mn-05,
.active-mn-06 .mn-06 {
  color: #FE7D28 !important;
}

.active-mn-top-01 .mn-top-01 .icon path,
.active-mn-top-02 .mn-top-02 .icon path {
  fill: #FE7D28 !important;
}
.active-mn-top-01 .mn-top-01 .text,
.active-mn-top-02 .mn-top-02 .text {
  color: #FE7D28 !important;
}

.menu-responsive {
  opacity: 0;
  visibility: hidden;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 15;
  padding-top: 80px;
  width: 100%;
  height: 100%;
  overflow: auto;
  background-color: #fff;
  border-top: 1px solid #FFDAB2;
  -webkit-transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
  transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
  display: none;
}
@media only screen and (max-width: 1180px) {
  .menu-responsive {
    display: block;
  }
}
.menu-responsive.active {
  opacity: 1;
  visibility: visible;
}
.menu-responsive .banner {
  margin: 5%;
  background: rgb(158, 229, 255);
  background: -webkit-gradient(left top, right top, color-stop(0%, rgb(158, 229, 255)), color-stop(100%, rgb(205, 241, 255)));
  background: -webkit-gradient(linear, left top, right top, from(rgb(158, 229, 255)), to(rgb(205, 241, 255)));
  background: linear-gradient(to right, rgb(158, 229, 255) 0%, rgb(205, 241, 255) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#9ee5ff", endColorstr="#cdf1ff", GradientType=1 );
}
.menu-responsive .banner a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 20px;
  background-image: url("/assets/images/commons/header-banner-arrow.svg");
  background-repeat: no-repeat;
  background-position: center right 20px;
  background-size: 10px 20px;
}
.menu-responsive .banner a .text {
  padding-left: 15px;
  font-size: 1.6rem;
  line-height: 2.6rem;
  color: #002740;
  font-weight: bold;
}
.menu-responsive .banner a .text span {
  display: block;
  font-size: 2.4rem;
}
.menu-responsive nav > ul > li {
  border-bottom: 1px solid #FFDAB2;
}
.menu-responsive nav > ul > li > a {
  display: block;
  padding: 20px 5%;
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: bold;
  background-image: url("/assets/images/commons/btn-arrow-right.svg");
  background-repeat: no-repeat;
  background-position: center right 5%;
  background-size: 18px 9px;
}
.menu-responsive nav > ul > li > a.toggle-btn {
  background-image: url("/assets/images/commons/header-icon-toggle-close.svg");
  background-size: 18px;
}
.menu-responsive nav > ul > li > a.toggle-btn.active {
  background-image: url("/assets/images/commons/header-icon-toggle-open.svg");
  background-color: #FEF7F3;
}
.menu-responsive nav > ul > li .toggle-content {
  display: none;
  padding: 0 5%;
  background-color: #FEF7F3;
}
.menu-responsive nav > ul > li .toggle-content ul li {
  border-top: 1px solid #FFDAB2;
}
.menu-responsive nav > ul > li .toggle-content ul li a {
  display: block;
  padding: 15px 10px;
  font-size: 2rem;
  line-height: 3rem;
  background-image: url("/assets/images/commons/header-banner-arrow.svg");
  background-repeat: no-repeat;
  background-position: center right 10px;
  background-size: 7px 12px;
}

.dropdown {
  opacity: 0;
  visibility: hidden;
  position: absolute;
  top: 108px;
  left: 145px;
  right: 0;
  z-index: 17;
  display: table;
  margin-left: auto;
  margin-right: auto;
  width: 90%;
  width: 946px;
  background-color: #fff;
  border: 1px solid #FFEFE3;
  -webkit-transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
  transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
}
.dropdown.active {
  top: 118px;
  opacity: 1;
  visibility: visible;
}
@media only screen and (max-width: 1180px) {
  .dropdown {
    display: none;
  }
}
.dropdown::before {
  content: "";
  position: absolute;
  top: -15px;
  left: 0;
  right: 0;
  z-index: 1;
  display: table;
  margin-left: auto;
  margin-right: auto;
  width: 26px;
  height: 15px;
  background-image: url("/assets/images/commons/dropdown-arrow-top.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 26px 15px;
}
.dropdown .title {
  display: table;
}
.dropdown .title a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 70px;
  padding: 0 10px;
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: bold;
}
.dropdown .title a span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-left: 10px;
}
.dropdown .title a:hover {
  color: #FE7D28;
}
.dropdown .title a:hover span svg path {
  fill: #FE7D28;
}
.dropdown ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 0 1.25%;
}
.dropdown ul li {
  width: 24%;
}
.dropdown ul li a {
  display: block;
}
.dropdown ul li a:hover {
  opacity: 1;
}
.dropdown ul li a:hover .cover img {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
.dropdown ul li a:hover p {
  color: #FE7D28;
}
.dropdown ul li a .cover {
  overflow: hidden;
}
.dropdown ul li a p {
  font-weight: bold;
  padding: 10px 10px;
  -webkit-transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
  transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
}
.dropdown .dropdown-close {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 40px;
  font-weight: bold;
  background-color: #FFEFE3;
}
.dropdown .dropdown-close:hover {
  opacity: 1;
  color: #FE7D28;
}
.dropdown .dropdown-close:hover span svg path {
  fill: #FE7D28;
}
.dropdown .dropdown-close span {
  margin-right: 6px;
}

/* Footer */
footer {
  position: relative;
  z-index: 14;
  padding-top: 60px;
  padding-bottom: 30px;
  background-color: #fff;
}
@media only screen and (max-width: 850px) {
  footer {
    padding-top: 40px;
  }
}
footer .footer .flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
footer .footer .flex .col-left {
  width: 260px;
  min-width: 260px;
}
@media only screen and (max-width: 850px) {
  footer .footer .flex .col-left {
    width: 100%;
    min-width: 100%;
  }
}
footer .footer .flex .col-left .logo {
  display: block;
}
@media only screen and (max-width: 1180px) {
  footer .footer .flex .col-left .logo {
    width: 240px;
  }
}
@media only screen and (max-width: 750px) {
  footer .footer .flex .col-left .logo {
    width: 200px;
  }
}
footer .footer .flex .col-left .address {
  margin: 20px 0;
}
footer .footer .flex .col-left .address p {
  font-size: 1.4rem;
  line-height: 2.4rem;
  font-weight: bold;
}
footer .footer .flex .col-left .sns {
  position: relative;
}
footer .footer .flex .col-left .sns::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: -1;
  display: table;
  margin-top: auto;
  margin-bottom: auto;
  width: 100%;
  height: 1px;
  background-color: #E6E6E6;
}
footer .footer .flex .col-left .sns ul {
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
footer .footer .flex .col-left .sns ul li {
  padding-right: 10px;
  background-color: #fff;
}
footer .footer .flex .col-left .sns ul li a {
  display: block;
}
footer .footer .flex .col-right {
  width: 100%;
  padding-top: 5px;
  padding-left: 100px;
}
@media only screen and (max-width: 850px) {
  footer .footer .flex .col-right {
    display: none;
  }
}
footer .footer .flex .col-right .sitemap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-left: -40px;
}
@media only screen and (max-width: 1180px) {
  footer .footer .flex .col-right .sitemap {
    margin-left: -20px;
  }
}
footer .footer .flex .col-right .sitemap ul {
  margin-left: 40px;
}
@media only screen and (max-width: 1180px) {
  footer .footer .flex .col-right .sitemap ul {
    margin-left: 20px;
  }
}
footer .footer .flex .col-right .sitemap ul li {
  position: relative;
  padding-left: 18px;
}
footer .footer .flex .col-right .sitemap ul li::before {
  content: "";
  position: absolute;
  top: 10px;
  left: 0;
  z-index: 1;
  width: 7px;
  height: 7px;
  background-color: #FFB800;
  border-radius: 100%;
}
footer .footer .flex .col-right .sitemap ul li a {
  display: block;
  font-weight: bold;
}
footer .footer .flex .col-right .sitemap ul li a:hover {
  text-decoration: underline;
}
footer .footer .flex .col-right .sitemap ul li ul {
  margin-top: 5px;
  margin-left: 0;
}
footer .footer .flex .col-right .sitemap ul li ul li {
  margin-top: 0;
  padding-left: 12px;
  font-size: 1.3rem;
  line-height: 2.3rem;
}
footer .footer .flex .col-right .sitemap ul li ul li::before {
  content: "•";
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: auto;
  height: auto;
  background-color: transparent;
  color: #CCCCCC;
}
footer .footer .flex .col-right .sitemap ul li + li {
  margin-top: 30px;
}
footer .footer .copyright {
  margin-top: 80px;
  font-size: 1rem;
  line-height: 1.6rem;
  text-align: center;
}
@media only screen and (max-width: 850px) {
  footer .footer .copyright {
    margin-top: 40px;
  }
}

/* MV */
#mv {
  position: relative;
  padding-bottom: 90px;
}
@media only screen and (max-width: 750px) {
  #mv {
    padding-bottom: 0;
  }
}
#mv .mv {
  position: relative;
  padding: 0 20px;
}
@media only screen and (max-width: 750px) {
  #mv .mv {
    padding: 5% 5% 0 5%;
  }
}
#mv .mv .mv-slick .slick-slide > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#mv .mv .mv-slick .item .mv-img {
  display: table;
  overflow: hidden;
  width: 64.285%;
  max-width: 900px;
}
@media only screen and (max-width: 750px) {
  #mv .mv .mv-slick .item .mv-img {
    width: 100%;
  }
}
#mv .mv .mv-slick .item .mv-img img {
  min-height: 727px;
  -o-object-fit: cover;
  object-fit: cover;
}
@media only screen and (max-width: 1180px) {
  #mv .mv .mv-slick .item .mv-img img {
    min-height: 627px;
  }
}
@media only screen and (max-width: 750px) {
  #mv .mv .mv-slick .item .mv-img img {
    min-height: auto;
  }
}
#mv .mv .mv-slick .item .mv-text {
  position: absolute;
  top: 80px;
  right: 0;
  z-index: 1;
  width: 100%;
  max-width: 660px;
  display: table;
  padding: 80px 70px;
  color: #fff;
  background: rgba(254, 125, 40, 0.9);
  background: -webkit-gradient(left top, right bottom, color-stop(0%, rgba(254, 125, 40, 0.9)), color-stop(100%, rgba(255, 184, 0, 0.9)));
  background: linear-gradient(135deg, rgba(254, 125, 40, 0.9) 0%, rgba(255, 184, 0, 0.9) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#fe7d28", endColorstr="#ffb800", GradientType=1 );
}
@media only screen and (max-width: 1180px) {
  #mv .mv .mv-slick .item .mv-text {
    padding: 60px 50px;
    max-width: 454px;
  }
}
@media only screen and (max-width: 750px) {
  #mv .mv .mv-slick .item .mv-text {
    position: static;
    padding: 30px;
  }
}
#mv .mv .mv-slick .item .mv-text h1 {
  font-size: 6.4rem;
  line-height: 8rem;
  font-weight: bold;
  margin-bottom: 30px;
}
@media only screen and (max-width: 1180px) {
  #mv .mv .mv-slick .item .mv-text h1 {
    font-size: 4.4rem;
    line-height: 6rem;
    margin-bottom: 20px;
  }
}
@media only screen and (max-width: 750px) {
  #mv .mv .mv-slick .item .mv-text h1 {
    font-size: 3rem;
    line-height: 4rem;
    margin-bottom: 15px;
  }
}
#mv .mv .mv-slick .item .mv-text p {
  font-size: 2rem;
  line-height: 3rem;
  font-weight: bold;
}
#mv .mv .mv-slick-arrow {
  position: absolute;
  bottom: 0;
  left: 65.5%;
  z-index: 8;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media only screen and (max-width: 750px) {
  #mv .mv .mv-slick-arrow {
    position: static;
    margin-top: 20px;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}
#mv .mv .mv-slick-arrow a {
  width: 60px;
  height: 60px;
  border: 1px solid #000;
  border-radius: 100%;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 18px;
}
@media only screen and (max-width: 1180px) {
  #mv .mv .mv-slick-arrow a {
    width: 50px;
    height: 50px;
  }
}
#mv .mv .mv-slick-arrow a:hover {
  opacity: 1;
  border-color: #FE7D28;
}
#mv .mv .mv-slick-arrow a.mv-slick-arrow-prev {
  background-image: url("/assets/images/commons/btn-arrow-left.svg");
}
#mv .mv .mv-slick-arrow a.mv-slick-arrow-next {
  margin-left: 10px;
  background-image: url("/assets/images/commons/btn-arrow-right.svg");
}
#mv .mv-arrow {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  display: table;
  margin-left: auto;
  margin-right: auto;
  width: 115px;
}
@media only screen and (max-width: 1180px) {
  #mv .mv-arrow {
    width: 80px;
  }
}
@media only screen and (max-width: 750px) {
  #mv .mv-arrow {
    display: none;
  }
}
#mv .mv-arrow img {
  position: relative;
  -webkit-animation: jumpInfinite 1.5s infinite;
  animation: jumpInfinite 1.5s infinite;
}
@-webkit-keyframes jumpInfinite {
  0% {
    top: 0;
  }
  50% {
    top: 15px;
  }
  100% {
    top: 0;
  }
}
@keyframes jumpInfinite {
  0% {
    top: 0;
  }
  50% {
    top: 15px;
  }
  100% {
    top: 0;
  }
}

/* objective */
#objective {
  padding: 0 10px;
}
@media only screen and (max-width: 750px) {
  #objective {
    padding: 0;
  }
}
#objective .objective {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  max-width: 628px;
}
@media only screen and (max-width: 750px) {
  #objective .objective {
    padding-top: 60px;
    padding-left: 5%;
    padding-right: 5%;
  }
}
#objective .objective .col-img {
  position: absolute;
  top: 0;
  left: -400px;
  z-index: 1;
  width: 380px;
}
#objective .objective .col-img.right {
  left: inherit;
  right: -400px;
}
#objective .objective .col-img ul li + li {
  margin-top: 10px;
}
#objective .objective .col-text {
  position: relative;
  z-index: 8;
  width: 100%;
  max-width: 628px;
  min-height: 740px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 40px;
}
@media only screen and (max-width: 750px) {
  #objective .objective .col-text {
    padding-top: 0;
    min-height: auto;
  }
}
#objective .objective .col-text .icon-circle {
  display: table;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 40px;
}
@media only screen and (max-width: 750px) {
  #objective .objective .col-text .icon-circle {
    width: 42px;
    margin-bottom: 10px;
  }
}
#objective .objective .col-text h2 {
  position: relative;
  margin-bottom: 60px;
  padding-top: 40px;
}
@media only screen and (max-width: 850px) {
  #objective .objective .col-text h2 {
    margin-bottom: 40px;
  }
}
@media only screen and (max-width: 750px) {
  #objective .objective .col-text h2 {
    margin-bottom: 20px;
  }
}
#objective .objective .col-text h2 img {
  width: 88.216%;
  max-width: 554px;
  margin-left: auto;
  margin-right: auto;
}
#objective .objective .col-text h2 span {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: -1;
  display: table;
  margin: auto;
  font-family: Helvetica Neue, Helvetica, serif;
  font-size: 9.6rem;
  line-height: 9rem;
  font-weight: bold;
  color: #F2F2F2;
  text-align: center;
}
@media only screen and (max-width: 850px) {
  #objective .objective .col-text h2 span {
    font-size: 8rem;
    line-height: 8rem;
  }
}
@media only screen and (max-width: 750px) {
  #objective .objective .col-text h2 span {
    font-size: 5rem;
    line-height: 5rem;
  }
}
#objective .objective .col-text p {
  text-align: center;
}
@media only screen and (max-width: 750px) {
  #objective .objective .col-text p {
    text-align: left;
  }
}

/* Vision */
#vision .vision {
  position: relative;
  /*padding-top: 150px;*/
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media only screen and (max-width: 1180px) {
  #vision .vision {
    padding-right: 5%;
  }
}
@media only screen and (max-width: 850px) {
  #vision .vision {
    /*padding-top: 60px;*/
  }
}
@media only screen and (max-width: 750px) {
  #vision .vision {
    display: block;
    padding-left: 5%;
  }
}
#vision .vision .col-left {
  width: 55.972%;
  max-width: 806px;
}
@media only screen and (max-width: 1180px) {
  #vision .vision .col-left {
    width: 52.5%;
  }
}
@media only screen and (max-width: 750px) {
  #vision .vision .col-left {
    width: 100%;
  }
}
#vision .vision .col-right {
  width: 30.222%;
  margin-left: 3.5%;
}
@media only screen and (max-width: 1180px) {
  #vision .vision .col-right {
    width: 47.5%;
    margin-left: 0;
    padding-left: 3.5%;
  }
}
@media only screen and (max-width: 750px) {
  #vision .vision .col-right {
    width: 100%;
    padding: 0;
    margin-top: 25px;
  }
}
#vision .vision .qoute {
  position: absolute;
  top: 0;
  left: 130px;
  z-index: -1;
  font-family: Helvetica Neue, Helvetica, serif;
  font-size: 12.8rem;
  line-height: 12rem;
  font-weight: bold;
  color: #F2F2F2;
}
@media only screen and (max-width: 850px) {
  #vision .vision .qoute {
    font-size: 6rem;
    line-height: 5rem;
    left: 5%;
  }
}
@media only screen and (max-width: 750px) {
  #vision .vision .qoute {
    font-size: 4rem;
    line-height: 4rem;
  }
}
#vision .vision .qoute span {
  display: block;
  margin-left: 360px;
}
@media only screen and (max-width: 850px) {
  #vision .vision .qoute span {
    margin-left: 170px;
  }
}
@media only screen and (max-width: 750px) {
  #vision .vision .qoute span {
    margin-left: 100px;
  }
}

/* Brand */
#brand {
  padding-bottom: 160px;
  background-color: #FDF5F2;
}
@media only screen and (max-width: 1180px) {
  #brand {
    padding-bottom: 140px;
  }
}
@media only screen and (max-width: 750px) {
  #brand {
    padding-bottom: 80px;
  }
}
#brand .brand {
  position: relative;
  max-width: 1192px;
}
@media only screen and (max-width: 750px) {
  #brand .brand .content > p {
    text-align: left;
  }
}

.brand-list {
  margin-top: 60px;
}
@media only screen and (max-width: 750px) {
  .brand-list {
    margin-top: 30px;
  }
}
.brand-list ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: -20px;
  margin-left: -1.66%;
}
@media only screen and (max-width: 750px) {
  .brand-list ul {
    margin-top: -15px;
    margin-left: -3%;
  }
}
.brand-list ul li {
  width: 15%;
  max-width: 180px;
  margin-top: 20px;
  margin-left: 1.66%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media only screen and (max-width: 850px) {
  .brand-list ul li {
    width: 31.33%;
    margin-left: 1%;
    margin-right: 1%;
  }
}
@media only screen and (max-width: 750px) {
  .brand-list ul li {
    width: 30.33%;
    margin-left: 3%;
    margin-right: 0;
    margin-top: 15px;
  }
}
.brand-list ul li .box {
  display: block;
}
.brand-list ul li .box:hover .logo img {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}
.brand-list ul li .box:hover .name {
  text-decoration: underline;
}
.brand-list ul li .box .logo {
  border: 1px solid #FE7D28;
  overflow: hidden;
}
.brand-list ul li .box .name {
  margin-top: 8px;
  font-size: 1.4rem;
  line-height: 2.4rem;
  font-weight: bold;
  text-align: center;
  height: 48px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

/* Business */
#business {
  position: relative;
  z-index: 8;
  padding-bottom: 160px;
}
@media only screen and (max-width: 1180px) {
  #business {
    padding-bottom: 80px;
  }
}
#business .qoute {
  position: absolute;
  left: 0;
  top: -55px;
  z-index: 1;
  font-family: Helvetica Neue, Helvetica, serif;
  font-size: 12.8rem;
  line-height: 10rem;
  width: 100%;
  height: 210px;
  font-weight: bold;
  background: #FFB800;
  background: -webkit-gradient(linear, right bottom, left top, from(#FFB800), to(#FE7D28));
  background: linear-gradient(to top left, #FFB800 0%, #FE7D28 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-transform: uppercase;
  text-align: center;
}
@media only screen and (max-width: 850px) {
  #business .qoute {
    top: -37px;
    font-size: 8rem;
    line-height: 7rem;
  }
}
@media only screen and (max-width: 750px) {
  #business .qoute {
    top: -23px;
    font-size: 5rem;
    line-height: 4.5rem;
  }
}
#business .business {
  padding-top: 120px;
}
@media only screen and (max-width: 850px) {
  #business .business {
    padding-top: 80px;
  }
}
@media only screen and (max-width: 750px) {
  #business .business {
    padding-top: 45px;
  }
}
#business .business .txthead-box h2 span {
  padding: 20px;
  background-color: #fff;
}
#business .business .content h3 {
  margin-top: -5px;
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 30px;
}
@media only screen and (max-width: 1180px) {
  #business .business .content h3 {
    font-size: 2rem;
    line-height: 3rem;
  }
}
#business .business .content h3 span {
  padding: 6px 17px;
  background-color: #fff;
}
#business .business .content > p {
  color: #fff;
  text-shadow: 0px 1px 2px rgba(0, 0, 0, 0.35);
}
@media only screen and (max-width: 750px) {
  #business .business .content > p {
    text-align: left;
  }
}
#business .business .content .business-list {
  margin-top: 60px;
}
@media only screen and (max-width: 750px) {
  #business .business .content .business-list {
    margin-top: 30px;
  }
}
#business .business .content .business-list ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
@media only screen and (max-width: 750px) {
  #business .business .content .business-list ul {
    display: block;
  }
}
#business .business .content .business-list ul li {
  width: 47.07%;
  max-width: 482px;
  background-color: #fff;
  border-radius: 16px;
}
@media only screen and (max-width: 750px) {
  #business .business .content .business-list ul li {
    width: 100%;
    max-width: 100%;
  }
}
@media only screen and (max-width: 750px) {
  #business .business .content .business-list ul li + li {
    margin-top: 5%;
  }
}
#business .business .content .business-list ul li a {
  display: block;
  height: 100%;
  overflow: hidden;
  background-color: #fff;
  -webkit-box-shadow: 0px 8px 12px 0px rgba(0, 0, 0, 0.15);
  box-shadow: 0px 8px 12px 0px rgba(0, 0, 0, 0.15);
}
#business .business .content .business-list ul li a:hover .cover img {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}
#business .business .content .business-list ul li a .cover {
  overflow: hidden;
}
#business .business .content .business-list ul li a .brief {
  padding: 20px;
}
#business .business .content .business-list ul li a .brief h4 {
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: bold;
  margin-bottom: 10px;
  background-image: url("/assets/images/commons/btn-arrow-right.svg");
  background-repeat: no-repeat;
  background-position: center right;
  background-size: 18px;
}
@media only screen and (max-width: 1180px) {
  #business .business .content .business-list ul li a .brief h4 {
    font-size: 2rem;
    line-height: 3rem;
  }
}
#business .business .content .business-list ul li a .brief p {
  font-size: 1.4rem;
  line-height: 2.4rem;
  font-weight: bold;
}
#business .business-bg {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 551px;
}
#business .business-bg img {
  width: 100%;
  max-height: 551px;
  min-height: 551px;
  -o-object-fit: cover;
  object-fit: cover;
}

/* Recruit */
#recruit {
  position: relative;
  z-index: 8;
  background: rgb(254, 125, 40);
  background: -webkit-gradient(left top, right bottom, color-stop(0%, rgb(254, 125, 40)), color-stop(100%, rgb(255, 184, 0)));
  background: linear-gradient(135deg, rgb(254, 125, 40) 0%, rgb(255, 184, 0) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#fe7d28", endColorstr="#ffb800", GradientType=1 );
}
#recruit .recruit {
  position: relative;
  display: table;
  padding-top: 100px;
  padding-right: 30px;
}
@media only screen and (max-width: 750px) {
  #recruit .recruit {
    padding-top: 30px;
    padding-bottom: 60px;
    padding-right: 5%;
  }
}
#recruit .recruit .recruit-abs {
  position: absolute;
  left: 0;
  right: 0;
  z-index: 9;
  width: 90%;
  max-width: 1024px;
  height: 100%;
  display: -webkit-box;
  margin-left: auto;
  margin-right: auto;
  padding-top: 25px;
  color: #fff;
}
@media only screen and (max-width: 750px) {
  #recruit .recruit .recruit-abs {
    position: relative;
  }
}
#recruit .recruit .recruit-abs .content {
  width: 34%;
}
@media only screen and (max-width: 750px) {
  #recruit .recruit .recruit-abs .content {
    width: 100%;
  }
}
#recruit .recruit .recruit-abs .content .recruit-img-sp {
  display: none;
  margin-bottom: 25px;
}
@media only screen and (max-width: 750px) {
  #recruit .recruit .recruit-abs .content .recruit-img-sp {
    display: block;
  }
}
#recruit .recruit .recruit-abs .content .recruit-img-sp img {
  border-radius: 28px;
}
@media only screen and (max-width: 750px) {
  #recruit .recruit .recruit-abs .content .btn-box a {
    margin-left: auto;
    margin-right: auto;
  }
}
#recruit .recruit .recruit-abs .handwrite {
  position: absolute;
  bottom: -12.5%;
  left: 2.5%;
  z-index: 8;
  width: 81.152%;
  max-width: 831px;
}
@media only screen and (max-width: 1180px) {
  #recruit .recruit .recruit-abs .handwrite {
    bottom: -2.5%;
  }
}
@media only screen and (max-width: 750px) {
  #recruit .recruit .recruit-abs .handwrite {
    display: none;
  }
}
#recruit .recruit .recruit-img {
  position: relative;
  z-index: 8;
  display: -webkit-box;
  width: 57.222%;
  max-width: 824px;
  margin-left: auto;
  margin-bottom: -150px;
}
@media only screen and (max-width: 750px) {
  #recruit .recruit .recruit-img {
    display: none;
  }
}
#recruit .recruit .recruit-img img {
  min-height: 545px;
  -o-object-fit: cover;
  object-fit: cover;
}

/* Store & Notice */
#store-notice {
  position: relative;
  z-index: 1;
}
#store-notice::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 40%;
  height: 100%;
  background-color: #FDF5F2;
}
@media only screen and (max-width: 750px) {
  #store-notice::after {
    display: none;
  }
}
#store-notice .store-notice {
  position: relative;
  padding-top: 270px;
  padding-bottom: 140px;
}
@media only screen and (max-width: 1180px) {
  #store-notice .store-notice {
    padding-top: 160px;
    padding-bottom: 80px;
  }
}
@media only screen and (max-width: 750px) {
  #store-notice .store-notice {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}
#store-notice .store-notice::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 50%;
  height: 100%;
  background-color: #FDF5F2;
}
@media only screen and (max-width: 750px) {
  #store-notice .store-notice::after {
    display: none;
  }
}
#store-notice .store-notice .flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
@media only screen and (max-width: 750px) {
  #store-notice .store-notice .flex {
    display: block;
  }
}
#store-notice .store-notice .flex .col {
  width: 47.07%;
  max-width: 482px;
}
@media only screen and (max-width: 750px) {
  #store-notice .store-notice .flex .col {
    width: 100%;
    max-width: 100%;
  }
}
@media only screen and (max-width: 750px) {
  #store-notice .store-notice .flex .col.store .txthead-box h2 {
    background-color: #fff;
  }
}
@media only screen and (max-width: 750px) {
  #store-notice .store-notice .flex .col.store .txthead-box .btn-box {
    background-color: #fff;
  }
}
@media only screen and (max-width: 750px) {
  #store-notice .store-notice .flex .col.notice {
    margin-top: 60px;
  }
}
#store-notice .store-notice .flex .col.notice .txthead-box h2 {
  background-color: #fff;
}
#store-notice .store-notice .flex .col.notice .txthead-box .btn-box {
  background-color: #fff;
}
#store-notice .store-notice .flex .col .store-notice-list ul li + li {
  margin-top: 40px;
}
@media only screen and (max-width: 750px) {
  #store-notice .store-notice .flex .col .store-notice-list ul li + li {
    margin-top: 20px;
  }
}
#store-notice .store-notice .flex .col .store-notice-list ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
#store-notice .store-notice .flex .col .store-notice-list ul li a:hover .cover img {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}
#store-notice .store-notice .flex .col .store-notice-list ul li a:hover .brief .topic {
  text-decoration: underline;
}
#store-notice .store-notice .flex .col .store-notice-list ul li a .cover {
  overflow: hidden;
  width: 44.2%;
  max-width: 213px;
}
@media only screen and (max-width: 750px) {
  #store-notice .store-notice .flex .col .store-notice-list ul li a .cover {
    width: 39.2%;
  }
}
#store-notice .store-notice .flex .col .store-notice-list ul li a .brief {
  width: 49.8%;
}
@media only screen and (max-width: 750px) {
  #store-notice .store-notice .flex .col .store-notice-list ul li a .brief {
    width: 54.8%;
  }
}
#store-notice .store-notice .flex .col .store-notice-list ul li a .brief .date {
  font-size: 1.4rem;
  line-height: 2.4rem;
  margin-bottom: 10px;
}
@media only screen and (max-width: 750px) {
  #store-notice .store-notice .flex .col .store-notice-list ul li a .brief .date {
    margin-bottom: 5px;
  }
}
#store-notice .store-notice .flex .col .store-notice-list ul li a .brief .topic {
  font-weight: bold;
}

/* Blog */
#blog {
  overflow: hidden;
}
#blog .blog {
  position: relative;
}
#blog .blog::after {
  content: "";
  position: absolute;
  top: 0;
  left: -2000px;
  z-index: 1;
  width: 2000px;
  height: 100%;
  background-color: #fff;
}
#blog .blog .content .blog-slick {
  position: relative;
  padding-bottom: 120px;
}
@media only screen and (max-width: 750px) {
  #blog .blog .content .blog-slick {
    padding-bottom: 80px;
  }
}
#blog .blog .content .blog-slick .slick-list {
  margin: 0 -20px;
  overflow: visible;
}
@media only screen and (max-width: 750px) {
  #blog .blog .content .blog-slick .slick-list {
    margin: 0 -10px;
  }
}
#blog .blog .content .blog-slick .slick-slide {
  margin: 0 20px;
}
@media only screen and (max-width: 750px) {
  #blog .blog .content .blog-slick .slick-slide {
    margin: 0 10px;
  }
}
#blog .blog .content .blog-slick .slick-slide > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#blog .blog .content .blog-slick .slick-dots {
  position: absolute;
  bottom: 28px;
  left: 0;
  z-index: 7;
  width: 100%;
  padding-right: 165px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media only screen and (max-width: 1180px) {
  #blog .blog .content .blog-slick .slick-dots {
    bottom: 23px;
    padding-right: 125px;
  }
}
#blog .blog .content .blog-slick .slick-dots li {
  width: 100%;
}
#blog .blog .content .blog-slick .slick-dots li.slick-active button {
  background-color: #000;
}
#blog .blog .content .blog-slick .slick-dots li button {
  display: block;
  width: 100%;
  height: 1px;
  font-size: 0;
  line-height: 0;
  background-color: #E6E6E6;
  border: 0;
  outline: none;
  -webkit-transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
  transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
}
#blog .blog .content .blog-slick .slick-arrow {
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 8;
  width: 58px;
  height: 58px;
  border: 1px solid #000;
  border-radius: 100%;
  color: transparent;
  outline: none;
  font-size: 0;
  line-height: 0;
  background-color: transparent;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
  transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
}
@media only screen and (max-width: 1180px) {
  #blog .blog .content .blog-slick .slick-arrow {
    width: 48px;
    height: 48px;
  }
}
#blog .blog .content .blog-slick .slick-arrow:hover {
  cursor: pointer;
  border-color: #FE7D28;
}
#blog .blog .content .blog-slick .slick-arrow.slick-disabled {
  border-color: #CCCCCC !important;
}
#blog .blog .content .blog-slick .slick-arrow.slick-prev {
  right: 80px;
  background-image: url("/assets/images/commons/btn-arrow-left.svg");
}
@media only screen and (max-width: 1180px) {
  #blog .blog .content .blog-slick .slick-arrow.slick-prev {
    right: 60px;
  }
}
#blog .blog .content .blog-slick .slick-arrow.slick-next {
  background-image: url("/assets/images/commons/btn-arrow-right.svg");
}
#blog .blog .content .blog-slick .item a {
  display: block;
}
#blog .blog .content .blog-slick .item a:hover .cover img {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}
#blog .blog .content .blog-slick .item a:hover .brief .topic {
  text-decoration: underline;
}
#blog .blog .content .blog-slick .item a .cover {
  overflow: hidden;
}
#blog .blog .content .blog-slick .item a .brief {
  margin-top: 30px;
}
@media only screen and (max-width: 750px) {
  #blog .blog .content .blog-slick .item a .brief {
    margin-top: 15px;
  }
}
#blog .blog .content .blog-slick .item a .brief .date {
  font-size: 1.4rem;
  line-height: 2.4rem;
  margin-bottom: 10px;
}
@media only screen and (max-width: 750px) {
  #blog .blog .content .blog-slick .item a .brief .date {
    margin-bottom: 5px;
  }
}
#blog .blog .content .blog-slick .item a .brief .topic {
  font-weight: 700;
}

/* About */
#about .about p {
  text-align: center;
}
#about .about .list-link {
  margin-top: 30px;
}
#about .about .list-link ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-top: -2.93%;
}
#about .about .list-link ul li {
  width: 48.535%;
  max-width: 497px;
  margin-top: 2.93%;
  -webkit-box-shadow: 6px 6px 12px 0px rgba(0, 0, 0, 0.1);
  box-shadow: 6px 6px 12px 0px rgba(0, 0, 0, 0.1);
}
#about .about .list-link ul li a {
  display: block;
  position: relative;
}
#about .about .list-link ul li a:hover {
  opacity: 1;
}
#about .about .list-link ul li a:hover .button h2 {
  color: #FE7D28;
}
#about .about .list-link ul li a:hover .button .arrow svg path {
  fill: #FE7D28;
}
#about .about .list-link ul li a:hover .cover img {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}
#about .about .list-link ul li a .cover {
  overflow: hidden;
}
#about .about .list-link ul li a .button {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  background-color: #fff;
  padding: 14px 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media only screen and (max-width: 750px) {
  #about .about .list-link ul li a .button {
    padding: 10px 15px;
  }
}
#about .about .list-link ul li a .button h2 {
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: 700;
  -webkit-transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
  transition: all 0.2s cubic-bezier(0.75, 0.3, 0.25, 1);
}
@media only screen and (max-width: 1180px) {
  #about .about .list-link ul li a .button h2 {
    font-size: 2rem;
    line-height: 3rem;
  }
}
@media only screen and (max-width: 750px) {
  #about .about .list-link ul li a .button h2 {
    font-size: 1.8rem;
    line-height: 2.8rem;
  }
}
#about .message .row .flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
@media only screen and (max-width: 750px) {
  #about .message .row .flex {
    display: block;
  }
}
#about .message .row .flex .col-left {
  width: 39.55%;
}
@media only screen and (max-width: 750px) {
  #about .message .row .flex .col-left {
    margin-left: auto;
    margin-right: auto;
  }
}
#about .message .row .flex .col-left p {
  font-size: 1.4rem;
  line-height: 2.4rem;
  font-weight: bold;
  margin-top: 20px;
}
#about .message .row .flex .col-left p span {
  display: block;
  font-size: 2rem;
  margin-top: 5px;
}
#about .message .row .flex .col-right {
  width: 53.71%;
}
@media only screen and (max-width: 750px) {
  #about .message .row .flex .col-right {
    width: 100%;
    margin-top: 30px;
  }
}
#about .message .row .flex .col-right h2 {
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: bold;
  margin-bottom: 30px;
}
@media only screen and (max-width: 1180px) {
  #about .message .row .flex .col-right h2 {
    font-size: 2rem;
    line-height: 3rem;
    margin-bottom: 20px;
  }
}
@media only screen and (max-width: 750px) {
  #about .message .row .flex .col-right h2 {
    font-size: 1.8rem;
    line-height: 2.6rem;
    margin-bottom: 15px;
  }
}
#about .philosophy .row.management .content h3 {
  font-size: 6rem;
  line-height: 6rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 60px;
  color: #FE7D28;
  background-image: -webkit-gradient(linear, left top, right top, color-stop(50%, #FE7D28), to(#FFB800));
  background-image: linear-gradient(90deg, #FE7D28 50%, #FFB800 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media only screen and (max-width: 1180px) {
  #about .philosophy .row.management .content h3 {
    font-size: 4rem;
    line-height: 4rem;
    margin-bottom: 40px;
  }
}
@media only screen and (max-width: 750px) {
  #about .philosophy .row.management .content h3 {
    font-size: 3rem;
    line-height: 3rem;
    margin-bottom: 25px;
  }
}
#about .philosophy .row.management .content .flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
@media only screen and (max-width: 850px) {
  #about .philosophy .row.management .content .flex {
    display: block;
  }
}
#about .philosophy .row.management .content .flex .col {
  width: 30.46875%;
}
@media only screen and (max-width: 850px) {
  #about .philosophy .row.management .content .flex .col {
    width: 100%;
  }
}
@media only screen and (max-width: 850px) {
  #about .philosophy .row.management .content .flex .col + .col {
    margin-top: 40px;
  }
}
#about .philosophy .row.management .content .flex .col .box {
  position: relative;
  padding: 2px;
}
#about .philosophy .row.management .content .flex .col .box::before {
  content: "";
  position: absolute;
  bottom: -17px;
  left: 0;
  right: 0;
  z-index: 1;
  display: table;
  margin-left: auto;
  margin-right: auto;
  width: 12px;
  height: 35px;
  background-image: url("/assets/images/about/philosophy/management-box-arrow.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 12px;
}
#about .philosophy .row.management .content .flex .col .box .box-content {
  padding: 30px 25px;
  background-color: #fff;
}
#about .philosophy .row.management .content .flex .col .box .box-content .icon {
  display: table;
  margin-left: auto;
  margin-right: auto;
}
#about .philosophy .row.management .content .flex .col .box .box-content .icon img {
  width: auto;
  height: 90px;
}
@media only screen and (max-width: 1180px) {
  #about .philosophy .row.management .content .flex .col .box .box-content .icon img {
    height: 70px;
  }
}
#about .philosophy .row.management .content .flex .col .box .box-content h4 {
  margin-top: 5px;
  margin-bottom: 10px;
  font-size: 3rem;
  line-height: 4rem;
  font-weight: bold;
  color: #FE7D28;
  text-align: center;
}
@media only screen and (max-width: 1180px) {
  #about .philosophy .row.management .content .flex .col .box .box-content h4 {
    font-size: 2.4rem;
    line-height: 3.4rem;
  }
}
#about .philosophy .row.management .content .flex .col .box .box-content h5 {
  min-height: 120px;
  font-size: 1.8rem;
  line-height: 2.8rem;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 1180px) {
  #about .philosophy .row.management .content .flex .col .box .box-content h5 {
    font-size: 1.6rem;
    line-height: 2.6rem;
    min-height: 104px;
  }
}
#about .philosophy .row.management .content .flex .col p {
  margin-top: 40px;
  font-size: 1.4rem;
  line-height: 2.4rem;
}
@media only screen and (max-width: 850px) {
  #about .philosophy .row.management .content .flex .col p {
    margin-top: 30px;
  }
}
#about .philosophy .row.fujiya .content .box-text {
  padding: 25px;
}
@media only screen and (max-width: 1180px) {
  #about .philosophy .row.fujiya .content .box-text {
    padding: 20px;
  }
}
#about .philosophy .row.fujiya .content .box-text h3 {
  font-size: 2rem;
  line-height: 3rem;
  font-weight: bold;
  color: #fff;
  text-align: center;
}
@media only screen and (max-width: 1180px) {
  #about .philosophy .row.fujiya .content .box-text h3 {
    font-size: 1.8rem;
    line-height: 2.8rem;
  }
}
#about .philosophy .row.fujiya .content .box-text h3 span {
  display: block;
  font-size: 3rem;
  line-height: 4rem;
}
@media only screen and (max-width: 1180px) {
  #about .philosophy .row.fujiya .content .box-text h3 span {
    font-size: 2.6rem;
    line-height: 3.6rem;
  }
}
#about .philosophy .row.fujiya .content .flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
@media only screen and (max-width: 750px) {
  #about .philosophy .row.fujiya .content .flex {
    display: block;
  }
}
#about .philosophy .row.fujiya .content .flex .col {
  width: 47.77%;
  margin-top: 4.66%;
  padding: 25px;
  background-color: #fff;
  -webkit-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.1);
  box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.1);
}
@media only screen and (max-width: 750px) {
  #about .philosophy .row.fujiya .content .flex .col {
    width: 100%;
  }
}
#about .philosophy .row.fujiya .content .flex .col .no-icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}
#about .philosophy .row.fujiya .content .flex .col .no-icon .no {
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: bold;
  color: #FFB800;
}
@media only screen and (max-width: 1180px) {
  #about .philosophy .row.fujiya .content .flex .col .no-icon .no {
    font-size: 2rem;
    line-height: 3rem;
  }
}
#about .philosophy .row.fujiya .content .flex .col h4 {
  margin-top: 30px;
  font-size: 2.2rem;
  line-height: 3.2rem;
  font-weight: bold;
}
@media only screen and (max-width: 1180px) {
  #about .philosophy .row.fujiya .content .flex .col h4 {
    font-size: 1.8rem;
    line-height: 2.8rem;
  }
}
#about .philosophy .row.csr {
  background-image: url("/assets/images/about/philosophy/csr-bg.jpg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
#about .philosophy .row.csr .box-white {
  padding: 40px;
  background-color: #fff;
}
@media only screen and (max-width: 750px) {
  #about .philosophy .row.csr .box-white {
    padding: 25px;
  }
}
#about .philosophy .row.csr .box-white .content h3 {
  margin-bottom: 20px;
  display: table;
  margin-left: auto;
  margin-right: auto;
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: 700;
  text-align: center;
  position: relative;
  padding: 0 20px;
}
@media only screen and (max-width: 1180px) {
  #about .philosophy .row.csr .box-white .content h3 {
    font-size: 2rem;
    line-height: 3rem;
  }
}
#about .philosophy .row.csr .box-white .content h3::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  z-index: 1;
  width: 6px;
  height: 6px;
  border-radius: 100%;
  background-color: #FE7D28;
  display: table;
  margin-top: auto;
  margin-bottom: auto;
}
#about .philosophy .row.csr .box-white .content h3::after {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  z-index: 1;
  width: 6px;
  height: 6px;
  border-radius: 100%;
  background-color: #FE7D28;
  display: table;
  margin-top: auto;
  margin-bottom: auto;
}
#about .philosophy .row.csr .box-white .content p + h4 {
  margin-top: 30px;
}
#about .philosophy .row.csr .box-white .content h4 {
  font-size: 2rem;
  line-height: 3rem;
  font-weight: bold;
  margin-bottom: 20px;
}
@media only screen and (max-width: 1180px) {
  #about .philosophy .row.csr .box-white .content h4 {
    font-size: 1.8rem;
    line-height: 2.8rem;
  }
}
@media only screen and (max-width: 750px) {
  #about .philosophy .row.csr .box-white .content h4 {
    margin-bottom: 10px;
  }
}
#about .philosophy .row.csr-activities .content ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-left: -1.89%;
  margin-top: -3.78%;
}
@media only screen and (max-width: 750px) {
  #about .philosophy .row.csr-activities .content ul {
    display: block;
    margin-left: 0;
    margin-top: 0;
  }
}
#about .philosophy .row.csr-activities .content ul li {
  width: 31.44%;
  margin-left: 1.89%;
  margin-top: 3.78%;
}
@media only screen and (max-width: 750px) {
  #about .philosophy .row.csr-activities .content ul li {
    width: 100%;
    margin-top: 0;
    margin-left: 0;
  }
}
@media only screen and (max-width: 750px) {
  #about .philosophy .row.csr-activities .content ul li + li {
    margin-top: 30px;
  }
}
#about .philosophy .row.csr-activities .content ul li a {
  display: block;
}
#about .philosophy .row.csr-activities .content ul li a:hover .cover img {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}
#about .philosophy .row.csr-activities .content ul li a .cover {
  overflow: hidden;
}
#about .philosophy .row.csr-activities .content ul li a .brief {
  margin-top: 20px;
}
@media only screen and (max-width: 750px) {
  #about .philosophy .row.csr-activities .content ul li a .brief {
    margin-top: 15px;
  }
}
#about .philosophy .row.csr-activities .content ul li a .brief .date {
  font-size: 1.4rem;
  line-height: 2rem;
  margin-bottom: 2px;
}
#about .philosophy .row.csr-activities .content ul li a .brief .ttl {
  font-weight: bold;
}
#about .outline .row.profile .content .table .tr {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#about .outline .row.profile .content .table .tr .td {
  width: 100%;
  padding: 20px 15px;
  border-bottom: 1px solid #ccc;
}
@media only screen and (max-width: 750px) {
  #about .outline .row.profile .content .table .tr .td {
    padding: 15px;
  }
}
#about .outline .row.profile .content .table .tr .td.topic {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-weight: 700;
  width: 220px;
  min-width: 220px;
  border-bottom: 1px solid #666;
  text-align: center;
}
@media only screen and (max-width: 1180px) {
  #about .outline .row.profile .content .table .tr .td.topic {
    width: 180px;
    min-width: 180px;
  }
}
@media only screen and (max-width: 750px) {
  #about .outline .row.profile .content .table .tr .td.topic {
    width: 100px;
    min-width: 100px;
  }
}
#about .outline .row.access .content .gmap {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 470px;
}
#about .outline .row.access .content .gmap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#about .outline .row.access .content .flex {
  margin-top: 80px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: 100%;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (max-width: 1180px) {
  #about .outline .row.access .content .flex {
    margin-top: 60px;
  }
}
@media only screen and (max-width: 750px) {
  #about .outline .row.access .content .flex {
    margin-top: 40px;
  }
}
#about .outline .row.access .content .flex .img {
  width: 34.5%;
}
#about .outline .row.access .content .flex .text {
  width: 61.25%;
}
#about .outline .row.access .content .flex .text h3 {
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: bold;
  margin-bottom: 15px;
}
@media only screen and (max-width: 1180px) {
  #about .outline .row.access .content .flex .text h3 {
    font-size: 2rem;
    line-height: 3rem;
  }
}
@media only screen and (max-width: 750px) {
  #about .outline .row.access .content .flex .text h3 {
    font-size: 1.8rem;
    line-height: 2.8rem;
    margin-bottom: 10px;
  }
}
#about .outline .row.access .content .flex .text p strong {
  font-weight: bold;
}
#about .history {
  position: relative;
  padding-top: 85px;
}
#about .history::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1;
  display: table;
  margin-left: auto;
  margin-right: auto;
  width: 1px;
  height: 100%;
  background-color: #ccc;
}
#about .history .row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
#about .history .row + .row {
  padding-top: 80px;
}
@media only screen and (max-width: 1180px) {
  #about .history .row + .row {
    padding-top: 60px;
  }
}
@media only screen and (max-width: 750px) {
  #about .history .row + .row {
    padding-top: 40px;
  }
}
#about .history .row.pad-short {
  padding-top: 25px;
}
#about .history .row.pad-short + .row {
  padding-top: 25px;
}
#about .history .row .col {
  width: 47.07%;
  position: relative;
}
@media only screen and (max-width: 1180px) {
  #about .history .row .col {
    width: 45%;
  }
}
#about .history .row .col.right {
  width: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-left: auto;
}
#about .history .row .col .des {
  position: relative;
  padding-left: 5%;
  max-width: 464px;
}
@media only screen and (max-width: 1180px) {
  #about .history .row .col .des {
    padding-left: 10%;
  }
}
#about .history .row .col .des::before {
  content: "";
  position: absolute;
  top: 3px;
  left: -20px;
  z-index: 2;
  width: 22px;
  height: 22px;
  border-radius: 100%;
  background-color: #FE7D28;
  border: 10px solid #fff;
}
@media only screen and (max-width: 1180px) {
  #about .history .row .col .des::before {
    width: 16px;
    height: 16px;
    left: -17px;
    top: 0;
  }
}
@media only screen and (max-width: 750px) {
  #about .history .row .col .des::before {
    width: 12px;
    height: 12px;
    left: -15px;
    top: -1px;
  }
}
#about .history .row .col .des h2 {
  font-size: 3.6rem;
  line-height: 4.6rem;
  font-weight: bold;
  margin-bottom: 10px;
}
@media only screen and (max-width: 1180px) {
  #about .history .row .col .des h2 {
    font-size: 2.6rem;
    line-height: 3.6rem;
  }
}
@media only screen and (max-width: 750px) {
  #about .history .row .col .des h2 {
    font-size: 2rem;
    line-height: 3rem;
    margin-bottom: 0;
  }
}
#about .history .row .end {
  position: relative;
  z-index: 2;
  margin-top: 50px;
  display: table;
  margin-left: auto;
  margin-right: auto;
  border-top: 10px solid #fff;
}
@media only screen and (max-width: 1180px) {
  #about .history .row .end {
    margin-top: 30px;
  }
}
@media only screen and (max-width: 750px) {
  #about .history .row .end {
    margin-top: 0;
  }
}

/* restaurant */
#restaurant .intro .content p + p {
  margin-top: 25px;
}
#restaurant .features .content .row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media only screen and (max-width: 1180px) {
  #restaurant .features .content .row {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
@media only screen and (max-width: 750px) {
  #restaurant .features .content .row {
    display: block;
  }
}
@media only screen and (max-width: 1180px) {
  #restaurant .features .content .row + .row {
    margin-top: 40px;
  }
}
#restaurant .features .content .row:nth-child(even) {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
#restaurant .features .content .row:nth-child(even) .col .text {
  margin-left: auto;
  padding-left: 0;
  padding-right: 40px;
}
#restaurant .features .content .row .col {
  width: 50%;
}
@media only screen and (max-width: 750px) {
  #restaurant .features .content .row .col {
    width: 100%;
  }
}
#restaurant .features .content .row .col .text {
  padding-top: 40px;
  padding-bottom: 40px;
  padding-left: 40px;
  max-width: 520px;
}
@media only screen and (max-width: 1180px) {
  #restaurant .features .content .row .col .text {
    padding-top: 0;
    padding-bottom: 0;
  }
}
@media only screen and (max-width: 750px) {
  #restaurant .features .content .row .col .text {
    padding: 0;
    margin-top: 20px;
  }
}
#restaurant .features .content .row .col .text h3 {
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: bold;
  margin-bottom: 20px;
  padding-bottom: 10px;
  border-bottom: 1px solid #E6E6E6;
}
@media only screen and (max-width: 1180px) {
  #restaurant .features .content .row .col .text h3 {
    font-size: 2rem;
    line-height: 3rem;
  }
}
@media only screen and (max-width: 750px) {
  #restaurant .features .content .row .col .text h3 {
    font-size: 1.8rem;
    line-height: 2.8rem;
    margin-bottom: 15px;
  }
}
#restaurant .features .content .row .col .text p + p {
  margin-top: 25px;
}
@media only screen and (max-width: 750px) {
  #restaurant .features .content .row .col .text p + p {
    margin-top: 15px;
  }
}
#restaurant .sustain .box {
  width: 90%;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
  margin-top: -60px;
  padding: 40px;
  padding-bottom: 0;
  background-color: #fff;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 750px) {
  #restaurant .sustain .box {
    padding: 30px;
  }
}
#restaurant .sustain .box .content p + p {
  margin-top: 25px;
}
#restaurant .brand-list {
  margin-top: 0;
}

/* Food */
#food .intro .content p + p {
  margin-top: 25px;
}
@media only screen and (max-width: 750px) {
  #food .intro .content p + p {
    margin-top: 15px;
  }
}
#food .business .content .row .box {
  padding: 60px 40px;
  background-color: #fff;
}
@media only screen and (max-width: 750px) {
  #food .business .content .row .box {
    padding: 30px;
  }
}
#food .business .content .row .box .des .flex {
  margin-top: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media only screen and (max-width: 750px) {
  #food .business .content .row .box .des .flex {
    margin-top: 30px;
    display: block;
  }
}
#food .business .content .row .box .des .flex .col {
  width: 47.987%;
  max-width: 453px;
}
@media only screen and (max-width: 750px) {
  #food .business .content .row .box .des .flex .col {
    width: 100%;
    max-width: 100%;
  }
}
@media only screen and (max-width: 750px) {
  #food .business .content .row .box .des .flex .col + .col {
    margin-top: 30px;
  }
}
#food .business .content .row .box .des .flex .col h4 {
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: bold;
  margin-bottom: 20px;
  padding-bottom: 10px;
  border-bottom: 1px solid #E6E6E6;
}
@media only screen and (max-width: 1180px) {
  #food .business .content .row .box .des .flex .col h4 {
    font-size: 2rem;
    line-height: 3rem;
  }
}
@media only screen and (max-width: 750px) {
  #food .business .content .row .box .des .flex .col h4 {
    font-size: 1.8rem;
    line-height: 2.8rem;
    margin-bottom: 15px;
  }
}
#food .business .content .row .box .des .flex .col p + p {
  margin-top: 25px;
}
@media only screen and (max-width: 750px) {
  #food .business .content .row .box .des .flex .col p + p {
    margin-top: 15px;
  }
}
#food .business .content .row .box .des .flex + .flex {
  margin-top: 60px;
}
@media only screen and (max-width: 750px) {
  #food .business .content .row .box .des .flex + .flex {
    margin-top: 40px;
  }
}
#food .business .content .row .box .des .flex:nth-child(odd) {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
#food .business .content .row .box .des .box-list {
  margin-top: 60px;
  padding: 40px;
  background-color: #F2F2F2;
}
@media only screen and (max-width: 750px) {
  #food .business .content .row .box .des .box-list {
    margin-top: 40px;
    padding: 30px;
  }
}
#food .business .content .row .box .des .box-list h5 {
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 30px;
}
@media only screen and (max-width: 1180px) {
  #food .business .content .row .box .des .box-list h5 {
    font-size: 2rem;
    line-height: 3rem;
  }
}
@media only screen and (max-width: 750px) {
  #food .business .content .row .box .des .box-list h5 {
    font-size: 1.8rem;
    line-height: 2.8rem;
  }
}
#food .business .content .row .box .des .box-list ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-left: -2%;
  margin-top: -20px;
}
@media only screen and (max-width: 850px) {
  #food .business .content .row .box .des .box-list ul {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-left: 0;
  }
}
#food .business .content .row .box .des .box-list ul li {
  width: 23%;
  margin-left: 2%;
  margin-top: 20px;
}
@media only screen and (max-width: 850px) {
  #food .business .content .row .box .des .box-list ul li {
    width: 48%;
    margin-left: 0;
  }
}
#food .business .content .row .box .des .box-list ul li .cover img {
  width: 100%;
  height: auto;
}
#food .business .content .row .box .des .box-list ul li .brief {
  margin-top: 15px;
}
@media only screen and (max-width: 750px) {
  #food .business .content .row .box .des .box-list ul li .brief {
    margin-top: 10px;
  }
}
#food .business .content .row .box .des .box-list ul li .brief h6 {
  font-weight: bold;
}
@media only screen and (max-width: 750px) {
  #food .business .content .row .box .des .box-list ul li .brief h6 {
    font-size: 1.4rem;
    line-height: 2.4rem;
  }
}
#food .business .content .oem {
  margin-top: 60px;
  background-image: url("/assets/images/food_development/oem-bg.jpg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  padding: 80px 40px;
}
@media only screen and (max-width: 750px) {
  #food .business .content .oem {
    margin-top: 40px;
    padding: 40px 30px;
  }
}
#food .business .content .oem h3 {
  font-size: 3rem;
  line-height: 4rem;
  font-weight: bold;
  color: #fff;
  text-align: center;
  text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.25);
}
@media only screen and (max-width: 1180px) {
  #food .business .content .oem h3 {
    font-size: 2.4rem;
    line-height: 3.4rem;
  }
}
@media only screen and (max-width: 750px) {
  #food .business .content .oem .btn-box {
    margin-top: 15px;
  }
}

/* Brand */
#brand-inner .intro .content p {
  text-align: center;
}
@media only screen and (max-width: 750px) {
  #brand-inner .intro .content p {
    text-align: left;
  }
}
#brand-inner .section .section-row + .section-row {
  margin-top: 100px;
}
@media only screen and (max-width: 1180px) {
  #brand-inner .section .section-row + .section-row {
    margin-top: 80px;
  }
}
@media only screen and (max-width: 750px) {
  #brand-inner .section .section-row + .section-row {
    margin-top: 60px;
  }
}
#brand-inner .section .section-row .box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  padding: 40px;
  border: 1px solid #ccc;
  background-color: #fff;
}
@media only screen and (max-width: 750px) {
  #brand-inner .section .section-row .box {
    display: block;
    padding: 30px;
  }
}
#brand-inner .section .section-row .box + .box {
  margin-top: 20px;
}
@media only screen and (max-width: 750px) {
  #brand-inner .section .section-row .box + .box {
    margin-top: 5%;
  }
}
#brand-inner .section .section-row .box .col-left {
  width: 28.67%;
  max-width: 268px;
  padding: 1px;
}
@media only screen and (max-width: 750px) {
  #brand-inner .section .section-row .box .col-left {
    width: 100%;
    max-width: 168px;
    margin-left: auto;
    margin-right: auto;
  }
}
#brand-inner .section .section-row .box .col-right {
  width: 71.33%;
  padding-left: 40px;
}
@media only screen and (max-width: 750px) {
  #brand-inner .section .section-row .box .col-right {
    width: 100%;
    padding-left: 0;
    margin-top: 25px;
  }
}
#brand-inner .section .section-row .box .col-right h3 {
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: bold;
  margin-bottom: 10px;
}
@media only screen and (max-width: 1180px) {
  #brand-inner .section .section-row .box .col-right h3 {
    font-size: 2rem;
    line-height: 3rem;
  }
}
@media only screen and (max-width: 750px) {
  #brand-inner .section .section-row .box .col-right .btn-box .btn {
    margin-left: auto;
    margin-right: auto;
  }
}
#brand-inner .brand-list {
  margin-top: 0;
}

/* News */
#news .news .content .news-list ul li + li {
  margin-top: 40px;
  padding-top: 41px;
  border-top: 1px solid #E6E6E6;
}
@media only screen and (max-width: 750px) {
  #news .news .content .news-list ul li + li {
    margin-top: 30px;
    padding-top: 31px;
  }
}
#news .news .content .news-list ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}
#news .news .content .news-list ul li a:hover {
  opacity: 1;
}
#news .news .content .news-list ul li a:hover .cover img {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}
#news .news .content .news-list ul li a:hover .brief .topic {
  text-decoration: underline;
}
#news .news .content .news-list ul li a .cover {
  width: 20.8%;
  max-width: 213px;
  overflow: hidden;
}
@media only screen and (max-width: 750px) {
  #news .news .content .news-list ul li a .cover {
    width: 30%;
  }
}
#news .news .content .news-list ul li a .brief {
  width: 79.2%;
  padding-left: 30px;
}
@media only screen and (max-width: 750px) {
  #news .news .content .news-list ul li a .brief {
    width: 70%;
    padding-left: 20px;
  }
}
#news .news .content .news-list ul li a .brief .topic {
  font-size: 2rem;
  line-height: 3rem;
  font-weight: bold;
  margin-bottom: 20px;
}
@media only screen and (max-width: 1180px) {
  #news .news .content .news-list ul li a .brief .topic {
    font-size: 1.8rem;
    line-height: 2.8rem;
  }
}
@media only screen and (max-width: 750px) {
  #news .news .content .news-list ul li a .brief .topic {
    margin-bottom: 10px;
  }
}
#news .news .content .news-detail .txthead-box {
  margin-bottom: 30px;
  padding-bottom: 31px;
  border-bottom: 1px solid #E6E6E6;
}
#news .news .content .news-detail p + p {
  margin-top: 30px;
}
@media only screen and (max-width: 750px) {
  #news .news .content .news-detail p + p {
    margin-top: 20px;
  }
}
#news .news .content .news-detail p + h2 {
  margin-top: 60px;
}
@media only screen and (max-width: 750px) {
  #news .news .content .news-detail p + h2 {
    margin-top: 40px;
  }
}
#news .news .content .news-detail .img-center {
  margin-top: 50px;
}
@media only screen and (max-width: 750px) {
  #news .news .content .news-detail .img-center {
    margin-top: 35px;
  }
}
#news .news .content .news-detail .img-center div {
  display: table;
  margin-left: auto;
  margin-right: auto;
}
#news .news .content .news-detail .img-center div p {
  font-size: 1.4rem;
  line-height: 2rem;
  margin-top: 10px;
}
#news .news .content .news-detail .img-center + h2 {
  margin-top: 60px;
}
@media only screen and (max-width: 750px) {
  #news .news .content .news-detail .img-center + h2 {
    margin-top: 40px;
  }
}
#news .news .content .news-detail .img-col2 {
  margin-top: 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
#news .news .content .news-detail .img-col2 div {
  width: 47.169811%;
}
#news .news .content .news-detail .img-col2 div p {
  font-size: 1.4rem;
  line-height: 2rem;
  margin-top: 10px;
}
#news .news .content .news-detail h2 {
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: bold;
  border-bottom: 1px solid #E6E6E6;
  padding-bottom: 10px;
  margin-bottom: 15px;
}
@media only screen and (max-width: 1180px) {
  #news .news .content .news-detail h2 {
    font-size: 2rem;
    line-height: 3rem;
  }
}
#news .news .content .news-detail h3 {
  font-size: 1.8rem;
  line-height: 2.8rem;
  font-weight: bold;
  margin-bottom: 10px;
}
@media only screen and (max-width: 750px) {
  #news .news .content .news-detail h3 {
    margin-bottom: 5px;
  }
}
#news .news .content .news-detail .link {
  margin-top: 60px;
}
@media only screen and (max-width: 750px) {
  #news .news .content .news-detail .link {
    margin-top: 40px;
  }
}
#news .news .content .news-detail .link a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  text-decoration: underline;
}
#news .news .content .news-detail .link a span {
  margin-top: 10px;
  margin-left: 10px;
}
#news .news .content .news-detail .link a:hover {
  color: #FE7D28;
}
#news .news .content .news-detail .link + .img-col2 {
  margin-top: 60px;
}

.date-tag-new {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
@media only screen and (max-width: 750px) {
  .date-tag-new {
    margin-bottom: 10px;
  }
}
.date-tag-new .date {
  margin-right: 10px;
  font-size: 1.6rem;
  line-height: 2.4rem;
}
.date-tag-new .tag {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-right: 10px;
  padding: 0 10px;
  height: 24px;
  font-size: 1.2rem;
  line-height: 1.2rem;
  color: #fff;
  background-color: #25B172;
  border-radius: 3px;
}
.date-tag-new .new {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0 10px;
  height: 24px;
  font-size: 1.2rem;
  line-height: 1.2rem;
  color: #FF0000;
  background-color: #fff;
  border-radius: 3px;
  border: 1px solid #FF0000;
}

.wp-pagenavi {
  margin-top: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.wp-pagenavi > *:hover {
  cursor: pointer;
  opacity: 0.6;
}
.wp-pagenavi a {
  display: block;
}
.wp-pagenavi a.previouspostslink {
  margin-right: 40px;
  width: 50px;
  height: 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  border-radius: 100%;
  border: 1px solid #000;
}
@media only screen and (max-width: 750px) {
  .wp-pagenavi a.previouspostslink {
    margin-right: 10px;
  }
}
.wp-pagenavi a.previouspostslink:hover {
  opacity: 1;
  border-color: #FE7D28;
}
.wp-pagenavi a.nextpostslink {
  margin-left: 40px;
  width: 50px;
  height: 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  border-radius: 100%;
  border: 1px solid #000;
}
@media only screen and (max-width: 750px) {
  .wp-pagenavi a.nextpostslink {
    margin-left: 10px;
  }
}
.wp-pagenavi a.nextpostslink:hover {
  opacity: 1;
  border-color: #FE7D28;
}
.wp-pagenavi .current, .wp-pagenavi .page, .wp-pagenavi .extend {
  width: 50px;
  height: 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  border-bottom: 1px solid transparent;
}
@media only screen and (max-width: 750px) {
  .wp-pagenavi .current, .wp-pagenavi .page, .wp-pagenavi .extend {
    display: none !important;
  }
}
.wp-pagenavi .current {
  color: #FE7D28;
  border-bottom-color: #FE7D28;
}
.wp-pagenavi .current:hover {
  opacity: 1 !important;
}

/* Contact */
#contact-inner .contact-inner .content p + p {
  margin-top: 30px;
}
@media only screen and (max-width: 1180px) {
  #contact-inner .contact-inner .content p + p {
    margin-top: 20px;
  }
}
@media only screen and (max-width: 750px) {
  #contact-inner .contact-inner .content p + p {
    margin-top: 15px;
  }
}
#contact-inner .contact-inner .content .box {
  margin-top: 60px;
  padding: 2px;
}
@media only screen and (max-width: 1180px) {
  #contact-inner .contact-inner .content .box {
    margin-top: 40px;
  }
}
@media only screen and (max-width: 750px) {
  #contact-inner .contact-inner .content .box {
    margin-top: 30px;
  }
}
#contact-inner .contact-inner .content .box > div {
  padding: 35px;
  background-color: #fff;
}
@media only screen and (max-width: 1180px) {
  #contact-inner .contact-inner .content .box > div {
    padding: 30px;
  }
}
@media only screen and (max-width: 750px) {
  #contact-inner .contact-inner .content .box > div {
    padding: 20px;
  }
}
#contact-inner .contact-inner .content .box > div h2 {
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: bold;
  color: #FE7D28;
  text-align: center;
  margin-bottom: 20px;
}
@media only screen and (max-width: 1180px) {
  #contact-inner .contact-inner .content .box > div h2 {
    font-size: 2rem;
    line-height: 3rem;
    margin-bottom: 10px;
  }
}
@media only screen and (max-width: 750px) {
  #contact-inner .contact-inner .content .box > div h2 {
    font-size: 1.8rem;
    line-height: 2.8rem;
    margin-bottom: 5px;
  }
}
#contact-inner .contact-inner .content .box > div p {
  text-align: center;
}
#contact-inner .contact-inner .content .box > div a {
  display: table;
  margin-top: 20px;
  margin-left: auto;
  margin-right: auto;
  font-size: 4.8rem;
  font-weight: bold;
}
@media only screen and (max-width: 1180px) {
  #contact-inner .contact-inner .content .box > div a {
    font-size: 3.8rem;
    margin-top: 10px;
  }
}
@media only screen and (max-width: 750px) {
  #contact-inner .contact-inner .content .box > div a {
    font-size: 2.8rem;
    margin-top: 5px;
  }
}
#contact-inner .contact-inner .content .box > div a span {
  font-size: 2.4rem;
}
@media only screen and (max-width: 1180px) {
  #contact-inner .contact-inner .content .box > div a span {
    font-size: 2rem;
  }
}
@media only screen and (max-width: 750px) {
  #contact-inner .contact-inner .content .box > div a span {
    font-size: 1.8rem;
  }
}
#contact-inner .contact-inner .content .box-imp {
  margin-bottom: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media only screen and (max-width: 750px) {
  #contact-inner .contact-inner .content .box-imp {
    margin-bottom: 15px;
  }
}
#contact-inner .contact-inner .content .box-imp span {
  margin-right: 10px;
  margin-top: 1px;
  display: -ms-inline-grid;
  display: inline-grid;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
  width: 68px;
  height: 28px;
  font-size: 1.2rem;
  line-height: 1.2rem;
  color: #fff;
  background-color: #F10016;
}
#contact-inner .contact-inner .content .form {
  margin-top: 60px;
}
@media only screen and (max-width: 1180px) {
  #contact-inner .contact-inner .content .form {
    margin-top: 50px;
  }
}
@media only screen and (max-width: 750px) {
  #contact-inner .contact-inner .content .form {
    margin-top: 40px;
  }
}
#contact-inner .contact-inner .content .form .row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-top: 1px solid #E6E6E6;
  padding-top: 21px;
  padding-left: 25px;
  padding-right: 25px;
  padding-bottom: 20px;
}
@media only screen and (max-width: 750px) {
  #contact-inner .contact-inner .content .form .row {
    padding-top: 16px;
    padding-bottom: 15px;
    padding-left: 0;
    padding-right: 0;
    display: block;
  }
}
#contact-inner .contact-inner .content .form .row .topic {
  width: 225px;
  min-width: 225px;
  font-weight: bold;
  padding-top: 11px;
}
@media only screen and (max-width: 750px) {
  #contact-inner .contact-inner .content .form .row .topic {
    width: 100%;
    padding-top: 0;
    margin-bottom: 10px;
  }
}
#contact-inner .contact-inner .content .form .row .topic .imp {
  margin-left: 10px;
  margin-top: 1px;
  display: -ms-inline-grid;
  display: inline-grid;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
  width: 68px;
  height: 28px;
  font-size: 1.2rem;
  line-height: 1.2rem;
  color: #fff;
  background-color: #B3B3B3;
}
#contact-inner .contact-inner .content .form .row .topic .imp.red {
  background-color: #F10016;
}
#contact-inner .contact-inner .content .form .row .field {
  width: 100%;
}
#contact-inner .contact-inner .content .form .row.agree {
  display: block;
  padding-top: 40px;
}
@media only screen and (max-width: 750px) {
  #contact-inner .contact-inner .content .form .row.agree {
    padding-top: 30px;
  }
}
#contact-inner .contact-inner .content .form .row.agree .box {
  margin-top: 20px;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 30px;
  background-color: #F2F2F2;
}
@media only screen and (max-width: 750px) {
  #contact-inner .contact-inner .content .form .row.agree .box {
    padding: 20px;
  }
}

.textbox {
  display: block;
  width: 100%;
  padding: 11px;
  font-family: YuGothic, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif;
  font-size: 16px;
  line-height: 26px;
  border: 1px solid #666;
  background-color: #FBFBFB;
}

textarea.textbox {
  resize: none;
  display: block;
  width: 100%;
  padding: 11px;
  font-family: YuGothic, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif;
  font-size: 16px;
  line-height: 26px;
  border: 1px solid #666;
  background-color: #FBFBFB;
}

.chkbox-btn {
  display: table;
  position: relative;
  padding-left: 28px;
  margin-top: 0px;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.chkbox-btn:last-child {
  margin-right: 0;
}

.chkbox-btn input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
  height: 0;
  width: 0;
}

.chkbox {
  position: absolute;
  top: 5px;
  left: 0;
  border: 1px solid #B3B3B3;
  height: 20px;
  width: 20px;
  background-color: #fff;
  border-radius: 3px;
}

.chkbox-btn input:checked ~ .chkbox {
  background-color: #fff;
  border-color: #B3B3B3;
}

.chkbox:after {
  content: "";
  position: absolute;
  display: none;
}

.chkbox-btn input:checked ~ .chkbox:after {
  display: block;
}

.chkbox-btn .chkbox:after {
  top: 0;
  left: 5px;
  width: 6px;
  height: 13px;
  border: solid #FE7D28;
  border-width: 0 2px 2px 0;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}