@charset "UTF-8";
/* mediaquery
----------------------------------------------------------------- */
.pc_LL_display {
  display: none;
}
@media screen and (max-width: 1600px) {
  .pc_LL_display {
    display: block;
  }
}

.pc_L_display {
  display: none;
}
@media screen and (max-width: 1400px) {
  .pc_L_display {
    display: block;
  }
}

.pc_M_display {
  display: none;
}
@media screen and (max-width: 1200px) {
  .pc_M_display {
    display: block;
  }
}

.pc_S_display {
  display: none;
}
@media screen and (max-width: 1000px) {
  .pc_S_display {
    display: block;
  }
}

.tab_display {
  display: none;
}
@media screen and (max-width: 800px) {
  .tab_display {
    display: block;
  }
}

.sp_LL_display {
  display: none;
}
@media screen and (max-width: 600px) {
  .sp_LL_display {
    display: block;
  }
}

.sp_L_display {
  display: none;
}
@media screen and (max-width: 430px) {
  .sp_L_display {
    display: block;
  }
}

.sp_ML_display {
  display: none;
}
@media screen and (max-width: 400px) {
  .sp_ML_display {
    display: block;
  }
}

.sp_M_display {
  display: none;
}
@media screen and (max-width: 375px) {
  .sp_M_display {
    display: block;
  }
}

.sp_S_display {
  display: none;
}
@media screen and (max-width: 350px) {
  .sp_S_display {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .sp_LL_hidden {
    display: none;
  }
}

@font-face {
  font-family: "Charter";
  src: url("font/charter-roman.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
/* mediaquery
----------------------------------------------------------------- */
.pc_LL_display {
  display: none;
}
@media screen and (max-width: 1600px) {
  .pc_LL_display {
    display: block;
  }
}

.pc_L_display {
  display: none;
}
@media screen and (max-width: 1400px) {
  .pc_L_display {
    display: block;
  }
}

.pc_M_display {
  display: none;
}
@media screen and (max-width: 1200px) {
  .pc_M_display {
    display: block;
  }
}

.pc_S_display {
  display: none;
}
@media screen and (max-width: 1000px) {
  .pc_S_display {
    display: block;
  }
}

.tab_display {
  display: none;
}
@media screen and (max-width: 800px) {
  .tab_display {
    display: block;
  }
}

.sp_LL_display {
  display: none;
}
@media screen and (max-width: 600px) {
  .sp_LL_display {
    display: block;
  }
}

.sp_L_display {
  display: none;
}
@media screen and (max-width: 430px) {
  .sp_L_display {
    display: block;
  }
}

.sp_ML_display {
  display: none;
}
@media screen and (max-width: 400px) {
  .sp_ML_display {
    display: block;
  }
}

.sp_M_display {
  display: none;
}
@media screen and (max-width: 375px) {
  .sp_M_display {
    display: block;
  }
}

.sp_S_display {
  display: none;
}
@media screen and (max-width: 350px) {
  .sp_S_display {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .sp_LL_hidden {
    display: none;
  }
}

@font-face {
  font-family: "Charter";
  src: url("font/charter-roman.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
.footer {
  background-color: #fff;
  padding: 80px 0;
}
@media screen and (max-width: 600px) {
  .footer {
    padding: 40px 0 60px;
  }
}
.footer small {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  font-size: 14px;
  color: #DBDBDB;
}

.footer_inner {
  display: flex;
  justify-content: space-between;
  margin-bottom: 80px;
}
@media screen and (max-width: 800px) {
  .footer_inner {
    flex-direction: column;
    gap: 60px;
  }
}
@media screen and (max-width: 600px) {
  .footer_inner {
    margin-bottom: 40px;
  }
}

.footer_logo {
  width: 160px;
}
@media screen and (max-width: 600px) {
  .footer_logo {
    width: 110px;
  }
}

.footer_left {
  display: flex;
  gap: 80px;
}
@media screen and (max-width: 1400px) {
  .footer_left {
    gap: 40px;
  }
}
@media screen and (max-width: 1000px) {
  .footer_left {
    flex-direction: column;
  }
}

.footer_link {
  display: flex;
  gap: 80px;
  font-family: "Charter", sans-serif;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1400px) {
  .footer_link {
    gap: 40px;
  }
}
@media screen and (max-width: 375px) {
  .footer_link {
    gap: 24px;
  }
}

.footer_link_row {
  display: flex;
  gap: 24px;
  flex-direction: column;
}
@media screen and (max-width: 600px) {
  .footer_link_row {
    font-size: 13px;
  }
}

.footer_link_row a {
  transition: all 0.3s;
}
.footer_link_row a:hover {
  opacity: 0.6;
}

.footer_right h3 {
  font-size: 18px;
  margin-bottom: 8px;
}
@media screen and (max-width: 600px) {
  .footer_right h3 {
    font-size: 14px;
  }
}
.footer_right p {
  line-height: 1.8;
  font-size: 14px;
}
@media screen and (max-width: 600px) {
  .footer_right p {
    font-size: 12px;
  }
}
.footer_right p:nth-child(2) {
  margin-bottom: 8px;
}

/* mediaquery
----------------------------------------------------------------- */
.pc_LL_display {
  display: none;
}
@media screen and (max-width: 1600px) {
  .pc_LL_display {
    display: block;
  }
}

.pc_L_display {
  display: none;
}
@media screen and (max-width: 1400px) {
  .pc_L_display {
    display: block;
  }
}

.pc_M_display {
  display: none;
}
@media screen and (max-width: 1200px) {
  .pc_M_display {
    display: block;
  }
}

.pc_S_display {
  display: none;
}
@media screen and (max-width: 1000px) {
  .pc_S_display {
    display: block;
  }
}

.tab_display {
  display: none;
}
@media screen and (max-width: 800px) {
  .tab_display {
    display: block;
  }
}

.sp_LL_display {
  display: none;
}
@media screen and (max-width: 600px) {
  .sp_LL_display {
    display: block;
  }
}

.sp_L_display {
  display: none;
}
@media screen and (max-width: 430px) {
  .sp_L_display {
    display: block;
  }
}

.sp_ML_display {
  display: none;
}
@media screen and (max-width: 400px) {
  .sp_ML_display {
    display: block;
  }
}

.sp_M_display {
  display: none;
}
@media screen and (max-width: 375px) {
  .sp_M_display {
    display: block;
  }
}

.sp_S_display {
  display: none;
}
@media screen and (max-width: 350px) {
  .sp_S_display {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .sp_LL_hidden {
    display: none;
  }
}

@font-face {
  font-family: "Charter";
  src: url("font/charter-roman.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
  padding: 24px 0;
  transition: all 0.3s;
}
@media screen and (max-width: 1000px) {
  .header {
    padding: 32px 0;
  }
}
@media screen and (max-width: 600px) {
  .header {
    padding: 28px 0;
  }
}

.header.bg {
  background-color: #F8F8F8;
  border-bottom: 1px solid #DBDBDB;
}

.header.bg.open {
  background-color: unset;
  border-bottom: none;
}

.open .header_logo {
  opacity: 0;
  pointer-events: none;
  cursor: default;
}

.top .header_logo {
  opacity: 0;
  pointer-events: none;
  cursor: default;
}

.bg .header_logo .header_logo-black {
  display: block;
}
.bg .header_logo .header_logo-white {
  display: none;
}

.header_logo {
  width: 118px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 40px;
}
@media screen and (max-width: 600px) {
  .header_logo {
    width: 96px;
    left: 24px;
  }
}
@media screen and (max-width: 375px) {
  .header_logo {
    left: 12px;
  }
}
.header_logo .header_logo-black {
  display: none;
}

.header_nav {
  display: flex;
  gap: 40px;
  align-items: center;
  justify-content: center;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
@media screen and (max-width: 1000px) {
  .header_nav {
    display: none;
  }
}

.header_nav_item {
  font-family: "Charter", sans-serif;
  letter-spacing: 0.1em;
  color: #fff;
  font-size: 16px;
}

.header_nav_item a {
  transition: all 0.4s;
}
.header_nav_item a:hover {
  opacity: 0.5;
}

.header.bg .header_nav_item {
  color: #333333;
}

.header_cta {
  background-color: #808080;
  padding: 10px 32px;
  display: block;
  color: #fff;
  font-family: "Charter", sans-serif;
  letter-spacing: 0.1em;
  width: -moz-fit-content;
  width: fit-content;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 40px;
  transition: all 0.3s;
  border: 1px solid #808080;
  transition: all 0.3s;
}
@media screen and (max-width: 1000px) {
  .header_cta {
    right: 90px;
  }
}
@media screen and (max-width: 375px) {
  .header_cta {
    right: 60px;
  }
}
.header_cta:hover {
  background-color: #fff;
  color: #333333;
}

.open .header_cta-top {
  opacity: 0;
  pointer-events: none;
  cursor: default;
}

.header_hamburger_menu {
  display: none;
}
@media screen and (max-width: 1000px) {
  .header_hamburger_menu {
    display: block;
    position: absolute;
    z-index: 200;
    top: 50%;
    transform: translateY(-50%);
    right: 24px;
  }
}
@media screen and (max-width: 375px) {
  .header_hamburger_menu {
    right: 12px;
  }
}

.mask {
  display: none;
  padding: 120px 0;
}
@media screen and (max-width: 1000px) {
  .mask {
    display: block;
    position: fixed;
    opacity: 0;
    top: 0;
    right: -1000px;
    height: 100vh;
    max-width: 600px;
    width: 100%;
    background: #fff;
    z-index: -4;
    transition: all 0.5s;
  }
}

.mask .header_cta {
  margin: 0 auto;
  position: static;
  transform: none;
}

.mask .header_link {
  margin: 0 auto 54px;
  width: -moz-fit-content;
  width: fit-content;
}

.mask .header_link a {
  font-size: 18px;
  font-family: "Charter", sans-serif;
  letter-spacing: 0.1em;
  font-weight: 600;
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 40px;
  transform: all 0.3s;
}
.mask .header_link a:hover {
  opacity: 0.6;
}

.open.mask {
  opacity: 1;
  z-index: 80;
  right: 0;
}

.toggle_btn {
  width: 36px;
  height: 36px;
  cursor: pointer;
  position: relative;
  transition: all 0.3s;
}
.toggle_btn:hover {
  opacity: 0.7;
}
.toggle_btn span {
  display: block;
  position: absolute;
  left: 0;
  height: 2px;
  background-color: #fff;
  transition: all 0.5s;
}
.toggle_btn span:nth-child(1) {
  top: 4px;
  width: 100%;
}
.toggle_btn span:nth-child(2) {
  top: 16px;
  width: 100%;
}
.toggle_btn span:nth-child(3) {
  bottom: 4px;
  width: 100%;
}

.header.bg .toggle_btn span {
  background-color: #333;
}

.open .toggle_btn span {
  background-color: #333;
  transition: all 0.5s;
}
.open .toggle_btn span:nth-child(1) {
  top: 18px;
  transform: rotate(45deg);
}
.open .toggle_btn span:nth-child(2) {
  opacity: 0;
}
.open .toggle_btn span:nth-child(3) {
  bottom: 15px;
  transform: rotate(-45deg);
}

/* mediaquery
----------------------------------------------------------------- */
.pc_LL_display {
  display: none;
}
@media screen and (max-width: 1600px) {
  .pc_LL_display {
    display: block;
  }
}

.pc_L_display {
  display: none;
}
@media screen and (max-width: 1400px) {
  .pc_L_display {
    display: block;
  }
}

.pc_M_display {
  display: none;
}
@media screen and (max-width: 1200px) {
  .pc_M_display {
    display: block;
  }
}

.pc_S_display {
  display: none;
}
@media screen and (max-width: 1000px) {
  .pc_S_display {
    display: block;
  }
}

.tab_display {
  display: none;
}
@media screen and (max-width: 800px) {
  .tab_display {
    display: block;
  }
}

.sp_LL_display {
  display: none;
}
@media screen and (max-width: 600px) {
  .sp_LL_display {
    display: block;
  }
}

.sp_L_display {
  display: none;
}
@media screen and (max-width: 430px) {
  .sp_L_display {
    display: block;
  }
}

.sp_ML_display {
  display: none;
}
@media screen and (max-width: 400px) {
  .sp_ML_display {
    display: block;
  }
}

.sp_M_display {
  display: none;
}
@media screen and (max-width: 375px) {
  .sp_M_display {
    display: block;
  }
}

.sp_S_display {
  display: none;
}
@media screen and (max-width: 350px) {
  .sp_S_display {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .sp_LL_hidden {
    display: none;
  }
}

@font-face {
  font-family: "Charter";
  src: url("font/charter-roman.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
body {
  width: 100%;
  overflow-x: hidden;
  background-color: #F8F8F8;
  font-family: "Zen Old Mincho", serif;
  color: #333333;
  position: relative;
}

body.open {
  height: 100%;
  overflow: hidden;
}

img {
  display: block;
  width: 100%;
}

a {
  text-decoration: none;
}

.animation_fuwafuwa {
  animation: fuwafuwa 2s linear infinite;
  scale: 1;
}

@keyframes fuwafuwa {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(5px);
  }
  100% {
    transform: translateY(0);
  }
}
.animation_dokundokun {
  animation: dokundokun 1300ms ease infinite;
}

@keyframes dokundokun {
  0% {
    transform: scale(1);
  }
  20% {
    transform: scale(1.1);
  }
  40% {
    transform: scale(1);
  }
  70% {
    transform: scale(1.1);
  }
  100% {
    transform: scale(1);
  }
}
.animation_shiny {
  background: #D96F86;
  background: linear-gradient(-45deg, #D96F86 50%, rgb(238.2967032967, 191.7032967033, 201.8131868132) 60%, #D96F86 70%);
  background-size: 600% 100%;
  animation: shine 20s infinite;
  animation-delay: 0s;
  animation-timing-function: linear;
}

@keyframes shine {
  0% {
    background-position-x: 400%;
  }
  50% {
    background-position-x: 0%;
  }
  100% {
    background-position-x: -400%;
  }
}
.fadein {
  opacity: 0;
  transform: translateY(20px);
  transition: all 1s;
}

.scrollin {
  opacity: 1;
  transform: translateY(0);
}

.wrap-sm {
  width: 72%;
  margin: 0 auto;
  max-width: 1100px;
}
@media screen and (max-width: 1400px) {
  .wrap-sm {
    width: 80%;
  }
}
@media screen and (max-width: 1200px) {
  .wrap-sm {
    width: 86%;
  }
}
@media screen and (max-width: 800px) {
  .wrap-sm {
    width: 90%;
  }
}
@media screen and (max-width: 600px) {
  .wrap-sm {
    width: 92%;
  }
}

.wrap-ssm {
  width: 68%;
  margin: 0 auto;
  max-width: 1000px;
}
@media screen and (max-width: 1400px) {
  .wrap-ssm {
    width: 80%;
  }
}
@media screen and (max-width: 1200px) {
  .wrap-ssm {
    width: 86%;
  }
}
@media screen and (max-width: 800px) {
  .wrap-ssm {
    width: 90%;
  }
}
@media screen and (max-width: 600px) {
  .wrap-ssm {
    width: 92%;
  }
}

.wrap {
  width: 80%;
  margin: 0 auto;
  max-width: 1200px;
}
@media screen and (max-width: 1200px) {
  .wrap {
    width: 90%;
  }
}
@media screen and (max-width: 600px) {
  .wrap {
    width: 92%;
  }
}

.wrap-lg {
  width: 90%;
  margin: 0 auto;
  max-width: 1400px;
}
@media screen and (max-width: 600px) {
  .wrap-lg {
    width: 92%;
  }
}

.more_btn {
  display: flex;
  align-items: center;
  gap: 20px;
  font-size: 18px;
  width: -moz-fit-content;
  width: fit-content;
  font-family: "Charter", sans-serif;
  letter-spacing: 0.1em;
}

@media screen and (max-width: 1000px) {
  .more_btn-pc {
    display: none;
  }
}

.more_btn-sp {
  display: none;
}
@media screen and (max-width: 1000px) {
  .more_btn-sp {
    display: flex;
  }
}

.more_btn:hover .more_btn_arrow img {
  transform: translateX(100%);
}
.more_btn:hover .more_btn_arrow::after {
  left: 0;
}

.more_btn_arrow {
  width: 32px;
  overflow: hidden;
  aspect-ratio: 8/1.2;
  transition: all 0.5s ease;
  position: relative;
}
.more_btn_arrow img {
  aspect-ratio: 8/1.2;
  transition: all 0.5s ease;
}
.more_btn_arrow::after {
  content: "";
  position: absolute;
  width: 32px;
  aspect-ratio: 8/1.2;
  background-image: url(../images/common/arrow.webp);
  background-size: 100% 100%;
  top: 0;
  left: -150%;
  transition: all 0.5s ease;
}

p {
  line-height: 2.2;
}
@media screen and (max-width: 1000px) {
  p {
    font-size: 14px;
  }
}
@media screen and (max-width: 600px) {
  p {
    font-size: 13px;
  }
}

.cta {
  padding: 0 0 120px;
}
@media screen and (max-width: 600px) {
  .cta {
    padding: 0 0 40px;
  }
}

.cta_wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
@media screen and (max-width: 800px) {
  .cta_wrap {
    grid-template-columns: 1fr;
  }
}

.cta_link {
  position: relative;
  overflow: hidden;
}

.cta_link_inner {
  color: #fff;
  position: absolute;
  bottom: 24px;
  left: 24px;
  display: flex;
  align-items: center;
  gap: 24px;
}
@media screen and (max-width: 600px) {
  .cta_link_inner {
    bottom: 16px;
    left: 16px;
    gap: 12px;
  }
}
.cta_link_inner span {
  font-family: "Charter", sans-serif;
  letter-spacing: 0.1em;
  font-size: 16px;
  display: block;
  margin-bottom: 8px;
}
@media screen and (max-width: 600px) {
  .cta_link_inner span {
    font-size: 14px;
  }
}
.cta_link_inner h2 {
  font-size: 20px;
}
@media screen and (max-width: 600px) {
  .cta_link_inner h2 {
    font-size: 18px;
  }
}

.cta_link:hover .cta_link_bg img {
  transition: all 0.5s;
  transform: scale(1.1);
}
.cta_link:hover .cta_link_arrow_img img {
  transform: translateX(100%);
}
.cta_link:hover .cta_link_arrow_img::after {
  left: 0;
}

.cta_link_bg img {
  transition: all 0.5s;
}

.cta_link_arrow {
  width: 45px;
  height: 45px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1.6px solid #fff;
  border-radius: 50%;
}
@media screen and (max-width: 600px) {
  .cta_link_arrow {
    width: 26px;
    height: 26px;
    border: 1px solid #fff;
  }
}

.cta_link_arrow_img {
  aspect-ratio: 18/5;
  transition: all 0.5s ease;
  width: 24px;
  overflow: hidden;
  position: relative;
}
@media screen and (max-width: 600px) {
  .cta_link_arrow_img {
    width: 14px;
  }
}
.cta_link_arrow_img img {
  aspect-ratio: 18/5;
  transition: all 0.5s ease;
  width: 24px;
}
@media screen and (max-width: 600px) {
  .cta_link_arrow_img img {
    width: 14px;
  }
}
.cta_link_arrow_img::after {
  content: "";
  position: absolute;
  width: 24px;
  aspect-ratio: 18/5;
  background-image: url(../images/common/arrow-white.webp);
  background-size: 100% 100%;
  top: 0;
  left: -150%;
  transition: all 0.5s ease;
}
@media screen and (max-width: 600px) {
  .cta_link_arrow_img::after {
    width: 14px;
  }
}

.page-ttl {
  position: relative;
  width: 100%;
  padding: 200px 0 120px;
  overflow: hidden;
}
@media screen and (max-width: 600px) {
  .page-ttl {
    padding: 180px 0 60px;
  }
}

.page-ttl_txt {
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  font-size: 28px;
  font-family: "Charter", sans-serif;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1400px) {
  .page-ttl_txt {
    font-size: 24px;
  }
}
@media screen and (max-width: 800px) {
  .page-ttl_txt {
    font-size: 20px;
  }
}

.page-top {
  position: relative;
  width: 100%;
  height: 96vh;
  overflow: hidden;
}

.page-top_bg {
  position: absolute;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  top: 0;
  left: 0;
}

.page-top_logo {
  width: 240px;
  position: absolute;
  z-index: 2;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
@media screen and (max-width: 600px) {
  .page-top_logo {
    width: 140px;
  }
}

.page-ttl .breadcrumb {
  color: #333333;
}
.page-ttl .breadcrumb .breadcrumb_item:not(:first-child)::after {
  background-color: #333;
}

.breadcrumb {
  position: absolute;
  top: 90px;
  left: 40px;
  color: #fff;
  z-index: 3;
  font-family: "Charter", sans-serif;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 600px) {
  .breadcrumb {
    left: 20px;
  }
}
@media screen and (max-width: 375px) {
  .breadcrumb {
    left: 12px;
  }
}

.breadcrumb_list {
  display: flex;
  align-items: center;
  gap: 16px;
}
@media screen and (max-width: 600px) {
  .breadcrumb_list {
    font-size: 12px;
  }
}

.breadcrumb_item:not(:first-child) {
  position: relative;
}
.breadcrumb_item:not(:first-child)::after {
  content: "";
  position: absolute;
  top: 60%;
  transform: translateY(-50%);
  width: 4px;
  height: 1px;
  left: -10px;
  background-color: #fff;
}

.page-error {
  padding: 180px 0 120px;
}

.page-error h1 {
  font-size: 32px;
  margin-bottom: 24px;
}
@media screen and (max-width: 600px) {
  .page-error h1 {
    font-size: 26px;
  }
}

.page-error h2 {
  font-size: 20px;
  margin-bottom: 40px;
}
@media screen and (max-width: 600px) {
  .page-error h2 {
    font-size: 16px;
  }
}

.post_pagination {
  width: -moz-fit-content;
  width: fit-content;
  margin: 120px auto 0;
  font-family: "Charter", sans-serif;
  letter-spacing: 0.1em;
  display: flex;
  gap: 24px;
  font-size: 20px;
}
.post_pagination .page-numbers.current {
  color: #2B2B2B;
}
.post_pagination .page-numbers {
  color: #DBDBDB;
}

.prev.page-numbers,
.next.page-numbers {
  display: none;
}

/* mediaquery
----------------------------------------------------------------- */
.pc_LL_display {
  display: none;
}
@media screen and (max-width: 1600px) {
  .pc_LL_display {
    display: block;
  }
}

.pc_L_display {
  display: none;
}
@media screen and (max-width: 1400px) {
  .pc_L_display {
    display: block;
  }
}

.pc_M_display {
  display: none;
}
@media screen and (max-width: 1200px) {
  .pc_M_display {
    display: block;
  }
}

.pc_S_display {
  display: none;
}
@media screen and (max-width: 1000px) {
  .pc_S_display {
    display: block;
  }
}

.tab_display {
  display: none;
}
@media screen and (max-width: 800px) {
  .tab_display {
    display: block;
  }
}

.sp_LL_display {
  display: none;
}
@media screen and (max-width: 600px) {
  .sp_LL_display {
    display: block;
  }
}

.sp_L_display {
  display: none;
}
@media screen and (max-width: 430px) {
  .sp_L_display {
    display: block;
  }
}

.sp_ML_display {
  display: none;
}
@media screen and (max-width: 400px) {
  .sp_ML_display {
    display: block;
  }
}

.sp_M_display {
  display: none;
}
@media screen and (max-width: 375px) {
  .sp_M_display {
    display: block;
  }
}

.sp_S_display {
  display: none;
}
@media screen and (max-width: 350px) {
  .sp_S_display {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .sp_LL_hidden {
    display: none;
  }
}

@font-face {
  font-family: "Charter";
  src: url("font/charter-roman.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
/* --------------------------------------------------------------------- 
front
-----------------------------------------------------------------------*/
/*--------------- mv ---------------*/
.mv {
  position: relative;
  height: 100vh;
  overflow: hidden;
}

.mv_logo {
  width: 210px;
  position: absolute;
  transform: translate(-50%, -50%);
  left: 50%;
  top: 50%;
  z-index: 10;
}
@media screen and (max-width: 600px) {
  .mv_logo {
    width: 160px;
  }
}

.mv_bg_img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center center;
  opacity: 0;
  animation: image-switch-animation 27s infinite;
  animation-fill-mode: both;
  z-index: 1;
}

.mv_bg_img.src1 {
  animation-delay: 0s;
}
.mv_bg_img.src1 .mv_bg_wrap {
  animation-delay: 0s;
}

.mv_bg_img.src2 {
  animation-delay: 9s;
}
.mv_bg_img.src2 .mv_bg_wrap {
  animation-delay: 9s;
}

.mv_bg_img.src3 {
  animation-delay: 18s;
}
.mv_bg_img.src3 .mv_bg_wrap {
  animation-delay: 18s;
}

@keyframes image-switch-animation {
  0% {
    opacity: 0;
    z-index: 1;
  }
  2% {
    opacity: 1;
    z-index: 2;
  }
  34% {
    opacity: 1;
    z-index: 2;
  }
  36% {
    opacity: 0;
    z-index: 2;
  }
  100% {
    opacity: 0;
    z-index: 1;
  }
}
.mv_bg_wrap {
  width: 110%;
  height: 100%;
  animation: slowPan 10s linear forwards;
}

.mv_bg_wrap .thumbnail {
  height: 100vh;
  -o-object-fit: cover;
     object-fit: cover;
}

@keyframes slowPan {
  0% {
    transform: translateX(0);
  }
  3% {
    transform: translateX(-0.4vw);
  }
  100% {
    transform: translateX(-1.6vw);
  }
}
/*--------------- top-concept ---------------*/
.top-concept {
  padding: 140px 0 220px;
}
@media screen and (max-width: 600px) {
  .top-concept {
    padding: 80px 0 120px;
  }
}

.top-ttl {
  font-family: "Charter", sans-serif;
  letter-spacing: 0.1em;
  font-size: 32px;
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 80px;
}
@media screen and (max-width: 600px) {
  .top-ttl {
    font-size: 22px;
    margin: 0 auto 40px;
  }
}

.top-concept_content {
  display: grid;
  grid-template-columns: 50% 1fr;
  gap: 64px;
  align-items: center;
}
@media screen and (max-width: 1000px) {
  .top-concept_content {
    grid-template-columns: 1fr;
  }
}
@media screen and (max-width: 600px) {
  .top-concept_content {
    gap: 40px;
  }
}

@media screen and (max-width: 1000px) {
  .top-concept_img {
    max-width: 400px;
    margin: 0 auto;
    width: 94%;
  }
}

.top-concept_txt h3 {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 40px;
}
@media screen and (max-width: 600px) {
  .top-concept_txt h3 {
    font-size: 16px;
    margin-bottom: 24px;
  }
}

.top-concept_txt p {
  font-size: 16px;
  line-height: 2.2;
  text-align: justify;
}
@media screen and (max-width: 600px) {
  .top-concept_txt p {
    font-size: 13px;
  }
}

/*--------------- top-lineup ---------------*/
.top-lineup_link {
  display: block;
  width: 100%;
  overflow: hidden;
  transition: all 0.5s ease;
  position: relative;
}
@media screen and (max-width: 800px) {
  .top-lineup_link {
    aspect-ratio: 39/40;
  }
}
@media screen and (max-width: 600px) {
  .top-lineup_link {
    aspect-ratio: 39/60;
  }
}

.top-lineup_bg {
  transition: all 0.5s ease;
}
@media screen and (max-width: 800px) {
  .top-lineup_bg {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

.top-lineup_link:hover .top-lineup_bg {
  transform: scale(1.1);
}
.top-lineup_link:hover .top-lineup_arrow_img img {
  transform: translateX(100%);
}
.top-lineup_link:hover .top-lineup_arrow_img::after {
  left: 0;
}

.top-lineup_txt {
  position: absolute;
  bottom: 80px;
  width: 80%;
  left: 50%;
  transform: translateX(-50%);
  max-width: 1200px;
}
@media screen and (max-width: 1200px) {
  .top-lineup_txt {
    width: 90%;
  }
}
@media screen and (max-width: 800px) {
  .top-lineup_txt {
    bottom: 200px;
  }
}
@media screen and (max-width: 600px) {
  .top-lineup_txt {
    width: 92%;
    bottom: 140px;
  }
}

.top-lineup_txt img {
  width: 240px;
  margin-bottom: 40px;
}
@media screen and (max-width: 800px) {
  .top-lineup_txt img {
    width: 160px;
    margin-bottom: 24px;
  }
}
@media screen and (max-width: 600px) {
  .top-lineup_txt img {
    width: 140px;
  }
}

.top-lineup_txt p {
  font-size: 16px;
  line-height: 2.2;
  color: #fff;
  width: 400px;
}
@media screen and (max-width: 800px) {
  .top-lineup_txt p {
    font-size: 14px;
    width: 100%;
  }
}

.top-lineup_arrow {
  width: 140px;
  height: 140px;
  border: 2px solid #fff;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-family: "Charter", sans-serif;
  letter-spacing: 0.1em;
  font-size: 16px;
}
@media screen and (max-width: 800px) {
  .top-lineup_arrow {
    left: 50%;
    transform: translateX(-50%);
    bottom: 24px;
    top: auto;
  }
}
@media screen and (max-width: 600px) {
  .top-lineup_arrow {
    width: 96px;
    height: 96px;
    font-size: 14px;
  }
}

.top-lineup_arrow_img {
  width: 32px;
  bottom: 32px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  overflow: hidden;
  aspect-ratio: 8/1.2;
  transition: all 0.5s ease;
}
@media screen and (max-width: 600px) {
  .top-lineup_arrow_img {
    bottom: 20px;
    width: 24px;
  }
}
.top-lineup_arrow_img img {
  width: 100%;
  aspect-ratio: 8/1.2;
  transition: all 0.5s ease;
}
.top-lineup_arrow_img::after {
  content: "";
  position: absolute;
  width: 32px;
  aspect-ratio: 8/1.2;
  background-image: url(../images/common/arrow-white.webp);
  background-size: 100% 100%;
  top: 0;
  left: -150%;
  transition: all 0.5s ease;
}
@media screen and (max-width: 600px) {
  .top-lineup_arrow_img::after {
    width: 24px;
  }
}

/*--------------- top-event ---------------*/
.top-event {
  padding: 140px 0 180px;
}
@media screen and (max-width: 600px) {
  .top-event {
    padding: 80px 0;
  }
}
.top-event .more_btn {
  margin-left: auto;
}

.top-event_list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 32px;
  margin-bottom: 40px;
}
@media screen and (max-width: 1000px) {
  .top-event_list {
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (max-width: 800px) {
  .top-event_list {
    grid-template-columns: 1fr;
  }
}

.top-event_item {
  transition: all 0.4s;
}
.top-event_item:hover {
  opacity: 0.6;
}

.top-event_img {
  margin-bottom: 16px;
  aspect-ratio: 3/2;
  -o-object-fit: cover;
     object-fit: cover;
}

.event_tag {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 12px;
}

.event_tag_item {
  display: flex;
  align-items: center;
  gap: 4px;
}
.event_tag_item:nth-child(1) {
  font-family: "Charter", sans-serif;
  letter-spacing: 0.1em;
}
.event_tag_item img {
  width: 22px;
}
@media screen and (max-width: 1400px) {
  .event_tag_item img {
    width: 19px;
  }
}
.event_tag_item span {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 1400px) {
  .event_tag_item span {
    font-size: 14px;
  }
}

.event_ttl {
  font-size: 20px;
}
@media screen and (max-width: 1200px) {
  .event_ttl {
    font-size: 18px;
  }
}

.top-menu {
  position: relative;
  padding-bottom: 180px;
}
@media screen and (max-width: 600px) {
  .top-menu {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}
.top-menu .top-ttl {
  margin-left: 0;
  width: -moz-fit-content;
  width: fit-content;
  line-height: 2;
}
@media screen and (max-width: 600px) {
  .top-menu .top-ttl {
    font-size: 20px;
    margin-bottom: 24px;
  }
}

.top-menu_bg {
  position: absolute;
  width: 78%;
  background-color: #fff;
  bottom: 0;
  left: 0;
  height: calc(36vw + 180px);
}
@media screen and (max-width: 600px) {
  .top-menu_bg {
    height: 100%;
    width: 100%;
  }
}

.top-menu_wrap {
  position: relative;
  z-index: 2;
}

.top-menu_top {
  max-width: 500px;
  width: 100%;
  margin-bottom: 72px;
}
@media screen and (max-width: 600px) {
  .top-menu_top {
    font-size: 13px;
    margin-bottom: 40px;
  }
}

.top-menu_list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
}
@media screen and (max-width: 1000px) {
  .top-menu_list {
    gap: 16px;
  }
}
@media screen and (max-width: 800px) {
  .top-menu_list {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}

.top-menu_link:hover .top-menu_img img {
  transition: all 0.5s;
  transform: scale(1.1);
}
.top-menu_link:hover .top-menu_arrow_img img {
  transform: translateX(100%);
}
.top-menu_link:hover .top-menu_arrow_img::after {
  left: 0;
}

.top-menu_img {
  aspect-ratio: 32/24;
  transition: all 0.5s;
  overflow: hidden;
  margin-bottom: 28px;
}
@media screen and (max-width: 600px) {
  .top-menu_img {
    aspect-ratio: 32/24;
    margin-bottom: 16px;
  }
}
.top-menu_img img {
  transition: all 0.5s;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.top-menu_txt {
  position: relative;
}

.top-menu_sub {
  display: block;
  color: #DBDBDB;
  font-size: 14px;
  font-family: "Charter", sans-serif;
  letter-spacing: 0.1em;
  margin-bottom: 6px;
}

.top-menu_ttl {
  font-size: 20px;
}

.top-menu_arrow {
  width: 45px;
  height: 45px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1.6px solid #DBDBDB;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
}

.top-menu_arrow_img {
  aspect-ratio: 18/5;
  transition: all 0.5s ease;
  width: 24px;
  overflow: hidden;
  position: relative;
}
.top-menu_arrow_img img {
  aspect-ratio: 18/5;
  transition: all 0.5s ease;
  width: 24px;
}
.top-menu_arrow_img::after {
  content: "";
  position: absolute;
  width: 24px;
  aspect-ratio: 18/5;
  background-image: url(../images/common/arrow-gray.webp);
  background-size: 100% 100%;
  top: 0;
  left: -150%;
  transition: all 0.5s ease;
}

.top-works {
  padding: 180px 0 210px;
  width: 100%;
  overflow: hidden;
}
@media screen and (max-width: 600px) {
  .top-works {
    padding: 80px 0 80px;
  }
}
@media screen and (max-width: 600px) {
  .top-works .more_btn {
    margin: 0 auto;
  }
}

.top-works.top-works-page {
  padding: 80px 0 210px;
  border-top: 1px solid #DBDBDB;
}
@media screen and (max-width: 600px) {
  .top-works.top-works-page {
    padding: 40px 0 80px;
  }
}

.top-works_wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 1000px) {
  .top-works_wrap {
    flex-direction: column;
    gap: 40px;
    align-items: flex-start;
    width: 96%;
    margin-left: auto;
  }
}

.top-works_ttl {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 40px;
  padding-left: 80px;
}
@media screen and (max-width: 1000px) {
  .top-works_ttl {
    padding-left: 0;
    margin-left: 0;
  }
}
.top-works_ttl .top-ttl {
  width: -moz-fit-content;
  width: fit-content;
  margin-left: 0;
  margin-bottom: 0;
}

.top-works_swiper {
  width: 76vw;
  margin: 0;
  overflow: hidden;
  position: relative;
}
@media screen and (max-width: 1000px) {
  .top-works_swiper {
    width: 90%;
  }
}
@media screen and (max-width: 600px) {
  .top-works_swiper {
    width: 100%;
  }
}

.top-works_swiper .swiper-button-next,
.top-works_swiper .swiper-button-prev {
  color: #fff !important;
  transition: all 0.5s ease;
}
@media screen and (max-width: 600px) {
  .top-works_swiper .swiper-button-next,
  .top-works_swiper .swiper-button-prev {
    display: none;
  }
}
.top-works_swiper .swiper-button-next:hover,
.top-works_swiper .swiper-button-prev:hover {
  opacity: 0.6;
}

.top-works_item {
  padding-right: 40px;
}
@media screen and (max-width: 1000px) {
  .top-works_item {
    padding-right: 16px;
  }
}

.top-works_item:hover .top-works_img img {
  transform: scale(1.1);
}

.top-works_img {
  margin-bottom: 8px;
  aspect-ratio: 38/50;
  overflow: hidden;
}

.top-works_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: all 0.5s ease;
}

.works_date {
  display: block;
  font-family: "Charter", sans-serif;
  letter-spacing: 0.1em;
  font-size: 14px;
  margin-bottom: 4px;
}

.works_tag {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px;
  flex-wrap: wrap;
}
.works_tag span {
  color: #fff;
  background-color: #B4B4B4;
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  padding: 2px 8px 3px;
  font-size: 14px;
}
@media screen and (max-width: 600px) {
  .works_tag span {
    font-size: 13px;
  }
}

.works_ttl {
  font-size: 20px;
}
@media screen and (max-width: 600px) {
  .works_ttl {
    font-size: 18px;
  }
}

/* mediaquery
----------------------------------------------------------------- */
.pc_LL_display {
  display: none;
}
@media screen and (max-width: 1600px) {
  .pc_LL_display {
    display: block;
  }
}

.pc_L_display {
  display: none;
}
@media screen and (max-width: 1400px) {
  .pc_L_display {
    display: block;
  }
}

.pc_M_display {
  display: none;
}
@media screen and (max-width: 1200px) {
  .pc_M_display {
    display: block;
  }
}

.pc_S_display {
  display: none;
}
@media screen and (max-width: 1000px) {
  .pc_S_display {
    display: block;
  }
}

.tab_display {
  display: none;
}
@media screen and (max-width: 800px) {
  .tab_display {
    display: block;
  }
}

.sp_LL_display {
  display: none;
}
@media screen and (max-width: 600px) {
  .sp_LL_display {
    display: block;
  }
}

.sp_L_display {
  display: none;
}
@media screen and (max-width: 430px) {
  .sp_L_display {
    display: block;
  }
}

.sp_ML_display {
  display: none;
}
@media screen and (max-width: 400px) {
  .sp_ML_display {
    display: block;
  }
}

.sp_M_display {
  display: none;
}
@media screen and (max-width: 375px) {
  .sp_M_display {
    display: block;
  }
}

.sp_S_display {
  display: none;
}
@media screen and (max-width: 350px) {
  .sp_S_display {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .sp_LL_hidden {
    display: none;
  }
}

@font-face {
  font-family: "Charter";
  src: url("font/charter-roman.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
.signature_top_txt {
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  padding: 120px 6vw 120px 0;
}
@media screen and (max-width: 1400px) {
  .signature_top_txt {
    font-size: 14px;
  }
}
@media screen and (max-width: 1000px) {
  .signature_top_txt {
    padding: 120px 0;
  }
}
@media screen and (max-width: 600px) {
  .signature_top_txt {
    font-size: 13px;
    padding: 40px 0;
  }
}

.signature_top_list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 60px;
  margin-bottom: 240px;
}
@media screen and (max-width: 1000px) {
  .signature_top_list {
    gap: 24px;
  }
}
@media screen and (max-width: 600px) {
  .signature_top_list {
    gap: 8px;
    margin-bottom: 90px;
  }
}

.signature_point {
  position: relative;
  padding-bottom: 120px;
}
@media screen and (max-width: 600px) {
  .signature_point {
    padding-bottom: 60px;
  }
}

.signature_point_bg {
  position: absolute;
  width: 90%;
  height: calc(88% + 120px);
  bottom: 0;
  left: 0;
  background-color: #fff;
}
@media screen and (max-width: 600px) {
  .signature_point_bg {
    width: 100%;
    height: calc(94% + 60px);
  }
}

.signature_point_list {
  position: relative;
  z-index: 2;
}

.signature_point_item {
  display: grid;
  grid-template-columns: 38% 1fr;
  align-items: center;
  gap: 90px;
}
@media screen and (max-width: 1000px) {
  .signature_point_item {
    gap: 40px;
  }
}
@media screen and (max-width: 800px) {
  .signature_point_item {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}
.signature_point_item:not(:last-child) {
  margin-bottom: 40px;
}

@media screen and (max-width: 800px) {
  .signature_point_item img {
    max-width: 400px;
  }
}
@media screen and (max-width: 600px) {
  .signature_point_item img {
    max-width: 250px;
  }
}

.signature_point_txt h2 {
  font-size: 18px;
  font-weight: 700;
  display: block;
  margin-bottom: 40px;
}
@media screen and (max-width: 1000px) {
  .signature_point_txt h2 {
    margin-bottom: 24px;
    font-size: 16px;
  }
}
@media screen and (max-width: 800px) {
  .signature_point_txt h2 {
    margin-bottom: 16px;
  }
}

@media screen and (max-width: 1000px) {
  .signature_point_txt p {
    font-size: 14px;
  }
}

.signature_message {
  padding: 180px 0;
  display: flex;
  gap: 90px;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
@media screen and (max-width: 1200px) {
  .signature_message {
    gap: 40px;
  }
}
@media screen and (max-width: 1000px) {
  .signature_message {
    flex-direction: column;
    max-width: 92%;
  }
}
@media screen and (max-width: 600px) {
  .signature_message {
    padding: 80px 0;
    gap: 24px;
  }
}

.signature_message h2 {
  font-size: 18px;
  font-weight: 700;
  margin-top: 8px;
}
@media screen and (max-width: 1400px) {
  .signature_message h2 {
    font-size: 16px;
  }
}
@media screen and (max-width: 1000px) {
  .signature_message h2 {
    margin-top: 0;
  }
}

.signature_message p {
  max-width: 640px;
}
@media screen and (max-width: 1400px) {
  .signature_message p {
    font-size: 14px;
    max-width: 560px;
  }
}
@media screen and (max-width: 600px) {
  .signature_message p {
    font-size: 13px;
  }
}

/* mediaquery
----------------------------------------------------------------- */
.pc_LL_display {
  display: none;
}
@media screen and (max-width: 1600px) {
  .pc_LL_display {
    display: block;
  }
}

.pc_L_display {
  display: none;
}
@media screen and (max-width: 1400px) {
  .pc_L_display {
    display: block;
  }
}

.pc_M_display {
  display: none;
}
@media screen and (max-width: 1200px) {
  .pc_M_display {
    display: block;
  }
}

.pc_S_display {
  display: none;
}
@media screen and (max-width: 1000px) {
  .pc_S_display {
    display: block;
  }
}

.tab_display {
  display: none;
}
@media screen and (max-width: 800px) {
  .tab_display {
    display: block;
  }
}

.sp_LL_display {
  display: none;
}
@media screen and (max-width: 600px) {
  .sp_LL_display {
    display: block;
  }
}

.sp_L_display {
  display: none;
}
@media screen and (max-width: 430px) {
  .sp_L_display {
    display: block;
  }
}

.sp_ML_display {
  display: none;
}
@media screen and (max-width: 400px) {
  .sp_ML_display {
    display: block;
  }
}

.sp_M_display {
  display: none;
}
@media screen and (max-width: 375px) {
  .sp_M_display {
    display: block;
  }
}

.sp_S_display {
  display: none;
}
@media screen and (max-width: 350px) {
  .sp_S_display {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .sp_LL_hidden {
    display: none;
  }
}

@font-face {
  font-family: "Charter";
  src: url("font/charter-roman.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
.more_top {
  width: 100%;
  overflow: hidden;
  padding-bottom: 120px;
}
@media screen and (max-width: 600px) {
  .more_top {
    padding-bottom: 40px;
  }
}

.more_top_txt p {
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  padding: 120px 0;
  max-width: 840px;
}
@media screen and (max-width: 1400px) {
  .more_top_txt p {
    font-size: 14px;
    max-width: 720px;
  }
}
@media screen and (max-width: 600px) {
  .more_top_txt p {
    padding: 60px 0 40px;
    font-size: 13px;
  }
}

.more_swiper {
  position: relative;
}
.more_swiper .swiper-pagination-bullet {
  background-color: #E2E2E2 !important;
  opacity: 1 !important;
}
.more_swiper .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background-color: #918A84 !important;
}

/*------------- order -------------*/
.order_top {
  display: grid;
  grid-template-columns: 300px 680px;
  margin-bottom: 140px;
}
@media screen and (max-width: 1400px) {
  .order_top {
    grid-template-columns: 280px 600px;
  }
}
@media screen and (max-width: 1000px) {
  .order_top {
    grid-template-columns: 1fr;
    gap: 40px;
  }
}
@media screen and (max-width: 600px) {
  .order_top {
    gap: 32px;
    margin-bottom: 80px;
  }
}

.order_top h2 {
  font-size: 18px;
  font-weight: 700;
  margin-top: 8px;
}
@media screen and (max-width: 1400px) {
  .order_top h2 {
    font-size: 16px;
  }
}
@media screen and (max-width: 1000px) {
  .order_top h2 {
    margin-top: 0;
  }
}

@media screen and (max-width: 1400px) {
  .order_top p {
    font-size: 14px;
  }
}
@media screen and (max-width: 600px) {
  .order_top p {
    font-size: 13px;
  }
}

.order_des {
  padding-bottom: 200px;
}
@media screen and (max-width: 600px) {
  .order_des {
    padding-bottom: 80px;
  }
}

.order_des_list {
  display: grid;
  grid-template-columns: 5fr 5.36fr;
  gap: 60px;
  margin-bottom: 16px;
}
@media screen and (max-width: 1400px) {
  .order_des_list {
    gap: 40px;
  }
}
@media screen and (max-width: 1000px) {
  .order_des_list {
    gap: 12px;
  }
}
@media screen and (max-width: 800px) {
  .order_des_list {
    grid-template-columns: 1fr;
    gap: 40px;
  }
}

.order_des_item h3 {
  font-size: 22px;
  font-weight: 700;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 32px;
}
@media screen and (max-width: 1400px) {
  .order_des_item h3 {
    font-size: 20px;
  }
}
@media screen and (max-width: 600px) {
  .order_des_item h3 {
    font-size: 18px;
    margin: 0 auto 20px;
  }
}

.order_des_note {
  display: block;
  margin-left: auto;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 14px;
}
@media screen and (max-width: 600px) {
  .order_des_note {
    font-size: 10px;
  }
}

/*------------- rule -------------*/
.rule {
  padding: 60px 0 180px;
  border-top: 1px solid #DBDBDB;
}
@media screen and (max-width: 600px) {
  .rule {
    padding: 40px 0 80px;
  }
}

.rule_top {
  display: grid;
  grid-template-columns: 300px 680px;
  margin-bottom: 140px;
}
@media screen and (max-width: 1400px) {
  .rule_top {
    grid-template-columns: 280px 600px;
  }
}
@media screen and (max-width: 1000px) {
  .rule_top {
    grid-template-columns: 1fr;
    gap: 40px;
  }
}
@media screen and (max-width: 600px) {
  .rule_top {
    gap: 32px;
    margin-bottom: 40px;
  }
}

.rule_top h2 {
  font-size: 18px;
  font-weight: 700;
  margin-top: 8px;
}
@media screen and (max-width: 1400px) {
  .rule_top h2 {
    font-size: 16px;
  }
}
@media screen and (max-width: 1000px) {
  .rule_top h2 {
    margin-top: 0;
  }
}

@media screen and (max-width: 1400px) {
  .rule_top p {
    font-size: 14px;
  }
}
@media screen and (max-width: 600px) {
  .rule_top p {
    font-size: 13px;
  }
}

.rule_content {
  background-color: #fff;
}

.rule_txt {
  padding: 54px 0;
  width: 800px;
  margin: 0 auto;
}
@media screen and (max-width: 1400px) {
  .rule_txt {
    max-width: 720px;
    width: 90%;
  }
}
@media screen and (max-width: 600px) {
  .rule_txt {
    padding: 20px 0;
    width: 94%;
  }
}

.rule_txt h3 {
  font-size: 18px;
  font-weight: 700;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 24px;
}
@media screen and (max-width: 1400px) {
  .rule_txt h3 {
    font-size: 16px;
  }
}
@media screen and (max-width: 600px) {
  .rule_txt h3 {
    margin: 0 auto 16px;
  }
}

.rule_list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 16px;
}
@media screen and (max-width: 1400px) {
  .rule_list {
    gap: 6px;
  }
}
@media screen and (max-width: 600px) {
  .rule_list {
    margin-bottom: 12px;
    gap: 2px;
  }
}

.rule_item {
  width: 100%;
  height: 64px;
  border: 1px solid #333;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  text-align: center;
}
@media screen and (max-width: 1400px) {
  .rule_item {
    font-size: 14px;
    height: 60px;
  }
}
@media screen and (max-width: 600px) {
  .rule_item {
    font-size: 11px;
    line-height: 1.3;
  }
}
@media screen and (max-width: 375px) {
  .rule_item {
    font-size: 10px;
  }
}

@media screen and (max-width: 1400px) {
  .rule_txt p {
    font-size: 14px;
  }
}
@media screen and (max-width: 600px) {
  .rule_txt p {
    font-size: 13px;
    text-align: justify;
  }
}

/*------------- safe -------------*/
.safe {
  padding: 60px 0 100px;
  position: relative;
  border-top: 1px solid #DBDBDB;
}
@media screen and (max-width: 600px) {
  .safe {
    padding: 40px 0;
  }
}

.safe_bg {
  position: absolute;
  display: block;
  background-color: #fff;
  bottom: 0;
  right: 0;
  width: 80%;
  height: 80%;
}
@media screen and (max-width: 800px) {
  .safe_bg {
    width: 100%;
    height: calc(100% - 90px);
  }
}

.safe_wrap {
  position: relative;
  z-index: 2;
}

.safe_ttl {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 60px;
}
@media screen and (max-width: 600px) {
  .safe_ttl {
    font-size: 16px;
    margin-bottom: 60px;
  }
}

.safe_list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 60px;
}
@media screen and (max-width: 1400px) {
  .safe_list {
    gap: 40px;
  }
}
@media screen and (max-width: 800px) {
  .safe_list {
    grid-template-columns: 1fr;
  }
}

.safe_item img {
  margin-bottom: 12px;
}
.safe_item h3 {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 16px;
}
@media screen and (max-width: 1400px) {
  .safe_item h3 {
    font-size: 18px;
  }
}
@media screen and (max-width: 600px) {
  .safe_item h3 {
    font-size: 16px;
    margin-bottom: 12px;
  }
}
.safe_item p {
  text-align: justify;
}
@media screen and (max-width: 1400px) {
  .safe_item p {
    font-size: 14px;
  }
}
@media screen and (max-width: 600px) {
  .safe_item p {
    font-size: 13px;
  }
}

/*------------- beauty -------------*/
.beauty {
  padding: 90px 0 280px;
  position: relative;
}
@media screen and (max-width: 600px) {
  .beauty {
    padding: 80px 0 120px;
  }
}

.beauty_bg {
  background-color: #fff;
  width: 80%;
  height: calc(100% - 380px);
  bottom: 160px;
  position: absolute;
}
@media screen and (max-width: 600px) {
  .beauty_bg {
    bottom: 80px;
    width: 100%;
    height: calc(100% - 220px);
  }
}

.beauty_wrap {
  position: relative;
  z-index: 2;
}

.beauty_ttl {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 80px;
}
@media screen and (max-width: 600px) {
  .beauty_ttl {
    font-size: 16px;
    margin-bottom: 60px;
  }
}

@media screen and (max-width: 600px) {
  .beauty_list {
    display: none;
  }
}

.beauty_item {
  display: grid;
  grid-template-columns: 38% 1fr;
  gap: 90px;
  align-items: center;
}
@media screen and (max-width: 1000px) {
  .beauty_item {
    grid-template-columns: 1fr;
    gap: 24px;
  }
}
@media screen and (max-width: 600px) {
  .beauty_item {
    gap: 16px;
  }
}
.beauty_item:not(:last-child) {
  margin-bottom: 40px;
}

@media screen and (max-width: 1000px) {
  .beauty_item_img {
    max-width: 500px;
  }
}

.beauty_item_txt h3 {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 40px;
}
@media screen and (max-width: 1000px) {
  .beauty_item_txt h3 {
    margin-bottom: 20px;
    font-size: 16px;
  }
}
@media screen and (max-width: 600px) {
  .beauty_item_txt h3 {
    margin-bottom: 12px;
  }
}

.beauty_swiper {
  width: 100%;
  overflow: hidden;
  display: none;
}
@media screen and (max-width: 600px) {
  .beauty_swiper {
    display: block;
    padding-bottom: 40px;
  }
}
.beauty_swiper .swiper-pagination-bullet {
  background-color: #E2E2E2 !important;
  opacity: 1 !important;
}
.beauty_swiper .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background-color: #918A84 !important;
}

/*------------- style -------------*/
.style {
  border-top: 1px solid #DBDBDB;
  padding: 80px 0 160px;
}
@media screen and (max-width: 600px) {
  .style {
    padding: 40px 0;
  }
}

.style_ttl {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 60px;
}
@media screen and (max-width: 600px) {
  .style_ttl {
    font-size: 16px;
    margin-bottom: 40px;
  }
}

.style_group:not(:last-child) {
  margin-bottom: 160px;
}
@media screen and (max-width: 600px) {
  .style_group:not(:last-child) {
    margin-bottom: 60px;
  }
}

.style_top {
  display: grid;
  grid-template-columns: 160px 1fr;
  margin-bottom: 60px;
}
@media screen and (max-width: 1000px) {
  .style_top {
    grid-template-columns: 1fr;
    gap: 16px;
    margin-bottom: 32px;
  }
}

.style_top h3 {
  font-size: 24px;
  font-weight: 700;
  margin-top: 4px;
}
@media screen and (max-width: 1000px) {
  .style_top h3 {
    font-size: 20px;
    margin-top: 0;
  }
}

.style_top_txt p:nth-child(1) {
  font-size: 18px;
}
@media screen and (max-width: 600px) {
  .style_top_txt p:nth-child(1) {
    font-size: 15px;
  }
}

.style_top_txt p:nth-child(2) {
  margin-top: 8px;
}
@media screen and (max-width: 600px) {
  .style_top_txt p:nth-child(2) {
    font-size: 12px;
  }
}

.style_list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 60px;
}
@media screen and (max-width: 1000px) {
  .style_list {
    gap: 24px;
  }
}
@media screen and (max-width: 800px) {
  .style_list {
    grid-template-columns: 1fr;
  }
}

@media screen and (max-width: 800px) {
  .style_group:nth-child(1) .style_item {
    display: grid;
    grid-template-columns: 38% 1fr;
    gap: 16px;
    align-items: center;
  }
}

@media screen and (max-width: 800px) {
  .style_group:nth-child(2) .style_item img {
    aspect-ratio: 35/22;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

.style_item img {
  margin-bottom: 16px;
}

.style_item h4 {
  margin-bottom: 16px;
  font-size: 18px;
  font-weight: 700;
}
@media screen and (max-width: 1000px) {
  .style_item h4 {
    font-size: 16px;
  }
}
@media screen and (max-width: 600px) {
  .style_item h4 {
    font-size: 14px;
    margin-bottom: 8px;
  }
}

@media screen and (max-width: 600px) {
  .style_item p {
    font-size: 12px;
  }
}

/*------------- option -------------*/
.option {
  padding: 180px 0;
}
@media screen and (max-width: 600px) {
  .option {
    padding: 40px 0 80px;
  }
}

.option_ttl {
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 60px;
}
@media screen and (max-width: 1000px) {
  .option_ttl {
    font-size: 20px;
  }
}
@media screen and (max-width: 600px) {
  .option_ttl {
    margin-bottom: 24px;
  }
}

.option_item img {
  margin-bottom: 16px;
}

.option_item h3 {
  font-weight: 700;
  font-size: 18px;
  margin-bottom: 8px;
}
@media screen and (max-width: 1400px) {
  .option_item h3 {
    font-size: 16px;
  }
}

@media screen and (max-width: 1400px) {
  .option_item p {
    font-size: 14px;
  }
}

.option_swiper {
  position: relative;
}

.option_swiper .swiper-button-next,
.option_swiper .swiper-button-prev {
  color: #fff !important;
  transition: all 0.5s ease;
}
@media screen and (max-width: 600px) {
  .option_swiper .swiper-button-next,
  .option_swiper .swiper-button-prev {
    display: none;
  }
}
.option_swiper .swiper-button-next:hover,
.option_swiper .swiper-button-prev:hover {
  opacity: 0.6;
}

/*------------- rule -------------*/
/*------------- rule -------------*/
/*------------- rule -------------*/
/* mediaquery
----------------------------------------------------------------- */
.pc_LL_display {
  display: none;
}
@media screen and (max-width: 1600px) {
  .pc_LL_display {
    display: block;
  }
}

.pc_L_display {
  display: none;
}
@media screen and (max-width: 1400px) {
  .pc_L_display {
    display: block;
  }
}

.pc_M_display {
  display: none;
}
@media screen and (max-width: 1200px) {
  .pc_M_display {
    display: block;
  }
}

.pc_S_display {
  display: none;
}
@media screen and (max-width: 1000px) {
  .pc_S_display {
    display: block;
  }
}

.tab_display {
  display: none;
}
@media screen and (max-width: 800px) {
  .tab_display {
    display: block;
  }
}

.sp_LL_display {
  display: none;
}
@media screen and (max-width: 600px) {
  .sp_LL_display {
    display: block;
  }
}

.sp_L_display {
  display: none;
}
@media screen and (max-width: 430px) {
  .sp_L_display {
    display: block;
  }
}

.sp_ML_display {
  display: none;
}
@media screen and (max-width: 400px) {
  .sp_ML_display {
    display: block;
  }
}

.sp_M_display {
  display: none;
}
@media screen and (max-width: 375px) {
  .sp_M_display {
    display: block;
  }
}

.sp_S_display {
  display: none;
}
@media screen and (max-width: 350px) {
  .sp_S_display {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .sp_LL_hidden {
    display: none;
  }
}

@font-face {
  font-family: "Charter";
  src: url("font/charter-roman.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
.basia_top {
  padding: 150px 0;
  background-image: url(../images/basia/basia_top.webp);
  background-size: cover;
  background-position: right;
}
@media screen and (max-width: 1400px) {
  .basia_top {
    padding: 120px 0;
  }
}
@media screen and (max-width: 800px) {
  .basia_top {
    padding: 120px 0 460px;
    background-image: url(../images/basia/basia_top_sp.webp);
    background-position: bottom;
  }
}
@media screen and (max-width: 600px) {
  .basia_top {
    padding: 32px 0 264px;
  }
}

.basia_top_txt p {
  width: 480px;
  text-align: justify;
}
@media screen and (max-width: 1400px) {
  .basia_top_txt p {
    width: 420px;
  }
}
@media screen and (max-width: 800px) {
  .basia_top_txt p {
    width: 100%;
  }
}
@media screen and (max-width: 600px) {
  .basia_top_txt p {
    font-size: 12px;
  }
}

/* mediaquery
----------------------------------------------------------------- */
.pc_LL_display {
  display: none;
}
@media screen and (max-width: 1600px) {
  .pc_LL_display {
    display: block;
  }
}

.pc_L_display {
  display: none;
}
@media screen and (max-width: 1400px) {
  .pc_L_display {
    display: block;
  }
}

.pc_M_display {
  display: none;
}
@media screen and (max-width: 1200px) {
  .pc_M_display {
    display: block;
  }
}

.pc_S_display {
  display: none;
}
@media screen and (max-width: 1000px) {
  .pc_S_display {
    display: block;
  }
}

.tab_display {
  display: none;
}
@media screen and (max-width: 800px) {
  .tab_display {
    display: block;
  }
}

.sp_LL_display {
  display: none;
}
@media screen and (max-width: 600px) {
  .sp_LL_display {
    display: block;
  }
}

.sp_L_display {
  display: none;
}
@media screen and (max-width: 430px) {
  .sp_L_display {
    display: block;
  }
}

.sp_ML_display {
  display: none;
}
@media screen and (max-width: 400px) {
  .sp_ML_display {
    display: block;
  }
}

.sp_M_display {
  display: none;
}
@media screen and (max-width: 375px) {
  .sp_M_display {
    display: block;
  }
}

.sp_S_display {
  display: none;
}
@media screen and (max-width: 350px) {
  .sp_S_display {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .sp_LL_hidden {
    display: none;
  }
}

@font-face {
  font-family: "Charter";
  src: url("font/charter-roman.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
.glamp_top {
  padding: 120px 0 120px;
}
@media screen and (max-width: 600px) {
  .glamp_top {
    padding: 32px 0 40px;
  }
}

.glamp_top_txt h2 {
  font-size: 22px;
  text-align: center;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 76px;
  line-height: 2.5;
}
@media screen and (max-width: 1000px) {
  .glamp_top_txt h2 {
    font-size: 18px;
  }
}
@media screen and (max-width: 600px) {
  .glamp_top_txt h2 {
    font-size: 16px;
    margin: 0 auto 32px;
  }
}

.glamp_top_txt p {
  text-align: center;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 140px;
}
@media screen and (max-width: 600px) {
  .glamp_top_txt p {
    margin: 0 auto 60px;
    text-align: left;
  }
}

.glamp_top_img {
  width: 90%;
}
@media screen and (max-width: 600px) {
  .glamp_top_img {
    width: 96%;
  }
}

.glamp_top_img_pc {
  display: block;
}
@media screen and (max-width: 600px) {
  .glamp_top_img_pc {
    display: none;
  }
}

.glamp_top_img_sp {
  display: none;
}
@media screen and (max-width: 600px) {
  .glamp_top_img_sp {
    display: block;
  }
}

/*------------- home -------------*/
.home {
  padding: 90px 0 280px;
  position: relative;
}
@media screen and (max-width: 600px) {
  .home {
    padding: 40px 0 80px;
  }
}

.home_bg {
  background-color: #fff;
  width: 80%;
  height: calc(100% - 380px);
  bottom: 160px;
  position: absolute;
}
@media screen and (max-width: 600px) {
  .home_bg {
    bottom: 0;
    width: 100%;
    height: calc(100% - 160px);
  }
}

.home_wrap {
  position: relative;
  z-index: 2;
}

.home_ttl {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 80px;
}
@media screen and (max-width: 800px) {
  .home_ttl {
    line-height: 2;
  }
}
@media screen and (max-width: 600px) {
  .home_ttl {
    font-size: 16px;
    margin-bottom: 60px;
  }
}

.home_item {
  display: grid;
  grid-template-columns: 38% 1fr;
  gap: 90px;
  align-items: center;
}
@media screen and (max-width: 1000px) {
  .home_item {
    grid-template-columns: 1fr;
    gap: 24px;
  }
}
@media screen and (max-width: 600px) {
  .home_item {
    gap: 16px;
  }
}
.home_item:not(:last-child) {
  margin-bottom: 40px;
}

@media screen and (max-width: 1000px) {
  .home_item_img {
    max-width: 500px;
  }
}

.home_item_txt h3 {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 40px;
}
@media screen and (max-width: 1000px) {
  .home_item_txt h3 {
    margin-bottom: 20px;
    font-size: 16px;
  }
}
@media screen and (max-width: 600px) {
  .home_item_txt h3 {
    margin-bottom: 12px;
  }
}

.photo {
  padding-bottom: 200px;
  width: 80%;
  margin: 0 auto;
  max-width: 1200px;
}
@media screen and (max-width: 1200px) {
  .photo {
    width: 90%;
  }
}
@media screen and (max-width: 600px) {
  .photo {
    width: 100%;
    padding-bottom: 60px;
  }
}

/* mediaquery
----------------------------------------------------------------- */
.pc_LL_display {
  display: none;
}
@media screen and (max-width: 1600px) {
  .pc_LL_display {
    display: block;
  }
}

.pc_L_display {
  display: none;
}
@media screen and (max-width: 1400px) {
  .pc_L_display {
    display: block;
  }
}

.pc_M_display {
  display: none;
}
@media screen and (max-width: 1200px) {
  .pc_M_display {
    display: block;
  }
}

.pc_S_display {
  display: none;
}
@media screen and (max-width: 1000px) {
  .pc_S_display {
    display: block;
  }
}

.tab_display {
  display: none;
}
@media screen and (max-width: 800px) {
  .tab_display {
    display: block;
  }
}

.sp_LL_display {
  display: none;
}
@media screen and (max-width: 600px) {
  .sp_LL_display {
    display: block;
  }
}

.sp_L_display {
  display: none;
}
@media screen and (max-width: 430px) {
  .sp_L_display {
    display: block;
  }
}

.sp_ML_display {
  display: none;
}
@media screen and (max-width: 400px) {
  .sp_ML_display {
    display: block;
  }
}

.sp_M_display {
  display: none;
}
@media screen and (max-width: 375px) {
  .sp_M_display {
    display: block;
  }
}

.sp_S_display {
  display: none;
}
@media screen and (max-width: 350px) {
  .sp_S_display {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .sp_LL_hidden {
    display: none;
  }
}

@font-face {
  font-family: "Charter";
  src: url("font/charter-roman.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
.company h3 {
  font-size: 20px;
  font-weight: 700;
}
@media screen and (max-width: 600px) {
  .company h3 {
    font-size: 18px;
  }
}

.message {
  padding-top: 60px;
  padding-bottom: 140px;
}
@media screen and (max-width: 600px) {
  .message {
    padding-top: 24px;
    padding-bottom: 80px;
  }
}

.message_wrap {
  display: grid;
  grid-template-columns: 220px 1fr;
}
@media screen and (max-width: 1200px) {
  .message_wrap {
    grid-template-columns: 160px 1fr;
  }
}
@media screen and (max-width: 1000px) {
  .message_wrap {
    gap: 40px;
    grid-template-columns: 1fr;
  }
}
@media screen and (max-width: 600px) {
  .message_wrap {
    gap: 24px;
  }
}

.message_top {
  display: grid;
  grid-template-columns: 40% 1fr;
  align-items: center;
  gap: 40px;
  margin-bottom: 40px;
}
@media screen and (max-width: 800px) {
  .message_top {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}
@media screen and (max-width: 600px) {
  .message_top {
    margin-bottom: 20px;
  }
}

@media screen and (max-width: 800px) {
  .message_top img {
    max-width: 220px;
  }
}

.message_top_txt p {
  margin-bottom: 24px;
}
@media screen and (max-width: 1000px) {
  .message_top_txt p {
    margin-bottom: 10px;
  }
}

.message_top_txt span {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
}
@media screen and (max-width: 1000px) {
  .message_top_txt span {
    font-size: 14px;
  }
}

.message_bottom {
  background-color: #fff;
  padding: 32px 40px;
}
@media screen and (max-width: 800px) {
  .message_bottom {
    padding: 24px 16px;
  }
}

.message_bottom_item:not(:last-child) {
  margin-bottom: 24px;
}

.message_bottom_item h4 {
  font-size: 18px;
  margin-bottom: 6px;
}
@media screen and (max-width: 1000px) {
  .message_bottom_item h4 {
    font-size: 16px;
  }
}

.overview {
  border-top: 1px solid #DBDBDB;
  padding: 48px 0 180px;
}
@media screen and (max-width: 600px) {
  .overview {
    padding: 40px 0 80px;
  }
}

.overview_wrap {
  display: grid;
  grid-template-columns: 320px 1fr;
}
@media screen and (max-width: 1400px) {
  .overview_wrap {
    grid-template-columns: 200px 1fr;
  }
}
@media screen and (max-width: 1200px) {
  .overview_wrap {
    grid-template-columns: 1fr;
    gap: 40px;
  }
}
@media screen and (max-width: 600px) {
  .overview_wrap {
    gap: 24px;
  }
}

.overview_item {
  display: grid;
  grid-template-columns: 120px 1fr;
  line-height: 2.2;
}
@media screen and (max-width: 1000px) {
  .overview_item {
    font-size: 14px;
  }
}
@media screen and (max-width: 600px) {
  .overview_item {
    font-size: 13px;
    grid-template-columns: 64px 1fr;
  }
}
.overview_item:not(:last-child) {
  margin-bottom: 16px;
}
@media screen and (max-width: 600px) {
  .overview_item:not(:last-child) {
    margin-bottom: 8px;
  }
}
@media screen and (max-width: 800px) {
  .overview_item br {
    display: none;
  }
}

.overview_item span {
  display: block;
}

.access {
  border-top: 1px solid #DBDBDB;
  padding: 60px 0 180px;
}
@media screen and (max-width: 600px) {
  .access {
    padding: 40px 0 80px;
  }
}

.access h3 {
  margin-bottom: 72px;
}
@media screen and (max-width: 600px) {
  .access h3 {
    margin-bottom: 40px;
  }
}

.access_list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 60px;
  margin-bottom: 100px;
}
@media screen and (max-width: 1400px) {
  .access_list {
    gap: 40px;
  }
}
@media screen and (max-width: 1000px) {
  .access_list {
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (max-width: 600px) {
  .access_list {
    grid-template-columns: 1fr;
    gap: 16px;
    margin-bottom: 40px;
  }
}

.access_item img {
  margin-bottom: 16px;
}

.access_item h4 {
  line-height: 2;
  margin-bottom: 4px;
}
@media screen and (max-width: 800px) {
  .access_item h4 {
    font-size: 13px;
  }
}
@media screen and (max-width: 600px) {
  .access_item h4 {
    line-height: 1.5;
  }
}

.access_item p {
  font-size: 14px;
}
@media screen and (max-width: 800px) {
  .access_item p {
    font-size: 12px;
  }
}
@media screen and (max-width: 600px) {
  .access_item p {
    font-size: 11px;
    line-height: 1.8;
  }
}

.access_map {
  height: 600px;
}
@media screen and (max-width: 600px) {
  .access_map {
    height: 420px;
  }
}
.access_map iframe {
  width: 100%;
  height: 100%;
}

.history {
  border-top: 1px solid #DBDBDB;
  padding: 60px 0 180px;
}
@media screen and (max-width: 600px) {
  .history {
    padding: 40px 0 80px;
  }
}

.history_wrap {
  display: grid;
  grid-template-columns: 320px 1fr;
}
@media screen and (max-width: 1400px) {
  .history_wrap {
    grid-template-columns: 200px 1fr;
  }
}
@media screen and (max-width: 1200px) {
  .history_wrap {
    grid-template-columns: 1fr;
    gap: 40px;
  }
}
@media screen and (max-width: 600px) {
  .history_wrap {
    gap: 24px;
  }
}

.history_list {
  position: relative;
}
.history_list::after {
  content: "";
  width: 2px;
  height: calc(100% - 24px);
  background-color: #DBDBDB;
  position: absolute;
  top: 12px;
  left: 104px;
}
@media screen and (max-width: 600px) {
  .history_list::after {
    left: 76.5px;
    width: 1px;
  }
}

.history_item {
  display: grid;
  grid-template-columns: 100px 40px 1fr;
  line-height: 2;
}
@media screen and (max-width: 1000px) {
  .history_item {
    font-size: 14px;
  }
}
@media screen and (max-width: 600px) {
  .history_item {
    font-size: 12px;
    grid-template-columns: 72px 20px 1fr;
  }
}
.history_item:not(:last-child) {
  margin-bottom: 16px;
}
@media screen and (max-width: 600px) {
  .history_item:not(:last-child) {
    margin-bottom: 10px;
  }
}

.history_item_circle {
  display: block;
  width: 10px;
  height: 10px;
  background-color: #333;
  border-radius: 50%;
  margin-top: 11px;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 600px) {
  .history_item_circle {
    margin-top: 7px;
  }
}

/* mediaquery
----------------------------------------------------------------- */
.pc_LL_display {
  display: none;
}
@media screen and (max-width: 1600px) {
  .pc_LL_display {
    display: block;
  }
}

.pc_L_display {
  display: none;
}
@media screen and (max-width: 1400px) {
  .pc_L_display {
    display: block;
  }
}

.pc_M_display {
  display: none;
}
@media screen and (max-width: 1200px) {
  .pc_M_display {
    display: block;
  }
}

.pc_S_display {
  display: none;
}
@media screen and (max-width: 1000px) {
  .pc_S_display {
    display: block;
  }
}

.tab_display {
  display: none;
}
@media screen and (max-width: 800px) {
  .tab_display {
    display: block;
  }
}

.sp_LL_display {
  display: none;
}
@media screen and (max-width: 600px) {
  .sp_LL_display {
    display: block;
  }
}

.sp_L_display {
  display: none;
}
@media screen and (max-width: 430px) {
  .sp_L_display {
    display: block;
  }
}

.sp_ML_display {
  display: none;
}
@media screen and (max-width: 400px) {
  .sp_ML_display {
    display: block;
  }
}

.sp_M_display {
  display: none;
}
@media screen and (max-width: 375px) {
  .sp_M_display {
    display: block;
  }
}

.sp_S_display {
  display: none;
}
@media screen and (max-width: 350px) {
  .sp_S_display {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .sp_LL_hidden {
    display: none;
  }
}

@font-face {
  font-family: "Charter";
  src: url("font/charter-roman.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
.event {
  padding-bottom: 210px;
}
@media screen and (max-width: 600px) {
  .event {
    padding-bottom: 80px;
  }
}

.event_list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 32px;
  row-gap: 48px;
}
@media screen and (max-width: 1200px) {
  .event_list {
    -moz-column-gap: 16px;
         column-gap: 16px;
  }
}
@media screen and (max-width: 1000px) {
  .event_list {
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (max-width: 600px) {
  .event_list {
    grid-template-columns: 1fr;
    row-gap: 24px;
  }
}

.event_item .event_tag {
  margin-bottom: 12px;
}

.event_item_img {
  aspect-ratio: 3/2;
  -o-object-fit: cover;
     object-fit: cover;
  margin-bottom: 16px;
}
@media screen and (max-width: 600px) {
  .event_item_img {
    margin-bottom: 12px;
  }
}

.event_ttl {
  font-size: 18px;
}
@media screen and (max-width: 600px) {
  .event_ttl {
    font-size: 16px;
  }
}

.event_post .event_tag {
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 40px;
}
@media screen and (max-width: 600px) {
  .event_post .event_tag {
    gap: 10px;
  }
}

.event_post .event_ttl {
  font-size: 22px;
  margin-bottom: 20px;
}
@media screen and (max-width: 1000px) {
  .event_post .event_ttl {
    font-size: 20px;
  }
}
@media screen and (max-width: 600px) {
  .event_post .event_ttl {
    font-size: 18px;
  }
}

.event_content {
  margin-bottom: 120px;
  font-size: 16px;
  line-height: 2.2;
  font-family: "Zen Old Mincho", serif;
  color: #333333;
}
@media screen and (max-width: 1000px) {
  .event_content {
    font-size: 14px;
  }
}
@media screen and (max-width: 600px) {
  .event_content {
    font-size: 13px;
    margin-bottom: 60px;
  }
}
.event_content p:not(:first-child) {
  margin-top: 16px;
}
@media screen and (max-width: 600px) {
  .event_content p:not(:first-child) {
    margin-top: 8px;
  }
}
.event_content pre {
  font-size: 16px;
  line-height: 2.2;
  font-family: "Zen Old Mincho", serif;
  color: #333333;
}
@media screen and (max-width: 1000px) {
  .event_content pre {
    font-size: 14px;
  }
}
@media screen and (max-width: 600px) {
  .event_content pre {
    font-size: 13px;
  }
}
.event_content h1,
.event_content h2,
.event_content h3,
.event_content h4,
.event_content h5,
.event_content h6 {
  font-size: 18px;
  font-weight: 700;
}
@media screen and (max-width: 600px) {
  .event_content h1,
  .event_content h2,
  .event_content h3,
  .event_content h4,
  .event_content h5,
  .event_content h6 {
    font-size: 16px;
  }
}
.event_content h1:not(:first-child),
.event_content h2:not(:first-child),
.event_content h3:not(:first-child),
.event_content h4:not(:first-child),
.event_content h5:not(:first-child),
.event_content h6:not(:first-child) {
  margin-top: 40px;
}
@media screen and (max-width: 600px) {
  .event_content h1:not(:first-child),
  .event_content h2:not(:first-child),
  .event_content h3:not(:first-child),
  .event_content h4:not(:first-child),
  .event_content h5:not(:first-child),
  .event_content h6:not(:first-child) {
    margin-top: 24px;
  }
}
.event_content figure:not(:last-child) {
  margin-top: 16px;
}
@media screen and (max-width: 600px) {
  .event_content figure:not(:last-child) {
    margin-top: 8px;
  }
}

.event_info {
  padding-bottom: 140px;
}
@media screen and (max-width: 600px) {
  .event_info {
    padding-bottom: 80px;
  }
}

.event_info h4 {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 24px;
}
@media screen and (max-width: 1000px) {
  .event_info h4 {
    font-size: 18px;
  }
}
@media screen and (max-width: 600px) {
  .event_info h4 {
    font-size: 16px;
  }
}

.event_info_item {
  display: grid;
  grid-template-columns: 200px 1fr;
  line-height: 1.5;
}
@media screen and (max-width: 1000px) {
  .event_info_item {
    font-size: 14px;
  }
}
@media screen and (max-width: 600px) {
  .event_info_item {
    font-size: 13px;
    grid-template-columns: 100px 1fr;
  }
}
.event_info_item:not(:last-child) {
  margin-bottom: 4px;
}

.event_info_item h5 {
  padding: 24px 32px;
  background-color: #E2E2E2;
  height: 100%;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 600px) {
  .event_info_item h5 {
    padding: 16px 12px;
  }
}

.event_info_item span {
  padding: 24px 32px;
  background-color: #fff;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 600px) {
  .event_info_item span {
    padding: 16px 12px;
  }
}

.event_form {
  border-top: 1px solid #d8d8d8;
  padding-top: 100px;
}
@media screen and (max-width: 600px) {
  .event_form {
    padding-top: 60px;
  }
}
.event_form .contact_wrap {
  margin-bottom: 120px;
}
@media screen and (max-width: 600px) {
  .event_form .contact_wrap {
    margin-bottom: 60px;
  }
}
.event_form .more_btn {
  margin: 0 auto;
}

.event_form_ttl {
  font-size: 28px;
  font-family: "Charter", sans-serif;
  letter-spacing: 0.1em;
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 80px;
}
@media screen and (max-width: 1000px) {
  .event_form_ttl {
    font-size: 24px;
  }
}
@media screen and (max-width: 600px) {
  .event_form_ttl {
    font-size: 20px;
    margin: 0 auto 48px;
  }
}

.event_content_img {
  margin-bottom: 40px;
}
.event_content_img img {
  height: -moz-fit-content;
  height: fit-content;
  width: 100%;
}

/* mediaquery
----------------------------------------------------------------- */
.pc_LL_display {
  display: none;
}
@media screen and (max-width: 1600px) {
  .pc_LL_display {
    display: block;
  }
}

.pc_L_display {
  display: none;
}
@media screen and (max-width: 1400px) {
  .pc_L_display {
    display: block;
  }
}

.pc_M_display {
  display: none;
}
@media screen and (max-width: 1200px) {
  .pc_M_display {
    display: block;
  }
}

.pc_S_display {
  display: none;
}
@media screen and (max-width: 1000px) {
  .pc_S_display {
    display: block;
  }
}

.tab_display {
  display: none;
}
@media screen and (max-width: 800px) {
  .tab_display {
    display: block;
  }
}

.sp_LL_display {
  display: none;
}
@media screen and (max-width: 600px) {
  .sp_LL_display {
    display: block;
  }
}

.sp_L_display {
  display: none;
}
@media screen and (max-width: 430px) {
  .sp_L_display {
    display: block;
  }
}

.sp_ML_display {
  display: none;
}
@media screen and (max-width: 400px) {
  .sp_ML_display {
    display: block;
  }
}

.sp_M_display {
  display: none;
}
@media screen and (max-width: 375px) {
  .sp_M_display {
    display: block;
  }
}

.sp_S_display {
  display: none;
}
@media screen and (max-width: 350px) {
  .sp_S_display {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .sp_LL_hidden {
    display: none;
  }
}

@font-face {
  font-family: "Charter";
  src: url("font/charter-roman.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
.works {
  padding-bottom: 210px;
}
@media screen and (max-width: 600px) {
  .works {
    padding-bottom: 90px;
  }
}

.works_list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 32px;
  row-gap: 48px;
}
@media screen and (max-width: 1200px) {
  .works_list {
    -moz-column-gap: 16px;
         column-gap: 16px;
  }
}
@media screen and (max-width: 1000px) {
  .works_list {
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (max-width: 600px) {
  .works_list {
    grid-template-columns: 1fr;
    row-gap: 24px;
  }
}

.works_item .event_tag {
  margin-bottom: 12px;
}

.works_item_img {
  aspect-ratio: 3/2;
  -o-object-fit: cover;
     object-fit: cover;
  margin-bottom: 16px;
}
@media screen and (max-width: 600px) {
  .works_item_img {
    margin-bottom: 12px;
  }
}

.works_ttl {
  font-size: 18px;
}
@media screen and (max-width: 600px) {
  .works_ttl {
    font-size: 16px;
  }
}

.works_top {
  height: 90vh;
  width: 100%;
  overflow: hidden;
  position: relative;
}

.works_top_bg {
  position: absolute;
  width: 100%;
  height: 90vh;
  top: 0;
  left: 0;
}
.works_top_bg::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 1;
  background-color: rgba(0, 0, 0, 0.3);
}
.works_top_bg img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

.works_top_txt {
  position: absolute;
  z-index: 5;
  bottom: 40px;
  left: 40px;
  color: #fff;
}
@media screen and (max-width: 600px) {
  .works_top_txt {
    left: 20px;
  }
}

.works_top_txt .works_date {
  font-size: 16px;
  margin-bottom: 16px;
}
@media screen and (max-width: 600px) {
  .works_top_txt .works_date {
    font-size: 12px;
    margin-bottom: 8px;
  }
}

.works_top_txt .works_tag {
  margin-bottom: 24px;
}
@media screen and (max-width: 600px) {
  .works_top_txt .works_tag {
    margin-bottom: 16px;
  }
}

.works_top_txt .works_ttl {
  font-size: 32px;
}
@media screen and (max-width: 600px) {
  .works_top_txt .works_ttl {
    font-size: 24px;
  }
}

.works_content {
  padding: 54px 0 80px;
}
@media screen and (max-width: 600px) {
  .works_content {
    padding: 32px 0 40px;
  }
}

.works_content {
  font-size: 16px;
  line-height: 2.2;
  font-family: "Zen Old Mincho", serif;
  color: #333333;
}
@media screen and (max-width: 1000px) {
  .works_content {
    font-size: 14px;
  }
}
@media screen and (max-width: 600px) {
  .works_content {
    font-size: 13px;
    margin-bottom: 60px;
  }
}
.works_content p:not(:first-child) {
  margin-top: 16px;
}
@media screen and (max-width: 600px) {
  .works_content p:not(:first-child) {
    margin-top: 8px;
  }
}
.works_content pre {
  font-size: 16px;
  line-height: 2.2;
  font-family: "Zen Old Mincho", serif;
  color: #333333;
}
@media screen and (max-width: 1000px) {
  .works_content pre {
    font-size: 14px;
  }
}
@media screen and (max-width: 600px) {
  .works_content pre {
    font-size: 13px;
  }
}
.works_content h1,
.works_content h2,
.works_content h3,
.works_content h4,
.works_content h5,
.works_content h6 {
  font-size: 18px;
  font-weight: 700;
}
@media screen and (max-width: 600px) {
  .works_content h1,
  .works_content h2,
  .works_content h3,
  .works_content h4,
  .works_content h5,
  .works_content h6 {
    font-size: 16px;
  }
}
.works_content h1:not(:first-child),
.works_content h2:not(:first-child),
.works_content h3:not(:first-child),
.works_content h4:not(:first-child),
.works_content h5:not(:first-child),
.works_content h6:not(:first-child) {
  margin-top: 40px;
}
@media screen and (max-width: 600px) {
  .works_content h1:not(:first-child),
  .works_content h2:not(:first-child),
  .works_content h3:not(:first-child),
  .works_content h4:not(:first-child),
  .works_content h5:not(:first-child),
  .works_content h6:not(:first-child) {
    margin-top: 24px;
  }
}
.works_content figure:not(:last-child) {
  margin-top: 16px;
}
@media screen and (max-width: 600px) {
  .works_content figure:not(:last-child) {
    margin-top: 8px;
  }
}

.works_photo {
  padding-bottom: 200px;
}
@media screen and (max-width: 600px) {
  .works_photo {
    padding-bottom: 90px;
  }
}

.works_photo_heading {
  font-size: 20px;
  margin-bottom: 24px;
  font-weight: 700;
}
@media screen and (max-width: 600px) {
  .works_photo_heading {
    font-size: 18px;
    margin-bottom: 16px;
  }
}

.slider-for img {
  aspect-ratio: 10/6;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  margin-bottom: 16px;
}
@media screen and (max-width: 600px) {
  .slider-for img {
    margin-bottom: 12px;
  }
}

.slick-dots {
  bottom: -246px !important;
}
@media screen and (max-width: 1400px) {
  .slick-dots {
    bottom: calc(-15px - 17vw) !important;
  }
}
@media screen and (max-width: 1200px) {
  .slick-dots {
    bottom: calc(-20px - 18vw) !important;
  }
}
@media screen and (max-width: 1000px) {
  .slick-dots {
    bottom: calc(-20px - 19vw) !important;
  }
}
@media screen and (max-width: 800px) {
  .slick-dots {
    bottom: calc(-15px - 21vw) !important;
  }
}
@media screen and (max-width: 600px) {
  .slick-dots {
    bottom: calc(-20px - 29vw) !important;
  }
}

.slider-nav img {
  aspect-ratio: 10/8;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

@media screen and (max-width: 600px) {
  .slick-dotted.slick-slider {
    margin-bottom: 16px !important;
  }
}

.slick-dots li {
  margin: 0 !important;
}
.slick-dots button::before {
  color: #E2E2E2 !important;
  opacity: 1 !important;
  font-size: 12px !important;
}
@media screen and (max-width: 600px) {
  .slick-dots button::before {
    font-size: 8px !important;
  }
}
.slick-dots .slick-active button::before {
  color: #918A84 !important;
}

.slider-nav .slick-slide {
  margin-right: 12px;
}
@media screen and (max-width: 600px) {
  .slider-nav .slick-slide {
    margin-right: 8px;
  }
}

.slider-nav .slick-list {
  margin-right: -12px;
}
@media screen and (max-width: 600px) {
  .slider-nav .slick-list {
    margin-right: -8px;
  }
}

.works_bottom {
  padding-bottom: 120px;
}
@media screen and (max-width: 600px) {
  .works_bottom {
    padding-bottom: 60px;
  }
}

.works_table:not(:first-child) {
  margin-top: 120px;
}
@media screen and (max-width: 600px) {
  .works_table:not(:first-child) {
    margin-top: 40px;
  }
}

.works_table h3 {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 24px;
}
@media screen and (max-width: 600px) {
  .works_table h3 {
    font-size: 16px;
    margin-bottom: 16px;
  }
}

.works_table_item {
  display: grid;
  grid-template-columns: 200px 1fr;
  min-height: 70px;
}
@media screen and (max-width: 1000px) {
  .works_table_item {
    font-size: 14px;
  }
}
@media screen and (max-width: 600px) {
  .works_table_item {
    font-size: 13px;
    grid-template-columns: 1fr;
  }
}
.works_table_item:not(:last-child) {
  margin-bottom: 4px;
}

.works_table_item h4 {
  padding: 24px 32px;
  background-color: #E2E2E2;
  height: 100%;
  display: flex;
  align-items: center;
  line-height: 1.8;
}
@media screen and (max-width: 600px) {
  .works_table_item h4 {
    padding: 14px 16px;
  }
}

.works_table_item p {
  padding: 24px 32px;
  background-color: #fff;
  height: 100%;
  display: flex;
  align-items: center;
  line-height: 1.8;
}
@media screen and (max-width: 600px) {
  .works_table_item p {
    padding: 14px 16px;
  }
}

.works_post .more_btn {
  margin: 0 auto;
}

/* mediaquery
----------------------------------------------------------------- */
.pc_LL_display {
  display: none;
}
@media screen and (max-width: 1600px) {
  .pc_LL_display {
    display: block;
  }
}

.pc_L_display {
  display: none;
}
@media screen and (max-width: 1400px) {
  .pc_L_display {
    display: block;
  }
}

.pc_M_display {
  display: none;
}
@media screen and (max-width: 1200px) {
  .pc_M_display {
    display: block;
  }
}

.pc_S_display {
  display: none;
}
@media screen and (max-width: 1000px) {
  .pc_S_display {
    display: block;
  }
}

.tab_display {
  display: none;
}
@media screen and (max-width: 800px) {
  .tab_display {
    display: block;
  }
}

.sp_LL_display {
  display: none;
}
@media screen and (max-width: 600px) {
  .sp_LL_display {
    display: block;
  }
}

.sp_L_display {
  display: none;
}
@media screen and (max-width: 430px) {
  .sp_L_display {
    display: block;
  }
}

.sp_ML_display {
  display: none;
}
@media screen and (max-width: 400px) {
  .sp_ML_display {
    display: block;
  }
}

.sp_M_display {
  display: none;
}
@media screen and (max-width: 375px) {
  .sp_M_display {
    display: block;
  }
}

.sp_S_display {
  display: none;
}
@media screen and (max-width: 350px) {
  .sp_S_display {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .sp_LL_hidden {
    display: none;
  }
}

@font-face {
  font-family: "Charter";
  src: url("font/charter-roman.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
.contact {
  padding-bottom: 160px;
}
@media screen and (max-width: 600px) {
  .contact {
    padding-bottom: 80px;
  }
}

.contact_txt {
  margin-bottom: 48px;
}
@media screen and (max-width: 600px) {
  .contact_txt {
    margin-bottom: 32px;
  }
}

.contact_list {
  margin-bottom: 60px;
}
@media screen and (max-width: 600px) {
  .contact_list {
    margin-bottom: 40px;
  }
}

.contact_item {
  display: grid;
  grid-template-columns: 250px 1fr;
}
@media screen and (max-width: 1000px) {
  .contact_item {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}
.contact_item:not(:last-child) {
  margin-bottom: 32px;
}
@media screen and (max-width: 600px) {
  .contact_item:not(:last-child) {
    margin-bottom: 20px;
  }
}

.contact .contact_item-first {
  margin-bottom: 32px;
}
@media screen and (max-width: 600px) {
  .contact .contact_item-first {
    margin-bottom: 20px;
  }
}

.contact_ttl {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 6px;
}

.contact_ttl h3 {
  font-size: 16px;
}
@media screen and (max-width: 600px) {
  .contact_ttl h3 {
    font-size: 15px;
  }
}

.contact_ttl span {
  color: #fff;
  background-color: #333333;
  font-family: "Noto Sans JP", sans-serif;
  padding: 4px 6px;
  width: -moz-fit-content;
  width: fit-content;
  display: block;
  font-size: 11px;
}
@media screen and (max-width: 600px) {
  .contact_ttl span {
    font-size: 10px;
    padding: 3px 6px;
  }
}

.contact_input.contact_input_date {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 24px;
}
@media screen and (max-width: 600px) {
  .contact_input.contact_input_date {
    gap: 8px;
  }
}
.contact_input.contact_input_date .contact_select {
  max-width: calc((100% - 24px) / 2);
}
@media screen and (max-width: 600px) {
  .contact_input.contact_input_date .contact_select {
    max-width: calc((100% - 8px) / 2);
  }
}

.contact_input input,
.contact_input textarea,
.contact_input select {
  display: block;
  background-color: #fff;
  padding: 24px 32px;
  width: 100%;
  line-height: 1.4;
}
@media screen and (max-width: 600px) {
  .contact_input input,
  .contact_input textarea,
  .contact_input select {
    padding: 16px 16px;
    font-size: 15px;
  }
}
.contact_input input::-moz-placeholder, .contact_input textarea::-moz-placeholder, .contact_input select::-moz-placeholder {
  color: #C3C3C3;
}
.contact_input input::placeholder,
.contact_input textarea::placeholder,
.contact_input select::placeholder {
  color: #C3C3C3;
}

.contact_select {
  width: 320px;
  position: relative;
}
@media screen and (max-width: 600px) {
  .contact_select {
    width: 100%;
  }
}
.contact_select::after {
  content: "";
  width: 16px;
  height: 10px;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  background-color: #EEEEEE;
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
}
@media screen and (max-width: 600px) {
  .contact_select::after {
    width: 12px;
    height: 8px;
    right: 12px;
  }
}

.contact_input-sm input {
  width: 220px;
}
@media screen and (max-width: 600px) {
  .contact_input-sm input {
    width: 180px;
  }
}

.contact_privacy {
  width: -moz-fit-content;
  width: fit-content;
  text-align: center;
  margin: 0 auto 40px;
}

.contact_privacy a {
  display: inline-block;
  position: relative;
}
.contact_privacy a::after {
  content: "";
  width: 100%;
  height: 1px;
  background-color: #333;
  bottom: 4px;
  left: 0;
  position: absolute;
}
.contact_privacy a:hover {
  opacity: 0.6;
}

.contact_submit {
  color: #fff;
  font-size: 18px;
  padding: 20px 80px;
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  background-color: #333333;
  transition: all 0.4s;
  border: 1px solid #333;
}
@media screen and (max-width: 600px) {
  .contact_submit {
    font-size: 16px;
  }
}
@media screen and (max-width: 375px) {
  .contact_submit {
    padding: 20px 60px;
  }
}
.contact_submit:hover {
  background-color: #fff;
  color: #333333;
}

.contact_toggle {
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 80px;
}
@media screen and (max-width: 600px) {
  .contact_toggle {
    width: 100%;
    margin: 0 auto 40px;
  }
}

.contact .wpcf7-form input[type=radio] {
  display: none;
}

.wpcf7-list-item.first .wpcf7-list-item-label {
  border-right: none;
}

.contact .wpcf7-list-item-label {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px 0;
  border: 1px solid #707070;
  width: 200px;
  background: #DBDBDB;
  color: #333;
  cursor: pointer;
  font-family: "Noto Sans JP", sans-serif;
}
@media screen and (max-width: 600px) {
  .contact .wpcf7-list-item-label {
    width: 100%;
    font-size: 14px;
  }
}

.wpcf7-form-control.wpcf7-radio {
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 600px) {
  .wpcf7-form-control.wpcf7-radio {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
}

.contact .wpcf7-form input[type=radio]:checked + span {
  background: #fff;
}

.wpcf7-list-item {
  margin: 0 !important;
}

/* mediaquery
----------------------------------------------------------------- */
.pc_LL_display {
  display: none;
}
@media screen and (max-width: 1600px) {
  .pc_LL_display {
    display: block;
  }
}

.pc_L_display {
  display: none;
}
@media screen and (max-width: 1400px) {
  .pc_L_display {
    display: block;
  }
}

.pc_M_display {
  display: none;
}
@media screen and (max-width: 1200px) {
  .pc_M_display {
    display: block;
  }
}

.pc_S_display {
  display: none;
}
@media screen and (max-width: 1000px) {
  .pc_S_display {
    display: block;
  }
}

.tab_display {
  display: none;
}
@media screen and (max-width: 800px) {
  .tab_display {
    display: block;
  }
}

.sp_LL_display {
  display: none;
}
@media screen and (max-width: 600px) {
  .sp_LL_display {
    display: block;
  }
}

.sp_L_display {
  display: none;
}
@media screen and (max-width: 430px) {
  .sp_L_display {
    display: block;
  }
}

.sp_ML_display {
  display: none;
}
@media screen and (max-width: 400px) {
  .sp_ML_display {
    display: block;
  }
}

.sp_M_display {
  display: none;
}
@media screen and (max-width: 375px) {
  .sp_M_display {
    display: block;
  }
}

.sp_S_display {
  display: none;
}
@media screen and (max-width: 350px) {
  .sp_S_display {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .sp_LL_hidden {
    display: none;
  }
}

@font-face {
  font-family: "Charter";
  src: url("font/charter-roman.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
.spec_top {
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  padding-bottom: 90px;
  max-width: 90%;
}
@media screen and (max-width: 600px) {
  .spec_top {
    padding-bottom: 60px;
  }
}
.spec_top h3 {
  font-size: 24px;
  line-height: 2;
  margin-bottom: 40px;
}
@media screen and (max-width: 600px) {
  .spec_top h3 {
    margin-bottom: 24px;
  }
}
.spec_top p {
  font-size: 14px;
}
@media screen and (max-width: 600px) {
  .spec_top p {
    line-height: 2.6;
  }
}

.spec_inner {
  display: grid;
  grid-template-columns: 240px 1fr;
  position: relative;
}
@media screen and (max-width: 1200px) {
  .spec_inner {
    grid-template-columns: 180px 1fr;
  }
}
@media screen and (max-width: 1000px) {
  .spec_inner {
    grid-template-columns: 1fr;
  }
}
.spec_inner::after {
  content: "";
  position: absolute;
  height: calc(100% - 20px);
  width: 40px;
  top: 0;
  right: 0;
  background-color: #fff;
  z-index: 2;
}
@media screen and (max-width: 1000px) {
  .spec_inner::after {
    height: calc(100% - 160px);
    top: 120px;
  }
}
@media screen and (max-width: 600px) {
  .spec_inner::after {
    width: 12px;
  }
}

.spec_inner h4 {
  font-size: 18px;
  font-weight: 500;
  display: block;
}
@media screen and (max-width: 1000px) {
  .spec_inner h4 {
    margin-bottom: 24px;
  }
}

.spec_content {
  border-top: 1px solid #DBDBDB;
  padding: 60px 0 120px;
}
@media screen and (max-width: 600px) {
  .spec_content {
    padding: 40px 0 80px;
  }
}

.spec_note {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  font-size: 14px;
  margin-bottom: 24px;
}
@media screen and (max-width: 1000px) {
  .spec_note {
    font-size: 12px;
  }
}
@media screen and (max-width: 800px) {
  .spec_note {
    font-size: 10px;
  }
}

@media screen and (max-width: 1000px) {
  .spec_note-pc {
    display: none;
  }
}

.spec_note-sp {
  display: none;
}
@media screen and (max-width: 1000px) {
  .spec_note-sp {
    display: block;
  }
}

.spec_slide {
  background-color: #fff;
  padding: 40px;
  overflow-x: scroll;
  width: 100%;
}
@media screen and (max-width: 600px) {
  .spec_slide {
    padding: 20px 12px;
  }
}

.spec_table {
  width: 1280px;
  font-size: 14px;
}
@media screen and (max-width: 800px) {
  .spec_table {
    font-size: 12px;
    width: 800px;
  }
}
@media screen and (max-width: 600px) {
  .spec_table {
    font-size: 11px;
    width: 700px;
  }
}

.spec_table tr {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}
@media screen and (max-width: 600px) {
  .spec_table tr {
    grid-template-columns: 100px 1fr 1fr 1fr;
  }
}

.spec_table th {
  position: sticky;
  left: 0;
  background-color: #fff;
  border-right: 1px solid #DBDBDB;
}
.spec_table th::after {
  content: "";
  width: 40px;
  left: -40px;
  background-color: #fff;
  height: calc(100% + 2px);
  position: absolute;
  top: -1px;
}
@media screen and (max-width: 600px) {
  .spec_table th::after {
    width: 12px;
    left: -12px;
  }
}

.spec_table tr:not(:last-child) {
  border-bottom: 1px solid #DBDBDB;
}

.spec_table_head td img {
  max-width: 220px;
  width: 90%;
  margin: 0 auto;
}

.spec_table th,
.spec_table td {
  width: 100%;
  padding: 20px 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
@media screen and (max-width: 600px) {
  .spec_table th,
  .spec_table td {
    padding: 20px 8px;
  }
}
.spec_table th span,
.spec_table td span {
  line-height: 1.7;
  text-align: center;
}

.spec_table td:not(:last-child) {
  border-right: 1px solid #DBDBDB;
}

/* Chrome / Safari */
.spec_slide::-webkit-scrollbar {
  height: 8px; /* 横スクロールなので height */
}

.spec_slide::-webkit-scrollbar-track {
  background: transparent;
}

.spec_slide::-webkit-scrollbar-thumb {
  background-color: #999;
  border-radius: 10px;
}

.spec_slide::-webkit-scrollbar-thumb:hover {
  background-color: #666;
}

/* mediaquery
----------------------------------------------------------------- */
.pc_LL_display {
  display: none;
}
@media screen and (max-width: 1600px) {
  .pc_LL_display {
    display: block;
  }
}

.pc_L_display {
  display: none;
}
@media screen and (max-width: 1400px) {
  .pc_L_display {
    display: block;
  }
}

.pc_M_display {
  display: none;
}
@media screen and (max-width: 1200px) {
  .pc_M_display {
    display: block;
  }
}

.pc_S_display {
  display: none;
}
@media screen and (max-width: 1000px) {
  .pc_S_display {
    display: block;
  }
}

.tab_display {
  display: none;
}
@media screen and (max-width: 800px) {
  .tab_display {
    display: block;
  }
}

.sp_LL_display {
  display: none;
}
@media screen and (max-width: 600px) {
  .sp_LL_display {
    display: block;
  }
}

.sp_L_display {
  display: none;
}
@media screen and (max-width: 430px) {
  .sp_L_display {
    display: block;
  }
}

.sp_ML_display {
  display: none;
}
@media screen and (max-width: 400px) {
  .sp_ML_display {
    display: block;
  }
}

.sp_M_display {
  display: none;
}
@media screen and (max-width: 375px) {
  .sp_M_display {
    display: block;
  }
}

.sp_S_display {
  display: none;
}
@media screen and (max-width: 350px) {
  .sp_S_display {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .sp_LL_hidden {
    display: none;
  }
}

@font-face {
  font-family: "Charter";
  src: url("font/charter-roman.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
.thanks_wrap {
  padding-bottom: 160px;
}
@media screen and (max-width: 600px) {
  .thanks_wrap {
    padding-bottom: 80px;
  }
}
.thanks_wrap p {
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 80px;
}
@media screen and (max-width: 600px) {
  .thanks_wrap p {
    margin: 0 auto 60px;
  }
}
.thanks_wrap .more_btn {
  margin: 0 auto;
}/*# sourceMappingURL=style.css.map */