@charset "UTF-8";
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  box-sizing: border-box;
  list-style: none;
}

body {
  line-height: 1;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  box-sizing: border-box;
  text-decoration: none;
  transition: 0.5s;
  color: #360e07;
}

a:hover {
  opacity: 0.75;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  	/*
    border-collapse: collapse;
  	*/
  border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input,
select {
  vertical-align: middle;
}

img {
  width: 100%;
  max-width: 100%;
  height: auto;
}

button,
input[type="submit"] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 0;
  border: none;
  outline: none;
  background: transparent;
  cursor: pointer;
}

input {
  box-sizing: border-box;
}

input[type="text"] {
  padding: 0;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
}

input[type="radio"] {
  display: none;
}

textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  resize: none;
  padding: 0;
  border: 0;
  outline: none;
  background: transparent;
  box-sizing: border-box;
}

select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  outline: none;
  background: transparent;
}

select::-ms-expand {
  display: none;
}

select:-moz-focusring {
  color: transparent;
  text-shadow: 0 0 0 #828c9a;
}

img {
  max-width: 100%;
}

@media (min-width: 821px) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
    color: inherit;
  }
}
@media screen and (max-width: 768px) {
  img[src$="_pc.jpg"], img[src$="_pc.png"] {
    display: none !important;
  }
}
@media screen and (min-width: 769px) {
  img[src$="_sp.jpg"], img[src$="_sp.png"] {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  .pc_only {
    display: none !important;
  }
}
@media screen and (min-width: 769px) {
  .sp_only {
    display: none !important;
  }
}
html {
  overflow-x: hidden;
}

html {
  font-size: 0.666666667vw;
  /* 1460pxで0.684931507vw */
  overflow-x: hidden;
  overflow-y: auto;
}

@media screen and (max-width: 768px) {
  html {
    font-size: 1.3333333333vw;
  }
}
@media screen and (min-width: 1500px) {
  html {
    font-size: 10px;
  }
}
body {
  margin: 0;
  font-weight: 400;
  font-family: "Zen Kaku Gothic New", sans-serif;
  color: #552e30;
  overflow-x: hidden;
}

header {
  width: 100%;
  height: 10rem;
  background: #fff;
  position: relative;
  z-index: 3;
}
@media screen and (max-width: 768px) {
  header {
    height: 11rem;
  }
}
header .headCont {
  width: 100%;
  height: 100%;
  margin: auto;
  position: relative;
}
@media screen and (max-width: 768px) {
  header .headCont {
    width: 100%;
  }
}
header .headCont h1.logo {
  width: 23.8rem;
  position: absolute;
  top: 1.5rem;
  left: 2.4rem;
}
header .headCont .menu-open {
  position: absolute;
  top: 0;
  right: 0;
  width: 10rem;
  height: 10rem;
  background: #f0dcd2;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  header .headCont .menu-open {
    width: 11rem;
    height: 11rem;
  }
}
header .headCont .entry {
  position: absolute;
  top: 0;
  right: 10rem;
}
@media screen and (max-width: 768px) {
  header .headCont .entry {
    right: 11rem;
  }
}
header .headCont .entry a {
  width: 16rem;
  height: 10rem;
  background: #552e30;
  font-size: 2.9rem;
  font-weight: 700;
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 768px) {
  header .headCont .entry a {
    width: 17.6rem;
    height: 11rem;
  }
}

.fadeIn {
  opacity: 0;
}

.float-object01 {
  padding: 20px;
  transition: transform 2s ease-out;
  will-change: transform;
  animation: fluffy01 3s ease-in-out infinite;
}

.float-object02 {
  padding: 20px;
  transition: transform 3s ease-out;
  will-change: transform;
  animation: fluffy01 2.5s ease-in-out infinite;
}

.float-object03 {
  padding: 20px;
  transition: transform 1.5s ease-out;
  will-change: transform;
  animation: fluffy01 3.5s ease-in-out infinite;
}

.float-object04 {
  padding: 20px;
  transition: transform 3s ease-out;
  will-change: transform;
  animation: fluffy01 4s ease-in-out infinite;
}

.float-object05 {
  padding: 20px;
  transition: transform 2s ease-out;
  will-change: transform;
  animation: fluffy01 2.8s ease-in-out infinite;
}

.float-object06 {
  padding: 20px;
  transition: transform 2s ease-out;
  will-change: transform;
  animation: fluffy01 3.2s ease-in-out infinite;
}

.float-object07 {
  padding: 20px;
  transition: transform 2s ease-out;
  will-change: transform;
  animation: fluffy01 2s ease-in-out infinite;
}

@keyframes burstScale {
  0% {
    opacity: 0;
    transform: scale(0);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes fluffy01 {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-10px);
  }
}
@keyframes fadefrombelow {
  0% {
    opacity: 0;
    transform: translateY(1rem);
    filter: blur(1.5px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }
}
.mv {
  width: 100%;
  height: 62.7vw;
  margin: auto auto 13.5rem;
  position: relative;
  background: url("../images/bg_mv.webp") no-repeat;
  background-size: 100%;
}
@media screen and (max-width: 768px) {
  .mv {
    height: 187vw;
    background: url("../images/bg_mv_sp.webp") no-repeat top -10.8rem left;
    background-size: 100%;
    overflow-x: hidden;
  }
}
.mv figure.mv01 {
  width: 40vw;
  position: absolute;
  top: 3.2vw;
  left: 28.2vw;
  z-index: 2;
  transform: scale(0);
  animation: burstScale 0.8s cubic-bezier(0.2, 0, 0.2, 1);
  animation-fill-mode: forwards;
}
@media screen and (max-width: 768px) {
  .mv figure.mv01 {
    width: 73rem;
    top: 5.2rem;
    left: -6.2rem;
    font-size: 2.6rem;
  }
}
.mv figure.mv02 {
  width: 23.3vw;
  position: absolute;
  top: 12.3vw;
  left: 72.2vw;
  z-index: 2;
  transform: scale(0);
  animation: burstScale 0.8s cubic-bezier(0.2, 0, 0.2, 1) 0.3s;
  animation-fill-mode: forwards;
}
@media screen and (max-width: 768px) {
  .mv figure.mv02 {
    width: 37.2rem;
    top: 79.4rem;
    left: auto;
    right: -2rem;
    font-size: 2.6rem;
  }
}
.mv figure.mv03 {
  width: 19.6vw;
  position: absolute;
  top: 36.4vw;
  left: 62.5vw;
  z-index: 2;
  transform: scale(0);
  animation: burstScale 0.8s cubic-bezier(0.2, 0, 0.2, 1) 0.5s;
  animation-fill-mode: forwards;
}
@media screen and (max-width: 768px) {
  .mv figure.mv03 {
    width: 73rem;
    top: 29.4rem;
    left: auto;
    right: -12.2rem;
    z-index: 1;
  }
}
.mv figure.mv04 {
  width: 40vw;
  position: absolute;
  top: 14.2vw;
  left: 41.3vw;
  transform: scale(0);
  animation: burstScale 1.4s cubic-bezier(0.2, 0, 0.2, 1) 0.7s;
  animation-fill-mode: forwards;
}
@media screen and (max-width: 768px) {
  .mv figure.mv04 {
    display: none;
  }
}
.mv h2 {
  font-size: 3.85vw;
  font-weight: 900;
  line-height: 1.4;
  color: #fff;
  position: absolute;
  top: 14.2vw;
  left: 11.9vw;
  z-index: 3;
  animation: fadefrombelow 1s cubic-bezier(0.2, 0, 0.2, 1) 1.5s;
  animation-fill-mode: forwards;
  opacity: 0;
}
@media screen and (max-width: 768px) {
  .mv h2 {
    top: 58rem;
    left: 4.5rem;
    font-size: 7rem;
    line-height: 10rem;
    letter-spacing: -0.3rem;
    z-index: 2;
  }
}
.mv p.lead {
  font-size: 1vw;
  font-weight: 700;
  line-height: 2;
  position: absolute;
  top: 31.9vw;
  left: 11.9vw;
  animation: fadefrombelow 1s cubic-bezier(0.2, 0, 0.2, 1) 2.3s;
  animation-fill-mode: forwards;
  opacity: 0;
}
@media screen and (max-width: 768px) {
  .mv p.lead {
    top: 94.8rem;
    left: 5rem;
    font-size: 2.6rem;
    z-index: 2;
    letter-spacing: -0.3rem;
  }
}

section {
  width: 100%;
  position: relative;
}
section p.sub {
  font-size: 5.2rem;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 768px) {
  section p.sub {
    font-size: 6rem;
  }
}

section.thisis {
  padding-bottom: 18.6rem;
}
@media screen and (max-width: 768px) {
  section.thisis {
    padding-bottom: 10rem;
  }
}
section.thisis h2 {
  width: 76.55rem;
  margin: auto auto 4.5rem;
}
@media screen and (max-width: 768px) {
  section.thisis h2 {
    width: 69.7rem;
  }
}
section.thisis ul.feature {
  width: 146rem;
  margin: 8rem auto 0;
  display: flex;
  justify-content: center;
  gap: 2.3rem;
}
@media screen and (max-width: 768px) {
  section.thisis ul.feature {
    width: 65rem;
    flex-direction: column;
    gap: 4rem;
  }
}
section.thisis ul.feature li {
  width: 47rem;
  border-radius: 4.8rem;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  section.thisis ul.feature li {
    width: 100%;
    border-radius: 8rem;
  }
}
section.thisis ul.feature li dl {
  width: 100%;
}
section.thisis ul.feature li dl dt {
  width: 100%;
  height: 25.7rem;
  overflow: hidden;
  position: relative;
}
@media screen and (max-width: 768px) {
  section.thisis ul.feature li dl dt {
    height: 42.8rem;
  }
}
section.thisis ul.feature li dl dt figure {
  width: 100%;
  overflow: hidden;
}
section.thisis ul.feature li dl dt figure img {
  transition: all 0.8s ease;
}
section.thisis ul.feature li dl dt figure img:hover {
  transform: scale(1.1, 1.1);
  opacity: 1;
}
section.thisis ul.feature li dl dt span.numero {
  width: 6.4rem;
  position: absolute;
  top: 8.9rem;
  left: 2.9rem;
}
@media screen and (max-width: 768px) {
  section.thisis ul.feature li dl dt span.numero {
    width: 10.5rem;
    top: 8.5rem;
    left: 4.4rem;
  }
}
section.thisis ul.feature li dl dt span.numero img {
  width: 100%;
}
section.thisis ul.feature li dl dt h3 {
  font-size: 3.1rem;
  font-weight: 700;
  color: #fff;
  position: absolute;
  top: 20.5rem;
  left: 2.4rem;
}
@media screen and (max-width: 768px) {
  section.thisis ul.feature li dl dt h3 {
    font-size: 5.2rem;
    line-height: 7.6rem;
    top: 25.5rem;
    left: 3.5rem;
  }
}
section.thisis ul.feature li dl dd {
  padding: 2.8rem 2.6rem 2.2rem;
  background: #f9be00;
}
@media screen and (max-width: 768px) {
  section.thisis ul.feature li dl dd {
    padding: 4.5rem;
  }
}
section.thisis ul.feature li dl dd span.explain {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 3rem;
  font-feature-settings: "palt";
  letter-spacing: -0.15rem;
  text-align: justify;
}
@media screen and (max-width: 768px) {
  section.thisis ul.feature li dl dd span.explain {
    font-size: 2.6rem;
    line-height: 5rem;
  }
}
section.thisis ul.feature li dl dd span.viewMore {
  height: 3.2rem;
  font-size: 1.8rem;
  font-weight: 800;
  background: url("../images/bg_viewmore.webp") no-repeat right center;
  background-size: 3.2rem;
  padding-right: 4rem;
  margin-top: 1rem;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding-bottom: 0.5rem;
}
@media screen and (max-width: 768px) {
  section.thisis ul.feature li dl dd span.viewMore {
    font-size: 2.8rem;
    background: url("../images/bg_viewmore.webp") no-repeat right center;
    background-size: 5rem;
    padding-right: 6.2rem;
    height: 6.2rem;
  }
}

section.about {
  padding-top: 17.4rem;
  background: #f9be00;
}
@media screen and (max-width: 678px) {
  section.about {
    padding-top: 24.6rem;
  }
}
section.about::before {
  content: '';
  width: 100%;
  height: 45.2rem;
  background: url("../images/bg_about_before.jpg") no-repeat center top;
  background-size: 1920px;
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (min-width: 1920px) {
  section.about::before {
    height: 23.5vw;
    background: url("../images/bg_about_before.jpg") no-repeat center top;
    background-size: 100%;
  }
}
@media screen and (max-width: 678px) {
  section.about::before {
    height: 22.4rem;
    background: url("../images/bg_about_before_sp.jpg") no-repeat center top;
    background-size: 100%;
  }
}
section.about::after {
  content: '';
  width: 100%;
  height: 40.4rem;
  background: url("../images/bg_about_after.jpg") no-repeat center bottom;
  background-size: 1920px;
  position: absolute;
  bottom: -20rem;
  left: 0;
  z-index: 1;
}
@media screen and (min-width: 1920px) {
  section.about::after {
    height: 21vw;
    background: url("../images/bg_about_after.jpg") no-repeat center top;
    background-size: 100%;
    height: 20vw;
    background: url(../images/bg_about_after.jpg) no-repeat center bottom;
    background-size: 100%;
    bottom: -5vw;
    z-index: 2;
  }
}
@media screen and (max-width: 678px) {
  section.about::after {
    height: 17.5rem;
    background: url("../images/bg_about_after_sp.jpg") no-repeat center top;
    background-size: 100%;
    bottom: -17rem;
  }
}
section.about h2 {
  width: 77.7rem;
  margin: auto auto 4.5rem;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  section.about h2 {
    width: 62.6rem;
  }
}
section.about p.sub {
  position: relative;
  z-index: 2;
}
section.about .inner {
  width: 121rem;
  margin: 18rem auto auto;
}
@media screen and (max-width: 768px) {
  section.about .inner {
    width: 100%;
    margin: 14rem auto auto;
  }
}
section.about .inner .aboutCont {
  width: 100%;
  min-height: 31.2rem;
  position: relative;
  z-index: 3;
}
@media screen and (max-width: 678px) {
  section.about .inner .aboutCont {
    width: 65rem;
    margin: auto;
    min-height: 82.7rem;
  }
}
section.about .inner .aboutCont h3 {
  width: 22rem;
  height: 6.79rem;
  position: relative;
  font-size: 2.15rem;
  font-weight: 900;
  z-index: 3;
}
@media screen and (max-width: 678px) {
  section.about .inner .aboutCont h3 {
    width: auto;
    height: auto;
    padding-bottom: 1.5rem;
    font-size: 3.8rem;
    display: inline-block;
  }
}
@media screen and (max-width: 678px) {
  section.about .inner .aboutCont h3::before {
    content: '';
    width: 100%;
    border-bottom: 0.3rem solid #552e30;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 2;
  }
}
section.about .inner .aboutCont h3::after {
  content: '';
  width: 20rem;
  height: 6.79rem;
  background: url("../images/bg_h3_about.webp") no-repeat;
  background-size: 20rem;
  position: absolute;
  top: -2.4rem;
  left: -1rem;
  z-index: -1;
}
@media screen and (max-width: 678px) {
  section.about .inner .aboutCont h3::after {
    width: 12.4rem;
    height: 12.4em;
    background: url("../images/bg_h3_about_sp.webp") no-repeat;
    background-size: 100%;
    top: -4.5rem;
    left: -1.9rem;
    z-index: -1;
  }
}
section.about .inner .aboutCont h3.last {
  letter-spacing: -0.25rem;
}
section.about .inner .aboutCont p.headLine {
  font-size: 4.4rem;
  font-weight: 700;
  line-height: 1.35;
  position: absolute;
  top: -0.6rem;
  left: 23.5rem;
  letter-spacing: -0.2rem;
}
@media screen and (max-width: 678px) {
  section.about .inner .aboutCont p.headLine {
    top: 11.6rem;
    left: 0;
    font-size: 5.4rem;
    line-height: 8.3rem;
    z-index: 2;
    letter-spacing: -0.3rem;
  }
}
section.about .inner .aboutCont p.lead {
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 4.6rem;
  position: absolute;
  top: -0.8rem;
  left: 23.5rem;
  letter-spacing: -0.2rem;
  z-index: 2;
}
@media screen and (max-width: 678px) {
  section.about .inner .aboutCont p.lead {
    top: 12rem;
    left: 0;
  }
}
section.about .inner .aboutCont p.viewMorePlus {
  position: absolute;
  top: 13.5rem;
  left: 23.5rem;
  height: 3.2rem;
  font-size: 1.8rem;
  font-weight: 800;
  background: url("../images/bg_viewmore_plus.webp") no-repeat right center;
  background-size: 3.2rem;
  padding-right: 4rem;
  margin-top: 1rem;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding-bottom: 0.5rem;
  cursor: pointer;
}
@media screen and (max-width: 678px) {
  section.about .inner .aboutCont p.viewMorePlus {
    height: 5rem;
    top: 44rem;
    left: -0.4rem;
    font-size: 2.8rem;
    background: url("../images/bg_viewmore_plus.webp") no-repeat right center;
    background-size: 5rem;
    padding-right: 6.6rem;
  }
}
section.about .inner .aboutCont p.viewMore {
  position: absolute;
  top: 14.5rem;
  left: 23.5rem;
  z-index: 2;
}
@media screen and (max-width: 678px) {
  section.about .inner .aboutCont p.viewMore {
    top: 44rem;
    left: -0.4rem;
  }
}
section.about .inner .aboutCont p.viewMore a {
  height: 3.2rem;
  font-size: 1.8rem;
  font-weight: 800;
  background: url("../images/bg_viewmore.webp") no-repeat right center;
  background-size: 3.2rem;
  padding-right: 4rem;
  margin-top: 1rem;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding-bottom: 0.5rem;
  color: #552e30;
}
@media screen and (max-width: 678px) {
  section.about .inner .aboutCont p.viewMore a {
    font-size: 2.8rem;
    background: url("../images/bg_viewmore.webp") no-repeat right center;
    background-size: 5rem;
    height: 5rem;
    padding-right: 6.6rem;
  }
}
section.about .inner .aboutCont figure.about01 {
  width: 37rem;
  position: absolute;
  top: -5.4rem;
  right: 1.5rem;
  z-index: 2;
}
@media screen and (max-width: 678px) {
  section.about .inner .aboutCont figure.about01 {
    width: 58rem;
    top: 5rem;
    right: -10rem;
    z-index: 1;
  }
}
section.about .inner .aboutCont ul.digitCard {
  width: 100%;
  display: flex;
  justify-content: space-between;
  margin-bottom: 16.7rem;
}
@media screen and (max-width: 768px) {
  section.about .inner .aboutCont ul.digitCard {
    flex-wrap: wrap;
    row-gap: 2.2rem;
    margin-top: 6rem;
  }
}
section.about .inner .aboutCont ul.digitCard li {
  width: 18.6rem;
  height: 27.9rem;
  padding-top: 2.5rem;
  text-align: center;
}
@media screen and (max-width: 768px) {
  section.about .inner .aboutCont ul.digitCard li {
    width: 31.2rem;
    height: 46.7rem;
    padding-top: 4.8rem;
  }
}
section.about .inner .aboutCont ul.digitCard li:nth-of-type(1) {
  background: url("../images/bg_digi01.webp") no-repeat;
  background-size: 100%;
}
@media screen and (max-width: 768px) {
  section.about .inner .aboutCont ul.digitCard li:nth-of-type(1) {
    background: url("../images/bg_digi01_sp.webp") no-repeat;
    background-size: 100%;
  }
}
section.about .inner .aboutCont ul.digitCard li:nth-of-type(2) {
  background: url("../images/bg_digi02.webp") no-repeat;
  background-size: 100%;
}
@media screen and (max-width: 768px) {
  section.about .inner .aboutCont ul.digitCard li:nth-of-type(2) {
    background: url("../images/bg_digi02_sp.webp") no-repeat;
    background-size: 100%;
  }
}
section.about .inner .aboutCont ul.digitCard li:nth-of-type(3) {
  background: url("../images/bg_digi03.webp") no-repeat;
  background-size: 100%;
}
@media screen and (max-width: 768px) {
  section.about .inner .aboutCont ul.digitCard li:nth-of-type(3) {
    background: url("../images/bg_digi03_sp.webp") no-repeat;
    background-size: 100%;
  }
}
section.about .inner .aboutCont ul.digitCard li:nth-of-type(4) {
  background: url("../images/bg_digi04.webp") no-repeat;
  background-size: 100%;
}
@media screen and (max-width: 768px) {
  section.about .inner .aboutCont ul.digitCard li:nth-of-type(4) {
    background: url("../images/bg_digi04_sp.webp") no-repeat;
    background-size: 100%;
  }
}
section.about .inner .aboutCont ul.digitCard li:nth-of-type(5) {
  background: url("../images/bg_digi05.webp") no-repeat;
  background-size: 100%;
}
@media screen and (max-width: 768px) {
  section.about .inner .aboutCont ul.digitCard li:nth-of-type(5) {
    background: url("../images/bg_digi05_sp.webp") no-repeat;
    background-size: 100%;
  }
}
section.about .inner .aboutCont ul.digitCard li:nth-of-type(6) {
  background: url("../images/bg_digi06.webp") no-repeat;
  background-size: 100%;
}
@media screen and (max-width: 768px) {
  section.about .inner .aboutCont ul.digitCard li:nth-of-type(6) {
    background: url("../images/bg_digi06_sp.webp") no-repeat;
    background-size: 100%;
  }
}
section.about .inner .aboutCont ul.digitCard li h4 {
  font-size: 2.26rem;
  font-weight: 700;
  line-height: 2.86rem;
  height: 5rem;
  margin-bottom: 8rem;
}
@media screen and (max-width: 768px) {
  section.about .inner .aboutCont ul.digitCard li h4 {
    font-size: 3.8rem;
    font-weight: 700;
    line-height: 4.8rem;
    height: 8.6rem;
    margin-bottom: 13.6rem;
  }
}
section.about .inner .aboutCont ul.digitCard li figure {
  width: 14rem;
  margin: auto auto 0.9rem;
}
@media screen and (max-width: 768px) {
  section.about .inner .aboutCont ul.digitCard li figure {
    width: 23.65rem;
  }
}
section.about .inner .aboutCont ul.digitCard li p {
  font-size: 2.26rem;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  section.about .inner .aboutCont ul.digitCard li p {
    font-size: 3.8rem;
  }
}
section.about .inner .aboutCont ul.digitCard li p span {
  font-size: 1rem;
  display: block;
  margin-top: 0.8rem;
  letter-spacing: -0.1rem;
}
@media screen and (max-width: 768px) {
  section.about .inner .aboutCont ul.digitCard li p span {
    font-size: 1.67rem;
  }
}

section.work {
  padding-top: 34rem;
}
@media screen and (max-width: 768px) {
  section.work {
    padding-top: 25rem;
  }
}
section.work h2 {
  width: 86.7rem;
  margin: auto auto 4rem;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  section.work h2 {
    width: 70.6rem;
  }
}
section.work p.sub {
  position: relative;
  z-index: 2;
}
section.work ul.worker {
  width: 146rem;
  margin: 13.8rem auto 8rem;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  section.work ul.worker {
    width: 65rem;
    flex-wrap: wrap;
    gap: 7rem;
  }
}
section.work ul.worker li.left {
  width: 47rem;
  height: 47.16rem;
  border: 0.6rem solid #f9be00;
  border-radius: 4.8rem;
  position: relative;
  box-sizing: border-box;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.left {
    width: 100%;
    height: 84.4rem;
    border: 1rem solid #f9be00;
  }
}
section.work ul.worker li.left dl {
  width: 100%;
}
section.work ul.worker li.left dl dt {
  width: 28.6rem;
  height: 28.6rem;
  position: absolute;
  top: -13.4rem;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.left dl dt {
    width: 41.7rem;
    top: -6rem;
  }
}
section.work ul.worker li.left dl dd {
  width: 37.4rem;
  position: absolute;
  top: 14.4rem;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.left dl dd {
    top: 34.2rem;
    width: 56.7rem;
  }
}
section.work ul.worker li.left dl dd h3 {
  font-size: 2.32rem;
  font-weight: 700;
  color: #fff;
  padding: 0.7rem 3rem 0.7rem 1.2rem;
  background: #552e30;
  width: 100%;
  text-align: center;
  margin-bottom: 1.6rem;
  position: relative;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.left dl dd h3 {
    width: 98%;
    margin: auto;
    font-size: 3.16rem;
    padding: 1.1rem 4rem 1.1rem 2.1rem;
    margin-bottom: 2rem;
  }
}
section.work ul.worker li.left dl dd h3::after {
  content: '';
  width: 1.4rem;
  height: 0.4rem;
  position: absolute;
  top: 0;
  right: -1px;
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 1.9rem solid transparent;
  border-bottom: 1.9rem solid transparent;
  border-right: 1.4rem solid #ffffff;
  border-left: 0;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.left dl dd h3::after {
    border-width: 2.9rem 2rem 2.9rem 0;
    border-color: transparent #FFFFFF transparent transparent;
  }
}
section.work ul.worker li.left dl dd h4 {
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 4.2rem;
  margin-bottom: 1.6rem;
  font-feature-settings: "palt";
  letter-spacing: -0.2rem;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.left dl dd h4 {
    font-size: 3.8rem;
    line-height: 6.4rem;
    margin-bottom: 2rem;
    letter-spacing: -0.3rem;
  }
}
section.work ul.worker li.left dl dd h4 span {
  font-size: 2rem;
  letter-spacing: -0.5rem;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.left dl dd h4 span {
    font-size: 2.9rem;
  }
}
section.work ul.worker li.left dl dd .prof {
  margin-bottom: 3rem;
}
section.work ul.worker li.left dl dd .prof p {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.7;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.left dl dd .prof p {
    font-size: 2.8rem;
    line-height: 1.5;
  }
}
section.work ul.worker li.left dl dd .prof p span {
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.left dl dd .prof p span {
    font-size: 3.4rem;
  }
}
section.work ul.worker li.left dl dd p.viewMore {
  position: absolute;
  bottom: 3rem;
  right: 0;
  z-index: 2;
}
section.work ul.worker li.left dl dd p.viewMore a {
  width: 12.4rem;
  height: 3.2rem;
  font-size: 1.8rem;
  font-weight: 900;
  background: url("../images/bg_viewmore.webp") no-repeat right center;
  background-size: 3.2rem;
  padding-right: 4rem;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  color: #552e30;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.left dl dd p.viewMore a {
    font-size: 2.8rem;
    background: url("../images/bg_viewmore.webp") no-repeat right center;
    background-size: 5rem;
    width: 19.8rem;
    height: 5rem;
    padding-right: 6.7rem;
    padding-bottom: 1rem;
  }
}
section.work ul.worker li.right {
  width: 47rem;
  height: 47.16rem;
  border: 0.6rem solid #f9be00;
  border-radius: 4.8rem;
  position: relative;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.right {
    width: 100%;
    height: 75.4rem;
  }
}
section.work ul.worker li.right dl {
  width: 100%;
  display: flex;
  justify-content: space-between;
  flex-direction: row-reverse;
}
section.work ul.worker li.right dl dt {
  width: 33.4rem;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.right dl dt {
    width: 26.1rem;
  }
}
section.work ul.worker li.right dl dt img {
  position: absolute;
  bottom: 0;
  left: auto;
  right: 5rem;
  width: 24.8rem;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.right dl dt img {
    bottom: 0;
    left: auto;
    right: -2rem;
    width: 26.2rem;
  }
}
section.work ul.worker li.right dl dd {
  width: 45rem;
  padding-top: 4.5rem;
  margin-left: 9.8rem;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.right dl dd {
    padding-top: 6rem;
    margin-left: 5.8rem;
    width: 100rem;
    position: relative;
    z-index: 2;
  }
}
section.work ul.worker li.right dl dd h3 {
  font-size: 2.32rem;
  font-weight: 700;
  color: #fff;
  padding: 0.7rem 3rem 0.7rem 1.2rem;
  background: #552e30;
  display: inline-block;
  margin-bottom: 3rem;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.right dl dd h3 {
    font-size: 3.16rem;
    padding: 0.8rem 4rem 0.8rem 2.1rem;
    margin-bottom: 8rem;
  }
}
section.work ul.worker li.right dl dd h3::after {
  content: '';
  width: 1.4rem;
  height: 0.4rem;
  position: absolute;
  top: 0;
  right: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 1.9rem solid transparent;
  border-bottom: 1.9rem solid transparent;
  border-right: 1.4rem solid #ffffff;
  border-left: 0;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.right dl dd h3::after {
    border-width: 2.4rem 1.6rem 2.4rem 0;
    border-color: transparent #FFFFFF transparent transparent;
  }
}
section.work ul.worker li.right dl dd h4 {
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 5.1rem;
  margin-bottom: 3rem;
  letter-spacing: -0.2rem;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.right dl dd h4 {
    font-size: 4.6rem;
    line-height: 7.4rem;
    margin-bottom: 5rem;
  }
}
section.work ul.worker li.right dl dd .prof {
  margin-bottom: 3rem;
}
section.work ul.worker li.right dl dd .prof p {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.7;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.right dl dd .prof p {
    font-size: 2.8rem;
    line-height: 1.5;
  }
}
section.work ul.worker li.right dl dd .prof p strong {
  font-size: 2.2rem;
  font-weight: 700;
  display: block;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.right dl dd .prof p strong {
    font-size: 3.4rem;
  }
}
section.work ul.worker li.right dl dd p.viewMore {
  margin-top: 1rem;
  padding-bottom: 0.5rem;
  z-index: 2;
}
section.work ul.worker li.right dl dd p.viewMore a {
  width: 12.4rem;
  height: 3.2rem;
  font-size: 1.8rem;
  font-weight: 800;
  background: url("../images/bg_viewmore.webp") no-repeat right center;
  background-size: 3.2rem;
  padding-right: 4rem;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  color: #552e30;
}
@media screen and (max-width: 768px) {
  section.work ul.worker li.right dl dd p.viewMore a {
    font-size: 2.8rem;
    background: url("../images/bg_viewmore.webp") no-repeat right center;
    background-size: 5rem;
    width: 19.8rem;
    height: 5rem;
    padding-right: 6.7rem;
    padding-bottom: 1rem;
  }
}
section.work p.ribon {
  width: 80rem;
  height: 12.8rem;
  margin: auto auto 14.5rem;
}
@media screen and (max-width: 768px) {
  section.work p.ribon {
    width: 65rem;
    height: 12.8rem;
    margin: auto auto 10rem;
  }
}
section.work p.ribon a {
  width: 100%;
  height: 100%;
  font-size: 3.15rem;
  font-weight: 900;
  color: #552e30;
  background: url("../images/bg_viewmore.webp") no-repeat center right 4.2rem #f9be00;
  background-size: 3.94rem;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 768px) {
  section.work p.ribon a {
    font-size: 3.2rem;
    background: url("../images/bg_viewmore.webp") no-repeat center right 4.2rem #f9be00;
    background-size: 5rem;
  }
}
section.work .foodLine {
  width: 100%;
  height: 19.3rem;
  background-image: url(../images/foods.png);
  background-repeat: repeat-x;
  background-size: 192rem auto;
  animation: foods_flow 30s linear infinite;
}
@media screen and (max-width: 768px) {
  section.work .foodLine {
    height: 28rem;
    background-size: 1200px auto;
  }
}

@keyframes foods_flow {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -1140px 0;
  }
}
section.career {
  margin-top: 20rem;
  padding-top: 17.4rem;
  padding-bottom: 10rem;
  background: #f9be00;
}
@media screen and (max-width: 678px) {
  section.career {
    margin-top: 6rem;
    padding-top: 19rem;
    padding-bottom: 5rem;
  }
}
section.career::before {
  content: '';
  width: 100%;
  height: 45.2rem;
  background: url("../images/bg_about_before.jpg") no-repeat center top;
  background-size: 1920px;
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (max-width: 678px) {
  section.career::before {
    height: 22.4rem;
    background: url("../images/bg_about_before_sp.jpg") no-repeat center top;
    background-size: 100%;
  }
}
@media screen and (min-width: 1920px) {
  section.career::before {
    height: 23.5vw;
    background: url(../images/bg_about_before.jpg) no-repeat center top;
    background-size: 100%;
  }
}
section.career h2 {
  width: 35.2rem;
  margin: auto auto 4.5rem;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 678px) {
  section.career h2 {
    width: 28.3rem;
  }
}
section.career p.sub {
  position: relative;
  z-index: 2;
}
section.career .intro {
  margin: 12.9rem auto 7.4rem;
  width: 121rem;
  position: relative;
}
@media screen and (max-width: 768px) {
  section.career .intro {
    width: 100%;
    margin: 12rem auto 1rem;
    height: 108rem;
  }
}
section.career .intro figure.intro01 {
  width: 66rem;
  border-radius: 3.3rem;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  section.career .intro figure.intro01 {
    position: absolute;
    width: 65rem;
    left: 5rem;
  }
}
section.career .intro figure.intro02 {
  width: 46rem;
  position: absolute;
  top: 1.2rem;
  left: 54rem;
}
@media screen and (max-width: 768px) {
  section.career .intro figure.intro02 {
    width: 52rem;
    top: 39rem;
    left: -5rem;
    z-index: 2;
  }
}
section.career .intro .txts {
  position: absolute;
  top: 9rem;
  left: 66em;
}
@media screen and (max-width: 768px) {
  section.career .intro .txts {
    top: 55.5rem;
    left: 6.2rem;
    z-index: 3;
  }
}
section.career .intro .txts p.suki {
  font-size: 3.9rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
}
@media screen and (max-width: 768px) {
  section.career .intro .txts p.suki {
    font-size: 5.4rem;
  }
}
section.career .intro .txts p.suki::first-letter {
  font-size: 6rem;
}
@media screen and (max-width: 768px) {
  section.career .intro .txts p.suki::first-letter {
    font-size: 8rem;
  }
}
section.career .intro .txts p.lead {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 4.2rem;
  margin-top: 4rem;
}
@media screen and (max-width: 768px) {
  section.career .intro .txts p.lead {
    font-size: 2.6rem;
    line-height: 5rem;
  }
}
section.career .step {
  margin: auto;
  margin-top: 5.6rem;
  width: 121rem;
}
@media screen and (max-width: 768px) {
  section.career .step {
    width: 100%;
    margin-top: 1rem;
  }
}
section.career .step h3 {
  font-size: 2.7rem;
  font-weight: 700;
  margin-bottom: 2.7rem;
}
@media screen and (max-width: 768px) {
  section.career .step h3 {
    font-size: 4.5rem;
    width: 65rem;
    margin: auto;
    margin-bottom: 4rem;
  }
}
section.career .step p.lead {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 3.12rem;
  margin-bottom: 4rem;
}
@media screen and (max-width: 768px) {
  section.career .step p.lead {
    font-size: 2.6rem;
    line-height: 5rem;
    width: 65rem;
    margin: auto auto 6.5rem auto;
  }
}
section.career .step .figBox {
  width: 100%;
  padding: 6.2rem;
  border-radius: 6.8rem;
  background: #fff;
}
section.career .step .figBox figure {
  width: 100%;
}
section.career .step .figBox p {
  font-size: 1.92rem;
  font-weight: 700;
  margin-bottom: 2.4rem;
}
section.career .step .figBox p span {
  color: #ff7026;
}
section.career .step .scrollBox {
  width: auto;
}
@media screen and (max-width: 768px) {
  section.career .step .scrollBox {
    margin-left: 5rem;
    margin-bottom: 12.6rem;
    overflow-x: scroll;
  }
}
@media screen and (max-width: 768px) {
  section.career .step .scrollBox img.step01_fig {
    width: 170rem;
    max-width: 170rem;
    height: 54.2rem;
    margin-bottom: 5.2rem;
  }
}
@media screen and (max-width: 768px) {
  section.career .step .scrollBox img.step02_fig {
    width: 213.6rem;
    max-width: 213.6rem;
    height: 84.5rem;
    margin-bottom: 5.2rem;
  }
}

.infomation {
  background: rgba(249, 190, 0, 0.15);
  padding-top: 10rem;
  padding-bottom: 4.5em;
}
@media screen and (max-width: 678px) {
  .infomation {
    padding-bottom: 14.5rem;
  }
}
.infomation.others {
  padding-top: 5.4rem;
}
.infomation h2 {
  font-size: 5.2rem;
  font-weight: 700;
  margin-bottom: 9rem;
  text-align: center;
}
@media screen and (max-width: 678px) {
  .infomation h2 {
    font-size: 6rem;
  }
}
.infomation p.ribon {
  width: 80rem;
  height: 10rem;
  margin: auto auto 1.5rem;
}
@media screen and (max-width: 768px) {
  .infomation p.ribon {
    width: 65rem;
    height: 12.8rem;
    margin: auto auto 1.8rem;
  }
}
.infomation p.ribon a {
  width: 100%;
  height: 100%;
  font-size: 3.15rem;
  font-weight: 900;
  color: #552e30;
  background: url(../images/bg_viewmore.webp) no-repeat center right 4.2rem #f9be00;
  background-size: 3.94rem;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .infomation p.ribon a {
    font-size: 3.2rem;
    background: url(../images/bg_viewmore.webp) no-repeat center right 4.2rem #f9be00;
    background-size: 5rem;
  }
}
.infomation p.entry {
  width: 80rem;
  height: 12.8rem;
  margin: 3.6rem auto 7.7rem;
}
@media screen and (max-width: 768px) {
  .infomation p.entry {
    width: 65rem;
    height: 16rem;
    margin: 7rem auto 11.8rem;
  }
}
.infomation p.entry a {
  width: 100%;
  height: 100%;
  font-size: 4.5rem;
  font-weight: 700;
  color: #fff;
  background: #552e30;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .infomation p.entry a {
    font-size: 5.6rem;
  }
}
.infomation ul {
  margin: auto auto 8.2rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 1.8rem;
}
@media screen and (max-width: 768px) {
  .infomation ul {
    gap: 3.6rem;
    margin: auto auto 11.8rem;
  }
}
.infomation ul li a {
  font-size: 1.68rem;
  font-weight: 900;
  background: url("../images/arrow_r.webp") no-repeat center right;
  background-size: 1.4rem;
  padding-right: 2rem;
}
@media screen and (max-width: 768px) {
  .infomation ul li a {
    font-size: 2.8rem;
    background: url("../images/arrow_r.webp") no-repeat center right;
    background-size: 2.5rem;
    padding-right: 3.2rem;
  }
}
.infomation .logos {
  width: 80rem;
  padding-left: 21rem;
  margin: auto;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 5.5rem;
}
@media screen and (max-width: 768px) {
  .infomation .logos {
    width: 100%;
    padding-left: 8rem;
    gap: 7rem;
  }
}
.infomation .logos figure.cocos {
  width: 15.6rem;
}
@media screen and (max-width: 768px) {
  .infomation .logos figure.cocos {
    width: 20rem;
  }
}
.infomation .logos figure.zensho {
  width: 22.1rem;
}
@media screen and (max-width: 768px) {
  .infomation .logos figure.zensho {
    width: 28.3rem;
  }
}

footer {
  width: 100%;
  height: 5.6rem;
  background: #f9be00;
}
@media screen and (max-width: 768px) {
  footer {
    height: 8.6rem;
  }
}
footer p {
  width: 100%;
  height: 100%;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.4rem;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 768px) {
  footer p {
    font-size: 2.2rem;
  }
}

#backtopBox {
  width: 4.2rem;
  height: 6.7rem;
  position: fixed;
  bottom: 8rem;
  right: 1.9rem;
  z-index: 4;
  transition: all 0.4s ease;
  opacity: 1;
  pointer-events: none;
}
@media screen and (max-width: 768px) {
  #backtopBox {
    bottom: 10rem;
    right: 3rem;
    transform: translateY(0);
    width: 7rem;
    height: 11.6rem;
  }
}

#backtopBox a {
  display: block;
  height: 100%;
  width: 100%;
  transition: all 0.2s ease;
  pointer-events: all;
}
@media screen and (max-width: 768px) {
  #backtopBox a {
    height: 11.6rem;
    width: 7rem;
  }
}

#menu-open {
  top: 0;
  right: 0;
  width: 10rem;
  height: 10rem;
  position: absolute;
  color: #fff;
  text-align: center;
  padding-top: 0;
  box-sizing: border-box;
  font-size: 1.74rem;
  z-index: 21;
  opacity: 1;
}
@media screen and (max-width: 768px) {
  #menu-open {
    width: 11rem;
    height: 11rem;
  }
}

a#menu-open span {
  display: block;
  width: 3.6rem;
  height: 0.27rem;
  background: #552e30;
}
@media screen and (max-width: 768px) {
  a#menu-open span {
    width: 4rem;
    height: 0.3rem;
  }
}

a#menu-open span:first-child {
  position: absolute;
  top: 3.5rem;
  right: 3.2rem;
  transition: all 0.4s ease;
}
@media screen and (max-width: 768px) {
  a#menu-open span:first-child {
    top: 4rem;
    right: 3.5rem;
  }
}

a#menu-open span:nth-child(2) {
  position: absolute;
  top: 4.7rem;
  right: 3.2rem;
  transition: all 0.4s ease;
}
@media screen and (max-width: 768px) {
  a#menu-open span:nth-child(2) {
    top: 5.2rem;
    right: 3.5rem;
  }
}

a#menu-open span:nth-child(3) {
  position: absolute;
  top: 5.9rem;
  right: 3.2rem;
  transition: all 0.4s ease;
}
@media screen and (max-width: 768px) {
  a#menu-open span:nth-child(3) {
    top: 6.4rem;
    right: 3.5rem;
  }
}

#menu-open.open {
  position: fixed;
  right: 0;
  width: 10rem;
  height: 10rem;
  z-index: -1;
  opacity: 0;
}
@media screen and (max-width: 768px) {
  #menu-open.open {
    width: 11rem;
    height: 11rem;
  }
}

#menu-panel {
  opacity: 0;
  visibility: hidden;
  position: absolute;
  top: 10rem;
  right: 0;
  z-index: 20;
  padding: 0 5rem 0;
  width: 50rem;
  height: 68rem;
  background: #f0dcd2;
  box-sizing: border-box;
  transition: all 0.5s ease;
}
@media screen and (max-width: 768px) {
  #menu-panel {
    top: 11rem;
    width: 100%;
    height: 100vh;
    padding: 0 9.9rem 0;
  }
}

#menu-panel.open {
  opacity: 1;
  visibility: visible;
  z-index: 20;
}

#menu-panel > ul {
  margin: auto;
}

#menu-panel > ul > li {
  border-bottom: 2rem solid #fff;
  margin-bottom: 0;
}
#menu-panel > ul > li:last-of-type {
  border: none;
}
@media screen and (max-width: 768px) {
  #menu-panel > ul > li:last-of-type {
    border-bottom: 2rem solid #fff;
  }
}

#menu-panel > ul > li > a {
  font-size: 2.56rem;
  padding: 5.4rem 0.9rem;
  display: block;
  color: #fff;
}

#menu-panel > ul li ul.secondDeg {
  margin-top: 0;
  padding-bottom: 1rem;
}

#menu-panel > ul li ul.secondDeg li {
  border-bottom: none;
  margin-bottom: 2.1rem;
}

#menu-panel > ul li ul.secondDeg li a {
  font-size: 2.4rem;
  padding: 1rem 0;
  display: block;
  color: #fff;
}

#menu-panel > ul:nth-of-type(3) {
  width: 67rem;
  display: grid;
  /* width: fit-content; */
  column-gap: 2em;
  grid-template-columns: repeat(2, auto);
  margin-top: 3rem;
}

#menu-panel > ul:nth-of-type(3) li {
  border-bottom: none;
}

p.navRights {
  font-size: 1.8rem;
  color: #fff;
  text-align: center;
  margin-top: 26.2rem;
}

.btn-menu {
  position: absolute;
  right: 0;
  top: 0;
  padding: 0 0;
  border: none;
  height: 10rem;
  width: 10rem;
  opacity: 0 !important;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .btn-menu {
    height: 11rem;
    width: 11rem;
  }
}

.btn-menu.active {
  opacity: 1 !important;
  z-index: 30;
}

#menu-close {
  top: -10rem;
  background: #f0dcd2;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  #menu-close {
    top: -11rem;
  }
}

#menu-close span {
  width: 4.3rem;
  height: 0.27rem;
  background: #552e30;
  transition: 0.4s;
}
@media screen and (max-width: 768px) {
  #menu-close span {
    height: 0.3rem;
  }
}

#menu-close span:first-child {
  position: absolute;
  top: 4.8rem;
  right: 2.9rem;
  transition: all 0.4s ease;
  transform: rotate(45deg);
}
@media screen and (max-width: 768px) {
  #menu-close span:first-child {
    top: 5.3rem;
    right: 3.25rem;
  }
}

#menu-close span:nth-child(2) {
  display: none;
}

#menu-close span:nth-child(3) {
  position: absolute;
  top: 4.8rem;
  right: 2.9rem;
  transition: all 0.4s ease;
  transform: rotate(-45deg);
}
@media screen and (max-width: 768px) {
  #menu-close span:nth-child(3) {
    top: 5.3rem;
    right: 3.25rem;
  }
}

nav ul li {
  border-bottom: 0.2rem solid #fff;
  margin-bottom: 0;
}
nav ul li:last-of-type {
  border: none;
}
@media screen and (max-width: 768px) {
  nav ul li:last-of-type {
    border-bottom: 0.2rem solid #fff;
  }
}

nav ul li a {
  font-size: 2.56rem;
  font-weight: 700;
  padding: 5.4rem 0.9rem;
  display: block;
  color: #552e30;
}
@media screen and (max-width: 768px) {
  nav ul li a {
    font-size: 2.8rem;
    padding: 6.4rem 0.9rem;
  }
}

.modal {
  display: none;
  /* 初期状態は非表示 */
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(249, 190, 0, 0.5);
  justify-content: center;
  align-items: center;
  z-index: 501;
}
@media screen and (max-width: 768px) {
  .modal {
    padding-top: 0;
  }
}

@keyframes fadeInUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.modal-content {
  background-color: #fff;
  padding: 5.4vw 9vw;
  box-sizing: border-box;
  width: auto;
  height: 90vh;
  position: relative;
  border-radius: 4.8rem;
  opacity: 0;
  transform: translateY(20px);
  /* 下から20pxずらして表示 */
  animation: fadeInUp 0.4s ease-out forwards;
}
@media screen and (max-width: 768px) {
  .modal-content {
    width: 65rem;
    padding: 8rem 3rem 8rem 3.8rem;
  }
}
.modal-content figure {
  width: auto;
  height: 100%;
}
.modal-content figure img {
  width: auto;
  height: auto;
}
.modal-content .close-modal {
  position: absolute;
  top: 4vw;
  right: 4vw;
  cursor: pointer;
  width: 1.67vw;
  height: 1.67vw;
  background: url("../images/close.webp") no-repeat;
  background-size: 1.67vw;
}
@media screen and (max-width: 768px) {
  .modal-content .close-modal {
    background: url("../images/close.webp") no-repeat top 1.2rem left 1.5rem;
    background-size: 3.6rem;
    top: 4.7vw;
    right: 5.9vw;
    width: 5.4rem;
    height: 7rem;
  }
}
.modal-content h3 {
  font-size: 1.45vw;
  font-weight: 700;
  color: #f9aa00;
  margin-bottom: 1.7vw;
}
@media screen and (max-width: 768px) {
  .modal-content h3 {
    font-size: 3rem;
    margin-bottom: 4.8rem;
  }
}
.modal-content .message {
  height: 90%;
  overflow-y: auto;
}
.modal-content .message p {
  font-size: 1.04vw;
  font-weight: 700;
  line-height: 2.2;
  margin-bottom: 1.4vw;
}
@media screen and (max-width: 768px) {
  .modal-content .message p {
    font-size: 2.4rem;
    line-height: 4.6rem;
    margin-bottom: 3rem;
    letter-spacing: -0.2rem;
  }
}
.modal-content .message p.president {
  font-size: 1.87vw;
  font-weight: 700;
  margin-top: 3vw;
  line-height: 1;
  text-align: left;
  float: right;
  padding-right: 4rem;
}
@media screen and (max-width: 768px) {
  .modal-content .message p.president {
    font-size: 3.8rem;
    margin-top: 7rem;
    padding-right: 0;
  }
}
.modal-content .message p.president span {
  margin-bottom: 0.6vw;
  font-size: 50%;
  display: block;
}
@media screen and (max-width: 768px) {
  .modal-content .message p.president span {
    font-size: 2.2rem;
    margin-bottom: 1rem;
  }
}

.pageTtlOther {
  width: 100%;
  height: 17.7vw;
  position: relative;
}
@media screen and (max-width: 768px) {
  .pageTtlOther {
    height: 38rem;
  }
}
.pageTtlOther.csr {
  margin-bottom: 16.5rem;
}
@media screen and (max-width: 768px) {
  .pageTtlOther.csr {
    margin-bottom: 9rem;
  }
}
.pageTtlOther h1 {
  position: absolute;
  top: 5.3vw;
  left: 12.1vw;
  font-size: 2.18vw;
  font-weight: 700;
  color: #552e30;
  padding-top: 4.89vw;
}
@media screen and (max-width: 768px) {
  .pageTtlOther h1 {
    top: 4.7rem;
    left: 5rem;
    padding-top: 22rem;
    font-size: 4.6rem;
  }
}
.pageTtlOther h1.recruit {
  width: 47vw;
  height: 7.2vw;
  background: url("../images/bg_recruit.webp") no-repeat;
  background-size: 100%;
}
@media screen and (max-width: 768px) {
  .pageTtlOther h1.recruit {
    width: 44.1rem;
    height: 25.8rem;
    background: url("../images/bg_recruit_sp.webp") no-repeat;
    background-size: 100%;
  }
}
.pageTtlOther h1.work {
  width: 37.3vw;
  height: 7.2vw;
  background: url("../images/bg_work.webp") no-repeat;
  background-size: 100%;
}
@media screen and (max-width: 768px) {
  .pageTtlOther h1.work {
    width: 40.67rem;
    height: 20.19rem;
    background: url("../images/bg_work_sp.webp") no-repeat;
    background-size: 100%;
    padding-top: 16.3rem;
    font-size: 3.8rem;
  }
}
.pageTtlOther h1.more {
  width: 30.3vw;
  height: 8vw;
  background: url("../images/bg_more.webp") no-repeat;
  background-size: 100%;
}
@media screen and (max-width: 768px) {
  .pageTtlOther h1.more {
    width: 50rem;
    height: 20.19rem;
    background: url("../images/bg_more_sp.webp") no-repeat;
    background-size: 28.41rem;
    padding-top: 16.3rem;
    font-size: 3.8rem;
  }
}
.pageTtlOther h1.csr {
  width: 29.9vw;
  height: 8vw;
  background: url("../images/bg_csr.webp") no-repeat;
  background-size: 100%;
}
@media screen and (max-width: 768px) {
  .pageTtlOther h1.csr {
    width: 50rem;
    height: 20.19rem;
    background: url("../images/bg_csr_sp.webp") no-repeat;
    background-size: 28.41rem;
    padding-top: 16.3rem;
    font-size: 3.8rem;
  }
}

.pageTtl {
  width: 100%;
  height: 28.12vw;
  position: relative;
}
@media screen and (max-width: 768px) {
  .pageTtl {
    height: 90rem;
  }
}
.pageTtl h1 {
  position: absolute;
  top: 5.4vw;
  left: 11.8vw;
  font-size: 2.18vw;
  font-weight: 700;
  color: #552e30;
  padding-top: 12.3vw;
  background: url("../images/bg_workttl.webp") no-repeat;
  background-size: 100%;
  width: 19.8vw;
  height: 13.7vw;
}
@media screen and (max-width: 768px) {
  .pageTtl h1 {
    width: 28.36rem;
    height: 20.1rem;
    top: 7.48rem;
    left: 4.26rem;
    font-size: 3.8rem;
    padding-top: 16.2rem;
  }
}
.pageTtl .intTtl {
  position: absolute;
  top: 14vw;
  left: 41.3vw;
}
@media screen and (max-width: 768px) {
  .pageTtl .intTtl {
    top: 51.6rem;
    left: 5rem;
  }
}
.pageTtl .intTtl figure {
  width: 10.9vw;
  margin-bottom: 1.5vw;
}
@media screen and (max-width: 768px) {
  .pageTtl .intTtl figure {
    width: 21rem;
    margin-bottom: 2.5rem;
  }
}
.pageTtl .intTtl p {
  font-size: 2.7vw;
  font-weight: 700;
  line-height: 3vw;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .pageTtl .intTtl p {
    font-size: 5.4rem;
    line-height: 8rem;
  }
}
.pageTtl .intTtl p span {
  font-size: 65%;
  letter-spacing: -0.4rem;
}
@media screen and (max-width: 768px) {
  .pageTtl .intTtl p span {
    font-size: 60%;
    letter-spacing: -0.5rem;
  }
}

section.int01 {
  width: 100%;
  margin-top: 3.4rem;
}
@media screen and (max-width: 768px) {
  section.int01 {
    margin-top: 6.5rem;
    padding-bottom: 8rem;
  }
}
section.int01 .inner {
  width: 126rem;
  margin: auto;
}
@media screen and (max-width: 768px) {
  section.int01 .inner {
    width: 100%;
  }
}
section.int01 .inner .intro {
  width: 100rem;
  margin: auto;
  display: flex;
  justify-content: space-between;
  padding-left: 5.5rem;
  margin-bottom: 5.4rem;
}
@media screen and (max-width: 768px) {
  section.int01 .inner .intro {
    width: 100%;
    padding-left: 1.8rem;
    padding-right: 4.5rem;
  }
}
section.int01 .inner .intro.p003 {
  width: 104.5rem;
  padding-left: 0;
}
section.int01 .inner .intro.p003 figure {
  width: 29.6rem;
}
section.int01 .inner .intro.p003 .txts {
  padding-top: 0;
}
section.int01 .inner .intro figure {
  width: 17.77rem;
}
@media screen and (max-width: 768px) {
  section.int01 .inner .intro figure {
    width: 22.7rem;
  }
}
section.int01 .inner .intro .txts {
  width: 72.8rem;
  padding-top: 8rem;
}
@media screen and (max-width: 768px) {
  section.int01 .inner .intro .txts {
    width: 44.1rem;
    padding-top: 2.6rem;
  }
}
section.int01 .inner .intro .txts p.name {
  font-size: 4.2rem;
  font-weight: 700;
  color: #552e30;
  padding-bottom: 2.4rem;
  margin-bottom: 2.9rem;
  border-bottom: 0.4rem dotted #f9be00;
}
section.int01 .inner .intro .txts p.name span {
  font-size: 2.4rem;
  font-weight: 500;
  display: block;
  margin-top: 1.2rem;
}
@media screen and (max-width: 768px) {
  section.int01 .inner .intro .txts p.name span {
    font-size: 2.6rem;
  }
}
section.int01 .inner .intro .txts p.prof {
  font-size: 2rem;
  font-weight: 500;
  line-height: 3.8rem;
  color: #552e30;
  margin-bottom: 3.9rem;
}
@media screen and (max-width: 768px) {
  section.int01 .inner .intro .txts p.prof {
    font-size: 2.6rem;
    line-height: 4.8rem;
    margin-bottom: auto;
  }
}
section.int01 .inner .intro .txts p.lead {
  font-size: 2rem;
  font-weight: 500;
  line-height: 3.8rem;
  color: #552e30;
  font-feature-settings: "palt";
  letter-spacing: -0.1rem;
}
@media screen and (max-width: 768px) {
  section.int01 .inner .intro .txts p.lead {
    font-size: 2.6rem;
    line-height: 4.8rem;
    text-align: justify;
    letter-spacing: -0.2rem;
  }
}
section.int01 .inner .daigomi {
  width: 100%;
  background: rgba(249, 190, 0, 0.15);
  border-radius: 3rem;
  padding: 5.4rem 6.4rem 5rem;
}
@media screen and (max-width: 768px) {
  section.int01 .inner .daigomi {
    width: 65rem;
    margin: auto;
  }
}
section.int01 .inner .daigomi h2 {
  font-size: 3.6rem;
  font-weight: 700;
  color: #552e30;
  text-align: center;
  margin-bottom: 3rem;
}
@media screen and (max-width: 768px) {
  section.int01 .inner .daigomi h2 {
    font-size: 3.8rem;
  }
}
section.int01 .inner .daigomi p {
  font-size: 2rem;
  font-weight: 500;
  line-height: 3.8rem;
  color: #552e30;
  text-align: justify;
}
@media screen and (max-width: 768px) {
  section.int01 .inner .daigomi p {
    font-size: 2.6rem;
    line-height: 4.8rem;
    letter-spacing: -0.4rem;
  }
}

section.schedule {
  padding-top: 23rem;
  background: url("../images/bg_p01.jpg") no-repeat center top;
  background-size: 1920px;
  padding-bottom: 37rem;
  /*
  	&::before {
  		content:'';
  		width:100%;
  		height:45.2rem;
  		background:url("../images/bg_about_before.jpg") no-repeat center top;
  		background-size:1920px;
  		position:absolute;
  		top:0;
  		left:0;
  		
  		
  		@media screen and (min-width: 1920px) {
  			height:23.5vw;
  			background:url("../images/bg_about_before.jpg") no-repeat center top;
  			background-size:100%;
  		}
  		@media screen and (max-width: 678px) {
  			height:22.4rem;
  			background:url("../images/bg_about_before_sp.jpg") no-repeat center top;
  			background-size:100%;
  		}
  	}
  	
  	&::after {
  		content:'';
  		width:100%;
  		height:40.4rem;
  		background:url("../images/bg_schedule_after.jpg") no-repeat center bottom;
  		background-size:1920px;
  		position:absolute;
  		bottom:-20rem;
  		left:0;
  		z-index: 1;
  		
  		@media screen and (min-width: 1920px) {
  			height:24.9vw;
  			background:url("../images/bg_schedule_after.jpg") no-repeat center top;
  			background-size:100%;
  			height: 20vw;
          	background: url(../images/bg_schedule_after.jpg) no-repeat center bottom;
          	background-size: 100%;
          	bottom: -5vw;
          	z-index: 2;
  		}
  		
  		@media screen and (max-width: 678px) {
  			height:17.5rem;
  			background:url("../images/bg_about_after_sp.jpg") no-repeat center top;
  			background-size:100%;
  			bottom:-17rem;
  
  		}
  	}
  */
}
@media screen and (max-width: 1500px) {
  section.schedule {
    background: url("../images/bg_p01_1500.jpg") no-repeat center top;
    background-size: 100%;
  }
}
@media screen and (max-width: 768px) {
  section.schedule {
    background: url("../images/bg_p01_sp.jpg") no-repeat center top;
    background-size: 100%;
    padding-bottom: 30rem;
  }
}
section.schedule.p03 {
  background: url("../images/bg_p03.jpg") no-repeat center top;
  background-size: 1920px;
}
@media screen and (max-width: 1500px) {
  section.schedule.p03 {
    background: url("../images/bg_p03_1500.jpg") no-repeat center top;
    background-size: 100%;
  }
}
@media screen and (max-width: 768px) {
  section.schedule.p03 {
    background: url("../images/bg_p03_sp.jpg") no-repeat center top;
    background-size: 100%;
  }
}
section.schedule .inner {
  width: 100rem;
  margin: auto;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  section.schedule .inner {
    width: 65rem;
  }
}
section.schedule .inner h2 {
  font-size: 4.2rem;
  font-weight: 700;
  color: #552e30;
  text-align: center;
  margin-bottom: 9.4rem;
}
@media screen and (max-width: 768px) {
  section.schedule .inner h2 {
    margin-bottom: 9.8rem;
  }
}

.oneday {
  width: 100%;
  position: relative;
}
.oneday::before {
  content: '';
  width: 0.3rem;
  height: 98%;
  background: #552e30;
  position: absolute;
  top: 0;
  left: 13rem;
}
@media screen and (max-width: 768px) {
  .oneday::before {
    height: 99%;
    left: 13.4rem;
  }
}
.oneday dl {
  width: 100%;
  display: flex;
  justify-content: space-between;
}
.oneday dl dt {
  width: 13rem;
  display: flex;
  justify-content: flex-end;
  gap: 1.6rem;
}
@media screen and (max-width: 768px) {
  .oneday dl dt {
    width: 14.2rem;
  }
}
.oneday dl dt figure {
  width: 15rem;
  margin-top: -0.1rem;
  margin-right: -2.2rem;
  position: relative;
  z-index: 3;
}
@media screen and (max-width: 768px) {
  .oneday dl dt figure {
    width: 17rem;
  }
}
.oneday dl dt figure.t-init {
  width: 13.1rem;
}
@media screen and (max-width: 768px) {
  .oneday dl dt figure.t-init {
    width: 15rem;
  }
}
.oneday dl dd {
  width: calc(100% - 13rem);
  padding: 0.7rem 0 0 3rem;
  padding-bottom: 6.5rem;
  margin-top: -0.1rem;
}
@media screen and (max-width: 768px) {
  .oneday dl dd {
    padding: 0.7rem 0 0 4.2rem;
    padding-bottom: 4rem;
    width: calc(100% - 14.2rem);
    margin-top: 0.2rem;
  }
}
.oneday dl dd.last {
  padding-bottom: 0;
}
.oneday dl dd h3 {
  font-size: 3.2rem;
  font-weight: 700;
  color: #552e30;
  display: flex;
  align-items: center;
  margin-bottom: 1.1rem;
}
@media screen and (max-width: 768px) {
  .oneday dl dd h3 {
    font-size: 3rem;
    line-height: 4rem;
    margin-bottom: 0.7rem;
  }
}
.oneday dl dd h3 span {
  font-size: 1.6rem;
  margin-left: 1.5rem;
}
@media screen and (max-width: 768px) {
  .oneday dl dd h3 span {
    font-size: 1.6rem;
  }
}
.oneday dl dd p {
  font-size: 2rem;
  font-weight: 500;
  color: #552e30;
}
@media screen and (max-width: 768px) {
  .oneday dl dd p {
    font-size: 2.6rem;
    line-height: 4rem;
    letter-spacing: -0.2rem;
  }
}
.oneday dl dd .fukidashi {
  width: 100%;
  margin-top: 3.4rem;
  background-color: #FFF4DB;
  padding: 2.5rem 3rem;
  border-radius: 3rem;
  display: flex;
  justify-content: space-between;
  position: relative;
}
@media screen and (max-width: 768px) {
  .oneday dl dd .fukidashi {
    flex-direction: column;
    gap: 1.5rem;
    margin-top: 2.4rem;
  }
}
.oneday dl dd .fukidashi::before {
  content: '';
  width: 2.3rem;
  height: 2.7rem;
  background: url("../images/triangle.webp") no-repeat;
  background-size: 100%;
  position: absolute;
  top: -1.5rem;
  left: 5.7rem;
}
@media screen and (max-width: 768px) {
  .oneday dl dd .fukidashi::before {
    top: -2.2rem;
  }
}
.oneday dl dd .fukidashi p {
  width: 37rem;
  font-size: 2rem;
  font-weight: 500;
  line-height: 3.8rem;
  color: #552e30;
}
@media screen and (max-width: 768px) {
  .oneday dl dd .fukidashi p {
    font-size: 2.6rem;
    line-height: 4rem;
    width: 100%;
    letter-spacing: -0.1rem;
  }
}
.oneday dl dd .fukidashi figure {
  width: 37rem;
}
@media screen and (max-width: 768px) {
  .oneday dl dd .fukidashi figure {
    width: 100%;
  }
}

section.holiday {
  width: 100%;
}
section.holiday .inner {
  width: 102rem;
  margin: auto;
}
@media screen and (max-width: 768px) {
  section.holiday .inner {
    width: 100%;
  }
}
section.holiday .inner h2 {
  font-size: 4.2rem;
  font-weight: 700;
  color: #552e30;
  text-align: center;
  margin-bottom: 6.9rem;
}
section.holiday .inner .spend {
  width: 100%;
  display: flex;
  margin: auto auto 16rem;
}
@media screen and (max-width: 768px) {
  section.holiday .inner .spend {
    display: block;
    position: relative;
  }
}
@media screen and (max-width: 768px) {
  section.holiday .inner .spend.dm {
    height: 99.9rem;
  }
}
@media screen and (max-width: 768px) {
  section.holiday .inner .spend.hq {
    height: 119.1rem;
  }
}
@media screen and (max-width: 768px) {
  section.holiday .inner .spend.smit {
    height: 92.8rem;
  }
}
section.holiday .inner .spend figure {
  width: 53.2rem;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  section.holiday .inner .spend figure.dm, section.holiday .inner .spend figure.hq, section.holiday .inner .spend figure.smit {
    width: 56.8rem;
    position: absolute;
    top: 0;
    left: -4.4rem;
  }
}
section.holiday .inner .spend p {
  width: 53.2rem;
  height: 57.8rem;
  margin-left: -4.2rem;
  background: url("../images/bg_holiday.jpg") no-repeat;
  background-size: 100%;
  font-size: 2rem;
  font-weight: 500;
  line-height: 3.8rem;
  color: #552e30;
  padding: 0 9rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  section.holiday .inner .spend p {
    font-size: 2.6rem;
    line-height: 5rem;
    letter-spacing: -0.2rem;
  }
}
@media screen and (max-width: 768px) {
  section.holiday .inner .spend p.dm {
    width: 53.2rem;
    position: absolute;
    top: 42rem;
    right: -2.8rem;
    background: url("../images/bg_holiday_dm_sp.jpg") no-repeat;
    background-size: 100%;
    display: block;
    padding: 17rem 8rem 0 10.6rem;
  }
}
@media screen and (max-width: 768px) {
  section.holiday .inner .spend p.hq {
    width: 67.7rem;
    height: 73.4rem;
    position: absolute;
    top: 46rem;
    right: -6rem;
    background: url("../images/bg_holiday_hq_sp.jpg") no-repeat;
    background-size: 100%;
    display: block;
    padding: 17rem 10rem 0 13rem;
  }
}
@media screen and (max-width: 768px) {
  section.holiday .inner .spend p.smit {
    width: 53.2rem;
    height: 57.7rem;
    position: absolute;
    top: 35rem;
    right: -2.8rem;
    background: url("../images/bg_holiday_smit_sp.jpg") no-repeat;
    background-size: 100%;
    display: block;
    padding: 17rem 10rem 0 13rem;
  }
}

section.message {
  width: 100%;
  padding-bottom: 16.6rem;
}
@media screen and (max-width: 768px) {
  section.message {
    padding-bottom: 11rem;
  }
}
section.message .inner {
  width: 100rem;
  margin: auto;
}
@media screen and (max-width: 768px) {
  section.message .inner {
    width: 65rem;
  }
}
section.message .inner h2 {
  width: 100%;
  margin-bottom: 3.6rem;
}
section.message .inner h3 {
  font-size: 4.2rem;
  font-weight: 700;
  line-height: 5.9rem;
  color: #552e30;
  text-align: center;
  margin-bottom: 3.4rem;
}
section.message .inner p.lead {
  width: 100%;
  font-size: 2.6rem;
  font-weight: 500;
  line-height: 5rem;
  color: #552e30;
  text-align: justify;
  margin-bottom: 12.8rem;
}
@media screen and (max-width: 768px) {
  section.message .inner p.lead {
    margin-bottom: 9.8rem;
  }
}
section.message .inner p.btn-what {
  width: 80rem;
  height: 10rem;
  margin: auto;
}
@media screen and (max-width: 768px) {
  section.message .inner p.btn-what {
    width: 65rem;
    height: 12.8rem;
  }
}
section.message .inner p.btn-what a {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 2.48rem;
  font-weight: 900;
  color: #552e30;
  background: url(../images/bg_what.webp) no-repeat center right 3rem #f9be00;
  background-size: 4rem;
}
@media screen and (max-width: 768px) {
  section.message .inner p.btn-what a {
    font-size: 3.2rem;
    background: url(../images/bg_what.webp) no-repeat center right 4.4rem #f9be00;
    background-size: 5rem;
  }
}

section.another {
  width: 100%;
  background: #f9be00;
  padding: 7.8rem 0 9.8rem;
}
@media screen and (max-width: 768px) {
  section.another {
    padding: 12rem 0 17.8rem;
  }
}
section.another .inner {
  width: 103rem;
  margin: auto;
}
@media screen and (max-width: 768px) {
  section.another .inner {
    width: 65.8rem;
  }
}
section.another .inner h2 {
  width: 68rem;
  margin: auto;
  margin-bottom: 5.6rem;
}
@media screen and (max-width: 768px) {
  section.another .inner h2 {
    width: 65.8rem;
  }
}
section.another .inner ul {
  width: 100%;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  section.another .inner ul {
    flex-direction: column;
    gap: 2.8rem;
  }
}
section.another .inner ul li {
  width: 50rem;
}
@media screen and (max-width: 768px) {
  section.another .inner ul li {
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  section.int01 .inner .intro.p003 {
    width: 65rem;
    margin: auto auto 11rem;
    display: block;
    padding-right: 0;
  }
}
@media screen and (max-width: 768px) {
  section.int01 .inner .intro.p003 figure {
    display: flex;
    justify-content: space-between;
    width: 100%;
    padding: 0 0 0 1.2rem;
    padding-bottom: 3.5rem;
    margin-bottom: 2.9rem;
    border-bottom: 0.4rem dotted #f9be00;
  }
}
@media screen and (max-width: 768px) {
  section.int01 .inner .intro.p003 figure img {
    width: 22.9rem;
  }
}
@media screen and (max-width: 768px) {
  section.int01 .inner .intro.p003 figure figcaption {
    width: 38rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 1.3rem;
    font-size: 4.2rem;
    font-weight: 700;
    color: #552e30;
  }
}
@media screen and (max-width: 768px) {
  section.int01 .inner .intro.p003 figure figcaption span {
    font-size: 2.6rem;
    display: block;
  }
}
@media screen and (max-width: 768px) {
  section.int01 .inner .intro.p003 .txts {
    width: 100%;
  }
}

section.youkou {
  width: 100%;
  padding-top: 11rem;
  padding-bottom: 13rem;
}
@media screen and (max-width: 768px) {
  section.youkou {
    padding-top: 14rem;
    padding-bottom: 0;
  }
}
section.youkou .inner {
  width: 146rem;
  margin: auto;
}
@media screen and (max-width: 768px) {
  section.youkou .inner {
    width: 65rem;
  }
}
section.youkou .inner h2 {
  font-size: 5.2rem;
  font-weight: 700;
  color: #552e30;
  text-align: center;
  margin-bottom: 7rem;
}
@media screen and (max-width: 768px) {
  section.youkou .inner h2 {
    margin-bottom: 8rem;
  }
}
section.youkou .inner .tableBoxBox {
  width: 100%;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  section.youkou .inner .tableBoxBox {
    flex-direction: column;
  }
}
section.youkou .inner .tableBoxBox .tableBox {
  width: 69rem;
  border-top: 0.16rem solid #f9be00;
}
@media screen and (max-width: 768px) {
  section.youkou .inner .tableBoxBox .tableBox {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  section.youkou .inner .tableBoxBox .tableBox + .tableBox {
    border-top: none;
  }
}
section.youkou .inner .tableBoxBox .tableBox dl {
  width: 100%;
  line-height: 2.6rem;
  background: rgba(249, 190, 0, 0.15);
  border-bottom: 0.16rem solid #f9be00;
  display: flex;
  justify-content: space-between;
}
section.youkou .inner .tableBoxBox .tableBox dl dt {
  width: 17.9rem;
  font-size: 1.8rem;
  font-weight: 700;
  color: #552e30;
  padding: 3.2rem 1.9rem;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}
@media screen and (max-width: 768px) {
  section.youkou .inner .tableBoxBox .tableBox dl dt {
    font-size: 2.6rem;
    width: 22.4rem;
  }
}
section.youkou .inner .tableBoxBox .tableBox dl dt span {
  font-size: 1.4rem;
  display: block;
}
@media screen and (max-width: 768px) {
  section.youkou .inner .tableBoxBox .tableBox dl dt span {
    font-size: 2rem;
    margin-top: 0.5rem;
  }
}
section.youkou .inner .tableBoxBox .tableBox dl dd {
  width: calc(100% - 17.9rem);
  font-size: 1.8rem;
  font-weight: 500;
  color: #552e30;
  background: #fff;
  padding: 3.2rem 1.9rem;
}
@media screen and (max-width: 768px) {
  section.youkou .inner .tableBoxBox .tableBox dl dd {
    width: calc(100% - 22.4rem);
    font-size: 2.6rem;
    line-height: 3.6rem;
  }
}

section.faq {
  width: 100%;
  padding-top: 11rem;
  padding-bottom: 18rem;
}
@media screen and (max-width: 768px) {
  section.faq {
    padding-top: 13rem;
    padding-bottom: 11.6rem;
  }
}
section.faq .inner {
  width: 146rem;
  margin: auto;
}
@media screen and (max-width: 768px) {
  section.faq .inner {
    width: 65rem;
  }
}
section.faq .inner h2 {
  font-size: 5.2rem;
  font-weight: 700;
  color: #552e30;
  text-align: center;
  margin-bottom: 7rem;
}
@media screen and (max-width: 768px) {
  section.faq .inner h2 {
    margin-bottom: 8rem;
  }
}
section.faq .inner .faqBoxBox {
  width: 100%;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  section.faq .inner .faqBoxBox {
    flex-direction: column;
  }
}
section.faq .inner .faqBoxBox .faqBox {
  width: 69rem;
  border-top: 0.16rem solid #f9be00;
}
@media screen and (max-width: 768px) {
  section.faq .inner .faqBoxBox .faqBox {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  section.faq .inner .faqBoxBox .faqBox + .faqBox {
    border-top: none;
  }
}
section.faq .inner .faqBoxBox .faqBox dl {
  width: 100%;
  line-height: 2.6rem;
  background: rgba(249, 190, 0, 0.15);
  border-bottom: 0.16rem solid #f9be00;
  display: flex;
  justify-content: space-between;
  flex-direction: column;
}
@media screen and (max-width: 768px) {
  section.faq .inner .faqBoxBox .faqBox dl {
    line-height: 3.6rem;
  }
}
section.faq .inner .faqBoxBox .faqBox dl dt {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 700;
  color: #552e30;
  padding: 3.2rem 1.9rem 3.2rem 6.7rem;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-direction: column;
  background: url("../images/bg_q.webp") no-repeat top 2.7rem left 1.2rem;
  background-size: 3.82rem;
  position: relative;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  section.faq .inner .faqBoxBox .faqBox dl dt {
    font-size: 2.6rem;
    background: url("../images/bg_q.webp") no-repeat center left 1.6rem;
    background-size: 4.77rem;
    padding: 0 6rem 0 8.5rem;
    height: 12.8rem;
  }
}
section.faq .inner .faqBoxBox .faqBox dl dt::after {
  content: '';
  width: 1.6rem;
  height: 1.6rem;
  background: url("../images/ico_plus.webp") no-repeat center center;
  background-size: 100%;
  position: absolute;
  top: 3.7rem;
  right: 2.8rem;
}
@media screen and (max-width: 768px) {
  section.faq .inner .faqBoxBox .faqBox dl dt::after {
    width: 2rem;
    height: 2rem;
    top: 50%;
    right: 3rem;
    transform: translateY(-50%);
  }
}
section.faq .inner .faqBoxBox .faqBox dl dt.open::after {
  background: url("../images/ico_minus.webp") no-repeat center center;
  background-size: 100%;
}
section.faq .inner .faqBoxBox .faqBox dl dt span {
  font-size: 1.4rem;
  display: block;
}
section.faq .inner .faqBoxBox .faqBox dl dd {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 500;
  color: #552e30;
  padding: 3.2rem 1.9rem 3.2rem 6.7rem;
  background: url("../images/bg_a.webp") no-repeat top 2.7rem left 1.5rem #fff;
  background-size: 3.428rem;
  display: none;
  height: 0;
  transition: all 0.4s ease;
}
@media screen and (max-width: 768px) {
  section.faq .inner .faqBoxBox .faqBox dl dd {
    font-size: 2.6rem;
    background: url("../images/bg_a.webp") no-repeat top 2.7rem left 1.8rem #fff;
    background-size: 4.28rem;
    padding: 3rem 6rem 4rem 8.5rem;
  }
}
section.faq .inner .faqBoxBox .faqBox dl dd.open {
  display: block;
  height: auto;
}
section.faq .inner .faqBoxBox .faqBox dl dd a {
  color: #f9aa00;
  text-decoration: underline;
}

.pageIntro {
  width: 146rem;
  margin: auto;
  padding: 15.8rem 0 0;
  border-bottom: 0.6rem solid #ffdb42;
}
@media screen and (max-width: 768px) {
  .pageIntro {
    width: 65rem;
    padding: 8rem 0 0;
  }
}
.pageIntro p.catch {
  font-size: 5.2rem;
  font-weight: 700;
  color: #552e30;
  text-align: center;
  margin-bottom: 5rem;
}
@media screen and (max-width: 768px) {
  .pageIntro p.catch {
    font-size: 5.4rem;
    line-height: 7.2rem;
  }
}
.pageIntro p.lead {
  font-size: 2.8rem;
  font-weight: 500;
  color: #552e30;
  margin-bottom: 9rem;
  letter-spacing: -0.2rem;
}
@media screen and (max-width: 768px) {
  .pageIntro p.lead {
    line-height: 4.6rem;
    letter-spacing: -0.4rem;
  }
}

.pageMoreIntro {
  width: 146rem;
  margin: auto;
  padding: 9.8rem 0 7rem;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .pageMoreIntro {
    width: 65rem;
    flex-direction: column;
    row-gap: 6.4rem;
  }
}
.pageMoreIntro .txts {
  width: 84.56rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .pageMoreIntro .txts {
    width: 100%;
  }
}
.pageMoreIntro .txts h2 {
  font-size: 5.2rem;
  font-weight: 700;
  color: #552e30;
  margin-bottom: 4rem;
}
@media screen and (max-width: 768px) {
  .pageMoreIntro .txts h2 {
    font-size: 5.4rem;
    text-align: center;
  }
}
.pageMoreIntro .txts p.lead {
  font-size: 2.8rem;
  font-weight: 500;
  line-height: 4.6rem;
  color: #552e30;
  text-align: justify;
  letter-spacing: -0.2rem;
}
.pageMoreIntro figure {
  width: 52rem;
}
@media screen and (max-width: 768px) {
  .pageMoreIntro figure {
    width: 100%;
  }
}

ul.introCard {
  width: 100%;
  display: flex;
  justify-content: center;
  gap: 3.1rem;
  margin-bottom: 16.7rem;
}
@media screen and (max-width: 768px) {
  ul.introCard {
    flex-wrap: wrap;
    gap: 2rem;
    margin-top: 6rem;
    margin-bottom: 13rem;
  }
}
ul.introCard li {
  width: 26.4rem;
  height: 39.6rem;
  padding-top: 3.7rem;
  text-align: center;
}
@media screen and (max-width: 768px) {
  ul.introCard li {
    width: 20.1rem;
    height: 30.21rem;
    padding-top: 2.4rem;
  }
}
ul.introCard li:nth-of-type(1) {
  background: url("../images/bg_intro01.webp") no-repeat;
  background-size: 100%;
}
@media screen and (max-width: 768px) {
  ul.introCard li:nth-of-type(1) {
    background: url("../images/bg_intro01_sp.webp") no-repeat;
    background-size: 100%;
  }
}
ul.introCard li:nth-of-type(2) {
  background: url("../images/bg_intro02.webp") no-repeat;
  background-size: 100%;
}
@media screen and (max-width: 768px) {
  ul.introCard li:nth-of-type(2) {
    background: url("../images/bg_intro02_sp.webp") no-repeat;
    background-size: 100%;
  }
}
ul.introCard li:nth-of-type(3) {
  background: url("../images/bg_intro03.webp") no-repeat;
  background-size: 100%;
}
@media screen and (max-width: 768px) {
  ul.introCard li:nth-of-type(3) {
    background: url("../images/bg_intro03_sp.webp") no-repeat;
    background-size: 100%;
  }
}
ul.introCard li h4 {
  font-size: 2.916rem;
  font-weight: 700;
  line-height: 3.79rem;
  height: 6.5rem;
  margin-bottom: 13.5rem;
}
@media screen and (max-width: 768px) {
  ul.introCard li h4 {
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 3.1rem;
    height: 5.4rem;
    margin-bottom: 9.5rem;
  }
}
ul.introCard li figure {
  width: 19.9528rem;
  margin: auto auto 0.75rem;
}
@media screen and (max-width: 768px) {
  ul.introCard li figure {
    width: 16.8rem;
  }
}
ul.introCard li p {
  font-size: 3.25rem;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  ul.introCard li p {
    font-size: 2.4rem;
  }
}
ul.introCard li p span {
  font-size: 1.434rem;
  display: block;
  margin-top: 0.75rem;
  letter-spacing: -0.1rem;
}
@media screen and (max-width: 768px) {
  ul.introCard li p span {
    font-size: 1.3rem;
  }
}

section.systems {
  width: 146rem;
  margin: auto;
  padding-top: 10.8rem;
  padding-bottom: 16rem;
}
@media screen and (max-width: 768px) {
  section.systems {
    width: 65rem;
    padding-top: 7.4em;
    padding-bottom: 12rem;
  }
}
section.systems h2 {
  font-size: 4.2rem;
  font-weight: 700;
  color: #552e30;
  margin-bottom: 10.8rem;
  text-align: center;
}
@media screen and (max-width: 768px) {
  section.systems h2 {
    margin-bottom: 7.4rem;
  }
}
section.systems .system {
  width: 100%;
  padding-bottom: 11.2rem;
  border-bottom: 0.4rem dotted #f9be00;
}
section.systems .system + .system {
  margin-top: 10rem;
}
section.systems .system:last-of-type {
  border-bottom: none;
  padding-bottom: 0;
}
section.systems .system ul {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 3.9rem;
  row-gap: 5.7rem;
}
@media screen and (max-width: 768px) {
  section.systems .system ul {
    gap: 3.8rem;
    row-gap: 6.4rem;
  }
}
section.systems .system ul li {
  width: 33.2rem;
}
@media screen and (max-width: 768px) {
  section.systems .system ul li {
    width: 30.6rem;
  }
}
section.systems .system ul li h3 {
  width: 100%;
  height: 11.2rem;
  font-size: 2.8rem;
  font-weight: 900;
  line-height: 3.8rem;
  color: #552e30;
  border-radius: 3rem;
  background: #f9be00;
  margin-bottom: 1.8rem;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}
section.systems .system ul li p {
  font-size: 2rem;
  font-weight: 500;
  line-height: 3.8rem;
  color: #552e30;
  overflow-wrap: break-word;
}
@media screen and (max-width: 768px) {
  section.systems .system ul li p {
    font-size: 2.6rem;
    line-height: 3.6rem;
    letter-spacing: -0.2rem;
  }
}

section.history {
  width: 100%;
  background: url("../images/bg_history.png") no-repeat center top;
  background-size: 1920px;
  padding-bottom: 15.9rem;
}
@media screen and (max-width: 1500px) {
  section.history {
    background: url("../images/bg_history1500.png") no-repeat center top;
    background-size: 100%;
  }
}
@media screen and (max-width: 768px) {
  section.history {
    background: url("../images/bg_history_sp.webp") no-repeat center top;
    background-size: 100%;
  }
}
section.history .inner {
  width: 100rem;
  margin: auto;
  padding-top: 16rem;
  padding-bottom: 9.4rem;
}
@media screen and (max-width: 768px) {
  section.history .inner {
    width: 65rem;
    padding-top: 28rem;
  }
}
section.history .inner .dlBox {
  width: 100%;
  position: relative;
}
section.history .inner .dlBox::before {
  content: '';
  width: 0.3rem;
  height: calc(100% - 1rem);
  background: #552e30;
  position: absolute;
  top: 1.2rem;
  left: 15.7rem;
  transform: translateX(-50%);
}
@media screen and (max-width: 768px) {
  section.history .inner .dlBox::before {
    left: 13.6rem;
    height: calc(100% + 2.8rem);
  }
}
section.history .inner .dlBox::after {
  content: '';
  width: 2.748rem;
  height: 2.1528rem;
  background: url("../images//arrow_history.webp") no-repeat bottom center;
  background-size: 100%;
  position: absolute;
  bottom: -0.5rem;
  left: 15.7rem;
  transform: translateX(-50%);
}
@media screen and (max-width: 768px) {
  section.history .inner .dlBox::after {
    left: 13.65rem;
    bottom: -5rem;
    width: 3.29rem;
    height: 2.58rem;
  }
}
section.history .inner dl {
  width: 100%;
  display: flex;
  justify-content: space-between;
}
section.history .inner dl:last-of-type dt::after {
  display: none;
}
section.history .inner dl:last-of-type dd {
  padding-bottom: 6rem;
}
section.history .inner dl dt {
  width: 15.7rem;
  padding-top: 1rem;
  padding-left: 3.7rem;
  position: relative;
}
@media screen and (max-width: 768px) {
  section.history .inner dl dt {
    width: 13.6rem;
    padding-left: 0;
  }
}
section.history .inner dl dt::after {
  content: '';
  width: 2rem;
  height: 1.9529rem;
  background: #552e30;
  border-radius: 50%;
  position: absolute;
  top: 1.1rem;
  right: -1rem;
}
@media screen and (max-width: 768px) {
  section.history .inner dl dt::after {
    width: 2.4rem;
    height: 2.343rem;
    right: -1.2rem;
  }
}
section.history .inner dl dt figure {
  width: 8.239rem;
}
@media screen and (max-width: 768px) {
  section.history .inner dl dt figure {
    width: 9.657rem;
  }
}
section.history .inner dl dt figure.tw {
  width: 8.048rem;
}
@media screen and (max-width: 768px) {
  section.history .inner dl dt figure.tw {
    width: 9.88rem;
  }
}
section.history .inner dl dd {
  width: calc(100% - 15.7rem);
  font-size: 2.4rem;
  padding-left: 3.8rem;
  padding-bottom: 0.4rem;
}
@media screen and (max-width: 768px) {
  section.history .inner dl dd {
    font-size: 2.8rem;
    padding-left: 2rem;
    padding-bottom: 1rem;
  }
}
section.history .inner dl dd p {
  font-weight: 500;
  line-height: 4.2rem;
  color: #552e30;
  letter-spacing: -0.2rem;
  margin-bottom: 2.5rem;
  font-feature-settings: "palt";
}
@media screen and (max-width: 768px) {
  section.history .inner dl dd p {
    line-height: 4.4rem;
  }
}
section.history .inner dl dd p span {
  color: #ff7026;
}
section.history .inner dl dd p.large {
  font-size: 4.2rem;
  font-weight: 700;
  margin: 7.8rem 0 3rem;
}
@media screen and (max-width: 768px) {
  section.history .inner dl dd p.large {
    line-height: 5.9rem;
  }
}

section.map {
  width: 146rem;
  min-height: 205rem;
  margin: auto;
  border-top: 0.6rem solid #ffdb42;
  padding-top: 12.6rem;
  padding-bottom: 77rem;
  background: url("../images/bg_map.webp") no-repeat top 38rem left 3.5rem;
  background-size: 132.9rem;
}
@media screen and (max-width: 768px) {
  section.map {
    width: 100%;
    padding-top: 0;
    background: url("../images/bg_map_sp.webp") no-repeat top 45rem left 3.6rem;
    background-size: 67.7rem;
    border-top: none;
    padding-bottom: 50rem;
    min-height: 0;
  }
}
@media screen and (max-width: 768px) {
  section.map .inner {
    width: 65rem;
    margin: auto;
    border-top: 0.6rem solid #ffdb42;
    padding-top: 8.5rem;
  }
}
section.map h2 {
  font-size: 5.2rem;
  font-weight: 700;
  color: #552e30;
  text-align: center;
  margin-bottom: 3.9rem;
}
@media screen and (max-width: 768px) {
  section.map h2 {
    font-size: 5.4rem;
    line-height: 7.2rem;
  }
}
section.map p.lead {
  font-size: 2.8rem;
  font-weight: 500;
  line-height: 4.6rem;
  color: #552e30;
  margin: auto;
}
@media screen and (max-width: 768px) {
  section.map p.lead {
    letter-spacing: -0.3rem;
  }
}
section.map .shopListBoxBox {
  width: 59rem;
  margin: 12rem 0 0 10.4rem;
  padding: 3rem 0 0 2rem;
  background: url(../images/bg_h3_map.webp) no-repeat top 2.6rem left 0.5rem;
  background-size: 7.82rem;
}
section.map .shopListBoxBox h3 {
  font-size: 2.8rem;
  font-weight: 900;
  color: #552e30;
  padding-bottom: 0.6rem;
  border-bottom: 0.2rem solid #552e30;
  margin-bottom: 2.8rem;
}
section.map .shopListBoxBox h3 span {
  font-size: 5.37rem;
  font-weight: 700;
  margin-left: 1.7rem;
}
section.map .shopListBoxBox h3 span.license {
  font-size: 2.1rem;
  letter-spacing: -0.1rem;
  float: right;
  line-height: 1.2;
  margin-top: 0.5rem;
}
@media screen and (max-width: 768px) {
  section.map .shopListBoxBox h3 span.license {
    font-size: 2.685rem;
  }
}

.shopListBox {
  width: 100%;
  display: flex;
  justify-content: space-between;
}
.shopListBox .shopList {
  width: 16.4rem;
  display: flex;
  flex-direction: column;
  gap: 2.1rem;
}
.shopListBox dl {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 2.117rem;
}
.shopListBox dl dt {
  width: 8.8rem;
  font-size: 2.1rem;
  font-weight: 500;
  color: #552e30;
}
.shopListBox dl dd {
  width: 7.8rem;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  font-size: 3rem;
  font-weight: 700;
  color: #552e30;
}
.shopListBox dl dd span {
  font-size: 2.1rem;
  font-weight: 500;
  margin-left: 0.4rem;
}

@media screen and (max-width: 768px) {
  .btnBox {
    width: 30.56rem;
    height: 33.13rem;
    background: url("../images/bg_btnbox.webp") no-repeat;
    background-size: 100%;
    margin: 12rem 0 0 3.6rem;
    padding: 7rem 6.2rem 0 6.6rem;
  }
}
@media screen and (max-width: 768px) {
  .btnBox h3 {
    font-size: 2.685rem;
    font-weight: 900;
    line-height: 3.86rem;
    color: #552e30;
    letter-spacing: -0.2rem;
    margin-bottom: 0.6rem;
  }
}
@media screen and (max-width: 768px) {
  .btnBox p.tenpo {
    font-size: 6.75rem;
    font-weight: 700;
    color: #552e30;
    margin-bottom: 1rem;
  }
}
@media screen and (max-width: 768px) {
  .btnBox p.tenpo span {
    font-size: 3.53rem;
    font-weight: 900;
  }
}
@media screen and (max-width: 768px) {
  .btnBox p.license {
    font-size: 2.685rem;
    letter-spacing: -0.2rem;
    margin-left: -4rem;
    white-space: nowrap;
    margin-bottom: 1rem;
  }
}
@media screen and (max-width: 768px) {
  .btnBox p.toModal {
    font-size: 2.2rem;
    font-weight: 700;
    color: #552e30;
    background: url("../images/ico_circle_plus.webp") no-repeat center right;
    background-size: 4rem;
    width: 15.5rem;
    height: 4rem;
    display: flex;
    align-items: center;
    letter-spacing: -0.2rem;
  }
}

.modal_shop {
  display: none;
  position: fixed;
  z-index: 9999;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(249, 190, 0, 0.5);
}

.modal-content_shop {
  background: #fff;
  margin: 4vh auto;
  padding: 11.4rem 4rem 6rem 5.4rem;
  width: 65rem;
  border-radius: 8rem;
  position: relative;
  height: 92vh;
}

.close_shop {
  position: absolute;
  right: 5.4rem;
  top: 5.4rem;
  cursor: pointer;
  font-size: 24px;
}

.shopListBoxSP {
  display: flex;
  justify-content: space-between;
  height: calc(90vh - 17.4rem);
  overflow-y: scroll;
}
.shopListBoxSP .shopListSP {
  width: 23rem;
  display: flex;
  flex-direction: column;
  gap: 2.2rem;
}
.shopListBoxSP .shopListSP dl {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #552e30;
}
.shopListBoxSP .shopListSP dl dt {
  width: 12.4rem;
  font-size: 2.8rem;
  font-weight: 500;
}
.shopListBoxSP .shopListSP dl dd {
  width: calc(100% - 12.4rem);
  font-size: 4rem;
  font-weight: 700;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
.shopListBoxSP .shopListSP dl dd span {
  font-size: 2.8rem;
  font-weight: 500;
  margin-left: 0.6rem;
}

.simplebar-content {
  display: flex;
  justify-content: space-between;
}
.simplebar-content::before {
  display: none;
}

section.csr01 {
  width: 100%;
  padding-bottom: 19.8rem;
  margin-top: -5rem;
  padding-top: 5rem;
}
section.csr01 .inner {
  width: 146rem;
  margin: auto;
}
@media screen and (max-width: 768px) {
  section.csr01 .inner {
    width: 100%;
  }
}
section.csr01 .inner h2 {
  width: 100%;
  padding: 7.5rem 0;
  font-size: 5.2rem;
  font-weight: 700;
  color: #552e30;
  text-align: center;
  border-top: 0.6rem solid #ffdb42;
  border-bottom: 0.6rem solid #ffdb42;
  position: relative;
  margin-bottom: 6rem;
}
@media screen and (max-width: 768px) {
  section.csr01 .inner h2 {
    font-size: 5.4rem;
    letter-spacing: -0.2rem;
    padding: 8rem 0;
  }
}
section.csr01 .inner h2::before {
  content: '';
  width: 8.3189rem;
  height: 9.02rem;
  background: url("../images/bg_h2_csr01.webp") no-repeat;
  background-size: 100%;
  position: absolute;
  top: -4.8rem;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 768px) {
  section.csr01 .inner h2::before {
    width: 6.4rem;
    height: 7rem;
    top: -4rem;
  }
}
section.csr01 .inner p.lead {
  font-size: 2.8rem;
  font-weight: 500;
  line-height: 4.6rem;
  color: #552e30;
  letter-spacing: -0.2rem;
  margin-bottom: 9.5rem;
}
@media screen and (max-width: 768px) {
  section.csr01 .inner p.lead {
    width: 65rem;
    margin: auto auto 6rem;
  }
}
section.csr01 .inner ul {
  width: 120rem;
  margin: auto auto 9rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  row-gap: 5.8rem;
}
@media screen and (max-width: 768px) {
  section.csr01 .inner ul {
    width: 55rem;
    flex-direction: column;
  }
}
section.csr01 .inner ul li {
  width: 56.2rem;
}
section.csr01 .inner ul li h3 {
  font-size: 3.2rem;
  font-weight: 900;
  color: #552e30;
  margin-bottom: 2.4rem;
  padding-bottom: 2.4rem;
  border-bottom: 0.4rem dotted #f9be00;
  text-align: center;
}
@media screen and (max-width: 768px) {
  section.csr01 .inner ul li h3 {
    padding-bottom: 2.8rem;
  }
}
section.csr01 .inner ul li figure {
  width: 100%;
  margin-bottom: 2.4rem;
}
@media screen and (max-width: 768px) {
  section.csr01 .inner ul li figure {
    margin-bottom: 2.8rem;
  }
}
section.csr01 .inner ul li p {
  font-size: 2rem;
  font-weight: 500;
  line-height: 3.8rem;
  color: #552e30;
  text-align: justify;
  letter-spacing: -0.2rem;
}
@media screen and (max-width: 768px) {
  section.csr01 .inner ul li p {
    font-size: 2.6rem;
    line-height: 4rem;
  }
}
section.csr01 .inner .comment {
  width: 100%;
  border-radius: 3rem;
  background: rgba(249, 190, 0, 0.15);
  padding: 5rem 7rem;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  section.csr01 .inner .comment {
    width: 65rem;
    margin: auto;
    padding: 5.6rem 5rem;
  }
}
section.csr01 .inner .comment p {
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 4.6rem;
  color: #552e30;
  letter-spacing: -0.2rem;
}

section.csr02 {
  width: 100%;
  padding-bottom: 19.8rem;
  margin-top: -5rem;
  padding-top: 5rem;
}
section.csr02 .inner {
  width: 146rem;
  margin: auto;
}
@media screen and (max-width: 768px) {
  section.csr02 .inner {
    width: 100%;
  }
}
section.csr02 .inner h2 {
  width: 100%;
  padding: 7.5rem 0;
  font-size: 5.2rem;
  font-weight: 700;
  color: #552e30;
  text-align: center;
  border-top: 0.6rem solid #ffdb42;
  border-bottom: 0.6rem solid #ffdb42;
  position: relative;
  margin-bottom: 6rem;
}
@media screen and (max-width: 768px) {
  section.csr02 .inner h2 {
    font-size: 5.4rem;
    letter-spacing: -0.2rem;
    padding: 8rem 0;
  }
}
section.csr02 .inner h2::before {
  content: '';
  width: 8.3189rem;
  height: 9.02rem;
  background: url("../images/bg_h2_csr02.webp") no-repeat;
  background-size: 100%;
  position: absolute;
  top: -4.8rem;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 768px) {
  section.csr02 .inner h2::before {
    width: 6.4rem;
    height: 7rem;
    top: -4rem;
  }
}
section.csr02 .inner p.lead {
  font-size: 2.8rem;
  font-weight: 500;
  line-height: 4.6rem;
  color: #552e30;
  letter-spacing: -0.2rem;
  margin-bottom: 6rem;
}
@media screen and (max-width: 768px) {
  section.csr02 .inner p.lead {
    width: 65rem;
    margin: auto auto 6rem;
  }
}
section.csr02 .inner .comment.widthH3 {
  width: 100%;
  border-radius: 3rem;
  background: rgba(249, 190, 0, 0.15);
  padding: 4.5rem 7rem;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  section.csr02 .inner .comment.widthH3 {
    width: 65rem;
    margin: auto;
    flex-direction: column;
    gap: 2.5rem;
    padding: 5.6rem 5rem;
  }
}
section.csr02 .inner .comment.widthH3 h3 {
  width: 30.2rem;
  font-size: 2.8rem;
  font-weight: 900;
  line-height: 3.8rem;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 768px) {
  section.csr02 .inner .comment.widthH3 h3 {
    width: 100%;
    font-size: 3.2rem;
  }
}
section.csr02 .inner .comment.widthH3 p {
  width: calc(100% - 30.2rem);
  font-size: 2rem;
  font-weight: 500;
  line-height: 3.8rem;
  color: #552e30;
  letter-spacing: -0.2rem;
}
@media screen and (max-width: 768px) {
  section.csr02 .inner .comment.widthH3 p {
    width: 100%;
    font-size: 2.6rem;
    line-height: 4rem;
  }
}

.teikyou {
  width: 120rem;
  margin: 4rem auto auto;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .teikyou {
    width: 55rem;
    flex-direction: column;
    gap: 3.2rem;
  }
}
.teikyou figure {
  width: 57.4rem;
}
@media screen and (max-width: 768px) {
  .teikyou figure {
    width: 53.6rem;
  }
}
.teikyou figure.teikyou02 {
  width: 49.2rem;
  margin-top: 20rem;
}
@media screen and (max-width: 768px) {
  .teikyou figure.teikyou02 {
    width: 55em;
    margin-top: 3rem;
  }
}
.teikyou .txts {
  width: 58.8rem;
  padding-top: 9.4rem;
}
@media screen and (max-width: 768px) {
  .teikyou .txts {
    width: 100%;
  }
}
.teikyou .txts h3 {
  font-size: 3.2rem;
  font-weight: 900;
  border-bottom: 0.24rem solid #552e30;
  padding-bottom: 0.6rem;
  position: relative;
  letter-spacing: -0.2rem;
  margin-bottom: 4.95rem;
}
@media screen and (max-width: 768px) {
  .teikyou .txts h3 {
    letter-spacing: -0.1rem;
    margin-bottom: 4rem;
  }
}
@media screen and (max-width: 768px) {
  .teikyou .txts h3.tsume {
    letter-spacing: -0.4rem;
  }
}
.teikyou .txts h3::after {
  content: '';
  width: 8.92rem;
  height: 9.7rem;
  background: url("../images/bg_h3.webp") no-repeat;
  background-size: cover;
  position: absolute;
  top: -3rem;
  left: -1.6rem;
  z-index: -1;
}
.teikyou .txts p {
  font-size: 2rem;
  font-weight: 500;
  line-height: 3.8rem;
  letter-spacing: -0.2rem;
}
@media screen and (max-width: 768px) {
  .teikyou .txts p {
    font-size: 2.6rem;
    line-height: 4rem;
    letter-spacing: -0.4rem;
  }
}
.teikyou .txts p.teikyou02 {
  width: 65.6rem;
}
@media screen and (max-width: 768px) {
  .teikyou .txts p.teikyou02 {
    width: 100%;
  }
}
.teikyou .txts p.attention {
  font-size: 1.6rem;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .teikyou .txts p.attention {
    font-size: 2rem;
  }
}
.teikyou .txts ul {
  list-style-type: none;
  display: flex;
  flex-direction: column;
  gap: 1.35rem;
  margin-top: 3rem;
}
@media screen and (max-width: 768px) {
  .teikyou .txts ul {
    gap: 1.7rem;
  }
}
.teikyou .txts ul li {
  font-size: 2.4rem;
  font-weight: 700;
  position: relative;
  padding-left: 3.47rem;
}
@media screen and (max-width: 768px) {
  .teikyou .txts ul li {
    font-size: 2.6rem;
  }
}
.teikyou .txts ul li::before {
  content: '';
  width: 2.1rem;
  height: 2.1rem;
  border-radius: 50%;
  background: #f9be00;
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (max-width: 768px) {
  .teikyou .txts ul li::before {
    width: 2.28rem;
    height: 2.28rem;
    top: 0.4rem;
  }
}

section.csr03 {
  width: 100%;
  padding-bottom: 19.5rem;
  margin-top: -5rem;
  padding-top: 5rem;
}
@media screen and (max-width: 768px) {
  section.csr03 {
    padding-bottom: 12rem;
  }
}
section.csr03 .inner {
  width: 146rem;
  margin: auto;
}
@media screen and (max-width: 768px) {
  section.csr03 .inner {
    width: 100%;
  }
}
section.csr03 .inner h2 {
  width: 100%;
  padding: 7.5rem 0;
  font-size: 5.2rem;
  font-weight: 700;
  color: #552e30;
  text-align: center;
  border-top: 0.6rem solid #ffdb42;
  border-bottom: 0.6rem solid #ffdb42;
  position: relative;
  margin-bottom: 6rem;
}
@media screen and (max-width: 768px) {
  section.csr03 .inner h2 {
    font-size: 5.4rem;
    letter-spacing: -0.2rem;
    padding: 8rem 0;
  }
}
section.csr03 .inner h2::before {
  content: '';
  width: 8.3189rem;
  height: 9.02rem;
  background: url("../images/bg_h2_csr03.webp") no-repeat;
  background-size: 100%;
  position: absolute;
  top: -4.8rem;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 768px) {
  section.csr03 .inner h2::before {
    width: 6.4rem;
    height: 7rem;
    top: -4rem;
  }
}
section.csr03 .inner p.lead {
  font-size: 2.8rem;
  font-weight: 500;
  line-height: 4.6rem;
  color: #552e30;
  letter-spacing: -0.2rem;
  margin-bottom: 6rem;
}
@media screen and (max-width: 768px) {
  section.csr03 .inner p.lead {
    width: 65rem;
    margin: auto auto 6rem;
  }
}
section.csr03 .inner .comment.widthH3 {
  width: 100%;
  border-radius: 3rem;
  background: rgba(249, 190, 0, 0.15);
  padding: 4.5rem 7rem;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  section.csr03 .inner .comment.widthH3 {
    width: 65rem;
    margin: auto;
    flex-direction: column;
    gap: 2.5rem;
    padding: 5.6rem 5rem;
  }
}
section.csr03 .inner .comment.widthH3 h3 {
  width: 30.2rem;
  font-size: 2.8rem;
  font-weight: 900;
  line-height: 3.8rem;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 768px) {
  section.csr03 .inner .comment.widthH3 h3 {
    width: 100%;
    font-size: 3.2rem;
  }
}
section.csr03 .inner .comment.widthH3 p {
  width: calc(100% - 30.2rem);
  font-size: 2rem;
  font-weight: 500;
  line-height: 3.8rem;
  color: #552e30;
  letter-spacing: -0.2rem;
}
@media screen and (max-width: 768px) {
  section.csr03 .inner .comment.widthH3 p {
    width: 100%;
    font-size: 2.6rem;
    line-height: 4rem;
  }
}
section.csr03 .inner figure {
  width: 121rem;
  margin: 6.8rem auto auto;
}
@media screen and (max-width: 768px) {
  section.csr03 .inner figure {
    width: 59.8rem;
  }
}

.scrollArea {
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.scrollArea::-webkit-scrollbar {
  display: none;
}
@media screen and (max-width: 950px) {
  .scrollArea {
    overflow-y: scroll;
    margin-top: 0;
  }
}

.simplebar-track.simplebar-vertical {
  top: 0;
  width: 1rem;
  background: rgba(249, 190, 0, 0.4);
  border-radius: 0.5rem;
}

.simplebar-scrollbar {
  background: #552e30;
  border-radius: 0.5rem;
}

.simplebar-scrollbar.simplebar-visible {
  background: #552e30 !important;
}

.simplebar-scrollbar.simplebar-visible:before {
  background: #552e30 !important;
}

.simplebar-track .simplebar-scrollbar.simplebar-visible::before {
  opacity: 1;
}

.simplebar-track .simplebar-scrollbar::before {
  background: #552e30;
}

/* スクロールバー全体 */
.message::-webkit-scrollbar {
  width: 0.46vw;
  /* 横幅 */
}

/* スクロールバーのトラック部分（背景） */
.message::-webkit-scrollbar-track {
  background: rgba(249, 190, 0, 0.4);
}

/* スクロールバーのつまみ部分（ドラッグできる部分） */
.message::-webkit-scrollbar-thumb {
  background: #552e30;
  border-radius: 0.46vw;
}

/* ホバー時のつまみ色 */
.message::-webkit-scrollbar-thumb:hover {
  background: #552e30;
}

.message::-webkit-scrollbar-button {
  display: none;
}

/* Firefox用にスクロールバーの色を指定 */
.message {
  scrollbar-color: #552e30 rgba(249, 190, 0, 0.4);
  /* thumb color, track color */
  scrollbar-width: thin;
  /* auto, thin, none */
}
