@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Crimson+Text:ital,wght@0,400;0,600;0,700;1,400;1,600;1,700&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&family=Source+Sans+3:ital,wght@0,200..900;1,200..900&display=swap");
:root {
  --base-col: #FFFFFF;
  --primary-col: #FFFFFF;
  --secondary-col: #3A3A3A;
  --third-col: #FAFAFA;
  --force-col: #D9D9D9;
  --fifth-col: #6E6E6E;
  --six-col: #F6F6F6;
  --seven-col: #969696;
  --eight-col: #F5F5F5;
  --nine-col: #E9E9E9;
  --ten-col: #A7A397;
  --eleven-col: #76808B;
  --twelve-col: #B79286;
  --thirteen-col: #EFEFEF;
  --fourteen-col: #666666;
  --fifteen-col: #9D9D9D;
  --sixteen-col: #DCDCDC;
  --seventeen-col: #F2F3F4;
  --black-col: #000000;
  --gray-col: #6E6E6E;
  --pink-col: #cc9cad;
  --white-col: #FFFFFF;
  --red-col: #ba6247;
  --red2-col: #AB1C23;
  --red3-col: #912228;
  --camel-col: #9F5950;
  --sakura-col: #F0A0BB;
  --deep_pink-col: #E41C96;
  --s_blue-col: #44418C;
  --orange-col: #EEB460;
  --kimidori-col: #D0D75F;
  --red4-col: #C30300;
  --pink-col: #E165B0;
  --gold-col: #AD9149;
  --silver-col: #979797;
  --s_blue-col: #44418C;
  --txt-col: #3A3A3A;
  --link-col: #000000;
  --link-hov-col: #4c4c4c;
  --header-col: var(--base-col);
  --header-txt-col: var(--base-col);
  --bg-col: var(--base-col);
  --btn-col: var(--primary-col);
  --btn-txt-col: var(--secondary-col);
  --border-form-col: #FFFFFF;
  --border-table-col: var(--gray-col);
  --check-active-col: #FFFFFF;
  --section-active-col: #FFFFFF;
  --font-size: 10px;
  --font-primary: "Noto Serif JP", serif;
  --font-secondary: "Shippori Mincho", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
  --font-third: "Source Sans 3", sans-serif;
  --font-arial: "Crimson Text", "Noto Serif JP", serif;
  --header-height: 7.0rem;
}

.col1 {
  --bg-col: var(--base-col);
}

.col2 {
  --bg-col: var(--secondary-col);
}

.col3 {
  --bg-col: var(--third-col);
}

.col4 {
  --bg-col: var(--force-col);
}

.col5 {
  --bg-col: var(--primary-col);
}

.col6 {
  --bg-col: var(--six-col);
  --txt-col: var(--base-col);
}

.col7 {
  --bg-col: var(--seven-col);
  --txt-col: var(--base-col);
}

/*
    --figure-height: 60vh;
    @include figure;
*/
/*
font-family: "Noto Sans JP", sans-serif;
font-optical-sizing: auto;
font-weight: <weight>;
font-style: normal;
*/
/*
font-family: "Noto Serif JP", serif;
font-optical-sizing: auto;
font-weight: <weight>;
font-style: normal;
*/
/*
font-family: "Crimson Text", serif;
font-weight: 400;
font-style: normal;
*/
/*
font-family: "Source Sans 3", sans-serif;
font-optical-sizing: auto;
font-weight: <weight>;
font-style: normal;
*/
/* ----------------------------------------------------------------
base
-------------------------------------------------------------------*/
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html,
body {
  height: 100%;
  font-family: var(--font-primary);
  font-weight: 400;
  font-style: normal;
  font-size: var(--font-size);
}

body {
  padding: 0;
  color: var(--txt-col);
  letter-spacing: 1px;
  -webkit-text-size-adjust: 100%;
  background-color: #ffffff;
}

body, button, input, textarea {
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

a {
  text-decoration: underline;
  color: var(--link-col);
  background-color: transparent;
  transition: all 0.1s linear;
}
a:active {
  outline: 0;
}
a:hover {
  color: var(--link-hov-col);
  outline: 0;
  text-decoration: none;
}

h1 {
  font-size: 3.2rem;
}
@media screen and (max-width: 1024px) {
  h1 {
    font-size: 2.8rem;
  }
}

h2 {
  font-size: 2.8rem;
}
@media screen and (max-width: 1024px) {
  h2 {
    font-size: 2.4rem;
  }
}

h3 {
  font-size: 2.4rem;
}
@media screen and (max-width: 1024px) {
  h3 {
    font-size: 2rem;
  }
}

h4 {
  font-size: 2rem;
}
@media screen and (max-width: 1024px) {
  h4 {
    font-size: 1.8rem;
  }
}

h5 {
  font-size: 1.8rem;
}
@media screen and (max-width: 1024px) {
  h5 {
    font-size: 1.6rem;
  }
}

table {
  --bg-col: none;
  border-spacing: 0;
  border-collapse: collapse;
  width: 100%;
  font-size: 1.5rem;
}
table td,
table th {
  font-size: 1.8rem;
  font-weight: normal;
}
@media screen and (min-width: 1025px) {
  table td,
  table th {
    border-bottom: solid 1px var(--border-table-col);
    padding: 12px 2rem;
  }
}
table thead th {
  text-align: left;
  background-color: var(--bg-col);
  color: var(--txt-col);
  font-size: 2rem;
}
table tbody th {
  text-align: left;
  background-color: var(--bg-col);
  color: var(--txt-col);
}
table tbody td {
  text-align: left;
  background-color: var(--bg-col);
  color: var(--txt-col);
}
@media screen and (max-width: 1024px) {
  table:not(.nores) {
    display: block;
  }
}
@media screen and (max-width: 1024px) {
  table:not(.nores) tr {
    display: block;
    border-bottom: solid 1px var(--border-table-col);
    padding: 2rem 0;
  }
}
@media screen and (max-width: 1024px) {
  table:not(.nores) td,
  table:not(.nores) th {
    display: block;
    padding: 0 2rem;
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 1024px) {
  table:not(.nores) td:before,
  table:not(.nores) th:before {
    content: attr(title);
  }
}
@media screen and (max-width: 1024px) {
  table:not(.nores) thead {
    display: none;
  }
}
@media screen and (max-width: 1024px) {
  table:not(.nores) thead th {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 1024px) {
  table:not(.nores) tbody {
    border-top: solid 1px var(--border-table-col);
    display: block;
  }
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}

p,
label {
  font-size: 1.8rem;
  line-height: 1.6;
}
@media screen and (max-width: 1024px) {
  p,
  label {
    font-size: 1.6rem;
  }
}

ul li,
ol li {
  font-size: 1.6rem;
  padding: 0;
  margin: 0;
  list-style: none;
}

ol li {
  list-style: decimal;
  margin-left: 20px;
}

input[type=checkbox] {
  display: inline-block;
  width: auto;
  margin-right: 0.5rem;
}

summary {
  cursor: pointer;
  list-style: none;
  position: relative;
}

summary::-webkit-details-marker {
  display: none;
}

/* ----------------------------------------------------------------
header
-------------------------------------------------------------------*/
.header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 201;
  opacity: 1;
  transition: all 0.8s ease;
  --header-txt-col: var(--secondary-col);
  --header-base-col: var(--base-col);
  --header-btn-txt-col: var(--base-col);
  --header-btn-bg-col: var(--secondary-col);
}
.header:not(.top_header) {
  background-color: rgba(250, 250, 250, 0.9);
}
.header:not(.top_header) .header_inner {
  backdrop-filter: blur(8px);
}
.header_inner {
  --header-height: 7.0rem;
  width: 100%;
  height: var(--header-height);
  align-items: center;
  display: grid;
  grid-gap: 2rem;
  grid-template-areas: "heading navs";
  grid-template-columns: 1fr;
  justify-content: flex-end;
  align-items: center;
  padding: 0 2rem;
  position: relative;
  z-index: 400;
}
@media screen and (min-width: 1025px) {
  .header_inner {
    grid-template-areas: "heading nav1 navs";
    grid-template-columns: auto 1fr auto;
    justify-content: flex-start;
    padding: 0 6rem;
  }
}
@media screen and (max-width: 1200px) {
  .header_inner {
    padding-left: 2rem;
  }
}
.header_inner .header-logo {
  grid-area: heading;
}
.header_inner .gnav {
  grid-area: nav1;
}
.header_inner .menu {
  grid-area: navs;
}
.header-logo {
  display: block;
  text-align: center;
}
.header-logo h1 {
  color: var(--txt-col);
  position: relative;
  text-align: center;
  display: flex;
  align-items: center;
  font-family: "Source Sans 3", sans-serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
  font-size: 2.2rem;
  letter-spacing: 0.23em;
}
@media screen and (max-width: 1024px) {
  .header-logo h1 {
    font-size: 1.6rem;
  }
}
.header-logo h1 a {
  color: var(--txt-col);
  display: inline-block;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: var(--header-txt-col);
}
.header-logo h1 a:hover {
  opacity: 0.8;
}
.header .gnav {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  grid-gap: 2rem;
}
@media screen and (max-width: 1200px) {
  .header .gnav {
    grid-gap: 0rem;
  }
}
@media screen and (max-width: 1024px) {
  .header .gnav {
    display: none;
  }
}
.header .gnav-menu {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  grid-gap: 4rem;
}
@media screen and (max-width: 1200px) {
  .header .gnav-menu {
    grid-gap: 1.5rem;
  }
}
@media screen and (max-width: 1024px) {
  .header .gnav-menu {
    display: none;
  }
}
.header .gnav-menu > li {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  color: var(--header-txt-col);
}
@media screen and (max-width: 1200px) {
  .header .gnav-menu > li {
    font-size: 1.2rem;
  }
}
.header .gnav-menu > li > a {
  text-decoration: none;
  position: relative;
  display: block;
  text-align: center;
  transition: all 0.2s ease;
  color: var(--header-txt-col);
  z-index: 3;
  line-height: var(--header-height);
}
.header .gnav-menu > li > a:after {
  content: "";
  position: absolute;
  left: -15px;
  top: 50%;
  margin-top: -2.5px;
  width: 5px;
  height: 5px;
  border-radius: 2.5px;
  background-color: var(--header-txt-col);
  display: block;
  transition: all 0.3s ease;
  opacity: 0;
}
.header .gnav-menu > li > a:hover:after {
  opacity: 1;
}
.header .gnav-menu > li > a.is_active:after {
  opacity: 1;
}
.header .gnav-menu > li > p {
  color: var(--txt-col);
  text-decoration: none;
  position: relative;
  display: block;
  text-align: center;
  font-size: 1.4rem;
  font-weight: 600;
  letter-spacing: 0px;
}
.header .gnav-link {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  grid-gap: 2rem;
  margin-left: 4rem;
  margin-left: 0rem;
}
@media screen and (max-width: 1200px) {
  .header .gnav-link {
    margin-left: 2rem;
  }
}
@media screen and (max-width: 1024px) {
  .header .gnav-link {
    display: none;
  }
}
.header .gnav-link li {
  font-family: var(--font-arial);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  position: relative;
  color: var(--gray-col);
}
.header .gnav-link li a {
  color: var(--txt-col);
  text-decoration: none;
  position: relative;
  display: block;
  text-align: center;
  transition: all 0.2s ease;
  color: var(--header-btn-txt-col);
  background-color: var(--header-btn-bg-col);
  border-radius: 4px;
  padding: 0 6px;
}
.header .gnav-link li a:hover {
  opacity: 0.8;
}
.header .menu {
  --txt-col: var(--primary-col);
}
.header .menu-drawer {
  display: flex;
}
@media screen and (max-width: 1024px) {
  .header .menu-drawer {
    justify-content: flex-end;
    grid-gap: 2.4rem;
    align-items: center;
  }
  .header .menu-drawer .icon-cart {
    color: var(--header-txt-col);
  }
}
.header .menu-drawer-btn {
  --btn-width: 20px;
  width: var(--btn-width);
  height: 14px;
  border-top: solid 2px var(--header-txt-col);
  border-bottom: solid 2px var(--header-txt-col);
  position: relative;
  cursor: pointer;
  transition: all 0.1s linear;
  z-index: 99;
  border-width: 1px;
}
.header .menu-drawer-btn span:before {
  content: "";
  width: var(--btn-width);
  height: 1px;
  background-color: var(--header-txt-col);
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  margin-top: -1px;
  transition: all 0.1s linear;
}
.header .menu-drawer-btn span:after {
  content: "";
  width: var(--btn-width);
  height: 1px;
  background-color: var(--header-txt-col);
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  margin-top: -1px;
  transition: all 0.1s linear;
}
.header .menu-drawer-btn:hover {
  opacity: 0.7;
}
.header .menu-drawer__inner {
  position: absolute;
  transform: translate(100%);
  visibility: hidden;
  z-index: 3;
  right: 0;
  top: 0;
  width: 100vw;
  padding: 0;
  background-color: var(--header-col);
  overflow-x: hidden;
  height: 100vh;
}
.header .menu-drawer__inner-container {
  position: relative;
  height: 100%;
}
.header .menu-drawer[open] > .menu-drawer__inner {
  transition: transform 0.2s ease, visibility 0.2s ease;
}
.header .menu-drawer[open].menu-opening > .menu-drawer__inner {
  transform: translate(0);
  visibility: visible;
}
.header .menu-drawer[open] .menu-drawer-btn {
  border-width: 0;
  border-color: var(--txt-col);
}
.header .menu-drawer[open] .menu-drawer-btn span:before {
  transform: rotate(45deg);
  background-color: var(--txt-col);
}
.header .menu-drawer[open] .menu-drawer-btn span:after {
  transform: rotate(-45deg);
  background-color: var(--txt-col);
}
.header .menu-drawer__navigation {
  padding-top: 12rem;
  display: flex;
  justify-content: center;
}
.header .menu-drawer__navigation ul li {
  font-family: var(--font-arial);
  margin-bottom: 4rem;
  letter-spacing: 2px;
  position: relative;
  padding-left: 2.4rem;
}
.header .menu-drawer__navigation ul li:after {
  content: "";
  width: 20px;
  height: 20px;
  border-radius: 10px;
  background-color: var(--primary-col);
  display: block;
  position: absolute;
  left: 0;
  top: 2px;
  z-index: 1;
}
.header .menu-drawer__navigation ul li p {
  font-size: 1.6rem;
  font-weight: 600;
  padding: 0 1rem;
}
.header .menu-drawer__navigation ul li p span {
  font-size: 1.2rem;
}
.header .menu-drawer__navigation ul li a {
  text-decoration: none;
  position: relative;
  color: var(--txt-col);
  display: flex;
  align-items: center;
}
.header .menu-drawer__navigation ul li a.active {
  font-size: 24px;
  color: #78a779;
}
.header .menu-drawer__navigation ul li a.active:before {
  content: "";
  width: 10px;
  height: 32px;
  background-color: #78a779;
  display: inline-block;
  transform: rotate(90deg);
  position: absolute;
  left: -30px;
  top: 50%;
  margin-top: -16px;
  transition: all 0.2s ease;
}
.header .menu-drawer__navigation ul li a:hover:before {
  background-color: var(--link-hov-col);
}
.header .menu-seminar {
  position: absolute;
  right: 0;
  top: 5rem;
}
.header .menu-seminar a {
  display: block;
  background-color: var(--force-col);
  border-radius: 4px 4px 0 0;
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.1em;
  padding: 10px 14px;
  text-decoration: none;
  color: var(--fifth-col);
  transform-origin: bottom right;
  transform: rotate(-90deg);
}
.header_lang {
  position: absolute;
  right: 6rem;
  top: var(--header-height);
  padding-top: 2.6rem;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  grid-gap: 4.7rem;
}
@media screen and (max-width: 1024px) {
  .header_lang {
    display: none;
  }
}
.header_lang ul {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.header_lang ul li {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  color: var(--secondary-col);
}
.header_lang ul li:not(:last-child) {
  margin-right: 0.5rem;
}
.header_lang ul li:not(:last-child):after {
  content: "|";
}
.header_lang ul li a {
  color: var(--secondary-col);
}
.header_nav_service {
  --txt-col: var(--secondary-col);
  background-color: rgba(250, 250, 250, 0.9);
  backdrop-filter: blur(8px);
  padding: 4rem 2rem 6rem;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1;
  transform: translateY(-100vh);
  opacity: 0;
  transition: all 0.3s ease;
  box-shadow: 0 10px 10px rgba(0, 0, 0, 0.1);
}
@media screen and (max-width: 1024px) {
  .header_nav_service {
    display: none;
  }
}
.header_nav_service_inner {
  display: grid;
  grid-template-columns: 37.5% auto auto;
  justify-content: flex-start;
}
.header_nav_service_left {
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
  padding-right: 20%;
}
.header_nav_service_guide {
  border: solid 1px var(--seven-col);
  text-align: center;
  padding: 1.5rem 2.5rem 2.2rem;
  text-decoration: none;
  display: inline-block;
  color: var(--txt-col);
}
.header_nav_service_guide h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.7rem;
  letter-spacing: 0.1em;
  line-height: 32px;
  color: var(--txt-col);
}
.header_nav_service_guide p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  color: var(--txt-col);
  margin-top: -6px;
}
.header_nav_service_menu {
  display: flex;
  align-items: flex-start;
}
.header_nav_service_menu_left {
  border-right: solid 1px var(--seven-col);
  padding-right: 5rem;
}
.header_nav_service_menu_right {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  grid-gap: 6rem;
  padding-left: 4.4rem;
}
.header_nav_service_menu_list {
  min-width: 14rem;
}
.header_nav_service_menu_list h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  color: var(--seven-col);
}
.header_nav_service_menu_list h4 + h5 {
  margin-top: 0.5rem;
}
.header_nav_service_menu_list h4 + ul {
  margin-top: 2.2rem;
}
.header_nav_service_menu_list h5 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  line-height: 1.4rem;
  color: var(--seven-col);
}
.header_nav_service_menu_list h5 + ul {
  margin-top: 1.5rem;
}
.header_nav_service_menu_list > ul {
  padding-right: 3rem;
}
.header_nav_service_menu_list > ul > li {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.7rem;
  letter-spacing: 0.1em;
  line-height: 32px;
  color: var(--seven-col);
  margin-bottom: 0.2rem;
  padding-left: 2.4rem;
}
.header_nav_service_menu_list > ul > li:last-child {
  margin-bottom: 0;
}
.header_nav_service_menu_list > ul > li a {
  text-decoration: none;
  position: relative;
  transition: all 0.2s ease;
  color: var(--txt-col);
}
.header_nav_service_menu_list > ul > li a:before {
  content: "";
  position: absolute;
  left: -2.4rem;
  top: 50%;
  margin-top: -2.5px;
  width: 5px;
  height: 5px;
  border-radius: 2.5px;
  background-color: var(--txt-col);
  display: block;
  transition: all 0.3s ease;
  opacity: 0;
}
.header_nav_service_menu_list > ul > li a:hover:before {
  opacity: 1;
}
.header_nav_service_menu_list > ul > li p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  color: var(--txt-col);
  opacity: 0.5;
  margin-bottom: 1.1rem;
}
.header_nav_service_menu_list > ul > li span {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 0.8rem;
  letter-spacing: 0.1em;
  color: var(--seven-col);
}
.header_nav_service_menu_list > ul + ul {
  margin-top: 2rem;
  position: relative;
  padding-top: 1.7rem;
}
.header_nav_service_menu_list > ul + ul:before {
  content: "";
  width: 100%;
  height: 1px;
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  background-color: var(--force-col);
}
.header_nav_about {
  --txt-col: var(--secondary-col);
  background-color: rgba(250, 250, 250, 0.9);
  backdrop-filter: blur(8px);
  padding: 4rem 2rem 6rem;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1;
  transform: translateY(-100vh);
  opacity: 0;
  transition: all 0.3s ease;
  box-shadow: 0 10px 10px rgba(0, 0, 0, 0.1);
}
@media screen and (max-width: 1024px) {
  .header_nav_about {
    display: none;
  }
}
.header_nav_about_inner {
  display: grid;
  grid-template-columns: auto;
  justify-content: flex-start;
}
.header_nav_about_menu_list {
  position: relative;
}
.header_nav_about_menu_list > ul > li {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  margin-bottom: 1.5rem;
  padding-left: 2.4rem;
}
.header_nav_about_menu_list > ul > li:last-child {
  margin-bottom: 0;
}
.header_nav_about_menu_list > ul > li a {
  text-decoration: none;
  position: relative;
  transition: all 0.2s ease;
  color: var(--txt-col);
}
.header_nav_about_menu_list > ul > li a:before {
  content: "";
  position: absolute;
  left: -1.5rem;
  top: 50%;
  margin-top: -2.5px;
  width: 5px;
  height: 5px;
  border-radius: 2.5px;
  background-color: var(--txt-col);
  display: block;
  transition: all 0.3s ease;
  opacity: 0;
}
.header_nav_about_menu_list > ul > li a:hover:before {
  opacity: 1;
}
.header_nav_support {
  --txt-col: var(--secondary-col);
  background-color: rgba(250, 250, 250, 0.9);
  backdrop-filter: blur(8px);
  padding: 4rem 2rem 6rem;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1;
  transform: translateY(-100vh);
  opacity: 0;
  transition: all 0.3s ease;
  box-shadow: 0 10px 10px rgba(0, 0, 0, 0.1);
}
@media screen and (max-width: 1024px) {
  .header_nav_support {
    display: none;
  }
}
.header_nav_support_inner {
  display: grid;
  grid-template-columns: auto;
  justify-content: flex-start;
}
.header_nav_support_menu_list {
  position: relative;
}
.header_nav_support_menu_list > ul > li {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  margin-bottom: 1.5rem;
  padding-left: 2.4rem;
}
.header_nav_support_menu_list > ul > li:last-child {
  margin-bottom: 0;
}
.header_nav_support_menu_list > ul > li a {
  text-decoration: none;
  position: relative;
  transition: all 0.2s ease;
  color: var(--txt-col);
}
.header_nav_support_menu_list > ul > li a:before {
  content: "";
  position: absolute;
  left: -1.5rem;
  top: 50%;
  margin-top: -2.5px;
  width: 5px;
  height: 5px;
  border-radius: 2.5px;
  background-color: var(--txt-col);
  display: block;
  transition: all 0.3s ease;
  opacity: 0;
}
.header_nav_support_menu_list > ul > li a:hover:before {
  opacity: 1;
}
.header .nav_open2 {
  position: relative;
}
.header.is_open .header_nav_service {
  opacity: 1;
  transform: translateY(var(--header-height));
}
.header.is_open2 .header_nav_about {
  opacity: 1;
  transform: translateY(var(--header-height));
}
.header.is_open3 .header_nav_support {
  opacity: 1;
  transform: translateY(var(--header-height));
}
.header_drawer {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 100vh;
  z-index: 100;
  background-color: rgba(250, 250, 250, 0.9);
  backdrop-filter: blur(12px);
  transform: translateY(-100vh);
  opacity: 0;
  transition: all 0.3s ease;
}
@media screen and (max-width: 1024px) {
  .header_drawer {
    background-color: #fafafa;
  }
}
.header_drawer_inner {
  padding: 2.5rem 5rem 10rem;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .header_drawer_inner {
    padding: 2.5rem 0;
  }
}
.header_drawer_close {
  position: absolute;
  right: 5rem;
  top: 2.5rem;
  z-index: 1;
}
@media screen and (max-width: 1024px) {
  .header_drawer_close {
    right: 2rem;
    top: 2.5rem;
  }
}
.header_drawer_close_btn {
  position: relative;
  width: 20px;
  height: 20px;
  display: block;
}
@media screen and (max-width: 1024px) {
  .header_drawer_close_btn {
    width: 26px;
    height: 26px;
  }
}
.header_drawer_close_btn:hover {
  opacity: 0.5;
}
.header_drawer_close_btn span {
  display: none;
}
.header_drawer_close_btn:before {
  content: "";
  width: 28px;
  height: 1px;
  background-color: var(--seven-col);
  transform: rotate(45deg);
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 1;
  margin-top: 0px;
  margin-left: -14px;
}
.header_drawer_close_btn:after {
  content: "";
  width: 28px;
  height: 1px;
  background-color: var(--seven-col);
  transform: rotate(-45deg);
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 1;
  margin-top: 0px;
  margin-left: -14px;
}
.header_drawer_head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 8rem;
}
@media screen and (max-width: 1024px) {
  .header_drawer_head {
    margin-bottom: 6rem;
    padding: 0 2rem;
  }
}
.header_drawer_head_menu {
  padding-right: 11rem;
}
.header_drawer_head_menu ul {
  display: flex;
  align-items: center;
  grid-gap: 4rem;
}
.header_drawer_head_menu ul li {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
}
.header_drawer_head_menu ul li a {
  color: var(--txt-col);
  text-decoration: none;
}
.header_drawer_logo img {
  max-width: 7rem;
}
@media screen and (max-width: 1024px) {
  .header_drawer_logo img {
    max-width: 6rem;
  }
}
@media screen and (min-width: 1025px) {
  .header_drawer_menu {
    display: grid;
    grid-template-columns: auto auto;
    justify-content: center;
    grid-gap: 4.7rem;
  }
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu {
    overflow: auto;
    height: calc(100svh - 17rem);
  }
}
@media screen and (min-width: 1025px) {
  .header_drawer_menu_left {
    display: grid;
    grid-template-columns: auto auto;
    align-items: flex-start;
    justify-content: center;
    grid-gap: 8rem;
    padding-right: 10rem;
    border-right: solid 1px var(--seven-col);
  }
}
.header_drawer_menu_right {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.header_drawer_menu_list {
  position: relative;
}
.header_drawer_menu_list > h4 {
  color: var(--seven-col);
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_list > h4 {
    font-size: 1.6rem;
    padding: 2rem 3rem;
    border-top: solid 1px #D9D9D9;
    background-color: rgba(233, 233, 233, 0.5);
  }
}
.header_drawer_menu_list > h4 + h5 {
  margin-top: 1.5rem;
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_list > h4 + h5 {
    position: absolute;
    left: 3rem;
    top: 6rem;
    z-index: 1;
  }
}
@media screen and (min-width: 1025px) {
  .header_drawer_menu_list > h4 + ul {
    margin-top: 1.8rem;
  }
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_list > h4.is_active + h5 {
    display: block;
  }
  .header_drawer_menu_list > h4.is_active + h5 + ul {
    display: block;
  }
  .header_drawer_menu_list > h4.is_active + h5 + ul + ul {
    display: block;
  }
  .header_drawer_menu_list > h4.is_active + h5 + ul + ul + .header_drawer_menu_guide {
    display: block;
  }
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_list > h4.is_active + ul {
    display: block;
  }
}
.header_drawer_menu_list > h5 {
  color: var(--seven-col);
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  line-height: 32px;
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_list > h5 {
    display: none;
  }
}
@media screen and (min-width: 1025px) {
  .header_drawer_menu_list > h5 + ul {
    margin-top: 0.2rem;
  }
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_list > h5 + ul li {
    padding-left: 5rem;
  }
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_list:not(.header_drawer_menu_list_news) > ul {
    background-color: #E9E9E9;
    display: none;
  }
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_list > ul {
    position: relative;
  }
}
.header_drawer_menu_list > ul > li {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.7rem;
  letter-spacing: 0.1em;
  line-height: 32px;
  color: var(--seven-col);
  margin-bottom: 0.2rem;
  padding-left: 2.4rem;
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_list > ul > li {
    line-height: 1;
    font-size: 1.6rem;
    padding-left: 0;
    margin-bottom: 0;
    border-top: solid 1px #D9D9D9;
  }
}
.header_drawer_menu_list > ul > li:last-child {
  margin-bottom: 0;
}
.header_drawer_menu_list > ul > li a {
  text-decoration: none;
  position: relative;
  transition: all 0.2s ease;
  color: var(--txt-col);
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_list > ul > li a {
    display: block;
    padding: 2rem 3rem;
    color: #808080;
  }
}
@media screen and (min-width: 1025px) {
  .header_drawer_menu_list > ul > li a:before {
    content: "";
    position: absolute;
    left: -2.4rem;
    top: 50%;
    margin-top: -2.5px;
    width: 5px;
    height: 5px;
    border-radius: 2.5px;
    background-color: var(--txt-col);
    display: block;
    transition: all 0.3s ease;
    opacity: 0;
  }
}
.header_drawer_menu_list > ul > li a:hover:before {
  opacity: 1;
}
.header_drawer_menu_list > ul > li p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  color: var(--txt-col);
  opacity: 0.5;
  margin-bottom: 1.3rem;
  margin-top: -0.2rem;
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_list > ul > li p {
    display: none;
  }
}
.header_drawer_menu_list > ul > li span {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 0.8rem;
  letter-spacing: 0.1em;
  color: var(--seven-col);
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_list > ul > li span {
    display: none;
  }
}
@media screen and (min-width: 1025px) {
  .header_drawer_menu_list > ul + h4 {
    margin-top: 5.4rem;
  }
}
@media screen and (min-width: 1025px) {
  .header_drawer_menu_list + h3 {
    margin-top: 3.7rem;
  }
}
.header_drawer_menu_product h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  margin-bottom: 2.4rem;
  color: var(--seven-col);
  position: relative;
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_product h3 {
    font-size: 1.7rem;
    padding: 2rem 3rem;
    border-top: solid 1px #D9D9D9;
    margin-bottom: 0;
  }
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_product h3.is_active + .header_drawer_menu_product_list {
    display: block;
  }
}
@media screen and (min-width: 1025px) {
  .header_drawer_menu_product_list {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    grid-gap: 6rem;
  }
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_product_list {
    display: none;
  }
}
.header_drawer_menu_product_list ul + ul {
  position: relative;
}
@media screen and (min-width: 1025px) {
  .header_drawer_menu_product_list ul + ul {
    padding-top: 1.7rem;
    margin-top: 2rem;
  }
}
.header_drawer_menu_product_list ul + ul:before {
  content: "";
  width: 19.6rem;
  height: 1px;
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  background-color: var(--force-col);
}
.header_drawer_menu_about h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  margin-bottom: 2.6rem;
  color: var(--seven-col);
  position: relative;
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_about h3 {
    padding: 2rem 3rem;
    margin-bottom: 0;
    border-top: solid 1px #D9D9D9;
  }
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_about h3.is_active + .header_drawer_menu_list ul {
    display: block;
  }
}
.header_drawer_menu_about ul li {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 2;
}
.header_drawer_menu_guide {
  margin-top: 3.3rem;
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_guide {
    margin-top: 0;
    display: none;
  }
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_guide .header_nav_service_guide {
    border: none;
    background-color: rgba(217, 217, 217, 0.8);
    display: block;
    display: flex;
    align-items: center;
    padding: 2rem 3rem;
  }
  .header_drawer_menu_guide .header_nav_service_guide h4 {
    line-height: 1;
    color: #808080;
    width: 50%;
    text-align: left;
  }
  .header_drawer_menu_guide .header_nav_service_guide p {
    line-height: 1;
    color: #808080;
    width: 50%;
    text-align: left;
  }
}
.header_drawer_menu_ec {
  position: relative;
}
@media screen and (min-width: 1025px) {
  .header_drawer_menu_ec {
    margin-bottom: 4.6rem;
  }
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_ec {
    padding: 2rem 3rem;
    border-top: solid 1px #808080;
  }
}
.header_drawer_menu_ec a {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  text-decoration: none;
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_ec a {
    color: #808080;
  }
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_ec.is_active + .header_drawer_menu_other_list {
    display: block;
  }
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_other {
    border-bottom: solid 1px #D9D9D9;
    margin-bottom: 6rem;
  }
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_other_list {
    display: none;
  }
}
.header_drawer_menu_other_list h4 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  color: var(--seven-col);
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_other_list h4 {
    padding: 2rem 3rem;
    color: #808080;
    border-top: solid 1px #D9D9D9;
  }
}
@media screen and (min-width: 1025px) {
  .header_drawer_menu_other_list h4 + ul {
    margin-top: 1.7rem;
  }
}
.header_drawer_menu_other_list ul li {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.5rem;
  letter-spacing: 0.1em;
  line-height: 30px;
  color: var(--seven-col);
}
@media screen and (min-width: 1025px) {
  .header_drawer_menu_other_list ul li {
    padding-left: 2.4rem;
  }
}
.header_drawer_menu_other_list ul li a {
  text-decoration: none;
  position: relative;
  transition: all 0.2s ease;
  color: var(--seven-col);
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_other_list ul li a {
    padding: 2rem 3rem;
    display: block;
    border-top: solid 1px #D9D9D9;
    background-color: #E9E9E9;
    padding-left: 14rem;
  }
}
.header_drawer_menu_other_list ul li a.target:after {
  width: 8px;
  height: 8px;
  opacity: 0.4;
}
.header_drawer_menu_other_list ul li a:before {
  content: "";
  position: absolute;
  left: -2.4rem;
  top: 50%;
  margin-top: -2.5px;
  width: 5px;
  height: 5px;
  border-radius: 2.5px;
  background-color: var(--txt-col);
  display: block;
  transition: all 0.3s ease;
  opacity: 0;
}
.header_drawer_menu_other_list ul li a:hover:before {
  opacity: 1;
}
@media screen and (min-width: 1025px) {
  .header_drawer_menu_other_list ul + h4 {
    margin-top: 4.6rem;
  }
}
.header_drawer_menu_sns {
  display: flex;
  align-items: center;
  justify-content: center;
  grid-gap: 2.4rem;
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_sns {
    justify-content: flex-start;
    padding-left: 3rem;
    border-bottom: solid 1px #D9D9D9;
    padding-bottom: 2.7rem;
  }
}
.header_drawer_menu_sns img {
  max-width: 2rem;
  width: 100%;
  height: auto;
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_sns img {
    max-width: 2.6rem;
  }
}
.header_drawer_menu_lang {
  display: none;
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu_lang {
    display: block;
    padding: 2.7rem 3rem;
  }
}
.header_drawer_menu_lang a {
  font-size: 1.3rem;
  font-weight: 400;
  letter-spacing: 0.1em;
  color: #969696;
  text-decoration: none;
}
.header_drawer_menu .accordion_btn {
  display: none;
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu .accordion_btn {
    display: block;
    position: absolute;
    right: 3rem;
    top: 50%;
    transform: translateY(-50%);
  }
  .header_drawer_menu .accordion_btn .icon {
    width: 1.4rem;
    height: 1.4rem;
    color: #808080;
  }
  .header_drawer_menu .accordion_btn .icon-minus {
    display: none;
  }
}
@media screen and (max-width: 1024px) {
  .header_drawer_menu .is_active .accordion_btn .icon-plus {
    display: none;
  }
  .header_drawer_menu .is_active .accordion_btn .icon-minus {
    display: block;
  }
}
.header.is_d_open .header_drawer {
  opacity: 1;
  transform: translateY(0);
  z-index: 500;
}

#top .header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 200;
  opacity: 1;
  transition: all 0.4s ease;
  --header-btn-txt-col: var(--gray-col);
  --header-btn-bg-col: var(--base-col);
  --header-txt-col: var(--base-col);
  background: none;
}
#top .header.is_hide .header_inner,
#top .header.is_hide .header_lang,
#top .header.is_hide .header_nav_service,
#top .header.is_hide .header_nav_about,
#top .header.is_hide .header_nav_support {
  opacity: 0;
}
#top .header.is_fixed {
  --header-txt-col: var(--secondary-col);
  --header-base-col: var(--base-col);
  --header-btn-txt-col: var(--base-col);
  --header-btn-bg-col: var(--secondary-col);
  position: fixed;
  background-color: rgba(250, 250, 250, 0.9);
}
#top .header.is_fixed .header_inner {
  backdrop-filter: blur(8px);
}
#top .header.is_open {
  position: fixed;
  /*
  background-color: var(--third-col);
  */
  background-color: rgba(250, 250, 250, 0.9);
  --header-txt-col: var(--secondary-col);
  --header-base-col: var(--base-col);
  --header-btn-txt-col: var(--base-col);
  --header-btn-bg-col: var(--secondary-col);
}
#top .header.is_open2 {
  position: fixed;
  /*
  background-color: var(--third-col);
  */
  background-color: rgba(250, 250, 250, 0.9);
  --header-txt-col: var(--secondary-col);
  --header-base-col: var(--base-col);
  --header-btn-txt-col: var(--base-col);
  --header-btn-bg-col: var(--secondary-col);
}
#top .header.is_open3 {
  position: fixed;
  /*
  background-color: var(--third-col);
  */
  background-color: rgba(250, 250, 250, 0.9);
  --header-txt-col: var(--secondary-col);
  --header-base-col: var(--base-col);
  --header-btn-txt-col: var(--base-col);
  --header-btn-bg-col: var(--secondary-col);
}
#top .header .header_lang ul li {
  color: var(--header-txt-col);
}
#top .header .header_lang ul li a {
  color: var(--header-txt-col);
}

#cosmos .header_lang ul li {
  color: var(--base-col);
}
#cosmos .header_lang ul li a {
  color: var(--base-col);
}

#thinning .header_lang ul li {
  color: var(--base-col);
}
#thinning .header_lang ul li a {
  color: var(--base-col);
}

#lefty .header_lang ul li {
  color: var(--base-col);
}
#lefty .header_lang ul li a {
  color: var(--base-col);
}

.header_b {
  position: absolute;
  top: var(--header-height);
  left: 0;
  right: 0;
  z-index: 200;
  opacity: 1;
  transition: all 0.8s ease;
  --header-btn-txt-col: var(--gray-col);
  --header-btn-bg-col: var(--base-col);
  background-color: var(--secondary-col);
}
@media screen and (min-width: 1025px) {
  .header_b_inner {
    --header-height: 7.0rem;
    width: 100%;
    height: var(--header-height);
    display: grid;
    grid-gap: 0;
    grid-template-columns: 1fr;
    justify-content: flex-start;
    align-items: center;
    position: relative;
    z-index: 4;
    grid-gap: 2rem;
    grid-template-areas: "heading nav1 nav2";
    grid-template-columns: 1fr 3fr 1fr;
    justify-content: flex-start;
    padding: 0;
  }
}
.header_b_inner .header-title {
  grid-area: heading;
}
.header_b_inner .gnav {
  grid-area: nav1;
}
.header_b_inner .header_category {
  grid-area: nav2;
}
.header_b-title {
  text-align: center;
}
@media screen and (min-width: 1025px) {
  .header_b-title {
    display: block;
    padding-left: 5.6vw;
  }
}
@media screen and (max-width: 1024px) {
  .header_b-title {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 5.3rem;
    padding: 0 2rem;
  }
}
.header_b-title h2 {
  color: var(--base-col);
  position: relative;
  text-align: center;
  display: flex;
  align-items: center;
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 2rem;
  letter-spacing: 0.1em;
  line-height: 15px;
}
.header_b .gnav {
  display: flex;
  justify-content: center;
  align-items: center;
  grid-gap: 2rem;
  top: 0;
  transition: all 0.5s ease;
}
@media screen and (max-width: 1024px) {
  .header_b .gnav {
    height: 5.3rem;
    padding: 0 1rem;
  }
}
.header_b .gnav-menu {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  grid-gap: 4rem;
}
@media screen and (max-width: 1024px) {
  .header_b .gnav-menu {
    grid-gap: 1.5rem;
  }
}
.header_b .gnav-menu > li {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  color: var(--header-txt-col);
}
@media screen and (max-width: 1024px) {
  .header_b .gnav-menu > li {
    font-size: 1.2rem;
  }
}
.header_b .gnav-menu > li > a {
  text-decoration: none;
  position: relative;
  display: block;
  text-align: center;
  transition: all 0.2s ease;
  color: var(--header-txt-col);
  z-index: 3;
  line-height: var(--header-height);
}
@media screen and (max-width: 1024px) {
  .header_b .gnav-menu > li > a {
    line-height: 1.2;
  }
}
.header_b .gnav-menu > li > a:before {
  content: "";
  position: absolute;
  left: -15px;
  top: 50%;
  margin-top: -2.5px;
  width: 5px;
  height: 5px;
  border-radius: 2.5px;
  background-color: var(--header-txt-col);
  display: block;
  transition: all 0.3s ease;
  opacity: 0;
}
@media screen and (min-width: 1025px) {
  .header_b .gnav-menu > li > a:hover:before {
    opacity: 1;
  }
}
@media screen and (min-width: 1025px) {
  .header_b .gnav-menu > li > a.is_active:before {
    opacity: 1;
  }
}
@media screen and (max-width: 1024px) {
  .header_b .gnav-menu > li > a.is_active {
    opacity: 0.5;
  }
}
.header_b .gnav-menu > li > p {
  color: var(--txt-col);
  text-decoration: none;
  position: relative;
  display: block;
  text-align: center;
  font-size: 1.4rem;
  font-weight: 600;
  letter-spacing: 0px;
}

@media screen and (max-width: 1024px) {
  .is_nav_hide.is_scrl_up .header_b .gnav {
    position: fixed;
    top: 7rem;
    left: 0;
    right: 0;
    z-index: 4;
    background-color: var(--secondary-col);
  }
}

.header_c {
  position: absolute;
  top: var(--header-height);
  left: 0;
  right: 0;
  z-index: 200;
  opacity: 1;
  transition: all 0.8s ease;
  --header-btn-txt-col: var(--gray-col);
  --header-btn-bg-col: var(--base-col);
}
.header_c_inner {
  width: 100%;
  height: var(--header-height);
  align-items: center;
  display: grid;
  grid-gap: 2rem;
  grid-template-areas: "nav2";
  grid-template-columns: 40% auto;
  justify-content: flex-start;
  align-items: center;
  padding: 0 2rem;
  position: relative;
  z-index: 4;
}
@media screen and (min-width: 1025px) {
  .header_c_inner {
    --header-height: 7.0rem;
    grid-template-areas: "nav2";
    grid-template-columns: 1fr;
    justify-content: flex-end;
    padding: 0 6rem;
  }
}
.header_c_inner .header_category {
  grid-area: nav2;
}

.header_category {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.1rem;
  letter-spacing: 0.1em;
  color: var(--secondary-col);
  text-align: right;
  padding-right: 9.8rem;
  /*
  display: none;
  */
}

#cosmos .header_category {
  color: rgba(255, 255, 255, 0.5);
  display: block;
}

#thinning .header_category {
  color: rgba(255, 255, 255, 0.5);
  display: block;
}

#hikari .header_category {
  color: rgba(58, 58, 58, 0.5);
  display: block;
}

#lefty .header_category {
  color: rgba(255, 255, 255, 0.5);
  display: block;
}

.is_nav_open:not(.is_scrl):before,
.is_nav_open:not(.is_nav_hide):before {
  content: "";
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  z-index: 13;
  backdrop-filter: blur(48px);
}

.is_scrl header.is_open .header_nav_service {
  display: none;
}
.is_scrl header.is_open2 .header_nav_about {
  display: none;
}
.is_scrl header.is_open3 .header_nav_support {
  display: none;
}

/* ----------------------------------------------------------------
footer
-------------------------------------------------------------------*/
.footer {
  --bg-col: var(--third-col);
  width: 100%;
  background-color: var(--bg-col);
  color: var(--txt-col);
  transition: all 0.1s linear;
  position: relative;
  padding-top: 7rem;
  z-index: 3;
}
@media screen and (min-width: 1025px) {
  .footer {
    padding-top: 7.6rem;
  }
}
@media screen and (min-width: 1025px) {
  .footer_top {
    padding: 0 9.72% 8rem;
    display: grid;
    grid-template-columns: 20% auto;
  }
}
@media screen and (max-width: 1024px) {
  .footer_top {
    padding: 0 2rem;
    display: flex;
    flex-direction: column-reverse;
  }
}
@media screen and (min-width: 1025px) {
  .footer_top_left {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    border-right: solid 1px var(--seven-col);
  }
}
@media screen and (max-width: 1024px) {
  .footer_top_left {
    display: flex;
    justify-content: space-between;
  }
}
@media screen and (min-width: 1025px) {
  .footer_top_nav {
    padding-left: 3.6rem;
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    grid-gap: 4rem;
  }
}
@media screen and (max-width: 1024px) {
  .footer_top_nav {
    display: grid;
    grid-template-columns: 1fr 1fr;
    padding-bottom: 2.3rem;
    border-bottom: solid 1px #D9D9D9;
    margin-bottom: 2.7rem;
  }
}
@media screen and (max-width: 1024px) {
  .footer_top_nav_title {
    grid-column: 1/3;
    grid-row: 1;
    margin-bottom: 3rem;
  }
}
.footer_top_nav_title h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  color: var(--seven-col);
}
.footer_top_nav_list {
  min-width: 14rem;
}
@media screen and (max-width: 1024px) {
  .footer_top_nav_list.footer_top_nav_list_s1 {
    grid-column: 1/2;
    grid-row: 2;
  }
  .footer_top_nav_list.footer_top_nav_list_s2 {
    grid-column: 2/3;
    grid-row: 2;
  }
  .footer_top_nav_list.footer_top_nav_list_s3 {
    grid-column: 1/2;
    grid-row: 3;
    margin-top: 2.7rem;
    border-top: solid 1px #D9D9D9;
    padding-top: 2.7rem;
  }
  .footer_top_nav_list.footer_top_nav_list_s4 {
    grid-column: 2/3;
    grid-row: 3;
    margin-top: 2.7rem;
    border-top: solid 1px #D9D9D9;
    padding-top: 2.7rem;
  }
}
.footer_top_nav_list h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  color: var(--seven-col);
  margin-bottom: 2rem;
}
.footer_top_nav_list > ul > li {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  color: var(--seven-col);
  margin-bottom: 0.6rem;
}
.footer_top_nav_list > ul > li:last-child {
  margin-bottom: 0;
}
.footer_top_nav_list > ul > li a {
  text-decoration: none;
}
.footer_top_nav_list > ul + ul {
  margin-top: 2rem;
}
.footer_top_nav_list > ul + h4 {
  margin-top: 3.08rem;
}
.footer_top_nav_list > ul + ul.footer_top_nav_list_2 {
  margin-top: 8rem;
}
@media screen and (max-width: 1024px) {
  .footer_top_nav_list > ul + ul.footer_top_nav_list_2 {
    margin-top: 5rem;
  }
}
.footer_top_nav_list > ul + ul.footer_top_nav_list_2 > li {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  color: var(--seven-col);
  margin-bottom: 1.4rem;
}
.footer_top_nav_list_sec {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  grid-gap: 2.4rem;
  margin-bottom: 2.9rem;
}
.footer_top_nav_list_sec h5 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  line-height: 14px;
  color: var(--seven-col);
}
.footer_top_nav_list_sec > ul > li {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  color: var(--seven-col);
  margin-bottom: 0.6rem;
}
.footer_top_nav_list_sec > ul > li:last-child {
  margin-bottom: 0;
}
.footer_top_nav_list_sec > ul > li a {
  text-decoration: none;
}
.footer_top_nav_list a.target:after {
  width: 9px;
  height: 9px;
  margin-left: 4px;
}
.footer_top_nav_list .font_ja {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1024px) {
  .footer_link_ec {
    width: 50%;
  }
}
.footer_link_ec a {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  text-decoration: none;
}
.footer_link_sns {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  grid-gap: 2.4rem;
}
@media screen and (max-width: 1024px) {
  .footer_link_sns {
    width: 50%;
    justify-content: flex-end;
  }
}
@media screen and (min-width: 1025px) {
  .footer_bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 5rem 1.8rem;
    flex-direction: row-reverse;
  }
}
@media screen and (max-width: 1024px) {
  .footer_bottom {
    padding: 0 2rem 2.2rem;
    margin-top: 2.5rem;
  }
}
.footer_bottom .copyright {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.1em;
  line-height: 28px;
  color: var(--seven-col);
}
@media screen and (min-width: 1025px) {
  .footer_bottom ul {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    grid-gap: 6rem;
  }
}
@media screen and (max-width: 1024px) {
  .footer_bottom ul {
    display: grid;
    grid-template-columns: 1fr 1fr;
    margin-bottom: 2.4rem;
  }
}
.footer_bottom ul li {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 28px;
  color: var(--seven-col);
}
.footer_bottom ul li:nth-child(1) {
  grid-column: 1/3;
  grid-row: 1;
}
.footer_bottom ul li:nth-child(2) {
  grid-column: 1/2;
  grid-row: 2;
}
.footer_bottom ul li:nth-child(3) {
  grid-column: 2/3;
  grid-row: 2;
  text-align: right;
}
.footer_bottom ul li a {
  color: var(--seven-col);
  text-decoration: none;
}
.footer_bottom ul li .icon-target {
  width: 8px;
  height: 8px;
  margin-left: 1rem;
}

body:not(.is_top) .wrapper {
  background-color: var(--third-col);
  position: relative;
}

body:not(.is_top) .wrapper {
  padding-top: calc(var(--header-height) * 2);
}
@media screen and (max-width: 1024px) {
  body:not(.is_top) .wrapper {
    padding-top: calc(var(--header-height) + 10.6rem);
  }
}

body:not(.is_top) .nohead .wrapper {
  padding-top: calc(var(--header-height) * 1);
}

.page {
  position: relative;
}

.bread {
  width: 100%;
  position: absolute;
  top: 0;
  top: calc(var(--header-height) * 2);
  left: 0;
  right: 0;
  z-index: 21;
}
@media screen and (max-width: 1024px) {
  .bread {
    top: calc(var(--header-height) + 10.6rem);
  }
}
.bread_inner {
  padding: 2.6rem 9.72vw 0;
}
@media screen and (max-width: 1024px) {
  .bread_inner {
    padding: 2rem 2rem 0;
  }
}
.bread_inner ul {
  display: flex;
}
@media screen and (max-width: 1024px) {
  .bread_inner ul {
    flex-wrap: wrap;
  }
}
.bread_inner ul li {
  color: var(--fifteen-col);
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1024px) {
  .bread_inner ul li {
    font-size: 1rem;
  }
}
.bread_inner ul li:not(:last-child):after {
  content: " ＞ ";
}
.bread_inner ul li a {
  color: var(--fifteen-col);
  text-decoration: none;
}

.nohead .bread {
  top: calc(var(--header-height) * 1);
}

#top {
  /*
  background-image: url(../img/main.webp);
  */
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  background-attachment: fixed;
}

.top_bg {
  position: fixed;
  left: 0;
  top: 0;
  right: 0;
  z-index: 0;
  width: 100%;
  height: 100vh;
  display: block;
  --figure-height: 100vh;
  padding-top: var(--figure-height);
  overflow: hidden;
}
.top_bg video {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  object-fit: cover;
  transition: all 0.3s linear;
}

.top_main {
  position: relative;
  z-index: 3;
  height: 350vh;
}

.top_kv {
  position: relative;
  z-index: 2;
}
.top_kv_inner {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1;
}
@media screen and (max-width: 1024px) {
  .top_kv_inner {
    flex-direction: column;
  }
}
@media screen and (max-width: 1024px) {
  .top_kv_inner h1 {
    margin-bottom: 4rem;
  }
  .top_kv_inner h1 img {
    max-width: 7.8rem;
  }
}
.top_kv_inner h2 {
  font-family: var(--font-arial);
  font-weight: 600;
  font-size: 1.6rem;
  letter-spacing: 0.23em;
  color: var(--base-col);
}
@media screen and (min-width: 1025px) {
  .top_kv_inner h2 {
    display: none;
  }
}
.top_kv_scl {
  position: absolute;
  bottom: 2rem;
  left: 0;
  right: 0;
  z-index: 1;
  text-align: center;
}
.top_kv_scl a {
  font-family: var(--font-arial);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  color: var(--base-col);
  text-decoration: none;
}
@media screen and (max-width: 1024px) {
  .top_kv_scl a {
    font-family: var(--font-arial);
    font-weight: 400;
    font-size: 1.1rem;
    letter-spacing: 0.1em;
  }
}

.top_concept {
  position: relative;
  z-index: 1;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  opacity: 0;
}
.top_concept_overlay {
  background-color: rgba(0, 0, 0, 0.4);
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 2;
  height: 200vh;
}
.top_concept_inner {
  position: relative;
  z-index: 3;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.top_concept_inner p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  text-align: center;
  color: var(--base-col);
}
@media screen and (max-width: 1024px) {
  .top_concept_inner p {
    font-family: var(--font-primary);
    font-weight: 500;
    font-size: 1.6rem;
    letter-spacing: 0.2em;
    line-height: 36px;
  }
}

.top_quality {
  position: relative;
  z-index: 3;
}
.top_quality_inner {
  position: relative;
  z-index: 4;
  width: 100%;
  height: auto !important;
  margin: 0 auto;
  padding: 21.8rem 2rem 0;
  padding-left: 15.28%;
}
@media screen and (max-width: 1024px) {
  .top_quality_inner {
    padding: 21.8rem 3.2rem 0;
  }
}
.top_quality_inner_text {
  position: relative;
  z-index: 3;
}
.top_quality_inner_text h2 {
  font-weight: 500;
  font-size: 2.1rem;
  letter-spacing: 0.2em;
  line-height: 33px;
  margin-bottom: 18rem;
}
@media screen and (max-width: 1024px) {
  .top_quality_inner_text h2 {
    font-weight: 500;
    font-size: 1.8rem;
    letter-spacing: 0.2em;
    line-height: 33px;
    margin-bottom: 6.3rem;
  }
}
.top_quality_inner_text p {
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 28px;
  margin-bottom: 7.8rem;
}
@media screen and (max-width: 1024px) {
  .top_quality_inner_text p {
    font-weight: 500;
    font-size: 1.2rem;
    letter-spacing: 0.2em;
    line-height: 28px;
    margin-bottom: 6.6rem;
  }
}
.top_quality_btn {
  margin-bottom: 1rem;
}
.top_quality_overlay {
  background-color: var(--third-col);
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  z-index: 2;
  width: 100%;
  display: block;
  bottom: 0;
}
.top_quality_bg_img1 {
  position: relative;
  z-index: 3;
}
.top_quality_bg_img1 figure img {
  width: 100%;
  height: auto;
}
.top_quality .layer {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 3;
}
.top_quality .layer.fixed {
  position: fixed;
}
.top_quality_txt {
  height: 100vh;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding-bottom: 4rem;
  z-index: 2;
}
.top_quality_txt p {
  font-family: "Source Sans 3", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 1.6rem;
  letter-spacing: 0.16em;
  line-height: 25px;
  text-align: center;
  color: var(--base-col);
}
@media screen and (max-width: 1024px) {
  .top_quality_txt p {
    font-size: 1.2rem;
    line-height: 17px;
  }
}
.top_quality_bg {
  background-color: var(--secondary-col);
}
.top_quality_bg_img {
  width: 100%;
  transition: opacity 0.7s linear;
}
.top_quality_bg_img2 {
  position: relative;
  padding-top: 100vh;
  overflow: hidden;
}
@media screen and (max-width: 1024px) {
  .top_quality_bg_img2 {
    padding-top: 110vw;
  }
}
.top_quality_bg_img2 img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  z-index: 2;
}
.top_quality_bg_img4 {
  position: relative;
  padding-top: 100vh;
  overflow: hidden;
}
@media screen and (max-width: 1024px) {
  .top_quality_bg_img4 {
    padding-top: 110vw;
  }
}
.top_quality_bg_img4 img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  z-index: 2;
}

[data-trigger=parallaxBg] {
  opacity: 1;
  transition: opacity 0.45s ease;
}

[data-trigger=parallaxBg].is-active {
  opacity: 1;
}

[data-trigger=parallaxBg] {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100lvh;
  object-fit: cover;
  transform: translateY(0);
  will-change: transform;
  scale: 1;
}

@media screen and (min-width: 835px) {
  [data-trigger=parallaxBg] {
    scale: 1.1;
  }
}
@media screen and (max-width: 834px) {
  [data-trigger=parallaxBg]:not(.img2) {
    width: 100%;
    height: 110vw;
    scale: 1.05;
  }
}
/* 低モーション環境では無効化 */
@media (prefers-reduced-motion: reduce) {
  [data-trigger=parallaxBg] {
    transition: none !important;
    transform: none !important;
  }
}
.top_topics {
  background-color: var(--third-col);
  position: relative;
  z-index: 3;
}
.top_topics_inner {
  padding: 15rem 0 8rem;
}
@media screen and (max-width: 1024px) {
  .top_topics_inner {
    padding: 11rem 3.2rem 7rem;
  }
}
.top_topics_ttl {
  text-align: center;
  margin-bottom: 4rem;
}
.top_topics_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 2.2rem;
  letter-spacing: 0.1em;
  margin-bottom: 1rem;
}
.top_topics_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
}
.top_topics_list {
  max-width: 137.4rem;
  margin: 0 auto;
  overflow: visible;
}
.top_topics_list_wrap {
  width: 100%;
  overflow: hidden;
}
.top_topics_list_inner {
  margin: 0 auto;
  margin-bottom: 4rem;
}
.top_topics_list_item figure {
  display: block;
  position: relative;
  padding-top: var(--figure-height);
  overflow: hidden;
  z-index: 1;
  padding-top: 50%;
}
.top_topics_list_item figure img {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  object-fit: cover;
  transition: all 0.3s linear;
}
@media screen and (max-width: 1024px) {
  .top_topics_list_item figure {
    padding-top: 100%;
  }
}
.top_topics_list_item a:hover figure img {
  opacity: 0.7;
}
.top_topics_list_pagination {
  text-align: center;
}
.top_topics_list_pagination .swiper-pagination-bullet {
  width: 5px;
  height: 5px;
  border-radius: 2.5px;
  opacity: 1 !important;
  background-color: var(--force-col);
}
.top_topics_list_pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background-color: var(--fifth-col);
}

.top_product {
  position: relative;
  z-index: 3;
  background-color: var(--six-col);
}
.top_product_inner {
  padding: 17rem 0 8rem;
}
.top_product_ttl {
  text-align: center;
  margin-bottom: 8rem;
}
.top_product_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 2.2rem;
  letter-spacing: 0.1em;
  margin-bottom: 1rem;
}
.top_product_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
}
.top_product_filter {
  width: 100%;
  padding-left: 13.89%;
  margin-bottom: 5rem;
}
.top_product_filter_inner {
  width: 100%;
  border-bottom: solid 1px var(--force-col);
  display: flex;
  align-items: center;
  justify-content: flex-start;
  grid-gap: 4rem;
}
.top_product_filter_label {
  font-family: var(--font-arial);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  background-color: var(--secondary-col);
  color: var(--base-col);
  padding: 0.6rem 1.5rem;
}
.top_product_filter_link {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  text-decoration: none;
  color: var(--seven-col);
  padding: 0.6rem 0;
}
.top_product_list {
  margin: 0 auto;
  padding-left: 13.89%;
  overflow: hidden;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .top_product_list {
    padding: 0 13.89%;
  }
}
.top_product_list:before {
  content: "";
  background-color: var(--six-col);
  width: 13.89%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 3;
  display: block;
}
.top_product_list_inner {
  margin: 0 auto;
  margin-bottom: 4rem;
}
.top_product_list_item {
  width: 32rem;
  margin-right: 3rem;
}
.top_product_list_item_img {
  margin: 0;
}
.top_product_list_item_img figure {
  display: block;
  position: relative;
  padding-top: var(--figure-height);
  overflow: hidden;
  z-index: 1;
  padding-top: 118.75%;
}
.top_product_list_item_img figure img {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  object-fit: cover;
  transition: all 0.3s linear;
}
@media screen and (max-width: 1024px) {
  .top_product_list_item_img figure {
    padding-top: 80.77%;
    background-color: #FFF;
  }
  .top_product_list_item_img figure img {
    object-fit: contain;
  }
}
.top_product_list_item_img a:hover figure img {
  opacity: 0.7;
}
.top_product_list_item_img img {
  vertical-align: bottom;
}
.top_product_list_item_label {
  text-align: right;
  margin-bottom: 3rem;
}
.top_product_list_item_label p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 17px;
  background-color: var(--base-col);
  display: inline-block;
  padding: 0.3rem 0.8rem;
}
.top_product_list_item_content h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.7rem;
  letter-spacing: 0.1em;
  line-height: 20px;
  margin-bottom: 0.6rem;
}
.top_product_list_item_content_detail {
  height: auto;
  min-height: 4.4rem;
  margin-bottom: 0.6rem;
}
.top_product_list_item_content_detail p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  line-height: 22px;
}
.top_product_list_item_content_detail p span {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.1em;
  line-height: 22px;
}
.top_product_list_item_content_price {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 28px;
}
.top_product_list .top_product_list_prev {
  top: 20rem;
  left: 13.89%;
  margin-left: -10rem;
}
.top_product_list .top_product_list_next {
  top: 20rem;
  right: 13.89%;
  margin-right: -10rem;
}

.top_space {
  position: relative;
  z-index: 3;
  background-color: var(--base-col);
  padding-top: 54rem;
}
@media screen and (max-width: 1024px) {
  .top_space {
    padding-top: 108vw;
  }
}
.top_space_inner {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
}
.top_space_img {
  width: 100%;
  height: 100svh;
  object-fit: cover;
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 1;
  display: block;
}

.top_introduction {
  position: relative;
  z-index: 3;
  background-color: var(--third-col);
}
.top_introduction_inner {
  padding: 11rem 0 8rem;
}
@media screen and (max-width: 1024px) {
  .top_introduction_inner {
    padding: 0 0 3rem;
  }
}
.top_introduction_ttl {
  text-align: center;
  margin-bottom: 11rem;
}
@media screen and (max-width: 1024px) {
  .top_introduction_ttl {
    display: none;
  }
}
.top_introduction_ttl h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
}
.top_introduction_list {
  margin: 0 auto;
  overflow: visible;
}
.top_introduction_list_item {
  width: 100%;
  background-image: url(../img/kv_bg.webp);
  background-size: cover;
  background-repeat: no-repeat;
  margin-bottom: 1rem;
  position: relative;
}
@media screen and (min-width: 1025px) {
  .top_introduction_list_item {
    display: grid;
    grid-template-columns: 28% auto;
    grid-gap: 4.86%;
    align-items: center;
    padding: 4rem 0 4rem;
    padding-left: 9.72vw;
    height: 54rem;
  }
}
@media screen and (max-width: 1024px) {
  .top_introduction_list_item {
    display: flex;
    flex-direction: column-reverse;
    justify-content: flex-end;
    padding: 5rem 0;
  }
}
@media screen and (max-width: 1024px) {
  .top_introduction_list_item_content {
    padding: 0 3.4rem;
    margin-top: -2rem;
  }
}
.top_introduction_list_item_content a {
  text-decoration: none;
}
.top_introduction_list_item_content a:after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 2;
}
.top_introduction_list_item_content_ttl {
  border-bottom: solid 1px var(--secondary-col);
  padding-bottom: 2rem;
  margin-bottom: 2rem;
}
@media screen and (max-width: 1024px) {
  .top_introduction_list_item_content_ttl {
    padding-bottom: 0.9rem;
    margin-bottom: 1rem;
  }
}
.top_introduction_list_item_content_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
  color: var(--secondary-col);
  margin-bottom: 1rem;
}
@media screen and (max-width: 1024px) {
  .top_introduction_list_item_content_ttl p {
    font-family: var(--font-primary);
    font-weight: 500;
    font-size: 1.1rem;
    letter-spacing: 0.12em;
    line-height: 18px;
  }
}
.top_introduction_list_item_content_ttl h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 2.4rem;
  letter-spacing: 0.15em;
  line-height: 32px;
  color: var(--secondary-col);
}
@media screen and (max-width: 1024px) {
  .top_introduction_list_item_content_ttl h4 {
    font-size: 1.8rem;
  }
}
.top_introduction_list_item_content_txt p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  line-height: 32px;
  color: var(--secondary-col);
}
@media screen and (max-width: 1024px) {
  .top_introduction_list_item_content_txt p {
    font-weight: 500;
    font-size: 1.2rem;
    letter-spacing: 0.1em;
    line-height: 22px;
  }
}
.top_introduction_list_item_imt img {
  width: 100%;
  max-width: 84rem;
}
.top_introduction_list #top_introduction_02 {
  background-image: url(../img/kv_bg.webp);
}
.top_introduction_sub_list {
  padding-top: 10rem;
  margin: 0 auto 3rem;
  overflow: visible;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 8rem;
  width: 100%;
  max-width: 118rem;
}
@media screen and (max-width: 1024px) {
  .top_introduction_sub_list {
    grid-template-columns: 1fr;
    padding: 3.2rem 3.2rem 3rem;
    grid-gap: 2.7rem;
    margin-bottom: 0;
  }
}
.top_introduction_sub_list_item {
  width: 100%;
}
.top_introduction_sub_list_item_imt {
  margin-bottom: 3rem;
}
@media screen and (max-width: 1024px) {
  .top_introduction_sub_list_item_imt {
    margin-bottom: 0.5rem;
  }
}
.top_introduction_sub_list_item_imt figure {
  display: block;
  position: relative;
  padding-top: var(--figure-height);
  overflow: hidden;
  z-index: 1;
  padding-top: 51.85%;
}
.top_introduction_sub_list_item_imt figure img {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  object-fit: cover;
  transition: all 0.3s linear;
}
.top_introduction_sub_list_item_imt a:hover figure img {
  opacity: 0.7;
}
.top_introduction_sub_list_item_content_ttl {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (min-width: 1025px) {
  .top_introduction_sub_list_item_content_ttl {
    grid-gap: 4rem;
    justify-content: flex-start;
  }
}
.top_introduction_sub_list_item_content_ttl h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.7rem;
  letter-spacing: 0.1em;
  line-height: 32px;
  color: var(--txt-col);
}
@media screen and (max-width: 1024px) {
  .top_introduction_sub_list_item_content_ttl h4 {
    font-size: 1.4rem;
  }
}
.top_introduction_sub_list_item_content_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  color: var(--txt-col);
}
@media screen and (max-width: 1024px) {
  .top_introduction_sub_list_item_content_ttl p {
    font-size: 1.1rem;
  }
}

.top_movie {
  position: relative;
  z-index: 3;
  background-color: var(--six-col);
}
.top_movie_inner {
  padding: 11rem 0 9rem;
}
@media screen and (max-width: 1024px) {
  .top_movie_inner {
    padding: 9rem 3.2rem 9rem;
  }
}
.top_movie_ttl {
  text-align: center;
  margin-bottom: 8rem;
}
@media screen and (max-width: 1024px) {
  .top_movie_ttl {
    margin-bottom: 5.7rem;
  }
}
.top_movie_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 2.2rem;
  letter-spacing: 0.1em;
  margin-bottom: 8px;
}
.top_movie_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
}
.top_movie_list {
  margin: 0 auto;
  overflow: visible;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 8rem;
  width: 100%;
  max-width: 118rem;
}
@media screen and (max-width: 1024px) {
  .top_movie_list {
    grid-template-columns: 1fr;
    grid-gap: 3.8rem;
  }
}
.top_movie_list_item {
  width: 100%;
}
.top_movie_list_item_imt {
  position: relative;
  margin-bottom: 1.3rem;
}
.top_movie_list_item_imt figure {
  display: block;
  position: relative;
  padding-top: var(--figure-height);
  overflow: hidden;
  z-index: 1;
  padding-top: 51.85%;
}
.top_movie_list_item_imt figure img {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  object-fit: cover;
  transition: all 0.3s linear;
}
.top_movie_list_item_imt a {
  position: relative;
  display: block;
}
.top_movie_list_item_imt a:hover figure img {
  opacity: 0.7;
}
.top_movie_list_item_imt a:before {
  content: "";
  width: 55px;
  height: 55px;
  border: solid 1px var(--base-col);
  border-radius: 50%;
  display: block;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translateX(-50%) translateY(-50%);
  z-index: 2;
}
.top_movie_list_item_imt a:after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.68px 0 4.68px 8.1px;
  border-color: transparent transparent transparent var(--base-col);
  display: block;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translateX(-50%) translateY(-50%);
  z-index: 2;
}
.top_movie_list_item_content_ttl {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  grid-gap: 4rem;
}
.top_movie_list_item_content_ttl h4 {
  font-family: var(--font-arial);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.2em;
  line-height: 26px;
  color: var(--txt-col);
}
@media screen and (max-width: 1024px) {
  .top_movie_list_item_content_ttl h4 {
    font-size: 1.2rem;
  }
}

.top_support {
  position: relative;
  z-index: 3;
  background-color: var(--third-col);
}
.top_support_inner {
  padding: 9rem 0 0;
}
@media screen and (max-width: 1024px) {
  .top_support_inner {
    padding: 9rem 0 9rem;
  }
}
.top_support_ttl {
  text-align: center;
  margin-bottom: 8rem;
}
@media screen and (max-width: 1024px) {
  .top_support_ttl {
    margin-bottom: 5rem;
  }
}
.top_support_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 2.2rem;
  letter-spacing: 0.1em;
  margin-bottom: 8px;
}
.top_support_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
}
.top_support_list {
  margin: 0 auto;
  overflow: visible;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 0;
  width: 100%;
}
.top_support_list_item {
  width: 100%;
  position: relative;
}
.top_support_list_item_imt {
  position: relative;
}
.top_support_list_item_imt figure {
  display: block;
  position: relative;
  padding-top: var(--figure-height);
  overflow: hidden;
  z-index: 1;
  padding-top: 46.11%;
}
.top_support_list_item_imt figure img {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  object-fit: cover;
  transition: all 0.3s linear;
}
@media screen and (max-width: 1024px) {
  .top_support_list_item_imt figure {
    padding-top: 100%;
  }
}
.top_support_list_item_imt a {
  position: relative;
  display: block;
}
.top_support_list_item_imt a:hover figure img {
  opacity: 0.7;
}
.top_support_list_item_ttl {
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
.top_support_list_item_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  color: var(--base-col);
  margin-bottom: 2px;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .top_support_list_item_ttl p {
    font-weight: 500;
    font-size: 1rem;
    letter-spacing: 0.1em;
    position: relative;
    padding-bottom: 7px;
    margin-bottom: 7px;
  }
  .top_support_list_item_ttl p:after {
    content: "";
    width: 9px;
    height: 1px;
    display: block;
    background-color: var(--base-col);
    position: absolute;
    bottom: 0;
    left: 50%;
    margin-left: -4.5px;
  }
}
.top_support_list_item_ttl h4 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.14em;
  line-height: 38px;
  color: var(--base-col);
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .top_support_list_item_ttl h4 {
    font-size: 1.2rem;
    line-height: 22px;
  }
}

.top_news {
  position: relative;
  z-index: 3;
  background-color: var(--eight-col);
}
.top_news_inner {
  padding: 10rem 9.72vw 10rem;
}
@media screen and (max-width: 1024px) {
  .top_news_inner {
    padding: 9rem 3.2rem 9rem;
  }
}
.top_news_contents {
  margin-bottom: 5rem;
}
@media screen and (min-width: 1025px) {
  .top_news_contents {
    display: grid;
    grid-template-columns: auto 78%;
    align-items: flex-start;
    margin-bottom: 7rem;
  }
}
.top_news_ttl {
  text-align: left;
  margin-bottom: 4.8rem;
}
@media screen and (max-width: 1024px) {
  .top_news_ttl {
    text-align: center;
    margin-bottom: 9.7rem;
  }
}
.top_news_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 2.2rem;
  letter-spacing: 0.1em;
  margin-bottom: 6px;
}
@media screen and (max-width: 1024px) {
  .top_news_ttl h3 {
    margin-bottom: 8px;
  }
}
.top_news_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
}
@media screen and (max-width: 1024px) {
  .top_news_category {
    display: none;
  }
}
.top_news_category li {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 36px;
}
.top_news_category li a {
  text-decoration: none;
}
.top_news_category li.is_active a:before {
  content: "・";
}
.top_news_list {
  width: 100%;
}
.top_news_list_item {
  width: 100%;
  position: relative;
  padding: 17px 0;
  border-bottom: solid 1px var(--force-col);
}
@media screen and (min-width: 1025px) {
  .top_news_list_item {
    display: grid;
    grid-template-columns: 12rem 10rem auto;
    padding: 21.3px 0;
  }
}
@media screen and (max-width: 1024px) {
  .top_news_list_item {
    display: grid;
    grid-template-columns: 8rem auto;
  }
}
.top_news_list_item:first-child {
  border-top: solid 1px var(--force-col);
}
@media screen and (max-width: 1024px) {
  .top_news_list_item_date {
    grid-row: 1;
    grid-column: 1/2;
  }
}
.top_news_list_item_date p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1024px) {
  .top_news_list_item_date p {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 1024px) {
  .top_news_list_item_cat {
    grid-row: 1;
    grid-column: 2/3;
  }
}
.top_news_list_item_cat p {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1024px) {
  .top_news_list_item_cat p {
    font-size: 1rem;
  }
}
@media screen and (max-width: 1024px) {
  .top_news_list_item_title {
    grid-row: 2;
    grid-column: 1/3;
  }
}
.top_news_list_item_title a {
  text-decoration: none;
  color: var(--txt-col);
}
.top_news_list_item_title a h4 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.2em;
}
@media screen and (max-width: 1024px) {
  .top_news_list_item_title a h4 {
    font-weight: 500;
    font-size: 1.3rem;
    letter-spacing: 0.2em;
    line-height: 24px;
  }
}
.top_news_list_item_title a:hover {
  opacity: 0.5;
}
.top_news_list_item_title a:after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  top: 0;
  z-index: 4;
}
@media screen and (max-width: 1024px) {
  .top_news_more {
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
.top_news_more a {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.1rem;
  letter-spacing: 0.2em;
  line-height: 36px;
  text-decoration: none;
  position: relative;
  padding-left: 7.5rem;
}
.top_news_more a:before {
  content: "";
  width: 5.9rem;
  height: 0.8rem;
  background-image: url(../img/ico_arrow_link.svg);
  background-size: contain;
  background-repeat: no-repeat;
  display: block;
  position: absolute;
  left: 0;
  top: 50%;
  z-index: 1;
  margin-top: -4px;
}

.top_company {
  position: relative;
  z-index: 3;
  background-color: var(--eight-col);
  background-image: url(../img/company_bg.webp);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}
.top_company_inner {
  padding: 10rem 4rem 10rem;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .top_company_inner {
    padding: 10rem 5rem 10rem;
  }
}
.top_company_logo {
  margin-bottom: 4.6rem;
}
.top_company_logo img {
  width: 8.2rem;
  height: auto;
}
.top_company_title {
  margin-bottom: 5.7rem;
}
.top_company_title h2 {
  font-family: "Source Sans 3", sans-serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
  font-size: 1.8rem;
  letter-spacing: 0.23em;
  margin-bottom: 7px;
}
.top_company_title p {
  font-family: "Source Sans 3", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 1.2rem;
  letter-spacing: 0.16em;
  line-height: 21px;
}
@media screen and (max-width: 1024px) {
  .top_company .btn {
    max-width: 100%;
  }
}

/* product page */
.kv {
  position: relative;
  z-index: 2;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  --kv-txt-col: var(--base-col);
  /*
  margin-top: var(--header-height);
  */
}
.kv_inner {
  height: auto;
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  padding: 0 9.72vw 5.4rem;
  display: grid;
  grid-template-columns: 1fr;
  align-items: flex-end;
  justify-content: center;
}
@media screen and (min-width: 1025px) {
  .kv_inner {
    min-height: calc(100vh - var(--header-height));
  }
}
@media screen and (max-width: 1024px) {
  .kv_inner {
    padding: 6rem 3.2rem 5.4rem;
  }
}
.kv_img {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 4rem 0;
}
@media screen and (max-width: 1024px) {
  .kv_img {
    padding: 0;
    margin-left: -3.2rem;
    margin-right: -3.2rem;
  }
}
.kv_img figure {
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  .kv_img figure {
    max-width: 1252px;
  }
}
.kv_content {
  max-width: 58rem;
}
.kv_content_title {
  margin-bottom: 2rem;
}
@media screen and (min-width: 1025px) {
  .kv_content_title {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    grid-gap: 5rem;
  }
}
.kv_content_title h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 2.2rem;
  letter-spacing: 0.1em;
  color: var(--kv-txt-col);
}
.kv_content_title p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
  color: var(--kv-txt-col);
  opacity: 0.7;
}
.kv_content_txt p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  line-height: 32px;
  color: var(--kv-txt-col);
}
@media screen and (max-width: 1024px) {
  .kv_content_txt p {
    font-size: 1.3rem;
    line-height: 2;
  }
}

#cosmos .kv {
  /*
    margin-top: calc(var(--header-height) * 2);
  */
}
#cosmos .kv_inner {
  min-height: calc(100vh - var(--header-height) * 2);
}
#cosmos .kv {
  background-image: url(../img/kv_bg.webp);
  --kv-txt-col: var(--txt-col);
}

#thinning .kv {
  /*
    margin-top: calc(var(--header-height) * 2);
  */
}
#thinning .kv_inner {
  min-height: calc(100vh - var(--header-height) * 2);
}
#thinning .kv {
  background-image: url(../img/kv_bg.webp);
  --kv-txt-col: var(--txt-col);
}

#hikari .kv {
  background-image: url(../img/kv_bg.webp);
  --kv-txt-col: var(--txt-col);
}

#lefty .kv {
  background-image: url(../img/kv_bg.webp);
  --kv-txt-col: var(--txt-col);
}

#cuticle_nipper .kv {
  background-image: url(../img/kv_bg.webp);
  --kv-txt-col: var(--txt-col);
}

.simple_kv {
  position: relative;
  z-index: 2;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  --kv-txt-col: var(--txt-col);
  margin-top: 0;
  background-image: url(../img/kv_bg.webp);
}
.simple_kv_inner {
  height: 21.5rem;
  min-height: 21.5rem;
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  padding: 5.4rem 9.72vw 5.4rem;
  display: grid;
  grid-template-columns: 1fr;
  align-items: center;
  justify-content: center;
}
.simple_kv_content {
  max-width: 58rem;
}
@media screen and (min-width: 1025px) {
  .simple_kv_content_title {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    grid-gap: 5rem;
  }
}
.simple_kv_content_title h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 2.2rem;
  letter-spacing: 0.1em;
  color: var(--kv-txt-col);
}
.simple_kv_content_title p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
  color: var(--kv-txt-col);
  opacity: 0.7;
}
.simple_kv_content_txt p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  line-height: 32px;
  color: var(--kv-txt-col);
}

.product {
  background-color: var(--third-col);
  padding: 11rem 9.72vw 0;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .product {
    padding: 11rem 3.2rem 0;
  }
}
.product_label {
  position: fixed;
  top: 14rem;
  left: 5rem;
  z-index: 2;
  transform-origin: top left;
  transform: rotate(90deg) translateX(4rem);
  display: inline-block;
  margin-left: 0;
  opacity: 0;
  transition: all 0.2s ease;
}
@media screen and (max-width: 1024px) {
  .product_label {
    top: 16rem;
    left: 2rem;
  }
}
.product_label p {
  font-family: var(--font-arial);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1024px) {
  .product_label p {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 1024px) {
  .product_label + .product_inner, .product_label + .cosmos_line_product_inner, .product_label ~ .spec_inner {
    padding-left: 5%;
  }
}
.product_label + .product_inner .product_option_contact {
  margin-left: calc((5% + 3.2rem) * -1);
  padding-left: calc(5% + 3.2rem);
}
.product_ttl {
  margin-bottom: 2.2rem;
}
.product_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 2.2rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1024px) {
  .product_ttl h3 {
    font-size: 2rem;
  }
}
.product_caption {
  max-width: 60rem;
  margin: 0 auto 0 0;
  margin-bottom: 9rem;
}
.product_caption h4 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.14em;
  line-height: 38px;
  margin-bottom: 1.4rem;
}
@media screen and (max-width: 1024px) {
  .product_caption h4 {
    font-size: 2rem;
  }
}
.product_caption p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  line-height: 32px;
}
@media screen and (max-width: 1024px) {
  .product_caption p {
    font-size: 1.4rem;
  }
}
.product_filter {
  width: 100%;
  margin-bottom: 0;
}
.product_filter_inner {
  width: 100%;
  border-bottom: solid 1px var(--secondary-col);
  display: flex;
  align-items: center;
  justify-content: flex-start;
  grid-gap: 4rem;
  padding-bottom: 1.8rem;
}
.product_filter_label {
  font-family: var(--font-arial);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
}
.product_list {
  margin: 0 auto;
  position: relative;
}
.product_list_inner {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-gap: 0;
  margin: 0 -3.5rem;
}
@media screen and (max-width: 1024px) {
  .product_list_inner {
    grid-template-columns: 1fr;
  }
}
.product_list_item {
  /*
  border-bottom: 1px solid var(--nine-col);
  */
  padding: 7rem 3.5rem 7rem;
  position: relative;
}
@media screen and (min-width: 1025px) {
  .product_list_item:nth-child(3n-2):after {
    content: "";
    width: 100%;
    width: 80.56vw;
    height: 1px;
    background-color: var(--nine-col);
    display: block;
    position: absolute;
    bottom: 0;
    left: 3.5rem;
    right: 0;
    z-index: 1;
  }
}
@media screen and (max-width: 1024px) {
  .product_list_item:after {
    content: "";
    width: 100%;
    width: 80.56vw;
    height: 1px;
    background-color: var(--nine-col);
    display: block;
    position: absolute;
    bottom: 0;
    left: 3.5rem;
    right: 0;
    z-index: 1;
  }
}
.product_list_item_img {
  margin: 0;
  position: relative;
}
.product_list_item_img figure {
  display: block;
  position: relative;
  padding-top: var(--figure-height);
  overflow: hidden;
  z-index: 1;
  padding-top: 118.75%;
  transition: all 0.2s ease;
}
.product_list_item_img figure img {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  object-fit: cover;
  transition: all 0.3s linear;
}
@media screen and (max-width: 1024px) {
  .product_list_item_img figure {
    padding-top: 64.4%;
    background-color: #FFF;
  }
  .product_list_item_img figure img {
    object-fit: contain;
  }
}
.product_list_item_img:hover figure {
  opacity: 0.7;
}
.product_list_item_img img {
  vertical-align: bottom;
  transition: all 0.2s ease;
}
.product_list_item_img img.is_hide {
  opacity: 0;
}
.product_list_item_img_swc {
  position: absolute;
  left: 1rem;
  bottom: 0.5rem;
  z-index: 1;
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.1em;
  line-height: 22px;
  color: var(--secondary-col);
}
.product_list_item_img_swc a {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.1em;
  line-height: 22px;
  color: var(--secondary-col);
  text-decoration: none;
  position: relative;
}
.product_list_item_img_swc a.is_active:after {
  content: "";
  width: 100%;
  height: 1px;
  display: block;
  background-color: var(--seven-col);
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 1;
}
.product_list_item_label {
  text-align: right;
  margin-bottom: 3rem;
}
.product_list_item_label p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 17px;
  background-color: var(--base-col);
  display: inline-block;
  padding: 0.3rem 0.8rem;
}
.product_list_item_content {
  position: relative;
}
.product_list_item_content_title {
  display: flex;
  justify-content: space-between;
}
.product_list_item_content_title h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.7rem;
  letter-spacing: 0.1em;
  line-height: 20px;
  margin-bottom: 1.5rem;
}
.product_list_item_content_title p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.1rem;
  letter-spacing: 0.1em;
  line-height: 20px;
}
.product_list_item_content_model {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  line-height: 17px;
  margin-bottom: 4px;
  padding-bottom: 4px;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  margin-top: -17px;
}
.product_list_item_content h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.7rem;
  letter-spacing: 0.1em;
  line-height: 20px;
  margin-bottom: 1.3rem;
}
.product_list_item_content h4 span {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  margin-left: 1.3rem;
}
.product_list_item_content_detail {
  height: auto;
  margin-bottom: 3.8rem;
}
.product_list_item_content_detail p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
}
.product_list_item_content_price dl {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
}
@media screen and (max-width: 1024px) {
  .product_list_item_content_price dl {
    align-items: flex-start;
    margin-bottom: 0.5rem;
  }
}
.product_list_item_content_price dl dt {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  line-height: 16px;
}
.product_list_item_content_price dl dt span {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.1em;
  line-height: 22px;
  margin-left: 1.5rem;
}
@media screen and (max-width: 1024px) {
  .product_list_item_content_price dl dt span {
    margin-left: 0.5rem;
  }
}
.product_list_item_content_price dl dt span.item_suki {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.1em;
  line-height: 16px;
  margin-left: 0rem;
}
.product_list_item_content_price dl dt .product_class {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  grid-gap: 2.2rem;
}
.product_list_item_content_price dl dt .product_class_color {
  text-align: center;
  padding-top: 2.6rem;
  position: relative;
}
.product_list_item_content_price dl dt .product_class_color:before {
  content: "";
  width: 1.8rem;
  height: 1.8rem;
  border-radius: 1rem;
  display: block;
  background-color: var(--base-col);
  border: solid 1px var(--force-col);
  position: absolute;
  top: 0;
  left: 50%;
  margin-left: -1rem;
}
.product_list_item_content_price dl dt .product_class_color > p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  line-height: 22px;
  line-height: 15px;
  color: var(--seven-col);
}
.product_list_item_content_price dl dd {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 22px;
}
.product_list_item_content_price > p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  margin-top: 1rem;
}
.product_list_item_content_price .product_class2 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  grid-gap: 2rem 0rem;
}
.product_list_item_content_price .product_class2_color {
  text-align: center;
  position: relative;
}
.product_list_item_content_price .product_class2_color figure {
  width: 4rem;
  height: 4rem;
  border-radius: 2rem;
  display: block;
  background-color: var(--base-col);
  margin: 0 auto 7px;
}
.product_list_item_content_price .product_class2_color > p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  line-height: 22px;
  line-height: 16px;
  color: var(--seven-col);
}
.product_list_item_content_class {
  margin-bottom: 3.8rem;
}
.product_list_item_content_class dl {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
}
.product_list_item_content_class dl dt {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  line-height: 16px;
}
.product_list_item_content_class dl dt span {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.1em;
  line-height: 22px;
  margin-left: 1.5rem;
}
.product_list_item_content_class dl dt span.item_suki {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.1em;
  line-height: 16px;
  margin-left: 0rem;
}
.product_list_item_content_class dl dt .product_class {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  grid-gap: 2.2rem;
  max-width: 30rem;
  flex-wrap: wrap;
}
.product_list_item_content_class dl dt .product_class.product_class_4 {
  max-width: 42rem;
}
.product_list_item_content_class dl dt .product_class_color {
  text-align: center;
  padding-top: 2.6rem;
  position: relative;
  width: 8.4rem;
}
.product_list_item_content_class dl dt .product_class_color:before {
  content: "";
  width: 1.8rem;
  height: 1.8rem;
  border-radius: 1rem;
  display: block;
  background-color: var(--base-col);
  border: solid 1px var(--force-col);
  position: absolute;
  top: 0;
  left: 50%;
  margin-left: -1rem;
}
.product_list_item_content_class dl dt .product_class_color > p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  line-height: 22px;
  line-height: 15px;
  color: var(--seven-col);
}
.product_list_item_content_class dl dd {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 22px;
}
.product_list_item_content_class > p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  margin-top: 1rem;
}
.product_list_item_content_class .product_class2 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  grid-gap: 2rem 0rem;
}
.product_list_item_content_class .product_class2_color {
  text-align: center;
  position: relative;
}
.product_list_item_content_class .product_class2_color figure {
  width: 4rem;
  height: 4rem;
  border-radius: 2rem;
  display: block;
  background-color: var(--base-col);
  margin: 0 auto 7px;
}
.product_list_item_content_class .product_class2_color > p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  line-height: 22px;
  line-height: 16px;
  color: var(--seven-col);
}
.product_list_item_content_btn {
  text-align: center;
  margin-top: 4.4rem;
}
.product_list_item_content_btn .btn {
  max-width: 100%;
}
.product_list_item_content_linkbtn {
  margin-top: 2.2rem;
  padding-bottom: 2px;
}
.product_list_item_content_linkbtn .btn {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 17px;
  --txt-col: var(--seven-col);
  --bg-col: var(--force-col);
  margin-left: 1px;
}
.product_list_item_content_linkbtn .btn .icon-arrow-btn {
  width: 2.5rem;
  height: 0.8rem;
  color: var(--bg-col);
}
.product_list_item.is_hide {
  display: none;
}
.product .product_class_color.camel:before {
  background-color: var(--camel-col);
}
.product .product_class_color.sakura:before {
  background-color: var(--sakura-col);
}
.product .product_class_color.deep_pink:before {
  background-color: var(--deep_pink-col);
}
.product .product_class_color.s_blue:before {
  background-color: var(--s_blue-col);
}
.product .product_class_color.orange:before {
  background-color: var(--orange-col);
}
.product .product_class_color.kimidori:before {
  background-color: var(--kimidori-col);
}
.product .product_class_color.red:before {
  background-color: var(--red4-col);
}
.product .product_class_color.white:before {
  background-color: var(--white-col);
}
.product .product_class_color.pink:before {
  background-color: var(--pink-col);
}
.product .product_class_color.black:before {
  background-color: var(--black-col);
}
.product .product_class_color.gold:before {
  background-color: var(--gold-col);
}
.product .product_class_color.silver:before {
  background-color: var(--silver-col);
}
.product .product_second_list .product_list_item_img figure {
  display: block;
  position: relative;
  padding-top: var(--figure-height);
  overflow: hidden;
  z-index: 1;
  padding-top: 83.57%;
  margin-bottom: 4.4rem;
}
.product .product_second_list .product_list_item_img figure img {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  object-fit: cover;
  transition: all 0.3s linear;
}
.product .product_second_list .product_list_item_content_title h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.7rem;
  letter-spacing: 0.1em;
  line-height: 20px;
  margin-bottom: 1.7rem;
}
.product .product_second_list .product_list_item_content_title h4.font-ja {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.08em;
  line-height: 24px;
}
.product .product_second_list .product_list_item_content_detail {
  margin-bottom: 3.5rem;
}
.product .product_second_list .product_list_item_content_price dl {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.product .product_second_list .product_list_item_content_price dl dt {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  line-height: 22px;
  display: grid;
  grid-template-columns: 10rem auto;
  align-items: center;
  justify-content: flex-start;
  grid-gap: 9px;
}
.product .product_second_list .product_list_item_content_price dl dt span {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  line-height: 22px;
  margin-left: 0;
  color: var(--black-col);
}
.product .product_second_list .product_list_item_content_price dl dt span.edge {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.2rem;
  letter-spacing: 0.05em;
  line-height: 22px;
  margin-left: 0;
}
.product .product_second_list .product_list_item_content_price dl dd {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 22px;
}
.product .product_second_list .product_list_item_content_price p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  line-height: 26px;
  margin-top: 3.8rem;
}
.product .product_second_list .product_list_item_content_price p a {
  color: rgba(58, 58, 58, 0.7);
  text-decoration: underline;
}
.product .product_third_list .product_list_item_img figure {
  display: block;
  position: relative;
  padding-top: var(--figure-height);
  overflow: hidden;
  z-index: 1;
  padding-top: 100%;
  margin-bottom: 4.4rem;
}
.product .product_third_list .product_list_item_img figure img {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  object-fit: cover;
  transition: all 0.3s linear;
}
.product .product_third_list .product_list_item_content_title h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.7rem;
  letter-spacing: 0.1em;
  line-height: 20px;
  margin-bottom: 1.7rem;
}
.product .product_third_list .product_list_item_content_title h4.font-ja {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.08em;
  line-height: 24px;
}
.product .product_third_list .product_list_item_content_detail {
  margin-bottom: 3.5rem;
}
.product .product_third_list .product_list_item_content_price dl {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
.product .product_third_list .product_list_item_content_price dl dt {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  line-height: 22px;
  display: grid;
  grid-template-columns: auto;
  align-items: center;
  justify-content: flex-start;
  grid-gap: 0px;
  line-height: 22px;
}
.product .product_third_list .product_list_item_content_price dl dt span {
  margin: 0;
}
.product .product_third_list .product_list_item_content_price dl dt span.edge {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.2rem;
  letter-spacing: 0.05em;
  line-height: 22px;
  margin-left: 0;
  margin-top: 0;
}
.product .product_third_list .product_list_item_content_price dl dd {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 22px;
}
.product .product_third_list .product_list_item_content_price p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  line-height: 26px;
  margin-top: 3.8rem;
}
.product .product_third_list .product_list_item_content_price p a {
  color: rgba(58, 58, 58, 0.7);
  text-decoration: underline;
}
.product .product_acc_list .product_list_item {
  position: relative;
}
@media screen and (min-width: 1025px) {
  .product .product_acc_list .product_list_item:nth-child(3n-2):after {
    content: "";
    width: 100%;
    width: 80.56vw;
    height: 1px;
    background-color: var(--nine-col);
    display: block;
    position: absolute;
    bottom: 0;
    left: 3.5rem;
    right: 0;
    z-index: 1;
  }
}
@media screen and (max-width: 1024px) {
  .product .product_acc_list .product_list_item:after {
    content: "";
    width: 100%;
    width: 80.56vw;
    height: 1px;
    background-color: var(--nine-col);
    display: block;
    position: absolute;
    bottom: 0;
    left: 3.5rem;
    right: 0;
    z-index: 1;
  }
}
@media screen and (min-width: 1025px) {
  .product .product_acc_list .product_list_item:nth-child(3n-2):last-child:after {
    display: none;
  }
}
.product .product_acc_list .product_list_item_img figure {
  display: block;
  position: relative;
  padding-top: var(--figure-height);
  overflow: hidden;
  z-index: 1;
  padding-top: 83.57%;
  margin-bottom: 4.4rem;
}
.product .product_acc_list .product_list_item_img figure img {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  object-fit: cover;
  transition: all 0.3s linear;
}
.product .product_acc_list .product_list_item_content_title h4 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.08em;
  line-height: 24px;
  margin-bottom: 1.7rem;
}
.product .product_acc_list .product_list_item_content_title h4.font-ja {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.08em;
  line-height: 24px;
}
.product .product_acc_list .product_list_item_content_detail {
  margin-bottom: 3.5rem;
}
.product .product_acc_list .product_list_item_content_price dl {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.product .product_acc_list .product_list_item_content_price dl dt {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  line-height: 22px;
  display: grid;
  grid-template-columns: 10rem auto;
  align-items: center;
  justify-content: flex-start;
  grid-gap: 9px;
}
.product .product_acc_list .product_list_item_content_price dl dt span {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  line-height: 22px;
  margin-left: 0;
  color: var(--black-col);
}
.product .product_acc_list .product_list_item_content_price dl dt span.edge {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.2rem;
  letter-spacing: 0.05em;
  line-height: 22px;
  margin-left: 0;
}
.product .product_acc_list .product_list_item_content_price dl dd {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 22px;
}
.product .product_acc_list .product_list_item_content_price > p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  line-height: 26px;
  margin-top: 3.8rem;
  color: rgba(58, 58, 58, 0.7);
  text-decoration: underline;
}
.product .product_acc_list .product_list_item_content_price + .product_list_item_content_price {
  margin-top: 3.8rem;
}
.product_inner + .spec_inner {
  margin-top: 7rem;
}

#lefty_product2 {
  padding-top: 7rem;
}
#lefty_product2 .product_inner {
  margin-top: -7rem;
}

#lefty_product3 {
  padding-top: 7rem;
}
@media screen and (max-width: 1024px) {
  #lefty_product3 {
    border-top: solid 1px var(--nine-col);
  }
}

#cuticle_nipper_product2 {
  padding-top: 0;
  padding-bottom: 7rem;
}

#cuticle_nipper_product3 {
  background-color: var(--base-col);
}

.cosmos_line_product {
  padding: 7rem 9.72vw 7rem;
  position: relative;
  z-index: 1;
}
.cosmos_line_product_ttl {
  margin-bottom: 2.1rem;
}
.cosmos_line_product_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 2.4rem;
  letter-spacing: 0.1em;
}
.cosmos_line_product_caption {
  max-width: 60rem;
  margin: 0 auto 0 0;
  margin-bottom: 7rem;
}
.cosmos_line_product_caption h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.7rem;
  letter-spacing: 0.1em;
  line-height: 20px;
}
.cosmos_line_product_caption h4 + p {
  margin-top: 2.1rem;
}
.cosmos_line_product_caption p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.2em;
  line-height: 28px;
}
.cosmos_line_product_list {
  margin: 0 auto;
  position: relative;
  padding: 0 5px;
}
.cosmos_line_product_list_wrap {
  position: relative;
}
.cosmos_line_product_list_inner {
  margin: 0;
}
.cosmos_line_product_list_item {
  padding: 0 0 5px;
  width: 33%;
  max-width: 34rem;
}
.cosmos_line_product_list_item_img {
  margin: 0;
}
.cosmos_line_product_list_item_img figure {
  display: block;
  position: relative;
  padding-top: var(--figure-height);
  overflow: hidden;
  z-index: 1;
  padding-top: 118.75%;
}
.cosmos_line_product_list_item_img figure img {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  object-fit: cover;
  transition: all 0.3s linear;
}
@media screen and (max-width: 1024px) {
  .cosmos_line_product_list_item_img figure {
    background-color: #FFF;
    padding-top: 64.4%;
  }
  .cosmos_line_product_list_item_img figure img {
    object-fit: contain;
  }
}
.cosmos_line_product_list_item_img a:hover figure img {
  opacity: 0.7;
}
.cosmos_line_product_list_item_img img {
  vertical-align: bottom;
}
.cosmos_line_product_list_item_label {
  text-align: right;
  margin-bottom: 3rem;
}
.cosmos_line_product_list_item_label p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 17px;
  background-color: var(--base-col);
  display: inline-block;
  padding: 0.3rem 0.8rem;
}
.cosmos_line_product_list_item_content h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.7rem;
  letter-spacing: 0.1em;
  line-height: 20px;
  margin-bottom: 1.3rem;
}
.cosmos_line_product_list_item_content_price dl {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 6px;
}
.cosmos_line_product_list_item_content_price dl dt {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  line-height: 16px;
}
.cosmos_line_product_list_item_content_price dl dt span {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.1em;
  line-height: 22px;
  margin-left: 1.5rem;
}
.cosmos_line_product_list_item_content_price dl dt span.item_suki {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.1em;
  line-height: 16px;
  margin-left: 0rem;
}
.cosmos_line_product_list_item_content_price dl dd {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 16px;
}
.cosmos_line_product_list_item_content_price p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  margin-top: 1rem;
}
.cosmos_line_product .swiper-button-prev {
  left: -40px;
  margin-top: -110px;
}
@media screen and (max-width: 1024px) {
  .cosmos_line_product .swiper-button-prev {
    left: -20px;
    margin-top: 0;
    top: 19vw;
  }
}
.cosmos_line_product .swiper-button-prev svg {
  color: rgba(255, 255, 255, 0.5);
}
.cosmos_line_product .swiper-button-next {
  right: -40px;
  margin-top: -110px;
}
@media screen and (max-width: 1024px) {
  .cosmos_line_product .swiper-button-next {
    right: -20px;
    margin-top: 0;
    top: 19vw;
  }
}
.cosmos_line_product .swiper-button-next svg {
  color: rgba(255, 255, 255, 0.5);
}
.cosmos_line_product .swiper-button-disabled {
  display: none;
}
.cosmos_line_product.is_active .product_list_item_content_linkbtn {
  opacity: 0.5;
}
.cosmos_line_product.is_active .product_list_item_content_linkbtn .btn {
  --txt-col: var(--base-col);
  --bg-col: var(--base-col);
}
.cosmos_line_product.is_active .product_list_item_content_linkbtn .btn:hover {
  --link-hov-col: var(--base-col);
}
.cosmos_line_product.is_active .product_list_item_content_linkbtn .btn .icon-arrow-btn {
  color: var(--bg-col);
}

.product_section {
  transition: all 0.4s ease;
}
@media screen and (max-width: 1024px) {
  .product_section {
    overflow: clip;
  }
}
.product_section.is_active .product_label {
  opacity: 1;
}
.product_section.is_active .thinning_product_label {
  opacity: 1;
}
.product_section.is_active#cosmos_product2 {
  background-color: var(--thirteen-col);
}
.product_section.is_active#cosmos_line_product1 {
  background-color: var(--ten-col);
}
.product_section.is_active#cosmos_line_product2 {
  background-color: var(--eleven-col);
}
.product_section.is_active#cosmos_line_product3 {
  background-color: var(--twelve-col);
}
.product_section.is_active#cosmos_line_product4 {
  background-color: #A9A7AA;
}

.spec {
  padding: 7rem 9.72vw 8rem;
  background-color: var(--third-col);
  position: relative;
  z-index: 1;
}
.spec#cosmos_spec_table2 {
  background-color: var(--thirteen-col);
  padding-bottom: 16rem;
}
.spec_inner {
  display: inline-block;
  max-width: 100%;
}
.spec_ttl {
  margin-bottom: 0;
}
.spec_ttl h3 {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
}
.spec_caption {
  text-align: right;
  margin-bottom: 1.6rem;
}
.spec_caption p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.1rem;
  letter-spacing: 0.1em;
  opacity: 0.5;
}
@media screen and (max-width: 1024px) {
  .spec_caption p {
    display: none;
  }
}
.spec_table {
  width: 100%;
  background-color: var(--base-col);
  padding-bottom: 1.5rem;
  width: 378rem;
}
.spec_table_wrap {
  overflow: auto;
  margin-right: -9.72vw;
}
.spec_table_wrap::-webkit-scrollbar {
  width: 14px;
}
.spec_table_wrap::-webkit-scrollbar-track {
  background-color: var(--force-col);
  border-radius: 3px;
}
.spec_table_wrap::-webkit-scrollbar-thumb {
  border: 2px solid var(--secondary-col);
  background-color: var(--secondary-col);
  border-radius: 5px;
  box-shadow: none;
}
.spec_table_inner {
  display: grid;
  grid-template-columns: 21rem 105rem 42rem 42rem 84rem 42rem 42rem;
  grid-gap: 0;
}
.spec_table_content {
  --grid-clm: 1;
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 7;
  grid-template-columns: repeat(var(--grid-clm), 21rem);
  grid-gap: 0;
  background-color: var(--base-col);
}
.spec_table_haed {
  gap: 0;
  align-items: flex-start;
  border-bottom: solid 1px rgba(58, 58, 58, 0.2);
  display: inherit;
  grid-template-rows: inherit;
  grid-row: inherit;
}
.spec_table_block {
  gap: 0;
  align-items: flex-start;
  border-bottom: solid 1px rgba(58, 58, 58, 0.2);
  display: inherit;
  grid-template-rows: inherit;
  grid-row: inherit;
  --spec-bg-col: var(--base-col);
}
.spec_table_block:hover {
  --spec-bg-col: #FAFAFA;
  background-color: rgba(217, 217, 217, 0.1);
}
.spec_table_th {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  border-top: solid 1px rgba(58, 58, 58, 0.2);
  padding: 15px 11px;
}
.spec_table_td {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  flex-wrap: wrap;
  border-top: solid 1px rgba(58, 58, 58, 0.2);
  padding: 1.5rem 1rem;
  height: 100%;
}
.spec_table_name {
  margin-top: -7px;
  height: 4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  width: 100%;
}
.spec_table_name h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  line-height: 20px;
  text-align: center;
  width: 100%;
}
.spec_table_name h5 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 17px;
  width: 100%;
  text-align: center;
}
.spec_table_name p {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 0.9rem;
  letter-spacing: 0.1em;
  line-height: 17px;
}
.spec_table_img {
  width: 100%;
  text-align: center;
}
.spec_table_img figure {
  text-align: center;
  position: relative;
  display: inline-block;
  width: auto;
}
.spec_table_img figure:after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  display: block;
  background-color: var(--spec-bg-col);
  mix-blend-mode: multiply;
}
.spec_table_img figure img {
  width: auto;
  height: 100px;
  max-width: 100%;
}
.spec_table_label {
  padding: 2px 11px;
}
.spec_table_label2 {
  padding: 2px 11px;
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.1rem;
  letter-spacing: 0.1em;
  line-height: 17px;
}
.spec_table_type {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 17px;
  width: 100%;
  text-align: center;
}
.spec_table_info {
  text-align: center;
}
.spec_table_info p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.05em;
  line-height: 28px;
  text-align: left;
}
.spec_table_info p span {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 28px;
  margin-left: 1rem;
}
.spec_table_info p span.item_suki {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.1em;
  line-height: 16px;
  margin-top: -0.5rem;
  margin-left: 0;
  display: block;
  text-align: left;
}
.spec_table_info p.caption {
  position: relative;
}
.spec_table_info p.caption:before {
  content: "※";
  position: absolute;
  left: -1.2em;
  top: 0;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 0.9rem;
  letter-spacing: 0.1em;
}
.spec_table_info_caption {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 0.9rem !important;
  letter-spacing: 0.1em;
  line-height: 1.8 !important;
  margin-top: 2rem;
  text-align: center !important;
  color: rgba(58, 58, 58, 0.5);
}
.spec_table_material {
  display: flex;
  align-items: center;
  justify-content: center;
}
.spec_table_material p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  line-height: 26px;
}
.spec_table_material p a {
  color: var(--txt-col);
}
.spec_table_comment {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  line-height: 26px;
}
.spec_table_comment a {
  color: var(--txt-col);
}
.spec_table_model {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  width: 100%;
  text-align: center;
}
.spec_table_block1 {
  --grid-clm: 5;
}
.spec_table_block2 {
  --grid-clm: 2;
}
.spec_table_block2 .spec_table_label {
  background-color: var(--force-col);
}
.spec_table_block3 {
  --grid-clm: 4;
}
.spec_table_block3 .spec_table_label {
  background-color: rgba(217, 217, 217, 0.5);
}
.spec_table_block4 {
  --grid-clm: 2;
}
.spec_table_block4 .spec_table_label {
  background-color: var(--force-col);
}
.spec_table_block5 {
  --grid-clm: 2;
}
.spec_table_block5 .spec_table_label {
  background-color: rgba(217, 217, 217, 0.5);
}
.spec_table_block6 {
  --grid-clm: 2;
}
.spec_table_block6 .spec_table_label {
  background-color: #c7c4c4;
}
.spec_table#spec_table2 {
  width: 147rem;
}
.spec_table#spec_table2 .spec_table_wrap {
  margin-right: -9.72vw;
}
.spec_table#spec_table2 .spec_table_inner {
  grid-template-columns: 21rem 126rem;
}
.spec_table#spec_table2 .spec_table_content {
  --grid-clm: 1;
  grid-row: span 6;
  grid-template-columns: repeat(var(--grid-clm), 21rem);
}
.spec_table#spec_table2 .spec_table_block1 {
  --grid-clm: 6;
}
.spec_table#spec_table3 {
  width: 252rem;
}
.spec_table#spec_table3 .spec_table_wrap {
  margin-right: -9.72vw;
}
.spec_table#spec_table3 .spec_table_inner {
  grid-template-columns: 21rem 63rem 21rem 21rem 21rem 105rem;
}
.spec_table#spec_table3 .spec_table_content {
  --grid-clm: 1;
  grid-row: span 7;
  grid-template-columns: repeat(var(--grid-clm), 21rem);
}
.spec_table#spec_table3 .spec_table_block1 {
  --grid-clm: 3;
}
.spec_table#spec_table3 .spec_table_block2 {
  --grid-clm: 1;
}
.spec_table#spec_table3 .spec_table_block3 {
  --grid-clm: 1;
}
.spec_table#spec_table3 .spec_table_block4 {
  --grid-clm: 1;
}
.spec_table#spec_table3 .spec_table_block5 {
  --grid-clm: 5;
}
.spec#spec_table4 .spec_table {
  width: 105rem;
}
.spec#spec_table4 .spec_table_wrap {
  margin-right: 0;
}
.spec#spec_table4 .spec_table_inner {
  grid-template-columns: 21rem 84rem;
}
.spec#spec_table4 .spec_table_content {
  --grid-clm: 1;
  grid-row: span 6;
  grid-template-columns: repeat(var(--grid-clm), 21rem);
}
.spec#spec_table4 .spec_table_block1 {
  --grid-clm: 4;
}
.spec#spec_table5 .spec_table {
  width: 189rem;
}
.spec#spec_table5 .spec_table_wrap {
  margin-right: -9.72vw;
}
.spec#spec_table5 .spec_table_inner {
  grid-template-columns: 21rem 126rem 42rem;
}
.spec#spec_table5 .spec_table_content {
  --grid-clm: 1;
  grid-row: span 7;
  grid-template-columns: repeat(var(--grid-clm), 21rem);
}
.spec#spec_table5 .spec_table_block1 {
  --grid-clm: 6;
}
.spec#spec_table5 .spec_table_block2 {
  --grid-clm: 2;
}
.spec#spec_table5 .spec_table_block2 .spec_table_label {
  background-color: rgba(217, 217, 217, 0.5);
}

#spec2 {
  padding-bottom: 46rem;
  width: 100%;
}
@media screen and (max-width: 1024px) {
  #spec2 {
    padding-bottom: 7rem;
  }
}

.product_about {
  width: 100%;
  background-color: var(--base-col);
  padding: 11rem 9.72vw;
}
@media screen and (max-width: 1024px) {
  .product_about {
    padding: 8rem 0 0;
  }
}
.product_about_banner {
  margin-bottom: 2rem;
}
@media screen and (max-width: 1024px) {
  .product_about_banner {
    margin-bottom: 3.6rem;
    padding: 0 3.2rem;
  }
}
.product_about_banner_img {
  background-image: url(../img/product_about_banner1.webp);
  background-size: cover;
  background-repeat: no-repeat;
  padding-top: 44%;
}
@media screen and (max-width: 1024px) {
  .product_about_banner_img {
    padding-top: 55.214%;
    margin-bottom: 2rem;
  }
}
.product_about_banner_btn {
  padding: 5rem 9.72vw 0;
}
@media screen and (max-width: 1024px) {
  .product_about_banner_btn {
    padding: 5rem 3.2rem 0;
  }
}
.product_about_banner_btn_inner {
  text-align: center;
  padding-bottom: 7rem;
}
@media screen and (min-width: 1025px) {
  .product_about_banner_btn_inner {
    border-bottom: solid 1px var(--nine-col);
  }
}
@media screen and (max-width: 1024px) {
  .product_about_banner_btn .btn {
    max-width: 100%;
  }
}
.product_about_banner_inner {
  position: relative;
}
.product_about_banner_ttl {
  max-width: 56rem;
}
@media screen and (min-width: 1025px) {
  .product_about_banner_ttl {
    position: absolute;
    left: 0;
    bottom: 7rem;
    z-index: 1;
    padding: 0 8rem;
  }
}
.product_about_banner_ttl h5 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  margin-bottom: 1rem;
}
@media screen and (min-width: 1025px) {
  .product_about_banner_ttl h5 {
    color: var(--base-col);
    margin-bottom: 1.8rem;
  }
}
@media screen and (max-width: 1024px) {
  .product_about_banner_ttl h5 {
    font-size: 1.2rem;
  }
}
.product_about_banner_ttl h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  margin-bottom: 1.2rem;
}
@media screen and (min-width: 1025px) {
  .product_about_banner_ttl h3 {
    color: var(--base-col);
    margin-bottom: 1.9rem;
  }
}
@media screen and (max-width: 1024px) {
  .product_about_banner_ttl h3 {
    font-size: 1.6rem;
    line-height: 2;
  }
}
.product_about_banner_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 36px;
}
@media screen and (min-width: 1025px) {
  .product_about_banner_ttl p {
    color: var(--base-col);
  }
}
@media screen and (max-width: 1024px) {
  .product_about_banner_ttl p {
    font-size: 1.2rem;
    line-height: 2.5;
  }
}
.product_about_banner#product_about1 .product_about_banner_img {
  background-image: url(../img/product_about_banner1.webp);
}
.product_about_banner#product_about1 .product_about_ttl {
  left: 0;
  bottom: 7rem;
}
.product_about_banner#product_about2 .product_about_banner_img {
  background-image: url(../img/product_about_banner2.webp);
}
.product_about_banner#product_about2 .product_about_ttl {
  right: 0;
  left: auto;
  bottom: 7rem;
}
.product_about_banner#product_about3 .product_about_banner_img {
  background-image: url(../img/product_about_banner3.webp);
}
.product_about_banner#product_about3 .product_about_ttl {
  left: 0;
  bottom: 7rem;
}
.product_about_guide {
  padding: 7rem 9.72vw 0;
  overflow: hidden;
}
@media screen and (max-width: 1024px) {
  .product_about_guide {
    padding: 7rem 3.2rem 9rem;
    background-color: #EFEFEF;
  }
}
.product_about_guide_item {
  position: relative;
  padding-bottom: 7rem;
}
@media screen and (max-width: 1024px) {
  .product_about_guide_item {
    padding-bottom: 2rem;
  }
}
.product_about_guide_item + .product_about_guide_item {
  border-top: solid 1px var(--nine-col);
  padding-top: 7rem;
}
.product_about_guide_item_inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  margin-left: -12.1%;
  margin-right: -12.1%;
}
@media screen and (max-width: 1024px) {
  .product_about_guide_item_inner {
    grid-template-columns: 1fr;
  }
}
.product_about_guide_img figure {
  --figure-height: 100%;
  display: block;
  position: relative;
  padding-top: var(--figure-height);
  overflow: hidden;
  z-index: 1;
}
.product_about_guide_img figure img {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  object-fit: cover;
  transition: all 0.3s linear;
}
.product_about_guide_ttl {
  padding: 0 7rem;
}
@media screen and (max-width: 1024px) {
  .product_about_guide_ttl {
    padding: 0 3.2rem;
  }
}
.product_about_guide_ttl h5 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  margin-bottom: 1.8rem;
}
@media screen and (max-width: 1024px) {
  .product_about_guide_ttl h5 {
    text-align: center;
    font-size: 1.2rem;
    margin-bottom: 1rem;
  }
}
.product_about_guide_ttl h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  margin-bottom: 1.8rem;
}
@media screen and (max-width: 1024px) {
  .product_about_guide_ttl h3 {
    text-align: center;
    font-size: 1.6rem;
    margin-bottom: 2.2rem;
  }
}
.product_about_guide_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 36px;
  max-width: 39rem;
  margin-bottom: 7rem;
}
@media screen and (max-width: 1024px) {
  .product_about_guide_ttl p {
    font-size: 1.2rem;
    line-height: 2;
    margin-top: 2.2rem;
    margin-bottom: 3rem;
  }
}
.product_about_guide_btn + .product_about_guide_btn {
  margin-top: 3rem;
}
@media screen and (max-width: 1024px) {
  .product_about_guide_btn .btn {
    max-width: 100%;
  }
}
@media screen and (min-width: 1025px) {
  .product_about #product_about2 .product_about_banner_ttl {
    position: absolute;
    right: 0;
    bottom: 7rem;
    z-index: 1;
    left: auto;
  }
}

.thinning_about {
  padding: 19rem 9.72vw 5rem;
  background-color: var(--third-col);
}
@media screen and (max-width: 1024px) {
  .thinning_about {
    padding: 12rem 3.2rem 5rem;
  }
}
.thinning_about_inner {
  padding: 0 5.55vw;
}
@media screen and (max-width: 1024px) {
  .thinning_about_inner {
    padding: 0;
  }
}
.thinning_about_grid {
  display: grid;
  grid-template-columns: auto 30vw;
  grid-gap: 7.5vw;
  padding-bottom: 9rem;
  border-bottom: solid 1px var(--nine-col);
}
@media screen and (max-width: 1024px) {
  .thinning_about_grid {
    grid-template-columns: 1fr;
    padding-bottom: 4rem;
  }
}
.thinning_about_grid + .thinning_about_grid {
  padding-top: 9rem;
}
@media screen and (max-width: 1024px) {
  .thinning_about_grid + .thinning_about_grid {
    padding-top: 4rem;
  }
}
.thinning_about_grid_2 {
  grid-template-columns: auto 30vw;
  grid-gap: 6.18vw;
  padding-left: 12.08vw;
}
@media screen and (max-width: 1024px) {
  .thinning_about_grid_2 {
    grid-template-columns: 1fr;
    padding-left: 0;
  }
}
.thinning_about_grid_3 {
  grid-template-columns: 1fr 1fr;
  grid-gap: 5vw;
  padding-left: 12.08vw;
}
@media screen and (max-width: 1024px) {
  .thinning_about_grid_3 {
    grid-template-columns: 1fr 1fr;
    grid-gap: 3.2rem;
    padding-left: 0;
  }
  .thinning_about_grid_3 .thinning_about_text {
    grid-row: 1;
    grid-column: 1/3;
  }
}
.thinning_about_grid_4 {
  border-bottom: none;
}
.thinning_about_text h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.14em;
  line-height: 38px;
  margin-bottom: 1.4rem;
}
@media screen and (max-width: 1024px) {
  .thinning_about_text h3 {
    font-size: 2rem;
  }
}
.thinning_about_text p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  line-height: 32px;
}
@media screen and (max-width: 1024px) {
  .thinning_about_text p {
    font-size: 1.4rem;
  }
}
.thinning_about_text p + p {
  margin-top: 3.4rem;
}
.thinning_about_text p span {
  color: var(--seven-col);
}
.thinning_about_img figure img {
  width: 100%;
}
.thinning_about_img p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  line-height: 32px;
  margin-top: 1.4rem;
}
@media screen and (max-width: 1024px) {
  .thinning_about_img p {
    font-size: 1.4rem;
  }
}
.thinning_about_img p span {
  color: var(--seven-col);
}
.thinning_about_img_grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 3.8rem;
}
.thinning_about_img_grid figure {
  margin-bottom: 1.3rem;
}
.thinning_about_img_grid p {
  text-align: center;
  color: var(--seven-col);
}
@media screen and (max-width: 1024px) {
  .thinning_about_img_grid p {
    font-size: 1.4rem;
  }
}

.thinning_product {
  padding: 11rem 0 6rem;
  position: relative;
  z-index: 1;
  background-color: var(--nine-col);
}
@media screen and (max-width: 1024px) {
  .thinning_product {
    padding: 11rem 3.2rem 6rem;
  }
}
.thinning_product_inner {
  padding: 0 9.72vw 11rem;
}
@media screen and (max-width: 1024px) {
  .thinning_product_inner {
    padding: 0 0 11rem;
  }
}
.thinning_product#thinning_product2 {
  background-color: var(--third-col);
}
.thinning_product#thinning_product4 {
  background-color: var(--third-col);
}
.thinning_product_label {
  position: fixed;
  top: 14rem;
  left: 5rem;
  z-index: 2;
  transform-origin: top left;
  transform: rotate(90deg) translateX(4rem);
  display: inline-block;
  margin-left: 0;
  opacity: 0;
  transition: all 0.2s ease;
}
@media screen and (max-width: 1024px) {
  .thinning_product_label {
    top: 16rem;
    left: 2rem;
  }
}
.thinning_product_label p {
  font-family: var(--font-arial);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1024px) {
  .thinning_product_label p {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 1024px) {
  .thinning_product_label + .thinning_product_inner, .thinning_product_label ~ .thinning_products {
    padding-left: 5%;
  }
}
.thinning_product_ttl {
  margin-bottom: 13rem;
  border-bottom: solid 1px var(--secondary-col);
}
@media screen and (min-width: 1025px) {
  .thinning_product_ttl {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    grid-gap: 5.8vw;
  }
}
@media screen and (max-width: 1024px) {
  .thinning_product_ttl {
    padding-bottom: 1rem;
  }
}
.thinning_product_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 2.2rem;
  letter-spacing: 0.1em;
}
.thinning_product_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
}
@media screen and (min-width: 1025px) {
  .thinning_product_info {
    display: grid;
    grid-template-columns: 52vw 33rem;
    justify-content: space-between;
  }
}
@media screen and (max-width: 1024px) {
  .thinning_product_info_table {
    width: 80rem;
  }
}
@media screen and (max-width: 1024px) {
  .thinning_product_info_table_wrap {
    overflow: auto;
    width: 100%;
    padding-bottom: 2rem;
    margin-bottom: 6rem;
  }
}
.thinning_product_info_table_wrap::-webkit-scrollbar {
  width: 14px;
}
.thinning_product_info_table_wrap::-webkit-scrollbar-track {
  background-color: var(--force-col);
  border-radius: 3px;
}
.thinning_product_info_table_wrap::-webkit-scrollbar-thumb {
  border: 2px solid var(--secondary-col);
  background-color: var(--secondary-col);
  border-radius: 5px;
  box-shadow: none;
}
.thinning_product_info_table_head {
  display: grid;
  grid-template-columns: 20% 13% 11% 23% 10% auto;
  border-bottom: solid 1px var(--seven-col);
}
.thinning_product_info_table_head_th {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
  padding-bottom: 2.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.thinning_product_info_table_head_th:first-child {
  justify-content: flex-start;
}
.thinning_product_info_table_body {
  display: contents;
  position: relative;
  display: grid;
  grid-template-columns: 20% 13% 11% 23% 10% auto;
  grid-column: 1/2;
  align-items: center;
}
.thinning_product_info_table_body.bg_2 .thinning_product_info_table_body_td {
  background-color: rgba(217, 217, 217, 0.2);
}
.thinning_product_info_table_body:before {
  content: "";
  height: 1px;
  width: 100%;
  display: block;
  background-color: var(--force-col);
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
}
.thinning_product_info_table_body:after {
  content: "";
  height: 1px;
  width: 20%;
  display: block;
  background-color: var(--seven-col);
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  transition: all 0.3s ease;
}
.thinning_product_info_table_body.has_sub {
  grid-template-columns: 20% auto;
}
.thinning_product_info_table_body_sub_list {
  position: relative;
  display: grid;
  grid-template-columns: 16% 14% 29% 12% auto;
}
.thinning_product_info_table_body_sub_list:before {
  content: "";
  height: 1px;
  width: 100%;
  display: block;
  background-color: var(--force-col);
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
}
.thinning_product_info_table_body_th {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
  padding: 1.3rem 0;
}
.thinning_product_info_table_body_td {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  padding: 1.3rem 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.thinning_product_info_table_body_last {
  grid-column: 2;
  grid-row: 1/8;
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: solid 1px var(--force-col);
}
.thinning_product_info_table_body a {
  text-decoration: none;
}
.thinning_product_info_table_body a:after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 2;
  display: block;
}
.thinning_product_info_table_body a:before {
  content: "";
  height: 1px;
  width: 0%;
  display: block;
  background-color: var(--seven-col);
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  transition: all 0.5s ease;
}
.thinning_product_info_table_body a:hover:before {
  width: 100%;
}
.thinning_product_info_table_body .product-price {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
}
.thinning_product_info_table_body .product-no {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
}
.thinning_product_info_table_body .product-suki {
  justify-content: flex-start;
}
.thinning_product_info_img {
  text-align: center;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .thinning_product_info_img {
    max-width: 55vw;
  }
}
.thinning_product_info_img .swiper-pagination-bullets {
  position: absolute;
  bottom: 50px;
  left: 0;
  z-index: 1;
  text-align: left;
  padding: 0 5px;
}
.thinning_product_info_img .swiper-pagination-bullet {
  width: 4px;
  height: 4px;
  border-radius: 2px;
  background-color: #d2d2d2;
  margin: 0 4px;
  opacity: 0.5;
}
.thinning_product_info_img .swiper-pagination-bullet-active {
  background-color: #d2d2d2;
  opacity: 1;
}
.thinning_product_info_img figure {
  background-color: var(--base-col);
}
.thinning_product_info_img figure img {
  width: 100%;
  height: auto;
}
.thinning_product_info_img p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
  color: var(--seven-col);
  margin-top: 2.4rem;
}

.thinning_products {
  position: relative;
  z-index: 1;
  overflow: hidden;
}
.thinning_products_list {
  margin: 0 auto;
  position: relative;
  overflow: visible;
}
.thinning_products_list_wrap {
  position: relative;
  padding: 0 9.72vw;
}
@media screen and (max-width: 1024px) {
  .thinning_products_list_wrap {
    padding: 0;
  }
}
.thinning_products_list_item {
  padding: 0 0;
  width: 33%;
  max-width: 34rem;
}
.thinning_products_list_item_img {
  margin: 0;
}
.thinning_products_list_item_img figure {
  display: block;
  position: relative;
  padding-top: var(--figure-height);
  overflow: hidden;
  z-index: 1;
  padding-top: 118.75%;
}
.thinning_products_list_item_img figure img {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  object-fit: cover;
  transition: all 0.3s linear;
}
@media screen and (max-width: 1024px) {
  .thinning_products_list_item_img figure {
    padding-top: 64.4%;
    background-color: #FFF;
  }
  .thinning_products_list_item_img figure img {
    object-fit: contain;
  }
}
.thinning_products_list_item_img a:hover figure img {
  opacity: 0.7;
}
.thinning_products_list_item_img img {
  vertical-align: bottom;
}
.thinning_products_list_item_label {
  text-align: right;
  margin-bottom: 3rem;
}
.thinning_products_list_item_label p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 17px;
  background-color: var(--base-col);
  display: inline-block;
  padding: 0.3rem 0.8rem;
}
.thinning_products_list_item_content_title {
  display: flex;
  justify-content: space-between;
}
.thinning_products_list_item_content_title h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.7rem;
  letter-spacing: 0.1em;
  line-height: 20px;
  margin-bottom: 1.3rem;
}
.thinning_products_list_item_content_title p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.1rem;
  letter-spacing: 0.1em;
  line-height: 20px;
}
.thinning_products_list_item_content_detail {
  height: auto;
  min-height: 4.4rem;
  margin-bottom: 3.8rem;
}
.thinning_products_list_item_content_detail p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
}
.thinning_products_list_item_content_detail p span {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.1em;
  line-height: 22px;
}
.thinning_products_list_item_content_price dl {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 6px;
}
.thinning_products_list_item_content_price dl dt {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  line-height: 16px;
}
.thinning_products_list_item_content_price dl dt span {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.1em;
  line-height: 22px;
  margin-left: 1.5rem;
}
.thinning_products_list_item_content_price dl dt span.item_suki {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.1em;
  line-height: 16px;
  margin-left: 0rem;
}
.thinning_products_list_item_content_price dl dd {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 16px;
}
.thinning_products_list_item_content_price p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  margin-top: 1rem;
}
.thinning_products .swiper-button-prev {
  left: -40px;
  margin-top: -160px;
}
@media screen and (max-width: 1024px) {
  .thinning_products .swiper-button-prev {
    left: -20px;
  }
}
.thinning_products .swiper-button-prev svg {
  color: var(--seven-col);
}
.thinning_products .swiper-button-next {
  right: -40px;
  margin-top: -160px;
}
@media screen and (max-width: 1024px) {
  .thinning_products .swiper-button-next {
    right: -20px;
  }
}
.thinning_products .swiper-button-next svg {
  color: var(--seven-col);
}
.thinning_products .swiper-button-disabled {
  display: none;
}

/* modal */
.modal {
  --modal-overlay-opacity: 0.7;
  --modal-overlay-color: #000;
  align-items: center;
  display: flex;
  height: 100%;
  justify-content: center;
  left: 0;
  opacity: 0;
  overflow: hidden;
  pointer-events: none;
  position: fixed;
  top: 0;
  transition: all 0.2s ease 0.4s;
  visibility: hidden;
  width: 100%;
  z-index: -1;
}
.modal__close {
  align-items: center;
  border: 0;
  cursor: pointer;
  display: flex;
  height: 2.5rem;
  justify-content: center;
  line-height: 1;
  position: absolute;
  right: 3.8rem;
  top: 2.7rem;
  transition: 0.6s ease;
  width: 2.5rem;
  z-index: 9991;
  background: none;
  color: var(--seven-col);
  right: 2rem;
  top: 2rem;
}
.modal__body {
  align-items: center;
  bottom: 0;
  display: flex;
  height: 100%;
  justify-content: center;
  left: 50%;
  opacity: 0;
  overflow: auto;
  position: fixed;
  top: 50%;
  transform: translate3d(-50%, -50%, 0) scale(0.5);
  transition: transform 1s ease, opacity 0.4s ease;
  width: 100%;
  z-index: 991;
  max-width: 90rem;
}
.modal__body_inner {
  position: relative;
  width: 100%;
  max-width: 90rem;
}
@media screen and (max-width: 1024px) {
  .modal__body_inner {
    width: calc(100vw - 6.4rem);
    margin: 0 auto;
  }
}
.modal__body .video_wrap {
  width: 100%;
  max-width: 90rem;
}
.modal__body video {
  width: 100%;
}
.modal__mask {
  bottom: 0;
  left: 0;
  opacity: 0;
  position: fixed;
  right: 0;
  top: 0;
  transition: opacity 0.3s ease-out 0.3s, visibility 0.3s ease-out 0.3s, z-index 0.3s ease-out 0.3s;
  visibility: hidden;
  background-color: rgba(0, 0, 0, 0.8);
  backdrop-filter: blur(8px);
}
.modal.is-open {
  animation: fade-in 1s ease both;
  display: block;
  pointer-events: unset;
  transition: all 0.1s ease;
  visibility: visible;
  z-index: 100001;
  opacity: 1;
}
.modal.is-open .modal__mask {
  visibility: visible;
  z-index: 991;
  opacity: 1;
}
.modal.is-open > .modal__body {
  opacity: 1;
  transform: translate3d(-50%, -50%, 0) scale(1);
  transition: transform 0.3s ease 0.4s, opacity 0.4s ease 0.4s !important;
}

.material_info {
  background-color: var(--seventeen-col);
  display: flex;
  width: 100%;
  max-width: 90rem;
  height: 60rem;
  align-items: center;
}
@media screen and (max-width: 1024px) {
  .material_info {
    flex-direction: column;
    height: 90svh;
    overflow: auto;
    justify-content: center;
    grid-gap: 4rem;
  }
}
.material_info_title {
  width: 44%;
  padding: 2.5rem 4.6rem;
  padding-right: 0;
}
@media screen and (max-width: 1024px) {
  .material_info_title {
    width: 100%;
    padding: 0 2rem;
  }
}
.material_info_title h5 {
  font-family: var(--font-third);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  color: var(--black-col);
  margin-bottom: 1.5rem;
}
.material_info_title h4 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  color: rgba(0, 0, 0, 0.6);
  margin-bottom: 3rem;
}
.material_info_title h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.15em;
  color: var(--black-col);
  margin-bottom: 1.7rem;
}
.material_info_title h3 span {
  font-family: var(--font-third);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
}
.material_info_title p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
  line-height: 28px;
  max-width: 28.4rem;
  color: var(--black-col);
}
.material_info_title p span {
  color: rgba(0, 0, 0, 0.7);
}
.material_info_img {
  width: 60%;
  padding: 2.5rem 2.4rem;
  padding-right: 4.6rem;
}
@media screen and (max-width: 1024px) {
  .material_info_img {
    width: 100%;
    padding: 0 2rem;
  }
}
.material_info_img figure {
  text-align: center;
}
.material_info_img figure img {
  max-width: 100%;
  height: auto;
  margin: 0 auto;
}

.material_info_single {
  background-color: var(--seventeen-col);
  display: flex;
  width: 100%;
  max-width: 90rem;
  height: 60rem;
  align-items: center;
  justify-content: center;
}
.material_info_single .material_info_title {
  width: auto;
  padding: 2.5rem 4.6rem;
}
.material_info_single .material_info_title h4 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  color: var(--black-col);
  margin-bottom: 3rem;
}
.material_info_single .material_info_title h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.15em;
  color: var(--black-col);
  margin-bottom: 1.7rem;
}
.material_info_single .material_info_title h3 span {
  font-family: var(--font-third);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
}
.material_info_single .material_info_title p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
  line-height: 28px;
  max-width: 45rem;
  color: var(--black-col);
}
.material_info_single .material_info_title p span {
  color: rgba(0, 0, 0, 0.7);
}

/* quality */
@media screen and (min-width: 1025px) {
  .quality#quality_section_3 {
    padding-top: 15rem;
  }
}
@media screen and (min-width: 1025px) {
  .quality#quality_section_4 {
    padding-top: 15rem;
    margin-bottom: 30rem;
  }
}
.quality_inner {
  position: relative;
  top: 0;
}
@media screen and (min-width: 1025px) {
  .quality_inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
}
.quality_imgs {
  padding-top: 0;
}
@media screen and (min-width: 1025px) {
  .quality_imgs {
    position: sticky;
    height: 100vh;
    top: 0;
    left: 0;
    z-index: 11;
  }
}
@media screen and (min-width: 1025px) {
  .quality_img {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
  }
}
.quality_img.fade-image {
  transition: opacity 1s linear;
  opacity: 0;
}
@media screen and (max-width: 1024px) {
  .quality_img.fade-image {
    opacity: 1 !important;
  }
}
.quality_img figure {
  --figure-height: 100vw;
  display: block;
  position: relative;
  padding-top: var(--figure-height);
  overflow: hidden;
  z-index: 1;
}
.quality_img figure img {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  object-fit: cover;
  transition: all 0.3s linear;
}
@media screen and (min-width: 1025px) {
  .quality_img figure {
    --figure-height: calc(100vh - 0px);
  }
}
.quality_img_set {
  margin-left: -3.2rem;
  margin-right: -3.2rem;
}
.quality_content {
  position: relative;
  padding: 8rem 3.2rem;
}
@media screen and (min-width: 1025px) {
  .quality_content {
    padding-left: 8vw;
    padding-right: 9.72vw;
    padding-top: 50rem;
    padding-bottom: 11rem;
  }
}
.quality_content h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  margin-bottom: 1.1rem;
}
@media screen and (max-width: 1024px) {
  .quality_content h3 {
    margin-bottom: 4rem;
    font-size: 1.4rem;
  }
}
.quality_content h2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  margin-bottom: 6.5rem;
}
@media screen and (max-width: 1024px) {
  .quality_content h2 {
    margin-bottom: 4rem;
    font-size: 2rem;
  }
}
.quality_content p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 36px;
  margin-bottom: 13.7rem;
}
@media screen and (max-width: 1024px) {
  .quality_content p {
    margin-bottom: 4rem;
    font-size: 1.4rem;
  }
}
.quality_content_label {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  margin-bottom: 7rem;
}
@media screen and (max-width: 1024px) {
  .quality_content_label {
    font-size: 1.1rem !important;
  }
}
@media screen and (min-width: 1025px) {
  .quality_content_block {
    padding-bottom: 100px;
    min-height: 100vh;
  }
}
@media screen and (max-width: 1024px) {
  .quality_content_block {
    padding-bottom: 8rem;
  }
}
.quality_content figure {
  margin-bottom: 13.7rem;
}
@media screen and (max-width: 1024px) {
  .quality_content figure {
    margin-bottom: 8rem;
  }
}

.quality_about {
  background-color: var(--black-col);
  padding: 10rem 9.72vw;
  --txt-col: rgba(255, 255, 255, 0.5);
}
@media screen and (max-width: 1024px) {
  .quality_about {
    padding: 5rem 3.2rem;
  }
}
.quality_about_title {
  text-align: center;
  margin-bottom: 4.6rem;
}
.quality_about_title h2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  color: var(--txt-col);
}
.quality_about_title2 {
  text-align: center;
  margin-bottom: 10.6rem;
}
@media screen and (max-width: 1024px) {
  .quality_about_title2 {
    margin-bottom: 4.6rem;
  }
}
.quality_about_title2 h2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  color: var(--txt-col);
}
@media screen and (min-width: 1025px) {
  .quality_about_grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: 0;
    padding-bottom: 11rem;
    border-bottom: solid 1px rgba(150, 150, 150, 0.5);
    margin-bottom: 11rem;
  }
}
@media screen and (max-width: 1024px) {
  .quality_about_grid {
    display: flex;
    flex-direction: column-reverse;
    margin-bottom: 7rem;
  }
}
.quality_about_grid_item {
  position: relative;
  display: grid;
  grid-template-rows: auto auto auto;
}
@media screen and (min-width: 1025px) {
  .quality_about_grid_item:first-child {
    padding-right: 3rem;
  }
}
@media screen and (min-width: 1025px) {
  .quality_about_grid_item:not(:first-child) {
    padding-left: 3rem;
  }
}
@media screen and (min-width: 1025px) {
  .quality_about_grid_item:not(:first-child):before {
    content: "";
    width: 1px;
    height: 100%;
    display: block;
    background-color: rgba(150, 150, 150, 0.5);
    position: absolute;
    left: 0;
    top: 50px;
    bottom: 0;
    z-index: 1;
  }
}
.quality_about_grid_item figure {
  max-width: 100%;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .quality_about_grid_item figure {
    padding-top: 7rem;
  }
}
.quality_about_grid_item figure .svg_logo {
  position: absolute;
  left: 7rem;
  bottom: 5rem;
  z-index: 1;
  width: 5.5rem;
}
@media screen and (max-width: 1024px) {
  .quality_about_grid_item figure .svg_logo {
    left: 0rem;
    width: 4rem;
  }
}
.quality_about_grid_item figure svg {
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 1024px) {
  .quality_about_grid_item figure svg {
    transform: scale(1.2);
  }
}
.quality_about_grid_item_text {
  margin-bottom: 7rem;
  position: relative;
}
@media screen and (min-width: 1025px) {
  .quality_about_grid_item_text {
    padding: 0 0 0 3rem;
  }
}
.quality_about_grid_item_text p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 36px;
  color: var(--txt-col);
  line-height: 27px;
}
.quality_about_grid_item_text p + p {
  margin-top: 1.8rem;
}
.quality_about_grid_item_text h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.3rem;
  letter-spacing: 0.2em;
  line-height: 36px;
  color: var(--txt-col);
  margin-bottom: 1.7rem;
  display: inline-block;
  position: relative;
}
.quality_about_grid_item_text h3:after {
  content: "";
  width: 100%;
  height: 1px;
  background-color: rgba(255, 255, 255, 0.5);
  position: absolute;
  left: 0;
  right: 0;
  z-index: 1;
  bottom: -1px;
}
@media screen and (min-width: 1025px) {
  .quality_about_grid_bottom {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: 4rem;
    padding-left: 3rem;
  }
}
@media screen and (max-width: 1024px) {
  .quality_about_grid_bottom {
    border-bottom: solid 1px #969696;
  }
}
@media screen and (max-width: 1024px) {
  .quality_about_grid_bottom_item {
    text-align: center;
    margin-bottom: 7rem;
  }
}
@media screen and (max-width: 1024px) {
  .quality_about_grid_bottom_item img {
    width: 100%;
    max-width: 20rem;
  }
}
.quality_about_content {
  padding-bottom: 7rem;
  border-bottom: solid 1px rgba(150, 150, 150, 0.5);
  margin-bottom: 7rem;
}
@media screen and (min-width: 1025px) {
  .quality_about_content {
    display: grid;
    grid-template-columns: auto 50%;
    align-items: center;
    grid-gap: 7%;
  }
}
.quality_about_content_text {
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .quality_about_content_text {
    margin-bottom: 4rem;
  }
}
.quality_about_content_text p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 27px;
  color: var(--txt-col);
  margin-bottom: 4.7rem;
}
.quality_about_content_text h4 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  color: var(--txt-col);
  font-size: 2rem;
  margin-bottom: 1.1rem;
}
@media screen and (max-width: 1024px) {
  .quality_about_content_text h4 {
    font-size: 2rem;
  }
}
.quality_about_content_text svg {
  width: 3rem;
  height: 3rem;
  color: var(--txt-col);
  fill: none;
}
.quality_about_content_img p {
  font-family: var(--font-arial);
  font-weight: 600;
  font-size: 1rem;
  letter-spacing: 0.2em;
  color: var(--txt-col);
  margin-top: 1rem;
}
@media screen and (min-width: 1025px) {
  .quality_about_content_grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: 10vw;
  }
}
@media screen and (max-width: 1024px) {
  .quality_about_content_grid_item {
    display: flex;
    flex-direction: column-reverse;
  }
}
.quality_about_content_grid_item_img {
  margin-bottom: 5rem;
}
.quality_about_content_grid_item_img figure img {
  width: 100%;
  height: auto;
}
.quality_about_content_grid_item_img p {
  font-family: var(--font-arial);
  font-weight: 600;
  font-size: 1rem;
  letter-spacing: 0.2em;
  color: var(--txt-col);
  margin-top: 1rem;
}
.quality_about_content_grid_item_text {
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .quality_about_content_grid_item_text {
    margin-bottom: 2rem;
  }
}
.quality_about_content_grid_item_text p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.1rem;
  letter-spacing: 0.2em;
  line-height: 21px;
  color: var(--txt-col);
}
.quality_about_content_grid_item_text h4 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.3rem;
  letter-spacing: 0.2em;
  line-height: 27px;
  color: var(--txt-col);
  margin-bottom: 1.4rem;
}
.quality_about_content_grid_item_text svg {
  width: 2.6rem;
  height: 2.2rem;
  color: var(--txt-col);
  fill: none;
  margin-bottom: 1.4rem;
}
.quality_about_content2 {
  position: relative;
  padding-bottom: 7rem;
  border-bottom: solid 1px rgba(150, 150, 150, 0.5);
  margin-bottom: 7rem;
}
@media screen and (max-width: 1200px) {
  .quality_about_content2 {
    padding-bottom: 14rem;
  }
}
.quality_about_content2_img {
  max-width: 65rem;
  margin: 0 auto;
}
@media screen and (max-width: 1024px) {
  .quality_about_content2_img {
    margin-left: -3.2rem;
    margin-right: -3.2rem;
    margin-bottom: 7rem;
  }
}
@media screen and (min-width: 1025px) {
  .quality_about_content2_img figure {
    margin-left: -50px;
  }
}
@media screen and (min-width: 1025px) {
  .quality_about_content2_text1 {
    width: 33rem;
    position: absolute;
    left: 0;
    top: 9rem;
    z-index: 1;
  }
}
@media screen and (max-width: 1200px) {
  .quality_about_content2_text1 {
    top: 0rem;
  }
}
@media screen and (max-width: 1024px) {
  .quality_about_content2_text1 {
    margin-bottom: 6rem;
  }
}
.quality_about_content2_text1 h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  color: rgba(255, 255, 255, 0.5);
}
.quality_about_content2_text1 p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 27px;
  color: rgba(255, 255, 255, 0.5);
  text-align: justify;
}
@media screen and (min-width: 1025px) {
  .quality_about_content2_text2 {
    width: 35rem;
    position: absolute;
    right: 0rem;
    bottom: 6rem;
    z-index: 1;
  }
}
@media screen and (max-width: 1200px) {
  .quality_about_content2_text2 {
    bottom: 6rem;
  }
}
.quality_about_content2_text2 h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  color: rgba(255, 255, 255, 0.5);
}
.quality_about_content2_text2 p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 27px;
  color: rgba(255, 255, 255, 0.5);
  text-align: justify;
}
.quality_about_content3 {
  max-width: 99rem;
  margin-left: auto;
  margin-right: auto;
}

.quality_about_2 {
  background-color: var(--nine-col);
  padding: 14rem 15.62vw;
  --txt-col: rgba($color: #3A3A3A, $alpha: 0.5);
}
@media screen and (max-width: 1024px) {
  .quality_about_2 {
    padding: 12rem 3.2rem;
  }
}
.quality_about_2_inner {
  border-top: solid 1px rgba(58, 58, 58, 0.5);
  padding: 6rem 8rem;
}
@media screen and (max-width: 1024px) {
  .quality_about_2_inner {
    padding: 6rem 0;
  }
}
.quality_about_2_inner:last-child {
  border-bottom: solid 1px rgba(58, 58, 58, 0.5);
}
.quality_about_2_title {
  text-align: center;
  margin-bottom: 10rem;
}
.quality_about_2_title h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  color: var(--txt-col);
  margin-bottom: 2.4rem;
}
.quality_about_2_title p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 27px;
  color: var(--txt-col);
}
.quality_about_2_grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-gap: 7rem;
  margin-bottom: 6.7rem;
}
@media screen and (max-width: 1024px) {
  .quality_about_2_grid {
    grid-template-columns: 1fr;
  }
}
.quality_about_2_grid_item {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 29rem auto;
}
.quality_about_2_grid_item figure {
  max-width: 100%;
  padding-bottom: 2rem;
}
@media screen and (min-width: 1025px) {
  .quality_about_2_grid_item figure {
    padding-bottom: 6rem;
  }
}
.quality_about_2_grid_item figure img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.quality_about_2_grid_item_label {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  color: rgba(0, 0, 0, 0.6);
  opacity: 0.5;
  margin-bottom: 3rem;
}
.quality_about_2_grid_item h4 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.15em;
  color: rgba(0, 0, 0, 0.5);
  margin-bottom: 2rem;
}
.quality_about_2_grid_item_txt {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
  line-height: 28px;
  color: rgba(0, 0, 0, 0.5);
}
.quality_about_2_caption {
  text-align: center;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.12em;
  line-height: 26px;
  --txt-col: rgba($color: #3A3A3A, $alpha: 0.8);
  color: var(--txt-col);
}
.quality_about_2_bottom {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: flex-start;
  padding: 1.5rem 0;
}
@media screen and (max-width: 1024px) {
  .quality_about_2_bottom {
    grid-template-columns: 1fr;
  }
}
.quality_about_2_bottom_title h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  color: var(--txt-col);
  margin-bottom: 3rem;
  opacity: 0.5;
}
.quality_about_2_bottom_title p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 27px;
  color: var(--txt-col);
  opacity: 0.5;
}
.quality_about_2_bottom_text p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
  line-height: 28px;
  color: rgba(0, 0, 0, 0.5);
}

.company {
  width: 100%;
}
.company#company1 {
  margin-top: calc(var(--header-height) * 2);
}
.company#company2 {
  margin-top: 17rem;
  padding-bottom: 14rem;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .company#company2 {
    margin-top: 10rem;
  }
}
.company > #company4 {
  padding-top: 12rem;
  padding-bottom: 12rem;
}
.company > #company6 {
  padding-top: 9rem;
  padding-bottom: 12rem;
}
@media screen and (max-width: 1024px) {
  .company > #company6 {
    padding-top: 4rem;
  }
}
.company_ttl {
  padding: 7rem 0 0;
  text-align: center;
  margin-bottom: 14rem;
}
@media screen and (max-width: 1024px) {
  .company_ttl {
    padding: 0;
  }
}
.company_ttl h1 {
  text-align: center;
  margin-bottom: 4.5rem;
}
@media screen and (max-width: 1024px) {
  .company_ttl h1 {
    margin-bottom: 3.5rem;
  }
}
.company_ttl h1 img {
  max-width: 8.2rem;
}
@media screen and (max-width: 1024px) {
  .company_ttl h1 img {
    max-width: 6.2rem;
  }
}
.company_ttl h2 {
  font-family: var(--font-arial);
  font-weight: 600;
  font-size: 1.8rem;
  letter-spacing: 0.23em;
  margin-bottom: 0.7rem;
}
@media screen and (max-width: 1024px) {
  .company_ttl h2 {
    font-size: 1.35rem;
  }
}
.company_ttl p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.2rem;
  letter-spacing: 0.16em;
  line-height: 21px;
}
@media screen and (max-width: 1024px) {
  .company_ttl p {
    font-size: 0.9rem;
    line-height: 1.5;
  }
}
.company_info {
  padding: 0 9.72vw;
  display: grid;
  grid-template-columns: 25vw auto;
}
@media screen and (max-width: 1024px) {
  .company_info {
    display: block;
    padding: 0 3.2rem;
  }
}
.company_info_history_wrap {
  height: 340px;
  overflow: hidden;
  position: relative;
}
.company_info_more {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 14rem;
  z-index: 2;
  background: #FAFAFA;
  background: linear-gradient(0deg, rgb(250, 250, 250) 0%, rgba(255, 255, 255, 0) 100%);
  height: 10rem;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.company_info_more a {
  display: block;
  width: 100%;
  text-align: center;
  text-decoration: none;
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.5rem;
  letter-spacing: 0.1em;
  line-height: 20px;
  color: var(--fifteen-col);
  margin-bottom: -4rem;
}
@media screen and (max-width: 1024px) {
  .company_info_title {
    text-align: center;
    margin-bottom: 4rem;
  }
}
.company_info_title h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  color: var(--black-col);
}
.company_info_table table tbody tr:first-child th {
  border-top: solid 1px var(--secondary-col);
}
.company_info_table table tbody tr:first-child td {
  border-top: solid 1px rgba(58, 58, 58, 0.3);
}
.company_info_table table tbody tr th {
  padding: 2.6rem 0;
  text-align: center;
  width: 17rem;
  border-bottom: solid 1px var(--secondary-col);
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
  vertical-align: top;
  line-height: 28px;
}
@media screen and (max-width: 1024px) {
  .company_info_table table tbody tr th {
    padding: 2.4rem 0;
    font-size: 1.2rem;
    width: 7rem;
    line-height: 1.4;
  }
}
.company_info_table table tbody tr td {
  padding: 2.6rem 5rem;
  text-align: left;
  border-bottom: solid 1px rgba(58, 58, 58, 0.3);
  vertical-align: top;
}
@media screen and (max-width: 1024px) {
  .company_info_table table tbody tr td {
    padding: 2.4rem 1.5rem;
  }
}
.company_info_table table tbody tr td p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
}
@media screen and (max-width: 1024px) {
  .company_info_table table tbody tr td p {
    font-size: 1.3rem;
    line-height: 1.4;
  }
}
@media screen and (max-width: 1024px) {
  .company_info_table table tbody tr td p span {
    display: block;
  }
}
@media screen and (min-width: 1025px) {
  .company_info_table table tbody tr td dl {
    display: grid;
    grid-template-columns: 10rem auto;
  }
}
.company_info_table table tbody tr td dl + dl {
  margin-top: 2.6rem;
}
.company_info_table table tbody tr td dl dt {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
}
@media screen and (max-width: 1024px) {
  .company_info_table table tbody tr td dl dt {
    margin-bottom: 2rem;
    font-size: 1.3rem;
  }
}
.company_info_table table tbody tr td dl dd {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
}
@media screen and (max-width: 1024px) {
  .company_info_table table tbody tr td dl dd {
    font-size: 1.3rem;
  }
}
.company_info_history {
  position: relative;
  padding: 2.6rem 0;
}
.company_info_history:before {
  content: "";
  width: 1px;
  height: 100%;
  display: block;
  background-color: var(--secondary-col);
  position: absolute;
  left: 17rem;
  top: 0;
  bottom: 0;
  z-index: 1;
}
@media screen and (max-width: 1024px) {
  .company_info_history:before {
    left: 6rem;
  }
}
.company_info_history dl {
  display: grid;
  grid-template-columns: 17rem auto;
  line-height: 3.6rem;
}
@media screen and (max-width: 1024px) {
  .company_info_history dl {
    grid-template-columns: 6rem auto;
  }
}
.company_info_history dl dt {
  text-align: center;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  line-height: 2.6rem;
  padding: 0.5rem 0;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .company_info_history dl dt {
    font-size: 1.1rem;
    line-height: 1.9;
    letter-spacing: 0;
  }
}
.company_info_history dl dt:after {
  content: "";
  width: 5px;
  height: 5px;
  display: block;
  border-radius: 50%;
  background-color: var(--secondary-col);
  position: absolute;
  right: -3px;
  top: 1.5rem;
  z-index: 1;
}
.company_info_history dl dd {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 2.6rem;
  padding: 0.5rem 0;
  padding-left: 2.8rem;
}
@media screen and (max-width: 1024px) {
  .company_info_history dl dd {
    font-size: 1.1rem;
    line-height: 1.9;
    padding-left: 2rem;
    letter-spacing: 0;
  }
}
.company_info_history dl dd span {
  font-size: 1.1rem;
  margin-top: -1rem;
}
.company_info_history dl dd a {
  text-decoration: none;
}
.company_info_history dl dd.font-12 {
  line-height: 22px;
}
.company.is_open .company_info_more {
  display: none;
}
.company_map {
  background-color: var(--nine-col);
}
.company_map_inner {
  padding: 7rem 9.72vw 17rem;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .company_map_inner {
    padding: 3.5rem 3.2rem;
  }
}
.company_map_title {
  margin-bottom: 10rem;
}
@media screen and (max-width: 1024px) {
  .company_map_title {
    margin-bottom: 1rem;
  }
}
.company_map_title h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  color: var(--black-col);
}
@media screen and (max-width: 1024px) {
  .company_map_title h3 {
    font-size: 1.1rem;
  }
}
.company_map_japan {
  position: relative;
}
@media screen and (min-width: 1025px) {
  .company_map_japan {
    padding-left: 7vw;
    padding-right: 7vw;
  }
}
@media screen and (max-width: 1024px) {
  .company_map_japan {
    margin-left: -2.4rem;
    margin-right: -2.4rem;
  }
}
.company_map_ww {
  position: relative;
}
@media screen and (min-width: 1025px) {
  .company_map_ww {
    padding-left: 7vw;
    padding-right: 7vw;
  }
}
@media screen and (max-width: 1024px) {
  .company_map_ww {
    margin-left: -2.4rem;
    margin-right: -2.4rem;
  }
}
.company_map_type {
  position: absolute;
  left: 0;
  right: 0;
  z-index: 1;
}
@media screen and (max-width: 1024px) {
  .company_map_type {
    left: 2.4rem;
    right: auto;
  }
}
.company_map_type p {
  font-size: 1.2rem;
  color: var(--black-col);
  padding-left: 2rem;
  position: relative;
  line-height: 28px;
  --bg-col: var(--red2-col);
  --border-col: var(--red2-col);
}
@media screen and (max-width: 1024px) {
  .company_map_type p {
    font-size: 0.9rem;
    line-height: 2;
    padding-left: 1rem;
  }
}
.company_map_type p:before {
  content: "";
  width: 10px;
  height: 10px;
  display: block;
  border-radius: 50%;
  background-color: var(--bg-col);
  border: solid 1px var(--border-col);
  position: absolute;
  left: 0;
  top: 50%;
  z-index: 1;
  margin-top: -5px;
}
@media screen and (max-width: 1024px) {
  .company_map_type p:before {
    width: 4.7px;
    height: 4.7px;
  }
}
.company_map_type p.type1 {
  --bg-col: var(--red2-col);
  --border-col: var(--red2-col);
}
.company_map_type p.type2 {
  --bg-col: var(--base-col);
  --border-col: var(--red2-col);
}
.company_map_type p.type3 {
  --bg-col: var(--fourteen-col);
  --border-col: var(--fourteen-col);
}
@media screen and (max-width: 1024px) {
  .company_map_link {
    display: none;
  }
}
.company_map_link_item {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 1;
  display: block;
  font-size: 13px;
  letter-spacing: 0.16em;
  white-space: nowrap;
  transition: all 1.1s ease;
}
.company_map_link_item a {
  display: block;
  opacity: 0;
}
.company_map_link_item_1 {
  margin-top: -24.1%;
  margin-left: -12%;
  width: 15.5%;
  height: 2.5%;
}
.company_map_link_item_2 {
  margin-top: -21.5%;
  margin-left: -12%;
  width: 7.5%;
  height: 2.5%;
}
.company_map_link_item_3 {
  margin-top: -11.7%;
  margin-left: -12%;
  width: 11.5%;
  height: 2.5%;
}
.company_map_link_item_4 {
  margin-top: -9.2%;
  margin-left: -12%;
  width: 14.5%;
  height: 2.5%;
}
.company_map_link_item_5 {
  margin-top: -6.7%;
  margin-left: -12%;
  width: 5.5%;
  height: 2.5%;
}
.company_map_link_item_6 {
  margin-top: 2%;
  margin-left: 24.2%;
  width: 15.5%;
  height: 2.5%;
}
.company_map_link_item_7 {
  margin-top: 6%;
  margin-left: 24.2%;
  font-size: 17px;
  width: 6.5%;
  height: 2.5%;
}
.company_map_link_item_8 {
  margin-top: 9.2%;
  margin-left: 24.2%;
  width: 5.5%;
  height: 2.5%;
}
.company_map_link_item_9 {
  margin-top: 11.8%;
  margin-left: 24.2%;
  width: 14.5%;
  height: 2.5%;
}
.company_map_link_item_10 {
  margin-top: 16.2%;
  margin-left: 24.2%;
  width: 17.5%;
  height: 2.5%;
}
.company_map_link_item_11 {
  margin-top: 25.5%;
  margin-left: -1%;
  width: 15.5%;
  height: 2.5%;
}
.company_map_link_item_12 {
  margin-top: 25.5%;
  margin-left: -14%;
  width: 7.5%;
  height: 2.5%;
}
.company_map_link_item_13 {
  margin-top: -12.3%;
  margin-left: -38.5%;
  width: 14.5%;
  height: 2.5%;
}
.company_map_link_item_14 {
  margin-top: 15.3%;
  margin-left: -3%;
  width: 8.5%;
  height: 2.5%;
}
.company_map_link_item_15 {
  margin-top: -0.2%;
  margin-left: -13.5%;
  width: 4.5%;
  height: 2.5%;
}
.company_map_link_item_16 {
  margin-top: -5.2%;
  margin-left: -33.5%;
  width: 5.5%;
  height: 2.5%;
}
.company_map_link_item_17 {
  margin-top: -1.9%;
  margin-left: -29.5%;
  width: 5.5%;
  height: 2.5%;
}
.company_map_link_item_18 {
  margin-top: 1.9%;
  margin-left: -18%;
  width: 8%;
  height: 2.5%;
}
.company_map_link_item_19 {
  margin-top: 10.9%;
  margin-left: -23.5%;
  width: 7.5%;
  height: 2.5%;
}
.company_map_link_item_20 {
  margin-top: -1.1%;
  margin-left: 20%;
  width: 9.5%;
  height: 2.5%;
}
.company_map_link_item_21 {
  margin-top: -3.2%;
  margin-left: -9%;
  width: 4.5%;
  height: 2.5%;
}
.company_map_link_item_22 {
  margin-top: 8%;
  margin-left: -22.8%;
  width: 7%;
  height: 2.5%;
}
.company_map_link_item_23 {
  margin-top: 16.6%;
  margin-left: 4.6%;
  width: 9.5%;
  height: 2.5%;
}
.company_map_link_item_24 {
  margin-top: -7.8%;
  margin-left: -26%;
  width: 4.5%;
  height: 2.5%;
}
.company_map_link_item_25 {
  margin-top: 9.5%;
  margin-left: -23.2%;
  width: 7.5%;
  height: 2.5%;
}
.company_map_link_item_26 {
  margin-top: 12.1%;
  margin-left: -28.5%;
  width: 9.5%;
  height: 2.5%;
}
.company_map_link_item_27 {
  margin-top: 2.5%;
  margin-left: -6.4%;
  width: 5.5%;
  height: 2.5%;
}
.company_map_link_item_28 {
  margin-top: -11.2%;
  margin-left: -36.4%;
  width: 5.5%;
  height: 2.5%;
}
.company_map_link_item_29 {
  margin-top: -9.5%;
  margin-left: -31.6%;
  width: 5%;
  height: 2.5%;
}
.company_map_link_item_30 {
  margin-top: -6.8%;
  margin-left: -37.8%;
  width: 9%;
  height: 2.5%;
}
.company_map_link_item_31 {
  margin-top: -4.8%;
  margin-left: -29.8%;
  width: 5.5%;
  height: 2.5%;
}
.company_map_link_item_32 {
  margin-top: -3.3%;
  margin-left: -29%;
  width: 6.5%;
  height: 2.5%;
}
.company_map_link_item_33 {
  margin-top: 4.2%;
  margin-left: -19.6%;
  width: 6.5%;
  height: 2.5%;
}
.company_map_link_item_34 {
  margin-top: 4.5%;
  margin-left: -6.4%;
  width: 8%;
  height: 2.5%;
}
.company_base {
  padding: 0 9.72vw;
}
@media screen and (max-width: 1024px) {
  .company_base {
    padding: 0 3.2rem;
  }
}
.company_base_japan {
  display: grid;
  grid-template-columns: 24.8vw auto;
}
@media screen and (max-width: 1024px) {
  .company_base_japan {
    grid-template-columns: 1fr;
  }
}
.company_base_japan + .company_base_japan {
  border-top: solid 1px rgba(58, 58, 58, 0.3);
  padding-top: 7rem;
  margin-top: 9rem;
}
@media screen and (max-width: 1024px) {
  .company_base_japan + .company_base_japan {
    padding-top: 4rem;
    margin-top: 4rem;
  }
}
.company_base_japan_title h4 {
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1.8rem;
  letter-spacing: 0.18em;
  line-height: 44px;
}
.company_base_japan_list_item {
  padding: 1.8rem 0;
  border-bottom: solid 1px rgba(58, 58, 58, 0.15);
}
@media screen and (min-width: 1025px) {
  .company_base_japan_list_item {
    display: grid;
    grid-template-columns: 22.2vw auto;
    align-items: center;
  }
}
.company_base_japan_list_item:last-child {
  border-bottom: none;
}
.company_base_japan_list_item#company_base_japan_1 {
  padding-bottom: 5rem;
  border-bottom: solid 1px rgba(58, 58, 58, 0.5);
}
@media screen and (min-width: 1025px) {
  .company_base_japan_list_item#company_base_japan_1 {
    grid-template-columns: 12vw auto;
    align-items: flex-start;
  }
}
.company_base_japan_list_item_title h4 {
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
  line-height: 22px;
}
.company_base_japan_list_item_info p {
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
  line-height: 22px;
}
@media screen and (max-width: 1024px) {
  .company_base_japan_list_item_info p {
    font-size: 1.2rem;
  }
}
.company_base_japan_list_item_info p a {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  text-decoration: none;
}
@media screen and (max-width: 1024px) {
  .company_base_japan_list_item_info p a {
    font-size: 1.2rem;
  }
}
.company_base_japan_list_item_info_map {
  margin: 3.5rem 0 1.5rem;
  border-bottom: solid 1px rgba(58, 58, 58, 0.15);
  padding-bottom: 1.5rem;
}
.company_base_japan_list_item_info_map_head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
}
.company_base_japan_list_item_info_map_head:hover {
  opacity: 0.8;
}
.company_base_japan_list_item_info_map_head_1 p {
  font-family: var(--font-arial);
  font-weight: 600;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
  line-height: 22px;
}
.company_base_japan_list_item_info_map_head_2 {
  display: flex;
  align-items: center;
}
.company_base_japan_list_item_info_map_head_2 p {
  font-weight: 600;
  font-size: 1rem;
  letter-spacing: 0.18em;
  line-height: 22px;
}
.company_base_japan_list_item_info_map_head_2 .icon-plus {
  width: 16px;
  height: 16px;
  margin-left: 2rem;
}
.company_base_japan_list_item_info_map_head_2 .icon-minus {
  display: none;
  width: 16px;
  height: 16px;
  margin-left: 2rem;
}
.company_base_japan_list_item_info_map_body {
  height: 0;
  overflow: hidden;
}
.company_base_japan_list_item_info_map_body figure {
  margin-bottom: 3.5rem;
  margin-top: 1.5rem;
}
.company_base_japan_list_item_info_map.is_open .company_base_japan_list_item_info_map_head_2 .icon-plus {
  display: none;
}
.company_base_japan_list_item_info_map.is_open .company_base_japan_list_item_info_map_head_2 .icon-minus {
  display: block;
}
.company_base_japan_list_item_info_map.is_open .company_base_japan_list_item_info_map_body {
  height: auto;
}
.company_base_japan_list_item_info_addr {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  border-bottom: solid 1px rgba(58, 58, 58, 0.15);
  padding-bottom: 1.5rem;
}
.company_base_japan_list_item_info_addr_left a {
  text-decoration: none;
  font-family: var(--font-arial);
  font-weight: 600;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
  line-height: 22px;
  color: var(--txt-col);
}
.company_base_japan_list_item_info_addr_right {
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  grid-gap: 2.3rem;
  margin-bottom: 2rem;
}
.company_base_japan_list_item_info_addr_right p {
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1.2rem;
  letter-spacing: 0.18em;
  line-height: 22px;
}
@media screen and (min-width: 1025px) {
  .company_base_ww {
    display: grid;
    grid-template-columns: 24.8vw auto;
  }
}
.company_base_ww_title h4 {
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
  line-height: 38px;
}
.company_base_ww_list_item {
  padding: 1.8rem 0;
  border-bottom: solid 1px rgba(58, 58, 58, 0.15);
}
@media screen and (min-width: 1025px) {
  .company_base_ww_list_item {
    display: grid;
    grid-template-columns: 13vw 10vw auto;
    align-items: flex-start;
  }
}
.company_base_ww_list_item_title h4 {
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
  line-height: 36px;
}
.company_base_ww_list_item_subtitle p {
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1.2rem;
  letter-spacing: 0.18em;
  color: rgba(58, 58, 58, 0.5);
  line-height: 36px;
}
.company_base_ww_list_item_info {
  text-align: left;
}
.company_base_ww_list_item_info p {
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
  line-height: 36px;
  word-break: break-all;
}
@media screen and (max-width: 1024px) {
  .company_base_ww_list_item_info p {
    font-size: 1.1rem;
  }
}
.company_base_ww_list_item_info p a {
  font-weight: 600;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
  text-decoration: underline;
  text-underline-offset: 4px;
}
@media screen and (max-width: 1024px) {
  .company_base_ww_list_item_info p a {
    font-size: 1.1rem;
  }
}
.company_base_ww_list_item_info p svg {
  margin-right: 1rem;
}
.company_base_ww_list_item_sub {
  grid-column: 2/4;
}
.company_base_ww_list_item_sub_item {
  display: grid;
  grid-template-columns: 10vw auto;
  align-items: flex-start;
}
@media screen and (max-width: 1024px) {
  .company_base_ww_list_item_sub_item {
    grid-template-columns: 1fr;
  }
}
.company_base_ww_list_item_sub_item + .company_base_ww_list_item_sub_item {
  border-top: solid 1px rgba(58, 58, 58, 0.15);
  padding-top: 1.8rem;
  margin-top: 1.8rem;
}
.company_plan {
  padding: 14rem 9.72vw;
  background-color: var(--nine-col);
}
@media screen and (min-width: 1025px) {
  .company_plan {
    display: grid;
    grid-template-columns: 25vw auto;
  }
}
@media screen and (max-width: 1024px) {
  .company_plan {
    padding: 7rem 3.2rem;
  }
}
@media screen and (max-width: 1024px) {
  .company_plan_title {
    margin-bottom: 4rem;
  }
}
.company_plan_title h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
}
.company_plan_list {
  position: relative;
}
.company_plan_list_item:not(:last-child) {
  padding-bottom: 3.6rem;
  border-bottom: solid 1px rgba(58, 58, 58, 0.3);
}
.company_plan_list_item + .company_plan_list_item {
  padding-top: 3.6rem;
}
.company_plan_list_item p {
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1.3rem;
  letter-spacing: 0.18em;
  line-height: 22px;
}
.company_plan_list_item dl {
  line-height: 3.6rem;
}
@media screen and (min-width: 1025px) {
  .company_plan_list_item dl {
    display: grid;
    grid-template-columns: 22.2rem auto;
  }
}
.company_plan_list_item dl + dl {
  margin-top: 3.6rem;
}
.company_plan_list_item dl dt {
  text-align: left;
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
  line-height: 2.2rem;
  position: relative;
}
.company_plan_list_item dl dd {
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
  line-height: 2.2rem;
}
.company_plan_list_item dl dd ul li {
  font-size: 1.3rem;
  position: relative;
  padding-left: 1em;
}
.company_plan_list_item dl dd ul li:before {
  content: "・";
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
}
.company_plan_list_item dl dd span {
  font-size: 1.1rem;
  display: block;
  margin-top: -1rem;
}
.company_plan_list_item dl dd.font-12 {
  line-height: 22px;
}

.product_option {
  padding: 0 0 20rem;
}
@media screen and (max-width: 1024px) {
  .product_option {
    padding: 0;
  }
}
.product_option_caption {
  max-width: 63rem;
  margin-right: 0;
}
.product_option_caption p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 36px;
  margin-bottom: 6.2rem;
}
@media screen and (max-width: 1024px) {
  .product_option_caption p {
    font-size: 1.4rem;
  }
}
.product_option_title {
  margin-top: 7rem;
  max-width: 63rem;
  margin-right: 0;
  margin-bottom: 4rem;
}
.product_option_title h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  margin-bottom: 2rem;
}
@media screen and (max-width: 1024px) {
  .product_option_title h4 {
    font-size: 1.2rem;
  }
}
.product_option_title h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
}
@media screen and (max-width: 1024px) {
  .product_option_title h3 {
    font-size: 2rem;
  }
}
.product_option_title_main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 45rem;
  margin-bottom: 4rem;
}
.product_option_title_main h3 span {
  font-size: 1.5rem;
  color: rgba(58, 58, 58, 0.7);
}
.product_option_title_tag {
  display: flex;
  grid-gap: 1.4rem;
}
.product_option_title_tag span {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.2rem;
  letter-spacing: 0.05em;
  line-height: 22px;
  border: solid 1px var(--secondary-col);
  padding: 4px 21px;
}
@media screen and (max-width: 1024px) {
  .product_option_title_tag span {
    font-size: 1.1rem;
    padding: 0px 13px;
  }
}
.product_option_title p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 36px;
}
@media screen and (max-width: 1024px) {
  .product_option_title p {
    font-size: 1.4rem;
  }
}
.product_option_title2 {
  margin-top: 7rem;
  margin-right: 0;
  margin-bottom: 4rem;
}
.product_option_title2 h4 {
  font-size: 1.2rem;
  margin-bottom: 2rem;
}
.product_option_title2 h3 {
  font-size: 1.9rem;
  font-weight: 500;
}
.product_option_title2 .product_option_title_main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 100%;
  margin-bottom: 4rem;
}
.product_option_title2 .product_option_title_main h3 span {
  font-size: 1.5rem;
  color: rgba(58, 58, 58, 0.7);
}
.product_option_title2 + .product_option_detail {
  grid-template-columns: 36vw auto;
}
.product_option_list {
  margin-bottom: 4.8rem;
}
.product_option_list_wrap > p {
  text-align: center;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 38px;
  margin-bottom: 4.8rem;
}
.product_option_list table thead th {
  padding: 1.2rem 0;
  border-bottom: solid 1px var(--secondary-col);
}
.product_option_list table thead td {
  padding: 0.8rem 0 1.2rem 0;
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.2rem;
  letter-spacing: 0.05em;
  line-height: 22px;
  text-align: center;
  border-bottom: solid 1px rgba(58, 58, 58, 0.3);
}
.product_option_list table thead td.option_status {
  background-color: var(--force-col);
}
.product_option_list table thead td.option_status + .option_status {
  border-left: solid 1px rgba(58, 58, 58, 0.3);
}
.product_option_list table tbody tr:first-child th {
  border-top: solid 1px var(--secondary-col);
}
.product_option_list table tbody tr:first-child td {
  border-top: solid 1px rgba(58, 58, 58, 0.3);
}
.product_option_list table tbody tr th {
  padding: 2.6rem 0;
  text-align: center;
  width: 17rem;
  border-bottom: solid 1px var(--secondary-col);
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
  vertical-align: middle;
  line-height: 28px;
}
.product_option_list table tbody tr th.option_name {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
  width: 19%;
}
.product_option_list table tbody tr td {
  padding: 2.6rem 1.7rem;
  text-align: left;
  border-bottom: solid 1px rgba(58, 58, 58, 0.3);
  vertical-align: middle;
}
.product_option_list table tbody tr td.option_comment {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
  width: auto;
}
.product_option_list table tbody tr td.option_cap {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.05em;
  line-height: 22px;
  width: 15%;
}
.product_option_list table tbody tr td.option_price {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 22px;
  width: 15%;
  text-align: right;
  padding-right: 4rem;
}
.product_option_list table tbody tr td.option_status {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  background-color: rgba(233, 233, 233, 0.5);
  width: 8%;
  text-align: center;
}
.product_option_list table tbody tr td.option_status + .option_status {
  border-left: solid 1px rgba(58, 58, 58, 0.3);
}
.product_option_btn {
  position: relative;
  padding-top: 4.8rem;
}
.product_option_btn:after {
  content: "";
  width: 1.3rem;
  height: 1px;
  display: block;
  background-color: rgba(58, 58, 58, 0.3);
  position: absolute;
  left: 50%;
  top: 0;
  z-index: 1;
  margin-left: -0.65rem;
}
.product_option_btn p {
  text-align: center;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 48px;
  margin-bottom: 1.3rem;
}
.product_option_btn .btn-area {
  text-align: center;
}
.product_option_item {
  margin-top: 13rem;
}
@media screen and (max-width: 1024px) {
  .product_option_item {
    margin-top: 7rem;
  }
}
.product_option_item + .product_option_item {
  border-top: solid 1px var(--sixteen-col);
  margin-top: 98px;
}
@media screen and (min-width: 1025px) {
  .product_option_detail {
    display: grid;
    grid-template-columns: 31.5vw auto;
    grid-gap: 8.8vw;
    padding-bottom: 6rem;
  }
}
.product_option_detail_info_price {
  border: solid 1px var(--force-col);
  padding: 2.7rem;
}
.product_option_detail_info_price dl {
  max-width: 44rem;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}
.product_option_detail_info_price dl dt {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.05em;
  line-height: 22px;
}
.product_option_detail_info_price dl dd {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
}
.product_option_detail_info_price + .product_option_detail_info_price {
  margin-top: 2.2rem;
}
.product_option_detail_info_table {
  background-color: var(--third-col);
}
.product_option_detail_info_table_wrap {
  margin-top: 14rem;
}
@media screen and (max-width: 1024px) {
  .product_option_detail_info_table_wrap {
    margin-top: 4rem;
  }
}
.product_option_detail_info_table_head {
  border-top: solid 1px var(--secondary-col);
  border-bottom: dashed 1px rgba(58, 58, 58, 0.7);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (min-width: 1025px) {
  .product_option_detail_info_table_head {
    height: 4rem;
  }
}
@media screen and (max-width: 1024px) {
  .product_option_detail_info_table_head {
    display: grid;
    grid-template-columns: 8rem auto;
    justify-content: flex-start;
    align-items: normal;
  }
}
.product_option_detail_info_table_label {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--secondary-col);
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
  color: var(--third-col);
  width: 10.7rem;
}
@media screen and (min-width: 1025px) {
  .product_option_detail_info_table_label {
    height: 4rem;
  }
}
@media screen and (max-width: 1024px) {
  .product_option_detail_info_table_label {
    width: 8rem;
    grid-row: 1/3;
  }
}
.product_option_detail_info_table_txt {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
}
@media screen and (min-width: 1025px) {
  .product_option_detail_info_table_txt {
    display: flex;
    align-items: center;
    grid-gap: 2rem;
  }
}
@media screen and (max-width: 1024px) {
  .product_option_detail_info_table_txt {
    padding: 8px 0 8px 1.5rem;
    grid-column: 2;
  }
}
.product_option_detail_info_table_sub {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.3rem;
  letter-spacing: 0.08em;
  line-height: 24px;
}
@media screen and (max-width: 1024px) {
  .product_option_detail_info_table_sub {
    display: block;
    line-height: 1;
    padding: 8px 0 0 1.5rem;
    color: rgba(58, 58, 58, 0.7);
  }
}
.product_option_detail_info_table_body {
  padding: 2.3rem 10rem 2.7rem 14.8rem;
}
@media screen and (max-width: 1024px) {
  .product_option_detail_info_table_body {
    padding: 2.3rem 3rem;
  }
}
.product_option_detail_info_table_body dl {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  grid-gap: 3.5rem;
}
.product_option_detail_info_table_body dl dt {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.08em;
  line-height: 24px;
  color: rgba(58, 58, 58, 0.7);
}
.product_option_detail_info_table_body dl dd {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  line-height: 28px;
  color: rgba(58, 58, 58, 0.7);
}
.product_option_detail_info_table_body dl dd .line1 {
  display: inline-block;
  text-align: center;
  position: relative;
  margin-right: 3px;
  width: 15px;
  color: rgba(58, 58, 58, 0.7);
}
.product_option_detail_info_table_body dl dd .line1:after {
  content: "";
  width: 100%;
  height: 1px;
  background-color: rgba(58, 58, 58, 0.7);
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
}
.product_option_detail_info_table_body dl dd .line2 {
  display: inline-block;
  text-align: center;
  position: relative;
  margin-right: 4px;
  width: 33px;
  color: rgba(58, 58, 58, 0.7);
}
.product_option_detail_info_table_body dl dd .line2:after {
  content: "";
  width: 100%;
  height: 1px;
  background-color: rgba(58, 58, 58, 0.7);
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
}
.product_option_detail_info_table_body dl dd .line3 {
  display: inline-block;
  text-align: center;
  position: relative;
  width: 41px;
  color: rgba(58, 58, 58, 0.7);
}
.product_option_detail_info_table_body dl dd .line3:after {
  content: "";
  width: 100%;
  height: 1px;
  background-color: rgba(58, 58, 58, 0.7);
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
}
.product_option_detail_info_table_body dl dd .line1s {
  display: inline-block;
  text-align: center;
  position: relative;
  margin-right: 3px;
  width: 15px;
  font-size: 1.3rem;
  color: rgba(58, 58, 58, 0.55);
}
.product_option_detail_info_table_body dl dd .line2s {
  display: inline-block;
  text-align: center;
  position: relative;
  margin-right: 4px;
  width: 33px;
  font-size: 1.3rem;
  color: rgba(58, 58, 58, 0.55);
}
.product_option_detail_info_table_body dl dd .line3s {
  display: inline-block;
  text-align: center;
  position: relative;
  width: 41px;
  font-size: 1.3rem;
  color: rgba(58, 58, 58, 0.55);
}
.product_option_detail_info_table_body dl dd .line4s {
  display: inline-block;
  text-align: center;
  position: relative;
  margin-left: 1.3rem;
  font-size: 1.3rem;
  color: rgba(58, 58, 58, 0.55);
}
.product_option_detail_info_table_body p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.08em;
  line-height: 24px;
  margin-top: 2.4rem;
}
.product_option_detail_info_attention {
  margin-top: 7rem;
}
@media screen and (max-width: 1024px) {
  .product_option_detail_info_attention {
    margin-top: 3rem;
  }
}
.product_option_detail_info_attention p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 28px;
}
@media screen and (max-width: 1024px) {
  .product_option_detail_img {
    margin-bottom: 4rem;
  }
}
.product_option_detail_img p {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 2.8rem;
  margin-bottom: 5.8rem;
}
.product_option_detail2 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-gap: 7rem;
}
@media screen and (max-width: 1024px) {
  .product_option_detail2 {
    grid-template-columns: 1fr;
    grid-gap: 4rem;
  }
}
.product_option_detail2_info_price {
  border: solid 1px var(--force-col);
  padding: 2.7rem;
}
@media screen and (max-width: 1024px) {
  .product_option_detail2_info_price {
    padding: 2rem;
  }
}
.product_option_detail2_info_price dl {
  max-width: 44rem;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  grid-gap: 2rem;
}
@media screen and (max-width: 1024px) {
  .product_option_detail2_info_price dl {
    justify-content: space-between;
    grid-gap: 1rem;
  }
}
.product_option_detail2_info_price dl dt {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.05em;
  line-height: 22px;
}
.product_option_detail2_info_price dl dd {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
}
.product_option_detail2_img {
  text-align: center;
}
.product_option_detail2_img figure {
  padding: 1rem;
  text-align: center;
}
.product_option_detail2_img p {
  font-size: 1.3rem;
  font-weight: 400;
  letter-spacing: 0.05em;
  color: rgba(58, 58, 58, 0.5);
  margin-top: 1rem;
}
.product_option_contact {
  margin-top: 16rem;
  background-color: var(--nine-col);
  padding: 8rem 16rem 5.5rem;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .product_option_contact {
    padding: 4rem 3.4rem;
    margin-left: -3.2rem;
    margin-right: -3.2rem;
  }
}
.product_option_contact h2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 1024px) {
  .product_option_contact h2 {
    font-size: 2rem;
  }
}
.product_option_contact h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.2em;
  line-height: 38px;
  margin-bottom: 4.2rem;
}
@media screen and (max-width: 1024px) {
  .product_option_contact h3 {
    margin-bottom: 5rem;
    font-size: 1.4rem;
    line-height: 2;
  }
}
.product_option_contact p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 48px;
  margin-bottom: 1.2rem;
}
@media screen and (max-width: 1024px) {
  .product_option_contact .btn {
    max-width: 100%;
  }
}
.product_option_howto {
  padding-top: 14rem;
}
@media screen and (max-width: 1024px) {
  .product_option_howto {
    padding-top: 7rem;
  }
}
.product_option_howto_item {
  border-bottom: solid 1px var(--fifteen-col);
}
.product_option_howto_item_img {
  margin-bottom: 7rem;
}
@media screen and (max-width: 1024px) {
  .product_option_howto_item_img {
    margin-bottom: 2rem;
  }
}
.product_option_howto_item + .product_option_howto_item {
  margin-top: 2rem;
}
.product_option_howto_item .accordion_head {
  border: none;
  text-align: left;
  display: block;
  width: 100%;
  border-top: solid 1px var(--fifteen-col);
  height: 5.2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: #FAFAFA;
  padding: 0 8rem;
}
@media screen and (max-width: 1024px) {
  .product_option_howto_item .accordion_head {
    padding: 1.5rem;
    height: auto;
  }
}
.product_option_howto_item .accordion_head h4 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.7rem;
  letter-spacing: 0.2em;
  color: #3A3A3A;
}
.product_option_howto_item .accordion_head .accordion_btn {
  color: #3A3A3A;
}
.product_option_howto_item .accordion_head .accordion_btn .icon-plus {
  width: 2rem;
  height: 2rem;
}
.product_option_howto_item .accordion_head .accordion_btn .icon-minus {
  width: 2rem;
  height: 2.1rem;
  display: none;
}
.product_option_howto_item .accordion_content {
  height: 0;
  overflow: hidden;
  transition: all 0.2s ease;
  background-color: #FAFAFA;
}
.product_option_howto_item .accordion_content_inner {
  padding: 7rem 8rem 7rem;
}
@media screen and (max-width: 1024px) {
  .product_option_howto_item .accordion_content_inner {
    padding: 2rem;
  }
}
.product_option_howto_item .accordion_content_inner p {
  font-size: 1.5rem;
  font-weight: 500;
  margin-bottom: 3rem;
}
.product_option_howto_item.is_active .accordion_head .accordion_btn .icon-plus {
  display: none;
}
.product_option_howto_item.is_active .accordion_head .accordion_btn .icon-minus {
  display: block;
}
.product_option_howto_caption {
  background-color: #FAFAFA;
  padding: 7rem 8rem 4rem;
  margin-top: 7rem;
}
@media screen and (max-width: 1024px) {
  .product_option_howto_caption {
    padding: 4rem 2rem 4rem;
    margin-bottom: 4rem;
  }
}
.product_option_howto_caption h3 {
  font-size: 1.7rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  margin-bottom: 3rem;
  color: rgba(58, 58, 58, 0.6);
}
.product_option_howto_caption p {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: rgba(58, 58, 58, 0.6);
}

.news {
  position: relative;
  z-index: 2;
  background-color: var(--base-col);
}
.news_inner {
  padding: 27.4rem 9.72vw 20rem;
}
@media screen and (max-width: 1024px) {
  .news_inner {
    padding: 9rem 3.2rem 9rem;
  }
}
.news_contents {
  margin-bottom: 5rem;
}
@media screen and (min-width: 1025px) {
  .news_contents {
    display: grid;
    grid-template-columns: auto 78%;
    align-items: flex-start;
    margin-bottom: 7rem;
  }
}
.news_ttl {
  text-align: left;
  margin-bottom: 11.8rem;
}
@media screen and (max-width: 1024px) {
  .news_ttl {
    text-align: center;
    margin-bottom: 9.7rem;
  }
}
.news_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  margin-bottom: 2px;
}
@media screen and (max-width: 1024px) {
  .news_ttl h3 {
    margin-bottom: 8px;
  }
}
.news_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
}
@media screen and (max-width: 1024px) {
  .news_category {
    display: none;
  }
}
.news_category li {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 36px;
}
.news_category li a {
  text-decoration: none;
  color: var(--black-col);
}
.news_category li.is_active a:before {
  content: "・";
}
.news_list {
  width: 100%;
  margin-bottom: 22rem;
}
.news_list_item {
  width: 100%;
  position: relative;
  padding: 17px 0;
  border-bottom: solid 1px var(--force-col);
}
@media screen and (min-width: 1025px) {
  .news_list_item {
    display: grid;
    grid-template-columns: 12rem 10rem auto;
    padding: 21.3px 0;
  }
}
@media screen and (max-width: 1024px) {
  .news_list_item {
    display: grid;
    grid-template-columns: 8rem auto;
  }
}
.news_list_item:first-child {
  border-top: solid 1px var(--force-col);
}
@media screen and (max-width: 1024px) {
  .news_list_item_date {
    grid-row: 1;
    grid-column: 1/2;
  }
}
.news_list_item_date p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1024px) {
  .news_list_item_date p {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_list_item_cat {
    grid-row: 1;
    grid-column: 2/3;
  }
}
.news_list_item_cat p {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1024px) {
  .news_list_item_cat p {
    font-size: 1rem;
  }
}
@media screen and (max-width: 1024px) {
  .news_list_item_title {
    grid-row: 2;
    grid-column: 1/3;
  }
}
.news_list_item_title a {
  text-decoration: none;
  color: var(--txt-col);
}
.news_list_item_title a h4 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.2em;
}
@media screen and (max-width: 1024px) {
  .news_list_item_title a h4 {
    font-weight: 500;
    font-size: 1.3rem;
    letter-spacing: 0.2em;
    line-height: 24px;
  }
}
.news_list_item_title a:hover {
  opacity: 0.5;
}
.news_list_item_title a:after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  top: 0;
  z-index: 4;
}
.news .navigation {
  display: flex;
  align-items: center;
  justify-content: center;
}
.news .navigation .page-numbers {
  display: flex;
  align-items: center;
  justify-content: center;
  grid-gap: 1.6rem;
}
.news .navigation .page-numbers li .page-numbers {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.6rem;
  letter-spacing: 0.2em;
  color: #ABABAB;
  text-decoration: none;
}
.news .navigation .page-numbers li .page-numbers.current {
  color: var(--secondary-col);
}
.news_bread ul {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  grid-gap: 1em;
}
.news_bread ul li {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
}
.news_bread ul li a {
  text-decoration: none;
}
.news_bread ul li + li:before {
  content: ">";
  margin-right: 1em;
}
.news_detail_title {
  border-top: solid 1px var(--force-col);
  padding-bottom: 1.6rem;
  border-bottom: solid 1px var(--force-col);
}
.news_detail_title_date {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  grid-gap: 4.6rem;
}
.news_detail_title_date .date {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  line-height: 65px;
}
.news_detail_title_date .category {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 65px;
}
.news_detail_title h2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
}
.news_detail_body {
  padding: 8.4rem 0;
}
.news_detail_body .rte {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 36px;
}
.news_detail_body .rte p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 36px;
}
.news_detail_body .rte figure {
  width: 100%;
}
.news_detail_body .rte figure img {
  width: 100%;
  height: auto;
}

#news_detail .news_inner {
  max-width: 144rem;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  #news_detail .news_inner {
    padding-left: 14rem;
    padding-right: 14rem;
  }
}
#news_detail .news_contents {
  grid-template-columns: auto 77.6%;
}

.guide {
  width: 100%;
}
.guide_inner {
  padding: 12rem 9.72vw 7rem;
}
@media screen and (max-width: 1024px) {
  .guide_inner {
    padding: 12rem 3.2rem 0;
  }
}
.guide_ttl {
  margin-bottom: 7rem;
}
@media screen and (max-width: 1024px) {
  .guide_ttl {
    margin-bottom: 4rem;
  }
}
.guide_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  margin-bottom: 2rem;
}
.guide_ttl h2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  margin-bottom: 4rem;
}
.guide_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 38px;
  max-width: 63rem;
}
.guide_tab {
  width: 100%;
}
.guide_tab_inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-bottom: solid 1px var(--secondary-col);
}
.guide_tab_label span {
  display: block;
  height: 7rem;
  line-height: 7rem;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  text-align: center;
  text-decoration: none;
  background-color: #3A3A3A;
  color: #FFF;
}
.guide_tab_label a {
  display: block;
  height: 7rem;
  line-height: 7rem;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  text-align: center;
  text-decoration: none;
  background-color: var(--force-col);
  opacity: 0.35;
}
.guide_filter {
  padding-bottom: 8rem;
  border-bottom: solid 1px rgba(58, 58, 58, 0.5);
  margin-bottom: 5rem;
  padding-top: 5rem;
}
@media screen and (max-width: 1024px) {
  .guide_filter {
    padding-top: 4rem;
  }
}
.guide_filter_cap {
  margin-bottom: 6rem;
}
@media screen and (min-width: 1025px) {
  .guide_filter_cap {
    text-align: right;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    grid-gap: 2rem;
  }
}
.guide_filter_cap p {
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.12em;
  line-height: 28px;
}
.guide_filter_cap .btn {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 17px;
  --txt-col: var(--seven-col);
  --bg-col: var(--force-col);
  margin-left: 1px;
}
@media screen and (max-width: 1024px) {
  .guide_filter_cap .btn {
    float: right;
  }
}
.guide_filter_cap .btn .icon-arrow-btn {
  width: 2.5rem;
  height: 0.8rem;
  color: var(--bg-col);
}
.guide_filter_block + .guide_filter_block {
  margin-top: 7.5rem;
}
.guide_filter_label {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.12em;
  margin-bottom: 7.5rem;
  color: rgba(58, 58, 58, 0.5);
  position: relative;
}
@media screen and (max-width: 1024px) {
  .guide_filter_label {
    margin-bottom: 2rem;
  }
}
.guide_filter_label:before {
  content: "";
  width: auto;
  height: 1px;
  border-bottom: dashed 1px rgba(58, 58, 58, 0.5);
  display: block;
  position: absolute;
  left: 14rem;
  right: 0;
  z-index: 1;
  top: 50%;
}
.guide_filter_list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  padding: 0 9%;
  grid-gap: 4.5rem;
}
@media screen and (max-width: 1024px) {
  .guide_filter_list {
    grid-template-columns: repeat(3, 1fr);
    padding: 0;
    grid-gap: 1.5rem;
  }
}
@media screen and (max-width: 1024px) {
  .guide_filter_list.guide_filter_list2 {
    grid-template-columns: repeat(2, 1fr);
    width: calc((100% - 6rem) / 3 * 2 + 3rem);
  }
}
.guide_filter_list_item {
  text-align: center;
  transition: all 0.2s ease;
  cursor: pointer;
  padding: 2.4rem 6%;
}
@media screen and (max-width: 1024px) {
  .guide_filter_list_item {
    padding: 1rem 6%;
  }
}
.guide_filter_list_item:hover {
  opacity: 0.7;
}
.guide_filter_list_item.active {
  background-color: rgba(235, 233, 221, 0.5);
}
.guide_filter_list_item figure {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
  height: 10.7rem;
}
@media screen and (min-width: 1025px) {
  .guide_filter_list_item figure {
    margin-bottom: 4rem;
  }
}
.guide_filter_list_item figure img {
  width: auto;
  height: auto;
}
@media screen and (max-width: 1024px) {
  .guide_filter_list_item figure img {
    width: 80%;
  }
}
.guide_filter_list_item h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  color: rgba(58, 58, 58, 0.6);
  margin-bottom: 1.4rem;
}
@media screen and (max-width: 1024px) {
  .guide_filter_list_item h4 {
    font-size: 1.3rem;
    margin-bottom: 1rem;
  }
}
.guide_filter_list_item p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.1rem;
  letter-spacing: 0.12em;
  color: rgba(58, 58, 58, 0.6);
}
.guide_filter_list_item h4 + p {
  color: rgba(58, 58, 58, 0.3);
}

.guide_product {
  border-bottom: solid 1px var(--black-col);
}
.guide_product > p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.12em;
  color: rgba(58, 58, 58, 0.5);
}
.guide_product .product_list_item:nth-child(3n-2):after {
  display: none;
}
.guide_product .product_list_item {
  border-bottom: 1px solid var(--nine-col);
}

.guide_banner {
  padding: 0 9.72vw;
}
@media screen and (max-width: 1024px) {
  .guide_banner {
    padding: 0 3.2rem;
  }
}
.guide_banner_inner {
  padding: 14rem 0;
}
@media screen and (max-width: 1024px) {
  .guide_banner_inner {
    padding: 7rem 0;
  }
}
.guide_banner_list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 7.7rem;
}
@media screen and (max-width: 1024px) {
  .guide_banner_list {
    grid-template-columns: 1fr;
    grid-gap: 4rem;
  }
}
.guide_banner_list_item {
  position: relative;
}
.guide_banner_list_img figure {
  --figure-height: 53.7%;
  display: block;
  position: relative;
  padding-top: var(--figure-height);
  overflow: hidden;
  z-index: 1;
}
.guide_banner_list_img figure img {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  object-fit: cover;
  transition: all 0.3s linear;
}
.guide_banner_list_ttl {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.guide_banner_list_ttl h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  margin-bottom: 7px;
  color: var(--base-col);
}
.guide_banner_list_ttl h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.3rem;
  letter-spacing: 0.2em;
  color: var(--base-col);
}

.chart {
  padding: 7rem 9.72vw 20rem;
}
@media screen and (max-width: 1024px) {
  .chart {
    padding: 7rem 3.2rem;
  }
}
.chart_nav_label {
  margin-bottom: 10rem;
}
@media screen and (min-width: 1025px) {
  .chart_nav_label {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}
.chart_nav_label h3 {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 2rem;
  letter-spacing: 0.05em;
  line-height: 36px;
  color: var(--fourteen-col);
}
.chart_nav_label p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  color: var(--fourteen-col);
}
.chart_nav_block + .chart_nav_block {
  margin-top: 14rem;
}
.chart_nav_list_item + .chart_nav_list_item {
  margin-top: 2rem;
}
.chart_nav_list_item .accordion_head {
  background: none;
  border: none;
  text-align: left;
  display: block;
  width: 100%;
  border-bottom: solid 1px var(--fifteen-col);
  height: 5.2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.chart_nav_list_item .accordion_head h4 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  color: var(--fourteen-col);
}
@media screen and (max-width: 1024px) {
  .chart_nav_list_item .accordion_head h4 {
    letter-spacing: 0.08em;
  }
}
.chart_nav_list_item .accordion_head h4 span {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  color: var(--fourteen-col);
}
.chart_nav_list_item .accordion_head p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  color: var(--fourteen-col);
}
.chart_nav_list_item .accordion_head .accordion_btn {
  color: #9d9d9d;
}
.chart_nav_list_item .accordion_head .accordion_btn .icon-plus {
  width: 2rem;
  height: 2rem;
}
.chart_nav_list_item .accordion_head .accordion_btn .icon-minus {
  width: 2rem;
  height: 2.1rem;
  display: none;
}
.chart_nav_list_item .accordion_content {
  height: 0;
  overflow: hidden;
  transition: all 0.2s ease;
}
@media screen and (max-width: 1024px) {
  .chart_nav_list_item .accordion_content {
    margin-right: -3.2rem;
  }
}
.chart_nav_list_item .accordion_content_inner {
  padding: 7rem 0 13rem;
}
@media screen and (max-width: 1024px) {
  .chart_nav_list_item .accordion_content_inner {
    padding: 7rem 0 7rem;
  }
}
.chart_nav_list_item .accordion_content figure img {
  width: auto;
  max-width: 100%;
}
.chart_nav_list_item.is_active .accordion_head .accordion_btn .icon-plus {
  display: none;
}
.chart_nav_list_item.is_active .accordion_head .accordion_btn .icon-minus {
  display: block;
}
.chart_img {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  align-items: flex-start;
  justify-content: flex-start;
}
@media screen and (max-width: 1024px) {
  .chart_img_wrap {
    overflow: auto;
  }
  .chart_img_wrap::-webkit-scrollbar {
    width: 14px;
  }
  .chart_img_wrap::-webkit-scrollbar-track {
    background-color: var(--force-col);
    border-radius: 3px;
  }
  .chart_img_wrap::-webkit-scrollbar-thumb {
    border: 2px solid var(--secondary-col);
    background-color: var(--secondary-col);
    border-radius: 5px;
    box-shadow: none;
  }
}
.chart_img table {
  width: 100%;
  --bg-col: var(--fourteen-col);
  --th-col: rgba(255, 255, 255, 0.5);
  --td-col: rgba(102, 102, 102, 0.05);
  --txt-col: var(--fourteen-col);
  --label-col: var(--base-col);
}
@media screen and (max-width: 1024px) {
  .chart_img table {
    width: 27rem;
  }
}
.chart_img table.chart_img_tbl_2 {
  --bg-col: #6D83A8;
  --td-col: rgba(109, 131, 168, 0.05);
  --th-col: rgba(255, 255, 255, 0.5);
  --txt-col: #6D83A8;
  --label-col: var(--base-col);
}
.chart_img table.chart_img_tbl_3 {
  --bg-col: #EBE9DD;
  --td-col: rgba(235, 233, 221, 0.05);
  --th-col: rgba(112, 107, 86, 0.5);
  --txt-col: #706B56;
  --label-col: #706B56;
}
.chart_img table thead tr th {
  text-align: center;
  background-color: var(--bg-col);
  border: solid 1px var(--fourteen-col);
  height: 10rem;
}
@media screen and (max-width: 1024px) {
  .chart_img table thead tr th {
    height: 8rem;
  }
}
.chart_img table thead tr th h4 {
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  color: var(--label-col);
  margin-bottom: 5px;
}
@media screen and (max-width: 1024px) {
  .chart_img table thead tr th h4 {
    font-size: 1.1rem;
  }
}
.chart_img table thead tr th p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 20px;
  color: var(--th-col);
}
@media screen and (max-width: 1024px) {
  .chart_img table thead tr th p {
    font-size: 1.2rem;
    line-height: 1.2;
  }
}
.chart_img table thead tr th p span {
  font-size: 1.2rem;
  line-height: 17px;
}
@media screen and (max-width: 1024px) {
  .chart_img table thead tr th p span {
    font-size: 1rem;
  }
}
.chart_img table tbody tr th {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  background-color: var(--td-col);
  color: var(--txt-col);
  border: solid 1px var(--fourteen-col);
  padding: 2rem;
  height: 9rem;
}
@media screen and (max-width: 1024px) {
  .chart_img table tbody tr th {
    font-size: 1rem;
    padding: 1.6rem 1.6rem;
    height: 7.2rem;
  }
}
.chart_img table tbody tr th.row2 {
  height: 18.2rem;
}
@media screen and (max-width: 1024px) {
  .chart_img table tbody tr th.row2 {
    height: 14.6rem;
  }
}
.chart_img table tbody tr th.row3 {
  height: 16.2rem;
}
@media screen and (max-width: 1024px) {
  .chart_img table tbody tr th.row3 {
    height: 12.6rem;
  }
}
.chart_img table tbody tr th.row4 {
  height: 34.2rem;
}
@media screen and (max-width: 1024px) {
  .chart_img table tbody tr th.row4 {
    height: 27.4rem;
  }
}
.chart_img table tbody tr td {
  background-color: var(--td-col);
  text-align: center;
  border: solid 1px var(--fourteen-col);
  padding: 2rem;
  height: 9rem;
}
@media screen and (max-width: 1024px) {
  .chart_img table tbody tr td {
    padding: 1.6rem 1rem;
    height: 7.2rem;
  }
}
.chart_img table tbody tr td.row2 {
  height: 18.4rem;
}
@media screen and (max-width: 1024px) {
  .chart_img table tbody tr td.row2 {
    height: 14.6rem;
  }
}
.chart_img table tbody tr td.row3 {
  height: 16.2rem;
}
@media screen and (max-width: 1024px) {
  .chart_img table tbody tr td.row3 {
    height: 12.6rem;
  }
}
.chart_img table tbody tr td.row4 {
  height: 34.2rem;
}
@media screen and (max-width: 1024px) {
  .chart_img table tbody tr td.row4 {
    height: 27.4rem;
  }
}
.chart_img table + table tbody th {
  border-left: none;
}
.chart_img table + table tbody td {
  border-left: none;
}
.chart_img_label {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.5rem;
  letter-spacing: 0.1em;
  line-height: 20px;
  height: 50px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background-color: var(--bg-col);
  color: var(--label-col);
  width: 17rem;
  margin: 0 auto;
  text-decoration: none;
}
.chart_img_label:hover {
  opacity: 0.5;
  color: var(--label-col);
}
@media screen and (max-width: 1024px) {
  .chart_img_label {
    font-size: 1.2rem;
    height: 40px;
    border-radius: 8px;
    width: 13.8rem;
  }
}
.chart_img_label + .chart_img_label {
  margin-top: 2rem;
}
@media screen and (max-width: 1024px) {
  .chart_img_label + .chart_img_label {
    margin-top: 1.5rem;
  }
}
@media screen and (min-width: 1025px) {
  .chart_img2 {
    width: auto;
    display: inline-block;
    max-width: calc(80.56vw - 20px);
  }
}
.chart_img2_cap {
  margin-bottom: 4rem;
  max-width: calc(80.56vw - 20px);
}
@media screen and (min-width: 1025px) {
  .chart_img2_cap {
    margin-bottom: 4rem;
  }
}
.chart_img2_cap p {
  position: relative;
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 20px;
  color: var(--fourteen-col);
  padding-left: 9.3rem;
  display: inline-block;
}
.chart_img2_cap p:before {
  content: "";
  width: 8rem;
  height: 1.8rem;
  display: block;
  background-color: var(--fourteen-col);
  position: absolute;
  left: 0;
}
.chart_img2_body {
  overflow: auto;
  padding-bottom: 2rem;
}
.chart_img2_body::-webkit-scrollbar {
  width: 14px;
}
.chart_img2_body::-webkit-scrollbar-track {
  background-color: var(--force-col);
  border-radius: 3px;
}
.chart_img2_body::-webkit-scrollbar-thumb {
  border: 2px solid var(--secondary-col);
  background-color: var(--secondary-col);
  border-radius: 5px;
  box-shadow: none;
}
.chart_img2_wrap {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  grid-gap: 2rem;
}
.chart_img2_tbl {
  width: auto;
  display: inline-block;
}
.chart_img2_tbl_head {
  background-color: var(--ten-col);
  border-radius: 10px 10px 0 0;
  height: 7.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 1024px) {
  .chart_img2_tbl_head {
    height: 6.2rem;
    border-radius: 9px 9px 0 0;
  }
}
.chart_img2_tbl_head h4 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  color: var(--base-col);
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .chart_img2_tbl_head h4 {
    font-size: 1rem;
  }
}
.chart_img2_tbl table {
  width: auto;
  --bg-col: var(--fourteen-col);
  --th-col: var(--base-col);
  --td-col: var(--base-col);
  --txt-col: var(--fourteen-col);
  --label-col: var(--base-col);
}
.chart_img2_tbl table tbody tr th {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  background-color: var(--td-col);
  color: var(--txt-col);
  border: solid 1px var(--fourteen-col);
  padding: 2rem;
  height: 9rem;
  text-align: center;
  min-width: 14rem;
}
@media screen and (max-width: 1024px) {
  .chart_img2_tbl table tbody tr th {
    font-size: 1rem;
    height: 8rem;
    padding: 1.6rem;
    min-width: 11.8rem;
  }
}
.chart_img2_tbl table tbody tr th.th {
  background-color: rgba(167, 163, 151, 0.2);
  text-align: center;
  color: #6D6A60;
  height: 5rem;
}
@media screen and (max-width: 1024px) {
  .chart_img2_tbl table tbody tr th.th {
    font-size: 1rem;
    height: 4.5rem;
  }
}
.chart_img2_tbl table tbody tr td {
  background-color: var(--td-col);
  text-align: center;
  border: solid 1px var(--fourteen-col);
  padding: 2rem;
  height: 9rem;
}
@media screen and (max-width: 1024px) {
  .chart_img2_tbl table tbody tr td {
    height: 8rem;
    padding: 1.6rem;
  }
}
.chart_img2_tbl_product {
  display: flex;
  justify-content: flex-start;
  --bg-col: var(--base-col);
  --bg2-col: var(--base-col);
  --txt-col: var(--fourteen-col);
  --txt2-col: var(--fourteen-col);
}
.chart_img2_tbl_product.is_special {
  --bg-col: var(--fourteen-col);
  --bg2-col: rgba(102, 102, 102, 0.2);
  --txt-col: var(--base-col);
  --txt2-col: var(--fourteen-col);
}
.chart_img2_tbl_product_item {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.5rem;
  letter-spacing: 0.1em;
  line-height: 20px;
  height: 5rem;
  background-color: var(--bg-col);
  color: var(--txt-col);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 17rem;
  border-radius: 10px 0 0 10px;
  border: solid 1px var(--fourteen-col);
  line-height: 1;
  text-decoration: none;
}
@media screen and (max-width: 1024px) {
  .chart_img2_tbl_product_item {
    font-size: 1.3rem;
    height: 4.5rem;
    width: 15.3rem;
  }
}
.chart_img2_tbl_product_item:last-child {
  border-radius: 10px 10px;
}
.chart_img2_tbl_product_item + .chart_img2_tbl_product_class {
  border-left: none;
}
.chart_img2_tbl_product a.chart_img2_tbl_product_item:hover {
  opacity: 0.5;
}
.chart_img2_tbl_product_class {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.5rem;
  letter-spacing: 0.1em;
  line-height: 20px;
  height: 5rem;
  background-color: var(--bg2-col);
  color: var(--txt2-col);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 8.7rem;
  border-radius: 0 0 0 0;
  border: solid 1px var(--fourteen-col);
  line-height: 1;
  text-decoration: none;
}
@media screen and (max-width: 1024px) {
  .chart_img2_tbl_product_class {
    font-size: 1.3rem;
    height: 4.5rem;
    width: 7.8rem;
    color: var(--txt2-col);
  }
}
.chart_img2_tbl_product_class:hover {
  opacity: 0.5;
}
.chart_img2_tbl_product_class + .chart_img2_tbl_product_class {
  border-left: none;
}
.chart_img2_tbl_product_class:last-child {
  border-radius: 0 10px 10px 0;
}
.chart_img2_tbl_product + .chart_img2_tbl_product {
  margin-top: 2rem;
}

.guide_step {
  padding: 0 9.72vw 20rem;
}
@media screen and (max-width: 1024px) {
  .guide_step {
    padding: 0 3.2rem 7rem;
  }
}
.guide_step_inner + .guide_step_inner {
  margin-top: 14rem;
}
@media screen and (min-width: 1025px) {
  .guide_step_inner + .guide_step_inner {
    border-top: solid 1px rgba(58, 58, 58, 0.5);
    margin-top: 14rem;
    padding-top: 14rem;
  }
}
@media screen and (min-width: 1025px) {
  .guide_step_block {
    display: grid;
    grid-template-columns: 27.78vw auto;
  }
}
@media screen and (min-width: 1025px) {
  .guide_step_block + .guide_step_block .guide_step_label {
    padding-top: 14.8rem;
  }
}
@media screen and (min-width: 1025px) {
  .guide_step_block + .guide_step_block .guide_step_content {
    padding-top: 14.8rem;
  }
}
.guide_step_label {
  position: relative;
}
@media screen and (max-width: 1024px) {
  .guide_step_label {
    padding-top: 4rem;
    margin-bottom: 3rem;
  }
}
@media screen and (min-width: 1025px) {
  .guide_step_label:after {
    content: "";
    width: 1px;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
    border-right: dashed 1px rgba(58, 58, 58, 0.5);
  }
}
@media screen and (max-width: 1024px) {
  .guide_step_label:after {
    content: "";
    width: 100%;
    height: 1px;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    z-index: 1;
    border-top: dashed 1px rgba(58, 58, 58, 0.5);
  }
}
.guide_step_label p {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 2.2rem;
  letter-spacing: 0.1em;
}
.guide_step_label.caution p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.2em;
  line-height: 36px;
  color: var(--red3-col);
}
@media screen and (min-width: 1025px) {
  .guide_step_content {
    padding-left: 9vw;
  }
}
.guide_step_content_inner + .guide_step_content_inner {
  border-top: solid 1px rgba(0, 0, 0, 0.2);
  margin-top: 7rem;
  padding-top: 4rem;
}
.guide_step_content_title {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  margin-bottom: 2.6rem;
}
.guide_step_content_title.caution {
  color: var(--red3-col);
}
.guide_step_content_txt {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 36px;
}
.guide_step_content_txt.caution {
  font-size: 1.6rem;
  color: var(--red3-col);
}
.guide_step_content_txt.caution .icon-cross {
  width: 20px;
  height: 20px;
  color: var(--red3-col);
  margin-right: 2rem;
}
.guide_step_content_txt2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.2em;
  line-height: 24px;
}
.guide_step_content_txt3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.08em;
  line-height: 36px;
}
.guide_step_content .cap {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.2em;
  line-height: 20px;
  color: rgba(58, 58, 58, 0.6);
  margin-bottom: 2.5rem;
}
.guide_step_content dl {
  margin-bottom: 1rem;
}
@media screen and (min-width: 1025px) {
  .guide_step_content dl {
    display: grid;
    grid-template-columns: auto auto;
    justify-content: flex-start;
    align-items: center;
    grid-column-gap: 2rem;
  }
}
.guide_step_content dl dt {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 36px;
}
.guide_step_content dl dd {
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 36px;
}
.guide_step_content_box {
  position: relative;
  background-color: var(--third-col);
  padding: 0 2rem;
}
.guide_step_content_box:after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  display: block;
  background-color: var(--third-col);
  mix-blend-mode: multiply;
}
.guide_step_content_box_sec {
  padding-top: 4.7rem;
  padding-bottom: 3.8rem;
}
.guide_step_content_box_sec + .guide_step_content_box_sec {
  border-top: solid 1px rgba(0, 0, 0, 0.5);
}
.guide_step_content_box_sec h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.8rem;
  letter-spacing: 0.2em;
  margin-bottom: 6rem;
  color: rgba(0, 0, 0, 0.6);
}
.guide_step_content_box_sec h3 span {
  font-size: 1.2rem;
}
.guide_step_content_box_sec h3 .icon-circle {
  color: rgba(58, 58, 58, 0.6);
  width: 20px;
  height: 20px;
  margin-right: 2rem;
}
.guide_step_content_box_sec .guide_step_content_box_sec_ttl2 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  margin-bottom: 5rem;
  color: rgba(0, 0, 0, 0.45);
}
.guide_step_content_box_sec .guide_step_content_box_sec_ttl2 span {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.2em;
}
@media screen and (min-width: 1025px) {
  .guide_step_content_box_sec .guide_step_content_box_sec_ttl2 span {
    margin-left: 2rem;
  }
}
@media screen and (max-width: 1024px) {
  .guide_step_content_box_sec .guide_step_content_box_sec_ttl2 span {
    display: block;
  }
}
.guide_step_content_box_sec figure {
  max-width: 44rem;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  .guide_step_content_box_inner {
    padding: 0 2.8rem;
  }
}
.guide_step_content_box_inner + .guide_step_content_box_inner {
  margin-top: 6rem;
}
.guide_step_content_box_inner h4 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  color: rgba(0, 0, 0, 0.45);
  margin-bottom: 1rem;
}
@media screen and (max-width: 1024px) {
  .guide_step_content_box_inner h4 {
    display: flex;
  }
}
.guide_step_content_box_inner h4 span {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  margin-right: 1rem;
}
.guide_step_content_box_inner p {
  padding-left: 4.1rem;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.2em;
  color: rgba(0, 0, 0, 0.45);
  margin-bottom: 4.4rem;
}
.guide_step_content_box_inner figure {
  margin: 0 auto;
  text-align: center;
}
.guide_step_content_box_img02 {
  max-width: 19.8rem;
}
.guide_step_content_box_img03 {
  max-width: 16.3rem;
}
.guide_step_content_box_img04 {
  max-width: 11.6rem;
}
.guide_step_content_caution {
  background-color: rgba(145, 34, 40, 0.8);
  padding: 5rem 6rem;
  margin-bottom: 14rem;
}
.guide_step_content_caution h4 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  color: var(--base-col);
  margin-bottom: 1.6rem;
}
.guide_step_content_caution h5 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.7rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  color: var(--base-col);
}
.guide_step_content_caution p {
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.2em;
  line-height: 27px;
  color: var(--base-col);
  opacity: 0.7;
}
.guide_step_content_btns {
  margin-top: 7rem;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  grid-gap: 6rem;
}
@media screen and (max-width: 1024px) {
  .guide_step_content_btns {
    flex-direction: column;
    grid-gap: 3rem;
  }
  .guide_step_content_btns .btn {
    max-width: 100%;
  }
}

.guide_trivia {
  height: 500vh;
}
@media screen and (max-width: 1024px) {
  .guide_trivia {
    display: none;
  }
}
.guide_trivia_img {
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  z-index: 2;
  height: 75vw;
  overflow: hidden;
}
.guide_trivia_img_txt_02 {
  position: absolute;
  left: 15%;
  top: 18.4%;
  z-index: 2;
  right: 0;
  width: 75.43%;
  opacity: 0;
  transition: all 0.8s ease;
  transform: translateY(10px);
}
.guide_trivia_img_txt_02.is_active {
  opacity: 1;
  transform: translateY(0);
}
.guide_trivia_img_txt_02 img {
  width: 100%;
  height: auto;
}
.guide_trivia_img_txt_03 {
  position: absolute;
  left: 15.4%;
  top: 21.4%;
  z-index: 2;
  right: 0;
  width: 75.57%;
  opacity: 0;
  transition: all 0.8s ease;
  transform: translateY(10px);
}
.guide_trivia_img_txt_03.is_active {
  opacity: 1;
  transform: translateY(0);
}
.guide_trivia_img_txt_03 img {
  width: 100%;
  height: auto;
}
.guide_trivia_img_txt {
  opacity: 0;
  transition: all 0.2s ease;
}
.guide_trivia_img_txt h5 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.15em;
  margin-bottom: 1.7rem;
}
.guide_trivia_img_txt p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
  line-height: 28px;
}
.guide_trivia_img_01 {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1;
  height: 75vw;
  opacity: 0;
  transition: all 1s ease;
}
.guide_trivia_img_01.is_active {
  opacity: 1;
}
.guide_trivia_img_02 {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1;
  height: 75vw;
}
.guide_trivia_img_02_img {
  opacity: 0;
  transition: all 1s ease;
}
.guide_trivia_img_02_img.is_active {
  opacity: 1;
}
.guide_trivia_img_03 {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1;
  height: 75vw;
}
.guide_trivia_inner {
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  padding: 0 9.74vw;
  padding-top: 8.4rem;
}
.guide_trivia_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  margin-bottom: 2.3rem;
}
.guide_trivia_ttl h2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
}

@media screen and (min-width: 1025px) {
  .guide_trivia_s {
    display: none;
  }
}
.guide_trivia_s_head {
  position: relative;
}
.guide_trivia_s_head figure {
  position: relative;
}
.guide_trivia_s_ttl {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1;
  padding: 0 3.2rem 5rem;
}
.guide_trivia_s_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  margin-bottom: 2.3rem;
}
.guide_trivia_s_ttl h2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
}
.guide_trivia_s_grid {
  display: grid;
  grid-template-columns: 14rem auto;
  padding-top: 7rem;
}
.guide_trivia_s_menu {
  padding-left: 2rem;
}
.guide_trivia_s_menu ul li {
  font-size: 1.3rem;
  font-weight: 500;
  line-height: 4rem;
  letter-spacing: 0.06em;
}
.guide_trivia_s_menu ul li a {
  text-decoration: none;
  position: relative;
}
.guide_trivia_s_menu ul li a.is_active:after {
  content: "";
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20width%3D%227%22%20height%3D%2212%22%20viewBox%3D%220%200%207%2012%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M0.389323%2011.625L6.22266%206L0.389323%200.375%22%20stroke%3D%22%23969696%22%2F%3E%3C%2Fsvg%3E");
  background-size: contain;
  background-repeat: no-repeat;
  width: 7px;
  height: 12px;
  display: block;
  position: absolute;
  right: -1rem;
  top: 50%;
  transform: translateY(-50%);
}
.guide_trivia_s_imgs {
  position: relative;
  padding-top: 120vw;
}
.guide_trivia_s_img {
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1;
  transition: all 0.5s ease;
}
.guide_trivia_s_img.is_active {
  opacity: 1;
}
.guide_trivia_s_img img {
  width: 100%;
  height: auto;
}
.guide_trivia_s_img_txt {
  padding-top: 3.5rem;
  padding-right: 3.2rem;
}
.guide_trivia_s_img_txt h5 {
  font-size: 1.3rem;
  font-weight: 500;
  letter-spacing: 0.15em;
}
.guide_trivia_s_img_txt p {
  font-size: 1.3rem;
  font-weight: 500;
  line-height: 2;
  letter-spacing: 0.12em;
}

.customize {
  width: 100%;
  background-color: var(--base-col);
}
.customize_label {
  position: fixed;
  top: 14rem;
  left: 5rem;
  z-index: 2;
  transform-origin: top left;
  transform: rotate(90deg) translateX(4rem);
  display: inline-block;
  margin-left: 0;
  opacity: 0;
  transition: all 0.2s ease;
}
@media screen and (max-width: 1024px) {
  .customize_label {
    top: 16rem;
    left: 3rem;
    display: none;
  }
}
.customize_label p {
  font-family: var(--font-arial);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1024px) {
  .customize_label p {
    font-size: 1.4rem;
  }
}
.customize_inner {
  padding: 12rem 9.72vw 20rem;
}
@media screen and (max-width: 1024px) {
  .customize_inner {
    padding: 12rem 3.2rem 10rem;
  }
}
.customize_ttl {
  margin-bottom: 7rem;
}
.customize_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  margin-bottom: 2rem;
}
@media screen and (max-width: 1024px) {
  .customize_ttl h3 {
    font-size: 1.4rem;
  }
}
.customize_ttl h2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  margin-bottom: 4rem;
}
@media screen and (max-width: 1024px) {
  .customize_ttl h2 {
    font-size: 2rem;
  }
}
.customize_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 38px;
  max-width: 63rem;
}
@media screen and (max-width: 1024px) {
  .customize_ttl p {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 1024px) {
  .customize_ttl .btn {
    display: none;
  }
}
.customize_img {
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .customize_img {
    margin-right: -3.2rem;
    overflow: auto;
  }
}
.customize_img::-webkit-scrollbar {
  width: 14px;
}
.customize_img::-webkit-scrollbar-track {
  background-color: var(--force-col);
  border-radius: 3px;
}
.customize_img::-webkit-scrollbar-thumb {
  border: 2px solid var(--secondary-col);
  background-color: var(--secondary-col);
  border-radius: 5px;
  box-shadow: none;
}
.customize_img figure {
  max-width: 824px;
  width: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 1024px) {
  .customize_img figure {
    width: 574px;
  }
}
.customize_list {
  width: 100%;
  background-color: var(--third-col);
}
.customize_list_inner {
  padding: 9.5rem 9.72vw 11.2rem;
}
@media screen and (max-width: 1024px) {
  .customize_list_inner {
    padding: 7rem 3.2rem;
  }
}
.customize_list_table {
  position: relative;
}
.customize_list_table_head {
  padding-top: 9.5rem;
  position: sticky;
  top: 0;
  z-index: 30;
  background-color: var(--third-col);
}
@media screen and (max-width: 1024px) {
  .customize_list_table_head {
    display: none;
  }
}
.customize_list_table_body {
  position: relative;
  z-index: 10;
}
@media screen and (min-width: 1025px) {
  .customize_list_table table th:nth-child(1),
  .customize_list_table table td:nth-child(1) {
    width: 22%;
  }
  .customize_list_table table th:nth-child(2),
  .customize_list_table table td:nth-child(2) {
    width: auto;
  }
  .customize_list_table table th:nth-child(3),
  .customize_list_table table td:nth-child(3) {
    width: 31%;
  }
  .customize_list_table table th:nth-child(4),
  .customize_list_table table td:nth-child(4) {
    width: 9.4rem;
  }
  .customize_list_table table th:nth-child(5),
  .customize_list_table table td:nth-child(5) {
    width: 9.4rem;
  }
}
.customize_list_table table .bdr {
  border-left: solid 1px rgba(58, 58, 58, 0.3);
}
.customize_list_table table th.action {
  background-color: #D9D9D9;
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 2.2rem;
  letter-spacing: 0.12em;
  text-align: center;
}
.customize_list_table table thead tr th {
  border-bottom: solid 1px rgba(58, 58, 58, 0.3);
}
@media screen and (max-width: 1024px) {
  .customize_list_table table tbody {
    padding: 0;
    border: none;
  }
}
@media screen and (max-width: 1024px) {
  .customize_list_table table tbody tr {
    padding: 0;
    border: none;
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
}
.customize_list_table table tbody tr th {
  border-bottom: solid 1px rgba(58, 58, 58, 0.3);
  background-color: #D9D9D9;
  padding: 1rem 1.2rem;
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 2.2rem;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 1024px) {
  .customize_list_table table tbody tr th {
    grid-column: 1/3;
    margin-top: 3rem;
  }
}
@media screen and (max-width: 1024px) {
  .customize_list_table table tbody tr th:empty {
    display: none;
  }
}
.customize_list_table table tbody tr td {
  border-bottom: solid 1px rgba(58, 58, 58, 0.3);
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.18em;
}
@media screen and (max-width: 1024px) {
  .customize_list_table table tbody tr td {
    grid-column: 1/3;
  }
}
.customize_list_table table tbody tr td.title {
  position: relative;
  padding-left: 4rem;
}
@media screen and (max-width: 1024px) {
  .customize_list_table table tbody tr td.title {
    padding: 4rem 1rem 1.5rem 3.5rem;
    border: none;
  }
}
.customize_list_table table tbody tr td.title > span {
  position: relative;
  font-family: "Crimson Text", "Noto Serif JP", serif;
  width: 18px;
  color: #3A3A3A;
  text-align: center;
  line-height: 20px;
  display: inline-block;
  font-size: 1.1rem;
  margin-right: 1rem;
  padding-left: 1px;
  letter-spacing: 0;
  transform: translateY(1px);
  position: absolute;
  left: 1.6rem;
  top: auto;
}
@media screen and (max-width: 1024px) {
  .customize_list_table table tbody tr td.title > span {
    left: 0.8rem;
  }
}
.customize_list_table table tbody tr td.title > span:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 18px;
  height: 18px;
  border: solid 1px #3A3A3A;
  border-radius: 9px;
  box-sizing: border-box;
}
@media screen and (max-width: 1024px) {
  .customize_list_table table tbody tr td.title > span {
    padding-left: 0;
  }
}
.customize_list_table table tbody tr td.comment {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
}
@media screen and (max-width: 1024px) {
  .customize_list_table table tbody tr td.comment {
    padding: 0 1rem 3rem;
    border: none;
  }
}
.customize_list_table table tbody tr td.comment > span, .customize_list_table table tbody tr td.comment > .flex span {
  font-size: 1.2rem;
  color: rgba(58, 58, 58, 0.5);
  line-height: 2rem;
}
.customize_list_table table tbody tr td.comment .btn {
  margin-top: 1rem;
}
@media screen and (max-width: 1024px) {
  .customize_list_table table tbody tr td.price {
    padding: 0 0 2.5rem;
    border-bottom: none;
  }
}
.customize_list_table table tbody tr td.price dl {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
@media screen and (max-width: 1024px) {
  .customize_list_table table tbody tr td.price dl {
    display: flex;
    justify-content: center;
  }
}
.customize_list_table table tbody tr td.price dl dt {
  font-size: 1.2rem;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 1024px) {
  .customize_list_table table tbody tr td.price dl dt {
    padding: 0 1rem;
    border: none;
    text-align: center;
  }
}
.customize_list_table table tbody tr td.price dl dd {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 22px;
}
@media screen and (max-width: 1024px) {
  .customize_list_table table tbody tr td.price dl dd {
    padding: 0 1rem;
    border: none;
    text-align: center;
  }
}
.customize_list_table table tbody tr td.price dl dd span {
  font-size: 1.2rem;
  letter-spacing: 0.05em;
}
.customize_list_table table tbody tr td.action {
  text-align: center;
  font-size: 1.6rem;
}
@media screen and (min-width: 1025px) {
  .customize_list_table table tbody tr td.action {
    background-color: rgba(233, 233, 233, 0.5);
  }
}
@media screen and (max-width: 1024px) {
  .customize_list_table table tbody tr td.action {
    padding: 6px 0;
    line-height: 1;
    border: none;
    border-top: solid 1px rgba(58, 58, 58, 0.3);
    border-bottom: solid 1px rgba(58, 58, 58, 0.3);
    grid-column: 1/2;
    vertical-align: middle;
  }
}
@media screen and (max-width: 1024px) {
  .customize_list_table table tbody tr td.action:last-child {
    grid-column: 2/3;
    border-left: solid 1px rgba(58, 58, 58, 0.3);
  }
}
@media screen and (max-width: 1024px) {
  .customize_list_table table tbody tr td.action:before {
    font-size: 1.2rem;
    transform: translateY(-2px);
    display: inline-block;
  }
}
.customize_parts {
  background-color: var(--base-col);
}
.customize_parts_inner {
  padding: 12rem 9.72vw 11rem;
}
@media screen and (max-width: 1024px) {
  .customize_parts_inner {
    padding: 7rem 3.2rem;
  }
}
.customize_parts_ttl {
  margin-bottom: 13rem;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .customize_parts_ttl {
    margin-bottom: 5rem;
  }
}
.customize_parts_ttl h3 {
  font-size: 1.6rem;
  font-weight: 500;
  letter-spacing: 0.2em;
}
.customize_parts_list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  grid-gap: 4rem;
}
@media screen and (max-width: 1024px) {
  .customize_parts_list {
    grid-template-columns: 1fr 1fr;
    grid-gap: 2.6rem;
  }
}
.customize_parts_list_item figure {
  width: 100%;
  margin-bottom: 1.5rem;
}
.customize_parts_list_item a {
  text-decoration: none;
}
.customize_parts_list_item p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
}
.customize_entry {
  background-color: #E9E9E9;
}
.customize_entry_inner {
  padding: 8rem 9.72vw 5rem;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .customize_entry_inner {
    padding: 8rem 3.2rem 5rem;
  }
}
.customize_entry_ttl {
  text-align: center;
  margin-bottom: 2.8rem;
}
.customize_entry_ttl h2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  margin-bottom: 3.5rem;
}
.customize_entry_ttl h3 {
  font-size: 1.6rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  line-height: 4.1rem;
}
@media screen and (max-width: 1024px) {
  .customize_entry_ttl h3 {
    line-height: 2;
  }
}
.customize_entry_ttl p {
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  line-height: 4.1rem;
}
@media screen and (max-width: 1024px) {
  .customize_entry_ttl p {
    line-height: 2;
  }
}
.customize_entry_content p {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 2.9rem;
}
.customize_entry_content p + p {
  margin-top: 1rem;
}
.customize_entry_content_btn {
  max-width: 60rem;
  margin: 0 auto;
  margin-top: 4rem;
  padding-top: 3.5rem;
  border-top: solid 1px rgba(58, 58, 58, 0.3);
}
.customize_entry_content_btn p {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  line-height: 5.8rem;
  margin-bottom: 2rem;
}
@media screen and (max-width: 1024px) {
  .customize_entry_content_btn p {
    line-height: 2;
  }
}
.customize_dl {
  background-color: #FAFAFA;
}
.customize_dl_inner {
  padding: 15rem 9.72vw;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .customize_dl_inner {
    padding: 7rem 3.2rem;
  }
}
.customize_dl_inner h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  color: #3A3A3A;
  margin-bottom: 4.5rem;
}
.customize_dl_inner .dl_btn {
  max-width: 72rem;
  background-color: #3A3A3A;
  color: var(--base-col);
  padding: 4.5rem 0;
}
@media screen and (max-width: 1024px) {
  .customize_dl_inner .dl_btn {
    padding: 2.5rem 0;
  }
}
@media screen and (min-width: 1025px) {
  .customize_dl_inner .dl_btn_inner {
    display: flex;
    align-items: center;
    justify-content: space-evenly;
  }
}
.customize_dl_inner .dl_btn_label {
  text-align: center;
}
@media screen and (min-width: 1025px) {
  .customize_dl_inner .dl_btn_label {
    text-align: left;
  }
}
.customize_dl_inner .dl_btn_label .btn_l3 {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 2.9rem;
}
@media screen and (max-width: 1024px) {
  .customize_dl_inner .dl_btn_label .btn_l3 {
    display: block;
    line-height: 2;
  }
}
.customize_dl_inner .dl_btn_label .btn_l4 {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 2.9rem;
}
@media screen and (max-width: 1024px) {
  .customize_dl_inner .dl_btn_label .btn_l4 {
    display: block;
    margin-bottom: 1rem;
    line-height: 1;
  }
}
.customize_dl_inner .dl_btn_icon {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
}
.customize_dl_inner .dl_btn_icon img {
  max-width: 5.7rem;
  margin-left: 2rem;
}
.customize_section {
  transition: all 0.4s ease;
}
.customize_section.is_active .customize_label {
  opacity: 1;
}

.customize_name {
  width: 100%;
  background-color: #FAFAFA;
}
.customize_name_inner {
  padding: 12rem 9.72vw 0;
}
@media screen and (max-width: 1024px) {
  .customize_name_inner {
    padding: 12rem 3.2rem 0;
  }
}
.customize_name_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 38px;
  max-width: 63rem;
}
.customize_name + .product {
  background-color: #FAFAFA !important;
  padding-top: 0;
}
.customize_name + .product .product_option_item {
  margin-top: 0;
}
.customize_name_dl {
  background-color: var(--base-col);
}
.customize_name_dl_inner {
  padding: 14rem 9.72vw;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .customize_name_dl_inner {
    padding: 7rem 3.2rem;
  }
}
.customize_name_dl_inner h3 {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 2.9rem;
  color: #3A3A3A;
  margin-bottom: 3rem;
}
.customize_name_dl_inner .btn {
  max-width: 28.5rem;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
}

.customize_cusotom_parts {
  width: 100%;
  background-color: var(--base-col);
}
.customize_cusotom_parts_inner {
  padding: 12rem 9.72vw 0rem;
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_inner {
    padding: 12rem 3.2rem 0;
  }
}
.customize_cusotom_parts_ttl {
  text-align: left;
  margin-bottom: 10rem;
}
.customize_cusotom_parts_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 38px;
  max-width: 63rem;
}
.customize_cusotom_parts_ttl2 {
  text-align: left;
  padding-bottom: 7rem;
  border-bottom: solid 1px #9D9D9D;
}
.customize_cusotom_parts_ttl2 h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  margin-bottom: 2rem;
}
.customize_cusotom_parts_ttl2 h2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  margin-bottom: 4rem;
}
.customize_cusotom_parts_ttl2 p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 38px;
}
.customize_cusotom_parts + .product {
  background-color: #FFF !important;
  padding-top: 0;
}
.customize_cusotom_parts + .product .product_option_item {
  margin-top: 0;
}
.customize_cusotom_parts_dl {
  background-color: #E9E9E9;
}
.customize_cusotom_parts_dl_inner {
  padding: 14rem 9.72vw;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_dl_inner {
    padding: 7rem 3.2rem;
  }
}
.customize_cusotom_parts_dl_inner h3 {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 2.9rem;
  color: #3A3A3A;
  margin-bottom: 3rem;
}
.customize_cusotom_parts_dl_inner .btn {
  max-width: 28.5rem;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
}
.customize_cusotom_parts_tbl {
  background-color: #FFF;
}
.customize_cusotom_parts_tbl_inner {
  padding: 12rem 9.72vw 10rem;
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_inner {
    padding: 7rem 3.2rem;
  }
}
.customize_cusotom_parts_tbl_ttl {
  text-align: center;
}
.customize_cusotom_parts_tbl_ttl h3 {
  font-size: 1.6rem;
  font-weight: 500;
  letter-spacing: 0.2em;
}
.customize_cusotom_parts_tbl_table {
  position: relative;
}
.customize_cusotom_parts_tbl_table_head {
  background-color: #FFF;
  padding-top: 10rem;
  position: sticky;
  top: 0;
  z-index: 3;
}
.customize_cusotom_parts_tbl_table table .type {
  width: auto;
}
.customize_cusotom_parts_tbl_table table .code {
  width: 10%;
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table .code {
    width: 14%;
  }
}
.customize_cusotom_parts_tbl_table table .inch {
  width: 10%;
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table .inch {
    width: 14%;
  }
}
.customize_cusotom_parts_tbl_table table .fig1 {
  width: 10%;
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table .fig1 {
    width: 14%;
  }
}
.customize_cusotom_parts_tbl_table table .fig2 {
  width: 10%;
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table .fig2 {
    width: 14%;
  }
}
.customize_cusotom_parts_tbl_table table .hit {
  width: 10%;
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table .hit {
    width: 14%;
  }
}
.customize_cusotom_parts_tbl_table table .pin {
  width: 10%;
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table .pin {
    width: 14%;
  }
}
.customize_cusotom_parts_tbl_table table .scr {
  width: 10%;
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table .scr {
    width: 14%;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table thead {
    display: table;
    width: 100%;
    position: sticky;
    top: 0;
    z-index: 3;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table thead tr {
    display: table-row;
    padding: 0;
  }
}
.customize_cusotom_parts_tbl_table table thead tr th {
  background-color: #FAFAFA;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  text-align: center;
  border: solid 1px #D9D9D9;
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table thead tr th {
    display: table-cell;
    padding: 5px 0;
    font-size: 1rem;
  }
}
@media screen and (min-width: 1025px) {
  .customize_cusotom_parts_tbl_table table thead tr th:first-child {
    border-left: none;
  }
}
@media screen and (min-width: 1025px) {
  .customize_cusotom_parts_tbl_table table thead tr th:last-child {
    border-right: none;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table thead tr th.type {
    display: none;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody {
    display: block;
    border: none;
    position: relative;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr {
    display: grid;
    grid-template-columns: auto 14% 14% 14% 14% 14% 14%;
    padding: 0;
    border: none;
    position: relative;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr.tr {
    position: sticky;
    top: 0;
    z-index: 2;
    padding-top: 15rem;
    margin-top: -15rem;
  }
}
.customize_cusotom_parts_tbl_table table tbody tr th {
  background-color: #E9E9E9;
  text-align: center;
  font-size: 1.3rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  border: solid 1px #D9D9D9;
  border-left: none;
  border-right: none;
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr th {
    display: block;
    padding: 1rem 0;
    font-size: 1rem;
    grid-column: 1/8;
    border: solid 1px #D9D9D9;
    border-top: none;
  }
}
.customize_cusotom_parts_tbl_table table tbody tr td {
  background-color: #FFF;
  text-align: center;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  border: solid 1px #D9D9D9;
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr td {
    padding: 1rem 0;
    font-size: 1rem;
    width: 100%;
    border: none;
    border-bottom: solid 1px #D9D9D9;
    border-left: solid 1px #D9D9D9;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr td[colspan="8"] {
    grid-column: 1/8;
    border-right: solid 1px #D9D9D9;
  }
}
@media screen and (min-width: 1025px) {
  .customize_cusotom_parts_tbl_table table tbody tr td:first-child {
    border-left: none;
  }
}
@media screen and (min-width: 1025px) {
  .customize_cusotom_parts_tbl_table table tbody tr td:last-child {
    border-right: none;
  }
}
.customize_cusotom_parts_tbl_table table tbody tr td.type {
  font-size: 1.3rem;
  font-weight: 600;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr td.type {
    display: block;
    width: 100%;
    grid-column: 1/8;
    border: solid 1px #D9D9D9;
    border-top: none;
    position: relative;
  }
  .customize_cusotom_parts_tbl_table table tbody tr td.type:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    z-index: 3;
    display: block;
  }
  .customize_cusotom_parts_tbl_table table tbody tr td.type:after {
    content: "";
    position: absolute;
    right: 1rem;
    top: 50%;
    z-index: 1;
    transform: translateY(-50%);
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20width%3D%2212%22%20height%3D%2212%22%20viewBox%3D%220%200%2012%2012%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20clip-path%3D%22url(%23clip0_1857_15317)%22%3E%3Cpath%20d%3D%22M0%206H12%22%20stroke%3D%22%239D9D9D%22%20stroke-width%3D%222%22%20stroke-miterlimit%3D%2210%22%2F%3E%3Cpath%20d%3D%22M6%2012V0%22%20stroke%3D%22%239D9D9D%22%20stroke-width%3D%222%22%20stroke-miterlimit%3D%2210%22%2F%3E%3C%2Fg%3E%3Cdefs%3E%3CclipPath%20id%3D%22clip0_1857_15317%22%3E%3Crect%20width%3D%2212%22%20height%3D%2212%22%20fill%3D%22white%22%2F%3E%3C%2FclipPath%3E%3C%2Fdefs%3E%3C%2Fsvg%3E");
    background-size: contain;
    background-repeat: no-repeat;
    width: 12px;
    height: 12px;
  }
}
.customize_cusotom_parts_tbl_table table tbody tr td.code {
  font-size: 1.3rem;
  font-weight: 600;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr td.code {
    width: 100%;
    display: none;
  }
}
.customize_cusotom_parts_tbl_table table tbody tr td.inch {
  font-size: 1.3rem;
  font-weight: 600;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr td.inch {
    width: 100%;
    display: none;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr td.fig1 {
    width: 100%;
    display: none;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr td.fig2 {
    width: 100%;
    display: none;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr td.hit {
    width: 100%;
    display: none;
  }
}
.customize_cusotom_parts_tbl_table table tbody tr td.big {
  background-color: rgba(171, 28, 35, 0.05);
  color: #AB1C23;
}
.customize_cusotom_parts_tbl_table table tbody tr td.sml {
  background-color: rgba(109, 131, 168, 0.1);
  color: #6D83A8;
}
.customize_cusotom_parts_tbl_table table tbody tr td.mid {
  background-color: rgba(124, 139, 118, 0.1);
  color: #7C8B76;
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr td.pin {
    width: 100%;
    display: none;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr td.scr {
    width: 100%;
    border-right: solid 1px #D9D9D9;
    display: none;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr.is_active td.type:after {
    content: "";
    position: absolute;
    right: 1rem;
    top: 50%;
    z-index: 1;
    transform: translateY(-50%);
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20width%3D%2212%22%20height%3D%2212%22%20viewBox%3D%220%200%2012%2012%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M0%206H12%22%20stroke%3D%22%239D9D9D%22%20stroke-width%3D%222%22%20stroke-miterlimit%3D%2210%22%2F%3E%3C%2Fsvg%3E");
    background-size: contain;
    background-repeat: no-repeat;
    width: 12px;
    height: 12px;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr.is_active td.code {
    display: block;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr.is_active td.inch {
    display: block;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr.is_active td.fig1 {
    display: block;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr.is_active td.fig2 {
    display: block;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr.is_active td.hit {
    display: block;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr.is_active td.pin {
    display: block;
  }
}
@media screen and (max-width: 1024px) {
  .customize_cusotom_parts_tbl_table table tbody tr.is_active td.scr {
    display: block;
  }
}
@media screen and (min-width: 1025px) {
  .customize_cusotom_parts .product_option_item {
    margin-top: 7rem;
  }
}
.customize_cusotom_parts .product_option_section {
  margin-top: calc(var(--header-height) * -1);
  padding-top: var(--header-height);
}

.maintenance {
  width: 100%;
  background-color: var(--base-col);
}
.maintenance_label {
  position: fixed;
  top: 14rem;
  left: 5rem;
  z-index: 2;
  transform-origin: top left;
  transform: rotate(90deg) translateX(4rem);
  display: inline-block;
  margin-left: 0;
  opacity: 0;
  transition: all 0.2s ease;
}
@media screen and (max-width: 1024px) {
  .maintenance_label {
    top: 16rem;
    left: 3rem;
    display: none;
  }
}
.maintenance_label p {
  font-family: var(--font-arial);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1024px) {
  .maintenance_label p {
    font-size: 1.4rem;
  }
}
.maintenance_inner {
  padding: 12rem 9.72vw 7rem;
}
@media screen and (max-width: 1024px) {
  .maintenance_inner {
    padding: 12rem 3.2rem 7rem;
  }
}
.maintenance_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  margin-bottom: 2rem;
}
.maintenance_ttl h2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  margin-bottom: 4rem;
}
.maintenance_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 38px;
  max-width: 63rem;
}
.maintenance_tab {
  width: 100%;
  padding: 0 9.72vw;
  background-color: var(--base-col);
}
@media screen and (max-width: 1024px) {
  .maintenance_tab {
    padding: 0;
  }
}
.maintenance_tab_inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-bottom: solid 1px var(--secondary-col);
}
.maintenance_tab_label a {
  display: block;
  height: 7rem;
  line-height: 7rem;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  text-align: center;
  text-decoration: none;
  background-color: var(--force-col);
  opacity: 0.35;
}
@media screen and (max-width: 1024px) {
  .maintenance_tab_label a {
    font-size: 1.2rem;
  }
}
.maintenance_tab_label a.is_active {
  background-color: #3A3A3A;
  opacity: 1;
  color: #FFF;
}
.maintenance_block {
  width: 100%;
  background-color: var(--third-col);
}
.maintenance_block_inner {
  padding: 14rem 9.72vw 7rem;
}
@media screen and (max-width: 1024px) {
  .maintenance_block_inner {
    padding: 7rem 3.2rem;
  }
}
.maintenance_block_step + .maintenance_block_step {
  padding-top: 7rem;
}
.maintenance_block_step_block {
  margin-bottom: 4rem;
}
@media screen and (min-width: 1025px) {
  .maintenance_block_step_block {
    display: grid;
    grid-template-columns: 13.47vw auto;
    margin-bottom: 7rem;
  }
}
.maintenance_block_step_label {
  position: relative;
}
@media screen and (max-width: 1024px) {
  .maintenance_block_step_label {
    padding-bottom: 2rem;
    margin-bottom: 4rem;
  }
}
.maintenance_block_step_label:after {
  content: "";
}
@media screen and (min-width: 1025px) {
  .maintenance_block_step_label:after {
    width: 1px;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
    border-right: dashed 1px rgba(58, 58, 58, 0.5);
  }
}
@media screen and (max-width: 1024px) {
  .maintenance_block_step_label:after {
    width: 100%;
    height: 1px;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
    border-bottom: dashed 1px rgba(58, 58, 58, 0.5);
  }
}
.maintenance_block_step_label p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
}
@media screen and (min-width: 1025px) {
  .maintenance_block_step_content {
    padding-left: 6.9vw;
  }
}
.maintenance_block_step_content_title {
  font-weight: 500;
  font-size: 2rem;
  letter-spacing: 0.2em;
  line-height: 3.4rem;
  color: #3a3a3a;
}
@media screen and (max-width: 1024px) {
  .maintenance_block_step_content_title {
    font-size: 1.6rem;
  }
}
.maintenance_block_step_content_title2 {
  font-weight: 700;
  font-size: 1.6rem;
  letter-spacing: 0.12em;
  color: #3a3a3a;
  margin-bottom: 1.7rem;
}
.maintenance_block_step_content_title2.caution {
  color: var(--red3-col);
}
.maintenance_block_step_content_txt {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 36px;
}
.maintenance_block_step_content_txt.caution {
  font-size: 1.5rem;
  line-height: 2.9rem;
  color: var(--red3-col);
  /*
              .icon-cross {
                width: 20px;
                height: 20px;
                color: var(--red3-col);
                margin-right: 2rem;
              }
  */
}
.maintenance_block_step_content_txt + p, .maintenance_block_step_content_txt + a {
  margin-top: 2.4rem;
}
.maintenance_block_step_content_txt2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl {
  width: 100%;
}
@media screen and (max-width: 1024px) {
  .maintenance_block_step_content table.maintenance_block_step_content_tbl {
    border: none;
  }
}
@media screen and (max-width: 1024px) {
  .maintenance_block_step_content table.maintenance_block_step_content_tbl tbody {
    border: none;
    padding-bottom: 0;
  }
}
@media screen and (max-width: 1024px) {
  .maintenance_block_step_content table.maintenance_block_step_content_tbl tbody tr {
    border: none;
    padding: 0;
  }
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl tbody tr th {
  background-color: rgba(233, 233, 233, 0.5);
  border-top: solid 1px rgba(58, 58, 58, 0.3);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.18em;
  padding: 3rem 2rem 1.5rem;
}
@media screen and (min-width: 1025px) {
  .maintenance_block_step_content table.maintenance_block_step_content_tbl tbody tr th {
    width: 25%;
    text-align: center;
    border-top: solid 1px #3A3A3A;
    border-bottom: solid 1px #3A3A3A;
    padding: 3rem 2rem;
  }
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl tbody tr td {
  background-color: rgba(233, 233, 233, 0.5);
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
  padding: 0rem 2rem 2rem;
}
@media screen and (min-width: 1025px) {
  .maintenance_block_step_content table.maintenance_block_step_content_tbl tbody tr td {
    border-top: solid 1px rgba(58, 58, 58, 0.3);
    border-bottom: solid 1px rgba(58, 58, 58, 0.3);
    padding: 3rem 2rem;
  }
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl tbody tr td.text p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
}
@media screen and (min-width: 1025px) {
  .maintenance_block_step_content table.maintenance_block_step_content_tbl tbody tr td.text p + p {
    margin-top: 2.5rem;
  }
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl tbody tr td.text p a {
  color: rgba(58, 58, 58, 0.5);
  text-decoration: none;
  font-size: 1.2rem;
}
@media screen and (min-width: 1025px) {
  .maintenance_block_step_content table.maintenance_block_step_content_tbl tbody tr td.price {
    width: 34%;
  }
}
@media screen and (max-width: 1024px) {
  .maintenance_block_step_content table.maintenance_block_step_content_tbl tbody tr td.price {
    padding-left: 4rem;
  }
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl tbody tr td.price dl {
  display: grid;
  align-items: center;
  grid-template-columns: 1fr 1fr;
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl tbody tr td.price dl dt {
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.05em;
  line-height: 2.2rem;
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl tbody tr td.price dl dd {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 22px;
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl2 {
  width: 100%;
}
@media screen and (max-width: 1024px) {
  .maintenance_block_step_content table.maintenance_block_step_content_tbl2 {
    border: none;
  }
}
@media screen and (max-width: 1024px) {
  .maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody {
    border: none;
    padding-bottom: 0;
  }
}
@media screen and (max-width: 1024px) {
  .maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr {
    border: none;
    padding: 0;
    padding-bottom: 7rem;
  }
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr th {
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.2em;
  line-height: 2.7rem;
  text-align: center;
  padding: 3rem 2rem;
}
@media screen and (min-width: 1025px) {
  .maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr th {
    width: 35%;
    border-top: solid 1px #3A3A3A;
    border-bottom: solid 1px #3A3A3A;
  }
}
@media screen and (max-width: 1024px) {
  .maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr th {
    background-color: #F2F3F4;
    padding: 2rem 2rem;
  }
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr th p {
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.2em;
  line-height: 2.7rem;
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr th p + p {
  margin-top: 1.4rem;
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr th p.caution {
  color: var(--red3-col);
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr th .step_label {
  border: solid 1px #D9D9D9;
  font-size: 1.2rem;
  display: inline-block;
  letter-spacing: 0.12em;
  padding: 0 9px;
  margin-bottom: 9px;
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr td {
  border-top: solid 1px #3A3A3A;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
  padding: 3rem 2rem 0;
  text-align: center;
}
@media screen and (min-width: 1025px) {
  .maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr td {
    border-bottom: solid 1px #3A3A3A;
    padding: 3rem 2rem;
    text-align: left;
  }
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr td hr {
  margin: 2rem 0;
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr td p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
}
@media screen and (max-width: 1024px) {
  .maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr td p {
    text-align: left;
  }
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr td p + p, .maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr td p + a {
  margin-top: 2.5rem;
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr td p a.link {
  color: #3A3A3A;
  text-decoration: underline;
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr td p a.btn {
  color: #3A3A3A;
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr td p a:not(.btn):not(.link) {
  color: rgba(58, 58, 58, 0.5);
  text-decoration: none;
  font-size: 1.2rem;
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr td p > span:not(.caution) {
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: 0.08em;
  line-height: 2.4rem;
  color: rgba(58, 58, 58, 0.6);
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr td .box_content {
  background-color: #F2F3F4;
  padding: 2rem;
  margin-top: 2.4rem;
  display: inline-block;
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr td .box_content p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
}
.maintenance_block_step_content table.maintenance_block_step_content_tbl2 tbody tr td .box_content p .caution {
  color: var(--red3-col);
}
.maintenance_block_step_content_grid {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: 2rem;
}
@media screen and (min-width: 1025px) {
  .maintenance_block_step_content_grid {
    grid-template-columns: 1fr 1fr 1fr;
    grid-gap: 3rem;
  }
}
.maintenance_block_step_content_grid_item {
  text-align: center;
  background-color: rgba(150, 150, 150, 0.3);
  padding: 7.8rem 3.5rem 6rem;
}
@media screen and (max-width: 1024px) {
  .maintenance_block_step_content_grid_item {
    padding: 4.5rem 3rem;
  }
}
.maintenance_block_step_content_grid_item h4 {
  font-family: "Source Sans 3", sans-serif;
  font-weight: 400;
  letter-spacing: 0.18em;
  font-size: 1.6rem;
  color: rgba(58, 58, 58, 0.8);
  margin-bottom: 1.3rem;
}
.maintenance_block_step_content_grid_item h3 {
  font-weight: 500;
  letter-spacing: 0.2em;
  font-size: 1.6rem;
  line-height: 2.7rem;
  color: #3a3a3a;
  margin-bottom: 2.1rem;
}
@media screen and (min-width: 1025px) {
  .maintenance_block_step_content_grid_item h3 {
    margin-bottom: 5.6rem;
  }
}
.maintenance_block_step_content_grid_item p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
  text-align: left;
}
@media screen and (max-width: 1024px) {
  .maintenance_block_step_content_grid_item p {
    text-align: justify;
  }
}
.maintenance_block_step_content_grid_item:nth-child(2) {
  background-color: rgba(150, 150, 150, 0.6);
}
.maintenance_block_step_content_grid_item:nth-child(3) {
  background-color: #969696;
  color: var(--base-col);
}
.maintenance_block_step_content_grid_item:nth-child(3) h3,
.maintenance_block_step_content_grid_item:nth-child(3) h4,
.maintenance_block_step_content_grid_item:nth-child(3) p {
  color: var(--base-col);
}
.maintenance_dl {
  background-color: #E9E9E9;
}
.maintenance_dl_inner {
  padding: 8.5rem 9.72vw;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .maintenance_dl_inner {
    padding: 6rem 3.2rem;
  }
}
.maintenance_dl_inner h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  color: #3A3A3A;
  margin-bottom: 4.5rem;
}
@media screen and (max-width: 1024px) {
  .maintenance_dl_inner h3 {
    font-size: 1.6rem;
  }
}
.maintenance_dl_inner .dl_btn {
  max-width: 54rem;
  background-color: #3A3A3A;
  color: var(--base-col);
  padding: 3rem 0;
}
@media screen and (min-width: 1025px) {
  .maintenance_dl_inner .dl_btn {
    padding: 3.5rem 0 5.5rem;
  }
}
@media screen and (min-width: 1025px) {
  .maintenance_dl_inner .dl_btn_inner {
    display: flex;
    align-items: center;
    justify-content: space-evenly;
  }
}
.maintenance_dl_inner .dl_btn_label {
  text-align: center;
}
@media screen and (min-width: 1025px) {
  .maintenance_dl_inner .dl_btn_label {
    text-align: left;
  }
}
@media screen and (max-width: 1024px) {
  .maintenance_dl_inner .dl_btn_label {
    margin-bottom: 2rem;
  }
}
.maintenance_dl_inner .dl_btn_label .btn_l3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
}
.maintenance_dl_inner .dl_btn_label .btn_l4 {
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.2em;
}
@media screen and (max-width: 1024px) {
  .maintenance_dl_inner .dl_btn_label .btn_l4 {
    font-size: 1.3rem;
  }
}
.maintenance_dl_inner .dl_btn_icon img {
  max-width: 5.7rem;
}
.maintenance_flow {
  background-color: var(--base-col);
}
.maintenance_flow_inner {
  padding: 14rem 9.72vw 14rem;
}
@media screen and (max-width: 1024px) {
  .maintenance_flow_inner {
    padding: 6rem 3.2rem;
  }
}
.maintenance_flow_inner h3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  text-align: center;
  margin-bottom: 7rem;
}
.maintenance_flow_grid {
  margin-bottom: 4.5rem;
}
@media screen and (min-width: 1025px) {
  .maintenance_flow_grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: 4.5rem;
  }
}
.maintenance_flow_grid_wrap {
  max-width: 86.3rem;
  margin: 0 auto 0;
}
.maintenance_flow_grid_item {
  display: grid;
  grid-template-rows: 4rem 3rem auto auto;
  text-align: center;
  padding: 2rem 4rem;
  border: solid 3px #D9D9D9;
}
@media screen and (max-width: 1024px) {
  .maintenance_flow_grid_item {
    margin-bottom: 4rem;
  }
}
.maintenance_flow_grid_item h4 {
  font-family: "Source Sans 3", sans-serif;
  font-weight: 400;
  font-size: 2.8rem;
  letter-spacing: 0.18em;
  margin-bottom: 0.9rem;
}
.maintenance_flow_grid_item h3 {
  font-size: 1.6rem;
  letter-spacing: 0.2em;
  line-height: 2.7rem;
  margin-bottom: 0;
}
.maintenance_flow_grid_item p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  line-height: 24px;
  text-align: left;
}
.maintenance_flow_grid_item p span {
  font-size: 1.2rem;
  line-height: 2rem;
  color: rgba(58, 58, 58, 0.7);
}
.maintenance_flow_grid_txt {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-direction: column;
}
.maintenance_flow_grid_txt p {
  width: 100%;
}
.maintenance_flow_txt {
  font-size: 1.2rem;
  line-height: 2.4rem;
  letter-spacing: 0.08em;
  color: rgba(58, 58, 58, 0.6);
}
.maintenance_flow_img {
  padding: 2.4rem;
}
.maintenance_flow_img img {
  width: auto;
  height: 6rem;
}
.maintenance_section {
  transition: all 0.4s ease;
}
.maintenance_section.is_active .maintenance_label {
  opacity: 1;
}

.tab_content {
  display: none;
}
.tab_content.is_active {
  display: block;
}

#factory_tour_page {
  background-color: var(--base-col);
}

.factory_tour {
  width: 100%;
}
.factory_tour_inner {
  padding: 12rem 9.72vw 20rem;
}
@media screen and (max-width: 1024px) {
  .factory_tour_inner {
    padding: 7rem 3.2rem;
  }
}
.factory_tour_contents {
  width: 100%;
  max-width: 100rem;
  margin: 0 auto;
}
.factory_tour_ttl {
  margin-bottom: 3.4rem;
}
.factory_tour_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  margin-bottom: 2rem;
}
.factory_tour_ttl h2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  margin-bottom: 4rem;
}
.factory_tour_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 38px;
  max-width: 63rem;
}
.factory_tour_img {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 1.4rem;
  margin-bottom: 16rem;
}
.factory_tour_img figure:nth-child(1) {
  grid-column: 1/3;
}
.factory_tour_list {
  width: 100%;
  max-width: 62.7rem;
  margin: 0 auto;
}
.factory_tour_list_attention {
  background-color: var(--red2-col);
  color: var(--base-col);
  display: flex;
  align-items: center;
  justify-content: center;
  height: 10rem;
  margin-bottom: 10rem;
}
.factory_tour_list_attention p {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 2;
}
.factory_tour_list_table {
  margin-bottom: 20rem;
}
@media screen and (max-width: 1024px) {
  .factory_tour_list_table {
    margin-bottom: 7rem;
  }
}
.factory_tour_list_table table {
  border-top: solid 1px rgba(58, 58, 58, 0.3);
}
.factory_tour_list_table table th, .factory_tour_list_table table td {
  border-bottom: solid 1px rgba(58, 58, 58, 0.3);
  font-size: 1.4rem;
  padding: 2.4rem 0;
}
@media screen and (max-width: 1024px) {
  .factory_tour_list_table table th, .factory_tour_list_table table td {
    font-size: 1.2rem;
  }
}
.factory_tour_list_table table th {
  width: 25%;
}
@media screen and (max-width: 1024px) {
  .factory_tour_list_table table th {
    width: 32%;
  }
}
.factory_tour_list_table table td span {
  font-size: 1.2rem;
}
@media screen and (max-width: 1024px) {
  .factory_tour_list_table table td span {
    font-size: 1rem;
  }
}
.factory_tour_contact {
  background-color: #ECECEC;
  text-align: center;
}
.factory_tour_contact_inner {
  padding: 5rem 2rem;
}
.factory_tour_contact_inner h3 {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 4.4rem;
  letter-spacing: 0.2em;
}
.factory_tour_contact_inner h4 {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  margin-top: 5px;
}
.factory_tour_contact_inner h5 {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
}
.factory_tour_contact_img {
  padding: 3.5rem 0;
}
.factory_tour_contact_img img {
  max-width: 2.78rem;
}
.factory_tour_contact_link {
  font-family: "Source Sans 3", sans-serif;
  font-size: 2.8rem;
  font-weight: 400;
  letter-spacing: 0.1em;
  margin-top: 1.4rem;
  margin-bottom: 5px;
}
.factory_tour_contact_link a {
  text-decoration: none;
  color: rgba(58, 58, 58, 0.8);
}
.factory_tour_contact_cap {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  color: rgba(58, 58, 58, 0.7);
}
.factory_tour_contact_cap + .factory_tour_contact_cap {
  margin-top: 1.4rem;
}

.support {
  width: 100%;
  background-color: var(--base-col);
}
.support_inner {
  padding: 12rem 9.72vw 7rem;
}
@media screen and (max-width: 1024px) {
  .support_inner {
    padding: 7rem 3.2rem;
  }
}
.support_contents {
  width: 100%;
  max-width: 100rem;
  margin: 0 auto;
}
@media screen and (max-width: 1024px) {
  .support_ttl {
    margin-bottom: 3rem;
  }
}
@media screen and (min-width: 1025px) {
  .support_ttl_wrap {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    justify-content: space-between;
  }
}
.support_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  margin-bottom: 2rem;
}
.support_ttl h2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  margin-bottom: 1.8rem;
}
.support_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 38px;
  max-width: 44.5rem;
}
.support_ttl_btn {
  display: flex;
  justify-content: flex-end;
}
.support_list {
  width: 100%;
  padding: 7rem 0;
  background-color: var(--third-col);
}
@media screen and (max-width: 1024px) {
  .support_list {
    padding: 7rem 3.2rem;
  }
}
.support_list_inner {
  width: 100%;
  max-width: 78rem;
  margin: 0 auto;
}
@media screen and (min-width: 1025px) {
  .support_list_btn {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    grid-gap: 3.7rem;
  }
}
@media screen and (max-width: 1024px) {
  .support_list_btn a + a {
    margin-top: 3rem;
  }
}
.support_contact {
  margin-top: 10rem;
  background-color: #ECECEC;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .support_contact {
    margin-left: -3.2rem;
    margin-right: -3.2rem;
  }
}
.support_contact_inner {
  padding: 5rem 2rem;
}
.support_contact .contact-type {
  max-width: 1160px;
  margin: 0 auto;
  padding: 3rem 3.2rem 1rem;
}
@media screen and (min-width: 1025px) {
  .support_contact .contact-type {
    display: grid;
    grid-template-columns: 1fr 1fr;
    padding: 3rem 0 1rem;
  }
}
.support_contact .contact-type_item {
  text-align: center;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto auto 7rem;
  padding: 5rem 0;
}
@media screen and (min-width: 1025px) {
  .support_contact .contact-type_item {
    padding: 2rem;
  }
}
@media screen and (max-width: 1024px) {
  .support_contact .contact-type_item {
    border-bottom: solid 1px rgba(58, 58, 58, 0.5);
  }
}
@media screen and (min-width: 1025px) {
  .support_contact .contact-type_item:first-child {
    border-right: solid 1px rgba(58, 58, 58, 0.5);
  }
}
@media screen and (max-width: 1024px) {
  .support_contact .contact-type_item:first-child {
    border-top: solid 1px rgba(58, 58, 58, 0.5);
  }
}
.support_contact .contact-type_item h5 {
  font-size: 1.4rem;
  letter-spacing: 0.2em;
}
.support_contact .contact-type_item p {
  font-family: "Source Sans 3", sans-serif;
  font-size: 2.8rem;
  line-height: 1.2;
  letter-spacing: 0.1em;
  color: rgba(58, 58, 58, 0.8);
}
.support_contact .contact-type_item p span {
  font-family: "Noto Serif JP", serif;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  color: rgba(58, 58, 58, 0.7);
}
.support_contact .contact-type_item a {
  text-decoration: none;
  position: relative;
  color: rgba(58, 58, 58, 0.8);
}
.support_contact .contact-type_item a.tel, .support_contact .contact-type_item a.mail {
  display: flex;
  align-items: center;
  margin-inline: auto;
}
.support_contact .contact-type-icon {
  padding: 4rem 0 3rem;
  text-align: center;
}
.support_contact .contact-type-icon img {
  margin: 0 auto;
}
.support_dl {
  width: 100%;
  background-color: var(--base-col);
}
.support_dl_inner {
  padding-bottom: 7rem;
}
@media screen and (min-width: 1025px) {
  .support_dl_inner {
    border-top: solid 1px var(--force-col);
    padding: 14rem 0 7rem;
  }
}
.support_dl_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  margin-bottom: 2rem;
}
.support_dl_ttl h2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
}
.support#support_contact .support_inner {
  padding-bottom: 14rem;
}
.support#support_catalog .support_inner {
  padding-top: 0;
}
.support_dl2 {
  width: 100%;
  background-color: var(--third-col);
  margin-bottom: 17rem;
}
.support_dl2_inner {
  padding: 5rem 0 3.5rem;
  text-align: center;
}
.support_dl2_img {
  margin-bottom: 4rem;
}
.support_dl2_img figure {
  max-width: 30rem;
  margin: 0 auto;
}
@media screen and (max-width: 1024px) {
  .support_dl2_ttl {
    padding: 0 3.2rem;
  }
}
.support_dl2_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 2.6rem;
  letter-spacing: 0.1em;
  margin-bottom: 0.6rem;
  color: rgba(58, 58, 58, 0.7);
}
.support_dl2_ttl h3 a {
  color: rgba(58, 58, 58, 0.7);
  text-decoration: none;
}
.support_dl2_ttl p {
  font-weight: 400;
  font-size: 1.2rem;
  letter-spacing: 0.18em;
  color: rgba(58, 58, 58, 0.5);
}
.support_dl2_ttl p a {
  color: rgba(58, 58, 58, 0.5);
  text-decoration: none;
}
.support_dl2_ttl_cap {
  margin-top: 2rem;
}

.btn.support_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
  background-color: var(--base-col);
  width: 100%;
  max-width: 37rem;
  height: 10rem;
}

.ic-arrow > span {
  display: flex;
  align-items: center;
  grid-gap: 1rem;
}
@media screen and (max-width: 1024px) {
  .ic-arrow > span {
    grid-gap: 0.2rem;
  }
}

#policy_page {
  background-color: var(--base-col);
}

.policy {
  width: 100%;
}
.policy_inner {
  padding: 12rem 9.72vw 20rem;
}
@media screen and (max-width: 1024px) {
  .policy_inner {
    padding: 7rem 3.2rem;
  }
}
.policy_contents {
  width: 100%;
  max-width: 100rem;
  margin: 0 auto;
}
.policy_ttl {
  margin-bottom: 3.4rem;
}
.policy_ttl h3 {
  font-family: var(--font-arial);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  margin-bottom: 2rem;
}
.policy_ttl h2 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  margin-bottom: 4rem;
}
.policy_ttl h4 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 44px;
  font-size: 1.6rem;
  font-weight: bold;
}
.policy_ttl p {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.2em;
  line-height: 38px;
  max-width: 63rem;
}

/* ----------------------------------------------------------------
table
-------------------------------------------------------------------*/
.table tbody th {
  background-color: var(--fifth-col);
}

/* ----------------------------------------------------------------
form
-------------------------------------------------------------------*/
.form-input {
  margin-bottom: 2rem;
  text-align: left;
}
@media screen and (min-width: 1025px) {
  .form-input {
    display: grid;
    grid-template-columns: 200px 1fr;
    grid-gap: 4rem;
    align-items: flex-start;
    justify-content: flex-start;
  }
}
@media screen and (min-width: 1025px) {
  .form-input-label {
    text-align: right;
  }
}
@media screen and (max-width: 1024px) {
  .form-input-label {
    margin-bottom: 1rem;
  }
}
.form-input-label label {
  display: block;
  width: 100%;
  font-family: var(--font-secondary);
  font-size: 1.6rem;
  font-weight: bold;
}
.form-input-label label span {
  background-color: var(--red-col);
  color: var(--white-col);
  font-weight: normal;
  font-size: 1.2rem;
  padding: 2px 6px;
}
.form-input-data {
  width: 100%;
}
@media screen and (min-width: 1025px) {
  .form-input-inline {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    grid-gap: 1rem;
  }
  .form-input-inline label {
    font-size: 1.4rem;
  }
}
.form-input input,
.form-input select,
.form-input textarea {
  font-family: var(--font-secondary);
  display: block;
  width: 100%;
  text-align: left;
  border: solid 1px var(--border-form-col);
  height: 30px;
  padding: 0 1rem;
}
.form-input input,
.form-input select {
  height: 4rem;
  line-height: 3.8rem;
}
.form-input textarea {
  min-height: 12rem;
  padding: 1rem;
}

.radio,
.checkbox {
  margin-top: 0 !important;
  margin-bottom: 0;
  display: inline-block;
  padding-top: 0 !important;
}
.radio label,
.checkbox label {
  line-height: 1.8;
  padding-left: 0;
  margin-right: 10px;
  font-family: var(--font-secondary);
  font-size: 14px;
  color: var(--txt-col);
}
.radio label > input[type=checkbox],
.checkbox label > input[type=checkbox] {
  margin-right: 5px;
}

.checkbox input[type=checkbox] {
  line-height: 1;
  -webkit-appearance: none;
  appearance: none;
  box-sizing: border-box;
  min-height: 0 !important;
  min-width: 14px;
  padding: 0;
  background-color: #fff;
  font-size: 14px;
  box-shadow: rgba(0, 0, 0, 0) 0 0 0 0, rgba(0, 0, 0, 0) 0 0 0 0, rgba(0, 0, 0, 0.05) 0 1px 2px 0;
  display: inline-block !important;
  margin: 0;
  width: 2rem;
  height: 2rem;
  cursor: pointer;
  position: relative;
  transition: all linear 0.1s;
  border-style: solid;
  border-width: 1px;
  border-color: var(--border-form-col);
  border-radius: 2px !important;
  vertical-align: middle;
}
.checkbox input[type=checkbox]:checked {
  background-size: 18px !important;
  border-color: transparent;
  background-size: 100% 100%;
  background-position: 50%;
  background-repeat: no-repeat;
  background-color: var(--check-active-col);
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 16 16' fill='%23333' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3E%3C/svg%3E");
}
.checkbox input[type=checkbox]:disabled {
  border-color: #DDDDDD;
  background-color: #EEEEEE;
}
.checkbox input[type=checkbox]:before {
  content: "";
  width: 14px;
  height: 14px;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.checkbox input[type=checkbox]:focus {
  outline: none;
}
.checkbox-group {
  display: flex;
  align-items: center;
  grid-gap: 1rem;
  margin-top: 1rem;
}

.form-confirm-text {
  margin-bottom: 2rem;
  font-family: var(--font-secondary);
  font-size: 1.8rem;
  text-align: center;
  padding: 2rem 0;
}
@media screen and (max-width: 1024px) {
  .form-confirm-text {
    font-size: 1.4rem;
  }
}

.form-btn {
  text-align: center;
}
.form-btn p {
  display: inline-block;
}

/* ----------------------------------------------------------------
btns
-------------------------------------------------------------------*/
.btn {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
  --txt-col: var(--btn-txt-col);
  --bg-col: var(--btn-txt-col);
  width: 100%;
  min-height: 4.7rem;
  display: inline-block;
  background: none;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.2s ease;
  border: none;
  padding: 1rem 2rem;
  color: var(--txt-col);
  position: relative;
  z-index: 2;
  max-width: 28.5rem;
  line-height: 2.6rem;
}
@media screen and (max-width: 1024px) {
  .btn {
    max-width: 16.1rem;
    font-family: var(--font-primary);
    font-weight: 500;
    font-size: 1.2rem;
    letter-spacing: 0.12em;
    line-height: 1.8;
    padding-top: 1.1rem;
  }
}
.btn span {
  position: relative;
  z-index: 2;
}
.btn:after {
  content: "";
  position: absolute;
  left: -1px;
  top: -1px;
  bottom: -1px;
  right: -1px;
  z-index: 1;
  border: solid 1px var(--bg-col);
  display: block;
  transition: all 0.2s ease;
}
.btn:hover {
  opacity: 0.8;
}

.btn-auto {
  max-width: 100%;
  width: auto;
}

.btn-xl {
  max-width: 46rem;
  height: 8rem;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 1024px) {
  .btn-xl {
    font-size: 1.4rem;
  }
}

.btn-l {
  max-width: 40rem;
}

.btn-xm {
  max-width: 40rem;
  height: auto;
  min-height: 3.4rem;
  border-radius: 0.6rem;
  line-height: 1.4;
  padding: 1rem 2rem;
}
.btn-xm:after {
  content: "";
  border-radius: 0.6rem;
}
@media screen and (max-width: 1024px) {
  .btn-xm {
    font-size: 1.2rem;
  }
}

.btn-m {
  max-width: 16rem;
  height: 4.7rem;
  font-size: 1.2rem;
  letter-spacing: 0.12em;
}

.btn-s {
  --bg-col: var(--force-col);
  width: 100%;
  max-width: 9.5rem;
  height: 2rem;
  padding: 0;
  min-height: 2rem;
  line-height: 1.8rem;
}

@media screen and (max-width: 1024px) {
  .s_btn-s {
    width: 100%;
    max-width: 18rem;
    height: 4rem;
    line-height: 1.4;
    font-size: 1.1rem;
    letter-spacing: 0;
    padding: 0 1rem;
    border-radius: 5px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .s_btn-s:after {
    content: "";
    border-radius: 5px;
  }
}

.btn-xs {
  max-width: 3rem;
  height: 2.8rem;
  line-height: 2.6rem;
  font-size: 1.4rem;
  padding: 0;
}

.btn-secondary {
  --bg-col: var(--secondary-col);
  background-color: var(--bg-col);
}

.btn-cancel {
  --bg-col: var(--nine-col);
  background-color: var(--bg-col);
}

.btn-red {
  --bg-col: var(--red-col);
  background-color: var(--bg-col);
}

.btn:disabled,
.btn.disabled {
  --bg-col: var(--disabled-btn-col);
  --txt-col: var(--disabled-btn-txt-col);
  cursor: default;
}
.btn:disabled:hover:after,
.btn.disabled:hover:after {
  transform: scale(1);
}

.btn_l1 {
  font-family: var(--font-primary);
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  line-height: 26px;
}

.btn_l2 {
  font-family: var(--font-primary);
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  line-height: 26px;
}

.btn_l3 {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
}

.btn_l4 {
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.12em;
}

/* ----------------------------------------------------------------
icon
-------------------------------------------------------------------*/
.icon {
  vertical-align: middle;
  display: inline-block;
}

.icon-target {
  width: 12px;
  height: 11px;
}

.icon-cart {
  width: 21px;
  height: 22px;
}

.icon-circle {
  fill: none;
}

.icon-instagram {
  width: 20px;
  height: 20px;
}

.icon-web {
  width: 20px;
  height: 20px;
}

.icon-mail {
  width: 20px;
  height: 15px;
}

.icon-pdf {
  width: 1.7rem;
  height: 1.8rem;
  margin-right: 0.4rem;
}

.icon-arrow {
  width: 1.4rem;
  height: 0.8rem;
  fill: none;
}

/* ----------------------------------------------------------------
plugin
-------------------------------------------------------------------*/
.swiper-button-next,
.swiper-button-prev {
  width: 15px;
  height: 30px;
  background: none;
}
.swiper-button-next:hover,
.swiper-button-prev:hover {
  transition: all 0.2s ease;
  opacity: 0.5;
}
.swiper-button-next svg,
.swiper-button-prev svg {
  width: 15px;
  height: 30px;
  fill: none;
  color: var(--seven-col);
}

.swiper-button-next,
.swiper-rtl .swiper-button-prev {
  right: 0;
}
@media screen and (min-width: 1025px) {
  .swiper-button-next,
  .swiper-rtl .swiper-button-prev {
    right: 0;
  }
}
.swiper-button-next:after,
.swiper-rtl .swiper-button-prev:after {
  display: none;
}

.swiper-button-prev,
.swiper-rtl .swiper-button-next {
  left: 0;
}
@media screen and (min-width: 1025px) {
  .swiper-button-prev,
  .swiper-rtl .swiper-button-next {
    left: 0;
  }
}
.swiper-button-prev:after,
.swiper-rtl .swiper-button-next:after {
  display: none;
}

.eu_anim {
  /*
  overflow: hidden;
  */
  opacity: 0;
}
.eu_anim.is_show {
  opacity: 1;
}
.eu_anim_fade_item {
  opacity: 0;
}
.eu_anim_fade_item.is_show {
  opacity: 1;
  transition: all 0.8s linear;
}
.eu_anim_wide_item {
  position: relative;
}
.eu_anim_wide_item:before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 2;
  background-color: var(--bg-col);
  transform: scaleX(1);
  transition: all 0.8s linear;
}
.eu_anim_wide_item.is_show:before {
  transform: scaleX(0);
}
.eu_anim_window_left {
  opacity: 0;
  transform: translateX(-400px);
}
.eu_anim_window_right {
  opacity: 0;
  transform: translateX(400px);
}
.eu_anim_window.is_show .eu_anim_window_left {
  opacity: 1;
  transform: translateX(0px);
  transition: all 0.8s linear;
}
.eu_anim_window.is_show .eu_anim_window_right {
  opacity: 1;
  transform: translateX(0px);
  transition: all 0.8s linear;
}
.eu_anim_slidetop_item, .eu_anim_slidetop_list {
  opacity: 0;
  transform: translateY(20px);
  transition: all 1.1s ease;
  transition-delay: 0s;
}
.eu_anim_slidetop_item.is_show, .eu_anim_slidetop_list.is_show {
  opacity: 1;
  transform: translateY(0px);
}

#eu_anim_section1_1 {
  opacity: 0;
}

#eu_anim_section1_2 {
  opacity: 0;
  transition: all 0.3s linear;
}
#eu_anim_section1_2.is_show {
  opacity: 1;
}

.eu_anim_section2 {
  opacity: 0;
  transition: all 1s linear;
  transform: translateY(50px);
}
.eu_anim_section2.is_show {
  opacity: 1;
  transform: translateY(0px);
}

/* ----------------------------------------------------------------
utility
-------------------------------------------------------------------*/
.text-center {
  text-align: center !important;
}

@media screen and (max-width: 1024px) {
  .s_text-center {
    text-align: center !important;
  }
}

.text-right {
  text-align: right !important;
}

.text-left {
  text-align: left !important;
}

.align-center {
  align-items: center !important;
}

.flex {
  display: flex;
  align-items: flex-start;
}

.between {
  justify-content: space-between;
}

.target {
  position: relative;
}
.target:after {
  content: "";
  width: 12.25px;
  height: 11.06px;
  background-image: url(../img/ico_link_target.svg);
  background-size: contain;
  background-repeat: no-repeat;
  display: inline-block;
  margin-left: 1rem;
}

.down {
  position: relative;
  padding-right: 2rem;
}
.down:after {
  content: "";
  width: 12px;
  height: 6px;
  background-image: url(../img/ico_down.svg);
  background-size: contain;
  background-repeat: no-repeat;
  display: inline-block;
  margin-left: 1rem;
  position: absolute;
  right: 0;
  top: 50%;
  margin-top: -3px;
}

.mb10 {
  margin-bottom: 10px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.mb70 {
  margin-bottom: 70px !important;
}

.mb80 {
  margin-bottom: 80px !important;
}

.mb90 {
  margin-bottom: 90px !important;
}

.mb100 {
  margin-bottom: 100px !important;
}

.mt0 {
  margin-top: 0px !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mt30 {
  margin-top: 30px !important;
}

.mt40 {
  margin-top: 40px !important;
}

.mt50 {
  margin-top: 50px !important;
}

.mt60 {
  margin-top: 60px !important;
}

.mt70 {
  margin-top: 70px !important;
}

.mt80 {
  margin-top: 80px !important;
}

.mt90 {
  margin-top: 90px !important;
}

.mt100 {
  margin-top: 100px !important;
}

.ml10 {
  margin-left: 10px !important;
}

.ml20 {
  margin-left: 20px !important;
}

.ml30 {
  margin-left: 30px !important;
}

.ml40 {
  margin-left: 40px !important;
}

.ml50 {
  margin-left: 50px !important;
}

.ml60 {
  margin-left: 60px !important;
}

.ml70 {
  margin-left: 70px !important;
}

.ml80 {
  margin-left: 80px !important;
}

.ml90 {
  margin-left: 90px !important;
}

.ml100 {
  margin-left: 100px !important;
}

.pt10 {
  padding-top: 10px !important;
}

.pt20 {
  padding-top: 20px !important;
}

.pt30 {
  padding-top: 30px !important;
}

.pt40 {
  padding-top: 40px !important;
}

.pt50 {
  padding-top: 50px !important;
}

.pt60 {
  padding-top: 60px !important;
}

.pt70 {
  padding-top: 70px !important;
}

.pt80 {
  padding-top: 80px !important;
}

.pt90 {
  padding-top: 90px !important;
}

.pt100 {
  padding-top: 100px !important;
}

.font-12 {
  font-size: 12px !important;
}

.font-13 {
  font-size: 13px !important;
}

.font-14 {
  font-size: 14px !important;
}

.font-15 {
  font-size: 15px !important;
}

.font-16 {
  font-size: 16px !important;
}

.font-17 {
  font-size: 17px !important;
}

.font-18 {
  font-size: 18px !important;
}

.font-19 {
  font-size: 19px !important;
}

.font-20 {
  font-size: 20px !important;
}

.font-21 {
  font-size: 21px !important;
}

.font-22 {
  font-size: 22px !important;
}

.font-23 {
  font-size: 23px !important;
}

.font-24 {
  font-size: 24px !important;
}

.font-25 {
  font-size: 25px !important;
}

.font-26 {
  font-size: 26px !important;
}

.font-27 {
  font-size: 27px !important;
}

.font-28 {
  font-size: 28px !important;
}

.font-29 {
  font-size: 29px !important;
}

.font-30 {
  font-size: 30px !important;
}

@media screen and (max-width: 1024px) {
  .s_font-12 {
    font-size: 12px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-13 {
    font-size: 13px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-14 {
    font-size: 14px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-15 {
    font-size: 15px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-16 {
    font-size: 16px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-17 {
    font-size: 17px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-18 {
    font-size: 18px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-19 {
    font-size: 19px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-20 {
    font-size: 20px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-21 {
    font-size: 21px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-22 {
    font-size: 22px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-23 {
    font-size: 23px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-24 {
    font-size: 24px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-25 {
    font-size: 25px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-26 {
    font-size: 26px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-27 {
    font-size: 27px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-28 {
    font-size: 28px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-29 {
    font-size: 29px !important;
  }
}

@media screen and (max-width: 1024px) {
  .s_font-30 {
    font-size: 30px !important;
  }
}

.small {
  font-size: 0.6em !important;
}

@media screen and (min-width: 1025px) {
  .sp {
    display: none;
  }
}

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

.red {
  color: #ff0000 !important;
}