@charset "UTF-8";
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "Acumin";
  src: url("../fonts/Acumin-Pro-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
}
*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

html {
  font-size: 0.76923vw;
  font-size: clamp(6px, 0.76923vw, 10px);
  margin: 0;
}

body {
  font-family: "KozGoPr6N", sans-serif;
  color: #3e3a39;
  font-weight: normal;
  font-size: 14px;
  line-height: 1.5;
  word-break: break-all;
  margin: 0;
  padding: 0;
  border: 0;
}

@media screen and (max-width: 1366px) {
  html,
  body {
    font-size: 0.0732064422vw;
  }
}
@media screen and (max-width: 1024px) {
  html,
  body {
    font-size: 0.1302083333vw;
  }
}
@media screen and (max-width: 640px) {
  html,
  body {
    font-size: min(0.15625vw, 1rem);
  }
}

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

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

[tabindex="-1"]:focus:not(:focus-visible) {
  outline: 0 !important;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}

h1,
h2 {
  line-height: 1.2;
}

h3,
h4 {
  line-height: 1.5;
}

h5,
h6 {
  line-height: inherit;
}

ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

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

b,
strong {
  font-weight: bolder;
}

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

a:not([href]):not([class]) {
  color: inherit;
  text-decoration: none;
}

a:not([href]):not([class]):hover {
  color: inherit;
  text-decoration: none;
}

a {
  color: inherit;
  text-decoration: none;
}

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

svg {
  overflow: hidden;
  vertical-align: middle;
}

[role=button] {
  cursor: pointer;
}

button:not(:disabled),
[type=button]:not(:disabled),
[type=reset]:not(:disabled),
[type=submit]:not(:disabled) {
  cursor: pointer;
}

button {
  outline: none;
  border: none;
  cursor: pointer;
}

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

textarea {
  overflow: auto;
  resize: none;
}

fieldset {
  min-width: 0;
  padding: 0;
  margin: 0;
  border: 0;
}

[hidden] {
  display: none !important;
}

*:focus {
  outline: none;
}

.clearfix::after {
  content: "";
  visibility: hidden;
  height: 0;
  display: block;
  font-size: 0;
  clear: both;
}

* html .clearfix {
  zoom: 1;
}

*:first-child + html .clearfix {
  zoom: 1;
}

@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "Acumin";
  src: url("../fonts/Acumin-Pro-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "Acumin";
  src: url("../fonts/Acumin-Pro-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
}
/*
pc remでかく
tb @include fluid-font(14, 18); 最小値14となるように
sp 768以下で調整
*/
body.no-scroll {
  overflow: hidden;
  height: 100vh;
}

.pc-hidden {
  display: none;
}
@media screen and (max-width: 1024px) {
  .pc-hidden {
    display: block;
  }
}

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

#main {
  overflow-x: clip;
}

img.w100 {
  max-width: 100%;
  height: auto;
}

.inner {
  max-width: 1200px;
  width: 90%;
  margin: auto;
}
@media screen and (max-width: 1366px) {
  .inner {
    max-width: 1200rem;
  }
}
@media screen and (max-width: 640px) {
  .inner {
    max-width: 580rem;
  }
}

.w1080 {
  max-width: 1080px;
  width: 90%;
  margin: auto;
}
@media screen and (max-width: 1366px) {
  .w1080 {
    max-width: 1080rem;
  }
}

.no-item {
  font-size: 16px;
}
@media screen and (max-width: 1366px) {
  .no-item {
    font-size: 16rem;
  }
}
@media screen and (max-width: 1024px) {
  .no-item {
    font-size: clamp(14px, 14px + (16 - 14) * (100vw - 320px) / (640 - 320), 16px);
  }
}

.fixed {
  position: fixed;
  right: 0;
  top: 22.108vw;
  z-index: 40;
  background-color: #fff;
  border-radius: 22px 0 0 22px;
  display: flex;
  flex-direction: column;
  padding: 30px 0;
  width: 75px;
  align-items: center;
}
.fixed:hover {
  filter: opacity(80%);
  transition: all 0.4s ease;
}
.fixed a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 1366px) {
  .fixed {
    border-radius: 22rem 0 0 22rem;
    padding: 30rem 0;
    width: 75rem;
  }
}
@media screen and (max-width: 1024px) {
  .fixed {
    display: none;
  }
}
.fixed .text {
  margin: 17px 0 29px;
  writing-mode: vertical-rl;
  font-size: 1.3rem;
  line-height: 1.3846153846;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.16em;
}
@media screen and (max-width: 1366px) {
  .fixed .text {
    margin: 17rem 0 28rem;
    font-size: 13rem;
  }
}
@media screen and (max-width: 1024px) {
  .fixed .text {
    font-size: clamp(14px, 14px + (13 - 14) * (100vw - 320px) / (640 - 320), 13px);
  }
}
.fixed svg {
  width: 25px;
  height: 25px;
}
@media screen and (max-width: 1366px) {
  .fixed svg {
    width: 25rem;
    height: 25rem;
  }
}

@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "Acumin";
  src: url("../fonts/Acumin-Pro-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
}
#header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  background: rgba(255, 255, 255, 0.7);
  z-index: 99999;
}
#header .h_wrap .inner {
  max-width: none;
  padding: 33px 0 44px 0;
  display: flex;
  align-items: center;
  width: 94.289897511vw;
}
@media screen and (max-width: 1366px) {
  #header .h_wrap .inner {
    padding: 33rem 0 44rem 0;
  }
}
@media screen and (max-width: 1024px) {
  #header .h_wrap .inner {
    padding: 12rem 0 24rem 0;
    justify-content: space-between;
  }
}
#header .h_wrap .inner .h_logo {
  max-width: 351px;
  transition: all 0.4s ease;
  width: 100%;
}
@media screen and (max-width: 1366px) {
  #header .h_wrap .inner .h_logo {
    max-width: 351rem;
  }
}
@media screen and (max-width: 1024px) {
  #header .h_wrap .inner .h_logo {
    max-width: 265rem;
  }
}
#header .h_wrap .inner .h_logo a {
  display: block;
}
#header .h_wrap .inner .h_logo a img {
  width: 100%;
}
#header .h_wrap .inner .h_logo:hover {
  filter: opacity(60%);
  transition: all 0.4s ease;
}
#header .h_wrap .inner .menu-contact {
  margin-left: auto;
  margin-right: 35px;
  display: flex;
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  #header .h_wrap .inner .menu-contact {
    margin-right: 35rem;
  }
}
@media screen and (max-width: 1024px) {
  #header .h_wrap .inner .menu-contact {
    display: none;
  }
}
#header .h_wrap .inner .menu-contact:hover {
  filter: opacity(80%);
  transition: all 0.4s ease;
}
#header .h_wrap .inner .menu-contact .instagram_logo {
  padding: 15px;
  width: 70px;
}
#header .h_wrap .inner .menu-contact .number {
  font-family: "Acumin", sans-serif;
  font-weight: 600;
  letter-spacing: 0.16em;
  font-size: 32px;
}
@media screen and (max-width: 1366px) {
  #header .h_wrap .inner .menu-contact .number {
    font-size: 32rem;
  }
}
#header .h_wrap .inner .menu-contact .time {
  display: flex;
  font-family: "KozGoPr6N", sans-serif;
  font-size: 12px;
  font-weight: 700;
  color: #3e3a39;
  letter-spacing: 0.08em;
  align-items: center;
}
#header .h_wrap .inner .menu-contact .time .box {
  background-color: #1f4c9f;
  font-family: "KozGoPr6N", sans-serif;
  font-size: 8px;
  letter-spacing: 0.08em;
  color: #fff;
  padding: 4px 13px;
  display: block;
  margin-right: 7px;
}
@media screen and (max-width: 1366px) {
  #header .h_wrap .inner .menu-contact .time .box {
    padding: 4rem 13rem;
    margin-right: 7rem;
  }
}
#header .h_wrap .inner .menu-contact .time .holiday {
  margin-left: auto;
  border: 1px solid #3e3a39;
  font-family: "KozGoPr6N", sans-serif;
  font-size: 8px;
  letter-spacing: 0.08em;
  color: #3e3a39;
  padding: 4px 6px;
  display: block;
}
@media screen and (max-width: 1366px) {
  #header .h_wrap .inner .menu-contact .time .holiday {
    padding: 4rem 6rem;
  }
}
#header #mobile-nav .hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  z-index: 10;
  width: 69px;
  height: 69px;
  background-color: #1f4c9f;
  border-radius: 7px;
  cursor: pointer;
  position: relative;
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .hamburger {
    width: 69rem;
    height: 69rem;
    border-radius: 7rem;
  }
}
#header #mobile-nav .hamburger:hover {
  filter: opacity(80%);
  transition: all 0.4s ease;
}
#header #mobile-nav .hamburger span {
  display: block;
  width: 29px;
  height: 2px;
  border-radius: 999px;
  margin-bottom: 8px;
  background-color: #ffffff;
  transition: all 0.3s ease-in-out;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .hamburger span {
    width: 29rem;
    height: 2rem;
    margin-bottom: 8rem;
  }
}
#header #mobile-nav .hamburger span.bar3 {
  margin-bottom: 0;
}
#header #mobile-nav .hamburger.is_open .bar1 {
  transform: translateY(12px) rotate(405deg);
  margin: 0;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .hamburger.is_open .bar1 {
    transform: translateY(12rem) rotate(405deg);
  }
}
#header #mobile-nav .hamburger.is_open .bar3 {
  transform: translateY(10px) rotate(495deg);
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .hamburger.is_open .bar3 {
    transform: translateY(10rem) rotate(495deg);
  }
}
#header #mobile-nav .hamburger.is_open .bar2 {
  display: none;
}
#header #mobile-nav .hamburger.is_open .text {
  margin-top: 25px;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .hamburger.is_open .text {
    margin-top: 25rem;
  }
}
#header #mobile-nav .hamburger.is_open .text::before {
  content: "CLOSE";
}
#header #mobile-nav .hamburger .text {
  margin-top: 10px;
  line-height: 1;
  position: relative;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .hamburger .text {
    margin-top: 10rem;
  }
}
#header #mobile-nav .hamburger .text::before {
  content: "MENU";
  font-family: "Acumin", sans-serif;
  font-size: 7px;
  color: #fff;
  letter-spacing: 0.16em;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  #header #mobile-nav .hamburger .text::before {
    font-size: 12rem;
  }
}
#header #mobile-nav .menu {
  opacity: 0;
  visibility: hidden;
  position: fixed;
  width: 100%;
  height: 100%;
  top: -100%;
  left: 0;
  bottom: 0;
  right: 0;
  overflow-y: scroll;
  z-index: -1;
  transition: all 0.4s ease;
}
#header #mobile-nav .menu.is_open {
  opacity: 1;
  visibility: visible;
  top: 0;
  display: flex;
  gap: 87px;
  overflow-x: hidden;
  background: #e7edf7;
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu.is_open {
    gap: 87rem;
  }
}
@media screen and (max-width: 1024px) {
  #header #mobile-nav .menu.is_open {
    flex-direction: column;
    gap: 58rem;
  }
}
#header #mobile-nav .menu .catchimg {
  width: 579px;
  height: 100vh;
  border-radius: 0 45px 45px 0;
}
#header #mobile-nav .menu .catchimg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0 45px 45px 0;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu .catchimg img {
    border-radius: 0 45rem 45rem 0;
  }
}
@media screen and (max-width: 1024px) {
  #header #mobile-nav .menu .catchimg img {
    border-radius: 0 0 45rem 45rem;
  }
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu .catchimg {
    width: 579rem;
    border-radius: 0 45rem 45rem 0;
  }
}
@media screen and (max-width: 1024px) {
  #header #mobile-nav .menu .catchimg {
    width: 100%;
    height: 487rem;
    border-radius: 0 0 45rem 45rem;
  }
}
#header #mobile-nav .menu .menu-right {
  margin-top: 163px;
  margin-right: 19px;
  flex: 1;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu .menu-right {
    margin-top: 163rem;
    margin-right: 19rem;
  }
}
@media screen and (max-width: 1024px) {
  #header #mobile-nav .menu .menu-right {
    margin: 0 auto;
    width: 90%;
  }
}
@media screen and (max-width: 640px) {
  #header #mobile-nav .menu .menu-right {
    width: 580rem;
  }
}
#header #mobile-nav .menu .menu-right .page_menu {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto;
  gap: 53px 31px;
  margin-bottom: 52px;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu .menu-right .page_menu {
    gap: 53rem 31rem;
    margin-bottom: 52rem;
  }
}
@media screen and (max-width: 1024px) {
  #header #mobile-nav .menu .menu-right .page_menu {
    grid-template-columns: 1fr;
  }
}
#header #mobile-nav .menu .menu-right .page_menu .menu-item .no-link {
  font-family: "Acumin", sans-serif;
  font-weight: 600;
  color: #1f4c9f;
  font-size: 15px;
  letter-spacing: 0.06em;
  padding-bottom: 15px;
  margin-bottom: 13px;
  border-bottom: 1px solid #3e3a39;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu .menu-right .page_menu .menu-item .no-link {
    font-size: 15rem;
    padding-bottom: 15rem;
    margin-bottom: 13rem;
  }
}
@media screen and (max-width: 1024px) {
  #header #mobile-nav .menu .menu-right .page_menu .menu-item .no-link {
    font-size: 36rem;
  }
}
#header #mobile-nav .menu .menu-right .page_menu .menu-item .submenu {
  display: flex;
  flex-direction: column;
  gap: 15px;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu .menu-right .page_menu .menu-item .submenu {
    gap: 15rem;
  }
}
#header #mobile-nav .menu .menu-right .page_menu .menu-item .submenu .menu-item a,
#header #mobile-nav .menu .menu-right .page_menu .menu-item .submenu .cat-item a {
  font-family: "KozGoPr6N", sans-serif;
  font-weight: 500;
  color: #3e3a39;
  font-size: 13px;
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu .menu-right .page_menu .menu-item .submenu .menu-item a,
  #header #mobile-nav .menu .menu-right .page_menu .menu-item .submenu .cat-item a {
    font-size: 13rem;
  }
}
@media screen and (max-width: 1024px) {
  #header #mobile-nav .menu .menu-right .page_menu .menu-item .submenu .menu-item a,
  #header #mobile-nav .menu .menu-right .page_menu .menu-item .submenu .cat-item a {
    font-size: 21rem;
  }
}
@media screen and (max-width: 640px) {
  #header #mobile-nav .menu .menu-right .page_menu .menu-item .submenu .menu-item a,
  #header #mobile-nav .menu .menu-right .page_menu .menu-item .submenu .cat-item a {
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
  }
}
#header #mobile-nav .menu .menu-right .page_menu .menu-item .submenu .menu-item a:hover,
#header #mobile-nav .menu .menu-right .page_menu .menu-item .submenu .cat-item a:hover {
  filter: opacity(80%);
  transition: all 0.4s ease;
}
#header #mobile-nav .menu .menu-right .page_menu .menu-item a {
  display: flex;
  gap: 8px;
  align-items: center;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu .menu-right .page_menu .menu-item a {
    gap: 8rem;
  }
}
#header #mobile-nav .menu .menu-right .banner {
  position: relative;
  max-width: 588px;
  width: 100%;
  border: 1px solid #3e3a39;
  border-radius: 25px;
  background-color: #fff;
  display: flex;
  align-items: center;
  margin-left: 45px;
  padding: 33px 0 35px 33px;
  gap: 77px;
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu .menu-right .banner {
    max-width: 588rem;
    border-radius: 25rem;
    margin-left: 45rem;
    padding: 33rem 0 35rem 33rem;
    gap: 77rem;
  }
}
@media screen and (max-width: 1024px) {
  #header #mobile-nav .menu .menu-right .banner {
    max-width: 580rem;
    margin: auto;
    gap: 0;
    padding: 30rem;
  }
}
#header #mobile-nav .menu .menu-right .banner .arrow {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 43px;
  height: 43px;
  border-radius: 16px 0 25px 0;
  background-color: #3e3a39;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu .menu-right .banner .arrow {
    width: 43rem;
    height: 43rem;
    border-radius: 16rem 0 25rem 0;
  }
}
#header #mobile-nav .menu .menu-right .banner .arrow svg {
  width: 15px;
  height: 12px;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu .menu-right .banner .arrow svg {
    width: 15rem;
    height: 12rem;
  }
}
#header #mobile-nav .menu .menu-right .banner:hover {
  filter: opacity(80%);
  transition: all 0.4s ease;
}
#header #mobile-nav .menu .menu-right .banner .img {
  width: 75px;
  height: auto;
  border-radius: 0;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu .menu-right .banner .img {
    width: 75rem;
  }
}
#header #mobile-nav .menu .menu-right .banner .img img {
  width: 100%;
  height: auto;
  object-fit: contain;
  border-radius: 0;
}
#header #mobile-nav .menu .menu-right .banner .text {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu .menu-right .banner .text {
    gap: 12rem;
  }
}
@media screen and (max-width: 1024px) {
  #header #mobile-nav .menu .menu-right .banner .text {
    gap: 13rem;
    flex: 1;
    align-items: flex-start;
  }
}
@media screen and (max-width: 640px) {
  #header #mobile-nav .menu .menu-right .banner .text {
    align-items: center;
  }
}
#header #mobile-nav .menu .menu-right .banner .text .sub {
  display: flex;
  gap: 1em;
  font-family: "KozGoPr6N", sans-serif;
  font-weight: 400;
  font-size: 1.1rem;
  line-height: 1.1818181818;
  font-size: 11px;
  align-items: flex-end;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu .menu-right .banner .text .sub {
    font-size: 11rem;
  }
}
@media screen and (max-width: 1024px) {
  #header #mobile-nav .menu .menu-right .banner .text .sub {
    align-items: center;
  }
}
#header #mobile-nav .menu .menu-right .banner .text .sub svg {
  width: 8px;
  height: 10px;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu .menu-right .banner .text .sub svg {
    width: 8rem;
    height: 10rem;
  }
}
#header #mobile-nav .menu .menu-right .banner .text .ttl {
  font-family: "KozGoPr6N", sans-serif;
  font-weight: 700;
  font-size: 18px;
  color: #1f4c9f;
  position: relative;
  padding-bottom: 11px;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu .menu-right .banner .text .ttl {
    font-size: 18rem;
    padding-bottom: 11rem;
  }
}
@media screen and (max-width: 1024px) {
  #header #mobile-nav .menu .menu-right .banner .text .ttl {
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
  }
}
#header #mobile-nav .menu .menu-right .banner .text .ttl::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 56px;
  height: 4px;
  margin: auto;
  background-image: radial-gradient(circle, #1f4c9f 2px, transparent 2px);
  background-size: 7px 4px;
  background-repeat: repeat-x;
}
@media screen and (max-width: 1366px) {
  #header #mobile-nav .menu .menu-right .banner .text .ttl::after {
    width: 56rem;
    height: 4rem;
    background-image: radial-gradient(circle, #1f4c9f 2rem, transparent 2rem);
    background-size: 7rem 4rem;
  }
}
@media screen and (max-width: 1024px) {
  #header #mobile-nav .menu .menu-right .banner .text .ttl::after {
    width: 51rem;
    height: 4rem;
  }
}
#header #mobile-nav .menu .menu-right .banner a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 1024px) {
  #header #mobile-nav .menu .t_insta {
    background-color: #fff;
  }
  #header #mobile-nav .menu .t_insta .inner {
    padding-top: 60rem;
    padding-bottom: 0;
    display: block;
  }
  #header #mobile-nav .menu .menu-in .inner {
    margin: auto;
    display: block;
  }
}

@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "Acumin";
  src: url("../fonts/Acumin-Pro-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
}
.t_insta .inner {
  max-width: none;
  width: 100%;
  padding-top: 88px;
}
@media screen and (max-width: 1366px) {
  .t_insta .inner {
    padding-top: 88rem;
  }
}
@media screen and (max-width: 1024px) {
  .t_insta .inner {
    padding-top: 63rem;
  }
}
.t_insta .inner .insta-logo {
  margin-bottom: 54px;
  text-align: center;
}
@media screen and (max-width: 1366px) {
  .t_insta .inner .insta-logo {
    margin-bottom: 54rem;
  }
}
@media screen and (max-width: 1024px) {
  .t_insta .inner .insta-logo {
    width: 295rem;
    margin: auto auto 54rem;
  }
}
.t_insta .inner #sb_instagram #sbi_images {
  padding: 0;
  gap: 16px;
  grid-template-columns: repeat(4, 1fr);
}
@media screen and (max-width: 1366px) {
  .t_insta .inner #sb_instagram #sbi_images {
    gap: 16rem;
  }
}
@media screen and (max-width: 1024px) {
  .t_insta .inner #sb_instagram #sbi_images {
    grid-template-columns: repeat(4, 252rem);
    margin-left: -173rem;
    gap: 12rem;
  }
}
.t_insta .inner #sb_instagram .sbi_item {
  height: 482px;
}
@media screen and (max-width: 1366px) {
  .t_insta .inner #sb_instagram .sbi_item {
    height: 482rem;
  }
}
@media screen and (max-width: 1024px) {
  .t_insta .inner #sb_instagram .sbi_item {
    height: 349rem;
  }
}
.t_insta .inner #sb_instagram .sbi_item .sbi_photo_wrap {
  height: 100%;
}
.t_insta .inner #sb_instagram .sbi_item .sbi_photo_wrap .sbi_photo {
  height: 100% !important;
}

#footer {
  background-color: #1f4c9f;
  position: relative;
}
#footer .wave {
  width: 100%;
  height: 125px;
  position: absolute;
  bottom: 99.9%;
  left: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
}
@media screen and (max-width: 1366px) {
  #footer .wave {
    height: 125rem;
  }
}
#footer .wave canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#footer .inner {
  max-width: 1200px;
}
@media screen and (max-width: 1366px) {
  #footer .inner {
    max-width: 1200rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner {
    max-width: 580rem;
  }
}
#footer .inner .foot-top {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
#footer .inner .foot-top .logo {
  margin-bottom: 46px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-top .logo {
    margin-bottom: 46rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-top .logo {
    width: 490rem;
    height: auto;
    margin-bottom: 60rem;
  }
}
#footer .inner .foot-top .f-contact {
  color: #fff;
  margin-bottom: 83px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-top .f-contact {
    margin-bottom: 83rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-top .f-contact {
    margin-bottom: 68rem;
  }
}
#footer .inner .foot-top .f-contact .address {
  font-family: "KozGoPr6N", sans-serif;
  font-weight: 500;
  font-size: 18px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-top .f-contact .address {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-top .f-contact .address {
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
    text-align: center;
  }
}
#footer .inner .foot-top .f-contact .number {
  font-family: "Acumin", sans-serif;
  font-weight: 600;
  letter-spacing: 0.16em;
  font-size: 48px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-top .f-contact .number {
    font-size: 48rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-top .f-contact .number {
    text-align: center;
  }
}
#footer .inner .foot-top .f-contact .time {
  display: flex;
  font-family: "KozGoPr6N", sans-serif;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.08em;
  align-items: center;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-top .f-contact .time {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-top .f-contact .time {
    gap: 10rem;
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
  }
}
#footer .inner .foot-top .f-contact .time .box {
  background-color: #fff;
  font-family: "KozGoPr6N", sans-serif;
  font-size: 12px;
  letter-spacing: 0.08em;
  color: #1f4c9f;
  padding: 4px 20px;
  display: block;
  margin-right: 7px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-top .f-contact .time .box {
    padding: 4rem 20rem;
    margin-right: 7rem;
  }
}
#footer .inner .foot-top .f-contact .time .holiday {
  margin-left: auto;
  border: 1px solid #fff;
  font-family: "KozGoPr6N", sans-serif;
  font-size: 12px;
  letter-spacing: 0.08em;
  padding: 4px 6px;
  display: block;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-top .f-contact .time .holiday {
    padding: 4rem 6rem;
  }
}
#footer .inner .foot-top .f-catch {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-bottom: 80px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-top .f-catch {
    margin-bottom: 80rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-top .f-catch {
    margin-bottom: 60rem;
  }
}
#footer .inner .foot-top .f-catch .main {
  font-size: 43px;
  font-family: "KozGoPr6N", sans-serif;
  font-weight: 900;
  letter-spacing: 0.06em;
  color: #fff;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-top .f-catch .main {
    font-size: 43rem;
  }
}
#footer .inner .foot-top .f-catch .sub {
  font-family: "Acumin", sans-serif;
  font-weight: 400;
  font-size: 14px;
  letter-spacing: 0.12em;
  color: #fff;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-top .f-catch .sub {
    font-size: 14rem;
  }
}
#footer .inner .foot-middle {
  margin-bottom: 89px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle {
    margin-bottom: 89rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-middle {
    margin-bottom: 53rem;
  }
}
#footer .inner .foot-middle .foot-middle_top {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 22px;
  padding-bottom: 34px;
  margin-bottom: 34px;
  border-bottom: 1px solid #fff;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_top {
    gap: 22rem;
    padding-bottom: 34rem;
    margin-bottom: 34rem;
    border-bottom: 1px solid #fff;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-middle .foot-middle_top {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    gap: 50rem;
    border-bottom: none;
    padding-bottom: 0;
    margin-bottom: 48rem;
  }
}
#footer .inner .foot-middle .foot-middle_top .item .item-ttl {
  font-family: "Acumin", sans-serif;
  font-weight: 600;
  font-size: 24px;
  letter-spacing: 0.16em;
  color: #fff;
  text-align: center;
  margin-bottom: 33px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_top .item .item-ttl {
    font-size: 24rem;
    margin-bottom: 33rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-middle .foot-middle_top .item .item-ttl {
    font-size: clamp(14px, 14px + (24 - 14) * (100vw - 320px) / (640 - 320), 24px);
  }
}
#footer .inner .foot-middle .foot-middle_top .item .banner {
  position: relative;
  max-width: 588px;
  width: 100%;
  border: 1px solid #3e3a39;
  border-radius: 25px;
  background-color: #fff;
  display: flex;
  padding: 33px 33px 35px 33px;
  gap: 77px;
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_top .item .banner {
    max-width: 588rem;
    border-radius: 25rem;
    padding: 33rem 33rem 35rem 33rem;
    gap: 77rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-middle .foot-middle_top .item .banner {
    max-width: 100%;
    padding: 31rem 33rem 32rem 49rem;
    align-items: center;
    gap: 0;
  }
}
#footer .inner .foot-middle .foot-middle_top .item .banner .img {
  width: 75px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_top .item .banner .img {
    width: 75rem;
  }
}
#footer .inner .foot-middle .foot-middle_top .item .banner .img img {
  width: 100%;
  height: auto;
}
#footer .inner .foot-middle .foot-middle_top .item .banner .arrow {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 43px;
  height: 43px;
  border-radius: 16px 0 25px 0;
  background-color: #3e3a39;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_top .item .banner .arrow {
    width: 43rem;
    height: 43rem;
    border-radius: 16rem 0 25rem 0;
  }
}
#footer .inner .foot-middle .foot-middle_top .item .banner .arrow svg {
  width: 15px;
  height: 12px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_top .item .banner .arrow svg {
    width: 15rem;
    height: 12rem;
  }
}
#footer .inner .foot-middle .foot-middle_top .item .banner:hover {
  filter: opacity(80%);
  transition: all 0.4s ease;
}
#footer .inner .foot-middle .foot-middle_top .item .banner .text {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_top .item .banner .text {
    gap: 12rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-middle .foot-middle_top .item .banner .text {
    gap: 16rem;
    flex: 1;
  }
}
#footer .inner .foot-middle .foot-middle_top .item .banner .text .sub {
  display: flex;
  gap: 1em;
  font-family: "KozGoPr6N", sans-serif;
  font-weight: 400;
  font-size: 11px;
  line-height: 1;
  align-items: flex-end;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_top .item .banner .text .sub {
    font-size: 11rem;
  }
}
#footer .inner .foot-middle .foot-middle_top .item .banner .text .sub svg {
  width: 8px;
  height: 10px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_top .item .banner .text .sub svg {
    width: 8rem;
    height: 10rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-middle .foot-middle_top .item .banner .text .sub {
    font-size: 14rem;
    align-items: center;
    justify-content: center;
  }
}
#footer .inner .foot-middle .foot-middle_top .item .banner .text .ttl {
  font-family: "KozGoPr6N", sans-serif;
  font-weight: 700;
  font-size: 18px;
  text-align: center;
  color: #1f4c9f;
  position: relative;
  padding-bottom: 11px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_top .item .banner .text .ttl {
    font-size: 18rem;
    padding-bottom: 11rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-middle .foot-middle_top .item .banner .text .ttl {
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
    padding-bottom: 14rem;
  }
}
#footer .inner .foot-middle .foot-middle_top .item .banner .text .ttl::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 56px;
  height: 4px;
  margin: auto;
  background-image: radial-gradient(circle, #1f4c9f 2px, transparent 2px);
  background-size: 7px 4px;
  background-repeat: repeat-x;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_top .item .banner .text .ttl::after {
    width: 56rem;
    height: 4rem;
    background-image: radial-gradient(circle, #1f4c9f 2rem, transparent 2rem);
    background-size: 7rem 4rem;
  }
}
#footer .inner .foot-middle .foot-middle_top .item .banner a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#footer .inner .foot-middle .foot-middle_top .item.item-contact .banner {
  padding: 31px 0 33px 55px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_top .item.item-contact .banner {
    padding: 31rem 0 33rem 55rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-middle .foot-middle_top .item.item-contact .banner {
    padding: 31rem 33rem 32rem 49rem;
    align-items: center;
  }
}
#footer .inner .foot-middle .foot-middle_top .item.item-contact .banner .img {
  width: 35px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_top .item.item-contact .banner .img {
    width: 35rem;
  }
}
#footer .inner .foot-middle .foot-middle_top .item.item-contact .banner .img img {
  width: 100%;
  height: auto;
}
#footer .inner .foot-middle .foot-middle_bottom {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_bottom {
    gap: 22rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-middle .foot-middle_bottom {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto;
    gap: 15rem;
  }
}
#footer .inner .foot-middle .foot-middle_bottom .item {
  position: relative;
  max-width: 283px;
  width: 100%;
  border: 1px solid #cccccc;
  border-radius: 25px;
  padding: 29px 0 25px;
  background-color: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_bottom .item {
    max-width: 283rem;
    border-radius: 25rem;
    padding: 29rem 0 25rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-middle .foot-middle_bottom .item {
    padding: 28rem 0 26rem;
  }
}
#footer .inner .foot-middle .foot-middle_bottom .item .arrow {
  position: absolute;
  right: -1px;
  bottom: -1px;
  width: 43px;
  height: 43px;
  border-radius: 16px 0 25px 0;
  background-color: #3e3a39;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_bottom .item .arrow {
    right: -1rem;
    bottom: -1rem;
    width: 43rem;
    height: 43rem;
    border-radius: 16rem 0 25rem 0;
  }
}
#footer .inner .foot-middle .foot-middle_bottom .item .arrow svg {
  width: 15px;
  height: 12px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_bottom .item .arrow svg {
    width: 15rem;
    height: 12rem;
  }
}
#footer .inner .foot-middle .foot-middle_bottom .item:hover {
  filter: opacity(80%);
  transition: all 0.4s ease;
}
#footer .inner .foot-middle .foot-middle_bottom .item .sub {
  display: flex;
  gap: 1em;
  font-family: "KozGoPr6N", sans-serif;
  font-weight: 400;
  font-size: 11px;
  line-height: 1;
  align-items: flex-end;
  margin-bottom: 10px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_bottom .item .sub {
    margin-bottom: 10rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-middle .foot-middle_bottom .item .sub {
    font-size: 14rem;
  }
}
#footer .inner .foot-middle .foot-middle_bottom .item .sub svg {
  width: 8px;
  height: 10px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_bottom .item .sub svg {
    width: 8rem;
    height: 10rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-middle .foot-middle_bottom .item .sub {
    align-items: center;
  }
}
#footer .inner .foot-middle .foot-middle_bottom .item .ttl {
  font-family: "KozGoPr6N", sans-serif;
  font-weight: 700;
  font-size: 18px;
  text-align: center;
  color: #1f4c9f;
  position: relative;
  padding-bottom: 11px;
  margin-top: 21px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_bottom .item .ttl {
    font-size: 18rem;
    padding-bottom: 11rem;
    margin-top: 21rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .foot-middle .foot-middle_bottom .item .ttl {
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
    padding-bottom: 14rem;
    margin-top: 23rem;
  }
}
#footer .inner .foot-middle .foot-middle_bottom .item .ttl::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 56px;
  height: 4px;
  margin: auto;
  background-image: radial-gradient(circle, #1f4c9f 2px, transparent 2px);
  background-size: 7px 4px;
  background-repeat: repeat-x;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_bottom .item .ttl::after {
    width: 56rem;
    height: 4rem;
    background-image: radial-gradient(circle, #1f4c9f 2rem, transparent 2rem);
    background-size: 7rem 4rem;
  }
}
#footer .inner .foot-middle .foot-middle_bottom .item a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#footer .inner .foot-middle .foot-middle_bottom .item.color01 .img {
  width: 90px;
  height: auto;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_bottom .item.color01 .img {
    width: 90rem;
  }
}
#footer .inner .foot-middle .foot-middle_bottom .item.color01 .arrow {
  background-color: #678dc9;
}
#footer .inner .foot-middle .foot-middle_bottom .item.color01 .ttl {
  color: #678dc9;
}
#footer .inner .foot-middle .foot-middle_bottom .item.color01 .ttl::after {
  background-image: radial-gradient(circle, #678dc9 2px, transparent 2px);
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_bottom .item.color01 .ttl::after {
    background-image: radial-gradient(circle, #678dc9 2rem, transparent 2rem);
  }
}
#footer .inner .foot-middle .foot-middle_bottom .item.color02 .img {
  width: 67px;
  height: auto;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_bottom .item.color02 .img {
    width: 67rem;
  }
}
#footer .inner .foot-middle .foot-middle_bottom .item.color02 .arrow {
  background-color: #67c1c6;
}
#footer .inner .foot-middle .foot-middle_bottom .item.color02 .ttl {
  color: #67c1c6;
}
#footer .inner .foot-middle .foot-middle_bottom .item.color02 .ttl::after {
  background-image: radial-gradient(circle, #67c1c6 2px, transparent 2px);
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_bottom .item.color02 .ttl::after {
    background-image: radial-gradient(circle, #67c1c6 2rem, transparent 2rem);
  }
}
#footer .inner .foot-middle .foot-middle_bottom .item.color03 .img {
  width: 33px;
  height: auto;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_bottom .item.color03 .img {
    width: 33rem;
  }
}
#footer .inner .foot-middle .foot-middle_bottom .item.color03 .arrow {
  background-color: #69c489;
}
#footer .inner .foot-middle .foot-middle_bottom .item.color03 .ttl {
  color: #69c489;
}
#footer .inner .foot-middle .foot-middle_bottom .item.color03 .ttl::after {
  background-image: radial-gradient(circle, #69c489 2px, transparent 2px);
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_bottom .item.color03 .ttl::after {
    background-image: radial-gradient(circle, #69c489 2rem, transparent 2rem);
  }
}
#footer .inner .foot-middle .foot-middle_bottom .item.color04 .img {
  width: 62px;
  height: auto;
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_bottom .item.color04 .img {
    width: 62rem;
  }
}
#footer .inner .foot-middle .foot-middle_bottom .item.color04 .arrow {
  background-color: #b6c168;
}
#footer .inner .foot-middle .foot-middle_bottom .item.color04 .ttl {
  color: #b6c168;
}
#footer .inner .foot-middle .foot-middle_bottom .item.color04 .ttl::after {
  background-image: radial-gradient(circle, #b6c168 2px, transparent 2px);
}
@media screen and (max-width: 1366px) {
  #footer .inner .foot-middle .foot-middle_bottom .item.color04 .ttl::after {
    background-image: radial-gradient(circle, #b6c168 2rem, transparent 2rem);
  }
}
#footer .inner .f_menu {
  margin-bottom: 63px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .f_menu {
    margin-bottom: 63rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .inner .f_menu {
    display: none;
  }
}
#footer .inner .f_menu .page_menu {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  grid-template-rows: auto;
  gap: 0 31px;
  width: 95%;
  margin: auto;
}
@media screen and (max-width: 1366px) {
  #footer .inner .f_menu .page_menu {
    gap: 0 31rem;
    width: 95%;
    margin: auto;
  }
}
#footer .inner .f_menu .page_menu .menu-item .no-link {
  font-family: "Acumin", sans-serif;
  font-weight: 600;
  color: #fff;
  font-size: 15px;
  line-height: 1;
  letter-spacing: 0.06em;
  padding-bottom: 15px;
  margin-bottom: 13px;
  border-bottom: 1px solid #fff;
}
@media screen and (max-width: 1366px) {
  #footer .inner .f_menu .page_menu .menu-item .no-link {
    font-size: 15rem;
    padding-bottom: 15rem;
    margin-bottom: 13rem;
    border-bottom: 1px solid #fff;
  }
}
#footer .inner .f_menu .page_menu .menu-item .submenu {
  display: flex;
  flex-direction: column;
  gap: 15px;
}
@media screen and (max-width: 1366px) {
  #footer .inner .f_menu .page_menu .menu-item .submenu {
    gap: 15rem;
  }
}
#footer .inner .f_menu .page_menu .menu-item .submenu .menu-item a,
#footer .inner .f_menu .page_menu .menu-item .submenu .cat-item a {
  font-family: "KozGoPr6N", sans-serif;
  font-weight: 500;
  color: #fff;
  font-size: 13px;
  line-height: 1;
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  #footer .inner .f_menu .page_menu .menu-item .submenu .menu-item a,
  #footer .inner .f_menu .page_menu .menu-item .submenu .cat-item a {
    font-size: 13rem;
  }
}
#footer .inner .f_menu .page_menu .menu-item .submenu .menu-item a:hover,
#footer .inner .f_menu .page_menu .menu-item .submenu .cat-item a:hover {
  filter: opacity(80%);
  transition: all 0.4s ease;
}
#footer .inner .f_menu .page_menu .menu-item a {
  display: flex;
  gap: 8px;
  align-items: center;
}
@media screen and (max-width: 1366px) {
  #footer .inner .f_menu .page_menu .menu-item a {
    gap: 8rem;
  }
}
#footer .column-contact {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  height: 90px;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
}
@media screen and (max-width: 1366px) {
  #footer .column-contact {
    height: 90rem;
  }
}
#footer .column-contact .item {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 42px 0 72px;
  position: relative;
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  #footer .column-contact .item {
    padding: 0 42rem 0 72rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .column-contact .item {
    padding: 0 19rem 0 23rem;
  }
}
#footer .column-contact .item a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#footer .column-contact .item:hover {
  filter: opacity(80%);
  transition: all 0.4s ease;
}
#footer .column-contact .item:hover svg {
  transform: translateX(4px);
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  #footer .column-contact .item:hover svg {
    transform: translateX(4rem);
  }
}
#footer .column-contact .item .img {
  margin-right: 20px;
}
@media screen and (max-width: 1366px) {
  #footer .column-contact .item .img {
    margin-right: 20rem;
  }
}
#footer .column-contact .item .img img {
  filter: brightness(20);
}
#footer .column-contact .item .text {
  font-size: 18px;
  font-family: "KozGoPr6N", sans-serif;
  font-weight: 700;
  color: #fff;
}
@media screen and (max-width: 1366px) {
  #footer .column-contact .item .text {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .column-contact .item .text {
    font-size: 16rem;
  }
}
#footer .column-contact .item .text .sp-hidden {
  display: inline;
}
@media screen and (max-width: 1024px) {
  #footer .column-contact .item .text .sp-hidden {
    display: none;
  }
}
#footer .column-contact .item svg {
  margin-left: auto;
  transition: all 0.4s ease;
  width: 15px;
  height: 12px;
}
@media screen and (max-width: 1366px) {
  #footer .column-contact .item svg {
    width: 15rem;
    height: 12rem;
  }
}
#footer .column-contact .item:first-child {
  border-right: 1px solid #fff;
}
#footer .copy {
  font-size: 12px;
  font-family: "KozGoPr6N", sans-serif;
  font-weight: 500;
  text-align: center;
  color: #fff;
  padding: 50px 0 70px;
}
@media screen and (max-width: 1366px) {
  #footer .copy {
    padding: 50rem 0 70rem;
  }
}
@media screen and (max-width: 1024px) {
  #footer .copy {
    padding: 44rem 0 47rem;
  }
}

@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "Acumin";
  src: url("../fonts/Acumin-Pro-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
}
.page-fv .fv-img {
  position: relative;
  width: 94.289897511vw;
  height: 517px;
  margin: auto;
  text-align: center;
  border-radius: 45px;
}
@media screen and (max-width: 1366px) {
  .page-fv .fv-img {
    height: 517rem;
    border-radius: 45rem;
  }
}
@media screen and (max-width: 640px) {
  .page-fv .fv-img {
    width: 580rem;
  }
}
.page-fv .fv-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 45px;
}
@media screen and (max-width: 1366px) {
  .page-fv .fv-img img {
    border-radius: 45rem;
  }
}
.page-fv .inner {
  display: flex;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 90%;
  height: 100%;
  margin: auto;
}
.page-fv .inner .title {
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto auto auto 0;
  width: fit-content;
  color: #fff;
  text-align: left;
  position: relative;
  padding-bottom: 50px;
}
@media screen and (max-width: 1366px) {
  .page-fv .inner .title {
    padding-bottom: 50rem;
  }
}
@media screen and (max-width: 1024px) {
  .page-fv .inner .title {
    margin: auto;
  }
}
.page-fv .inner .title .tit-en {
  color: #fff;
  text-transform: uppercase;
  font-family: "Acumin", sans-serif;
  font-size: 24px;
  font-weight: 600;
  letter-spacing: 0.16em;
  margin-bottom: 17px;
}
@media screen and (max-width: 1366px) {
  .page-fv .inner .title .tit-en {
    font-size: 24rem;
    margin-bottom: 17rem;
  }
}
.page-fv .inner .title .tit-ja {
  font-weight: 700;
  font-size: 48px;
  letter-spacing: 0.22em;
}
@media screen and (max-width: 1366px) {
  .page-fv .inner .title .tit-ja {
    font-size: 48rem;
  }
}
.page-fv .inner .title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 222px;
  height: 13px;
  margin: auto;
  background-image: radial-gradient(circle, #fff 6.5px, transparent 7px);
  background-size: 22.2px 13px;
  background-repeat: repeat-x;
}
@media screen and (max-width: 1366px) {
  .page-fv .inner .title::after {
    width: 222rem;
    height: 13rem;
    background-size: 22.2rem 13rem;
    background-image: radial-gradient(circle, #fff 6.5rem, transparent 7rem);
  }
}

.submenu-tabs {
  max-width: 1075px;
  width: 90%;
  margin: -67px auto 65px;
  padding: 33px 0 30px;
  background: linear-gradient(to bottom, rgb(255, 255, 255) 0%, rgb(255, 255, 255) 70px, rgba(255, 255, 255, 0) 70px, rgba(255, 255, 255, 0) 100%);
  border-radius: 45px 45px 0 0;
  position: relative;
}
@media screen and (max-width: 1366px) {
  .submenu-tabs {
    max-width: 1075rem;
    margin: -67rem auto 65rem;
    padding: 33rem 0 30rem;
    border-radius: 45rem 45rem 0 0;
    background: linear-gradient(to bottom, rgb(255, 255, 255) 0%, rgb(255, 255, 255) 70rem, rgba(255, 255, 255, 0) 70rem, rgba(255, 255, 255, 0) 100%);
  }
}
@media screen and (max-width: 640px) {
  .submenu-tabs {
    max-width: 550rem;
  }
}
.submenu-tabs .submenu-tabs__list {
  display: flex;
  justify-content: space-between;
  width: 80%;
  margin: auto;
}
@media screen and (max-width: 1024px) {
  .submenu-tabs .submenu-tabs__list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto;
    row-gap: 30rem;
    width: 100%;
  }
}
.submenu-tabs .submenu-tabs__list .submenu-tabs__item {
  padding-bottom: 22px;
  position: relative;
  min-width: 111px;
  text-align: center;
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  .submenu-tabs .submenu-tabs__list .submenu-tabs__item {
    padding-bottom: 22rem;
    min-width: 111rem;
  }
}
.submenu-tabs .submenu-tabs__list .submenu-tabs__item::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 111px;
  height: 6px;
  margin: auto;
  background-image: radial-gradient(circle, #1f4c9f 3px, transparent 3px);
  background-size: 11.1px 6px;
  background-repeat: repeat-x;
}
@media screen and (max-width: 1366px) {
  .submenu-tabs .submenu-tabs__list .submenu-tabs__item::after {
    width: 111rem;
    height: 6rem;
    background-size: 11.1rem 6rem;
    background-image: radial-gradient(circle, #1f4c9f 3rem, transparent 3rem);
  }
}
.submenu-tabs .submenu-tabs__list .submenu-tabs__item a {
  font-size: 18px;
  font-weight: 500;
  color: #1f4c9f;
  display: block;
}
@media screen and (max-width: 1366px) {
  .submenu-tabs .submenu-tabs__list .submenu-tabs__item a {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .submenu-tabs .submenu-tabs__list .submenu-tabs__item a {
    font-size: clamp(13px, 13px + (18 - 13) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.submenu-tabs .submenu-tabs__list .submenu-tabs__item:hover {
  filter: opacity(80%);
  transition: all 0.4s ease;
}
.submenu-tabs .product-cat-container {
  position: relative;
}
.submenu-tabs .product-cat-container.is-open .product-cat-list {
  max-height: none;
}
.submenu-tabs .product-cat-container.is-open .more-btn {
  display: none;
}
.submenu-tabs .product-cat-container .more-btn {
  display: block;
  margin: 10px auto;
  padding: 8px 20px;
  background: #eee;
  border: none;
  cursor: pointer;
}
.submenu-tabs .product-cat-list {
  max-width: 885px;
  width: 90%;
  margin: 63px auto 50px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: auto;
  gap: 38px 0;
  max-height: 50vh; /* 画面高の70% */
  overflow: hidden;
  transition: max-height 0.3s ease; /* スムーズに開閉したい場合 */
}
@media screen and (max-width: 1366px) {
  .submenu-tabs .product-cat-list {
    max-width: 885rem;
    margin: 63rem auto 50rem;
    gap: 38rem 0;
  }
}
@media screen and (max-width: 1024px) {
  .submenu-tabs .product-cat-list {
    max-width: fit-content;
    grid-template-columns: repeat(2, 1fr);
    gap: 38rem 100rem;
  }
}
@media screen and (max-width: 640px) {
  .submenu-tabs .product-cat-list {
    max-width: 580rem;
    grid-template-columns: repeat(2, 1fr);
    gap: 38rem 40rem;
    width: fit-content;
  }
}
.submenu-tabs .product-cat-list .cat__item {
  position: relative;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1366px) {
  .submenu-tabs .product-cat-list .cat__item {
    font-size: 16rem;
    letter-spacing: 0.1rem;
  }
}
@media screen and (max-width: 640px) {
  .submenu-tabs .product-cat-list .cat__item {
    font-size: clamp(12px, 12px + (16 - 12) * (100vw - 320px) / (640 - 320), 16px);
  }
}
.submenu-tabs .product-cat-list .cat__item::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 4px;
  background-color: #b3b3b3;
  border-radius: 50px;
  vertical-align: middle;
  margin-right: 6px;
}
@media screen and (max-width: 1366px) {
  .submenu-tabs .product-cat-list .cat__item::before {
    width: 4rem;
    height: 4rem;
    margin-right: 6rem;
  }
}
.submenu-tabs .product-cat-list .cat__item.active {
  color: #1f4c9f;
  font-weight: 900;
  text-decoration: underline;
}
.submenu-tabs .search-box {
  padding-left: 38px;
  padding-right: 38px;
  width: 725px;
  margin: auto;
  height: 75px;
  border: 1px solid #e6e6e6;
  border-radius: 50px;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 1366px) {
  .submenu-tabs .search-box {
    padding-left: 38rem;
    padding-right: 38rem;
    width: 725rem;
    height: 75rem;
    border: 1rem solid #e6e6e6;
    border-radius: 50rem;
  }
}
@media screen and (max-width: 1024px) {
  .submenu-tabs .search-box {
    width: 100%;
  }
}
.submenu-tabs .search-box .img {
  position: relative;
  padding-right: 28px;
}
@media screen and (max-width: 1366px) {
  .submenu-tabs .search-box .img {
    padding-right: 28rem;
  }
}
.submenu-tabs .search-box .img::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  right: 0;
  width: 1px;
  height: 100%;
  background-color: #b3b3b3;
}
@media screen and (max-width: 1366px) {
  .submenu-tabs .search-box .img::after {
    width: 1rem;
  }
}
.submenu-tabs .search-box .img svg {
  width: 28px;
  height: 28px;
}
@media screen and (max-width: 1366px) {
  .submenu-tabs .search-box .img svg {
    width: 28rem;
    height: 28rem;
  }
}
.submenu-tabs .search-box input {
  border: none;
  width: 100%;
  padding-left: 32px;
  font-size: 16px;
  font-weight: 500;
}
@media screen and (max-width: 1366px) {
  .submenu-tabs .search-box input {
    padding-left: 32rem;
    font-size: 16rem;
  }
}
.submenu-tabs .search-box input::placeholder {
  color: #b3b3b3;
  font-size: 16px;
  letter-spacing: 0.1em;
  font-weight: 500;
}
@media screen and (max-width: 1366px) {
  .submenu-tabs .search-box input::placeholder {
    font-size: 16rem;
    letter-spacing: 0.1rem;
  }
}

.tablecontents .item {
  display: grid;
  grid-template-columns: 260px 1fr;
  padding-bottom: 28px;
  border-bottom: 1px solid #d9dada;
  margin-bottom: 28px;
  padding-left: 32px;
}
@media screen and (max-width: 1366px) {
  .tablecontents .item {
    grid-template-columns: 260rem 1fr;
    padding-bottom: 28rem;
    margin-bottom: 28rem;
    padding-left: 32rem;
  }
}
@media screen and (max-width: 1024px) {
  .tablecontents .item {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    padding-left: 0;
  }
}
.tablecontents .item:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}
.tablecontents .item .ttl,
.tablecontents .item .detail {
  font-size: 1.8rem;
  line-height: 2;
  font-size: 18px;
}
@media screen and (max-width: 1366px) {
  .tablecontents .item .ttl,
  .tablecontents .item .detail {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .tablecontents .item .ttl,
  .tablecontents .item .detail {
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.tablecontents .item .ttl {
  font-weight: 700;
}
.tablecontents .item .detail {
  font-weight: 500;
}
.tablecontents .item .detail dl {
  margin-bottom: 30px;
}
@media screen and (max-width: 1366px) {
  .tablecontents .item .detail dl {
    margin-bottom: 30rem;
  }
}
.tablecontents .item .detail dl:last-child {
  margin-bottom: 0;
}
.tablecontents .item .detail dl dt {
  color: #1f4c9f;
}
.tablecontents .row-item {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: auto;
  column-gap: 7px;
}
@media screen and (max-width: 1366px) {
  .tablecontents .row-item {
    column-gap: 7rem;
  }
}
@media screen and (max-width: 1024px) {
  .tablecontents .row-item {
    grid-template-columns: 1fr;
  }
}
.tablecontents .row-item .item:last-child {
  border-bottom: 1px solid #d9dada;
  padding-bottom: 28px;
  margin-bottom: 28px;
}
@media screen and (max-width: 1366px) {
  .tablecontents .row-item .item:last-child {
    padding-bottom: 28rem;
    margin-bottom: 28rem;
  }
}

@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "Acumin";
  src: url("../fonts/Acumin-Pro-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
}
.company .title {
  padding-bottom: 36px;
  margin-bottom: 42px;
  position: relative;
}
@media screen and (max-width: 1366px) {
  .company .title {
    padding-bottom: 36rem;
    margin-bottom: 42rem;
  }
}
.company .title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 175px;
  height: 10px;
  margin: auto;
  background-image: radial-gradient(circle, #1f4c9f 5px, transparent 5px);
  background-size: 17.5px 10px;
  background-repeat: repeat-x;
}
@media screen and (max-width: 1366px) {
  .company .title::after {
    width: 175rem;
    height: 10rem;
    background-size: 17.5rem 10rem;
    background-image: radial-gradient(circle, #1f4c9f 5rem, transparent 5rem);
  }
}
.company .title .tit-en {
  color: #1f4c9f;
  font-size: 24px;
  font-family: "Acumin", sans-serif;
  font-weight: 600;
  letter-spacing: 0.16em;
}
@media screen and (max-width: 1366px) {
  .company .title .tit-en {
    font-size: 24rem;
  }
}
@media screen and (max-width: 1024px) {
  .company .title .tit-en {
    font-size: clamp(14px, 14px + (24 - 14) * (100vw - 320px) / (640 - 320), 24px);
  }
}
.company .title .tit-ja {
  font-size: 36px;
  letter-spacing: 0.22em;
  font-weight: 700;
}
@media screen and (max-width: 1366px) {
  .company .title .tit-ja {
    font-size: 36rem;
  }
}
.company .title.center {
  text-align: center;
}
.company .title.center::after {
  right: 0;
  margin: auto;
}

.company_message {
  display: flex;
  gap: 80px;
  align-items: center;
  margin-bottom: 95px;
}
@media screen and (max-width: 1366px) {
  .company_message {
    gap: 80rem;
    margin-bottom: 95rem;
  }
}
@media screen and (max-width: 1024px) {
  .company_message {
    flex-direction: column;
    align-items: flex-start;
    gap: 45rem;
  }
}
.company_message .img {
  width: 38.579795022vw;
  height: 562px;
  border-radius: 0 45px 45px 0;
}
@media screen and (max-width: 1366px) {
  .company_message .img {
    height: 562rem;
    border-radius: 0 45rem 45rem 0;
  }
}
@media screen and (max-width: 1024px) {
  .company_message .img {
    width: 610rem;
    height: 400rem;
  }
}
.company_message .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0 45px 45px 0;
}
@media screen and (max-width: 1366px) {
  .company_message .img img {
    border-radius: 0 45rem 45rem 0;
  }
}
.company_message .text {
  width: 612px;
}
@media screen and (max-width: 1366px) {
  .company_message .text {
    width: 612rem;
  }
}
@media screen and (max-width: 1024px) {
  .company_message .text {
    margin: auto;
  }
}
@media screen and (max-width: 640px) {
  .company_message .text {
    width: 580rem;
  }
}
.company_message .text .message-body .message-catch {
  font-size: 2.4rem;
  line-height: 1.5;
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 20px;
}
@media screen and (max-width: 1366px) {
  .company_message .text .message-body .message-catch {
    font-size: 24rem;
    margin-bottom: 20rem;
  }
}
@media screen and (max-width: 1024px) {
  .company_message .text .message-body .message-catch {
    font-size: clamp(14px, 14px + (24 - 14) * (100vw - 320px) / (640 - 320), 24px);
  }
}
.company_message .text .message-body .message-text {
  font-size: 1.8rem;
  line-height: 2;
  font-size: 18px;
  font-weight: 500;
}
@media screen and (max-width: 1366px) {
  .company_message .text .message-body .message-text {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .company_message .text .message-body .message-text {
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
  }
}

.company_mvv {
  position: relative;
}
.company_mvv #waveCanvasImg2,
.company_mvv #waveCanvasOverlay2 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
}
.company_mvv #waveCanvasImg2 {
  object-fit: cover;
}
.company_mvv #waveCanvasOverlay2 {
  mix-blend-mode: multiply;
}
.company_mvv .content {
  position: relative;
  padding-top: 120px;
  padding-bottom: 80px;
  max-width: 1080px;
  width: 90%;
  margin: auto;
}
@media screen and (max-width: 1366px) {
  .company_mvv .content {
    padding-top: 120rem;
    padding-bottom: 80rem;
    max-width: 1080rem;
  }
}
.company_mvv .content .title {
  color: #fff;
  text-align: center;
  margin-bottom: 63px;
}
@media screen and (max-width: 1366px) {
  .company_mvv .content .title {
    margin-bottom: 63rem;
  }
}
.company_mvv .content .title::after {
  right: 0;
  margin: auto;
  background-image: radial-gradient(circle, #fff 5px, transparent 5px);
}
@media screen and (max-width: 1366px) {
  .company_mvv .content .title::after {
    background-image: radial-gradient(circle, #fff 5rem, transparent 5rem);
  }
}
.company_mvv .content .title .tit-en {
  color: #fff;
}
.company_mvv .content .mvv__block {
  margin-bottom: 66px;
}
@media screen and (max-width: 1366px) {
  .company_mvv .content .mvv__block {
    margin-bottom: 66rem;
  }
}
.company_mvv .content .mvv__block:last-child {
  margin-bottom: 0;
}
.company_mvv .content .mvv__block .sub {
  display: flex;
  gap: 2em;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 400;
  color: #fff;
}
@media screen and (max-width: 1366px) {
  .company_mvv .content .mvv__block .sub {
    font-size: 13rem;
  }
}
@media screen and (max-width: 1024px) {
  .company_mvv .content .mvv__block .sub {
    font-size: clamp(12px, 12px + (13 - 12) * (100vw - 320px) / (640 - 320), 13px);
  }
}
.company_mvv .content .mvv__block .sub svg {
  width: 8px;
  height: 10px;
}
@media screen and (max-width: 1366px) {
  .company_mvv .content .mvv__block .sub svg {
    width: 8rem;
    height: 10rem;
  }
}
.company_mvv .content .mvv__block .mvv__title-en {
  font-size: 4.8rem;
  line-height: 1.1041666667;
  font-size: 48px;
  font-family: "Acumin", sans-serif;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-align: center;
  position: relative;
  padding-bottom: 30px;
  margin-bottom: 38px;
}
@media screen and (max-width: 1366px) {
  .company_mvv .content .mvv__block .mvv__title-en {
    font-size: 48rem;
    padding-bottom: 30rem;
    margin-bottom: 38rem;
  }
}
.company_mvv .content .mvv__block .mvv__title-en::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 222px;
  height: 13px;
  margin: auto;
  background-image: radial-gradient(circle, #fff 6.5px, transparent 7px);
  background-size: 22.2px 13px;
  background-repeat: repeat-x;
}
@media screen and (max-width: 1366px) {
  .company_mvv .content .mvv__block .mvv__title-en::after {
    width: 222rem;
    height: 13rem;
    background-size: 22.2rem 13rem;
    background-image: radial-gradient(circle, #fff 6.5rem, transparent 7rem);
  }
}
.company_mvv .content .mvv__block .mvv__catch {
  color: #fff;
  text-align: center;
  font-weight: 700;
  font-size: 24px;
  letter-spacing: 0.22em;
  margin-bottom: 20px;
}
@media screen and (max-width: 1366px) {
  .company_mvv .content .mvv__block .mvv__catch {
    font-size: 24rem;
    margin-bottom: 20rem;
  }
}
@media screen and (max-width: 1024px) {
  .company_mvv .content .mvv__block .mvv__catch {
    font-size: clamp(14px, 14px + (24 - 14) * (100vw - 320px) / (640 - 320), 24px);
  }
}
.company_mvv .content .mvv__block .mvv__desc {
  font-size: 1.8rem;
  line-height: 1.7777777778;
  font-size: 18px;
  font-weight: 500;
  color: #fff;
  text-align: center;
}
@media screen and (max-width: 1366px) {
  .company_mvv .content .mvv__block .mvv__desc {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .company_mvv .content .mvv__block .mvv__desc {
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
    text-align: left;
  }
}
.company_mvv .content .mvv__block .mvv__list li {
  text-align: center;
  margin-bottom: 45px;
}
@media screen and (max-width: 1366px) {
  .company_mvv .content .mvv__block .mvv__list li {
    margin-bottom: 45rem;
  }
}
.company_mvv .content .mvv__block .mvv__list li:last-child {
  margin-bottom: 0;
}
.company_mvv .content .mvv__block .mvv__list li strong {
  font-size: 2.1rem;
  line-height: 1.9047619048;
  font-size: 21px;
  font-weight: 700;
  color: #dae551;
  display: inline-block;
  margin-bottom: 20px;
}
@media screen and (max-width: 1366px) {
  .company_mvv .content .mvv__block .mvv__list li strong {
    font-size: 21rem;
    margin-bottom: 20rem;
  }
}
@media screen and (max-width: 1024px) {
  .company_mvv .content .mvv__block .mvv__list li strong {
    font-size: clamp(15px, 15px + (21 - 15) * (100vw - 320px) / (640 - 320), 21px);
  }
}
.company_mvv .content .mvv__block.green .mvv__title-en {
  color: rgba(56, 229, 109, 0.75);
}
.company_mvv .content .mvv__block.green .mvv__title-en::after {
  background-image: radial-gradient(circle, rgba(56, 229, 109, 0.75) 6.5px, transparent 7px);
}
@media screen and (max-width: 1366px) {
  .company_mvv .content .mvv__block.green .mvv__title-en::after {
    background-image: radial-gradient(circle, rgba(56, 229, 109, 0.75) 6.5rem, transparent 7rem);
  }
}
.company_mvv .content .mvv__block.blue .mvv__title-en {
  color: #4cf2f2;
}
.company_mvv .content .mvv__block.blue .mvv__title-en::after {
  background-image: radial-gradient(circle, #4cf2f2 6.5px, transparent 7px);
}
@media screen and (max-width: 1366px) {
  .company_mvv .content .mvv__block.blue .mvv__title-en::after {
    background-image: radial-gradient(circle, #4cf2f2 6.5rem, transparent 7rem);
  }
}
.company_mvv .content .mvv__block.yellow .mvv__title-en {
  color: rgba(218, 229, 81, 0.75);
}
.company_mvv .content .mvv__block.yellow .mvv__title-en::after {
  background-image: radial-gradient(circle, rgba(218, 229, 81, 0.75) 6.5px, transparent 7px);
}
@media screen and (max-width: 1366px) {
  .company_mvv .content .mvv__block.yellow .mvv__title-en::after {
    background-image: radial-gradient(circle, rgba(218, 229, 81, 0.75) 6.5rem, transparent 7rem);
  }
}

.company_about .inner {
  padding-top: 120px;
  padding-bottom: 170px;
}
@media screen and (max-width: 1366px) {
  .company_about .inner {
    padding-top: 120rem;
    padding-bottom: 170rem;
  }
}
.company_about .inner .title {
  margin-bottom: 90px;
}
@media screen and (max-width: 1366px) {
  .company_about .inner .title {
    margin-bottom: 90rem;
  }
}

.company_showroom .inner .title {
  margin-bottom: 90px;
}
@media screen and (max-width: 1366px) {
  .company_showroom .inner .title {
    margin-bottom: 90rem;
  }
}
.company_showroom .inner .map {
  border-radius: 30px;
  margin-bottom: 56px;
}
@media screen and (max-width: 1366px) {
  .company_showroom .inner .map {
    border-radius: 30rem;
    margin-bottom: 56rem;
  }
}
.company_showroom .inner .map iframe {
  width: 100%;
  height: 585px;
  border-radius: 30px;
}
@media screen and (max-width: 1366px) {
  .company_showroom .inner .map iframe {
    height: 585rem;
    border-radius: 30rem;
  }
}
@media screen and (max-width: 1024px) {
  .company_showroom .inner .map iframe {
    height: 300rem;
  }
}
.company_showroom .showroom-swiper {
  width: 914px; /* 2枚分＋余白 */
  margin: 0 auto;
  overflow: visible;
}
@media screen and (max-width: 1366px) {
  .company_showroom .showroom-swiper {
    width: 918rem;
  }
}
@media screen and (max-width: 1024px) {
  .company_showroom .showroom-swiper {
    width: 100%;
  }
}
.company_showroom .showroom-swiper .swiper-slide {
  width: 447px;
  aspect-ratio: 1/1;
  border-radius: 45px;
}
@media screen and (max-width: 1366px) {
  .company_showroom .showroom-swiper .swiper-slide {
    width: 447px;
    border-radius: 45rem;
  }
}
@media screen and (max-width: 1024px) {
  .company_showroom .showroom-swiper .swiper-slide {
    border-radius: 20rem;
    width: auto;
  }
}
.company_showroom .showroom-swiper .swiper-slide img {
  border-radius: 45px;
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}
@media screen and (max-width: 1366px) {
  .company_showroom .showroom-swiper .swiper-slide img {
    border-radius: 45rem;
  }
}

.company_history .inner {
  padding: 136px 0;
}
@media screen and (max-width: 1366px) {
  .company_history .inner {
    padding: 136rem 0;
  }
}
.company_history .inner .title {
  margin-bottom: 90px;
}
@media screen and (max-width: 1366px) {
  .company_history .inner .title {
    margin-bottom: 90rem;
  }
}
.company_history .inner .tablecontents .item:last-child {
  padding-bottom: 28px;
  border-bottom: 1px solid #d9dada;
}
@media screen and (max-width: 1366px) {
  .company_history .inner .tablecontents .item:last-child {
    padding-bottom: 28rem;
  }
}

.company_access .inner .title {
  margin-bottom: 60px;
}
@media screen and (max-width: 1366px) {
  .company_access .inner .title {
    margin-bottom: 60rem;
  }
}
.company_access .inner .access-body .map {
  border-radius: 30px;
  margin-bottom: 32px;
}
@media screen and (max-width: 1366px) {
  .company_access .inner .access-body .map {
    border-radius: 30rem;
    margin-bottom: 32rem;
  }
}
.company_access .inner .access-body .map iframe {
  width: 100%;
  height: 585px;
  border-radius: 30px;
}
@media screen and (max-width: 1366px) {
  .company_access .inner .access-body .map iframe {
    height: 585rem;
    border-radius: 30rem;
  }
}
@media screen and (max-width: 1024px) {
  .company_access .inner .access-body .map iframe {
    height: 300rem;
  }
}
.company_access .inner .access-body .text {
  text-align: center;
  font-size: 16px;
  font-weight: 500;
}
@media screen and (max-width: 1366px) {
  .company_access .inner .access-body .text {
    font-size: 16rem;
  }
}
@media screen and (max-width: 1024px) {
  .company_access .inner .access-body .text {
    font-size: clamp(14px, 14px + (16 - 14) * (100vw - 320px) / (640 - 320), 16px);
  }
}

@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "Acumin";
  src: url("../fonts/Acumin-Pro-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
}
.t_catch {
  background: url(../img/top/lookone.png) no-repeat center/contain;
  margin-bottom: 166px;
}
@media screen and (max-width: 1366px) {
  .t_catch {
    margin-bottom: 166rem;
  }
}
.t_catch .inner {
  display: flex;
  flex-direction: column;
  gap: 93px;
  align-items: flex-start;
  position: relative;
}
@media screen and (max-width: 1366px) {
  .t_catch .inner {
    gap: 93rem;
    max-width: 1366rem;
  }
}
@media screen and (max-width: 1024px) {
  .t_catch .inner {
    gap: 63rem;
    max-width: 581rem;
  }
}
.t_catch .inner .img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
.t_catch .inner .img .deco01 {
  position: absolute;
  top: 54px;
  left: -106px;
  width: 184px;
  height: 237px;
}
@media screen and (max-width: 1366px) {
  .t_catch .inner .img .deco01 {
    top: 54rem;
    left: -106rem;
    width: 184rem;
    height: 237rem;
  }
}
@media screen and (max-width: 1024px) {
  .t_catch .inner .img .deco01 {
    width: 186rem;
    height: 236rem;
    top: auto;
    bottom: -155rem;
    left: -61rem;
    transform: rotate(-77deg);
  }
}
.t_catch .inner .img .deco02 {
  position: absolute;
  bottom: -103px;
  left: -106px;
  width: 252px;
  height: 299px;
}
@media screen and (max-width: 1366px) {
  .t_catch .inner .img .deco02 {
    bottom: -103rem;
    left: -106rem;
    width: 252rem;
    height: 299rem;
  }
}
@media screen and (max-width: 1024px) {
  .t_catch .inner .img .deco02 {
    width: 157rem;
    height: 187rem;
    bottom: -155rem;
    right: -75px;
    left: auto;
  }
}
.t_catch .inner .img .deco03 {
  position: absolute;
  right: 0;
  top: 26px;
  width: 218px;
  height: 311px;
}
@media screen and (max-width: 1366px) {
  .t_catch .inner .img .deco03 {
    top: 26rem;
    width: 218rem;
    height: 311rem;
  }
}
@media screen and (max-width: 1024px) {
  .t_catch .inner .img .deco03 {
    right: -73rem;
    bottom: 232rem;
    width: 169rem;
    height: 241rem;
  }
}
.t_catch .inner .deco04 {
  position: absolute;
  right: -84px;
  bottom: -103px;
  width: 243px;
  height: 207px;
}
@media screen and (max-width: 1366px) {
  .t_catch .inner .deco04 {
    right: -84rem;
    bottom: -103rem;
    width: 243rem;
    height: 207rem;
  }
}
@media screen and (max-width: 1024px) {
  .t_catch .inner .deco04 {
    top: -166rem;
    right: -27rem;
    z-index: -1;
  }
}
.t_catch .inner .title {
  margin-left: 106px;
}
@media screen and (max-width: 1366px) {
  .t_catch .inner .title {
    margin-left: 106rem;
  }
}
@media screen and (max-width: 1024px) {
  .t_catch .inner .title {
    margin-left: 0;
  }
}
.t_catch .inner .title .logo {
  margin-bottom: 42px;
  width: 335px;
}
@media screen and (max-width: 1366px) {
  .t_catch .inner .title .logo {
    margin-bottom: 42rem;
    width: 335rem;
  }
}
@media screen and (max-width: 1024px) {
  .t_catch .inner .title .logo {
    margin-bottom: 52rem;
  }
}
.t_catch .inner .title .logo img {
  width: 100%;
  height: auto;
}
.t_catch .inner .title .catch {
  font-weight: 700;
  letter-spacing: 0.22em;
  text-decoration: underline;
  text-underline-offset: 12px;
  font-size: 4.8rem;
  line-height: 1.625;
  font-size: 48px;
}
@media screen and (max-width: 1366px) {
  .t_catch .inner .title .catch {
    font-size: 48rem;
    text-underline-offset: 12rem;
  }
}
@media screen and (max-width: 1024px) {
  .t_catch .inner .title .catch {
    font-size: 36rem;
  }
}
.t_catch .inner .catch__body {
  margin: auto;
}
.t_catch .inner .catch__body .text {
  font-size: 2.8rem;
  line-height: 2.0714285714;
  font-size: 28px;
  font-weight: 500;
}
@media screen and (max-width: 1366px) {
  .t_catch .inner .catch__body .text {
    font-size: 28rem;
  }
}
@media screen and (max-width: 1024px) {
  .t_catch .inner .catch__body .text {
    font-size: 2.1rem;
    line-height: 2.4761904762;
    font-size: clamp(12px, 12px + (21 - 12) * (100vw - 320px) / (640 - 320), 21px);
  }
}

.strengths_list {
  display: flex;
  gap: 13px;
  margin-bottom: 30px;
}
@media screen and (max-width: 1366px) {
  .strengths_list {
    gap: 13rem;
    margin-bottom: 30rem;
  }
}
@media screen and (max-width: 1024px) {
  .strengths_list {
    flex-direction: column;
    gap: 21rem;
  }
}
.strengths_list.mb0 {
  margin-bottom: 0;
}
.strengths_list.reverse {
  flex-direction: row-reverse;
}
@media screen and (max-width: 1024px) {
  .strengths_list.reverse {
    flex-direction: column;
  }
}
.strengths_list.reverse .img {
  border-radius: 45px 0 0 45px;
}
@media screen and (max-width: 1366px) {
  .strengths_list.reverse .img {
    border-radius: 45rem 0 0 45rem;
  }
}
@media screen and (max-width: 1024px) {
  .strengths_list.reverse .img {
    margin-left: auto;
  }
}
.strengths_list.reverse .img img {
  border-radius: 45px 0 0 45px;
}
@media screen and (max-width: 1366px) {
  .strengths_list.reverse .img img {
    border-radius: 45rem 0 0 45rem;
  }
}
.strengths_list.reverse .text {
  border-radius: 0 45px 45px 0;
  padding-right: 4.9048316252vw;
  padding-left: 10.4685212299vw;
}
@media screen and (max-width: 1366px) {
  .strengths_list.reverse .text {
    border-radius: 0 45rem 45rem 0;
  }
}
@media screen and (max-width: 1024px) {
  .strengths_list.reverse .text {
    margin-right: auto;
    margin-left: 0;
    padding-right: 15rem;
    padding-left: 21rem;
  }
}
.strengths_list.reverse .text::after {
  left: 4.2459736457vw;
  right: auto;
}
@media screen and (max-width: 1024px) {
  .strengths_list.reverse .text::after {
    left: 21rem;
  }
}
.strengths_list .img {
  width: 38.579795022vw;
  height: 562px;
  border-radius: 0 45px 45px 0;
}
@media screen and (max-width: 1366px) {
  .strengths_list .img {
    height: 562rem;
    border-radius: 0 45rem 45rem 0;
  }
}
@media screen and (max-width: 1024px) {
  .strengths_list .img {
    width: 610rem;
    height: 400rem;
  }
}
.strengths_list .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0 45px 45px 0;
}
@media screen and (max-width: 1366px) {
  .strengths_list .img img {
    border-radius: 0 45rem 45rem 0;
  }
}
.strengths_list .text {
  width: 60.3953147877vw;
  border-radius: 45px 0 0 45px;
  padding-left: 4.9048316252vw;
  padding-right: 10.4685212299vw;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
}
@media screen and (max-width: 1366px) {
  .strengths_list .text {
    border-radius: 45rem 0 0 45rem;
  }
}
@media screen and (max-width: 1024px) {
  .strengths_list .text {
    width: 610rem;
    margin-left: auto;
    padding-top: 172rem;
    padding-left: 15rem;
    padding-right: 21rem;
    padding-bottom: 75rem;
  }
}
.strengths_list .text::after {
  content: "";
  position: absolute;
  color: rgba(255, 255, 255, 0.5);
  font-size: 45px;
  font-weight: 600;
  font-family: "Acumin", sans-serif;
  writing-mode: vertical-lr;
  letter-spacing: 0.16em;
  right: 4.2459736457vw;
  top: 0;
  bottom: 0;
  margin: auto;
  width: fit-content;
  height: fit-content;
}
@media screen and (max-width: 1366px) {
  .strengths_list .text::after {
    font-size: 45rem;
  }
}
@media screen and (max-width: 1024px) {
  .strengths_list .text::after {
    bottom: auto;
    top: 60rem;
    writing-mode: horizontal-tb;
    right: auto;
    left: 21rem;
  }
}
.strengths_list .text.color01 {
  background-color: #67c1c6;
}
.strengths_list .text.color01::after {
  content: "STRENGTHS.01";
}
.strengths_list .text.color02 {
  background-color: #69c489;
}
.strengths_list .text.color02::after {
  content: "STRENGTHS.02";
}
.strengths_list .text.color03 {
  background-color: #b6c168;
}
.strengths_list .text.color03::after {
  content: "STRENGTHS.03";
}
.strengths_list .text.color04 {
  background-color: #678dc9;
}
.strengths_list .text.color04::after {
  content: "STRENGTHS.04";
}
.strengths_list .text.color05 {
  background-color: #f4c37d;
}
.strengths_list .text.color05::after {
  content: "STRENGTHS.05";
}
.strengths_list .text .title {
  padding-bottom: 36px;
  margin-bottom: 42px;
  position: relative;
}
@media screen and (max-width: 1366px) {
  .strengths_list .text .title {
    padding-bottom: 36rem;
    margin-bottom: 42rem;
  }
}
.strengths_list .text .title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 175px;
  height: 10px;
  margin: auto;
  background-image: radial-gradient(circle, #fff 5px, transparent 5px);
  background-size: 17.5px 10px;
  background-repeat: repeat-x;
}
@media screen and (max-width: 1366px) {
  .strengths_list .text .title::after {
    width: 175rem;
    height: 10rem;
    background-size: 17.5rem 10rem;
    background-image: radial-gradient(circle, #fff 5rem, transparent 5rem);
  }
}
.strengths_list .text .title .tit-en {
  color: #fff;
  font-size: 24px;
  font-family: "Acumin", sans-serif;
  font-weight: 600;
  letter-spacing: 0.16em;
}
@media screen and (max-width: 1366px) {
  .strengths_list .text .title .tit-en {
    font-size: 24rem;
  }
}
.strengths_list .text .title .tit-ja {
  font-size: 3.5rem;
  line-height: 1.4285714286;
  font-size: 36px;
  color: #fff;
  letter-spacing: 0.22em;
  font-weight: 700;
}
@media screen and (max-width: 1366px) {
  .strengths_list .text .title .tit-ja {
    font-size: 36rem;
  }
}
.strengths_list .text .list-body .strengths-catch {
  font-size: 2.4rem;
  line-height: 1.5;
  color: #fff;
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 12px;
}
@media screen and (max-width: 1366px) {
  .strengths_list .text .list-body .strengths-catch {
    font-size: 24rem;
    margin-bottom: 12rem;
  }
}
@media screen and (max-width: 1024px) {
  .strengths_list .text .list-body .strengths-catch {
    font-size: clamp(16px, 16px + (24 - 16) * (100vw - 320px) / (640 - 320), 24px);
  }
}
.strengths_list .text .list-body .strengths-text {
  font-size: 1.8rem;
  line-height: 2;
  font-size: 18px;
  color: #fff;
  font-weight: 500;
}
@media screen and (max-width: 1366px) {
  .strengths_list .text .list-body .strengths-text {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .strengths_list .text .list-body .strengths-text {
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
  }
}
@media screen and (max-width: 640px) {
  .strengths_list .text .list-body .strengths-text .pc {
    display: none;
  }
}

@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "Acumin";
  src: url("../fonts/Acumin-Pro-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
}
.service .desc {
  font-size: 1.8rem;
  line-height: 2;
  font-size: 18px;
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 1366px) {
  .service .desc {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .service .desc {
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.service .sec-subttl {
  font-size: 21px;
  font-weight: 700;
  padding-bottom: 32px;
  position: relative;
  text-align: center;
}
@media screen and (max-width: 1366px) {
  .service .sec-subttl {
    font-size: 21rem;
    padding-bottom: 32rem;
  }
}
@media screen and (max-width: 1024px) {
  .service .sec-subttl {
    font-size: clamp(16px, 16px + (21 - 16) * (100vw - 320px) / (640 - 320), 21px);
  }
}
.service .sec-subttl::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 162px;
  height: 8px;
  margin: auto;
  background-image: radial-gradient(circle, #1f4c9f 4px, transparent 4px);
  background-size: 14.7272727273px 8px;
  background-repeat: repeat-x;
}
@media screen and (max-width: 1366px) {
  .service .sec-subttl::after {
    width: 162rem;
    height: 8rem;
    background-size: 14.7272727273rem 8rem;
    background-image: radial-gradient(circle, #1f4c9f 4rem, transparent 4rem);
  }
}
.service .sec-title .tit-ja {
  position: relative;
  font-size: 36px;
  padding-bottom: 36px;
  letter-spacing: 0.22em;
  font-weight: 700;
}
@media screen and (max-width: 1366px) {
  .service .sec-title .tit-ja {
    font-size: 36rem;
    padding-bottom: 36rem;
  }
}
.service .sec-title .tit-ja::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 175px;
  height: 10px;
  margin: auto;
  background-image: radial-gradient(circle, #1f4c9f 5px, transparent 5px);
  background-size: 17.5px 10px;
  background-repeat: repeat-x;
}
@media screen and (max-width: 1366px) {
  .service .sec-title .tit-ja::after {
    width: 175rem;
    height: 10rem;
    background-size: 17.5rem 10rem;
    background-image: radial-gradient(circle, #1f4c9f 5rem, transparent 5rem);
  }
}
.service .sec-title .tit-ja.center {
  text-align: center;
}
.service .sec-title .tit-ja.center::after {
  right: 0;
  margin: auto;
}
.service .service-swiper .swiper-slide {
  width: 492px;
  height: 492px;
  border-radius: 45px;
  margin-left: 29px;
}
@media screen and (max-width: 1366px) {
  .service .service-swiper .swiper-slide {
    width: 492rem;
    height: 492rem;
    border-radius: 45rem;
    margin-left: 29rem;
  }
}
.service .service-swiper .swiper-slide img {
  width: 100%;
  height: 100%;
  border-radius: 45px;
}
@media screen and (max-width: 1366px) {
  .service .service-swiper .swiper-slide img {
    border-radius: 45rem;
  }
}
.service .service-swiper .swiper-pagination-bullet {
  width: 16px;
  height: 16px;
  background: #d6d7d8;
  opacity: 1;
  margin: 0;
  margin-right: 6px;
}
@media screen and (max-width: 1366px) {
  .service .service-swiper .swiper-pagination-bullet {
    width: 16rem;
    height: 16rem;
    margin-right: 6rem;
  }
}
@media screen and (max-width: 1024px) {
  .service .service-swiper .swiper-pagination-bullet {
    width: 16rem;
    height: 16rem;
    margin-right: 6rem;
  }
}
.service .service-swiper .swiper-pagination-bullet:last-child {
  margin-right: 0;
}
.service .service-swiper .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background: #1f4c9f;
}
.service .int_product {
  position: relative;
  border-radius: 45px;
  background-color: rgba(231, 237, 247, 0.5);
  display: flex;
  flex-direction: column;
  gap: 30px;
  padding: 42px 0 60px;
  border: 1px solid #e6e6e6;
}
@media screen and (max-width: 1366px) {
  .service .int_product {
    border-radius: 45rem;
    gap: 30rem;
    padding: 42rem 0 60rem;
    border: 1rem solid #e6e6e6;
  }
}
@media screen and (max-width: 1024px) {
  .service .int_product {
    padding: 30rem 0;
  }
}
.service .int_product .desc {
  width: 87.037037037%;
  margin: auto;
}
.service .int_product .deco01 {
  position: absolute;
  top: -65px;
  left: -25px;
}
@media screen and (max-width: 1366px) {
  .service .int_product .deco01 {
    top: -65rem;
    left: -25rem;
  }
}
@media screen and (max-width: 1024px) {
  .service .int_product .deco01 {
    width: 132rem;
    height: 157rem;
    left: -56rem;
  }
  .service .int_product .deco01 img {
    width: 100%;
    height: auto;
  }
}
.service .int_product .deco02 {
  position: absolute;
  right: -84px;
  bottom: -38px;
}
@media screen and (max-width: 1366px) {
  .service .int_product .deco02 {
    right: -84rem;
    bottom: -38rem;
  }
}
@media screen and (max-width: 1024px) {
  .service .int_product .deco02 {
    width: 117rem;
    height: 168rem;
    right: -30rem;
    bottom: -96rem;
  }
  .service .int_product .deco02 img {
    width: 100%;
    height: auto;
  }
}

.service_open .sec-title {
  margin-bottom: 50px;
}
@media screen and (max-width: 1366px) {
  .service_open .sec-title {
    margin-bottom: 50rem;
  }
}
.service_open .sec-title .tit-ja {
  margin-bottom: 45px;
}
@media screen and (max-width: 1366px) {
  .service_open .sec-title .tit-ja {
    margin-bottom: 45rem;
  }
}
.service_open .int_product {
  margin-top: 108px;
  margin-bottom: 83px;
}
@media screen and (max-width: 1366px) {
  .service_open .int_product {
    margin-top: 108rem;
    margin-bottom: 83rem;
  }
}

.service_openflow {
  position: relative;
  min-height: 400px;
}
.service_openflow.open::before {
  content: "OPEN OPEN";
  position: absolute;
  top: -111px;
  left: 0;
  right: 0;
  text-align: center;
  margin: auto;
  z-index: -1;
  font-size: 22.4rem;
  line-height: 1.1116071429;
  font-size: 224px;
  letter-spacing: 0.02em;
  font-family: "Acumin", sans-serif;
  font-weight: 600;
  color: rgba(103, 141, 201, 0.4);
}
@media screen and (max-width: 1366px) {
  .service_openflow.open::before {
    top: -111rem;
    font-size: 224rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_openflow.open::before {
    left: -382rem;
    right: auto;
  }
}
.service_openflow.buy::before {
  content: "";
  position: absolute;
  top: -74px;
  left: 0;
  right: 0;
  text-align: center;
  margin: auto;
  z-index: -1;
  background: url(../img/service/t-scroll.svg) no-repeat center/contain;
  width: 100%;
  height: 159px;
}
@media screen and (max-width: 1366px) {
  .service_openflow.buy::before {
    top: -74rem;
    height: 159rem;
    background: url(../img/service/t-scroll.svg) no-repeat center/cover;
  }
}
.service_openflow .waveCanvasImg-flow,
.service_openflow .waveCanvasOverlay-flow {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
}
.service_openflow .content {
  position: relative;
  padding-top: 150px;
  padding-bottom: 87px;
}
@media screen and (max-width: 1366px) {
  .service_openflow .content {
    padding-top: 150rem;
    padding-bottom: 87rem;
  }
}
.service_openflow .content .sec-title {
  color: #fff;
  margin-bottom: 62px;
}
@media screen and (max-width: 1366px) {
  .service_openflow .content .sec-title {
    margin-bottom: 62rem;
  }
}
.service_openflow .content .sec-title .tit-ja::after {
  background-image: radial-gradient(circle, #fff 4px, transparent 4px);
}
@media screen and (max-width: 1366px) {
  .service_openflow .content .sec-title .tit-ja::after {
    background-image: radial-gradient(circle, #fff 4rem, transparent 4rem);
  }
}
.service_openflow .content .sec-title .desc {
  font-weight: 700;
  margin-top: 42px;
}
@media screen and (max-width: 1366px) {
  .service_openflow .content .sec-title .desc {
    margin-top: 42rem;
  }
}
.service_openflow .content .flow-swiper {
  padding-bottom: 120px;
}
@media screen and (max-width: 1366px) {
  .service_openflow .content .flow-swiper {
    padding-bottom: 120rem;
  }
}
.service_openflow .content .flow-swiper .swiper-slide {
  border-radius: 34px;
  background-color: rgba(255, 255, 255, 0.85);
}
@media screen and (max-width: 1366px) {
  .service_openflow .content .flow-swiper .swiper-slide {
    border-radius: 34rem;
  }
}
.service_openflow .content .flow-swiper .swiper-slide .slide-header {
  position: relative;
  padding-bottom: 46px;
  border-bottom: 1px solid #1f4c9f;
  padding-top: 25px;
}
@media screen and (max-width: 1366px) {
  .service_openflow .content .flow-swiper .swiper-slide .slide-header {
    padding-bottom: 46rem;
    padding-top: 25rem;
    border-bottom: 1rem solid #1f4c9f;
  }
}
.service_openflow .content .flow-swiper .swiper-slide .slide-header .slidenum {
  position: absolute;
  top: 0;
  left: 0;
  font-weight: 700;
  font-size: 43px;
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 88px;
  height: 88px;
  background-color: #1f4c9f;
  border-radius: 34px 0 42px 0;
}
@media screen and (max-width: 1366px) {
  .service_openflow .content .flow-swiper .swiper-slide .slide-header .slidenum {
    font-size: 43rem;
    width: 88rem;
    height: 88rem;
    border-radius: 34rem 0 42rem 0;
  }
}
.service_openflow .content .flow-swiper .swiper-slide .slide-header .flow-ttl {
  width: 77.962962963%;
  margin: auto auto 40px;
  font-size: 30px;
  font-weight: 700;
  letter-spacing: 0.22em;
}
@media screen and (max-width: 1366px) {
  .service_openflow .content .flow-swiper .swiper-slide .slide-header .flow-ttl {
    margin: auto auto 40rem;
    font-size: 30rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_openflow .content .flow-swiper .swiper-slide .slide-header .flow-ttl {
    width: 56.8965517241%;
  }
}
.service_openflow .content .flow-swiper .swiper-slide .slide-header .desc {
  width: 77.962962963%;
  margin: auto;
  text-align: left;
}
@media screen and (max-width: 1024px) {
  .service_openflow .content .flow-swiper .swiper-slide .slide-header .desc {
    width: 550rem;
  }
}
.service_openflow .content .flow-swiper .swiper-slide .slide-body {
  padding: 28px 0 62px;
  display: flex;
  gap: 27px;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 1366px) {
  .service_openflow .content .flow-swiper .swiper-slide .slide-body {
    padding: 28rem 0 62rem;
    gap: 27rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_openflow .content .flow-swiper .swiper-slide .slide-body .img img {
    width: 63rem;
    height: auto;
  }
}
.service_openflow .content .flow-swiper .swiper-slide .slide-body .text {
  width: 68.1481481481%;
}
@media screen and (max-width: 1024px) {
  .service_openflow .content .flow-swiper .swiper-slide .slide-body .text {
    width: 81.724137931%;
  }
}
.service_openflow .content .flow-swiper .swiper-slide .slide-body .text .catch {
  color: #1f4c9f;
  font-size: 21px;
  font-weight: 700;
  font-feature-settings: "palt";
}
@media screen and (max-width: 1366px) {
  .service_openflow .content .flow-swiper .swiper-slide .slide-body .text .catch {
    font-size: 21rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_openflow .content .flow-swiper .swiper-slide .slide-body .text .catch {
    font-size: clamp(16px, 16px + (21 - 16) * (100vw - 320px) / (640 - 320), 21px);
  }
}
.service_openflow .content .flow-swiper .swiper-slide .slide-body .text .desc {
  font-size: 1.6rem;
  line-height: 2.25;
  font-size: 16px;
  text-align: left;
}
@media screen and (max-width: 1366px) {
  .service_openflow .content .flow-swiper .swiper-slide .slide-body .text .desc {
    font-size: 16rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_openflow .content .flow-swiper .swiper-slide .slide-body .text .desc {
    font-size: clamp(14px, 14px + (16 - 14) * (100vw - 320px) / (640 - 320), 16px);
  }
}
.service_openflow .content .flow-swiper .swiper-button-prev,
.service_openflow .content .flow-swiper .swiper-button-next {
  width: 62px;
  height: 62px;
  left: 43.5185185185%;
  bottom: 0;
  top: auto;
}
@media screen and (max-width: 1366px) {
  .service_openflow .content .flow-swiper .swiper-button-prev,
  .service_openflow .content .flow-swiper .swiper-button-next {
    width: 62rem;
    height: 62rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_openflow .content .flow-swiper .swiper-button-prev,
  .service_openflow .content .flow-swiper .swiper-button-next {
    left: 38.275862069%;
  }
}
.service_openflow .content .flow-swiper .swiper-button-prev::after,
.service_openflow .content .flow-swiper .swiper-button-next::after {
  content: none;
}
.service_openflow .content .flow-swiper .swiper-button-next {
  left: auto;
  right: 43.5185185185%;
}
@media screen and (max-width: 1024px) {
  .service_openflow .content .flow-swiper .swiper-button-next {
    right: 38.275862069%;
  }
}

.service_used {
  padding-top: 83px;
  padding-bottom: 78px;
}
@media screen and (max-width: 1366px) {
  .service_used {
    padding-top: 83rem;
    padding-bottom: 78rem;
  }
}
.service_used .sec-title {
  margin-bottom: 50px;
}
@media screen and (max-width: 1366px) {
  .service_used .sec-title {
    margin-bottom: 50rem;
  }
}
.service_used .sec-title .tit-ja {
  color: #67c1c6;
  margin-bottom: 40px;
}
@media screen and (max-width: 1366px) {
  .service_used .sec-title .tit-ja {
    margin-bottom: 40rem;
  }
}
.service_used .sec-title .tit-ja::after {
  background-image: radial-gradient(circle, #67c1c6 4px, transparent 4px);
}
@media screen and (max-width: 1366px) {
  .service_used .sec-title .tit-ja::after {
    background-image: radial-gradient(circle, #67c1c6 4rem, transparent 4rem);
  }
}
.service_used .int_product {
  margin-top: 145px;
  margin-bottom: 70px;
}
@media screen and (max-width: 1366px) {
  .service_used .int_product {
    margin-top: 145rem;
    margin-bottom: 70rem;
  }
}
.service_used .makers {
  margin-bottom: 95px;
}
@media screen and (max-width: 1366px) {
  .service_used .makers {
    margin-bottom: 95rem;
  }
}
.service_used .makers .sec-subttl {
  margin-bottom: 48px;
}
@media screen and (max-width: 1366px) {
  .service_used .makers .sec-subttl {
    margin-bottom: 48rem;
  }
}
.service_used .makers .makers-list {
  display: grid;
  justify-items: center;
  align-items: center;
  gap: 30px 40px;
  list-style: none;
  margin: 0 0 40px;
  padding: 0;
}
@media screen and (max-width: 1366px) {
  .service_used .makers .makers-list {
    gap: 30rem 40rem;
    margin: 0 0 40rem;
  }
}
.service_used .makers .makers-list.row-4 {
  grid-template-columns: repeat(4, 1fr);
}
.service_used .makers .makers-list.row-3 {
  display: flex;
  justify-content: center;
  column-gap: 40px;
  margin-bottom: 0;
}
@media screen and (max-width: 1366px) {
  .service_used .makers .makers-list.row-3 {
    column-gap: 40rem;
  }
}
.service_used .makers .makers-list img {
  max-width: 100%;
  height: auto;
  display: block;
}
.service_used .products .used__list02 {
  max-width: 1382px;
  width: 100%;
  margin: auto;
  z-index: 15;
}
@media screen and (max-width: 1366px) {
  .service_used .products .used__list02 {
    max-width: 1382rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_used .products .used__list02 {
    max-width: 100%;
    width: 100%;
  }
}
.service_used .products .used__list02 .swiper-slide {
  flex: 0 0 calc((100% - 90px) / 4);
  max-width: calc((100% - 90px) / 4);
  margin-right: 30px;
}
@media screen and (max-width: 1366px) {
  .service_used .products .used__list02 .swiper-slide {
    margin-right: 30rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_used .products .used__list02 .swiper-slide {
    flex: none;
    max-width: none;
    width: 322rem;
    margin-right: 13rem;
  }
}
.service_used .products .used__list02 .swiper-slide:last-child {
  margin-right: 0;
}
.service_used .products .used__list02 .swiper-slide .used__item .used__thumb {
  width: 100%;
  height: 214px;
  border-radius: 25px;
  margin-bottom: 13px;
}
@media screen and (max-width: 1366px) {
  .service_used .products .used__list02 .swiper-slide .used__item .used__thumb {
    height: 214rem;
    border-radius: 25rem;
    margin-bottom: 13rem;
  }
}
.service_used .products .used__list02 .swiper-slide .used__item .used__thumb img {
  width: 100%;
  height: 100%;
  border-radius: 25px;
  object-fit: cover;
}
@media screen and (max-width: 1366px) {
  .service_used .products .used__list02 .swiper-slide .used__item .used__thumb img {
    border-radius: 25rem;
  }
}
.service_used .products .used__list02 .swiper-slide .used__item .element {
  display: flex;
  justify-content: space-between;
}
.service_used .products .used__list02 .swiper-slide .used__item .element .used__date {
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 0.1em;
  color: #cccccc;
}
@media screen and (max-width: 1366px) {
  .service_used .products .used__list02 .swiper-slide .used__item .element .used__date {
    font-size: 16rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_used .products .used__list02 .swiper-slide .used__item .element .used__date {
    font-size: clamp(12px, 12px + (16 - 12) * (100vw - 320px) / (640 - 320), 16px);
  }
}
.service_used .products .used__list02 .swiper-slide .used__item .element .used__cat {
  color: #1f4c9f;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 0.1em;
  position: relative;
  display: flex;
  align-items: center;
  gap: 8px;
}
@media screen and (max-width: 1366px) {
  .service_used .products .used__list02 .swiper-slide .used__item .element .used__cat {
    font-size: 16rem;
    gap: 8rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_used .products .used__list02 .swiper-slide .used__item .element .used__cat {
    font-size: clamp(12px, 12px + (16 - 12) * (100vw - 320px) / (640 - 320), 16px);
  }
}
.service_used .products .used__list02 .swiper-slide .used__item .element .used__cat::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background-color: #1f4c9f;
}
.service_used .products .used__list02 .swiper-slide .used__item .used__heading {
  font-weight: 500;
  font-size: 1.8rem;
  line-height: 1.7777777778;
  font-size: 18px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 1;
}
@media screen and (max-width: 1366px) {
  .service_used .products .used__list02 .swiper-slide .used__item .used__heading {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_used .products .used__list02 .swiper-slide .used__item .used__heading {
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.service_used .products .btn {
  width: 336px;
  border-radius: 32px;
  font-size: 18px;
  font-weight: 700;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding-right: 21px;
  height: 65px;
  color: #fff;
  background-color: #67c1c6;
  gap: 70px;
  margin: 90px auto auto;
  filter: drop-shadow(2px 6px 0px #cccccc);
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  .service_used .products .btn {
    width: 336rem;
    border-radius: 32rem;
    font-size: 18rem;
    padding-right: 21rem;
    height: 65rem;
    gap: 70rem;
    margin-top: 90rem;
    filter: drop-shadow(2rem 6rem 0px #cccccc);
  }
}
@media screen and (max-width: 1024px) {
  .service_used .products .btn {
    width: 389rem;
    justify-content: center;
    padding-right: 0;
    gap: 22rem;
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
    height: 64rem;
    filter: drop-shadow(2rem 6rem 0px #cccccc);
  }
  .service_used .products .btn:hover {
    transform: translateY(6rem);
    filter: drop-shadow(2rem 0px 0px #cccccc);
  }
}
.service_used .products .btn svg {
  width: 15px;
  height: 12px;
}
@media screen and (max-width: 1366px) {
  .service_used .products .btn svg {
    width: 15rem;
    height: 12rem;
  }
}
.service_used .products .btn:hover {
  transform: translateY(6px);
  filter: drop-shadow(2px 0px 0px #cccccc);
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  .service_used .products .btn:hover {
    transform: translateY(6rem);
    filter: drop-shadow(2rem 0px 0px #cccccc);
  }
}

.service_design {
  background-color: #67c1c6;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 640px) {
  .service_design .sec-title .desc {
    text-align: left;
  }
}
.service_design .deco {
  position: absolute;
  z-index: -1;
}
.service_design .deco img {
  width: 100%;
  height: auto;
}
.service_design .deco.deco-top {
  width: 1180px;
  height: 486px;
  top: 0;
  right: 0;
}
@media screen and (max-width: 1366px) {
  .service_design .deco.deco-top {
    width: 1180rem;
    height: 486rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_design .deco.deco-top {
    right: -55%;
    height: 364rem;
    width: 883rem;
  }
}
.service_design .deco.deco-middle {
  top: 38.7060998152%;
  left: -216px;
  width: 1180px;
  height: 486px;
}
@media screen and (max-width: 1366px) {
  .service_design .deco.deco-middle {
    left: -216rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_design .deco.deco-middle {
    height: 364rem;
    width: 70%;
  }
}
.service_design .deco.deco-bottom {
  bottom: 0;
  left: 0;
}
@media screen and (max-width: 1024px) {
  .service_design .deco.deco-bottom {
    left: -55%;
    height: 364rem;
    width: 883rem;
  }
}
.service_design .w1080 {
  padding: 108px 0 80px;
}
@media screen and (max-width: 1366px) {
  .service_design .w1080 {
    padding: 108rem 0 80rem;
  }
}
.service_design .w1080 .sec-title {
  text-align: center;
  color: #fff;
  margin-bottom: 35px;
}
@media screen and (max-width: 1366px) {
  .service_design .w1080 .sec-title {
    margin-bottom: 35rem;
  }
}
.service_design .w1080 .sec-title .tit-ja {
  margin-bottom: 50px;
}
@media screen and (max-width: 1366px) {
  .service_design .w1080 .sec-title .tit-ja {
    margin-bottom: 50rem;
  }
}
.service_design .w1080 .sec-title .tit-ja::after {
  background-image: radial-gradient(circle, #fff 5px, transparent 5px);
}
@media screen and (max-width: 1366px) {
  .service_design .w1080 .sec-title .tit-ja::after {
    background-image: radial-gradient(circle, #fff 5rem, transparent 5rem);
  }
}
.service_design .w1080 .sec-title .catch {
  font-size: 2.4rem;
  line-height: 1.5;
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 30px;
}
@media screen and (max-width: 1366px) {
  .service_design .w1080 .sec-title .catch {
    font-size: 24rem;
    margin-bottom: 30rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_design .w1080 .sec-title .catch {
    font-size: clamp(14px, 14px + (24 - 14) * (100vw - 320px) / (640 - 320), 24px);
  }
}
.service_design .w1080 .design-body {
  color: #fff;
}
.service_design .w1080 .design-body .subttl {
  font-size: 24px;
  font-weight: 700;
  position: relative;
  margin-left: 30px;
  padding-left: 22px;
  margin-bottom: 15px;
}
@media screen and (max-width: 1366px) {
  .service_design .w1080 .design-body .subttl {
    font-size: 24rem;
    margin-left: 30rem;
    padding-left: 22rem;
    margin-bottom: 15rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_design .w1080 .design-body .subttl {
    font-size: clamp(16px, 16px + (24 - 16) * (100vw - 320px) / (640 - 320), 24px);
  }
}
.service_design .w1080 .design-body .subttl::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 11px;
  height: 11px;
  background-color: #fff;
  border-radius: 50px;
}
@media screen and (max-width: 1366px) {
  .service_design .w1080 .design-body .subttl::before {
    width: 11rem;
    height: 11rem;
    border-radius: 50rem;
  }
}
.service_design .w1080 .design-body .tablecontents .item {
  border-bottom: 1px solid #fff;
}
.service_design .w1080 .design-body .tablecontents .item:first-child {
  border-top: 1px solid #fff;
  padding-top: 30px;
  padding-bottom: 30px;
}
@media screen and (max-width: 1366px) {
  .service_design .w1080 .design-body .tablecontents .item:first-child {
    padding-top: 30rem;
    padding-bottom: 30rem;
  }
}
.service_design .w1080 .design-body .tablecontents .item:last-child {
  border-bottom: none;
}
.service_design .btn {
  width: 336px;
  border-radius: 32px;
  font-size: 18px;
  font-weight: 700;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding-right: 21px;
  height: 65px;
  color: #fff;
  background-color: #1f4c9f;
  gap: 44px;
  margin: 90px auto auto;
  filter: drop-shadow(2px 6px 0px #cccccc);
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  .service_design .btn {
    width: 336rem;
    border-radius: 32rem;
    font-size: 18rem;
    padding-right: 21rem;
    height: 65rem;
    gap: 44rem;
    margin: 90rem auto auto;
    filter: drop-shadow(2rem 6rem 0px #cccccc);
  }
}
@media screen and (max-width: 1024px) {
  .service_design .btn {
    width: 389rem;
    justify-content: center;
    padding-right: 0;
    gap: 22rem;
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
    height: 64rem;
    filter: drop-shadow(2rem 6rem 0px #cccccc);
  }
  .service_design .btn:hover {
    transform: translateY(6rem);
    filter: drop-shadow(2rem 0px 0px #cccccc);
  }
}
.service_design .btn svg {
  width: 15px;
  height: 12px;
}
@media screen and (max-width: 1366px) {
  .service_design .btn svg {
    width: 15rem;
    height: 12rem;
  }
}
.service_design .btn:hover {
  transform: translateY(6px);
  filter: drop-shadow(2px 0px 0px #cccccc);
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  .service_design .btn:hover {
    transform: translateY(6rem);
    filter: drop-shadow(2rem 0px 0px #cccccc);
  }
}

.service_maintenance {
  padding-top: 94px;
}
@media screen and (max-width: 1366px) {
  .service_maintenance {
    padding-top: 94rem;
  }
}
.service_maintenance .sec-title {
  text-align: center;
  margin-bottom: 35px;
}
@media screen and (max-width: 1366px) {
  .service_maintenance .sec-title {
    margin-bottom: 35rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_maintenance .sec-title {
    max-width: 580rem;
    width: 100%;
    margin: auto auto 35rem;
  }
}
.service_maintenance .sec-title .tit-ja {
  margin-bottom: 50px;
  color: #b6c168;
}
@media screen and (max-width: 1366px) {
  .service_maintenance .sec-title .tit-ja {
    margin-bottom: 50rem;
  }
}
.service_maintenance .sec-title .tit-ja::after {
  background-image: radial-gradient(circle, #b6c168 5px, transparent 5px);
}
@media screen and (max-width: 1366px) {
  .service_maintenance .sec-title .tit-ja::after {
    background-image: radial-gradient(circle, #b6c168 5rem, transparent 5rem);
  }
}
.service_maintenance .sec-title .catch {
  color: #b6c168;
  font-size: 2.4rem;
  line-height: 1.5;
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 20px;
}
@media screen and (max-width: 1366px) {
  .service_maintenance .sec-title .catch {
    font-size: 24rem;
    margin-bottom: 20rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_maintenance .sec-title .catch {
    font-size: clamp(14px, 14px + (24 - 14) * (100vw - 320px) / (640 - 320), 24px);
  }
}
.service_maintenance .grid-item {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: auto;
  gap: 25px 20px;
  margin-top: 55px;
}
@media screen and (max-width: 1366px) {
  .service_maintenance .grid-item {
    gap: 25rem 20rem;
    margin-top: 55rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_maintenance .grid-item {
    grid-template-columns: 1fr;
  }
}
.service_maintenance .grid-item .item {
  min-height: 330px;
  border: 1px solid #cccccc;
  border-radius: 23px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media screen and (max-width: 1366px) {
  .service_maintenance .grid-item .item {
    min-height: 330rem;
    border-radius: 23rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_maintenance .grid-item .item {
    padding: 20rem 0;
  }
}
.service_maintenance .grid-item .item .item-head {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.service_maintenance .grid-item .item .item-head img {
  width: 27px;
  height: auto;
  margin-bottom: 10px;
}
@media screen and (max-width: 1366px) {
  .service_maintenance .grid-item .item .item-head img {
    margin-bottom: 10rem;
  }
}
.service_maintenance .grid-item .item .item-head .sub {
  display: flex;
  gap: 1em;
  font-family: "KozGoPr6N", sans-serif;
  font-weight: 400;
  font-size: 16px;
  align-items: center;
  margin-bottom: 10px;
}
@media screen and (max-width: 1366px) {
  .service_maintenance .grid-item .item .item-head .sub {
    font-size: 16rem;
    margin-bottom: 10rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_maintenance .grid-item .item .item-head .sub {
    font-size: clamp(12px, 12px + (16 - 12) * (100vw - 320px) / (640 - 320), 16px);
  }
}
.service_maintenance .grid-item .item .item-head .sub svg {
  width: 12px;
  height: 15px;
}
@media screen and (max-width: 1366px) {
  .service_maintenance .grid-item .item .item-head .sub svg {
    width: 12rem;
    height: 15rem;
  }
}
.service_maintenance .grid-item .item .item-head .item-ttl {
  font-size: 2.4rem;
  line-height: 1.5;
  font-size: 24px;
  font-weight: 700;
  position: relative;
  color: #b6c168;
  padding-bottom: 21px;
  margin-bottom: 20px;
}
@media screen and (max-width: 1366px) {
  .service_maintenance .grid-item .item .item-head .item-ttl {
    font-size: 24rem;
    padding-bottom: 21rem;
    margin-bottom: 20rem;
  }
}
.service_maintenance .grid-item .item .item-head .item-ttl::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 122px;
  height: 7px;
  margin: auto;
  background-image: radial-gradient(circle, #b6c168 3px, transparent 4px);
  background-size: 13.5555555556px 7px;
  background-repeat: repeat-x;
}
@media screen and (max-width: 1366px) {
  .service_maintenance .grid-item .item .item-head .item-ttl::after {
    width: 175rem;
    height: 7rem;
    background-size: 13.5555555556rem 7rem;
    background-image: radial-gradient(circle, #b6c168 3rem, transparent 4rem);
  }
}
.service_maintenance .grid-item .item .desc {
  font-size: 1.6rem;
  line-height: 2;
  font-size: 16px;
  width: 89.6226415094%;
  margin: 0 auto;
}
@media screen and (max-width: 1366px) {
  .service_maintenance .grid-item .item .desc {
    font-size: 16rem;
  }
}
@media screen and (max-width: 1024px) {
  .service_maintenance .grid-item .item .desc {
    font-size: clamp(14px, 14px + (16 - 14) * (100vw - 320px) / (640 - 320), 16px);
  }
}
.service_maintenance .btn {
  width: 336px;
  border-radius: 32px;
  font-size: 18px;
  font-weight: 700;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding-right: 21px;
  height: 65px;
  color: #fff;
  background-color: #b6c168;
  gap: 44px;
  margin: 90px auto auto;
  filter: drop-shadow(2px 6px 0px #cccccc);
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  .service_maintenance .btn {
    width: 336rem;
    border-radius: 32rem;
    font-size: 18rem;
    padding-right: 21rem;
    height: 65rem;
    gap: 44rem;
    margin-top: 90rem;
    margin: 90rem auto auto;
    filter: drop-shadow(2rem 6rem 0px #cccccc);
  }
}
@media screen and (max-width: 1024px) {
  .service_maintenance .btn {
    width: 389rem;
    justify-content: center;
    padding-right: 0;
    gap: 22rem;
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
    height: 64rem;
    filter: drop-shadow(2rem 6rem 0px #cccccc);
  }
  .service_maintenance .btn:hover {
    transform: translateY(6rem);
    filter: drop-shadow(2rem 0px 0px #cccccc);
  }
}
.service_maintenance .btn svg {
  width: 15px;
  height: 12px;
}
@media screen and (max-width: 1366px) {
  .service_maintenance .btn svg {
    width: 15rem;
    height: 12rem;
  }
}
.service_maintenance .btn:hover {
  transform: translateY(6px);
  filter: drop-shadow(2px 0px 0px #cccccc);
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  .service_maintenance .btn:hover {
    transform: translateY(6rem);
    filter: drop-shadow(2rem 0px 0px #cccccc);
  }
}

@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "Acumin";
  src: url("../fonts/Acumin-Pro-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
}
.use .desc {
  font-size: 1.8rem;
  line-height: 2;
  font-size: 18px;
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 1366px) {
  .use .desc {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .use .desc {
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.use .sec-subttl {
  font-size: 21px;
  font-weight: 700;
  padding-bottom: 32px;
  position: relative;
  text-align: center;
}
@media screen and (max-width: 1366px) {
  .use .sec-subttl {
    font-size: 21rem;
    padding-bottom: 32rem;
  }
}
@media screen and (max-width: 1024px) {
  .use .sec-subttl {
    font-size: clamp(16px, 16px + (21 - 16) * (100vw - 320px) / (640 - 320), 21px);
  }
}
.use .sec-subttl::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 162px;
  height: 8px;
  margin: auto;
  background-image: radial-gradient(circle, #1f4c9f 4px, transparent 4px);
  background-size: 14.7272727273px 8px;
  background-repeat: repeat-x;
}
@media screen and (max-width: 1366px) {
  .use .sec-subttl::after {
    width: 162rem;
    height: 8rem;
    background-size: 14.7272727273rem 8rem;
    background-image: radial-gradient(circle, #1f4c9f 4rem, transparent 4rem);
  }
}
.use .sec-title .tit-ja {
  position: relative;
  font-size: 36px;
  padding-bottom: 36px;
  letter-spacing: 0.22em;
  font-weight: 700;
  margin-bottom: 69px;
}
@media screen and (max-width: 1366px) {
  .use .sec-title .tit-ja {
    font-size: 36rem;
    padding-bottom: 36rem;
    margin-bottom: 69rem;
  }
}
.use .sec-title .tit-ja::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 175px;
  height: 10px;
  margin: auto;
  background-image: radial-gradient(circle, #1f4c9f 5px, transparent 5px);
  background-size: 17.5px 10px;
  background-repeat: repeat-x;
}
@media screen and (max-width: 1366px) {
  .use .sec-title .tit-ja::after {
    width: 175rem;
    height: 10rem;
    background-size: 17.5rem 10rem;
    background-image: radial-gradient(circle, #1f4c9f 5rem, transparent 5rem);
  }
}
.use .sec-title .tit-ja.center {
  text-align: center;
}
.use .sec-title .tit-ja.center::after {
  right: 0;
  margin: auto;
}
.use .int_product {
  position: relative;
  border-radius: 45px;
  background-color: rgba(231, 237, 247, 0.5);
  display: flex;
  flex-direction: column;
  gap: 30px;
  padding: 42px 0 60px;
  border: 1px solid #e6e6e6;
}
@media screen and (max-width: 1366px) {
  .use .int_product {
    border-radius: 45rem;
    gap: 30rem;
    padding: 42rem 0 60rem;
    border: 1rem solid #e6e6e6;
  }
}
@media screen and (max-width: 1024px) {
  .use .int_product {
    padding: 30rem 0;
  }
}
.use .int_product .desc {
  width: 87.037037037%;
  margin: auto;
}
.use .int_product .deco01 {
  position: absolute;
  top: -65px;
  left: -25px;
}
@media screen and (max-width: 1366px) {
  .use .int_product .deco01 {
    top: -65rem;
    left: -25rem;
  }
}
@media screen and (max-width: 1024px) {
  .use .int_product .deco01 {
    width: 132rem;
    height: 157rem;
    left: -56rem;
  }
  .use .int_product .deco01 img {
    width: 100%;
    height: auto;
  }
}
.use .int_product .deco02 {
  position: absolute;
  right: -84px;
  bottom: -38px;
}
@media screen and (max-width: 1366px) {
  .use .int_product .deco02 {
    right: -84rem;
    bottom: -38rem;
  }
}
@media screen and (max-width: 1024px) {
  .use .int_product .deco02 {
    width: 117rem;
    height: 168rem;
    right: -30rem;
    bottom: -96rem;
  }
  .use .int_product .deco02 img {
    width: 100%;
    height: auto;
  }
}

.use_purchase {
  margin-bottom: 90px;
}
@media screen and (max-width: 1366px) {
  .use_purchase {
    margin-bottom: 90rem;
  }
}
.use_purchase .sec-title {
  margin-bottom: 55px;
}
@media screen and (max-width: 1366px) {
  .use_purchase .sec-title {
    margin-bottom: 55rem;
  }
}
@media screen and (max-width: 640px) {
  .use_purchase .sec-title .desc {
    text-align: left;
  }
}
.use_purchase .int_product {
  margin-bottom: 100px;
}
@media screen and (max-width: 1366px) {
  .use_purchase .int_product {
    margin-bottom: 100rem;
  }
}
.use_purchase .use-swiper {
  width: 914px; /* 2枚分＋余白 */
  margin: 0 auto;
  overflow: visible;
}
@media screen and (max-width: 1366px) {
  .use_purchase .use-swiper {
    width: 918rem;
  }
}
@media screen and (max-width: 1024px) {
  .use_purchase .use-swiper {
    width: 100%;
  }
}
.use_purchase .use-swiper .swiper-slide {
  width: 447px;
  aspect-ratio: 1/1;
  border-radius: 45px;
}
@media screen and (max-width: 1366px) {
  .use_purchase .use-swiper .swiper-slide {
    width: 447px;
    border-radius: 45rem;
  }
}
@media screen and (max-width: 1024px) {
  .use_purchase .use-swiper .swiper-slide {
    border-radius: 20rem;
    width: auto;
  }
}
.use_purchase .use-swiper .swiper-slide img {
  border-radius: 45px;
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}
@media screen and (max-width: 1366px) {
  .use_purchase .use-swiper .swiper-slide img {
    border-radius: 45rem;
  }
}

.use_pay {
  margin-bottom: 110px;
}
@media screen and (max-width: 1366px) {
  .use_pay {
    margin-bottom: 110rem;
  }
}
.use_pay .sec-title {
  margin-bottom: 30px;
}
@media screen and (max-width: 1366px) {
  .use_pay .sec-title {
    margin-bottom: 30rem;
  }
}
@media screen and (max-width: 640px) {
  .use_pay .sec-title .desc {
    text-align: left;
  }
}
.use_pay .grid-item {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 13px;
}
@media screen and (max-width: 1366px) {
  .use_pay .grid-item {
    gap: 13rem;
  }
}
@media screen and (max-width: 1024px) {
  .use_pay .grid-item {
    flex-direction: column;
  }
}

.use_delivery {
  margin-bottom: 80px;
}
@media screen and (max-width: 1366px) {
  .use_delivery {
    margin-bottom: 80rem;
  }
}
.use_delivery .sec-title .desc {
  margin: 10px 0;
}
@media screen and (max-width: 640px) {
  .use_delivery .sec-title .desc {
    text-align: left;
  }
}
.use_delivery .sec-title .desc.bold {
  font-weight: bold;
}
@media screen and (max-width: 640px) {
  .use_delivery .sec-title .desc.bold {
    text-align: center;
  }
}

.use_return {
  margin-bottom: 238px;
}
@media screen and (max-width: 1366px) {
  .use_return {
    margin-bottom: 238rem;
  }
}
.use_return .sec-title {
  margin-bottom: 45px;
}
@media screen and (max-width: 1366px) {
  .use_return .sec-title {
    margin-bottom: 45rem;
  }
}
@media screen and (max-width: 640px) {
  .use_return .sec-title .desc {
    text-align: left;
  }
}
.use_return .box-blue {
  position: relative;
  border-radius: 45px;
  background-color: rgba(231, 237, 247, 0.5);
  display: flex;
  flex-direction: column;
  gap: 30px;
  padding: 42px 0 60px;
  border: 1px solid #e6e6e6;
}
@media screen and (max-width: 1366px) {
  .use_return .box-blue {
    border-radius: 45rem;
    gap: 30rem;
    padding: 42rem 0 60rem;
    border: 1rem solid #e6e6e6;
  }
}
@media screen and (max-width: 1024px) {
  .use_return .box-blue {
    padding: 30rem 0;
  }
}
.use_return .box-blue .sec-subttl {
  color: #1f4c9f;
}
.use_return .box-blue .desc {
  width: 87.037037037%;
  margin: auto;
}
@media screen and (max-width: 640px) {
  .use_return .box-blue .desc {
    text-align: left;
  }
}

@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "Acumin";
  src: url("../fonts/Acumin-Pro-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
}
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(150px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.sp {
  display: none;
}
@media screen and (max-width: 1024px) {
  .sp {
    display: block;
  }
}

.csr .fadein-item-delay {
  opacity: 0;
  transform: translateY(0);
}
.csr .fadein-item-delay.is-show {
  animation: fadeInUp 0.5s ease-out forwards;
  animation-delay: 0.2s;
}
.csr .fadein-item-ttl {
  opacity: 0;
  transform: translateY(0);
}
.csr .fadein-item-ttl.is-show {
  animation: fadeInUp 0.5s ease-out forwards;
}

.fadein-item {
  opacity: 0;
  transform: translateY(0);
}

.fadein-item.is-show {
  animation: fadeInUp 0.5s ease-out forwards;
}

.csr .submenu-tabs .submenu-tabs__list {
  justify-content: center;
  gap: 73px;
}
@media screen and (max-width: 1366px) {
  .csr .submenu-tabs .submenu-tabs__list {
    gap: 73rem;
  }
}
.csr .desc {
  font-size: 1.8rem;
  line-height: 2;
  font-size: 18px;
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 1366px) {
  .csr .desc {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .csr .desc {
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.csr .sec-title .tit-ja {
  position: relative;
  font-size: 36px;
  padding-bottom: 36px;
  letter-spacing: 0.22em;
  font-weight: 700;
  margin-bottom: 40px;
}
@media screen and (max-width: 1366px) {
  .csr .sec-title .tit-ja {
    font-size: 36rem;
    padding-bottom: 36rem;
    margin-bottom: 40rem;
  }
}
.csr .sec-title .tit-ja::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 175px;
  height: 10px;
  margin: auto;
  background-image: radial-gradient(circle, #1f4c9f 5px, transparent 5px);
  background-size: 17.5px 10px;
  background-repeat: repeat-x;
}
@media screen and (max-width: 1366px) {
  .csr .sec-title .tit-ja::after {
    width: 175rem;
    height: 10rem;
    background-size: 17.5rem 10rem;
    background-image: radial-gradient(circle, #1f4c9f 5rem, transparent 5rem);
  }
}
.csr .sec-title .tit-ja.center {
  text-align: center;
}
.csr .sec-title .tit-ja.center::after {
  right: 0;
  margin: auto;
}
.csr .sec-title .tit-en {
  font-family: "Acumin", sans-serif;
  font-size: 24px;
  font-weight: 600;
  text-align: center;
}
@media screen and (max-width: 1366px) {
  .csr .sec-title .tit-en {
    font-size: 24rem;
  }
}

.csr_sdgs {
  margin-bottom: 100px;
}
@media screen and (max-width: 1366px) {
  .csr_sdgs {
    margin-bottom: 100rem;
  }
}
.csr_sdgs .sec-title .tit-en {
  color: #1f4c9f;
}
.csr_sdgs .sec-title .desc {
  font-size: 2.8rem;
  line-height: 2.0714285714;
  font-size: 28px;
  font-weight: 700;
  position: relative;
  z-index: 4;
}
.csr_sdgs .sec-title .desc::before {
  content: "";
  background: url(../img/csr/csr-bg.png) no-repeat center/contain;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
@media screen and (max-width: 1366px) {
  .csr_sdgs .sec-title .desc {
    font-size: 28rem;
  }
}
@media screen and (max-width: 1024px) {
  .csr_sdgs .sec-title .desc {
    font-size: 2.1rem;
    line-height: 2.4761904762;
    font-size: clamp(14px, 14px + (21 - 14) * (100vw - 320px) / (640 - 320), 21px);
  }
}
.csr_sdgs.col-2 {
  display: flex;
  align-items: center;
  gap: 80px;
  margin-bottom: 84px;
}
@media screen and (max-width: 1366px) {
  .csr_sdgs.col-2 {
    gap: 80rem;
    margin-bottom: 84rem;
  }
}
@media screen and (max-width: 1024px) {
  .csr_sdgs.col-2 {
    flex-direction: column;
    align-items: flex-start;
    gap: 45rem;
  }
}
.csr_sdgs.col-2 .img {
  width: 38.579795022vw;
  height: 562px;
  border-radius: 0 45px 45px 0;
}
@media screen and (max-width: 1366px) {
  .csr_sdgs.col-2 .img {
    height: 562rem;
    border-radius: 0 45rem 45rem 0;
  }
}
@media screen and (max-width: 1024px) {
  .csr_sdgs.col-2 .img {
    width: 610rem;
    height: 400rem;
  }
}
.csr_sdgs.col-2 .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0 45px 45px 0;
}
@media screen and (max-width: 1366px) {
  .csr_sdgs.col-2 .img img {
    border-radius: 0 45rem 45rem 0;
  }
}
.csr_sdgs.col-2 .text {
  width: fit-content;
}
@media screen and (max-width: 1024px) {
  .csr_sdgs.col-2 .text {
    width: 580rem;
    margin: auto;
  }
}
.csr_sdgs.col-2 .text .sec-title .tit-en {
  text-align: left;
}
.csr_sdgs.col-2 .text .sec-body .sec-text {
  font-size: 1.8rem;
  line-height: 2;
  font-size: 18px;
  font-weight: 500;
  margin-bottom: 53px;
}
@media screen and (max-width: 1366px) {
  .csr_sdgs.col-2 .text .sec-body .sec-text {
    font-size: 18rem;
    margin-bottom: 53rem;
  }
}
@media screen and (max-width: 1024px) {
  .csr_sdgs.col-2 .text .sec-body .sec-text {
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.csr_sdgs.col-2 .text .sec-body img {
  width: 520px;
  height: auto;
}
@media screen and (max-width: 1366px) {
  .csr_sdgs.col-2 .text .sec-body img {
    width: 520rem;
  }
}

.csr_list {
  position: relative;
  border-radius: 45px 0 0 45px;
  margin-bottom: 35px;
}
@media screen and (max-width: 1366px) {
  .csr_list {
    margin-bottom: 35rem;
    border-radius: 45rem 0 0 45rem;
  }
}
.csr_list.reverse {
  border-radius: 0 45px 45px 0;
}
@media screen and (max-width: 1366px) {
  .csr_list.reverse {
    border-radius: 0 45rem 45rem 0;
  }
}
.csr_list.reverse .icon {
  left: 0;
  right: auto;
}
.csr_list.reverse::after {
  left: 3.6603221083vw;
  right: auto;
}
@media screen and (max-width: 1024px) {
  .csr_list.reverse::after {
    left: 184rem;
  }
}
.csr_list.reverse .w1080 {
  max-width: 1001px;
}
@media screen and (max-width: 1366px) {
  .csr_list.reverse .w1080 {
    max-width: 1001rem;
  }
}
@media screen and (max-width: 1024px) {
  .csr_list.reverse .w1080 {
    width: 100%;
    padding-left: 28rem;
    padding-right: 15rem;
  }
}
.csr_list.reverse .w1080 .text .list-body {
  flex-direction: row-reverse;
  justify-content: center;
}
@media screen and (max-width: 1024px) {
  .csr_list.reverse .w1080 .text .list-body {
    flex-direction: column-reverse;
  }
}
.csr_list.reverse .w1080 .text .list-body .desc {
  width: 643px;
}
@media screen and (max-width: 1366px) {
  .csr_list.reverse .w1080 .text .list-body .desc {
    width: 643rem;
  }
}
@media screen and (max-width: 1024px) {
  .csr_list.reverse .w1080 .text .list-body .desc {
    width: 100%;
  }
}
.csr_list .icon {
  position: absolute;
  width: 142px;
  height: 142px;
  background-color: #fff;
  top: 0;
  right: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}
.csr_list .icon img {
  width: 85px;
  height: 85px;
}
@media screen and (max-width: 1366px) {
  .csr_list .icon img {
    width: 85rem;
    height: 85rem;
  }
}
@media screen and (max-width: 1366px) {
  .csr_list .icon {
    width: 142rem;
    height: 142rem;
  }
}
.csr_list::after {
  content: "";
  position: absolute;
  color: rgba(255, 255, 255, 0.5);
  font-size: 45px;
  font-weight: 600;
  font-family: "Acumin", sans-serif;
  writing-mode: vertical-lr;
  letter-spacing: 0.16em;
  right: 3.6603221083vw;
  bottom: 73px;
  margin: auto;
  width: fit-content;
  height: fit-content;
}
@media screen and (max-width: 1366px) {
  .csr_list::after {
    font-size: 45rem;
    bottom: 73rem;
  }
}
@media screen and (max-width: 1024px) {
  .csr_list::after {
    bottom: auto;
    top: 60rem;
    writing-mode: horizontal-tb;
    right: auto;
    left: 154rem;
  }
}
.csr_list .w1080 {
  padding: 110px 0;
}
@media screen and (max-width: 1366px) {
  .csr_list .w1080 {
    padding: 110rem 0;
  }
}
@media screen and (max-width: 1024px) {
  .csr_list .w1080 {
    padding: 172rem 0 43rem;
  }
}
.csr_list .w1080 .text {
  color: #fff;
}
.csr_list .w1080 .text .sec-title {
  margin-bottom: 40px;
}
@media screen and (max-width: 1366px) {
  .csr_list .w1080 .text .sec-title {
    margin-bottom: 40rem;
  }
}
.csr_list .w1080 .text .sec-title .tit-ja-sub {
  font-weight: 500;
  font-size: 1.8rem;
  line-height: 2;
  font-size: 18px;
}
@media screen and (max-width: 1366px) {
  .csr_list .w1080 .text .sec-title .tit-ja-sub {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .csr_list .w1080 .text .sec-title .tit-ja-sub {
    font-size: clamp(16px, 16px + (18 - 16) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.csr_list .w1080 .text .sec-title .tit-ja {
  margin-bottom: 0;
}
.csr_list .w1080 .text .sec-title .tit-ja::after {
  background-image: radial-gradient(circle, #fff 5px, transparent 5px);
}
@media screen and (max-width: 1366px) {
  .csr_list .w1080 .text .sec-title .tit-ja::after {
    background-image: radial-gradient(circle, #fff 5rem, transparent 5rem);
  }
}
.csr_list .w1080 .text .desc {
  text-align: left;
}
.csr_list .w1080 .text .list-body {
  display: flex;
  align-items: center;
  gap: 33px;
}
@media screen and (max-width: 1366px) {
  .csr_list .w1080 .text .list-body {
    gap: 33rem;
  }
}
@media screen and (max-width: 1024px) {
  .csr_list .w1080 .text .list-body {
    flex-direction: column-reverse;
    align-items: flex-start;
  }
}
.csr_list .w1080 .text .list-body .img {
  width: 326px;
  height: 204px;
  border-radius: 15px;
}
@media screen and (max-width: 1366px) {
  .csr_list .w1080 .text .list-body .img {
    width: 326rem;
    height: 204rem;
    border-radius: 15rem;
  }
}
@media screen and (max-width: 1024px) {
  .csr_list .w1080 .text .list-body .img {
    width: 550rem;
    height: 345rem;
    order: 1;
  }
}
.csr_list .w1080 .text .list-body .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 15px;
}
@media screen and (max-width: 1366px) {
  .csr_list .w1080 .text .list-body .img img {
    border-radius: 15rem;
  }
}
.csr_list .w1080 .text .list-body .desc {
  width: 679px;
}
@media screen and (max-width: 1366px) {
  .csr_list .w1080 .text .list-body .desc {
    width: 679rem;
  }
}
@media screen and (max-width: 1024px) {
  .csr_list .w1080 .text .list-body .desc {
    width: 100%;
  }
}
.csr_list.color01 {
  background-color: #00943b;
}
.csr_list.color01::after {
  content: "SDGs No.3";
}
.csr_list.color02 {
  background-color: #c40f28;
}
.csr_list.color02::after {
  content: "SDGs No.4";
}
.csr_list.color02 .text .flex {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media screen and (max-width: 1366px) {
  .csr_list.color02 .text .flex {
    gap: 20rem;
  }
}
.csr_list.color03 {
  background-color: #f7ba00;
}
.csr_list.color03::after {
  content: "SDGs No.7";
}
.csr_list.color04 {
  background-color: #940b30;
}
.csr_list.color04::after {
  content: "SDGs No.8";
}
.csr_list.color05 {
  background-color: #da007a;
}
.csr_list.color05::after {
  content: "SDGs No.10";
}
.csr_list.color06 {
  background-color: #f29f00;
}
.csr_list.color06::after {
  content: "SDGs No.11";
}
.csr_list.color07 {
  background-color: #d08f00;
}
.csr_list.color07::after {
  content: "SDGs No.12";
}
.csr_list.color08 {
  background-color: #25a539;
  margin-bottom: 122px;
}
@media screen and (max-width: 1366px) {
  .csr_list.color08 {
    margin-bottom: 122rem;
  }
}
.csr_list.color08::after {
  content: "SDGs No.15";
}

.csr_attempt {
  position: relative;
}
.csr_attempt #waveCanvasColor,
.csr_attempt #waveCanvasOverlayColor {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
}
.csr_attempt .content {
  position: relative;
  z-index: 10;
  padding-top: 183px;
  padding-bottom: 229px;
}
@media screen and (max-width: 1366px) {
  .csr_attempt .content {
    padding-top: 183rem;
    padding-bottom: 229rem;
  }
}
@media screen and (max-width: 1024px) {
  .csr_attempt .content {
    padding: 128rem 0;
  }
}
.csr_attempt .content .sec-title {
  color: #fff;
}
.csr_attempt .content .sec-title .tit-ja::after {
  background-image: radial-gradient(circle, #fff 5px, transparent 5px);
}
@media screen and (max-width: 1366px) {
  .csr_attempt .content .sec-title .tit-ja::after {
    background-image: radial-gradient(circle, #fff 5rem, transparent 5rem);
  }
}
.csr_attempt .content .grid-item {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: auto;
  gap: 70px 28px;
}
@media screen and (max-width: 1366px) {
  .csr_attempt .content .grid-item {
    gap: 70rem 28rem;
  }
}
@media screen and (max-width: 1024px) {
  .csr_attempt .content .grid-item {
    grid-template-columns: 1fr;
  }
}
.csr_attempt .content .grid-item .item .img {
  width: 526px;
  height: 325px;
  border-radius: 25px;
  margin-bottom: 30px;
}
@media screen and (max-width: 1366px) {
  .csr_attempt .content .grid-item .item .img {
    width: 526rem;
    height: 325rem;
    border-radius: 25rem;
    margin-bottom: 30rem;
  }
}
@media screen and (max-width: 1024px) {
  .csr_attempt .content .grid-item .item .img {
    width: 100%;
    height: 385rem;
  }
}
.csr_attempt .content .grid-item .item .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 25px;
}
@media screen and (max-width: 1366px) {
  .csr_attempt .content .grid-item .item .img img {
    border-radius: 25rem;
  }
}
.csr_attempt .content .grid-item .item .item-ttl {
  color: #fff;
  font-size: 2.4rem;
  line-height: 1.5;
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 26px;
}
@media screen and (max-width: 1366px) {
  .csr_attempt .content .grid-item .item .item-ttl {
    font-size: 24rem;
    margin-bottom: 26rem;
  }
}
@media screen and (max-width: 1024px) {
  .csr_attempt .content .grid-item .item .item-ttl {
    font-size: clamp(16px, 16px + (24 - 16) * (100vw - 320px) / (640 - 320), 24px);
  }
}
.csr_attempt .content .grid-item .item .desc {
  color: #fff;
  text-align: left;
}

@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "Acumin";
  src: url("../fonts/Acumin-Pro-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
}
.contact .submenu-tabs .submenu-tabs__list {
  justify-content: center;
  gap: 73px;
}
@media screen and (max-width: 1366px) {
  .contact .submenu-tabs .submenu-tabs__list {
    gap: 73rem;
  }
}
.contact .desc {
  font-size: 1.8rem;
  line-height: 2;
  font-size: 18px;
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 1366px) {
  .contact .desc {
    font-size: 18rem;
  }
}
.contact .sec-title .tit-ja {
  position: relative;
  font-size: 36px;
  padding-bottom: 36px;
  letter-spacing: 0.22em;
  font-weight: 700;
  margin-bottom: 40px;
}
@media screen and (max-width: 1366px) {
  .contact .sec-title .tit-ja {
    font-size: 36rem;
    padding-bottom: 36rem;
    margin-bottom: 40rem;
  }
}
.contact .sec-title .tit-ja::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 175px;
  height: 10px;
  margin: auto;
  background-image: radial-gradient(circle, #1f4c9f 5px, transparent 5px);
  background-size: 17.5px 10px;
  background-repeat: repeat-x;
}
@media screen and (max-width: 1366px) {
  .contact .sec-title .tit-ja::after {
    width: 175rem;
    height: 10rem;
    background-size: 17.5rem 10rem;
    background-image: radial-gradient(circle, #1f4c9f 5rem, transparent 5rem);
  }
}
.contact .sec-title .tit-ja.center {
  text-align: center;
}
.contact .sec-title .tit-ja.center::after {
  right: 0;
  margin: auto;
}
.contact .sec-title .tit-en {
  font-family: "Acumin", sans-serif;
  font-size: 24px;
  font-weight: 600;
  text-align: center;
}
@media screen and (max-width: 1366px) {
  .contact .sec-title .tit-en {
    font-size: 24rem;
  }
}

.contact_forms {
  padding-bottom: 100px;
  border-bottom: 1px solid #d9dada;
}
@media screen and (max-width: 1366px) {
  .contact_forms {
    padding-bottom: 100rem;
  }
}
.contact_forms .sec-title {
  margin-bottom: 80px;
}
@media screen and (max-width: 1366px) {
  .contact_forms .sec-title {
    margin-bottom: 80rem;
  }
}
.contact_forms .sec-title .tit-en {
  color: #1f4c9f;
}
.contact_forms .form_items form {
  display: flex;
  flex-direction: column;
  gap: 32px;
}
@media screen and (max-width: 1366px) {
  .contact_forms .form_items form {
    gap: 32rem;
  }
}
.contact_forms .form_items .item {
  display: grid;
  align-items: flex-start;
  grid-template-columns: 30% 1fr;
}
@media screen and (max-width: 1024px) {
  .contact_forms .form_items .item {
    display: flex;
    flex-direction: column;
    gap: 27rem;
  }
}
.contact_forms .form_items .item .ttl {
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0.1em;
  display: flex;
  align-items: center;
  gap: 13px;
}
@media screen and (max-width: 1366px) {
  .contact_forms .form_items .item .ttl {
    font-size: 18rem;
    gap: 13rem;
  }
}
.contact_forms .form_items .item .ttl .required {
  font-weight: 300;
  font-size: 10px;
  letter-spacing: 0.24em;
  width: 35px;
  height: 18px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  background-color: #1f4c9f;
  border-radius: 50px;
}
@media screen and (max-width: 1366px) {
  .contact_forms .form_items .item .ttl .required {
    font-size: 10rem;
    width: 35rem;
    height: 18rem;
    border-radius: 50rem;
  }
}
.contact_forms .form_items .item input,
.contact_forms .form_items .item textarea {
  width: 100%;
  border: 1px solid #e6e6e6;
  border-radius: 4px;
  font-size: 1.8rem;
  line-height: 2;
  font-size: 18px;
  padding: 4px 26px;
}
@media screen and (max-width: 1366px) {
  .contact_forms .form_items .item input,
  .contact_forms .form_items .item textarea {
    font-size: 18rem;
    border-radius: 4rem;
    padding: 4rem 26rem;
  }
}
.contact_forms .form_items .item input::placeholder,
.contact_forms .form_items .item textarea::placeholder {
  color: #abacac;
  font-size: 18px;
  letter-spacing: 0.1em;
  font-weight: 500;
  opacity: 1;
}
@media screen and (max-width: 1366px) {
  .contact_forms .form_items .item input::placeholder,
  .contact_forms .form_items .item textarea::placeholder {
    font-size: 18rem;
  }
}
.contact_forms .form_items .item input {
  height: 50px;
}
@media screen and (max-width: 1366px) {
  .contact_forms .form_items .item input {
    height: 50rem;
  }
}
.contact_forms .form_items .item input[type=checkbox] {
  margin: 0;
  width: 13px;
  height: 13px;
  border: 0.5px solid #3e3a39;
  margin-right: 15px;
}
@media screen and (max-width: 1366px) {
  .contact_forms .form_items .item input[type=checkbox] {
    width: 13rem;
    height: 13rem;
    margin-right: 15rem;
  }
}
@media screen and (max-width: 1024px) {
  .contact_forms .form_items .item input[type=checkbox] {
    width: 26rem;
    height: 26rem;
  }
}
.contact_forms .form_items .item .wrap {
  display: flex;
  flex-direction: column;
  gap: 32px;
}
@media screen and (max-width: 1366px) {
  .contact_forms .form_items .item .wrap {
    gap: 32rem;
  }
}
.contact_forms .form_items .item .wrap.column {
  flex-direction: row;
  gap: 30px;
}
@media screen and (max-width: 1366px) {
  .contact_forms .form_items .item .wrap.column {
    gap: 30rem;
  }
}
@media screen and (max-width: 1024px) {
  .contact_forms .form_items .item .wrap.column {
    flex-direction: column;
  }
}
.contact_forms .form_items .item .wrap .w376 {
  width: 376px;
}
@media screen and (max-width: 1366px) {
  .contact_forms .form_items .item .wrap .w376 {
    width: 376rem;
  }
}
@media screen and (max-width: 1024px) {
  .contact_forms .form_items .item .wrap .w376 {
    width: 100%;
  }
}
.contact_forms .form_items .item .wrap .w376 input {
  width: 100%;
}
@media screen and (max-width: 1024px) {
  .contact_forms .form_items .item .detail {
    width: 100%;
  }
}
.contact_forms .form_items .item .detail.column {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto;
}
@media screen and (max-width: 1024px) {
  .contact_forms .form_items .item .detail.column {
    gap: 15rem;
  }
}
.contact_forms .form_items .item .detail .mwform-checkbox-field {
  margin: 0;
}
@media screen and (max-width: 1024px) {
  .contact_forms .form_items .item .detail .mwform-checkbox-field label {
    display: flex;
    align-items: center;
  }
}
.contact_forms .form_items .item .detail .mwform-checkbox-field .mwform-checkbox-field-text {
  font-size: 1.8rem;
  line-height: 2;
  font-size: 18px;
  letter-spacing: 0.1em;
  font-weight: 500;
}
@media screen and (max-width: 1366px) {
  .contact_forms .form_items .item .detail .mwform-checkbox-field .mwform-checkbox-field-text {
    font-size: 18rem;
  }
}
.contact_forms .form_items .item .privacy .mwform-checkbox-field {
  margin: 0;
}
@media screen and (max-width: 1024px) {
  .contact_forms .form_items .item .privacy .mwform-checkbox-field label {
    display: flex;
    align-items: center;
  }
}
.contact_forms .form_items .item .privacy .mwform-checkbox-field .mwform-checkbox-field-text {
  font-size: 16px;
  letter-spacing: 0.1em;
  font-weight: 500;
}
@media screen and (max-width: 1366px) {
  .contact_forms .form_items .item .privacy .mwform-checkbox-field .mwform-checkbox-field-text {
    font-size: 16rem;
  }
}
.contact_forms .form_items .item .privacy .mwform-checkbox-field .mwform-checkbox-field-text a {
  color: #1f4c9f;
}
.contact_forms .btns .btn-confirm,
.contact_forms .btns .btn-submit,
.contact_forms .btns .btn-back {
  width: fit-content;
  margin: auto;
}
.contact_forms .btns .btn-confirm button,
.contact_forms .btns .btn-submit button,
.contact_forms .btns .btn-back button {
  position: relative;
  width: 336px;
  border-radius: 32px;
  font-size: 18px;
  font-weight: 700;
  display: flex;
  justify-content: center;
  align-items: center;
  padding-right: 21px;
  height: 65px;
  color: #fff;
  background-color: #1f4c9f;
  gap: 87px;
  margin: auto;
  filter: drop-shadow(2px 6px 0px #cccccc);
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  .contact_forms .btns .btn-confirm button,
  .contact_forms .btns .btn-submit button,
  .contact_forms .btns .btn-back button {
    width: 336rem;
    border-radius: 32rem;
    font-size: 18rem;
    padding-right: 21rem;
    height: 65rem;
    gap: 87rem;
    margin-bottom: 90rem;
    filter: drop-shadow(2rem 6rem 0px #cccccc);
  }
}
.contact_forms .btns .btn-confirm button::after,
.contact_forms .btns .btn-submit button::after,
.contact_forms .btns .btn-back button::after {
  content: "";
  background: url(../img/contact/i-arrow.svg) no-repeat center/contain;
  width: 15px;
  height: 12px;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  right: 21px;
}
@media screen and (max-width: 1366px) {
  .contact_forms .btns .btn-confirm button::after,
  .contact_forms .btns .btn-submit button::after,
  .contact_forms .btns .btn-back button::after {
    width: 15rem;
    height: 12rem;
    right: 21rem;
  }
}
.contact_forms .btns .btn-confirm button svg,
.contact_forms .btns .btn-submit button svg,
.contact_forms .btns .btn-back button svg {
  width: 15px;
  height: 12px;
}
@media screen and (max-width: 1366px) {
  .contact_forms .btns .btn-confirm button svg,
  .contact_forms .btns .btn-submit button svg,
  .contact_forms .btns .btn-back button svg {
    width: 15rem;
    height: 12rem;
  }
}
.contact_forms .btns .btn-confirm button:hover,
.contact_forms .btns .btn-submit button:hover,
.contact_forms .btns .btn-back button:hover {
  transform: translateY(6px);
  filter: drop-shadow(2px 0px 0px #cccccc);
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  .contact_forms .btns .btn-confirm button:hover,
  .contact_forms .btns .btn-submit button:hover,
  .contact_forms .btns .btn-back button:hover {
    transform: translateY(6rem);
    filter: drop-shadow(2rem 0px 0px #cccccc);
  }
}
.contact_forms .mw_wp_form_confirm .btns {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media screen and (max-width: 1366px) {
  .contact_forms .mw_wp_form_confirm .btns {
    gap: 20rem;
  }
}
.contact_forms .mw_wp_form_confirm .item p,
.contact_forms .mw_wp_form_confirm .item .detail,
.contact_forms .mw_wp_form_confirm .item .privacy {
  font-size: 1.8rem;
  line-height: 2;
  font-size: 18px;
  font-weight: 500;
}
@media screen and (max-width: 1366px) {
  .contact_forms .mw_wp_form_confirm .item p,
  .contact_forms .mw_wp_form_confirm .item .detail,
  .contact_forms .mw_wp_form_confirm .item .privacy {
    font-size: 18rem;
  }
}

.contact_qa .w1080 {
  padding: 60px 0 110px;
}
@media screen and (max-width: 1366px) {
  .contact_qa .w1080 {
    padding: 60rem 0 110rem;
  }
}
.contact_qa .w1080 .faq_list {
  display: flex;
  gap: 19px;
  justify-content: center;
  margin-bottom: 52px;
}
@media screen and (max-width: 1366px) {
  .contact_qa .w1080 .faq_list {
    gap: 19rem;
    margin-bottom: 52rem;
  }
}
@media screen and (max-width: 1024px) {
  .contact_qa .w1080 .faq_list {
    display: grid;
    align-items: center;
  }
}
.contact_qa .w1080 .faq_list .item {
  background-color: #fff;
  text-align: center;
  font-weight: 700;
  max-width: 265px;
  width: 100%;
  border-radius: 999px;
  position: relative;
  height: 51px;
  color: #1f4c9f;
  border: 1px solid #1f4c9f;
  transition: all 0.4s ease;
  cursor: pointer;
}
.contact_qa .w1080 .faq_list .item.is-active {
  background-color: #1f4c9f;
  color: #fff;
}
@media screen and (max-width: 1366px) {
  .contact_qa .w1080 .faq_list .item {
    max-width: 265rem;
    height: 51rem;
  }
}
@media screen and (max-width: 1024px) {
  .contact_qa .w1080 .faq_list .item {
    width: 265rem;
  }
}
.contact_qa .w1080 .faq_list .item p {
  font-size: 16px;
  line-height: 51px;
}
@media screen and (max-width: 1366px) {
  .contact_qa .w1080 .faq_list .item p {
    font-size: 16rem;
    line-height: 51rem;
  }
}
.contact_qa .w1080 .faq_list .item:hover {
  background-color: #1f4c9f;
  color: #fff;
  transition: all 0.4s ease;
}
.contact_qa .w1080 .faq_list .item:hover p {
  color: #fff;
}
@media screen and (max-width: 1024px) {
  .contact_qa .w1080 .faq_list .item:first-child {
    grid-column: 1/3;
    margin: auto;
  }
}
@media screen and (max-width: 1024px) {
  .contact_qa .w1080 .faq_list .item:nth-child(2) {
    grid-column: 1/2;
    grid-row: 2;
  }
}
@media screen and (max-width: 1024px) {
  .contact_qa .w1080 .faq_list .item:nth-child(3) {
    grid-column: 2/3;
    grid-row: 2;
  }
}
.contact_qa .w1080 .tab-content {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
@media screen and (max-width: 1366px) {
  .contact_qa .w1080 .tab-content {
    gap: 10rem;
  }
}
.contact_qa .w1080 .tab-content .item {
  max-width: 1060px;
  width: 100%;
  margin: auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
@media screen and (max-width: 1366px) {
  .contact_qa .w1080 .tab-content .item {
    max-width: 1060rem;
    gap: 12rem;
  }
}
@media screen and (max-width: 1024px) {
  .contact_qa .w1080 .tab-content .item {
    max-width: 580rem;
    gap: 17rem;
  }
}
.contact_qa .w1080 .tab-content .item .question {
  background-color: #1f4c9f;
  color: #fff;
  font-size: 2.1rem;
  line-height: 1.5238095238;
  font-size: 21px;
  font-weight: 700;
  padding: 24px 98px 24px 30px;
  border-radius: 12px;
  cursor: pointer;
  position: relative;
}
@media screen and (max-width: 1366px) {
  .contact_qa .w1080 .tab-content .item .question {
    font-size: 21rem;
    line-height: 32rem;
    padding: 24rem 98rem 24rem 30rem;
    border-radius: 12rem;
  }
}
.contact_qa .w1080 .tab-content .item .question::after {
  content: "＋";
  width: 38px;
  height: 38px;
  line-height: 38px;
  border: 1px solid #fff;
  color: #fff;
  border-radius: 999px;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  right: 31px;
}
@media screen and (max-width: 1366px) {
  .contact_qa .w1080 .tab-content .item .question::after {
    width: 38rem;
    height: 38rem;
    line-height: 38rem;
    right: 31rem;
  }
}
.contact_qa .w1080 .tab-content .item .answer {
  font-size: 1.8rem;
  line-height: 1.7777777778;
  font-size: 18px;
  max-width: 1039px;
  font-weight: 500;
  width: 100%;
  margin: auto;
  height: 0;
  visibility: hidden;
  opacity: 0;
  transition: padding 0.6s ease, opacity 0.6s ease, height 0.6s ease;
}
@media screen and (max-width: 1366px) {
  .contact_qa .w1080 .tab-content .item .answer {
    font-size: 18rem;
    max-width: 1039rem;
  }
}
.contact_qa .w1080 .tab-content .item.active .question::after {
  content: "ー";
}
.contact_qa .w1080 .tab-content .item.active .answer {
  max-height: 5000px;
  box-sizing: content-box;
  visibility: visible;
  opacity: 1;
  height: auto;
  padding-top: 34px;
  padding-bottom: 65px;
  transition: padding 0.6s ease, opacity 0.6s ease, height 0.6s ease;
}
@media screen and (max-width: 1366px) {
  .contact_qa .w1080 .tab-content .item.active .answer {
    padding-top: 34rem;
    padding-bottom: 65rem;
    max-height: 5000rem;
  }
}

@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "KozGoPr6N";
  src: url("../fonts/KozGoPr6N-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "Acumin";
  src: url("../fonts/Acumin-Pro-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
}
.news_list .w1080 {
  padding-bottom: 135px;
}
@media screen and (max-width: 1366px) {
  .news_list .w1080 {
    padding-bottom: 135rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_list .w1080 {
    width: 100%;
  }
}
.news_list .w1080 .grid-item {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto;
  gap: 81px 56px;
}
@media screen and (max-width: 1366px) {
  .news_list .w1080 .grid-item {
    gap: 81rem 56rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_list .w1080 .grid-item {
    width: 90%;
    margin: auto;
    justify-content: space-between;
    row-gap: 20rem;
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 640px) {
  .news_list .w1080 .grid-item {
    grid-template-columns: 580rem;
    gap: 30rem 10rem;
    justify-content: center;
  }
}
.news_list .w1080 .grid-item .item {
  position: relative;
  transition: 0.4s ease;
}
.news_list .w1080 .grid-item .item .thum {
  width: 100%;
  height: 214px;
  border-radius: 25px;
  margin-bottom: 11px;
}
@media screen and (max-width: 1366px) {
  .news_list .w1080 .grid-item .item .thum {
    height: 214rem;
    border-radius: 25rem;
    margin-bottom: 11rem;
  }
}
@media screen and (max-width: 640px) {
  .news_list .w1080 .grid-item .item .thum {
    height: 385rem;
  }
}
.news_list .w1080 .grid-item .item .thum img {
  border-radius: 25px;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media screen and (max-width: 1366px) {
  .news_list .w1080 .grid-item .item .thum img {
    border-radius: 25rem;
  }
}
.news_list .w1080 .grid-item .item:hover {
  filter: opacity(60%);
  transition: 0.4s ease;
}
.news_list .w1080 .grid-item .item a {
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.news_list .w1080 .grid-item .item .item-ttl {
  font-weight: 500;
  font-size: 1.8rem;
  line-height: 1.7777777778;
  font-size: 18px;
}
@media screen and (max-width: 1366px) {
  .news_list .w1080 .grid-item .item .item-ttl {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_list .w1080 .grid-item .item .item-ttl {
    font-size: clamp(16px, 16px + (18 - 16) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.news_list .w1080 .grid-item .item .item-element {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}
@media screen and (max-width: 1366px) {
  .news_list .w1080 .grid-item .item .item-element {
    margin-bottom: 10rem;
  }
}
.news_list .w1080 .grid-item .item .item-element .update {
  font-weight: 500;
  color: #cccccc;
  font-size: 18px;
  line-height: 1.2;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 1366px) {
  .news_list .w1080 .grid-item .item .item-element .update {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_list .w1080 .grid-item .item .item-element .update {
    font-size: clamp(12px, 12px + (18 - 12) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.news_list .w1080 .grid-item .item .item-element .cat {
  font-weight: 500;
  color: #1f4c9f;
  font-size: 16px;
  line-height: 1.2;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1366px) {
  .news_list .w1080 .grid-item .item .item-element .cat {
    font-size: 16rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_list .w1080 .grid-item .item .item-element .cat {
    font-size: clamp(12px, 12px + (18 - 12) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.news_list .w1080 .grid-item .item .item-element .cat::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 4px;
  background-color: #1f4c9f;
  border-radius: 50px;
  vertical-align: middle;
  margin-right: 6px;
}
@media screen and (max-width: 1366px) {
  .news_list .w1080 .grid-item .item .item-element .cat::before {
    margin-right: 6rem;
  }
}
.news_list .w1080 .grid-item .noarticle {
  font-size: 15px;
}
@media screen and (max-width: 1366px) {
  .news_list .w1080 .grid-item .noarticle {
    font-size: 15rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_list .w1080 .grid-item .noarticle {
    font-size: clamp(14px, 14px + (15 - 14) * (100vw - 320px) / (640 - 320), 15px);
  }
}
.news_list .pagination {
  display: flex;
  justify-content: center;
  gap: 14px;
  margin-top: 92px;
}
@media screen and (max-width: 1366px) {
  .news_list .pagination {
    gap: 14rem;
    margin-top: 92rem;
  }
}
.news_list .pagination li.current a {
  background-color: #1f4c9f;
  color: #fff;
}
.news_list .pagination li a {
  width: 65px;
  height: 65px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 18px;
  font-weight: 700;
  border-radius: 999px;
  background-color: transparent;
  border: 1px solid #1f4c9f;
}
@media screen and (max-width: 1366px) {
  .news_list .pagination li a {
    width: 65rem;
    height: 65rem;
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_list .pagination li a {
    font-size: clamp(12px, 12px + (18 - 12) * (100vw - 320px) / (640 - 320), 18px);
  }
}

.news_content {
  padding-top: 50px;
}
.news_content .w1080 {
  width: 100%;
  max-width: none;
}
.news_content .w1080 .item-element {
  max-width: 1080px;
  width: 90%;
  margin: auto auto 16px;
  display: flex;
  gap: 28px;
  align-items: center;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .item-element {
    max-width: 1080rem;
    margin-bottom: 16rem;
    gap: 28rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_content .w1080 .item-element {
    width: 580rem;
    gap: 24rem;
    margin-bottom: 20rem;
  }
}
.news_content .w1080 .item-element .update {
  font-weight: 500;
  color: #cccccc;
  font-size: 16px;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .item-element .update {
    font-size: 16rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_content .w1080 .item-element .update {
    font-size: clamp(12px, 12px + (16 - 12) * (100vw - 320px) / (640 - 320), 16px);
  }
}
.news_content .w1080 .item-element .cat {
  font-weight: 500;
  color: #1f4c9f;
  font-size: 16px;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .item-element .cat {
    font-size: 16rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_content .w1080 .item-element .cat {
    font-size: clamp(12px, 12px + (16 - 12) * (100vw - 320px) / (640 - 320), 16px);
  }
}
.news_content .w1080 .item-element .cat::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 4px;
  background-color: #1f4c9f;
  border-radius: 50px;
  vertical-align: middle;
  margin-right: 6px;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .item-element .cat::before {
    width: 4rem;
    height: 4rem;
    margin-right: 6rem;
  }
}
.news_content .w1080 .item-ttl {
  font-weight: 500;
  color: #3e3a39;
  max-width: 1080px;
  width: 90%;
  margin: auto auto 40px;
  font-size: 2.4rem;
  line-height: 1.3333333333;
  font-size: 24px;
  position: relative;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .item-ttl {
    max-width: 1080rem;
    font-size: 24rem;
    margin: auto auto 40rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_content .w1080 .item-ttl {
    max-width: 580rem;
    width: 100%;
    font-size: clamp(16px, 16px + (24 - 16) * (100vw - 320px) / (640 - 320), 24px);
  }
}
.news_content .w1080 .news-slider {
  padding-bottom: 90px;
  margin-bottom: 60px;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .news-slider {
    padding-bottom: 90rem;
    margin-bottom: 60rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_content .w1080 .news-slider {
    margin-bottom: 40rem;
  }
}
.news_content .w1080 .news-slider .swiper-slide {
  width: 758px;
  height: 504px;
  margin-left: 25px;
  border-radius: 25px;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .news-slider .swiper-slide {
    width: 758rem;
    height: 504rem;
    margin-left: 25rem;
    border-radius: 25rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_content .w1080 .news-slider .swiper-slide {
    width: 580rem;
    height: 385rem;
    margin-left: 18rem;
  }
}
.news_content .w1080 .news-slider .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 25px;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .news-slider .swiper-slide img {
    border-radius: 25rem;
  }
}
.news_content .w1080 .news-slider .swiper-button-prev,
.news_content .w1080 .news-slider .swiper-button-next {
  width: 62px;
  height: 62px;
  left: 45.0219619327%;
  bottom: 0;
  top: auto;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .news-slider .swiper-button-prev,
  .news_content .w1080 .news-slider .swiper-button-next {
    width: 62rem;
    height: 62rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_content .w1080 .news-slider .swiper-button-prev,
  .news_content .w1080 .news-slider .swiper-button-next {
    left: 39.375%;
  }
}
.news_content .w1080 .news-slider .swiper-button-prev::after,
.news_content .w1080 .news-slider .swiper-button-next::after {
  content: none;
}
.news_content .w1080 .news-slider .swiper-button-next {
  left: auto;
  right: 45.0219619327%;
}
@media screen and (max-width: 1024px) {
  .news_content .w1080 .news-slider .swiper-button-next {
    right: 39.375%;
  }
}
.news_content .w1080 .text {
  max-width: 1080px;
  width: 90%;
  margin: auto auto 78px;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .text {
    max-width: 1080rem;
    margin-bottom: 78rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_content .w1080 .text {
    max-width: 580rem;
  }
}
.news_content .w1080 .text p {
  font-size: 1.8rem;
  line-height: 2;
  font-size: 18px;
  font-weight: 500;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .text p {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_content .w1080 .text p {
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.news_content .w1080 .btn {
  width: 336px;
  border-radius: 32px;
  font-size: 18px;
  font-weight: 700;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding-right: 21px;
  height: 65px;
  color: #fff;
  background-color: #1f4c9f;
  gap: 87px;
  margin: auto auto 90px auto;
  filter: drop-shadow(2px 6px 0px #cccccc);
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .btn {
    width: 336rem;
    border-radius: 32rem;
    font-size: 18rem;
    padding-right: 21rem;
    height: 65rem;
    gap: 87rem;
    margin-bottom: 90rem;
    filter: drop-shadow(2rem 6rem 0px #cccccc);
  }
}
@media screen and (max-width: 1024px) {
  .news_content .w1080 .btn {
    width: 389rem;
    justify-content: center;
    padding-right: 0;
    gap: 22rem;
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
    height: 64rem;
    filter: drop-shadow(2rem 6rem 0px #cccccc);
  }
  .news_content .w1080 .btn:hover {
    transform: translateY(6rem);
    filter: drop-shadow(2rem 0px 0px #cccccc);
  }
}
.news_content .w1080 .btn svg {
  width: 15px;
  height: 12px;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .btn svg {
    width: 15rem;
    height: 12rem;
  }
}
.news_content .w1080 .btn:hover {
  transform: translateY(6px);
  filter: drop-shadow(2px 0px 0px #cccccc);
  transition: all 0.4s ease;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .btn:hover {
    transform: translateY(6rem);
    filter: drop-shadow(2rem 0px 0px #cccccc);
  }
}
.news_content .w1080 .product-wrap {
  position: relative;
  max-width: 1080px;
  width: 90%;
  margin: auto auto 45px;
  justify-content: center;
  display: grid;
  grid-template-columns: 471px 1fr;
  gap: 43px;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .product-wrap {
    max-width: 1080rem;
    margin-bottom: 45rem;
    grid-template-columns: 471rem 1fr;
    gap: 43rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_content .w1080 .product-wrap {
    display: flex;
    flex-direction: column;
  }
}
@media screen and (max-width: 640px) {
  .news_content .w1080 .product-wrap {
    max-width: 580rem;
  }
}
.news_content .w1080 .product-wrap .product-slider {
  margin-bottom: 13px;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .product-wrap .product-slider {
    margin-bottom: 13rem;
  }
}
.news_content .w1080 .product-wrap .product-slider .swiper-slide {
  width: 100%;
  height: 315px;
  border-radius: 25px;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .product-wrap .product-slider .swiper-slide {
    height: 315rem;
    border-radius: 25rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_content .w1080 .product-wrap .product-slider .swiper-slide {
    height: 385rem;
  }
}
.news_content .w1080 .product-wrap .product-slider .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 25px;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .product-wrap .product-slider .swiper-slide img {
    border-radius: 25rem;
  }
}
.news_content .w1080 .product-wrap .thumb-slider .swiper-slide {
  cursor: pointer;
  width: 109px;
  height: 73px;
  margin-right: 10px;
  border-radius: 11px;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .product-wrap .thumb-slider .swiper-slide {
    width: 109rem;
    height: 73rem;
    margin-right: 10rem;
    border-radius: 11rem;
  }
}
@media screen and (max-width: 640px) {
  .news_content .w1080 .product-wrap .thumb-slider .swiper-slide {
    width: 135rem;
    height: 90rem;
    margin-right: 13rem;
  }
}
.news_content .w1080 .product-wrap .thumb-slider .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 11px;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .product-wrap .thumb-slider .swiper-slide img {
    border-radius: 11rem;
  }
}
.news_content .w1080 .product-wrap .swiper-element {
  position: absolute;
  bottom: 0;
  left: 47.5%;
  width: 100%;
  height: 62px;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .product-wrap .swiper-element {
    height: 62rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_content .w1080 .product-wrap .swiper-element {
    left: auto;
    right: 0;
    width: 135rem;
  }
}
.news_content .w1080 .product-wrap .swiper-element .swiper-button-prev,
.news_content .w1080 .product-wrap .swiper-element .swiper-button-next {
  position: absolute;
  width: 62px;
  height: 62px;
  left: 0;
  bottom: 0;
  top: auto;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .product-wrap .swiper-element .swiper-button-prev,
  .news_content .w1080 .product-wrap .swiper-element .swiper-button-next {
    width: 62rem;
    height: 62rem;
  }
}
.news_content .w1080 .product-wrap .swiper-element .swiper-button-prev::after,
.news_content .w1080 .product-wrap .swiper-element .swiper-button-next::after {
  content: none;
}
.news_content .w1080 .product-wrap .swiper-element .swiper-button-next {
  left: 6.6666666667%;
}
@media screen and (max-width: 1024px) {
  .news_content .w1080 .product-wrap .swiper-element .swiper-button-next {
    left: auto;
    right: 0;
  }
}
.news_content .w1080 .product-detail .item-ttl {
  font-size: 3rem;
  line-height: 1.5333333333;
  font-size: 30px;
  font-weight: 500;
  margin: 0;
  margin-bottom: 24px;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .product-detail .item-ttl {
    font-size: 30rem;
    margin-bottom: 24rem;
  }
}
.news_content .w1080 .product-detail .item-element {
  margin: 0;
}
.news_content .w1080 .product-detail .pricearea .sale {
  font-size: 4.8rem;
  line-height: 0.6666666667;
  font-size: 48px;
  font-weight: 700;
  color: #1f4c9f;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .product-detail .pricearea .sale {
    font-size: 48rem;
  }
}
.news_content .w1080 .product-detail .pricearea .sale span {
  font-size: 2.1rem;
  line-height: 1.5238095238;
  font-size: 21px;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .product-detail .pricearea .sale span {
    font-size: 21rem;
  }
}
.news_content .w1080 .product-detail .pricearea .soldout {
  font-family: "Acumin", sans-serif;
  font-size: 5.2rem;
  line-height: 1.75;
  font-size: 52px;
  color: #ff0000;
  font-weight: 700;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1366px) {
  .news_content .w1080 .product-detail .pricearea .soldout {
    font-size: 52rem;
    letter-spacing: 0.1rem;
  }
}

.related-news .w1080 {
  max-width: 1080px;
}
@media screen and (max-width: 1366px) {
  .related-news .w1080 {
    max-width: 1080rem;
  }
}
@media screen and (max-width: 1024px) {
  .related-news .w1080 {
    max-width: 580rem;
  }
}
@media screen and (max-width: 1024px) {
  .related-news .w1080 .related-swiper {
    overflow: visible;
  }
}
.related-news .w1080 .related-swiper .swiper-wrapper {
  justify-content: space-between;
}
.related-news .w1080 .related-swiper .swiper-slide {
  position: relative;
  transition: 0.6s ease;
  width: 322px;
}
@media screen and (max-width: 1366px) {
  .related-news .w1080 .related-swiper .swiper-slide {
    width: 322rem;
  }
}
@media screen and (max-width: 1024px) {
  .related-news .w1080 .related-swiper .swiper-slide {
    width: 100%;
  }
}
.related-news .w1080 .related-swiper .swiper-slide:hover {
  filter: opacity(80%);
  transition: 0.6s ease;
}
.related-news .w1080 .related-swiper .swiper-slide a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
}
.related-news .w1080 .related-swiper .swiper-slide .thum {
  margin-bottom: 11px;
  height: 214px;
  border-radius: 25px;
}
@media screen and (max-width: 1366px) {
  .related-news .w1080 .related-swiper .swiper-slide .thum {
    margin-bottom: 11rem;
    height: 214rem;
    border-radius: 25rem;
  }
}
@media screen and (max-width: 1024px) {
  .related-news .w1080 .related-swiper .swiper-slide .thum {
    height: 300rem;
  }
}
.related-news .w1080 .related-swiper .swiper-slide .thum img {
  width: 100%;
  height: 100%;
  border-radius: 25px;
  object-fit: cover;
}
@media screen and (max-width: 1366px) {
  .related-news .w1080 .related-swiper .swiper-slide .thum img {
    border-radius: 25rem;
  }
}
.related-news .w1080 .related-swiper .swiper-slide .item-element {
  margin-bottom: 3px;
  justify-content: space-between;
}
@media screen and (max-width: 1366px) {
  .related-news .w1080 .related-swiper .swiper-slide .item-element {
    margin-bottom: 3rem;
  }
}
@media screen and (max-width: 1024px) {
  .related-news .w1080 .related-swiper .swiper-slide .item-element {
    width: 100%;
  }
}
.related-news .w1080 .related-swiper .swiper-slide .item-element .update {
  font-size: 18px;
}
@media screen and (max-width: 1366px) {
  .related-news .w1080 .related-swiper .swiper-slide .item-element .update {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .related-news .w1080 .related-swiper .swiper-slide .item-element .update {
    font-size: clamp(12px, 12px + (18 - 12) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.related-news .w1080 .related-swiper .swiper-slide .item-element .cat {
  font-size: 16px;
}
@media screen and (max-width: 1366px) {
  .related-news .w1080 .related-swiper .swiper-slide .item-element .cat {
    font-size: 16rem;
  }
}
@media screen and (max-width: 1024px) {
  .related-news .w1080 .related-swiper .swiper-slide .item-element .cat {
    font-size: clamp(12px, 12px + (18 - 12) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.related-news .w1080 .related-swiper .swiper-slide .item-ttl {
  font-size: 1.8rem;
  line-height: 1.7777777778;
  font-size: 18px;
  padding-bottom: 0;
  border: none;
}
@media screen and (max-width: 1366px) {
  .related-news .w1080 .related-swiper .swiper-slide .item-ttl {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .related-news .w1080 .related-swiper .swiper-slide .item-ttl {
    width: 100%;
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.related-news .w1080 .related-swiper .swiper-slide .item-ttl::after {
  content: none;
}

.article-info {
  max-width: 1080px;
  width: 90%;
  margin: auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 35px;
}
@media screen and (max-width: 1366px) {
  .article-info {
    max-width: 1080rem;
    gap: 10rem;
    margin-bottom: 35rem;
  }
}
.article-info .item {
  display: grid;
  grid-template-columns: 30% 1fr;
  gap: 11px 8px;
}
@media screen and (max-width: 1366px) {
  .article-info .item {
    gap: 11rem 8rem;
  }
}
@media screen and (max-width: 1024px) {
  .article-info .item {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
  }
}
.article-info .item .info__label {
  background-color: #e7edf7;
  border-radius: 15px 0 0 15px;
  display: table;
  padding-left: 32px;
}
@media screen and (max-width: 1366px) {
  .article-info .item .info__label {
    border-radius: 15rem 0 0 15rem;
    padding-left: 32rem;
  }
}
@media screen and (max-width: 1024px) {
  .article-info .item .info__label {
    height: 75rem;
    border-radius: 15rem 15rem 0 0;
    padding-left: 15rem;
  }
}
.article-info .item .info__label h3 {
  font-size: 18px;
  font-weight: 700;
  color: #1f4c9f;
  font-feature-settings: "palt";
  vertical-align: middle;
  display: table-cell;
}
@media screen and (max-width: 1366px) {
  .article-info .item .info__label h3 {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .article-info .item .info__label h3 {
    font-size: clamp(12px, 12px + (18 - 12) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.article-info .item .info__text {
  border-radius: 0 15px 15px 0;
  padding: 28px 32px;
  border: 1px solid #e6e6e6;
}
@media screen and (max-width: 1366px) {
  .article-info .item .info__text {
    border-radius: 0 15rem 15rem 0;
    padding: 28rem 32rem;
  }
}
@media screen and (max-width: 1024px) {
  .article-info .item .info__text {
    border-radius: 0 0 15rem 15rem;
    padding: 28rem 13rem;
  }
}
.article-info .item .info__text p,
.article-info .item .info__text a {
  font-size: 1.8rem;
  line-height: 2;
  font-size: 18px;
  font-weight: 400;
  font-feature-settings: "palt";
}
@media screen and (max-width: 1366px) {
  .article-info .item .info__text p,
  .article-info .item .info__text a {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .article-info .item .info__text p,
  .article-info .item .info__text a {
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.article-info .item.info__spec {
  margin-top: 55px;
}
@media screen and (max-width: 1366px) {
  .article-info .item.info__spec {
    margin-top: 55rem;
  }
}
.article-info .item.info__description, .article-info .item.info__delivery, .article-info .item.info__spec {
  grid-template-columns: 1fr;
  grid-template-rows: auto;
  gap: 33px;
  margin-bottom: 55px;
}
@media screen and (max-width: 1366px) {
  .article-info .item.info__description, .article-info .item.info__delivery, .article-info .item.info__spec {
    gap: 33rem;
    margin-bottom: 55rem;
  }
}
.article-info .item.info__description .info__label, .article-info .item.info__delivery .info__label, .article-info .item.info__spec .info__label {
  background-color: transparent;
  border-radius: 0;
  display: block;
  padding-left: 32px;
  padding-bottom: 20px;
  border-bottom: 4px solid #1f4c9f;
}
@media screen and (max-width: 1366px) {
  .article-info .item.info__description .info__label, .article-info .item.info__delivery .info__label, .article-info .item.info__spec .info__label {
    padding-left: 32rem;
    padding-bottom: 20rem;
    border-bottom: 4rem solid #1f4c9f;
  }
}
@media screen and (max-width: 1024px) {
  .article-info .item.info__description .info__label, .article-info .item.info__delivery .info__label, .article-info .item.info__spec .info__label {
    height: auto;
    padding-left: 15rem;
  }
}
.article-info .item.info__description .info__label h3, .article-info .item.info__delivery .info__label h3, .article-info .item.info__spec .info__label h3 {
  font-size: 21px;
  font-weight: 700;
  color: #1f4c9f;
  font-feature-settings: "palt";
}
@media screen and (max-width: 1366px) {
  .article-info .item.info__description .info__label h3, .article-info .item.info__delivery .info__label h3, .article-info .item.info__spec .info__label h3 {
    font-size: 21rem;
  }
}
@media screen and (max-width: 1024px) {
  .article-info .item.info__description .info__label h3, .article-info .item.info__delivery .info__label h3, .article-info .item.info__spec .info__label h3 {
    font-size: clamp(12px, 12px + (18 - 12) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.article-info .item.info__description .info__text, .article-info .item.info__delivery .info__text, .article-info .item.info__spec .info__text {
  display: block;
  border-radius: 0;
  padding: 0;
  padding-left: 32px;
  border: none;
}
@media screen and (max-width: 1366px) {
  .article-info .item.info__description .info__text, .article-info .item.info__delivery .info__text, .article-info .item.info__spec .info__text {
    padding-left: 32rem;
  }
}
@media screen and (max-width: 1024px) {
  .article-info .item.info__description .info__text, .article-info .item.info__delivery .info__text, .article-info .item.info__spec .info__text {
    padding-left: 15rem;
  }
}
.article-info .item.info__description .info__text p, .article-info .item.info__delivery .info__text p, .article-info .item.info__spec .info__text p {
  font-size: 1.8rem;
  line-height: 2;
  font-size: 18px;
  font-weight: 500;
  font-feature-settings: "palt";
  display: block;
}
@media screen and (max-width: 1366px) {
  .article-info .item.info__description .info__text p, .article-info .item.info__delivery .info__text p, .article-info .item.info__spec .info__text p {
    font-size: 18rem;
  }
}
@media screen and (max-width: 1024px) {
  .article-info .item.info__description .info__text p, .article-info .item.info__delivery .info__text p, .article-info .item.info__spec .info__text p {
    font-size: clamp(14px, 14px + (18 - 14) * (100vw - 320px) / (640 - 320), 18px);
  }
}
.article-info .item.info__remarks {
  margin-bottom: 0;
}
@media screen and (max-width: 1366px) {
  .article-info .item.info__remarks {
    margin-bottom: 0;
  }
}/*# sourceMappingURL=subpage.css.map */