@charset "UTF-8";
/*-------------------------------------------------------------------------------------------------------
*********************************************************************************************************
*********************************************************************************************************
******
****** PCスタイル
******
*********************************************************************************************************
*********************************************************************************************************
-------------------------------------------------------------------------------------------------------*/
html {
  font-size: 10px;
}

/*----------------------------------------------------------------------------
******************************************************************************
** common class
******************************************************************************
----------------------------------------------------------------------------*/
.sp {
  display: none !important;
}

a[href*="tel:"] {
  pointer-events: none;
}

.clearfix::after {
  content: "";
  clear: both;
  display: block;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  border: 0;
}

.container_100 {
  width: 100%;
  padding: 0 2rem;
}
.container_100 .container {
  width: 100%;
  max-width: 137rem;
  margin: 0 auto;
}

.dib {
  display: inline-block;
}

main {
  --hdMt: 11em;
}
main.sub_page {
  --hdMt: 15.4rem;
}
@media screen and (max-width: 1259.9px) {
  main {
    --hdMt: 8rem !important;
  }
}
main {
  margin-top: var(--hdMt) !important;
}
main .anchor {
  display: block;
  position: relative;
  top: calc(-1 * var(--hdMt));
  height: 0;
  visibility: hidden;
}

/*----------------------------------------------------------------------------
******************************************************************************
** header
******************************************************************************
----------------------------------------------------------------------------*/
@media screen and (min-width: 1260px) {
  .hd {
    width: 100%;
    min-height: 11rem;
    background-color: #fff;
    padding-top: 3rem;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 99;
  }
  .hd .container {
    max-width: 180rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .hd .container .hd_logo {
    width: 29.6rem;
  }
  .hd .container .hd_logo a {
    -webkit-transition: 0.2s;
    transition: 0.2s;
  }
  .hd .container .hd_logo a:hover {
    opacity: 0.7;
  }
  .hd .container .menu {
    width: calc(100% - 32.6rem);
    padding-top: 0.3rem;
  }
  .hd .container .menu nav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .hd .container .menu nav .main_nav_list {
    width: 100%;
    max-width: 94rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 1rem;
  }
  .hd .container .menu nav .main_nav_list li:not(.shop) {
    width: 100%;
    max-width: 20rem;
  }
  .hd .container .menu nav .main_nav_list li:not(.shop) a,
  .hd .container .menu nav .main_nav_list li:not(.shop) > span {
    width: 100%;
    height: 5rem;
    text-align: center;
    border-radius: 5rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 1rem;
    border: solid 0.1rem #262626;
    overflow: hidden;
    cursor: pointer;
    -webkit-transition: 0.2s;
    transition: 0.2s;
    position: relative;
  }
  .hd .container .menu nav .main_nav_list li:not(.shop) a::before,
  .hd .container .menu nav .main_nav_list li:not(.shop) > span::before {
    content: "";
    width: 100%;
    height: 100%;
    background-color: #19396d;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
    -webkit-transform-origin: left center;
            transform-origin: left center;
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  .hd .container .menu nav .main_nav_list li:not(.shop) a > span,
  .hd .container .menu nav .main_nav_list li:not(.shop) > span > span {
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: 0.05em;
    position: relative;
    z-index: 2;
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  .hd .container .menu nav .main_nav_list li:not(.shop) a:hover::before,
  .hd .container .menu nav .main_nav_list li:not(.shop) > span:hover::before {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  .hd .container .menu nav .main_nav_list li:not(.shop) a:hover > span,
  .hd .container .menu nav .main_nav_list li:not(.shop) > span:hover > span {
    color: #fff;
  }
  .hd .container .menu nav .main_nav_list li.shop {
    max-width: 3.4rem;
    -webkit-transform: scale(-1, 1);
            transform: scale(-1, 1);
    -webkit-filter: brightness(0);
            filter: brightness(0);
    padding-top: 0.6rem;
  }
  .hd .container .menu nav .main_nav_list li.shop a {
    display: inline-block;
  }
  .hd .container .menu nav .sub_nav_list {
    width: 100%;
    max-width: 93rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    gap: 3.4rem;
    margin-top: 2rem;
    display: none;
  }
  .hd .container .menu nav .sub_nav_list.show {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .hd .container .menu nav .sub_nav_list > li.hasclist {
    position: relative;
    padding-bottom: 0.6rem;
    --color: #000;
  }
  .hd .container .menu nav .sub_nav_list > li.hasclist::before {
    content: "";
    width: 100%;
    height: 0.1rem;
    background-color: var(--color);
    position: absolute;
    bottom: 0;
    left: 0;
  }
  .hd .container .menu nav .sub_nav_list > li.hasclist.blue {
    --color: #3878bf;
  }
  .hd .container .menu nav .sub_nav_list > li.hasclist.green {
    --color: #009944;
  }
  .hd .container .menu nav .sub_nav_list > li.hasclist > span {
    padding-right: 1.6em;
  }
  .hd .container .menu nav .sub_nav_list > li.hasclist > span::before {
    content: "";
    width: 2rem;
    aspect-ratio: 1/1;
    position: absolute;
    top: 0.3rem;
    right: 0;
    background-color: var(--color);
    border-radius: 50%;
    -webkit-transition: 0.2s;
    transition: 0.2s;
  }
  .hd .container .menu nav .sub_nav_list > li.hasclist > span::after {
    content: "";
    width: 0.7rem;
    aspect-ratio: 1/1;
    border-right: solid 0.1rem #fff;
    border-bottom: solid 0.1rem #fff;
    position: absolute;
    top: 0.8rem;
    right: 0.65rem;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    -webkit-transform-origin: center;
            transform-origin: center;
    -webkit-transition: 0.2s;
    transition: 0.2s;
  }
  .hd .container .menu nav .sub_nav_list > li.hasclist.open .sub_nav_clist_wrap {
    pointer-events: auto;
  }
  .hd .container .menu nav .sub_nav_list > li.hasclist.open .sub_nav_clist_wrap .sub_nav_clist_inner {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
  .hd .container .menu nav .sub_nav_list > li > a,
  .hd .container .menu nav .sub_nav_list > li > span {
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.625;
    letter-spacing: 0.05em;
    -webkit-transition: 0.2s;
    transition: 0.2s;
    cursor: pointer;
  }
  .hd .container .menu nav .sub_nav_list > li > a:hover {
    opacity: 0.7;
  }
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap {
    position: absolute;
    top: 3rem;
    left: -2rem;
    overflow: hidden;
    pointer-events: none;
  }
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner {
    padding: 1.8rem 0 0 1.9rem;
    -webkit-transform: translateY(-101%);
            transform: translateY(-101%);
    -webkit-transition: 0.4s;
    transition: 0.4s;
  }
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner .sub_nav_clist {
    min-width: 25rem;
    border-radius: 0.5rem;
    background-color: var(--color);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    z-index: 2;
  }
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner .sub_nav_clist > li {
    border-bottom: solid 0.1rem rgba(255, 255, 255, 0.4);
  }
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner .sub_nav_clist > li:last-of-type {
    border-bottom: none;
  }
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner .sub_nav_clist > li > a,
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner .sub_nav_clist > li > span {
    width: 100%;
    min-height: 5rem;
    font-size: 1.4rem;
    color: #fff;
    font-weight: 500;
    line-height: 1.625;
    letter-spacing: 0.05em;
    white-space: nowrap;
    padding: 1rem 4rem 1rem 2rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    position: relative;
    -webkit-transition: 0.2s;
    transition: 0.2s;
  }
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner .sub_nav_clist > li > a::before,
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner .sub_nav_clist > li > span::before {
    content: "";
    width: 1.2rem;
    height: 1.1rem;
    background: url(../images/common/common_arrow01.png) no-repeat center/contain;
    -webkit-filter: brightness(0) invert(1);
            filter: brightness(0) invert(1);
    position: absolute;
    top: 50%;
    right: 2rem;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    -webkit-transition: 0.2s;
    transition: 0.2s;
  }
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner .sub_nav_clist > li > a:hover,
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner .sub_nav_clist > li > span:hover {
    opacity: 0.7;
  }
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner .sub_nav_clist > li > a:hover::before,
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner .sub_nav_clist > li > span:hover::before {
    right: 1rem;
  }
  .hd .container .menu nav .nav_sns {
    width: 8rem;
    display: grid;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 3rem;
    position: fixed;
    top: calc(50% + 18.2rem);
    right: 0;
    z-index: 99;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .hd .container .menu nav .nav_sns li a {
    display: inline-block;
    -webkit-transition: 0.2s;
    transition: 0.2s;
  }
  .hd .container .menu nav .nav_sns li a:hover {
    opacity: 0.7;
  }
  .hd .container .menu nav .nav_sns.change_color li a {
    -webkit-filter: brightness(0) invert(1);
            filter: brightness(0) invert(1);
  }
  .hd .container .menu_trigger {
    display: none;
  }
  .hd.sub_page {
    min-height: 15.4rem;
  }
  .hd.sub_page .container .menu nav .main_nav_list {
    max-width: 26.5rem;
  }
}
@media screen and (max-width: 1259.9px) {
  .hd {
    width: 100%;
    height: 8rem;
    padding: 1rem 1.5rem;
    background-color: #fff;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100;
  }
  .hd .container {
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .hd .container .hd_logo {
    width: 25rem;
  }
  .hd .container .hd_logo a {
    -webkit-transition: 0.2s;
    transition: 0.2s;
  }
  .hd .container .hd_logo a:hover {
    opacity: 0.7;
  }
  .hd .container .menu {
    width: 50rem;
    height: calc(100vh - 8rem);
    overflow-y: scroll;
    padding: 3rem 2rem 5rem;
    background-color: #19396d;
    position: fixed;
    top: 8rem;
    right: -100%;
    z-index: 100;
    -webkit-transition: 0.4s;
    transition: 0.4s;
  }
  .hd .container .menu.open {
    right: 0;
  }
  .hd .container .menu nav .main_nav_list {
    width: 100%;
    display: grid;
    gap: 2rem;
  }
  .hd .container .menu nav .main_nav_list li {
    width: 100%;
  }
  .hd .container .menu nav .main_nav_list li a,
  .hd .container .menu nav .main_nav_list li > span {
    width: 100%;
    height: 5.5rem;
    text-align: center;
    border-radius: 5rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    border: solid 0.1rem #fff;
    background-color: #fff;
    cursor: pointer;
    -webkit-transition: 0.2s;
    transition: 0.2s;
  }
  .hd .container .menu nav .main_nav_list li a:hover,
  .hd .container .menu nav .main_nav_list li > span:hover {
    opacity: 0.7;
  }
  .hd .container .menu nav .main_nav_list li a > span,
  .hd .container .menu nav .main_nav_list li > span > span {
    font-size: 1.5rem;
    color: #19396d;
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: 0.05em;
  }
  .hd .container .menu nav .main_nav_list li.shop a {
    background-color: #f2f238;
    border: none;
  }
  .hd .container .menu nav .main_nav_list li.shop a .icon {
    width: 3.4rem;
    -webkit-transform: scale(-1, 1);
            transform: scale(-1, 1);
  }
  .hd .container .menu nav .sub_nav_list {
    width: 100%;
    border-top: solid 0.1rem rgba(255, 255, 255, 0.4);
    margin-top: 5rem;
  }
  .hd .container .menu nav .sub_nav_list > li {
    border-bottom: solid 0.1rem rgba(255, 255, 255, 0.4);
  }
  .hd .container .menu nav .sub_nav_list > li.hasclist {
    position: relative;
  }
  .hd .container .menu nav .sub_nav_list > li.hasclist > span::before {
    -webkit-transform: translateY(-50%) rotate(90deg);
            transform: translateY(-50%) rotate(90deg);
  }
  .hd .container .menu nav .sub_nav_list > li > a,
  .hd .container .menu nav .sub_nav_list > li > span {
    width: 100%;
    font-size: 1.5rem;
    color: #fff;
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: 0.05em;
    display: inline-block;
    padding: 2.2rem 5rem 2rem 0.5rem;
    position: relative;
  }
  .hd .container .menu nav .sub_nav_list > li > a::before,
  .hd .container .menu nav .sub_nav_list > li > span::before {
    content: "";
    width: 2.775rem;
    aspect-ratio: 1/1;
    border-radius: 50%;
    background: -webkit-image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1rem, #f2f238;
    background: image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1rem, #f2f238;
    position: absolute;
    top: 50%;
    right: 1rem;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    -webkit-transition: 0.2s;
    transition: 0.2s;
  }
  .hd .container .menu nav .sub_nav_list > li > a:hover::before {
    right: 0;
  }
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap {
    width: 100%;
  }
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner {
    width: 100%;
  }
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner .sub_nav_clist {
    width: 100%;
    padding: 0 5rem 2rem 1.5rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 1rem;
    -webkit-transition: 0.2s;
    transition: 0.2s;
  }
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner .sub_nav_clist > li > a,
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner .sub_nav_clist > li > span {
    font-size: 1.4rem;
    font-weight: 500;
    color: #fff;
    line-height: 1.625;
    letter-spacing: 0.05em;
    white-space: nowrap;
    -webkit-transition: 0.2s;
    transition: 0.2s;
  }
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner .sub_nav_clist > li > a:hover,
  .hd .container .menu nav .sub_nav_list > li .sub_nav_clist_wrap .sub_nav_clist_inner .sub_nav_clist > li > span:hover {
    opacity: 0.7;
  }
  .hd .container .menu nav .nav_tel {
    padding-top: 5.3rem;
  }
  .hd .container .menu nav .nav_tel a {
    display: inline-block;
    padding-left: 2.2rem;
  }
  .hd .container .menu nav .nav_tel a .num {
    font-family: "Jost";
    font-size: 3.6835rem;
    color: #fff;
    font-weight: 500;
    line-height: 1.25;
    letter-spacing: 0;
    padding-left: 5.4rem;
    position: relative;
  }
  .hd .container .menu nav .nav_tel a .num::before {
    content: "";
    width: 3.95rem;
    height: 2.65rem;
    background: url(../images/common/tel_icon.png) no-repeat center/contain;
    background: url(../images/common/tel_icon.svg) no-repeat center/contain;
    position: absolute;
    top: 1.3rem;
    left: 0.7rem;
    -webkit-filter: brightness(0) invert(1);
            filter: brightness(0) invert(1);
  }
  .hd .container .menu nav .nav_tel a .num .mr-20 {
    margin-right: -2rem;
  }
  .hd .container .menu nav .nav_tel a .num rt {
    font-family: YakuHanJP, "Noto Sans JP";
    font-size: 1.315rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -1.2em;
    position: relative;
    top: -0.4rem;
    left: -0.9rem;
  }
  .hd .container .menu nav .nav_tel a .num rt.ls {
    letter-spacing: 0.1em;
    left: 0;
  }
  .hd .container .menu nav .nav_tel a .txt {
    font-size: 1.4rem;
    color: #fff;
    font-weight: 400;
    line-height: 1.625;
    letter-spacing: 0.05em;
    text-align: center;
    display: block;
    margin-top: -0.1rem;
  }
  .hd .container .menu nav .nav_sns {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 3rem;
    margin-top: 6rem;
  }
  .hd .container .menu nav .nav_sns li.facebook {
    width: 3.2rem;
  }
  .hd .container .menu nav .nav_sns li.instagram {
    width: 3.05rem;
  }
  .hd .container .menu nav .nav_sns li a {
    width: 100%;
    display: inline-block;
    -webkit-filter: brightness(0) invert(1);
            filter: brightness(0) invert(1);
    -webkit-transition: 0.2s;
    transition: 0.2s;
  }
  .hd .container .menu nav .nav_sns li a img {
    width: 100%;
  }
  .hd .container .menu nav .nav_sns li a:hover {
    opacity: 0.7;
  }
  .hd .container .menu_trigger {
    width: 6rem;
    aspect-ratio: 1/1;
    position: absolute;
    top: 1rem;
    right: 1.5rem;
  }
  .hd .container .menu_trigger span {
    width: 3.3rem;
    height: 0.15rem;
    background-color: #19396d;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    -webkit-transition: 0.2s;
    transition: 0.2s;
  }
  .hd .container .menu_trigger span:nth-of-type(1) {
    top: calc(50% - 1rem);
  }
  .hd .container .menu_trigger span:nth-of-type(3) {
    top: calc(50% + 1rem);
  }
  .hd .container .menu_trigger.active span {
    top: 50%;
  }
  .hd .container .menu_trigger.active span:nth-of-type(1) {
    -webkit-transform: translate(-50%, -50%) rotate(35deg);
            transform: translate(-50%, -50%) rotate(35deg);
  }
  .hd .container .menu_trigger.active span:nth-of-type(2) {
    opacity: 0;
  }
  .hd .container .menu_trigger.active span:nth-of-type(3) {
    -webkit-transform: translate(-50%, -50%) rotate(-35deg);
            transform: translate(-50%, -50%) rotate(-35deg);
  }
}
/*----------------------------------------------------------------------------
******************************************************************************
** hero
******************************************************************************
----------------------------------------------------------------------------*/
@-webkit-keyframes textClip {
  to {
    clip-path: inset(0 0 0 0);
  }
}
@keyframes textClip {
  to {
    clip-path: inset(0 0 0 0);
  }
}
@-webkit-keyframes humanClip {
  to {
    clip-path: inset(0 0 0 0);
  }
}
@keyframes humanClip {
  to {
    clip-path: inset(0 0 0 0);
  }
}
@-webkit-keyframes drawS {
  to {
    stroke-dashoffset: 0;
  }
}
@keyframes drawS {
  to {
    stroke-dashoffset: 0;
  }
}
.hero_sec {
  overflow: hidden;
  background: -webkit-image-set(url(../images/top/hero_bg.png) 1x, url(../images/top/hero_bg@2x.png) 2x) no-repeat center bottom/cover;
  background: image-set(url(../images/top/hero_bg.png) 1x, url(../images/top/hero_bg@2x.png) 2x) no-repeat center bottom/cover;
  padding: 0;
}
.hero_sec .container {
  max-width: initial;
}
.hero_sec .container .hero_slider {
  width: 100%;
}
.hero_sec .container .hero_slider .hero_pagination {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 2rem;
  padding-bottom: 2rem;
}
.hero_sec .container .hero_slider .hero_pagination .swiper-pagination-bullet {
  width: 1.4rem;
  height: auto;
  aspect-ratio: 1/1;
  margin: 0;
}
.hero_sec .container .hero_slider .hero_pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background-color: #19396d;
}
.hero_sec .container .hero_slider .swiper-wrapper {
  -webkit-transition-timing-function: ease-in-out;
          transition-timing-function: ease-in-out;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide {
  overflow: hidden;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide a {
  display: block;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide.is-visible .hero_slide01 .hero_slide01_text .ttl::before {
  -webkit-animation: textClip 0.4s ease-out 1.2s forwards;
          animation: textClip 0.4s ease-out 1.2s forwards;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide.is-visible .hero_slide01 .hero_slide01_text .ttl picture {
  -webkit-animation: textClip 0.4s ease-out 0.8s forwards;
          animation: textClip 0.4s ease-out 0.8s forwards;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide.is-visible .hero_slide01 .hero_slide01_text .txt picture {
  -webkit-animation: textClip 0.4s ease-out 1.2s forwards;
          animation: textClip 0.4s ease-out 1.2s forwards;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide.is-visible .hero_slide01 .hero_slide01_text .s svg {
  -webkit-animation: drawS 1s ease-out forwards;
          animation: drawS 1s ease-out forwards;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide.is-visible .hero_slide01 .hero_slide01_bg .sand {
  -webkit-animation: humanClip 0.4s ease-out 0.6s forwards;
          animation: humanClip 0.4s ease-out 0.6s forwards;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide.is-visible .hero_slide01 .hero_slide01_bg .human {
  -webkit-animation: humanClip 1s ease-out 0.8s forwards;
          animation: humanClip 1s ease-out 0.8s forwards;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide.is-visible .hero_slide02 .hero_slide02_text .ttl::before {
  -webkit-animation: textClip 0.4s ease-out 1.2s forwards;
          animation: textClip 0.4s ease-out 1.2s forwards;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide.is-visible .hero_slide02 .hero_slide02_text .ttl picture {
  -webkit-animation: textClip 0.4s ease-out 0.8s forwards;
          animation: textClip 0.4s ease-out 0.8s forwards;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide.is-visible .hero_slide02 .hero_slide02_text .txt picture {
  -webkit-animation: textClip 0.4s ease-out 1.2s forwards;
          animation: textClip 0.4s ease-out 1.2s forwards;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide.is-visible .hero_slide02 .hero_slide02_bg .sand {
  -webkit-animation: humanClip 0.4s ease-out 0.6s forwards;
          animation: humanClip 0.4s ease-out 0.6s forwards;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide.is-visible .hero_slide02 .hero_slide02_bg .human {
  -webkit-animation: humanClip 1s ease-out 0.8s forwards;
          animation: humanClip 1s ease-out 0.8s forwards;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide.is-visible .hero_slide03 .hero_slide03_text .ttl::before {
  -webkit-animation: textClip 0.4s ease-out 1.2s forwards;
          animation: textClip 0.4s ease-out 1.2s forwards;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide.is-visible .hero_slide03 .hero_slide03_text .ttl picture {
  -webkit-animation: textClip 0.4s ease-out 0.8s forwards;
          animation: textClip 0.4s ease-out 0.8s forwards;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide.is-visible .hero_slide03 .hero_slide03_text .txt picture {
  -webkit-animation: textClip 0.4s ease-out 1.2s forwards;
          animation: textClip 0.4s ease-out 1.2s forwards;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide.is-visible .hero_slide03 .hero_slide03_bg .sand {
  -webkit-animation: humanClip 0.4s ease-out 0.6s forwards;
          animation: humanClip 0.4s ease-out 0.6s forwards;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide.is-visible .hero_slide03 .hero_slide03_bg .human {
  -webkit-animation: humanClip 1s ease-out 0.8s forwards;
          animation: humanClip 1s ease-out 0.8s forwards;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide01 {
  max-width: 141rem;
  padding-top: clamp(0px, 78.301886792%, 83rem);
  margin: 0 auto;
  position: relative;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide01 .hero_slide01_text {
  width: 100%;
  height: 100%;
  padding: clamp(0px, 24.705882352%, 25.2rem) 2rem 0;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide01 .hero_slide01_text .ttl {
  width: 37.653061224%;
  max-width: 36.9rem;
  position: relative;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide01 .hero_slide01_text .ttl::before {
  content: "";
  width: 117.344173442%;
  max-width: 43.3rem;
  aspect-ratio: 1/0.3487297921;
  background: url(../images/top/hero_slider01_line.png) no-repeat center/contain;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  clip-path: inset(0 100% 0 0);
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide01 .hero_slide01_text .ttl picture {
  display: inline-block;
  clip-path: inset(0 100% 0 0);
  position: relative;
  z-index: 2;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide01 .hero_slide01_text .txt {
  width: 43.469387755%;
  max-width: 42.6rem;
  margin-top: 3.8rem;
  margin-left: 0.1rem;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide01 .hero_slide01_text .txt picture {
  display: inline-block;
  clip-path: inset(0 100% 0 0);
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide01 .hero_slide01_text .s {
  width: 165.784313725%;
  max-width: 169.1rem;
  position: absolute;
  top: 14.457831325%;
  left: clamp(-36rem, -35.294117647%, 0px);
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide01 .hero_slide01_text .s svg {
  fill: none;
  stroke: #3778be;
  stroke-width: 4.6rem;
  stroke-dasharray: 3000;
  stroke-dashoffset: 3000;
  opacity: 0.12;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide01 .hero_slide01_bg {
  width: 52.647058823%;
  max-width: 53.7rem;
  position: absolute;
  top: 0;
  right: clamp(0px, 5%, 5.1rem);
  z-index: 2;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide01 .hero_slide01_bg .hourglass {
  width: 100%;
  display: inline-block;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide01 .hero_slide01_bg .sand {
  width: 1.675977653%;
  position: absolute;
  left: 49.348230912%;
  bottom: 27.889447236%;
  z-index: 2;
  clip-path: inset(0 0 100% 0);
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide01 .hero_slide01_bg .human {
  width: 58.472998137%;
  position: absolute;
  bottom: 4.519774011%;
  left: 19.180633147%;
  z-index: 3;
  clip-path: inset(0 0 100% 0);
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide02 {
  max-width: 141rem;
  padding-top: clamp(0px, 78.301886792%, 83rem);
  margin: 0 auto;
  position: relative;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide02 .hero_slide02_text {
  width: 100%;
  height: 100%;
  padding: clamp(0px, 23.773584905%, 25.2rem) 2rem 0;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide02 .hero_slide02_text .ttl {
  width: 38.265306122%;
  max-width: 37.5rem;
  position: relative;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide02 .hero_slide02_text .ttl::before {
  content: "";
  width: 114.666666667%;
  max-width: 43rem;
  aspect-ratio: 1/0.3488372093;
  background: url(../images/top/hero_slider02_line.png) no-repeat center/contain;
  position: absolute;
  top: 0;
  left: 3.466666666%;
  z-index: 1;
  clip-path: inset(0 100% 0 0);
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide02 .hero_slide02_text .ttl picture {
  display: inline-block;
  clip-path: inset(0 100% 0 0);
  position: relative;
  z-index: 2;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide02 .hero_slide02_text .txt {
  width: 43.571428571%;
  max-width: 42.7rem;
  margin-top: 3.8rem;
  margin-left: 0.1rem;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide02 .hero_slide02_text .txt picture {
  display: inline-block;
  clip-path: inset(0 100% 0 0);
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide02 .hero_slide02_bg {
  width: 91.078431372%;
  max-width: 92.9rem;
  position: absolute;
  top: clamp(0px, 2.048192771%, 1.7rem);
  right: clamp(-11.1rem, -10.882352941%, 0px);
  z-index: 1;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide02 .hero_slide02_bg .hourglass {
  width: 100%;
  display: inline-block;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide02 .hero_slide02_bg .sand {
  width: 1.675977653%;
  position: absolute;
  left: 53.283100107%;
  bottom: 27.889447236%;
  z-index: 2;
  clip-path: inset(0 0 100% 0);
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide02 .hero_slide02_bg .human {
  width: 26.695371367%;
  position: absolute;
  left: 39.827771797%;
  bottom: 3.594351732%;
  z-index: 3;
  clip-path: inset(0 0 100% 0);
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide03 {
  max-width: 141rem;
  padding-top: clamp(0px, 78.301886792%, 83rem);
  margin: 0 auto;
  position: relative;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide03 .hero_slide03_text {
  width: 100%;
  height: 100%;
  padding: clamp(0px, 23.773584905%, 25.2rem) 2rem 0;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide03 .hero_slide03_text .ttl {
  width: 38.571428571%;
  max-width: 37.8rem;
  position: relative;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide03 .hero_slide03_text .ttl::before {
  content: "";
  width: 115.079365079%;
  max-width: 43.5rem;
  aspect-ratio: 1/0.3471264368;
  background: url(../images/top/hero_slider03_line.png) no-repeat center/contain;
  position: absolute;
  top: 0.666666666%;
  left: 1.322751322%;
  z-index: 1;
  clip-path: inset(0 100% 0 0);
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide03 .hero_slide03_text .ttl picture {
  display: inline-block;
  clip-path: inset(0 100% 0 0);
  position: relative;
  z-index: 2;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide03 .hero_slide03_text .txt {
  width: 47.244897959%;
  max-width: 46.3rem;
  margin-top: 3.8rem;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide03 .hero_slide03_text .txt picture {
  display: inline-block;
  clip-path: inset(0 100% 0 0);
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide03 .hero_slide03_bg {
  width: 60.196078431%;
  max-width: 61.4rem;
  position: absolute;
  top: clamp(0px, 2.650602409%, 5.2rem);
  right: clamp(1.3rem, 1.274509803%, 0px);
  z-index: 1;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide03 .hero_slide03_bg .hourglass {
  width: 100%;
  display: inline-block;
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide03 .hero_slide03_bg .sand {
  width: 1.675977653%;
  position: absolute;
  left: 49.6742671017%;
  bottom: 27.889447236%;
  z-index: 2;
  clip-path: inset(0 0 100% 0);
}
.hero_sec .container .hero_slider .swiper-wrapper .swiper-slide .hero_slide03 .hero_slide03_bg .human {
  width: 42.833876221%;
  position: absolute;
  left: 33.06188925%;
  bottom: 6.322580645%;
  z-index: 3;
  clip-path: inset(0 0 100% 0);
}

.top_info_sec {
  padding: 0;
  padding-bottom: 8.2rem;
  position: relative;
  overflow: hidden;
}
.top_info_sec::before {
  content: "";
  width: 130.885416667%;
  height: 44rem;
  background-color: #19396d;
  border-radius: 50%;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: 1;
}
.top_info_sec .top_info_sec_wrap {
  width: 100%;
  padding: 11.1rem 2rem 6rem;
  background: #19396d;
  position: relative;
}
.top_info_sec .top_info_sec_wrap::before {
  content: "";
  width: 100%;
  height: calc(100% + 8.2rem);
  background: -webkit-image-set(url(../images/common/hourglass_bg.png) 1x, url(../images/common/hourglass_bg@2x.png) 2x) no-repeat top -33rem center;
  background: image-set(url(../images/common/hourglass_bg.png) 1x, url(../images/common/hourglass_bg@2x.png) 2x) no-repeat top -33rem center;
  opacity: 0.12;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: 1;
}
.top_info_sec .top_info_sec_wrap .container {
  position: relative;
  z-index: 1;
}
.top_info_sec .top_info_sec_wrap .container .top_topics_block {
  width: 100%;
  position: relative;
}
.top_info_sec .top_info_sec_wrap .container .top_topics_block .top_topics_ttl {
  margin-left: -0.9rem;
}
.top_info_sec .top_info_sec_wrap .container .top_topics_block .top_topics_list {
  margin-top: 3.9rem;
}
.top_info_sec .top_info_sec_wrap .container .top_topics_block .top_topics_list li:nth-of-type(4) {
  display: none;
}
@media screen and (max-width: 900px) {
  .top_info_sec .top_info_sec_wrap .container .top_topics_block .top_topics_list li:nth-of-type(4) {
    display: block;
  }
}
.top_info_sec .top_info_sec_wrap .container .top_topics_block .top_topics_btn {
  width: auto;
  position: absolute;
  top: 1rem;
  right: 0;
  z-index: 1;
}
.top_info_sec .top_info_sec_wrap .container .top_news_block {
  width: 100%;
  margin-top: 9.5rem;
}
.top_info_sec .top_info_sec_wrap .container .top_news_block .top_news_ttl {
  width: 21rem;
  padding-top: 1.7rem;
  float: left;
}
.top_info_sec .top_info_sec_wrap .container .top_news_block .top_news_list {
  width: calc(100% - 21rem);
  max-width: 111.4rem;
  padding-left: 3rem;
  float: right;
}
.top_info_sec .top_info_sec_wrap .container .top_news_block .top_news_btn {
  width: 21rem;
  padding-left: 0.2rem;
  margin-top: 4.2rem;
  float: left;
}

#sb_instagram .sb_instagram_header,
#sb_instagram #sbi_load {
  display: none;
}
#sb_instagram #sbi_images {
  padding: 0 !important;
  gap: 1rem;
}
#sb_instagram #sbi_images .sbi_item {
  border: solid 0.2rem #dddddd;
  border-radius: 1rem;
  overflow: hidden;
}

.top_activity_sec {
  padding-top: 12rem;
  padding-bottom: 12.1rem;
  position: relative;
  --pl: 5.065789473%;
  --listWidth: 51.644736842%;
}
.top_activity_sec::before {
  width: 100%;
  max-width: 192rem;
  content: "Sunmedical";
  font-family: "Jost";
  font-size: 17.5rem;
  color: #eee;
  font-weight: 500;
  line-height: 1.625;
  letter-spacing: 0.05em;
  overflow: hidden;
  padding: 0 1.354166666%;
  position: absolute;
  bottom: 9.4rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  pointer-events: none;
  z-index: 1;
}
@media screen and (max-width: 1400px) {
  .top_activity_sec::before {
    bottom: -8rem;
  }
}
@media screen and (max-width: 1200px) {
  .top_activity_sec {
    --pl: 0;
  }
}
@media screen and (max-width: 1200px) and (max-width: 1000px) {
  .top_activity_sec {
    --listWidth: 41rem;
  }
}
.top_activity_sec .container {
  max-width: 152rem;
  position: relative;
  z-index: 2;
}
.top_activity_sec .container .top_activity_ttl {
  width: calc(100% - (var(--listWidth) + 3rem));
  max-width: 66rem;
  padding: 4.4rem 0 0 var(--pl);
  float: left;
}
.top_activity_sec .container .top_activity_txt {
  width: calc(100% - (var(--listWidth) + 3rem));
  max-width: 66rem;
  padding-left: var(--pl);
  margin-top: 3rem;
  float: left;
}
.top_activity_sec .container .top_activity_list {
  width: var(--listWidth);
  float: right;
}
.top_activity_sec .container .top_activity_list .instagram_list {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
@media screen and (max-width: 1000px) {
  .top_activity_sec .container .top_activity_list .instagram_list {
    grid-template-columns: repeat(2, 1fr);
  }
}
.top_activity_sec .container .top_activity_list .instagram_list li {
  aspect-ratio: 1/1;
  border: solid 0.2rem #dddddd;
  background-color: #eef1f7;
  border-radius: 1rem;
  overflow: hidden;
}
.top_activity_sec .container .top_activity_list .instagram_list li button {
  width: 100%;
  height: 100%;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.top_activity_sec .container .top_activity_list .instagram_list li button img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.top_activity_sec .container .top_activity_list .instagram_list li button:hover {
  opacity: 0.7;
}
.top_activity_sec .container .top_activity_btn {
  width: calc(100% - (var(--listWidth) + 3rem));
  max-width: 66rem;
  padding-left: var(--pl);
  margin-top: 5.4rem;
  float: left;
}

.top_shop_sec {
  padding-top: 14.3rem;
  padding-bottom: 13.7rem;
  background: #19396d;
  position: relative;
  overflow: hidden;
}
.top_shop_sec::before {
  content: "";
  width: 100%;
  height: 100%;
  background: -webkit-image-set(url(../images/common/hourglass_bg.png) 1x, url(../images/common/hourglass_bg@2x.png) 2x) no-repeat top -68.5rem center;
  background: image-set(url(../images/common/hourglass_bg.png) 1x, url(../images/common/hourglass_bg@2x.png) 2x) no-repeat top -68.5rem center;
  opacity: 0.12;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%) scale(1, -1);
          transform: translateX(-50%) scale(1, -1);
  z-index: 1;
  pointer-events: none;
}
.top_shop_sec .container {
  max-width: 153rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  z-index: 2;
}
.top_shop_sec .container .wrapper {
  width: 39.215686275%;
  padding-left: 5.228758169%;
  padding-bottom: 0.6rem;
  float: left;
}
@media screen and (max-width: 1200px) {
  .top_shop_sec .container .wrapper {
    padding-left: 0;
  }
}
.top_shop_sec .container .wrapper .top_shop_ttl {
  width: 100%;
  padding-right: 2rem;
  padding-bottom: 2.1rem;
  border-bottom: solid 0.1rem #f2f238;
}
.top_shop_sec .container .wrapper .top_shop_ttl a {
  width: 100%;
  max-width: 43.4rem;
  font-family: "Jost";
  font-size: 4.2rem;
  color: #fff;
  font-weight: 500;
  line-height: 1.25;
  letter-spacing: 0.05em;
  padding-right: 6.6rem;
  display: inline-block;
  position: relative;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.top_shop_sec .container .wrapper .top_shop_ttl a span {
  display: inline-block;
  margin: 0 -0.5rem;
}
.top_shop_sec .container .wrapper .top_shop_ttl a::before {
  content: "";
  width: 4.6rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: -webkit-image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #f2f238;
  background: image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #f2f238;
  position: absolute;
  top: 50%;
  right: 1rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.top_shop_sec .container .wrapper .top_shop_ttl a:hover {
  color: #f2f238;
}
.top_shop_sec .container .wrapper .top_shop_ttl a:hover::before {
  right: 0;
}
.top_shop_sec .container .wrapper .top_shop_txt {
  width: 100%;
  max-width: 44rem;
  padding-right: 2rem;
  margin-top: 2.1rem;
}
.top_shop_sec .container .top_shop_img {
  width: 60.784313725%;
  padding-right: 8rem;
  position: relative;
  float: right;
}
.top_shop_sec .container .top_shop_img picture {
  border-radius: 1rem;
  overflow: hidden;
  display: inline-block;
}
.top_shop_sec .container .top_shop_img figcaption {
  font-family: "Jost";
  font-size: 12rem;
  color: #f2f238;
  font-weight: 500;
  line-height: 0.8333333333;
  letter-spacing: 0.05em;
  position: absolute;
  top: 5.6rem;
  right: -9.4rem;
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
}
.top_shop_sec .container .top_shop_img figcaption span {
  margin: 0 -2rem;
}

.common_ft_link_sec {
  padding-top: 13.1rem;
  padding-bottom: 13rem;
  background: -webkit-image-set(url(../images/common/ft_link_bg.jpg) 1x, url(../images/common/ft_link_bg@2x.jpg) 2x) no-repeat center/cover;
  background: image-set(url(../images/common/ft_link_bg.jpg) 1x, url(../images/common/ft_link_bg@2x.jpg) 2x) no-repeat center/cover;
  background: -webkit-image-set(url(../images/common/ft_link_bg.webp) 1x, url(../images/common/ft_link_bg@2x.webp) 2x) no-repeat center/cover;
  background: image-set(url(../images/common/ft_link_bg.webp) 1x, url(../images/common/ft_link_bg@2x.webp) 2x) no-repeat center/cover;
}
.common_ft_link_sec .container .ft_link_list {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.1rem;
}
.common_ft_link_sec .container .ft_link_list li {
  position: relative;
  padding: 0 2rem;
}
.common_ft_link_sec .container .ft_link_list li:last-of-type::before {
  display: none;
}
.common_ft_link_sec .container .ft_link_list li::before {
  content: "";
  width: 0.1rem;
  height: 100%;
  background-color: #19396d;
  opacity: 0.3;
  position: absolute;
  top: 0;
  right: -0.1rem;
}
.common_ft_link_sec .container .ft_link_list li .ft_link_ttl {
  width: 100%;
  text-align: center;
}
.common_ft_link_sec .container .ft_link_list li .ft_link_ttl .icon {
  width: 7.7rem;
  height: 7.4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0 auto;
}
.common_ft_link_sec .container .ft_link_list li .ft_link_ttl .ttl {
  width: 100%;
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-align: center;
  display: block;
  margin-top: 1.4rem;
}
.common_ft_link_sec .container .ft_link_list li .ft_link_txt {
  max-width: 35.4rem;
  margin: 2.8rem auto 0;
}
.common_ft_link_sec .container .ft_link_list li .ft_link_btn {
  margin-top: 3.4rem;
}
.common_ft_link_sec .container .ft_link_list li .ft_link_btn a {
  max-width: 35.6rem;
  margin: 0 auto;
}
@media screen and (max-width: 900px) {
  .common_ft_link_sec .container .ft_link_list li .ft_link_btn a {
    padding: 1rem 6rem 1rem 1rem;
  }
}

/*----------------------------------------------------------------------------
******************************************************************************
** common class
******************************************************************************
----------------------------------------------------------------------------*/
.common_txt01 {
  width: 100%;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
}
.common_txt01.white {
  color: #fff;
}

.common_ttl01 {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2rem;
}
.common_ttl01 .jp {
  font-size: 3.2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  display: inline-block;
}
.common_ttl01 .en {
  font-family: "Jost";
  font-size: 1.8rem;
  color: rgba(25, 57, 109, 0.5);
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: 0.05em;
  display: inline-block;
  padding-top: 0.5rem;
}
.common_ttl01.white .jp {
  color: #fff;
}
.common_ttl01.white .en {
  color: #f2f238;
}
.common_ttl01.center {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.common_btn01 {
  width: 100%;
  padding-right: 4.8rem;
  position: relative;
}
.common_btn01::before {
  content: "";
  width: 2.9rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: -webkit-image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.5rem, #f2f238;
  background: image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.5rem, #f2f238;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_btn01 span {
  font-size: 1.8rem;
  color: #fff;
  font-weight: 700;
  line-height: 2.5;
  letter-spacing: 0.05em;
  display: inline-block;
  position: relative;
}
.common_btn01 span::before {
  content: "";
  width: 100%;
  height: 0.1rem;
  background-color: #f2f238;
  position: absolute;
  bottom: 0;
  left: 0;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: center left;
          transform-origin: center left;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_btn01:hover::before {
  right: -1rem;
}
.common_btn01:hover span::before {
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
}
.common_btn01.large {
  font-size: 1.6rem;
  padding-right: 5.3rem;
}
.common_btn01.large::before {
  width: 4rem;
  background-size: 1.6rem;
}

.common_btn02,
.swpm-submit {
  width: 100%;
  max-width: 35rem;
  height: 6.6rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 1rem 7rem;
  background-color: #f2f238;
  border-radius: 5rem;
  position: relative;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_btn02.is_ended,
.swpm-submit.is_ended {
  opacity: 0.7;
  pointer-events: none;
}
.common_btn02.is_ended::before,
.swpm-submit.is_ended::before {
  display: none !important;
}
.common_btn02::before,
.swpm-submit::before {
  content: "";
  width: 4.6rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: -webkit-image-set(url(../images/common/common_arrow01_y.png) 1x, url(../images/common/common_arrow01_y@2x.png) 2x) no-repeat center/1.6rem, #19396d;
  background: image-set(url(../images/common/common_arrow01_y.png) 1x, url(../images/common/common_arrow01_y@2x.png) 2x) no-repeat center/1.6rem, #19396d;
  position: absolute;
  top: 50%;
  right: 1rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_btn02 span,
.swpm-submit span {
  font-size: 1.8rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: 0.05em;
  text-align: center;
  display: inline-block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_btn02:hover,
.swpm-submit:hover {
  background-color: #19396d;
}
.common_btn02:hover::before,
.swpm-submit:hover::before {
  background: -webkit-image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #f2f238;
  background: image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #f2f238;
  right: 0;
}
.common_btn02:hover span,
.swpm-submit:hover span {
  color: #f2f238;
}
.common_btn02.free_size,
.swpm-submit.free_size {
  width: auto;
  height: auto;
  max-width: none;
  display: inline-block;
  padding-top: 2.1rem;
  padding-bottom: 2.2rem;
}
.common_btn02.center,
.swpm-submit.center {
  margin: 0 auto;
}
.common_btn02.color,
.swpm-submit.color {
  background-color: #19396d;
}
.common_btn02.color::before,
.swpm-submit.color::before {
  background: -webkit-image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #fff;
  background: image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #fff;
}
.common_btn02.color span,
.swpm-submit.color span {
  color: #fff;
}
.common_btn02.color span::before,
.swpm-submit.color span::before {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
.common_btn02.small,
.swpm-submit.small {
  max-width: 30rem;
  height: 5.6rem;
}
.common_btn02.small::before,
.swpm-submit.small::before {
  width: 3.6rem;
  background-size: 1.3rem;
}
.common_btn02.small span,
.swpm-submit.small span {
  font-size: 1.6rem;
}
.common_btn02.large,
.swpm-submit.large {
  max-width: 50rem;
  min-height: 8rem;
}
.common_btn02.large::before,
.swpm-submit.large::before {
  right: 2rem;
}
.common_btn02.large span,
.swpm-submit.large span {
  font-size: 2.2rem;
}
.common_btn02.large:hover::before,
.swpm-submit.large:hover::before {
  right: 1rem;
}
.common_btn02.catalog span,
.swpm-submit.catalog span {
  padding-left: 3.3rem;
  position: relative;
}
.common_btn02.catalog span::before,
.swpm-submit.catalog span::before {
  content: "";
  width: 3.9rem;
  height: 2.9rem;
  background: url(../images/common/catalog_icon.png) no-repeat center/contain;
  background: url(../images/common/catalog_icon.svg) no-repeat center/contain;
  position: absolute;
  top: 50%;
  left: -1.5rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.common_btn02.document span,
.swpm-submit.document span {
  padding-left: 2.2rem;
  position: relative;
}
.common_btn02.document span::before,
.swpm-submit.document span::before {
  content: "";
  width: 2.7rem;
  height: 3.2rem;
  background: url(../images/common/document_icon.png) no-repeat center/contain;
  background: url(../images/common/document_icon.svg) no-repeat center/contain;
  position: absolute;
  top: 50%;
  left: -1.6rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.common_btn02.cart,
.swpm-submit.cart {
  max-width: 45rem;
  height: 8rem;
}
.common_btn02.cart.disabled,
.swpm-submit.cart.disabled {
  pointer-events: none;
  opacity: 0.5;
}
.common_btn02.cart::before,
.swpm-submit.cart::before {
  right: 1.5rem;
}
.common_btn02.cart span,
.swpm-submit.cart span {
  font-size: 2.2rem;
  padding-left: 4rem;
  position: relative;
}
.common_btn02.cart span::before,
.swpm-submit.cart span::before {
  content: "";
  width: 3.4rem;
  height: 3.6rem;
  background: url(../images/common/cart_icon.png) no-repeat center/contain;
  background: url(../images/common/cart_icon.svg) no-repeat center/contain;
  position: absolute;
  top: 50%;
  left: -0.4rem;
  -webkit-transform: translateY(-50%) scale(-1, 1);
          transform: translateY(-50%) scale(-1, 1);
}
.common_btn02.cart:hover::before,
.swpm-submit.cart:hover::before {
  right: 0.5rem;
}

.common_news_list {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  --baseColor: #262626;
  --dateColor: #808080;
  --catColor: #19396d;
  --borderColor: #dddddd;
}
.common_news_list.white {
  --baseColor: #fff;
  --dateColor: #fff;
  --catColor: #fff;
  --borderColor: rgba(255, 255, 255, 0.5);
}
.common_news_list li {
  width: 100%;
  border-bottom: solid 0.1rem var(--borderColor);
}
.common_news_list li:last-of-type {
  border-bottom: none;
}
.common_news_list li a {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 2.5rem 0.2rem;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_news_list li a .news_list_ttl {
  width: calc(100% - 22rem);
  font-size: 1.6rem;
  color: var(--baseColor);
  font-weight: 400;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-left: 1.7rem;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.common_news_list li a .news_list_data {
  width: 22rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-right: 0.5rem;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.common_news_list li a .news_list_data .news_list_cat {
  width: 11rem;
  height: 3.2rem;
  font-size: 1.4rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding: 1rem;
  background-color: #fff;
  border: solid 0.1rem var(--catColor);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 5rem;
}
.common_news_list li a .news_list_data .news_list_date {
  font-family: "Jost";
  font-size: 1.6rem;
  color: var(--dateColor);
  font-weight: 400;
  line-height: 1.625;
}
.common_news_list li a:hover {
  opacity: 0.7;
}

.common_topics_list {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3rem 2.262773722%;
}
@media screen and (max-width: 900px) {
  .common_topics_list {
    grid-template-columns: repeat(2, 1fr);
  }
}
.common_topics_list li {
  border-radius: 1rem;
  overflow: hidden;
  background-color: #fff;
}
.common_topics_list li a {
  width: 100%;
  height: 100%;
  padding: calc(56.19266055% + 2.5rem) 3rem 3.1rem 3rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: relative;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_topics_list li a .topics_list_ttl {
  width: 100%;
  font-size: 1.8rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.6666666667;
  letter-spacing: 0.05em;
  margin-top: 1.4rem;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.common_topics_list li a .topics_list_thumb {
  width: 100%;
  aspect-ratio: 1/0.5619266055;
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
}
.common_topics_list li a .topics_list_thumb picture {
  width: 100%;
  height: 100%;
  display: block;
}
.common_topics_list li a .topics_list_thumb picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_topics_list li a .topics_list_data {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.common_topics_list li a .topics_list_data .topics_list_cat {
  width: calc(100% - 9rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.5rem 1rem;
}
.common_topics_list li a .topics_list_data .topics_list_cat span {
  min-width: 11rem;
  height: 3.2rem;
  font-size: 1.4rem;
  color: #fff;
  font-weight: 400;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding: 1rem;
  background-color: #3778be;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 5rem;
}
.common_topics_list li a .topics_list_data .topics_list_date {
  width: 9rem;
  font-family: "Jost";
  font-size: 1.6rem;
  color: #808080;
  font-weight: 400;
  line-height: 1.625;
  letter-spacing: 0;
  text-align: right;
}
.common_topics_list li a:hover {
  opacity: 0.7;
}
.common_topics_list li a:hover .topics_list_thumb picture img {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}
.common_topics_list.small {
  gap: 3rem 2.897196261%;
}
@media screen and (max-width: 900px) {
  .common_topics_list.small {
    grid-template-columns: repeat(2, 1fr);
  }
}
.common_topics_list.small li a {
  padding: calc(56.25% + 1.5rem) 1.9rem 1.8rem;
  border: solid 0.1rem #dddddd;
  border-radius: 1rem;
}
.common_topics_list.small li a .topics_list_ttl {
  font-size: 1.6rem;
  line-height: 1.625;
  margin-top: 1.2rem;
}
.common_topics_list.small li a .topics_list_thumb {
  aspect-ratio: 1/0.5625;
}
.common_topics_list.small li a .topics_list_data .topics_list_cat span {
  min-width: 9rem;
  height: 2.8rem;
  font-size: 1.2rem;
}
.common_topics_list.small li a .topics_list_data .topics_list_date {
  font-size: 1.4rem;
}

/*----------------------------------------------------------------------------
******************************************************************************
** sub
******************************************************************************
----------------------------------------------------------------------------*/
.sub_hero {
  background: -webkit-image-set(url(../images/online_shop/mv.webp) 1x, url(../images/online_shop/mv@2x.webp) 2x) no-repeat center/cover;
  background: image-set(url(../images/online_shop/mv.webp) 1x, url(../images/online_shop/mv@2x.webp) 2x) no-repeat center/cover;
}
.sub_hero.online_shop {
  background: -webkit-image-set(url(../images/online_shop/mv.webp) 1x, url(../images/online_shop/mv@2x.webp) 2x) no-repeat center/cover;
  background: image-set(url(../images/online_shop/mv.webp) 1x, url(../images/online_shop/mv@2x.webp) 2x) no-repeat center/cover;
}
.sub_hero.topics {
  background: -webkit-image-set(url(../images/topics/mv.webp) 1x, url(../images/topics/mv@2x.webp) 2x) no-repeat center/cover;
  background: image-set(url(../images/topics/mv.webp) 1x, url(../images/topics/mv@2x.webp) 2x) no-repeat center/cover;
}
.sub_hero.news {
  background: -webkit-image-set(url(../images/news/mv.webp) 1x, url(../images/news/mv@2x.webp) 2x) no-repeat center/cover;
  background: image-set(url(../images/news/mv.webp) 1x, url(../images/news/mv@2x.webp) 2x) no-repeat center/cover;
}
.sub_hero.opening_clinic {
  background: -webkit-image-set(url(../images/opening_clinic/mv.webp) 1x, url(../images/opening_clinic/mv@2x.webp) 2x) no-repeat center/cover;
  background: image-set(url(../images/opening_clinic/mv.webp) 1x, url(../images/opening_clinic/mv@2x.webp) 2x) no-repeat center/cover;
}
.sub_hero.used_item {
  background: -webkit-image-set(url(../images/used/mv.webp) 1x, url(../images/used/mv@2x.webp) 2x) no-repeat center/cover;
  background: image-set(url(../images/used/mv.webp) 1x, url(../images/used/mv@2x.webp) 2x) no-repeat center/cover;
}
.sub_hero.safety_report {
  background: -webkit-image-set(url(../images/report/mv.webp) 1x, url(../images/report/mv@2x.webp) 2x) no-repeat center/cover;
  background: image-set(url(../images/report/mv.webp) 1x, url(../images/report/mv@2x.webp) 2x) no-repeat center/cover;
}
.sub_hero.member {
  background: -webkit-image-set(url(../images/member/mv.webp) 1x, url(../images/member/mv@2x.webp) 2x) no-repeat center/cover;
  background: image-set(url(../images/member/mv.webp) 1x, url(../images/member/mv@2x.webp) 2x) no-repeat center/cover;
}
.sub_hero.office {
  background: -webkit-image-set(url(../images/office/mv.webp) 1x, url(../images/office/mv@2x.webp) 2x) no-repeat center/cover;
  background: image-set(url(../images/office/mv.webp) 1x, url(../images/office/mv@2x.webp) 2x) no-repeat center/cover;
}
.sub_hero.contact {
  background: -webkit-image-set(url(../images/contact/mv.webp) 1x, url(../images/contact/mv@2x.webp) 2x) no-repeat center/cover;
  background: image-set(url(../images/contact/mv.webp) 1x, url(../images/contact/mv@2x.webp) 2x) no-repeat center/cover;
}
.sub_hero.company {
  background: -webkit-image-set(url(../images/company/mv.webp) 1x, url(../images/company/mv@2x.webp) 2x) no-repeat center/cover;
  background: image-set(url(../images/company/mv.webp) 1x, url(../images/company/mv@2x.webp) 2x) no-repeat center/cover;
}
.sub_hero.pharmaceutical {
  background: -webkit-image-set(url(../images/pharmaceutical/mv.webp) 1x, url(../images/pharmaceutical/mv@2x.webp) 2x) no-repeat center/cover;
  background: image-set(url(../images/pharmaceutical/mv.webp) 1x, url(../images/pharmaceutical/mv@2x.webp) 2x) no-repeat center/cover;
}
.sub_hero.faq {
  background: -webkit-image-set(url(../images/faq/mv.webp) 1x, url(../images/faq/mv@2x.webp) 2x) no-repeat center/cover;
  background: image-set(url(../images/faq/mv.webp) 1x, url(../images/faq/mv@2x.webp) 2x) no-repeat center/cover;
}
.sub_hero.link {
  background: -webkit-image-set(url(../images/link/mv.webp) 1x, url(../images/link/mv@2x.webp) 2x) no-repeat center/cover;
  background: image-set(url(../images/link/mv.webp) 1x, url(../images/link/mv@2x.webp) 2x) no-repeat center/cover;
}
.sub_hero .container {
  height: 30rem;
  padding-top: 8rem;
}
.sub_hero .container .sub_hero_ttl {
  min-width: 38rem;
  padding: 2.3rem 3rem 3.1rem 0;
  background-color: #19396d;
  display: inline-block;
  position: relative;
}
.sub_hero .container .sub_hero_ttl::before {
  content: "";
  width: calc((100vw - 100%) / 2);
  height: 100%;
  background-color: #19396d;
  position: absolute;
  top: 0;
  left: 0.1rem;
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
}
.sub_hero .container .sub_hero_ttl .jp {
  width: 100%;
  font-size: 3.4rem;
  color: #fff;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  display: block;
}
.sub_hero .container .sub_hero_ttl .en {
  width: 100%;
  font-family: "Jost";
  font-size: 1.8rem;
  color: #f2f238;
  font-weight: 600;
  line-height: 1.625;
  letter-spacing: 0.05em;
  display: block;
  margin-top: 0.2rem;
}

.breadcrumb {
  padding-top: 1.7rem;
  padding-bottom: 1.7rem;
}
.breadcrumb.no_hero {
  padding-bottom: 1.9rem;
  border-top: solid 0.1rem #dddddd;
  border-bottom: solid 0.1rem #dddddd;
}
.breadcrumb .breadcrumb_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 3.5rem;
}
.breadcrumb .breadcrumb_list li {
  position: relative;
}
.breadcrumb .breadcrumb_list li::before {
  content: "";
  width: 0.8rem;
  aspect-ratio: 1/1;
  border-right: solid 0.1rem #19396d;
  border-bottom: solid 0.1rem #19396d;
  position: absolute;
  top: calc(50% + 0.1rem);
  right: -1.8rem;
  -webkit-transform: translateY(-50%) rotate(-45deg);
          transform: translateY(-50%) rotate(-45deg);
}
.breadcrumb .breadcrumb_list li:last-of-type::before {
  display: none;
}
.breadcrumb .breadcrumb_list li a,
.breadcrumb .breadcrumb_list li span {
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.625;
  letter-spacing: 0.05em;
  display: inline-block;
}
.breadcrumb .breadcrumb_list li a {
  color: #19396d;
  text-decoration: underline;
  text-underline-offset: 0.8rem;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.breadcrumb .breadcrumb_list li a:hover {
  opacity: 0.7;
}

.online_shop_sec {
  padding-top: 13.3rem;
  padding-bottom: 15.3rem;
  overflow: hidden;
}
.online_shop_sec .container .online_shop_products_block {
  width: 100%;
  position: relative;
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_float_name {
  font-family: "Jost";
  font-size: 17.5rem;
  color: #eee;
  font-weight: 500;
  line-height: 1.1428571429;
  letter-spacing: 0;
  text-align: right;
  position: absolute;
  top: -5rem;
  right: 0;
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_txt {
  margin-top: 2.8rem;
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_txt.belt_txt03 {
  width: calc(100% - 65rem);
  font-size: 2rem;
  font-weight: 700;
  line-height: 2;
  letter-spacing: 0.05em;
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_txt.belt_txt01 {
  width: calc(100% - 32rem);
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_txt.belt_txt02 {
  width: calc(100% - 32rem);
  max-width: 100rem;
  margin-top: 3.2rem;
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_txt.consumables_txt01 {
  margin-top: 8rem;
}
.online_shop_sec .container .online_shop_products_block .online_shop_column_wrap {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 2rem;
  margin-top: 7.4rem;
}
.online_shop_sec .container .online_shop_products_block .online_shop_column_wrap .online_shop_products_list {
  width: 59.854014598%;
  margin: 0;
}
.online_shop_sec .container .online_shop_products_block .online_shop_column_wrap .online_shop_column_img {
  width: calc(100% - (59.854014598% + 2rem));
  aspect-ratio: 1/0.7547169811;
}
.online_shop_sec .container .online_shop_products_block .online_shop_column_wrap .online_shop_column_img a {
  width: 100%;
  display: block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.online_shop_sec .container .online_shop_products_block .online_shop_column_wrap .online_shop_column_img a:hover {
  opacity: 0.7;
}
.online_shop_sec .container .online_shop_products_block .online_shop_column_wrap .online_shop_column_img a figcaption {
  width: 100%;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.4545454546;
  letter-spacing: 0.05em;
  text-align: center;
  margin-top: 2.2rem;
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_list {
  width: 100%;
  display: grid;
  gap: 3rem 2rem;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 7.4rem;
  --column: 2;
  --ttl-fz: 2.2rem;
  --price-fz: 3rem;
  --yen-fz: 2.2rem;
  --tax-fz: 1.6rem;
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_list.pc_four_column {
  --column: 4;
  --ttl-fz: 2rem;
  --price-fz: 2.6rem;
  --yen-fz: 2rem;
  --tax-fz: 1.4rem;
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_list {
  grid-template-columns: repeat(var(--column), minmax(auto, 65rem));
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_list li a {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_list li a .products_name {
  width: 100%;
  font-size: var(--ttl-fz);
  font-weight: 700;
  line-height: 1.4545454546;
  letter-spacing: 0.05em;
  margin-top: 2.2rem;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_list li a .products_img {
  width: 100%;
  aspect-ratio: 1/1;
  border-radius: 1rem;
  overflow: hidden;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_list li a .products_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_list li a .products_price {
  width: 100%;
  margin-top: 1.2rem;
  margin-left: -0.1rem;
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_list li a .products_price .price {
  font-size: var(--price-fz);
  color: #19396d;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0;
  margin-right: -0.1rem;
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_list li a .products_price .yen {
  font-size: var(--yen-fz);
  color: #19396d;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
  margin-right: -0.1rem;
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_list li a .products_price .tax {
  font-size: var(--tax-fz);
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.05em;
}
.online_shop_sec .container .online_shop_products_block .online_shop_products_list li a:hover {
  opacity: 0.7;
}
.online_shop_sec .container .online_shop_products_block.belt {
  padding-bottom: 13.4rem;
}
.online_shop_sec .container .online_shop_products_block.belt::before {
  content: "";
  width: 100vw;
  height: 0.1rem;
  background-color: #dddddd;
  position: absolute;
  bottom: 0;
  left: calc((-100vw + 100%) / 2);
}
.online_shop_sec .container .online_shop_products_block.belt .online_shop_products_name {
  margin-left: -1.2rem;
}
@media screen and (max-width: 1080px) {
  .online_shop_sec .container .online_shop_products_block.belt .online_shop_products_float_name {
    font-size: 10rem;
    top: -3rem;
  }
  .online_shop_sec .container .online_shop_products_block.belt .online_shop_products_txt.belt_txt03 {
    width: calc(100% - 18rem);
  }
  .online_shop_sec .container .online_shop_products_block.belt .online_shop_products_txt.belt_txt01 {
    width: calc(100% - 18rem);
  }
  .online_shop_sec .container .online_shop_products_block.belt .online_shop_products_txt.belt_txt02 {
    width: calc(100% - 18rem);
  }
}
@media screen and (max-width: 1080px) and (max-width: 900px) {
  .online_shop_sec .container .online_shop_products_block.belt .online_shop_products_txt.belt_txt02 {
    width: 100%;
  }
}
.online_shop_sec .container .online_shop_products_block.consumables {
  padding-top: 16.7rem;
}
.online_shop_sec .container .online_shop_products_block.consumables .online_shop_products_name {
  position: relative;
  z-index: 2;
}
.online_shop_sec .container .online_shop_products_block.consumables .online_shop_products_float_name {
  top: 10.8rem;
  right: -0.5rem;
}
.online_shop_sec .container .online_shop_products_block.consumables .online_shop_products_list {
  margin-top: 11.5rem;
}
@media screen and (max-width: 1240px) {
  .online_shop_sec .container .online_shop_products_block.consumables .online_shop_products_float_name {
    font-size: 10rem;
    top: 14rem;
  }
  .online_shop_sec .container .online_shop_products_block.consumables .online_shop_products_txt.consumables_txt01 {
    margin-top: 3rem;
  }
  .online_shop_sec .container .online_shop_products_block.consumables .online_shop_products_list {
    margin-top: 7.4rem;
  }
}

.common_ttl02 {
  width: 100%;
}
.common_ttl02 .jp {
  width: 100%;
  font-size: 4rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  display: inline-block;
}
.common_ttl02 .jp sup {
  font-size: 2.5rem;
  position: relative;
  top: -1.4rem;
}
.common_ttl02 .en {
  width: 100%;
  font-family: "Jost";
  font-size: 1.8rem;
  color: #19396d;
  font-weight: 600;
  line-height: 1.625;
  letter-spacing: 0.05em;
  display: inline-block;
}
.common_ttl02.center {
  text-align: center;
}

.common_ttl04 {
  width: 100%;
  text-align: center;
}
.common_ttl04 .en {
  width: 100%;
  font-family: "Jost";
  font-size: 2rem;
  color: #19396d;
  font-weight: 500;
  line-height: 1.625;
  letter-spacing: 0.05em;
  text-align: center;
  display: inline-block;
  text-decoration: underline;
  text-decoration-color: #f2f238;
  text-underline-offset: 1rem;
}
.common_ttl04 .jp {
  width: 100%;
  font-size: 4.6rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  display: block;
  margin-top: 2.7rem;
}

/*----------------------------------------------------------------------------
******************************************************************************
** detail
******************************************************************************
----------------------------------------------------------------------------*/
.products_detail_sec {
  padding-top: 13.3rem;
  padding-bottom: 15.3rem;
}
.products_detail_sec .container .products_detail_purchase_block {
  width: 100%;
  position: relative;
  margin-top: 7.6rem;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box {
  width: calc(100% - (45.255474452% + 3rem));
  max-width: 65rem;
  margin-left: auto;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_name {
  width: 100%;
  font-size: 3.8rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-left: 0.1rem;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_price_wrap {
  width: 100%;
  padding-bottom: 3rem;
  border-bottom: solid 0.1rem #19396d;
  margin-top: 1.5em;
  margin-bottom: 3.9rem;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_price_wrap .products_detail_purchase_price_list {
  width: 100%;
  margin-top: 2rem;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_price_wrap .products_detail_purchase_price_list:first-of-type {
  margin-top: 0;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_price_wrap .products_detail_purchase_price_list dt {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0;
  margin-bottom: 1rem;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_price_wrap .products_detail_purchase_price {
  width: 100%;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_price_wrap .products_detail_purchase_price .price {
  font-size: 3rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0;
  margin-right: -0.1rem;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_price_wrap .products_detail_purchase_price .yen {
  font-size: 2.2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
  margin-right: -0.1rem;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_price_wrap .products_detail_purchase_price .tax {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.05em;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_slider {
  width: 45.255474452%;
  padding-top: 1.1rem;
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_slider .products_detail_purchase_main_slider .swiper-wrapper .swiper-slide {
  border-radius: 1rem;
  overflow: hidden;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_slider .products_detail_purchase_main_slider .swiper-wrapper .swiper-slide img {
  width: 100%;
  max-width: none;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_slider .products_detail_purchase_thumb {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem 2.2rem;
  margin-top: 2rem;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_slider .products_detail_purchase_thumb div {
  border-radius: 1rem;
  overflow: hidden;
  cursor: pointer;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_txt {
  margin-top: 3.1rem;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_txt p {
  margin: 3rem 0;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_txt.caution span {
  color: #19396d;
  font-weight: 700;
  display: block;
  margin-bottom: 0.5rem;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_note {
  margin-top: 1.9rem;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_size {
  width: 100%;
  margin-top: 4.3rem;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_size > dt {
  width: 100%;
  height: 6rem;
  font-size: 1.8rem;
  color: #fff;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 1rem;
  background-color: #19396d;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_size > dd {
  width: 100%;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_size > dd .products_detail_purchase_size_list {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_size > dd .products_detail_purchase_size_list dt {
  width: 13.846153846%;
  height: 6.1rem;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 1rem;
  border: solid 0.1rem #19396d;
  border-top: none;
  background-color: rgba(25, 57, 109, 0.1);
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_size > dd .products_detail_purchase_size_list dd {
  width: 36.153846153%;
  height: 6.1rem;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.05em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 1rem 1rem 1rem 2rem;
  border-bottom: solid 0.1rem #19396d;
  border-right: solid 0.1rem #19396d;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_size > dd .products_detail_purchase_size_list dd:nth-of-type(odd) {
  border-right: none;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_form {
  width: 100%;
  margin-top: 4.8rem;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_form .products_detail_purchase_select {
  width: 100%;
  margin-top: 3.5rem;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_form .products_detail_purchase_select:first-of-type {
  margin-top: 0;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_form .products_detail_purchase_select dt {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_form .products_detail_purchase_select dd {
  width: 100%;
  margin-top: 1rem;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_form .products_detail_purchase_select dd select {
  width: 100%;
  max-width: 35rem;
  height: 6rem;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding: 1rem 5rem 1rem 2rem;
  background: url(../images/common/select_arrows.png) no-repeat center right 1.8rem, #f5f5f5;
  border: solid 0.2rem #cccccc;
  border-radius: 0.4rem;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}
.products_detail_sec .container .products_detail_purchase_block .products_detail_purchase_box .products_detail_purchase_form .products_detail_purchase_btn {
  margin-top: 6.1rem;
}
.products_detail_sec .container .products_detail_data_block {
  width: 100%;
  max-width: 100rem;
  margin: 8.9rem auto 0;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_editor {
  width: 100%;
  margin-top: 8rem;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_editor:first-of-type {
  margin-top: 0;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_txt {
  margin-top: 2.8rem;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_txt + .products_detail_data_txt {
  margin-top: 3.6rem;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_video {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 5.3rem;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_video video {
  width: 60rem;
  aspect-ratio: 1/0.565;
  background-color: #ccc;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_features {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 3rem;
  margin-top: 9.9rem;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_features .products_detail_data_features_box {
  width: 100%;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_features .products_detail_data_features_box .products_detail_data_features_ttl {
  width: calc(100% - 32rem);
  max-width: 65.3rem;
  font-size: 2.2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  float: right;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_features .products_detail_data_features_box .products_detail_data_features_img {
  width: 30rem;
  float: left;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_features .products_detail_data_features_box .products_detail_data_features_txt {
  width: calc(100% - 32rem);
  max-width: 65.3rem;
  padding-left: 0.3rem;
  margin-top: 1.3rem;
  float: right;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_connection {
  width: 100%;
  margin-top: 8.2rem;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_connection .products_detail_data_connection_list {
  margin-top: 3.9rem;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_flow {
  width: 100%;
  margin-top: 9.1rem;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_flow .products_detail_data_flow_list {
  width: 100%;
  margin-top: 3.2rem;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_flow .products_detail_data_flow_list dt {
  width: 100%;
  font-size: 2.2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  margin-top: 6.4rem;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_flow .products_detail_data_flow_list dt:first-of-type {
  margin-top: 0;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_flow .products_detail_data_flow_list dd {
  width: 100%;
  margin-top: 0.8rem;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_flow .products_detail_data_flow_list dd ol {
  padding-top: 0.8rem;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_flow .products_detail_data_flow_list dd ol li {
  list-style: none;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_flow .products_detail_data_flow_list dd ol li .contact {
  display: block;
  margin-top: 1.5rem;
  margin-bottom: 0.7rem;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_flow .products_detail_data_flow_list dd p {
  margin-top: 0;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_flow .products_detail_data_flow_list dd p a {
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 1rem;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.products_detail_sec .container .products_detail_data_block .products_detail_data_flow .products_detail_data_flow_list dd p a:hover {
  opacity: 0.7;
}

.common_list01 {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1.5rem;
  counter-reset: number 0;
}
.common_list01 li {
  width: 100%;
  line-height: 1.6666666667;
  padding-left: 4.5rem;
  position: relative;
}
.common_list01 li::before {
  counter-increment: number 1;
  content: counter(number) " ";
  width: 3.2rem;
  aspect-ratio: 1/1;
  font-family: "Jost";
  font-size: 1.6rem;
  color: #19396d;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.05em;
  padding: 0.1rem 0 0;
  background-color: #f2f238;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: absolute;
  top: 0.1rem;
  left: 0.3rem;
}

.common_products_list {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
}
.common_products_list li a {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_products_list li a:hover {
  opacity: 0.7;
}
.common_products_list li a .products_name {
  width: 100%;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.625;
  letter-spacing: 0.05em;
  margin-top: 1.4rem;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.common_products_list li a .products_img {
  width: 100%;
  aspect-ratio: 1/1;
  border-radius: 1rem;
  overflow: hidden;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.common_products_list li a .products_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.common_products_list li a .products_price {
  width: 100%;
  margin-top: 0.7rem;
  margin-left: -0.1rem;
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
}
.common_products_list li a .products_price .price {
  font-size: 2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0;
  margin-right: -0.2rem;
}
.common_products_list li a .products_price .yen {
  font-size: 1.6rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
  margin-right: -0.3rem;
}
.common_products_list li a .products_price .tax {
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.05em;
}

.common_txt02 {
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
}

.common_ttl03 {
  width: 100%;
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-bottom: 0.6rem;
  border-bottom: solid 0.1rem #dddddd;
  position: relative;
}
.common_ttl03::before {
  content: "";
  width: 15rem;
  height: 0.1rem;
  background-color: #19396d;
  position: absolute;
  bottom: -0.1rem;
  left: 0;
}

/*----------------------------------------------------------------------------
******************************************************************************
** products
******************************************************************************
----------------------------------------------------------------------------*/
.products_mv {
  position: relative;
}
.products_mv .container {
  height: 100%;
  position: relative;
  z-index: 2;
}
.products_mv .container .products_mv_block {
  width: 100%;
  max-width: 118.5rem;
  padding: 6.2rem 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 7%;
}
.products_mv .container .products_mv_block .products_mv_box {
  margin: 0.2rem 0 0 -0.1rem;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.products_mv .container .products_mv_block .products_mv_box .products_mv_btn {
  margin-top: 3.5rem;
  margin-left: -1.4rem;
}
.products_mv .container .products_mv_block .products_mv_photo {
  margin: 0.1rem 0 0 0.2rem;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.products_mv .products_mv_bg {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
.products_mv .products_mv_bg > picture {
  width: 100%;
  height: 100%;
}
.products_mv .products_mv_bg > picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.products_mv .products_mv_bg .products_mv_bg_item {
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
}
.products_mv .products_mv_bg .products_mv_bg_item picture {
  height: 100%;
}
.products_mv .products_mv_bg .products_mv_bg_item picture img {
  width: auto;
  height: 100%;
}
@media screen and (max-width: 950px) {
  .products_mv .container .products_mv_block {
    width: 100%;
    padding: 5rem 0 18rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .products_mv .container .products_mv_block .products_mv_box {
    width: 50rem;
    margin: 0 auto;
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .products_mv .container .products_mv_block .products_mv_box .products_mv_btn {
    width: 50rem;
    margin: 0;
    position: absolute;
    bottom: 5rem;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  .products_mv .container .products_mv_block .products_mv_photo {
    width: 50rem;
    margin: 5rem auto 0;
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  .products_mv .products_mv_bg .products_mv_bg_item {
    display: none;
  }
}

.products_flexible_sec {
  padding-top: 8.6rem;
  padding-bottom: 10rem;
  position: relative;
  border-bottom: solid 0.1rem #ddd;
  overflow: hidden;
}
.products_flexible_sec:last-of-type {
  border-bottom: none;
}
.products_flexible_sec .container {
  position: relative;
}
.products_flexible_sec .container .products_flex_ttl {
  margin-top: 5rem;
}
.products_flexible_sec .container .products_flex_ttl:first-of-type {
  margin-top: 0;
}
.products_flexible_sec .container .products_overview_block {
  width: 100%;
}
.products_flexible_sec .container .products_overview_block .products_overview_assignment_box {
  width: 100%;
  max-width: 100rem;
  min-height: 28rem;
  padding: 3rem;
  border: solid 0.3rem #19396d;
  border-radius: 1rem;
  background-color: #edf0f5;
  margin: 8.2rem auto 9.1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
}
.products_flexible_sec .container .products_overview_block .products_overview_assignment_box::before {
  content: "";
  width: 31.7rem;
  height: 6.4rem;
  background-color: #19396d;
  clip-path: polygon(50% 6.4rem, 0% 0%, 31.7rem 0%);
  position: absolute;
  bottom: -2.8rem;
  left: 50%;
  -webkit-transform: translate(-50%, 100%);
          transform: translate(-50%, 100%);
}
.products_flexible_sec .container .products_overview_block .products_overview_assignment_box .products_overview_assignment_list {
  max-width: 80rem;
}
.products_flexible_sec .container .products_overview_block .products_overview_assignment_box .products_overview_assignment_list li {
  width: 100%;
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-left: 3.2rem;
  position: relative;
  margin-top: 1.4rem;
}
.products_flexible_sec .container .products_overview_block .products_overview_assignment_box .products_overview_assignment_list li:first-of-type {
  margin-top: 0;
}
.products_flexible_sec .container .products_overview_block .products_overview_assignment_box .products_overview_assignment_list li::before {
  content: "";
  width: 2.2rem;
  aspect-ratio: 1/1;
  background-color: #f2f238;
  border: solid 0.6rem #19396d;
  border-radius: 50%;
  position: absolute;
  top: 1.4rem;
  left: 0;
}
.products_flexible_sec .container .products_overview_block .products_overview_solution_box {
  width: 100%;
  padding-top: 1.8rem;
}
.products_flexible_sec .container .products_overview_block .products_overview_solution_box .products_overview_solution_txt {
  width: 100%;
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.7857142857;
  letter-spacing: 0.05em;
  text-align: center;
}
.products_flexible_sec .container .products_overview_block .products_overview_solution_box .products_overview_solution_list {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, minmax(auto, 42.6rem));
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 1rem;
  margin-top: 4.1rem;
}
.products_flexible_sec .container .products_overview_block .products_overview_solution_box .products_overview_solution_list li {
  min-height: 28rem;
  padding: 3rem;
  background-color: #19396d;
  border-radius: 1rem;
}
.products_flexible_sec .container .products_overview_block .products_overview_solution_box .products_overview_solution_list li .products_overview_solution_list_ttl {
  width: 100%;
  min-height: 8rem;
  font-size: 4.6rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: 0.05em;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 1rem;
  background-color: #fff;
  border-radius: 5rem;
}
.products_flexible_sec .container .products_overview_block .products_overview_solution_box .products_overview_solution_list li .products_overview_solution_list_txt {
  width: 100%;
  font-size: 2.2rem;
  color: #fff;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  text-align: center;
  margin-top: 0.9rem;
}
.products_flexible_sec .container .products_overview_block .products_overview_solution_box .products_overview_solution_list li .products_overview_solution_list_icon {
  width: 100%;
  text-align: center;
  margin-top: 1.4rem;
}
@media screen and (max-width: 1300px) {
  .products_flexible_sec .container .products_overview_block .products_overview_solution_box .products_overview_solution_list li {
    padding: 3rem 2rem;
  }
  .products_flexible_sec .container .products_overview_block .products_overview_solution_box .products_overview_solution_list li .products_overview_solution_list_ttl {
    min-height: 4rem;
    font-size: 2.5rem;
  }
}
.products_flexible_sec .container .products_overview_block .products_overview_cv_box {
  width: 100%;
  margin-top: 5.4rem;
}
.products_flexible_sec .container .products_overview_block .products_overview_cv_box .products_overview_cv_ttl {
  width: 100%;
  font-size: 3.8rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  text-align: center;
}
.products_flexible_sec .container .products_overview_block .products_overview_cv_box .products_overview_cv_btn {
  margin-top: 3.2rem;
}
.products_flexible_sec .container .products_introduction_block {
  --imgWidth: 29.854014598%;
  --width: calc(100% - (var(--imgWidth) + 2rem));
  --maxWidth: 94rem;
  position: relative;
}
.products_flexible_sec .container .products_introduction_block .products_introduction_ttl {
  width: var(--width);
  max-width: var(--maxWidth);
}
.products_flexible_sec .container .products_introduction_block .products_introduction_photo {
  width: var(--imgWidth);
  position: absolute;
  top: 3.9rem;
  right: -4.8rem;
}
.products_flexible_sec .container .products_introduction_block .products_introduction_txt {
  width: var(--width);
  max-width: var(--maxWidth);
  margin-top: 3.1rem;
}
.products_flexible_sec .container .products_introduction_block .products_introduction_txt:first-of-type {
  margin-top: 3.5rem;
}
.products_flexible_sec .container .products_introduction_block .products_introduction_txt:last-of-type {
  padding-bottom: 1.3rem;
}
.products_flexible_sec .container .products_introduction_block .products_introduction_box {
  --flexImgWidth: 53.571428571%;
}
.products_flexible_sec .container .products_introduction_block .products_introduction_box.w100 {
  --width: 100%;
  --maxWidth: 100%;
  --flexImgWidth: 35.433070866%;
}
.products_flexible_sec .container .products_introduction_block .products_introduction_box {
  width: var(--width);
  max-width: var(--maxWidth);
  min-height: 43rem;
  padding: 3.9rem 5rem;
  background-color: #edf0f5;
  border-radius: 1rem;
  margin-top: 4rem;
}
.products_flexible_sec .container .products_introduction_block .products_introduction_box .products_introduction_box_ttl {
  width: 100%;
  font-size: 2.6rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-top: 0.4rem;
  margin-bottom: 2rem;
}
.products_flexible_sec .container .products_introduction_block .products_introduction_box .products_introduction_box_txt {
  width: 100%;
}
.products_flexible_sec .container .products_introduction_block .products_introduction_box.flex .products_introduction_box_ttl {
  width: calc(100% - (var(--flexImgWidth) + 5rem));
  float: left;
}
.products_flexible_sec .container .products_introduction_block .products_introduction_box.flex .products_introduction_box_txt {
  width: calc(100% - (var(--flexImgWidth) + 5rem));
  float: left;
}
.products_flexible_sec .container .products_introduction_block .products_introduction_box.flex .products_introduction_box_img {
  width: var(--flexImgWidth);
  margin-top: 1.1rem;
  border-radius: 1rem;
  overflow: hidden;
  float: right;
}
.products_flexible_sec .container .products_introduction_block .products_introduction_box.w100 {
  --width: 100%;
  --maxWidth: 100%;
}
.products_flexible_sec .container .products_introduction_block .products_introduction_btn {
  margin-top: 8rem;
}
@media screen and (max-width: 1000px) {
  .products_flexible_sec .container .products_introduction_block .products_introduction_photo {
    top: 0;
    right: -2rem;
  }
  .products_flexible_sec .container .products_introduction_block .products_introduction_box .products_introduction_box_ttl {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .products_flexible_sec .container .products_introduction_block .products_introduction_box .products_introduction_box_txt {
    width: 100% !important;
    max-width: none !important;
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
  .products_flexible_sec .container .products_introduction_block .products_introduction_box .products_introduction_box_img {
    width: 30rem;
    margin: 0 auto 2rem;
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  .products_flexible_sec .container .products_introduction_block .products_introduction_btn {
    margin-top: 8rem;
  }
}
.products_flexible_sec .container .products_description_block {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 7.6rem;
}
.products_flexible_sec .container .products_description_block .products_desc_box {
  width: 47.810218978%;
}
.products_flexible_sec .container .products_description_block .products_desc_box .products_desc_ttl {
  width: 100%;
  font-size: 3.8rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.products_flexible_sec .container .products_description_block .products_desc_box .products_desc_photo {
  width: 100%;
  border-radius: 1rem;
  overflow: hidden;
  margin-top: 2.7rem;
}
.products_flexible_sec .container .products_description_block .products_desc_box .products_desc_txt {
  width: 100%;
  margin-top: 2.4rem;
}
.products_flexible_sec .container .products_wrap_column_block {
  width: 100%;
  border: solid 0.3rem #19396d;
  padding: 3.2rem 4.7rem 4.7rem;
  background-color: #edf0f5;
  border-radius: 1rem;
  margin-top: 9rem;
  --columnPhotoWidth: 45.669291338%;
}
.products_flexible_sec .container .products_wrap_column_block .products_wrap_col_ttl {
  width: calc(100% - (var(--columnPhotoWidth) + 6rem));
  font-size: 3.8rem;
  color: #fff;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding: 0.4rem 3rem 0.4rem 1.5rem;
  background-color: #19396d;
  clip-path: polygon(0 0, 100% 0, 96% 100%, 0% 100%);
  margin-top: 4.5rem;
  position: relative;
  float: right;
}
.products_flexible_sec .container .products_wrap_column_block .products_wrap_col_photo {
  width: var(--columnPhotoWidth);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 3rem;
  float: left;
}
.products_flexible_sec .container .products_wrap_column_block .products_wrap_col_photo picture {
  width: 100%;
  border-radius: 1rem;
  overflow: hidden;
  background-color: #ccc;
  display: block;
}
.products_flexible_sec .container .products_wrap_column_block .products_wrap_col_photo picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.products_flexible_sec .container .products_wrap_column_block .products_wrap_col_txt {
  width: calc(100% - (var(--columnPhotoWidth) + 6rem));
  float: right;
  margin-top: 3rem;
}
.products_flexible_sec .container .products_column_block_wrap {
  width: 100%;
  margin-top: 9rem;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block {
  width: 100%;
  --columnPhotoWidth: 42.335766423%;
  margin-top: 10rem;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block:first-of-type {
  margin-top: 0;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_ttl {
  width: calc(100% - (var(--columnPhotoWidth) + 6rem));
  font-size: 3.8rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  float: left;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_embed {
  width: var(--columnPhotoWidth);
  aspect-ratio: 1/0.5625;
  border-radius: 1rem;
  overflow: hidden;
  background-color: #ccc;
  display: block;
  float: right;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_embed iframe {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_photo {
  width: var(--columnPhotoWidth);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 3rem;
  float: right;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_photo .video_wrapper {
  width: 100%;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_photo .video_wrapper video {
  width: 100%;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_photo picture {
  width: 100%;
  border-radius: 1rem;
  overflow: hidden;
  background-color: #ccc;
  display: block;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_photo picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_txt {
  width: calc(100% - (var(--columnPhotoWidth) + 6rem));
  margin-top: 2rem;
  float: left;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_list {
  width: calc(100% - (var(--columnPhotoWidth) + 6rem));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 3rem;
  margin-top: 3.5rem;
  float: left;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_list dl {
  width: 100%;
  padding: 3.3rem 4.2rem 3.6rem;
  background-color: #edf0f5;
  border-radius: 1rem;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_list dl dt {
  width: 100%;
  font-size: 2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-left: 1.8rem;
  position: relative;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_list dl dt::before {
  content: "";
  width: 1.2rem;
  height: 0.2rem;
  background-color: #19396d;
  position: absolute;
  top: 1.6rem;
  left: -0.2rem;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_list dl dd {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.6666666667;
  letter-spacing: 0.05em;
  padding-top: 0.2rem;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_btn {
  width: calc(100% - (var(--columnPhotoWidth) + 6rem));
  margin-top: 3.3rem;
  float: left;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block.reverse .products_col_ttl {
  float: right;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block.reverse .products_col_txt {
  float: right;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block.reverse .products_col_list {
  float: right;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block.reverse .products_col_btn {
  float: right;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block.reverse .products_col_embed {
  float: left;
}
.products_flexible_sec .container .products_column_block_wrap .products_column_block.reverse .products_col_photo {
  float: left;
}
@media screen and (max-width: 1000px) {
  .products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_ttl {
    width: 100%;
    max-width: none;
  }
  .products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_ttl br {
    display: none;
  }
  .products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_embed {
    margin-top: 3rem;
  }
  .products_flexible_sec .container .products_column_block_wrap .products_column_block .products_col_photo {
    margin-top: 3rem;
  }
}
.products_flexible_sec .container .products_wrap_column_box {
  width: 100%;
  padding: 6.2rem 7rem 6.4rem;
  background-color: #edf0f5;
  border-radius: 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 6rem;
}
.products_flexible_sec .container .products_wrap_column_box .products_wrap_column_ttl {
  width: 100%;
  text-align: center;
  margin-bottom: 3.6rem;
}
.products_flexible_sec .container .products_wrap_column_box .products_wrap_column_ttl span {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding: 0 0.8rem 1rem;
  border-bottom: solid 0.1rem #19396d;
  display: inline-block;
}
.products_flexible_sec .container .products_wrap_column_box .products_wrap_column_inner {
  width: calc((100% - 2rem) / 2);
  max-width: 58rem;
}
.products_flexible_sec .container .products_wrap_column_box .products_wrap_column_inner .products_wrap_column_inner_ttl {
  width: 100%;
  font-size: 3.2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  text-align: center;
}
.products_flexible_sec .container .products_wrap_column_box .products_wrap_column_inner .products_wrap_column_inner_txt {
  width: 100%;
  font-size: 1.8rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  text-align: center;
  margin-bottom: 2rem;
}
.products_flexible_sec .container .products_wrap_column_box .products_wrap_column_inner .products_wrap_column_inner_embed {
  width: 100%;
  aspect-ratio: 1/0.5625;
  border-radius: 1rem;
  background-color: #ccc;
  overflow: hidden;
  display: block;
  margin-top: 0.9rem;
}
.products_flexible_sec .container .products_wrap_column_box .products_wrap_column_inner .products_wrap_column_inner_embed iframe {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.products_flexible_sec .container .products_wrap_column_box .products_wrap_column_inner .products_wrap_column_inner_img {
  width: 100%;
  margin-top: 0.9rem;
}
.products_flexible_sec .container .products_wrap_column_box .products_wrap_column_inner .products_wrap_column_inner_img .video_wrapper {
  width: 100%;
  aspect-ratio: 1/0.5625;
  border-radius: 1rem;
  background-color: #ccc;
  overflow: hidden;
  display: block;
}
.products_flexible_sec .container .products_wrap_column_box .products_wrap_column_inner .products_wrap_column_inner_img .video_wrapper video {
  width: 100%;
}
.products_flexible_sec .container .products_wrap_column_box .products_wrap_column_inner .products_wrap_column_inner_img picture {
  width: 100%;
  aspect-ratio: 1/0.4931034483;
  border-radius: 1rem;
  background-color: #ccc;
  overflow: hidden;
  display: block;
}
.products_flexible_sec .container .products_wrap_column_box .products_wrap_column_inner .products_wrap_column_inner_img picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.products_flexible_sec .container .products_wrap_column_box .products_wrap_column_inner .products_wrap_column_inner_img figcaption {
  width: 100%;
  margin-top: 0.7rem;
}
.products_flexible_sec .container .products_wrap_column_box .products_wrap_column_inner .products_wrap_column_inner_img figcaption.center {
  text-align: center;
}
.products_flexible_sec .container .products_four_column_list {
  margin-top: 4.4rem;
}
.products_flexible_sec .container .products_btn_block {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 3rem;
  margin-bottom: 5rem;
}
.products_flexible_sec .container .products_btn_block a.catalog span {
  letter-spacing: 0;
  padding-left: 4.7rem;
}
.products_flexible_sec .container .products_btn_block a.catalog span::before {
  left: 0.2rem;
}
.products_flexible_sec .container * + .products_btn_block {
  margin-top: 6.3rem;
}
.products_flexible_sec .container .products_voice_list {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4rem 3.357664233%;
  margin-top: 4.2rem;
}
.products_flexible_sec .container .products_voice_list.two_column {
  grid-template-columns: repeat(2, 1fr);
}
.products_flexible_sec .container .products_voice_list.two_column li {
  padding: 4rem 4rem 6.6rem;
}
.products_flexible_sec .container .products_voice_list.two_column li .products_voice_message {
  line-height: 1.8888888889;
}
.products_flexible_sec .container .products_voice_list li {
  padding: 3.2rem 4rem 6.5rem;
  position: relative;
  background-color: #edf0f5;
  border-radius: 1rem;
}
.products_flexible_sec .container .products_voice_list li .products_voice_message {
  width: 100%;
  line-height: 1.7777777778;
}
.products_flexible_sec .container .products_voice_list li .products_voice_user {
  font-size: 1.6rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-right: 0.8rem;
  text-align: right;
  position: absolute;
  bottom: 3.4rem;
  right: 4rem;
}
.products_flexible_sec .container .products_merit_list {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2.189781021%;
  margin-top: 4.4rem;
}
.products_flexible_sec .container .products_merit_list li {
  height: 22.5rem;
  font-size: 3rem;
  color: #fff;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-align: center;
  padding: 1rem;
  background-color: #19396d;
  border-radius: 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  overflow: hidden;
}
.products_flexible_sec .container .products_case_block {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 4rem;
  margin-top: 5rem;
}
.products_flexible_sec .container .products_case_block .products_case_box {
  width: 100%;
  padding: 5rem;
  background-color: #edf0f5;
  border-radius: 1rem;
  --imgWidth: 39.37007874%;
  --width: calc(100% - (var(--imgWidth) + 2rem));
}
.products_flexible_sec .container .products_case_block .products_case_box .products_case_ttl {
  width: var(--width);
  float: left;
}
.products_flexible_sec .container .products_case_block .products_case_box .products_case_ttl .num {
  width: 20rem;
  height: 5rem;
  font-size: 2.2rem;
  color: #fff;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
  border-radius: 5rem;
  padding: 1rem;
  background-color: #19396d;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.products_flexible_sec .container .products_case_block .products_case_box .products_case_ttl .ttl {
  width: 100%;
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 1.7692307692;
  letter-spacing: 0.05em;
  display: block;
  margin-top: 0.9rem;
}
.products_flexible_sec .container .products_case_block .products_case_box .products_case_img {
  width: var(--imgWidth);
  float: right;
}
.products_flexible_sec .container .products_case_block .products_case_box .products_case_img picture {
  width: 100%;
  aspect-ratio: 1/0.666;
  border-radius: 1rem;
  background-color: #ccc;
  overflow: hidden;
  display: block;
}
.products_flexible_sec .container .products_case_block .products_case_box .products_case_img picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.products_flexible_sec .container .products_case_block .products_case_box .products_case_desc {
  width: var(--width);
  margin-top: 1.8rem;
  float: left;
}
@media screen and (max-width: 1000px) {
  .products_flexible_sec .container .products_case_block .products_case_box .products_case_ttl {
    width: 100%;
  }
  .products_flexible_sec .container .products_case_block .products_case_box .products_case_img {
    margin-top: 1.8rem;
  }
}
.products_flexible_sec .container .products_spec_block {
  width: 100%;
  max-width: 90rem;
  margin: 4.5rem auto 0;
}
.products_flexible_sec .container .products_spec_block .products_spec_table_wrap .products_spec_table {
  width: 100%;
  display: table;
  border: solid 0.1rem #dddddd;
  border-right: none;
  border-left: none;
}
.products_flexible_sec .container .products_spec_block .products_spec_table_wrap .products_spec_table tr {
  border-bottom: solid 0.1rem #dddddd;
}
.products_flexible_sec .container .products_spec_block .products_spec_table_wrap .products_spec_table tr *:first-child {
  border-left: none;
}
.products_flexible_sec .container .products_spec_block .products_spec_table_wrap .products_spec_table tr *:last-child {
  border-right: none;
}
.products_flexible_sec .container .products_spec_block .products_spec_table_wrap .products_spec_table tr th {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  white-space: nowrap;
  padding: 1.6rem 2rem;
  background-color: #f3f3f3;
  border: solid 0.1rem #dddddd;
}
.products_flexible_sec .container .products_spec_block .products_spec_table_wrap .products_spec_table tr td {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding: 1.6rem 2rem;
  border: solid 0.1rem #dddddd;
}
.products_flexible_sec .container .products_spec_block .products_spec_note {
  width: 100%;
  margin-top: 2.6rem;
}
.products_flexible_sec .container .products_spec_block .products_spec_note dt {
  width: 100%;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  margin-bottom: 1.1rem;
}
.products_flexible_sec .container .products_spec_block .products_spec_note dt span {
  color: #e8472b;
}
.products_flexible_sec .container .products_spec_block .products_spec_note dd {
  width: 100%;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: 0.05em;
  position: relative;
  padding-left: 1.3rem;
}
.products_flexible_sec .container .products_spec_block .products_spec_note dd::before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
}

.common_item_list {
  width: 100%;
  display: grid;
}
.common_item_list.three_column {
  grid-template-columns: repeat(3, 1fr);
  gap: 3rem 3.357664233%;
}
.common_item_list.three_column li .products_item_name {
  margin-top: 2.5rem;
}
.common_item_list.three_column li .products_item_embed {
  aspect-ratio: 1/0.7464788732;
}
.common_item_list.three_column li .products_item_photo {
  width: 100%;
}
.common_item_list.three_column li .products_item_photo picture {
  aspect-ratio: 1/0.7464788732;
}
.common_item_list.three_column li .products_item_photo .video_wrapper {
  aspect-ratio: 1/0.7464788732;
}
.common_item_list.three_column li .products_item_desc {
  line-height: 1.7777777778;
  margin-top: 1rem;
}
.common_item_list.four_column {
  grid-template-columns: repeat(4, 1fr);
  gap: 3rem 2.189781021%;
}
.common_item_list.four_column li .products_item_name {
  margin-top: 2rem;
}
.common_item_list.four_column li .products_item_embed {
  aspect-ratio: 1/0.9125;
}
.common_item_list.four_column li .products_item_photo picture {
  aspect-ratio: 1/0.9125;
}
.common_item_list.four_column li .products_item_photo .video_wrapper {
  aspect-ratio: 1/0.9125;
}
.common_item_list.four_column li .products_item_desc {
  line-height: 1.5555555556;
  margin-top: 0;
}
.common_item_list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.common_item_list li .products_item_name {
  width: 100%;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.common_item_list li .products_item_embed {
  width: 100%;
  border-radius: 1rem;
  overflow: hidden;
}
.common_item_list li .products_item_embed iframe {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.common_item_list li .products_item_photo {
  width: 100%;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.common_item_list li .products_item_photo picture {
  width: 100%;
  border-radius: 1rem;
  background-color: #ccc;
  overflow: hidden;
  display: block;
}
.common_item_list li .products_item_photo picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.common_item_list li .products_item_photo .video_wrapper {
  background-color: #ccc;
  border-radius: 1rem;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.common_item_list li .products_item_photo .video_wrapper video {
  width: 100%;
}
.common_item_list li .products_item_desc {
  width: 100%;
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
}

/*----------------------------------------------------------------------------
******************************************************************************
** opening
******************************************************************************
----------------------------------------------------------------------------*/
.opening_clinic_sec01 {
  padding-top: 6rem;
  padding-bottom: 7.3rem;
  border-bottom: solid 0.1rem #dddddd;
}
.opening_clinic_sec01 .container .opening_clinic_txt {
  text-align: center;
  margin-top: 3.5rem;
}
.opening_clinic_sec01 .container .opening_clinic_flow_block {
  width: 100%;
  padding-top: 8rem;
  padding-bottom: 4rem;
}
.opening_clinic_sec01 .container .opening_clinic_flow_block .opening_clinic_flow_box {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 5rem;
  --contWidth: 61.313868613%;
}
.opening_clinic_sec01 .container .opening_clinic_flow_block .opening_clinic_flow_box .opening_clinic_flow_img {
  width: calc(100% - (var(--contWidth) + 2rem));
  max-width: 45rem;
  border-radius: 1rem;
  overflow: hidden;
}
.opening_clinic_sec01 .container .opening_clinic_flow_block .opening_clinic_flow_box .opening_clinic_flow_txt {
  width: var(--contWidth);
  padding-top: 1.1rem;
}
.opening_clinic_sec01 .container .opening_clinic_flow_block .opening_clinic_flow_chart {
  width: 100%;
  margin-top: 5rem;
}
.opening_clinic_sec01 .container .opening_clinic_layout_block {
  width: 100%;
  padding-top: 4.8rem;
  padding-bottom: 4rem;
}
.opening_clinic_sec01 .container .opening_clinic_layout_block .opening_clinic_layout_list {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 5rem;
}
.opening_clinic_sec01 .container .opening_clinic_layout_block .opening_clinic_layout_list li {
  width: calc((100% - 4rem) / 3);
  max-width: 43.6rem;
}
.opening_clinic_sec01 .container .opening_clinic_layout_block .opening_clinic_layout_list li a {
  width: 100%;
  display: block;
}
.opening_clinic_sec01 .container .opening_clinic_layout_block .opening_clinic_layout_list li a .layout_list_img {
  width: 100%;
  border-radius: 1rem;
  overflow: hidden;
}
.opening_clinic_sec01 .container .opening_clinic_layout_block .opening_clinic_layout_list li a .layout_list_img picture {
  width: 100%;
  aspect-ratio: 1/0.6651376147;
  display: inline-block;
}
.opening_clinic_sec01 .container .opening_clinic_layout_block .opening_clinic_layout_list li a .layout_list_img picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.opening_clinic_sec01 .container .opening_clinic_layout_block .opening_clinic_layout_list li a .layout_list_txt {
  width: 100%;
  font-size: 2.2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-left: 5.5rem;
  margin-top: 2.1rem;
  position: relative;
}
.opening_clinic_sec01 .container .opening_clinic_layout_block .opening_clinic_layout_list li a .layout_list_txt::before {
  content: "";
  width: 4rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: -webkit-image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #f2f238;
  background: image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #f2f238;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.opening_clinic_sec01 .container .opening_clinic_layout_block .opening_clinic_layout_list li a:hover .layout_list_txt::before {
  left: 1rem;
}
.opening_clinic_sec01 .container .opening_clinic_support_block {
  width: 100%;
  padding-top: 5.1rem;
  padding-bottom: 4rem;
}
.opening_clinic_sec01 .container .opening_clinic_support_block .opening_clinic_support_box {
  width: 100%;
  margin-top: 5rem;
  --contWidth: 61.313868613%;
}
.opening_clinic_sec01 .container .opening_clinic_support_block .opening_clinic_support_box .opening_clinic_support_img {
  width: calc(100% - (var(--contWidth) + 2rem));
  max-width: 47.3rem;
  margin-left: -1.1rem;
  float: left;
}
.opening_clinic_sec01 .container .opening_clinic_support_block .opening_clinic_support_box .opening_clinic_support_txt {
  width: var(--contWidth);
  padding-top: 1.1rem;
  float: right;
}
.opening_clinic_sec01 .container .opening_clinic_support_block .opening_clinic_support_box .opening_clinic_support_btn {
  width: var(--contWidth);
  margin-top: 4.2rem;
  float: right;
}
.opening_clinic_sec01 .container .opening_clinic_support_block .opening_clinic_support_box .opening_clinic_support_btn a {
  max-width: 45rem;
}
.opening_clinic_sec01 .container .opening_clinic_guarantee_block {
  width: 100%;
  padding-top: 4.8rem;
  padding-bottom: 4rem;
}
.opening_clinic_sec01 .container .opening_clinic_guarantee_block .opening_clinic_guarantee_box {
  width: 100%;
  margin-top: 5rem;
  --contWidth: 61.313868613%;
}
.opening_clinic_sec01 .container .opening_clinic_guarantee_block .opening_clinic_guarantee_box .opening_clinic_guarantee_img {
  width: calc(100% - (var(--contWidth) + 2rem));
  max-width: 45rem;
  float: left;
}
.opening_clinic_sec01 .container .opening_clinic_guarantee_block .opening_clinic_guarantee_box .opening_clinic_guarantee_txt {
  width: var(--contWidth);
  max-width: 84rem;
  margin-top: 2.1rem;
  float: right;
}
.opening_clinic_sec01 .container .opening_clinic_guarantee_block .opening_clinic_guarantee_box .opening_clinic_guarantee_txt .color {
  color: #e8472b;
}
.opening_clinic_sec01 .container .opening_clinic_guarantee_block .opening_clinic_guarantee_box .opening_clinic_guarantee_txt:first-of-type {
  padding-top: 1.1rem;
  margin-top: 0;
}

.opening_clinic_sec02 {
  padding-top: 11.3rem;
  padding-bottom: 14.2rem;
  border-bottom: solid 0.1rem #dddddd;
}
.opening_clinic_sec02 .container .opening_clinic_example_block {
  width: 100%;
  margin-top: 8.8rem;
}
.opening_clinic_sec02 .container .opening_clinic_example_block:first-of-type {
  margin-top: 7.4rem;
}
.opening_clinic_sec02 .container .opening_clinic_example_block .opening_clinic_example_txt {
  margin-top: 4rem;
}
.opening_clinic_sec02 .container .opening_clinic_example_block .opening_clinic_example_list {
  margin-top: 4.4rem;
}
.opening_clinic_sec02 .container .opening_clinic_example_block .opening_clinic_example_point {
  width: 100%;
  min-height: 22.8rem;
  padding: 4.7rem 5rem;
  background-color: #edf0f5;
  border-radius: 1rem;
  margin-top: 3.7rem;
}
.opening_clinic_sec02 .container .opening_clinic_example_block .opening_clinic_example_point .example_point_ttl {
  width: 100%;
  font-size: 2.4rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-left: 6.6rem;
  position: relative;
}
.opening_clinic_sec02 .container .opening_clinic_example_block .opening_clinic_example_point .example_point_ttl::before {
  content: "";
  width: 5.2rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: url(../images/common/point_icon.png) no-repeat center/2rem, #f2f238;
  background: url(../images/common/point_icon.svg) no-repeat center/2rem, #f2f238;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.opening_clinic_sec02 .container .opening_clinic_example_block .opening_clinic_example_point .example_point_txt {
  width: 100%;
  margin-top: 2rem;
}

.common_thumb_list {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.411192214%;
}
.common_thumb_list.large {
  grid-template-columns: repeat(3, 1fr);
  gap: 5.5rem 2.153284671%;
}
.common_thumb_list.large li .example_list_ttl {
  font-size: 2.2rem;
  margin-top: 1.7rem;
}
.common_thumb_list.large li .example_list_ttl::before {
  top: 1rem;
}
.common_thumb_list.large li .example_list_txt {
  font-size: 1.8rem;
  line-height: 1.7777777;
  margin-top: 0.9rem;
}
.common_thumb_list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.common_thumb_list li .example_list_ttl {
  width: 100%;
  font-size: 1.8rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-left: 2.6rem;
  margin-top: 1.6rem;
  position: relative;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.common_thumb_list li .example_list_ttl::before {
  content: "";
  width: 1.8rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  border: solid 0.5rem #19396d;
  background-color: #f2f238;
  position: absolute;
  top: 0.7rem;
  left: 0;
}
.common_thumb_list li .example_list_img {
  width: 100%;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.common_thumb_list li .example_list_txt {
  width: 100%;
  line-height: 1.625;
  margin-top: 0.4rem;
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
}

.opening_clinic_sec03 {
  padding-top: 11.3rem;
  padding-bottom: 12.2rem;
  border-bottom: solid 0.1rem #dddddd;
}
.opening_clinic_sec03 .container .opening_clinic_fl_point_block {
  width: 100%;
  margin-top: 7.4rem;
}
.opening_clinic_sec03 .container .opening_clinic_fl_point_block .opening_clinic_fl_point_box {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-top: 4.8rem;
  --contWidth: 47.445255474%;
}
.opening_clinic_sec03 .container .opening_clinic_fl_point_block .opening_clinic_fl_point_box .fl_point_box_txt {
  width: var(--contWidth);
}
.opening_clinic_sec03 .container .opening_clinic_fl_point_block .opening_clinic_fl_point_box .fl_point_box_inner {
  width: calc(100% - (var(--contWidth) + 2rem));
  max-width: 64.5rem;
  min-height: 27.9rem;
  padding: 3.2rem 3.8rem;
  background-color: #edf0f5;
  border-radius: 1rem;
  margin-top: 0.3rem;
}
.opening_clinic_sec03 .container .opening_clinic_fl_point_block .opening_clinic_fl_point_box .fl_point_box_inner .fl_point_box_inner_ttl {
  width: 100%;
  font-size: 2.2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.opening_clinic_sec03 .container .opening_clinic_fl_point_block .opening_clinic_fl_point_box .fl_point_box_inner .fl_point_box_inner_list {
  margin-top: 1.6rem;
}
.opening_clinic_sec03 .container .opening_clinic_fl_example_block {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 9rem;
}
.opening_clinic_sec03 .container .opening_clinic_fl_example_block .opening_clinic_fl_example_box {
  width: calc((100% - 2rem) / 2);
  max-width: 64.5rem;
}
.opening_clinic_sec03 .container .opening_clinic_fl_example_block .opening_clinic_fl_example_box .fl_example_box_ttl {
  width: 100%;
  min-height: 7rem;
  font-size: 2.6rem;
  color: #fff;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding: 1rem;
  background-color: #19396d;
  border-radius: 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.opening_clinic_sec03 .container .opening_clinic_fl_example_block .opening_clinic_fl_example_box .fl_example_box_img {
  width: 100%;
  text-align: center;
  margin-top: 4rem;
}

.opening_clinic_sec04 {
  padding-top: 11.3rem;
  padding-bottom: 14.5rem;
  border-bottom: solid 0.1rem #dddddd;
}
.opening_clinic_sec04 .container .opening_clinic_lighting_block {
  width: 100%;
  margin-top: 7.4rem;
}
.opening_clinic_sec04 .container .opening_clinic_lighting_block .opening_clinic_lighting_txt {
  margin-top: 3.2rem;
}
.opening_clinic_sec04 .container .opening_clinic_lighting_block .opening_clinic_lighting_txt:first-of-type {
  margin-top: 4rem;
}
.opening_clinic_sec04 .container .opening_clinic_lighting_block .opening_clinic_lighting_point {
  width: 100%;
  min-height: 14.1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1.1rem;
  padding: 3.5rem 4rem;
  background-color: #edf0f5;
  border-radius: 1rem;
  margin-top: 3.3rem;
}
.opening_clinic_sec04 .container .opening_clinic_lighting_block .opening_clinic_lighting_point li {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-left: 2.5rem;
  position: relative;
}
.opening_clinic_sec04 .container .opening_clinic_lighting_block .opening_clinic_lighting_point li::before {
  content: "";
  width: 1rem;
  aspect-ratio: 1/1;
  background-color: #19396d;
  border-radius: 50%;
  position: absolute;
  top: 1rem;
  left: 0;
}
.opening_clinic_sec04 .container .opening_clinic_lighting_block .opening_clinic_lighting_list {
  margin-top: 7rem;
}
.opening_clinic_sec04 .container .opening_clinic_lighting_block .opening_clinic_books_ttl {
  margin-top: 10rem;
}
.opening_clinic_sec04 .container .opening_clinic_lighting_block .opening_clinic_books {
  margin-top: 7rem;
}
.opening_clinic_sec04 .container .opening_clinic_lighting_block .opening_clinic_books a {
  display: inline-block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.opening_clinic_sec04 .container .opening_clinic_lighting_block .opening_clinic_books a:hover {
  opacity: 0.7;
}
.opening_clinic_sec04 .container .opening_clinic_lighting_block .opening_clinic_books a figcaption {
  text-align: center;
}

.opening_clinic_sec05 {
  padding-top: 11.3rem;
  padding-bottom: 14.5rem;
  border-bottom: solid 0.1rem #dddddd;
}
.opening_clinic_sec05 .container .opening_clinic_management_txt {
  margin-top: 5rem;
}
.opening_clinic_sec05 .container .opening_clinic_management_block {
  width: 100%;
  margin-top: 7.4rem;
}
.opening_clinic_sec05 .container .opening_clinic_management_block .opening_clinic_management_box {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 5rem;
  --contWidth: 61.313868613%;
}
.opening_clinic_sec05 .container .opening_clinic_management_block .opening_clinic_management_box .opening_clinic_management_img {
  width: calc(100% - (var(--contWidth) + 2rem));
  max-width: 45rem;
  text-align: center;
}
.opening_clinic_sec05 .container .opening_clinic_management_block .opening_clinic_management_box .opening_clinic_management_img a {
  display: inline-block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.opening_clinic_sec05 .container .opening_clinic_management_block .opening_clinic_management_box .opening_clinic_management_img a:hover {
  opacity: 0.7;
}
.opening_clinic_sec05 .container .opening_clinic_management_block .opening_clinic_management_box .opening_clinic_management_img figcaption {
  width: 100%;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.625;
  letter-spacing: 0.05em;
  text-align: center;
  margin-top: 0.5rem;
}
.opening_clinic_sec05 .container .opening_clinic_management_block .opening_clinic_management_box .opening_clinic_management_detail {
  width: var(--contWidth);
  padding-top: 1.1rem;
}
.opening_clinic_sec05 .container .opening_clinic_management_block .opening_clinic_management_box .opening_clinic_management_detail .opening_clinic_management_detail_list {
  width: 100%;
  margin-top: 2rem;
}
.opening_clinic_sec05 .container .opening_clinic_management_block .opening_clinic_management_box .opening_clinic_management_detail .opening_clinic_management_detail_btn {
  width: 100%;
  margin-top: 1rem;
}
.opening_clinic_sec05 .container .opening_clinic_management_block .opening_clinic_management_box .opening_clinic_management_detail .opening_clinic_management_detail_btn a {
  color: #19396d;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 0.5rem;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.opening_clinic_sec05 .container .opening_clinic_management_block .opening_clinic_management_box .opening_clinic_management_detail .opening_clinic_management_detail_btn a:hover {
  opacity: 0.7;
}
.opening_clinic_sec05 .container .opening_clinic_management_block .opening_clinic_management_btn {
  margin-top: 5rem;
}

.opening_clinic_sec06 {
  padding-top: 3rem;
  padding-bottom: 14.5rem;
}

.common_ttl05 {
  width: 100%;
  font-size: 3.4rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-bottom: 1.5rem;
  border-bottom: solid 0.1rem #19396d;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 2.2rem;
}
.common_ttl05 span {
  font-size: 2rem;
  display: inline-block;
  margin-top: 0.4rem;
}

.common_navi_sec {
  padding-top: 12rem;
  padding-bottom: 10rem;
  background: -webkit-image-set(url(../images/common/common_nav_sec_bg.jpg) 1x, url(../images/common/common_nav_sec_bg@2x.jpg) 2x) no-repeat center/cover;
  background: image-set(url(../images/common/common_nav_sec_bg.jpg) 1x, url(../images/common/common_nav_sec_bg@2x.jpg) 2x) no-repeat center/cover;
  background: -webkit-image-set(url(../images/common/common_nav_sec_bg.webp) 1x, url(../images/common/common_nav_sec_bg@2x.webp) 2x) no-repeat center/cover;
  background: image-set(url(../images/common/common_nav_sec_bg.webp) 1x, url(../images/common/common_nav_sec_bg@2x.webp) 2x) no-repeat center/cover;
}
.common_navi_sec .container .navi_sec_list {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.262773722%;
}
.common_navi_sec .container .navi_sec_list li a,
.common_navi_sec .container .navi_sec_list li > span {
  width: 100%;
  height: 100%;
  background-color: #fff;
  border-radius: 1rem;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
  cursor: pointer;
}
.common_navi_sec .container .navi_sec_list li a::before,
.common_navi_sec .container .navi_sec_list li > span::before {
  content: "";
  width: 4rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: -webkit-image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #f2f238;
  background: image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #f2f238;
  position: absolute;
  right: 1.5rem;
  bottom: 1.5rem;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_navi_sec .container .navi_sec_list li a .navi_sec_ttl,
.common_navi_sec .container .navi_sec_list li > span .navi_sec_ttl {
  width: 63.302752294%;
  padding: 6.880733944%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.common_navi_sec .container .navi_sec_list li a .navi_sec_ttl span,
.common_navi_sec .container .navi_sec_list li > span .navi_sec_ttl span {
  display: inline-block;
}
.common_navi_sec .container .navi_sec_list li a .navi_sec_ttl .wrap .en,
.common_navi_sec .container .navi_sec_list li > span .navi_sec_ttl .wrap .en {
  width: 100%;
  font-family: "Jost";
  font-size: 1.4rem;
  color: #19396d;
  font-weight: 500;
  line-height: 2;
  letter-spacing: 0.05em;
  display: inline-block;
  text-decoration: underline;
  text-decoration-color: #f2f238;
  text-underline-offset: 1rem;
  margin-left: 0.3rem;
}
.common_navi_sec .container .navi_sec_list li a .navi_sec_ttl .wrap .jp,
.common_navi_sec .container .navi_sec_list li > span .navi_sec_ttl .wrap .jp {
  width: 100%;
  font-size: 2.2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  display: block;
  margin-top: 0.8375rem;
}
@media screen and (max-width: 1200px) {
  .common_navi_sec .container .navi_sec_list li a .navi_sec_ttl .wrap .jp,
  .common_navi_sec .container .navi_sec_list li > span .navi_sec_ttl .wrap .jp {
    padding-right: 1rem;
  }
}
.common_navi_sec .container .navi_sec_list li a .navi_sec_img,
.common_navi_sec .container .navi_sec_list li > span .navi_sec_img {
  width: 36.697247706%;
  height: 100%;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.common_navi_sec .container .navi_sec_list li a .navi_sec_img picture,
.common_navi_sec .container .navi_sec_list li > span .navi_sec_img picture {
  width: 100%;
  height: 100%;
}
.common_navi_sec .container .navi_sec_list li a .navi_sec_img picture img,
.common_navi_sec .container .navi_sec_list li > span .navi_sec_img picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.common_navi_sec .container .navi_sec_list li a:hover::before,
.common_navi_sec .container .navi_sec_list li > span:hover::before {
  right: 0.5rem;
}

/*----------------------------------------------------------------------------
******************************************************************************
** used
******************************************************************************
----------------------------------------------------------------------------*/
.common_ttl06 {
  width: 100%;
  font-size: 2.2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
}

.used_sec01 {
  padding-top: 6rem;
  padding-bottom: 15rem;
  border-bottom: solid 0.1rem #dddddd;
}
.used_sec01 .container .used_block {
  width: 100%;
  margin-top: 7.3rem;
}
.used_sec01 .container .used_block .used_sub_ttl {
  margin-top: 4.4rem;
}
.used_sec01 .container .used_block .used_txt {
  margin-top: 1.4rem;
}
.used_sec01 .container .used_block .used_list_box {
  width: 100%;
  border-radius: 1rem;
  padding: 3.9rem 3.8rem 4.2rem;
  background-color: #edf0f5;
  margin-top: 2.4rem;
}
.used_sec01 .container .used_block .used_list_box .used_list {
  gap: 1.6rem;
}
.used_sec01 .container .used_block .used_caution {
  width: 100%;
  margin-top: 4.5rem;
}
.used_sec01 .container .used_block .used_caution dt {
  width: 100%;
  margin-bottom: 1.3rem;
}
.used_sec01 .container .used_block .used_caution dt span {
  width: 16rem;
  min-height: 4.6rem;
  font-size: 2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
  padding: 0.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 0.6rem;
  background-color: #f2f238;
}
.used_sec01 .container .used_block .used_caution dd {
  width: 100%;
}
.used_sec01 .container .used_block .used_caution dd a {
  text-decoration: underline;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.used_sec01 .container .used_block .used_caution dd a:hover {
  opacity: 0.7;
}
.used_sec01 .container .used_block .used_box {
  width: 100%;
  margin-top: 1.3rem;
}
.used_sec01 .container .used_block .used_box .used_box_ttl {
  width: 100%;
  font-weight: 700;
}
.used_sec01 .container .used_block .used_box .used_box_txt {
  width: 100%;
}
.used_sec01 .container .used_block .used_box .used_box_bunner {
  width: 100%;
  margin-top: 2.3rem;
}
.used_sec01 .container .used_block .used_box .used_box_bunner a {
  display: inline-block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.used_sec01 .container .used_block .used_box .used_box_bunner a:hover {
  opacity: 0.7;
}
.used_sec01 .container .used_block .used_flex_box {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 8.3rem;
  margin-top: 5.3rem;
}
.used_sec01 .container .used_block .used_flex_box .used_flex_inner .used_flex_file {
  width: 100%;
  margin-top: 1.8rem;
}
.used_sec01 .container .used_block .used_flex_box .used_flex_inner .used_flex_file a {
  display: inline-block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.used_sec01 .container .used_block .used_flex_box .used_flex_inner .used_flex_file a .used_file_btn {
  width: 100%;
  margin-top: 1.3rem;
}
.used_sec01 .container .used_block .used_flex_box .used_flex_inner .used_flex_file a .used_file_btn span {
  display: inline-block;
  position: relative;
  padding-right: 5.4rem;
}
.used_sec01 .container .used_block .used_flex_box .used_flex_inner .used_flex_file a .used_file_btn span::before {
  content: "";
  width: 3.1rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: -webkit-image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.3rem, #f2f238;
  background: image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.3rem, #f2f238;
  position: absolute;
  top: calc(50% + 0.2rem);
  right: 1rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.used_sec01 .container .used_block .used_flex_box .used_flex_inner .used_flex_file a:hover {
  opacity: 0.7;
}
.used_sec01 .container .used_block .used_flex_box .used_flex_inner .used_flex_file a:hover .used_file_btn span::before {
  right: 0;
}
.used_sec01 .container .used_block.btoc {
  margin-top: 8.1rem;
}
.used_sec01 .container .used_block.btoc .used_txt {
  margin-top: 2rem;
}
.used_sec01 .container .used_block.btoc .used_txt:first-of-type {
  margin-top: 4rem;
}
.used_sec01 .container .used_block.btoc .used_sub_ttl {
  margin-top: 4.6rem;
}

/*----------------------------------------------------------------------------
******************************************************************************
** Instructor
******************************************************************************
----------------------------------------------------------------------------*/
.instructor_sec01 {
  padding-top: 6rem;
  padding-bottom: 15rem;
}
.instructor_sec01 .container .instructor_txt {
  max-width: 100rem;
  margin: 3.7rem auto 0;
}
.instructor_sec01 .container .instructor_nav {
  margin-top: 7.3rem;
}
.instructor_sec01 .container .instructor_nav a {
  padding: 0 2.3rem;
}
.instructor_sec01 .container .instructor_area_block {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 9rem;
  margin-top: 8.7rem;
}
.instructor_sec01 .container .instructor_area_block .instructor_area_box {
  width: 100%;
}
.instructor_sec01 .container .instructor_area_block .instructor_area_box .instructor_area_list {
  margin-top: 4rem;
}

.onepoint-need-login {
  padding: 10rem 2rem;
}

.common_instructor_list {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 5rem 3rem;
}
@media screen and (max-width: 1000px) {
  .common_instructor_list {
    grid-template-columns: repeat(3, 1fr);
  }
}
.common_instructor_list li > div {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.common_instructor_list li > div .instructor_photo {
  width: 100%;
  aspect-ratio: 1/1;
  border-radius: 1rem;
  overflow: hidden;
  -webkit-box-ordinal-group: 0;
      -ms-flex-order: -1;
          order: -1;
}
.common_instructor_list li > div .instructor_photo picture {
  width: 100%;
  height: 100%;
}
.common_instructor_list li > div .instructor_photo picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.common_instructor_list li > div .instructor_name {
  width: 100%;
  font-size: 2.2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-left: 0.2rem;
  margin-top: 1.6rem;
}
.common_instructor_list li > div .instructor_position {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.555555;
  letter-spacing: 0.05em;
  padding-left: 0.2rem;
  margin-top: 0.9rem;
}
.common_instructor_list li > div .instructor_description {
  width: 100%;
  line-height: 1.875;
  padding: 1.7rem 2.8rem;
  background-color: #f3f3f3;
  margin-top: 1.5rem;
}

/*----------------------------------------------------------------------------
******************************************************************************
** safety data sheet
******************************************************************************
----------------------------------------------------------------------------*/
.sds_sec01 {
  padding-top: 6rem;
  padding-bottom: 15rem;
}
.sds_sec01 .container .sds_block {
  width: 100%;
  margin-top: 7.3rem;
}
.sds_sec01 .container .sds_block .sds_ttl {
  margin-bottom: 4.4rem;
}
.sds_sec01 .container .sds_block .sds_sub_ttl {
  margin-top: 4.4rem;
}
.sds_sec01 .container .sds_block .sds_sub_ttl span {
  font-size: 1.6rem;
}
.sds_sec01 .container .sds_block .sds_txt {
  margin-top: 1.4rem;
}
.sds_sec01 .container .sds_block .sds_txt a {
  color: #19396d;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 1rem;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.sds_sec01 .container .sds_block .sds_txt a:hover {
  opacity: 0.7;
}
.sds_sec01 .container .sds_block .sds_list {
  width: 100%;
  display: grid;
  gap: 3rem 5rem;
  margin-top: 3rem;
  margin-bottom: 5rem;
  grid-template-columns: repeat(3, minmax(auto, 36rem));
}
.sds_sec01 .container .sds_block .sds_list li a {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.sds_sec01 .container .sds_block .sds_list li a .sds_name {
  width: 100%;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.4545454546;
  letter-spacing: 0.05em;
  padding-right: 7rem;
  margin-top: 2.2rem;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.sds_sec01 .container .sds_block .sds_list li a .sds_img {
  width: 100%;
  max-width: 32rem;
  aspect-ratio: 1/1;
  border-radius: 1rem;
  overflow: hidden;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  margin: 0 auto;
}
.sds_sec01 .container .sds_block .sds_list li a .sds_img picture {
  width: 100%;
  height: 100%;
  display: inline-block;
}
.sds_sec01 .container .sds_block .sds_list li a .sds_img picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.sds_sec01 .container .sds_block .sds_list li a .sds_data {
  padding-right: 7rem;
  padding-bottom: 1rem;
  border-bottom: solid 0.1rem #19396d;
  margin-bottom: 1rem;
  position: relative;
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
}
.sds_sec01 .container .sds_block .sds_list li a .sds_data::before {
  content: "";
  width: 5rem;
  height: 4.375rem;
  background: url(../images/common/pdf_icon.png) no-repeat center/contain;
  position: absolute;
  bottom: 1rem;
  right: 0;
}
.sds_sec01 .container .sds_block .sds_list li a .sds_note {
  width: 100%;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.625;
  letter-spacing: 0.05em;
  -webkit-box-ordinal-group: 5;
      -ms-flex-order: 4;
          order: 4;
}
.sds_sec01 .container .sds_block .sds_list li a:hover {
  opacity: 0.7;
}

/*----------------------------------------------------------------------------
******************************************************************************
** pharmaceutical
******************************************************************************
----------------------------------------------------------------------------*/
.pharmaceutical_sec {
  padding-top: 6.8rem;
  padding-bottom: 15rem;
}
.pharmaceutical_sec .container .pharmaceutical_txt {
  margin-top: 3.8rem;
}
.pharmaceutical_sec .container .pharmaceutical_table {
  width: 100%;
  margin-top: 3.3rem;
}
.pharmaceutical_sec .container .pharmaceutical_table table {
  width: 100%;
}
.pharmaceutical_sec .container .pharmaceutical_table table thead {
  width: 100%;
}
.pharmaceutical_sec .container .pharmaceutical_table table thead tr {
  width: 100%;
}
.pharmaceutical_sec .container .pharmaceutical_table table thead tr th {
  font-weight: 700;
  background-color: #f3f3f3;
  height: 7rem;
  padding: 1rem 0.5rem 1.5rem 2.1rem;
  border-top: solid 0.1rem #ddd;
  border-bottom: solid 0.1rem #ddd;
  border-right: solid 0.1rem #ddd;
  --pl: 5.3rem;
}
@media screen and (max-width: 1200px) {
  .pharmaceutical_sec .container .pharmaceutical_table table thead tr th {
    --pl: 2.1rem;
  }
}
.pharmaceutical_sec .container .pharmaceutical_table table thead tr th:nth-of-type(1) {
  width: 27.00729927%;
}
.pharmaceutical_sec .container .pharmaceutical_table table thead tr th:nth-of-type(2) {
  width: 54.306569344%;
  padding-left: var(--pl);
}
.pharmaceutical_sec .container .pharmaceutical_table table thead tr th:nth-of-type(3) {
  width: 18.686131386%;
  padding-left: var(--pl);
  border-right: none;
}
.pharmaceutical_sec .container .pharmaceutical_table table tbody {
  width: 100%;
}
.pharmaceutical_sec .container .pharmaceutical_table table tbody tr {
  width: 100%;
}
.pharmaceutical_sec .container .pharmaceutical_table table tbody tr td {
  font-weight: 700;
  height: 7rem;
  padding: 1rem 1.8rem 1.5rem 1.8rem;
  border-bottom: solid 0.1rem #ddd;
  border-right: solid 0.1rem #ddd;
  --pl: 5.1rem;
}
@media screen and (max-width: 1200px) {
  .pharmaceutical_sec .container .pharmaceutical_table table tbody tr td {
    --pl: 1.8rem;
  }
}
.pharmaceutical_sec .container .pharmaceutical_table table tbody tr td:nth-of-type(2) {
  padding-left: var(--pl);
}
.pharmaceutical_sec .container .pharmaceutical_table table tbody tr td:nth-of-type(3) {
  padding-left: var(--pl);
  border-right: none;
}

/*----------------------------------------------------------------------------
******************************************************************************
** member
******************************************************************************
----------------------------------------------------------------------------*/
.member_sec {
  padding-top: 6rem;
  padding-bottom: 15rem;
}
.member_sec .container .member_block {
  width: 100%;
  margin-top: 8.6rem;
}
.member_sec .container .member_block:first-of-type {
  margin-top: 7.3rem;
}
.member_sec .container .member_block .member_block_list {
  margin-top: 5rem;
}
.member_sec .container .member_txt {
  text-align: center;
  margin-top: 5rem;
  margin-bottom: -3rem;
}
.member_sec .container .member_btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 3rem;
  margin-top: 10rem;
}

.member_navi_sec {
  padding-top: 5rem;
  padding-bottom: 15rem;
}
.member_navi_sec .container .member_navi_block01 {
  width: 100%;
}
.member_navi_sec .container .member_navi_block01 .member_navi_block01_list {
  margin-top: 5rem;
}
.member_navi_sec .container .member_navi_block02 {
  width: 100%;
  margin-top: 5.3rem;
}
.member_navi_sec .container .member_navi_block02 .member_navi_block02_list {
  margin-top: 2.4rem;
}

/*----------------------------------------------------------------------------
******************************************************************************
** one point
******************************************************************************
----------------------------------------------------------------------------*/
.common_list02 {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3.5rem 2rem;
}
.common_list02.four_columns {
  grid-template-columns: repeat(4, 1fr);
}
.common_list02.four_columns li a .list_thumb {
  aspect-ratio: 1/0.6684491979;
}
.common_list02.thumb_large li a .list_thumb {
  aspect-ratio: 1/1.4227799228;
}
.common_list02 li a {
  display: inline-block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_list02 li a .list_thumb {
  width: 100%;
  aspect-ratio: 1/0.6;
  display: inline-block;
  margin-bottom: 2rem;
}
.common_list02 li a .list_thumb picture {
  width: 100%;
  height: 100%;
  display: block;
}
.common_list02 li a .list_thumb picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.common_list02 li a span {
  font-size: 1.8rem;
  color: #19396d;
  font-weight: 400;
  line-height: 1.875;
  letter-spacing: 0.05em;
  text-underline-offset: 1rem;
  text-decoration: underline;
  display: inline-block;
  padding-left: 2.5rem;
  position: relative;
}
.common_list02 li a span::before {
  content: "";
  width: 1.3rem;
  height: 1.1rem;
  background: url(../images/common/common_arrow01.png) no-repeat center/contain;
  position: absolute;
  top: 1.1rem;
  left: 0.2rem;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_list02 li a:hover {
  opacity: 0.7;
}
.common_list02 li a:hover span::before {
  left: 1rem;
}

.one_point_sec {
  padding-top: 6rem;
  padding-bottom: 10rem;
}
.one_point_sec .container {
  max-width: 100rem;
}
.one_point_sec .container.w1370 {
  max-width: 137rem;
}
.one_point_sec .container .one_point_block {
  width: 100%;
  margin-top: 8.8rem;
}
.one_point_sec .container .one_point_block .one_point_block_list {
  margin-top: 4.3rem;
}
.one_point_sec .container .one_point_block .one_point_btn {
  margin-top: 7rem;
}

.common_tier_tabs {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 3rem;
  margin-top: 5.6rem;
}
.common_tier_tabs a {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  display: inline-block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_tier_tabs a:nth-of-type(2) {
  color: #19396d;
}
.common_tier_tabs a:hover {
  opacity: 0.7;
}

.common_link_list {
  width: 100%;
  max-width: 100rem;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 1rem 0;
  margin-top: 5.6rem;
}
.common_link_list.seminar a:nth-of-type(odd) {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.common_link_list.inner a span::before {
  -webkit-transform: translateY(-50%) rotate(90deg);
          transform: translateY(-50%) rotate(90deg);
}
.common_link_list.inner a:hover span::before {
  right: 0;
  top: calc(50% + 0.5rem);
}
.common_link_list a {
  min-height: 3.7rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0 4rem 0.2rem;
}
.common_link_list a + a {
  border-left: solid 0.1rem #cccccc;
}
.common_link_list a + a:last-of-type {
  border-right: solid 0.1rem #cccccc;
}
.common_link_list a span {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-right: 5.4rem;
  display: inline-block;
  position: relative;
}
.common_link_list a span::before {
  content: "";
  width: 3.1rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: -webkit-image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.3rem, #f2f238;
  background: image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.3rem, #f2f238;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_link_list a:hover {
  opacity: 0.7;
}
.common_link_list a:hover span::before {
  right: -1rem;
}

.common_ttl07 {
  width: 100%;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-left: 3.1rem;
  position: relative;
}
.common_ttl07::before {
  content: "";
  width: 2rem;
  aspect-ratio: 1/1;
  background-color: #f2f238;
  border: solid 0.6rem #19396d;
  border-radius: 50%;
  position: absolute;
  top: 0.9rem;
  left: 0;
}

/*----------------------------------------------------------------------------
******************************************************************************
** report
******************************************************************************
----------------------------------------------------------------------------*/
.report_sec {
  padding-top: 6rem;
  padding-bottom: 15rem;
}
.report_sec .container .report_block {
  width: 100%;
  margin-top: 8.6rem;
}
.report_sec .container .report_block:first-of-type {
  margin-top: 7.3rem;
}
.report_sec .container .report_block .report_block_list {
  margin-top: 5rem;
}

.common_column_list {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3rem 2.262773722%;
}
.common_column_list.four {
  grid-template-columns: repeat(4, 1fr);
}
@media screen and (max-width: 1000px) {
  .common_column_list.four {
    grid-template-columns: repeat(3, 1fr);
  }
}
.common_column_list.color li a {
  border: solid 0.1rem #19396d;
  background-color: #cfe2f3;
}
.common_column_list.color li a::before {
  background-image: -webkit-image-set(url(../images/common/common_arrow01_y.png) 1x, url(../images/common/common_arrow01_y@2x.png) 2x);
  background-image: image-set(url(../images/common/common_arrow01_y.png) 1x, url(../images/common/common_arrow01_y@2x.png) 2x);
  background-color: #19396d;
}
.common_column_list.color li a .ttl {
  color: #19396d;
  font-weight: 500;
}
.common_column_list li a {
  width: 100%;
  height: 100%;
  min-height: 11.1rem;
  padding: 2rem 7rem 2.3rem 2.9rem;
  background-color: #f5f5f5;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: 1rem;
  border: solid 0.1rem #ddd;
  position: relative;
}
.common_column_list li a::before {
  content: "";
  width: 3.1rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: -webkit-image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.3rem, #f2f238;
  background: image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.3rem, #f2f238;
  position: absolute;
  top: 50%;
  right: 3rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_column_list li a .ttl {
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.7777777778;
  letter-spacing: 0.05em;
  display: inline-block;
}
.common_column_list li a:hover {
  opacity: 0.7;
}
.common_column_list li a:hover::before {
  right: 2rem;
}

/*----------------------------------------------------------------------------
******************************************************************************
** seminar
******************************************************************************
----------------------------------------------------------------------------*/
.seminar_sec {
  padding-top: 6rem;
  padding-bottom: 10rem;
}
.seminar_sec .container .seminar_block {
  width: 100%;
  margin-top: 10.8rem;
}
.seminar_sec .container .seminar_block:first-of-type {
  margin-top: 8.8rem;
}
.seminar_sec .container .seminar_block .seminar_block_list {
  margin-top: 5.1rem;
}
.seminar_sec .container .seminar_block .seminar_txt {
  margin-top: 3rem;
}
.seminar_sec .container .seminar_block .seminar_btn {
  margin-top: 10rem;
}
.seminar_sec .container .seminar_block .seminar_btn a {
  max-width: 40rem;
  margin: 0 auto;
}

.common_seminar_list {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 5rem;
  --opacity: 0;
}
.common_seminar_list.end {
  --opacity: 1;
}
.common_seminar_list li {
  width: 100%;
}
.common_seminar_list li > span {
  pointer-events: none;
}
.common_seminar_list li a,
.common_seminar_list li > span {
  width: 100%;
  min-height: 23.2rem;
  padding: 1.8rem 0 0 29.197080292%;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
@media screen and (max-width: 1000px) {
  .common_seminar_list li a,
  .common_seminar_list li > span {
    padding-top: 0;
  }
}
.common_seminar_list li a .seminar_ttl,
.common_seminar_list li > span .seminar_ttl {
  width: 100%;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  margin-top: 0.9rem;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.common_seminar_list li a .seminar_img,
.common_seminar_list li > span .seminar_img {
  width: 25.547445255%;
  aspect-ratio: 1/0.6628571429;
  border-radius: 1rem;
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
}
.common_seminar_list li a .seminar_img img,
.common_seminar_list li > span .seminar_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.common_seminar_list li a .seminar_day,
.common_seminar_list li > span .seminar_day {
  width: 100%;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.common_seminar_list li a .seminar_day span,
.common_seminar_list li > span .seminar_day span {
  font-size: 1.8rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  display: inline-block;
  padding-right: 12rem;
  position: relative;
}
.common_seminar_list li a .seminar_day span::before,
.common_seminar_list li > span .seminar_day span::before {
  content: "終了";
  width: 10rem;
  height: 3.4rem;
  font-size: 1.6rem;
  color: #fff;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.05em;
  background-color: #19396d;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 5rem;
  opacity: var(--opacity);
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.common_seminar_list li a .seminar_data,
.common_seminar_list li > span .seminar_data {
  width: 100%;
  margin-top: 2.3rem;
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
}
.common_seminar_list li a .seminar_data dl,
.common_seminar_list li > span .seminar_data dl {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.7777777777;
  letter-spacing: 0.05em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.common_seminar_list li a:hover,
.common_seminar_list li > span:hover {
  opacity: 0.7;
}

/*----------------------------------------------------------------------------
******************************************************************************
** case
******************************************************************************
----------------------------------------------------------------------------*/
.case_sec {
  padding-top: 6rem;
  padding-bottom: 10rem;
}
.case_sec .container .case_list {
  margin-top: 10.1rem;
}

.common_case_list {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 5.4rem 2.262773722%;
}
.common_case_list li a {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.common_case_list li a .case_ttl {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.6666666666;
  letter-spacing: 0.05em;
  margin-top: 1.8rem;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.common_case_list li a .case_img {
  width: 100%;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.common_case_list li a .case_img picture {
  width: 100%;
  aspect-ratio: 1/0.6636155606;
  border-radius: 1rem;
  background-color: #ccc;
  overflow: hidden;
  display: block;
}
.common_case_list li a .case_img picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.common_case_list li a .case_name {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
  margin-top: 1.5rem;
}
.common_case_list li a .case_name span {
  min-width: 16rem;
  min-height: 3.4rem;
  font-size: 1.6rem;
  color: #fff;
  font-weight: 400;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding: 0.3rem 0.5rem;
  background-color: #19396d;
  border-radius: 5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.common_case_list li a .case_data {
  width: 100%;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: 0.05em;
  margin-top: 1.2rem;
  -webkit-box-ordinal-group: 5;
      -ms-flex-order: 4;
          order: 4;
}

.wp-pagenavi_wrap {
  width: 100%;
  margin-top: 10rem;
}
.wp-pagenavi_wrap .wp-pagenavi {
  font-size: 1.8rem;
  color: #19396d;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 2.4rem;
}
.wp-pagenavi_wrap .wp-pagenavi span:not(.extend),
.wp-pagenavi_wrap .wp-pagenavi a {
  width: 4.6rem;
  aspect-ratio: 1/1;
  font-family: "Jost";
  color: #19396d;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.05em;
  border: solid 0.1rem #19396d;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 50%;
}
.wp-pagenavi_wrap .wp-pagenavi span:not(.extend) {
  color: #fff;
  background-color: #19396d;
}
.wp-pagenavi_wrap .wp-pagenavi a {
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.wp-pagenavi_wrap .wp-pagenavi a:hover {
  color: #fff;
  background-color: #19396d;
}

/*----------------------------------------------------------------------------
******************************************************************************
** case detail
******************************************************************************
----------------------------------------------------------------------------*/
.case_detail_sec {
  padding-top: 6rem;
  padding-bottom: 9rem;
}
.case_detail_sec .container {
  max-width: 100rem;
}
.case_detail_sec .container .case_detail_block {
  width: 100%;
  margin-top: 9rem;
}
.case_detail_sec .container .case_detail_block .case_detail_block_data {
  width: 100%;
  --contWidth: 45%;
  --maxWidth: 45rem;
  position: relative;
}
.case_detail_sec .container .case_detail_block .case_detail_block_data .case_detail_block_ttl {
  width: var(--contWidth);
  max-width: var(--maxWidth);
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.6428571429;
  letter-spacing: 0.05em;
  float: left;
}
.case_detail_sec .container .case_detail_block .case_detail_block_data .case_detail_block_thumb {
  width: calc(100% - (var(--contWidth) + 2rem));
  max-width: 47rem;
  aspect-ratio: 1/0.6638297872;
  border-radius: 1rem;
  overflow: hidden;
  margin-top: 1rem;
  float: right;
}
.case_detail_sec .container .case_detail_block .case_detail_block_data .case_detail_block_thumb picture {
  width: 100%;
  height: 100%;
  display: inline-block;
  background-color: #ccc;
}
.case_detail_sec .container .case_detail_block .case_detail_block_data .case_detail_block_thumb picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.case_detail_sec .container .case_detail_block .case_detail_block_data .case_detail_block_name {
  width: var(--contWidth);
  max-width: var(--maxWidth);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  float: left;
  margin-top: 3.4rem;
}
.case_detail_sec .container .case_detail_block .case_detail_block_data .case_detail_block_name span {
  min-width: 22rem;
  min-height: 4.2rem;
  font-size: 1.8rem;
  color: #fff;
  font-weight: 400;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding: 0.5rem;
  background-color: #19396d;
  border-radius: 5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.case_detail_sec .container .case_detail_block .case_detail_block_data .case_detail_block_products {
  width: var(--contWidth);
  max-width: var(--maxWidth);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-left: 0.2rem;
  float: left;
  margin-top: 1.9rem;
}
.case_detail_sec .container .case_detail_block .case_detail_block_faq {
  width: 100%;
  margin-top: 4.6rem;
}
.case_detail_sec .container .case_detail_block .case_detail_block_faq dt {
  width: 100%;
  font-size: 2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-left: 2.9rem;
  position: relative;
  margin-top: 4.7rem;
}
.case_detail_sec .container .case_detail_block .case_detail_block_faq dt:first-of-type {
  margin-top: 0;
}
.case_detail_sec .container .case_detail_block .case_detail_block_faq dt::before {
  content: "";
  width: 1.8rem;
  height: 0.1rem;
  background-color: #19396d;
  position: absolute;
  top: 1.6rem;
  left: 0.1rem;
}
.case_detail_sec .container .case_detail_block .case_detail_block_faq dd {
  margin-top: 1.2rem;
}
.case_detail_sec .container .case_detail_btn {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 1rem;
  margin-top: 6.5rem;
}
.case_detail_sec .container .case_detail_btn a {
  max-width: 46rem;
  height: 10rem;
}
.case_detail_sec .container .case_detail_btn a::before {
  right: 2rem;
}
.case_detail_sec .container .case_detail_btn a span {
  font-size: 2.2rem;
  line-height: 1.4545454546;
  text-align: left;
}

/*----------------------------------------------------------------------------
******************************************************************************
** register
******************************************************************************
----------------------------------------------------------------------------*/
#swpm-login-form .swpm-join-us-link {
  display: none;
}

.swpm_form_sec {
  padding-top: 6rem;
  padding-bottom: 9rem;
}
.swpm_form_sec .container {
  max-width: 110rem;
}
.swpm_form_sec .container .register_btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 3rem;
  margin-top: 5rem;
}
.swpm_form_sec .container .spwm_btn {
  margin-top: 5rem;
}
.swpm_form_sec .container .swpm_form_ttl {
  margin-bottom: 5rem;
}
.swpm_form_sec .container .swpm_form_wrap {
  width: 100%;
}
.swpm_form_sec .container .swpm_form_wrap form,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged {
  border-top: solid 0.1rem #dddddd;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-submit-section {
  margin: 5rem 0 0;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section),
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 0;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section).swpm-membership-level-row,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner.swpm-membership-level-row,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div.swpm-membership-level-row {
  display: none;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) > *,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner > *,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div > * {
  width: 100%;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-form-label-wrap,
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-username-label,
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-password-label,
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-logged-label,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-form-label-wrap,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-username-label,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-password-label,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-logged-label,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-form-label-wrap,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-username-label,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-password-label,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-logged-label {
  width: 31rem;
  font-weight: 700;
  padding: 3.7rem 8rem 3.7rem 2.1rem;
  background-color: #f3f3f3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-bottom: solid 0.1rem #dddddd;
  position: relative;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-form-input-wrap,
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-username-input,
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-password-input,
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-logged-value,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-form-input-wrap,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-username-input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-password-input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-logged-value,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-form-input-wrap,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-username-input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-password-input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-logged-value {
  width: calc(100% - 31rem);
  padding: 2.1rem 3.1rem;
  border-bottom: solid 0.1rem #dddddd;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-form-input-wrap input,
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-username-input input,
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-password-input input,
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-logged-value input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-form-input-wrap input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-username-input input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-password-input input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-logged-value input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-form-input-wrap input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-username-input input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-password-input input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-logged-value input {
  width: 100%;
  height: 6rem;
  padding: 0.5rem 2.1rem;
  background-color: #f5f5f5;
  border: solid 0.2rem #cccccc;
  border-radius: 0.4rem;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-form-desc,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-form-desc,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-form-desc {
  width: 100%;
  grid-column: 1/-1;
  padding-left: 34.1rem;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-form-desc > *,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-form-desc > *,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-form-desc > * {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-remember-me,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-remember-me,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-remember-me {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 2rem;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-remember-me:has(.swpm-remember-checkbox input:checked) .swpm-rememberme-label .swpm-rember-label::after,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-remember-me:has(.swpm-remember-checkbox input:checked) .swpm-rememberme-label .swpm-rember-label::after,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-remember-me:has(.swpm-remember-checkbox input:checked) .swpm-rememberme-label .swpm-rember-label::after {
  display: block;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-remember-me .swpm-remember-checkbox input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-remember-me .swpm-remember-checkbox input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-remember-me .swpm-remember-checkbox input {
  display: none;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-remember-me .swpm-rememberme-label,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-remember-me .swpm-rememberme-label,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-remember-me .swpm-rememberme-label {
  cursor: pointer;
  display: inline-block;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-remember-me .swpm-rememberme-label .swpm-rember-label,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-remember-me .swpm-rememberme-label .swpm-rember-label,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-remember-me .swpm-rememberme-label .swpm-rember-label {
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.2222222222;
  letter-spacing: 0.05em;
  padding-left: 3.7rem;
  display: inline-block;
  position: relative;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-remember-me .swpm-rememberme-label .swpm-rember-label::before,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-remember-me .swpm-rememberme-label .swpm-rember-label::before,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-remember-me .swpm-rememberme-label .swpm-rember-label::before {
  content: "";
  width: 2.2rem;
  aspect-ratio: 1/1;
  border: solid 0.2rem #cccccc;
  background-color: #f5f5f5;
  border-radius: 0.4rem;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-remember-me .swpm-rememberme-label .swpm-rember-label::after,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-remember-me .swpm-rememberme-label .swpm-rember-label::after,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-remember-me .swpm-rememberme-label .swpm-rember-label::after {
  content: "";
  width: 1.2rem;
  aspect-ratio: 1/0.5;
  border-bottom: solid 0.2rem #19396d;
  border-left: solid 0.2rem #19396d;
  position: absolute;
  top: calc(50% - 0.2rem);
  left: 0.5rem;
  -webkit-transform: translateY(-50%) rotate(-45deg);
          transform: translateY(-50%) rotate(-45deg);
  display: none;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-login-submit,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-login-submit,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-login-submit {
  width: 100%;
  max-width: 35rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background-color: #f2f238;
  border-radius: 5rem;
  position: relative;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  margin: 3rem auto 0;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-login-submit::before,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-login-submit::before,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-login-submit::before {
  content: "";
  width: 4.6rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: -webkit-image-set(url(../images/common/common_arrow01_y.png) 1x, url(../images/common/common_arrow01_y@2x.png) 2x) no-repeat center/1.6rem, #19396d;
  background: image-set(url(../images/common/common_arrow01_y.png) 1x, url(../images/common/common_arrow01_y@2x.png) 2x) no-repeat center/1.6rem, #19396d;
  position: absolute;
  top: 50%;
  right: 1rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-login-submit input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-login-submit input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-login-submit input {
  padding: 0;
  border: none;
  border-radius: 0;
  outline: none;
  background: none;
  -webkit-box-shadow: none;
          box-shadow: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 100%;
  height: 6.6rem;
  font-size: 1.8rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: 0.05em;
  padding: 1rem 7rem;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-login-submit:hover,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-login-submit:hover,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-login-submit:hover {
  background-color: #19396d;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-login-submit:hover::before,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-login-submit:hover::before,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-login-submit:hover::before {
  background: -webkit-image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #f2f238;
  background: image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #f2f238;
  right: 0;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-login-submit:hover input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-login-submit:hover input,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-login-submit:hover input {
  color: #f2f238;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-forgot-pass-link,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-forgot-pass-link,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-forgot-pass-link {
  text-align: center;
  margin-top: 2rem;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-forgot-pass-link a,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-forgot-pass-link a,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-forgot-pass-link a {
  text-decoration: underline;
  text-underline-offset: 0.3rem;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-forgot-pass-link a:hover,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-forgot-pass-link a:hover,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-forgot-pass-link a:hover {
  opacity: 0.7;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-join-us-link,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-join-us-link,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-join-us-link {
  text-align: center;
  margin-top: 1rem;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-join-us-link a,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-join-us-link a,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-join-us-link a {
  text-decoration: underline;
  text-underline-offset: 0.3rem;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-form-row:not(.swpm-submit-section) .swpm-join-us-link a:hover,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-form-inner .swpm-join-us-link a:hover,
.swpm_form_sec .container .swpm_form_wrap .swpm-login-widget-logged > div .swpm-join-us-link a:hover {
  opacity: 0.7;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-edit-profile-link,
.swpm_form_sec .container .swpm_form_wrap .swpm-logged-logout-link {
  margin-top: 2rem !important;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-edit-profile-link a,
.swpm_form_sec .container .swpm_form_wrap .swpm-logged-logout-link a {
  text-decoration: underline;
  text-underline-offset: 0.3rem;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.swpm_form_sec .container .swpm_form_wrap .swpm-edit-profile-link a:hover,
.swpm_form_sec .container .swpm_form_wrap .swpm-logged-logout-link a:hover {
  opacity: 0.7;
}
.swpm_form_sec .container .swpm-membership-level-row {
  display: none;
}

.swpm-pw-reset-widget-inside {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: 3rem;
}
.swpm-pw-reset-widget-inside .swpm-pw-reset-email {
  width: 20rem;
  font-weight: 700;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.swpm-pw-reset-widget-inside .swpm-pw-reset-email-input {
  width: calc(100% - 20rem);
}
.swpm-pw-reset-widget-inside .swpm-pw-reset-email-input input {
  width: 100%;
  height: 6rem;
  padding: 0.5rem 2.1rem;
  background-color: #f5f5f5;
  border: solid 0.2rem #cccccc;
  border-radius: 0.4rem;
}
.swpm-pw-reset-widget-inside .swpm-pw-reset-submit-button {
  width: 100%;
  text-align: center;
  margin: 3rem 0 0 0;
}

/*----------------------------------------------------------------------------
******************************************************************************
** 404
******************************************************************************
----------------------------------------------------------------------------*/
.not_found {
  padding-top: 6rem;
  padding-bottom: 9rem;
}
.not_found .container .not_found_txt01,
.not_found .container .not_found_txt02 {
  text-align: center;
  margin-top: 2rem;
}
.not_found .container .not_found_btn01 {
  width: 100%;
  margin-top: 5rem;
}
.not_found .container .not_found_btn01 a {
  margin: 0 auto;
}

/*----------------------------------------------------------------------------
******************************************************************************
** news
******************************************************************************
----------------------------------------------------------------------------*/
.two_column_wrap {
  width: 100%;
}
.two_column_wrap .container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.two_column_wrap .container .main_block {
  width: calc(100% - 30rem);
}
.two_column_wrap .container .aside_block {
  width: 23rem;
}

.news_sec {
  padding-top: 6.3rem;
  padding-bottom: 13rem;
}

.aside_sup {
  width: 100%;
  padding-top: 0.5rem;
  margin-bottom: 3.5rem;
}
.aside_sup .aside_sup_list {
  width: 100%;
  border: solid 0.2rem #19396d;
  border-radius: 0.5rem;
}
.aside_sup .aside_sup_list .aside_sup_ttl {
  width: 100%;
  font-size: 1.6rem;
  color: #fff;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  text-align: center;
  padding: 1rem 1rem 1.2rem;
  background-color: #19396d;
}
.aside_sup .aside_sup_list .aside_sup_name {
  width: 100%;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0.05em;
  text-align: center;
  padding: 1.6rem;
  background-color: #edf0f5;
}

.aside_cat {
  width: 100%;
}
.aside_cat .aside_cat_ttl {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-bottom: 0.7rem;
  border-bottom: solid 0.1rem #19396d;
}
.aside_cat nav {
  width: 100%;
  padding-top: 0.7rem;
}
.aside_cat nav .aside_cat_navi {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.aside_cat nav .aside_cat_navi li {
  width: 100%;
  border-bottom: solid 0.1rem #ddd;
}
.aside_cat nav .aside_cat_navi li a {
  width: 100%;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.6875;
  letter-spacing: 0.05em;
  display: block;
  padding: 1.6rem 4rem;
  position: relative;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.aside_cat nav .aside_cat_navi li a::before {
  content: "";
  width: 2.7rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: -webkit-image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.3rem, #f2f238;
  background: image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.3rem, #f2f238;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.aside_cat nav .aside_cat_navi li a:hover {
  opacity: 0.7;
}
.aside_cat nav .aside_cat_navi li a:hover::before {
  left: 1rem;
}

.wp-pagenavi {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 2rem;
  margin-top: 10rem;
}
.wp-pagenavi a,
.wp-pagenavi span {
  width: 4.2rem;
  aspect-ratio: 1/1;
  font-family: "Jost";
  font-size: 1.8rem;
  color: #19396d;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border: solid 0.1rem #19396d;
  border-radius: 50%;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.wp-pagenavi a.previouspostslink, .wp-pagenavi a.nextpostslink,
.wp-pagenavi span.previouspostslink,
.wp-pagenavi span.nextpostslink {
  position: relative;
}
.wp-pagenavi a.previouspostslink::before, .wp-pagenavi a.nextpostslink::before,
.wp-pagenavi span.previouspostslink::before,
.wp-pagenavi span.nextpostslink::before {
  content: "";
  width: 1.6rem;
  height: 1.4rem;
  background: -webkit-image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/contain;
  background: image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/contain;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.wp-pagenavi a.previouspostslink::before,
.wp-pagenavi span.previouspostslink::before {
  -webkit-transform: translate(-50%, -50%) scale(-1, 1);
          transform: translate(-50%, -50%) scale(-1, 1);
}
.wp-pagenavi a.extend,
.wp-pagenavi span.extend {
  border: none;
}
.wp-pagenavi a.current,
.wp-pagenavi span.current {
  color: #fff;
  background-color: #19396d;
}
.wp-pagenavi a:hover {
  color: #fff;
  background-color: #19396d;
}
.wp-pagenavi a:hover.previouspostslink, .wp-pagenavi a:hover.nextpostslink {
  position: relative;
}
.wp-pagenavi a:hover.previouspostslink::before, .wp-pagenavi a:hover.nextpostslink::before {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}

/*----------------------------------------------------------------------------
******************************************************************************
** post detail
******************************************************************************
----------------------------------------------------------------------------*/
.post_detail_sec {
  padding-top: 6.3rem;
  padding-bottom: 13rem;
}
.post_detail_sec .container .main_block .post_detail_btn {
  margin-top: 5rem;
}

.post_detail_block {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding-top: 2.5rem;
}
.post_detail_block .post_detail_ttl {
  width: 100%;
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.6666666666;
  letter-spacing: 0.05em;
  padding-bottom: 2.1rem;
  border-bottom: solid 0.1rem #dddddd;
  margin-bottom: 4rem;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.post_detail_block .post_detail_data {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2.6rem;
  margin-bottom: 1.4rem;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.post_detail_block .post_detail_data .date {
  font-family: "Jost";
  font-size: 1.6rem;
  color: #808080;
  font-weight: 400;
  line-height: 1.625;
  letter-spacing: 0;
  padding-top: 0.3rem;
}
.post_detail_block .post_detail_data .cat {
  min-width: 11rem;
  height: 3.2rem;
  font-size: 1.4rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding: 1rem;
  background-color: #fff;
  border: solid 0.1rem #19396d;
  border-radius: 1.6rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.post_detail_block .post_detail_mokuji {
  padding-top: 3rem;
  margin-bottom: 6.9rem;
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
}
.post_detail_block .post_detail_editor {
  width: 100%;
  -webkit-box-ordinal-group: 5;
      -ms-flex-order: 4;
          order: 4;
}
.post_detail_block.topics .post_detail_ttl {
  color: #19396d;
}
.post_detail_block.topics .post_detail_data .cat {
  color: #fff;
  border: solid 0.1rem #3778be;
  background-color: #3778be;
}

.common_detail_btn {
  width: 100%;
  text-align: center;
}
.common_detail_btn .detail_btn_wrap {
  width: 100%;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.common_detail_btn .detail_btn_wrap .btn_wrap {
  width: calc((100% - 30rem) / 2);
  position: absolute;
  top: 50%;
  --position: calc(50% + 17rem);
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.common_detail_btn .detail_btn_wrap .btn_wrap.prev_warp {
  right: var(--position);
  text-align: right;
}
.common_detail_btn .detail_btn_wrap .btn_wrap.next_warp {
  left: var(--position);
  text-align: left;
}
.common_detail_btn .detail_btn_wrap .btn_wrap .prev,
.common_detail_btn .detail_btn_wrap .btn_wrap .next {
  font-size: 1.6rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  --onMouse: 1rem;
  --padding: 6.8rem;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  position: relative;
}
.common_detail_btn .detail_btn_wrap .btn_wrap .prev:hover,
.common_detail_btn .detail_btn_wrap .btn_wrap .next:hover {
  opacity: 0.7;
  --onMouse: 0;
}
.common_detail_btn .detail_btn_wrap .btn_wrap .prev::before,
.common_detail_btn .detail_btn_wrap .btn_wrap .next::before {
  content: "";
  width: 4.2rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: -webkit-image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #fff;
  background: image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #fff;
  border: solid 0.1rem #19396d;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_detail_btn .detail_btn_wrap .btn_wrap .prev {
  padding-left: var(--padding);
}
.common_detail_btn .detail_btn_wrap .btn_wrap .prev::before {
  left: var(--onMouse);
  -webkit-transform: translateY(-50%) scale(-1, 1);
          transform: translateY(-50%) scale(-1, 1);
}
.common_detail_btn .detail_btn_wrap .btn_wrap .next {
  padding-right: var(--padding);
}
.common_detail_btn .detail_btn_wrap .btn_wrap .next::before {
  right: var(--onMouse);
}
.common_detail_btn .detail_btn_wrap .back {
  width: 30rem;
  height: 6rem;
  font-size: 1.6rem;
  color: #fff;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
  border-radius: 5rem;
  padding: 2rem;
  background-color: #19396d;
  border: solid 0.1rem #19396d;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_detail_btn .detail_btn_wrap .back:hover {
  opacity: 0.7;
}

.editor_area .wp-block-accordion {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2rem;
}
.editor_area .wp-block-accordion .wp-block-accordion-item {
  width: 100%;
}
.editor_area .wp-block-accordion .wp-block-accordion-item .wp-block-accordion-heading {
  width: 100%;
}
.editor_area .wp-block-accordion .wp-block-accordion-item .wp-block-accordion-heading .wp-block-accordion-heading__toggle {
  width: 100% !important;
  padding: 2.8rem 2rem 2rem 2rem !important;
  background-color: #f5f5f5 !important;
  border: solid 0.1rem #dddddd;
  border-radius: 1rem !important;
  display: grid;
  grid-template-columns: auto 2rem;
  gap: 1rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.editor_area .wp-block-accordion .wp-block-accordion-item .wp-block-accordion-heading .wp-block-accordion-heading__toggle .wp-block-accordion-heading__toggle-title {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  display: grid;
  grid-template-columns: 5rem auto;
  gap: 1.5rem;
  text-decoration: none;
}
.editor_area .wp-block-accordion .wp-block-accordion-item .wp-block-accordion-heading .wp-block-accordion-heading__toggle .wp-block-accordion-heading__toggle-title strong {
  font-family: "Jost";
  color: #fff;
  letter-spacing: -0.05em;
  aspect-ratio: 1/1;
  background-color: #19396d;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: -0.8rem;
}
.editor_area .wp-block-accordion .wp-block-accordion-item .wp-block-accordion-heading .wp-block-accordion-heading__toggle .wp-block-accordion-heading__toggle-icon {
  width: auto;
  height: auto;
  overflow: hidden;
  text-indent: 100rem;
  color: #fff;
  position: relative;
}
.editor_area .wp-block-accordion .wp-block-accordion-item .wp-block-accordion-heading .wp-block-accordion-heading__toggle .wp-block-accordion-heading__toggle-icon::before, .editor_area .wp-block-accordion .wp-block-accordion-item .wp-block-accordion-heading .wp-block-accordion-heading__toggle .wp-block-accordion-heading__toggle-icon::after {
  content: "";
  width: 100%;
  height: 0.2rem;
  background-color: #000;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%);
          transform: translate(-50%);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.editor_area .wp-block-accordion .wp-block-accordion-item .wp-block-accordion-heading .wp-block-accordion-heading__toggle .wp-block-accordion-heading__toggle-icon::after {
  -webkit-transform: translate(-50%) rotate(90deg);
          transform: translate(-50%) rotate(90deg);
}
.editor_area .wp-block-accordion .wp-block-accordion-item .wp-block-accordion-panel {
  width: 100%;
  position: relative;
  padding: 2.5rem 0 2rem 8.5rem;
}
.editor_area .wp-block-accordion .wp-block-accordion-item .wp-block-accordion-panel::before {
  content: "A";
  width: 5rem;
  font-family: "Jost";
  font-size: 1.8rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.05em;
  aspect-ratio: 1/1;
  background-color: #19396d;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: absolute;
  top: 2rem;
  left: 2rem;
}
.editor_area .wp-block-accordion .wp-block-accordion-item.is-open .wp-block-accordion-heading .wp-block-accordion-heading__toggle .wp-block-accordion-heading__toggle-icon {
  -webkit-transform: rotate(0);
          transform: rotate(0);
}
.editor_area .wp-block-accordion .wp-block-accordion-item.is-open .wp-block-accordion-heading .wp-block-accordion-heading__toggle .wp-block-accordion-heading__toggle-icon::after {
  -webkit-transform: translate(-50%);
          transform: translate(-50%);
}
.editor_area > * {
  margin: 3rem 0;
}
.editor_area > *:first-child {
  margin-top: 0;
}
.editor_area table thead tr th {
  text-align: center;
}
.editor_area a {
  color: #19396d;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 0.5rem;
}
.editor_area .wp-block-embed-youtube .wp-block-embed__wrapper {
  aspect-ratio: 1/0.5625;
  position: relative;
}
.editor_area .wp-block-embed-youtube .wp-block-embed__wrapper iframe {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.editor_area {
  /* 共通 */
}
.editor_area .alignleft {
  float: left;
  margin-right: 1.5rem;
}
.editor_area .alignright {
  float: right;
  margin-left: 1.5rem;
}
.editor_area .aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.editor_area .text-left {
  text-align: left;
}
.editor_area .text-right {
  text-align: right;
}
.editor_area .text-center {
  text-align: center;
}

.common_editor_style h2:not(.wp-block-accordion-heading) {
  width: 100%;
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-bottom: 0.6rem;
  border-bottom: solid 0.1rem #dddddd;
  position: relative;
}
.common_editor_style h2:not(.wp-block-accordion-heading)::before {
  content: "";
  width: 15rem;
  height: 0.1rem;
  background-color: #19396d;
  position: absolute;
  bottom: -0.1rem;
  left: 0;
}
.common_editor_style h3:not(.wp-block-accordion-heading) {
  width: 100%;
  font-size: 2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-left: 2.9rem;
  position: relative;
}
.common_editor_style h3:not(.wp-block-accordion-heading)::before {
  content: "";
  width: 1.8rem;
  height: 0.1rem;
  background-color: #19396d;
  position: absolute;
  top: 1.6rem;
  left: 0.1rem;
}
.common_editor_style h4 {
  width: 100%;
  font-weight: 700;
}

.is-style-list_style01 {
  width: 100%;
}
.is-style-list_style01 li {
  width: 100%;
  padding-left: 2.2rem;
  position: relative;
}
.is-style-list_style01 li::before {
  content: "";
  width: 0.9rem;
  aspect-ratio: 1/1;
  background-color: #3778be;
  border-radius: 50%;
  position: absolute;
  top: 1.4rem;
  left: 0.3rem;
}

.is-style-list_style02 {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.4rem;
}
.is-style-list_style02 li {
  width: 100%;
  padding-left: 4.1rem;
  position: relative;
}
.is-style-list_style02 li::before {
  content: "";
  width: 3.2rem;
  height: 2.7rem;
  background: url(../images/common/check_icon.png) no-repeat center/contain;
  background: url(../images/common/check_icon.svg) no-repeat center/contain;
  position: absolute;
  top: 0.6rem;
  left: 0;
}

.is-style-list_style03 {
  width: 100%;
  counter-reset: number 0;
}
.is-style-list_style03 li {
  width: 100%;
  padding-left: 3.2rem;
  position: relative;
}
.is-style-list_style03 li::before {
  counter-increment: number 1;
  content: counter(number) " ";
  width: 2.5rem;
  aspect-ratio: 1/1;
  font-family: "Jost";
  font-size: 1.4rem;
  color: #fff;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.05em;
  padding: 0 0 0.1rem 0.1rem;
  background-color: #19396d;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: absolute;
  top: 0.55rem;
  left: 0;
}

.topics_editor_style h2 {
  width: 100%;
  font-size: 2.4rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding: 1.2rem 0 1.3rem;
  border-top: solid 0.3rem #19396d;
  border-bottom: solid 0.3rem #19396d;
}
.topics_editor_style h3 {
  width: 100%;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.81818181;
  letter-spacing: 0.05em;
  padding-left: 1.4rem;
  border-left: solid 0.5rem #19396d;
}
.topics_editor_style h4 {
  width: 100%;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding-bottom: 1.2rem;
  border-bottom: solid 0.1rem #dddddd;
}
.topics_editor_style table {
  width: 100%;
  border: solid 0.1rem #dddddd;
}
.topics_editor_style table tr {
  width: 100%;
  border: solid 0.1rem #dddddd;
}
.topics_editor_style table tr th {
  border: solid 0.1rem #dddddd;
  padding: 2rem 2rem 2.3rem 1.9rem;
  background-color: #f3f3f3;
  border: none;
}
.topics_editor_style table tr td {
  padding: 2rem 2rem 2.3rem 1.9rem;
  border: none;
}

.common_mokuji_box {
  width: 100%;
}
.common_mokuji_box .mokuji_box {
  width: 100%;
  max-width: 80rem;
  border: solid 0.2rem #19396d;
  border-radius: 0.5rem;
  overflow: hidden;
  margin: 0 auto;
}
.common_mokuji_box .mokuji_box .mokuji_title {
  width: 100%;
  min-height: 6.8rem;
  padding: 1rem 1rem 1.3rem;
  background-color: #19396d;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.common_mokuji_box .mokuji_box .mokuji_title span {
  font-size: 2.6rem;
  color: #fff;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  display: inline-block;
  padding: 0 8.4rem 0 8rem;
  position: relative;
}
.common_mokuji_box .mokuji_box .mokuji_title span::before {
  content: "";
  width: 3rem;
  height: 2rem;
  background: url(../images/common/mokuji_icon.png) no-repeat center/contain;
  background: url(../images/common/mokuji_icon.svg) no-repeat center/contain;
  position: absolute;
  top: 1.1rem;
  left: 3.4rem;
  z-index: 1;
}
.common_mokuji_box .mokuji_box .mokuji_title span::after {
  content: "[閉じる]";
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.625;
  letter-spacing: 0;
  text-decoration: underline;
  text-underline-offset: 0.8rem;
  text-decoration-thickness: 0.2rem;
  position: absolute;
  top: 0.8rem;
  right: 1rem;
  z-index: 1;
}
.common_mokuji_box .mokuji_box .mokuji {
  width: 100%;
  background-color: #edf0f5;
}
.common_mokuji_box .mokuji_box .mokuji .mokujiinner {
  width: 100%;
  padding: 2.9rem 8.6rem 4.6rem 6.2rem;
}
.common_mokuji_box .mokuji_box .mokuji .mokujiinner .chapter {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1.4rem;
}
.common_mokuji_box .mokuji_box .mokuji .mokujiinner .chapter li {
  width: 100%;
  list-style-type: none;
}
.common_mokuji_box .mokuji_box .mokuji .mokujiinner .chapter li a {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 2;
  letter-spacing: 0.05em;
  text-decoration: underline;
  text-underline-offset: 1rem;
  padding-left: 2.5rem;
  position: relative;
}
.common_mokuji_box .mokuji_box .mokuji .mokujiinner .chapter li a::before {
  content: "";
  width: 1.2rem;
  height: 0.2rem;
  background-color: #19396d;
  position: absolute;
  top: 1.9rem;
  left: 0;
}
.common_mokuji_box .mokuji_box.close .mokuji_title span::after {
  content: "[開く]";
}

/*----------------------------------------------------------------------------
******************************************************************************
** topics
******************************************************************************
----------------------------------------------------------------------------*/
.topics_sec {
  padding-top: 6.3rem;
  padding-bottom: 13rem;
}

/*----------------------------------------------------------------------------
******************************************************************************
** others
******************************************************************************
----------------------------------------------------------------------------*/
.others_sec {
  padding-top: 6rem;
  padding-bottom: 10rem;
}
.others_sec .container {
  max-width: 100rem;
}
.others_sec .container .others_editor {
  width: 100%;
  margin-top: 3.8rem;
}
.others_sec .container .post_detail_btn {
  margin-top: 8rem;
}

/*----------------------------------------------------------------------------
******************************************************************************
** cart
******************************************************************************
----------------------------------------------------------------------------*/
.cart_sec {
  padding-top: 6rem;
  padding-bottom: 9rem;
}

/*----------------------------------------------------------------------------
******************************************************************************
** contact
******************************************************************************
----------------------------------------------------------------------------*/
.contact_sec01 {
  padding-top: 6rem;
  padding-bottom: 5rem;
}
.contact_sec01.confirm, .contact_sec01.thanks, .contact_sec01.email_newslatter {
  padding-bottom: 9rem;
}
.contact_sec01 .container {
  max-width: 110rem;
}
.contact_sec01 .container .thanks_txt {
  text-align: center;
}
.contact_sec01 .container .thanks_btn {
  margin-top: 5rem;
}
.contact_sec01 .container .confirm_txt {
  margin-bottom: 2rem;
}
.contact_sec01 .container .contact_ttl {
  margin-bottom: 5rem;
}
.contact_sec01 .container .contact_flow_navi {
  margin-bottom: 4.5rem;
}
.contact_sec01 .container .contact_note {
  line-height: 1.625;
  padding-left: 1em;
  text-indent: -1em;
  margin-top: 3.5rem;
  margin-bottom: 2rem;
}
.contact_sec01 .container .contact_note.color {
  color: #b20000;
  margin: 0;
}
.contact_sec01 .container .contact_btn {
  margin-top: 4.5rem;
}
.contact_sec01 .confirm .common_form02 > dl > dt {
  padding: 2rem 3rem !important;
}
.contact_sec01 .confirm .common_form02 > dl > dt::before {
  display: none;
}
.contact_sec01 .confirm .common_form02 > dl > dd {
  padding: 2rem 3rem !important;
}
.contact_sec01 .confirm .common_form02 > dl > dd .input_box .inquiry_list {
  padding: 0;
}

.common_cf7_btn {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 3rem;
}
.common_cf7_btn .wpcf7-spinner {
  display: none;
}
.common_cf7_btn .wrap {
  width: 32rem;
  height: 6.6rem;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background-color: #f2f238;
  border-radius: 5rem;
  position: relative;
  display: block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_cf7_btn .wrap::before {
  content: "";
  width: 4.6rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: -webkit-image-set(url(../images/common/common_arrow01_y.png) 1x, url(../images/common/common_arrow01_y@2x.png) 2x) no-repeat center/1.6rem, #19396d;
  background: image-set(url(../images/common/common_arrow01_y.png) 1x, url(../images/common/common_arrow01_y@2x.png) 2x) no-repeat center/1.6rem, #19396d;
  position: absolute;
  top: 50%;
  right: 1rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_cf7_btn .wrap input {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 100%;
  height: 100%;
  padding: 1rem 7rem;
  font-size: 1.8rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: 0.05em;
}
.common_cf7_btn .wrap:hover {
  background-color: #19396d;
}
.common_cf7_btn .wrap:hover::before {
  background: -webkit-image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #f2f238;
  background: image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #f2f238;
  right: 0;
}
.common_cf7_btn .wrap:hover input {
  color: #f2f238;
}
.common_cf7_btn .wrap.back {
  background-color: #ddd;
}
.common_cf7_btn .wrap.back::before {
  display: none;
}
.common_cf7_btn .wrap.back input {
  color: #262626;
}
.common_cf7_btn .wrap.back:hover {
  background-color: #ddd;
  opacity: 0.7;
}

.contact_sec02 {
  padding-top: 7.6rem;
  padding-bottom: 14.6rem;
}
.contact_sec02 .container {
  max-width: 110rem;
}
.contact_sec02 .container .contact_tel {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 5.5rem;
}
.contact_sec02 .container .contact_tel .free_dial {
  min-width: 67.8rem;
  padding-bottom: 0.9rem;
  border-bottom: solid 0.1rem #dddddd;
}
.contact_sec02 .container .contact_tel .free_dial a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.contact_sec02 .container .contact_tel .free_dial a .num {
  font-family: "Jost";
  font-size: 4.7rem;
  color: #19396d;
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: -0.02em;
  padding-left: 5.5rem;
  position: relative;
}
.contact_sec02 .container .contact_tel .free_dial a .num::before {
  content: "";
  width: 5rem;
  height: 3.3rem;
  background: url(../images/common/tel_icon.png) no-repeat center/contain;
  background: url(../images/common/tel_icon.svg) no-repeat center/contain;
  position: absolute;
  top: 3.6rem;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.contact_sec02 .container .contact_tel .free_dial a .num .mr {
  margin-right: -2.6rem;
}
.contact_sec02 .container .contact_tel .free_dial a .num rt {
  font-family: YakuHanJP, "Noto Sans JP";
  font-size: 1.7rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -1.4em;
  position: relative;
  top: -0.3rem;
  left: -0.3rem;
}
.contact_sec02 .container .contact_tel .free_dial a .num rt.ls {
  letter-spacing: 0.1em;
  position: relative;
  left: 0.5rem;
  left: 0;
}
.contact_sec02 .container .contact_tel .free_dial a .txt {
  width: auto;
  padding: 0.6rem 0 0 0.3rem;
}
.contact_sec02 .container .contact_tel .others_contact {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 6rem;
  margin-top: 1.7rem;
}
.contact_sec02 .container .contact_tel .others_contact > a,
.contact_sec02 .container .contact_tel .others_contact span {
  font-family: "Jost";
  font-weight: 600;
}
.contact_sec02 .container .contact_tel .others_contact > a .txt,
.contact_sec02 .container .contact_tel .others_contact span .txt {
  font-size: 2.2rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0;
  display: inline-block;
  margin-right: -0.3rem;
}
.contact_sec02 .container .contact_tel .others_contact > a .num,
.contact_sec02 .container .contact_tel .others_contact span .num {
  font-size: 3.4rem;
  line-height: 1;
  letter-spacing: -0.08rem;
  display: inline-block;
  margin-right: 0;
}

.common_flow_navi {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.common_flow_navi .flow_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 6.6rem;
  position: relative;
}
.common_flow_navi .flow_wrap::before {
  content: "";
  width: 100%;
  height: 0.4rem;
  background-color: #e0e0e0;
  position: absolute;
  top: 2.5rem;
  left: 0;
  z-index: 1;
}
.common_flow_navi .flow_wrap .flow {
  position: relative;
  z-index: 2;
}
.common_flow_navi .flow_wrap .flow .num {
  width: 5.4rem;
  font-family: "Jost";
  font-size: 2rem;
  color: #19396d;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.05em;
  text-align: center;
  aspect-ratio: 1/1;
  background-color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 0.5rem;
  border: solid 0.2rem #19396d;
  border-radius: 50%;
}
.common_flow_navi .flow_wrap .flow .txt {
  width: 100%;
  font-size: 1.8rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  display: block;
  text-align: center;
  margin-top: 0.4rem;
}
.common_flow_navi .flow_wrap .flow.current .num {
  color: #fff;
  background-color: #19396d;
}

.common_form02 {
  width: 100%;
}
.common_form02 > dl {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
  display: grid;
  grid-template-columns: 31rem auto;
  border-top: solid 0.1rem #dddddd;
}
.common_form02 > dl > dt {
  font-weight: 700;
  padding: 3.7rem 8rem 3.7rem 2.1rem;
  background-color: #f3f3f3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-bottom: solid 0.1rem #dddddd;
  position: relative;
}
.common_form02 > dl > dt.school {
  padding-top: 2.2rem;
  padding-bottom: 2.2rem;
}
.common_form02 > dl > dt.chance {
  padding-top: 2.4rem;
  padding-bottom: 2.4rem;
}
.common_form02 > dl > dt.required {
  --txt: "必須";
  --bgc: #b20000;
}
.common_form02 > dl > dt.any {
  --txt: "任意";
  --bgc: #888888;
}
.common_form02 > dl > dt::before {
  content: var(--txt);
  width: 4.6rem;
  height: 2.6rem;
  font-size: 1.4rem;
  color: #fff;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.05em;
  border-radius: 0.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 0.2rem 0.2rem 0.4rem;
  background-color: var(--bgc);
  position: absolute;
  top: 3.8rem;
  right: 1.9rem;
}
.common_form02 > dl > dd {
  padding: 2.1rem 3.1rem;
  border-bottom: solid 0.1rem #dddddd;
}
.common_form02 > dl > dd.chance {
  padding-top: 3.6rem;
  padding-bottom: 3.6rem;
}
.common_form02 > dl > dd .input_box {
  width: 100%;
}
.common_form02 > dl > dd .input_box .wpcf7-list-item {
  margin: 0;
}
.common_form02 > dl > dd .input_box input[type=text],
.common_form02 > dl > dd .input_box input[type=email],
.common_form02 > dl > dd .input_box input[type=tel],
.common_form02 > dl > dd .input_box textarea,
.common_form02 > dl > dd .input_box select {
  width: 100%;
  height: 6rem;
  padding: 0.5rem 2.1rem;
  background-color: #f5f5f5;
  border: solid 0.2rem #cccccc;
  border-radius: 0.4rem;
}
.common_form02 > dl > dd .input_box input[type=text].small,
.common_form02 > dl > dd .input_box input[type=email].small,
.common_form02 > dl > dd .input_box input[type=tel].small,
.common_form02 > dl > dd .input_box textarea.small,
.common_form02 > dl > dd .input_box select.small {
  width: 25rem;
}
.common_form02 > dl > dd .input_box textarea {
  min-height: 30rem;
}
.common_form02 > dl > dd .input_box select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding-right: 4rem;
  background-image: url(../images/common/select_arrow.png);
  background-image: url(../images/common/select_arrow.svg);
  background-position: top 50% right 1.8rem;
  background-size: 1rem;
  background-repeat: no-repeat;
}
.common_form02 .address_list {
  width: 100%;
  padding-top: 1.2rem;
  display: grid;
  grid-template-columns: 9rem auto;
  gap: 2rem 0;
}
.common_form02 .address_list > dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.common_form02 .inquiry_list {
  width: 100%;
  padding-top: 1.2rem;
}
.common_form02 .inquiry_list > dt {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  margin-top: 3.2rem;
  margin-bottom: 1.2rem;
}
.common_form02 .inquiry_list > dt:first-of-type {
  margin-top: 0;
  margin-bottom: 0.9rem;
}
.common_form02 .inquiry_list dd {
  width: 100%;
}
.common_form02 .inquiry_list dd select {
  margin-top: 0.5rem;
}
.common_form02 .form_note {
  width: 100%;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.625;
  letter-spacing: 0.05em;
  margin-top: 0.9rem;
  margin-bottom: 0.4rem;
}
.common_form02 .wpcf7-checkbox {
  width: 100%;
  display: grid;
  gap: 0.4rem;
}
.common_form02 .wpcf7-checkbox .wpcf7-list-item label {
  cursor: pointer;
}
.common_form02 .wpcf7-checkbox .wpcf7-list-item label input {
  display: none;
}
.common_form02 .wpcf7-checkbox .wpcf7-list-item label input:checked + .wpcf7-list-item-label::after {
  display: block;
}
.common_form02 .wpcf7-checkbox .wpcf7-list-item label .wpcf7-list-item-label {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.2222222222;
  letter-spacing: 0.05em;
  padding-left: 3.7rem;
  display: inline-block;
  position: relative;
}
.common_form02 .wpcf7-checkbox .wpcf7-list-item label .wpcf7-list-item-label::before {
  content: "";
  width: 2.2rem;
  aspect-ratio: 1/1;
  border: solid 0.2rem #cccccc;
  background-color: #f5f5f5;
  border-radius: 0.4rem;
  position: absolute;
  top: 0.1rem;
  left: 0;
}
.common_form02 .wpcf7-checkbox .wpcf7-list-item label .wpcf7-list-item-label::after {
  content: "";
  width: 1.2rem;
  aspect-ratio: 1/0.5;
  border-bottom: solid 0.2rem #19396d;
  border-left: solid 0.2rem #19396d;
  position: absolute;
  top: 0.8rem;
  left: 0.5rem;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  display: none;
}
.common_form02 .wpcf7-checkbox.product_list {
  margin-bottom: -1.7rem;
}
.common_form02 .wpcf7-checkbox.product_list .wpcf7-list-item {
  padding-left: 10rem;
  position: relative;
}
.common_form02 .wpcf7-checkbox.product_list .wpcf7-list-item:nth-of-type(1) {
  --bg: url(../images/contact/elesas.png) no-repeat center/ contain;
}
.common_form02 .wpcf7-checkbox.product_list .wpcf7-list-item:nth-of-type(2) {
  --bg: url(../images/contact/acu.png) no-repeat center/ contain;
}
.common_form02 .wpcf7-checkbox.product_list .wpcf7-list-item:nth-of-type(3) {
  --bg: url(../images/contact/high_charge.png) no-repeat center/ contain;
}
.common_form02 .wpcf7-checkbox.product_list .wpcf7-list-item:nth-of-type(4) {
  --bg: url(../images/contact/high_charge_one.png) no-repeat center/ contain;
}
.common_form02 .wpcf7-checkbox.product_list .wpcf7-list-item:nth-of-type(5) {
  --bg: url(../images/contact/deep.png) no-repeat center/ contain;
}
.common_form02 .wpcf7-checkbox.product_list .wpcf7-list-item::before {
  content: "";
  width: 6rem;
  aspect-ratio: 1/1;
  background: var(--bg);
  position: absolute;
  top: 0;
  left: 0;
}
.common_form02 .wpcf7-checkbox.product_list .wpcf7-list-item label input {
  display: none;
}
.common_form02 .wpcf7-checkbox.product_list .wpcf7-list-item label input:checked + .wpcf7-list-item-label::after {
  display: block;
}
.common_form02 .wpcf7-checkbox.product_list .wpcf7-list-item label .wpcf7-list-item-label {
  line-height: 3.3333333333;
}
.common_form02 .wpcf7-checkbox.product_list .wpcf7-list-item label .wpcf7-list-item-label::before {
  top: 2rem;
}
.common_form02 .wpcf7-checkbox.product_list .wpcf7-list-item label .wpcf7-list-item-label::after {
  top: 2.7rem;
}
.common_form02 .wpcf7-radio {
  width: 100%;
  padding-top: 0.7rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 2.8rem;
  padding-bottom: 0.4rem;
}
.common_form02 .wpcf7-radio .wpcf7-list-item {
  display: inline-block;
}
.common_form02 .wpcf7-radio .wpcf7-list-item label input {
  display: none;
}
.common_form02 .wpcf7-radio .wpcf7-list-item label input:checked + .wpcf7-list-item-label::after {
  display: block;
}
.common_form02 .wpcf7-radio .wpcf7-list-item label .wpcf7-list-item-label {
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.333333;
  letter-spacing: 0.05em;
  padding-left: 3.1rem;
  position: relative;
  cursor: pointer;
}
.common_form02 .wpcf7-radio .wpcf7-list-item label .wpcf7-list-item-label::before {
  content: "";
  width: 2.4rem;
  aspect-ratio: 1/1;
  border: solid 0.2rem #cccccc;
  background-color: #f5f5f5;
  border-radius: 50%;
  position: absolute;
  top: 0.2rem;
  left: 0;
}
.common_form02 .wpcf7-radio .wpcf7-list-item label .wpcf7-list-item-label::after {
  content: "";
  width: 1.4rem;
  aspect-ratio: 1/1;
  background-color: #19396d;
  border-radius: 50%;
  position: absolute;
  top: 0.7rem;
  left: 0.5rem;
  display: none;
}
.common_form02 .wpcf7-radio.license_list {
  display: grid;
  gap: 1.1rem 2.8rem;
  grid-template-columns: 8rem 20rem auto;
}

/*----------------------------------------------------------------------------
******************************************************************************
** Privacy Policy
******************************************************************************
----------------------------------------------------------------------------*/
.privacy_sec01 {
  padding-top: 6rem;
  padding-bottom: 9rem;
}
.privacy_sec01 .container .privacy_block {
  width: 100%;
  margin-top: 5rem;
}
.privacy_sec01 .container .privacy_block:first-of-type {
  margin-top: 0;
}
.privacy_sec01 .container .privacy_block .privacy_ttl {
  margin-bottom: 3rem;
}
.privacy_sec01 .container .privacy_block .privacy_sub_ttl {
  margin-top: 3rem;
}
.privacy_sec01 .container .privacy_block .privacy_sub_ttl span {
  font-size: 1.6rem;
}
.privacy_sec01 .container .privacy_block .privacy_img {
  margin-top: 3rem;
}
.privacy_sec01 .container .privacy_block .privacy_txt {
  margin-top: 1.4rem;
}
.privacy_sec01 .container .privacy_block .privacy_txt a {
  color: #19396d;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 0.8rem;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.privacy_sec01 .container .privacy_block .privacy_txt a:hover {
  opacity: 0.7;
}
.privacy_sec01 .container .privacy_block .privacy_list {
  width: 100%;
  margin-top: 2rem;
  margin-bottom: 3rem;
}
.privacy_sec01 .container .privacy_block .privacy_list.no_dots li {
  padding-left: 0;
}
.privacy_sec01 .container .privacy_block .privacy_list.no_dots li::before {
  display: none;
}
.privacy_sec01 .container .privacy_block .privacy_list li {
  position: relative;
  padding-left: 2rem;
}
.privacy_sec01 .container .privacy_block .privacy_list li::before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0.4rem;
}
.privacy_sec01 .container .privacy_note {
  text-align: right;
  margin-top: 5rem;
}

.archive_search {
  width: 100%;
  margin-top: 5rem;
}
.archive_search .archive_search_form {
  width: 100%;
  max-width: 60rem;
  height: 5rem;
  display: grid;
  grid-template-columns: auto 8rem;
  gap: 2rem;
  margin: 0 auto;
}
.archive_search .archive_search_form input {
  height: 100%;
  padding: 0.5rem 2.1rem;
  background-color: #f5f5f5;
  border: solid 0.2rem #cccccc;
  border-radius: 0.4rem;
}
.archive_search .archive_search_form button {
  color: #fff;
  background-color: #19396d;
  border-radius: 0.4rem;
}

/*----------------------------------------------------------------------------
******************************************************************************
** office
******************************************************************************
----------------------------------------------------------------------------*/
.office_sec01 {
  padding-top: 6.8rem;
  padding-bottom: 14.6rem;
}
.office_sec01 .container {
  max-width: 100rem;
}
.office_sec01 .container .office_map {
  width: 100%;
  position: relative;
}
.office_sec01 .container .office_map .map {
  width: 79.3%;
  position: relative;
  top: 0;
  left: 6.4%;
}
.office_sec01 .container .office_map .each_office {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
}
.office_sec01 .container .office_map .each_office li {
  position: absolute;
}
.office_sec01 .container .office_map .each_office li.main_office {
  top: 76.8824%;
  left: 53.2%;
}
.office_sec01 .container .office_map .each_office li.kanto {
  top: 62.6143%;
  left: 60.5%;
}
.office_sec01 .container .office_map .each_office li.kansai {
  top: 86.79%;
  left: 50.7%;
}
.office_sec01 .container .office_map .each_office li.fukuyama {
  top: 67.7675%;
  left: 16.1%;
}
.office_sec01 .container .office_map .each_office li.fukuoka {
  top: 75.2972%;
  left: 7.3%;
}
.office_sec01 .container .office_map .each_office li a {
  font-size: clamp(0px, 1.923076923vw, 2rem);
  color: #19396d;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
  display: inline-block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  margin-right: 1rem;
}
.office_sec01 .container .office_map .each_office li a:last-of-type {
  margin-right: 0;
}
.office_sec01 .container .office_map .each_office li a:hover {
  opacity: 0.7;
}
.office_sec01 .container .office_list {
  width: 100%;
  margin-top: 6.8rem;
}
.office_sec01 .container .office_list .office_area {
  width: 100%;
  margin-top: 8.4rem;
}
.office_sec01 .container .office_list .office_area:first-of-type {
  margin-top: 0;
}
.office_sec01 .container .office_list .office_detail {
  width: 100%;
  margin-top: 3rem;
}
.office_sec01 .container .office_list .office_detail .office_name {
  width: calc(50% - 3rem);
  float: left;
  margin: 0.3rem 0 0.2rem;
}
.office_sec01 .container .office_list .office_detail p,
.office_sec01 .container .office_list .office_detail dl {
  width: calc(50% - 3rem);
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
  float: left;
}
.office_sec01 .container .office_list .office_detail p.free_num,
.office_sec01 .container .office_list .office_detail dl.free_num {
  color: #19396d;
  font-weight: 700;
}
.office_sec01 .container .office_list .office_detail dl {
  margin-top: 1rem;
}
.office_sec01 .container .office_list .office_detail dl dt {
  margin-top: 1rem;
}
.office_sec01 .container .office_list .office_detail .g_map {
  width: 50%;
  aspect-ratio: 1/0.64;
  margin-top: 1rem;
  float: right;
}
.office_sec01 .container .office_list .office_detail .g_map iframe {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.office_sec01 .container .office_list .office_detail + dd {
  margin-top: 3.6rem;
  border-top: solid 0.1rem #dddddd;
  padding-top: 3rem;
}

/*----------------------------------------------------------------------------
******************************************************************************
** company
******************************************************************************
----------------------------------------------------------------------------*/
.company_sec01 {
  padding-top: 17.4rem;
  padding-bottom: 15rem;
  background: -webkit-image-set(url(../images/company/company_bg.png) 1x, url(../images/company/company_bg@2x.png) 2x) no-repeat top 2.7rem center;
  background: image-set(url(../images/company/company_bg.png) 1x, url(../images/company/company_bg@2x.png) 2x) no-repeat top 2.7rem center;
}
.company_sec01 .container {
  max-width: 100rem;
}
.company_sec01 .container .cpmany_catch {
  width: 100%;
  font-size: 4.2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.6666666667;
  letter-spacing: 0.05em;
  text-align: center;
}
.company_sec01 .container .company_message_block {
  width: 100%;
  margin-top: 10.9rem;
}
.company_sec01 .container .company_message_block .company_message_txt {
  margin-top: 2rem;
}
.company_sec01 .container .company_message_block .company_message_txt:first-of-type {
  margin-top: 2.9rem;
}
.company_sec01 .container .company_message_block .company_message_name {
  width: 100%;
  text-align: right;
  margin-top: 2.2rem;
}
.company_sec01 .container .company_message_block .company_message_name .company_message_company {
  width: 100%;
  display: block;
}
.company_sec01 .container .company_message_block .company_message_name .company_message_executive {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  gap: 2rem;
}
.company_sec01 .container .company_message_block .company_message_name .company_message_executive .sign {
  display: inline-block;
  line-height: 1;
}
.company_sec01 .container .company_about_block {
  width: 100%;
  margin-top: 8rem;
}
.company_sec01 .container .company_about_block .company_about_list {
  margin-top: 4.1rem;
}
.company_sec01 .container .company_about_block .company_about_list > dt.office_list {
  padding-top: 2rem;
}
.company_sec01 .container .company_about_block .company_about_list > dd.office_list {
  padding-top: 2rem;
}
.company_sec01 .container .company_about_block .company_about_list > dd .company_about_clist {
  width: 100%;
  display: grid;
  grid-template-columns: 14rem auto;
  gap: 0.4rem 0;
  padding-bottom: 1.5rem;
}
.company_sec01 .container .company_about_block .company_about_list > dd .company_about_clist dt a {
  color: #19396d;
  text-decoration: underline;
  text-underline-offset: 1rem;
  text-decoration-thickness: 0.2rem;
  text-decoration-color: #a7aebf;
}
.company_sec01 .container .company_history_block {
  width: 100%;
  margin-top: 8.6rem;
}
.company_sec01 .container .company_history_block .company_history_list_wrap {
  width: 100%;
  margin-top: 2.1rem;
}
.company_sec01 .container .company_history_block .company_history_list_wrap .history_row {
  width: 100%;
  display: grid;
  grid-template-columns: 9.7rem auto;
  padding: 1.5rem 0 1.8rem 2.1rem;
  border-bottom: solid 0.1rem #dddddd;
}
.company_sec01 .container .company_history_block .company_history_list_wrap .history_row .history_year {
  font-size: 1.8rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.8888888888;
  letter-spacing: 0.05em;
}
.company_sec01 .container .company_history_block .company_history_list_wrap .history_row .history_event {
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.8888888888;
  letter-spacing: 0.05em;
  display: grid;
  grid-template-columns: 7.2rem auto;
}
.common_list03 {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
  display: grid;
  grid-template-columns: 19.3rem auto;
  border-top: solid 0.1rem #dddddd;
}
.common_list03 > dt {
  font-weight: 700;
  padding: 1.5rem 2.1rem 1.8rem;
  background-color: #f3f3f3;
  border-bottom: solid 0.1rem #dddddd;
}
.common_list03 > dd {
  padding: 1.5rem 2rem 1.8rem;
  border-bottom: solid 0.1rem #dddddd;
}

/*----------------------------------------------------------------------------
******************************************************************************
** faq
******************************************************************************
----------------------------------------------------------------------------*/
.faq_sec01 {
  padding-top: 6.7rem;
  padding-bottom: 15rem;
}
.faq_sec01 .container .faq_link_list {
  max-width: auto;
  max-width: initial;
  margin-top: 0;
}
.faq_sec01 .container .faq_link_list a {
  padding: 0 3rem;
  border-right: solid 0.1rem #cccccc;
}
.faq_sec01 .container .faq_link_list a span {
  padding-right: 4rem;
}
.faq_sec01 .container .faq_list {
  width: 100%;
  margin-top: 8.6rem;
}
.faq_sec01 .container .faq_list > dt {
  margin-top: 8.6rem;
  margin-bottom: 4rem;
}
.faq_sec01 .container .faq_list > dt:first-of-type {
  margin-top: 0;
}
.faq_sec01 .container .faq_list > dd {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 3rem;
}
.faq_sec01 .container .faq_list > dd .faq_clist {
  width: 100%;
  background-color: #f5f5f5;
  padding: 3.9rem 4rem 3.7rem;
  border: solid 0.1rem #dddddd;
  border-radius: 1rem;
  cursor: pointer;
}
.faq_sec01 .container .faq_list > dd .faq_clist dt {
  min-height: 4.4rem;
  position: relative;
  padding: 0.2rem 0 0 5.9rem;
}
.faq_sec01 .container .faq_list > dd .faq_clist dt::before {
  content: "Q";
  width: 4.4rem;
  aspect-ratio: 1/1;
  font-family: "Jost";
  font-size: 2.2rem;
  color: #fff;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
  border-radius: 50%;
  background-color: #19396d;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: absolute;
  top: 0;
  left: 0;
}
.faq_sec01 .container .faq_list > dd .faq_clist dt span {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  display: block;
  position: relative;
  padding-right: 4rem;
}
.faq_sec01 .container .faq_list > dd .faq_clist dt span::before, .faq_sec01 .container .faq_list > dd .faq_clist dt span::after {
  content: "";
  width: 2.2rem;
  height: 0.2rem;
  background-color: #19396d;
  position: absolute;
  top: 1.9rem;
  right: 0;
}
.faq_sec01 .container .faq_list > dd .faq_clist dt span::after {
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.faq_sec01 .container .faq_list > dd .faq_clist dt.open span::after {
  -webkit-transform: rotate(0);
          transform: rotate(0);
}
.faq_sec01 .container .faq_list > dd .faq_clist dd {
  width: 100%;
  display: none;
}
.faq_sec01 .container .faq_list > dd .faq_clist dd .faq_awnser_editor {
  width: 100%;
  min-height: 4.4rem;
  padding: 3.4rem 0 0 6.1rem;
  position: relative;
}
.faq_sec01 .container .faq_list > dd .faq_clist dd .faq_awnser_editor::before {
  content: "A";
  width: 4.4rem;
  aspect-ratio: 1/1;
  font-family: "Jost";
  font-size: 2.2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
  border-radius: 50%;
  background-color: #f2f238;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: absolute;
  top: 3.1rem;
  left: 0;
}

/*----------------------------------------------------------------------------
******************************************************************************
** link
******************************************************************************
----------------------------------------------------------------------------*/
.link_sec01 {
  padding-top: 5.3rem;
  padding-bottom: 15rem;
}
.link_sec01 .container {
  max-width: 100rem;
}
.link_sec01 .container .link_list {
  width: 100%;
}
.link_sec01 .container .link_list dt {
  margin-top: 8.5rem;
}
.link_sec01 .container .link_list dt:first-of-type {
  margin-top: 0;
}
.link_sec01 .container .link_list dd {
  width: 100%;
  margin-top: 4rem;
}
.link_sec01 .container .link_list dd .link_clist {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4rem;
}
.link_sec01 .container .link_list dd .link_clist li {
  border-radius: 1rem;
  border: solid 0.1rem #dddddd;
  overflow: hidden;
}
.link_sec01 .container .link_list dd .link_clist li a {
  height: 100%;
  display: block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.link_sec01 .container .link_list dd .link_clist li a:hover {
  opacity: 0.7;
}
.link_sec01 .container .link_list dd .link_clist li a .link_thumb {
  width: 100%;
  aspect-ratio: 1/0.39375;
  background-color: #ccc;
}
.link_sec01 .container .link_list dd .link_clist li a .link_thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.link_sec01 .container .link_list dd .link_clist li a .link_desc {
  width: 100%;
  padding: 1.6rem 2.6rem 1.9rem;
}
.link_sec01 .container .link_list dd .link_clist li a .link_desc .link_ttl {
  width: 100%;
  font-size: 2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.link_sec01 .container .link_list dd .link_clist li a .link_desc .link_txt {
  line-height: 1.625;
  margin-top: 0.6rem;
}

.swpm_profile_not_logged_in_msg {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.625;
  letter-spacing: 0.05em;
}

/*----------------------------------------------------------------------------
******************************************************************************
** membership plan
******************************************************************************
----------------------------------------------------------------------------*/
.membership_plan_sec01 {
  padding-top: 6rem;
  padding-bottom: 6rem;
}
.membership_plan_sec01 .container {
  max-width: 100rem;
}
.membership_plan_sec01 .container .membership_plan_lead {
  text-align: center;
  margin-top: 4rem;
}
.membership_plan_sec01 .container .membership_plan_sub_ttl {
  text-align: center;
  margin-top: 3rem;
}
.membership_plan_sec01 .container .membership_plan_txt {
  margin-top: 2rem;
}
.membership_plan_sec01 .container .membership_caution_ttl {
  margin-top: 3rem;
}
.membership_plan_sec01 .container .membership_caution_list {
  margin-top: 2rem;
}
.membership_plan_sec01 .container .membership_caution_list li {
  padding-left: 1em;
  text-indent: -1em;
}
.membership_plan_sec01 .container .membership_plan_table_wrap {
  width: 100%;
  margin-top: 5rem;
  overflow-x: auto;
}
.membership_plan_sec01 .container .membership_plan_table_wrap .membership_plan_table {
  width: 100%;
  border-collapse: collapse;
}
.membership_plan_sec01 .container .membership_plan_table_wrap .membership_plan_table thead tr th {
  height: 6rem;
  font-weight: 700;
  background-color: #f3f3f3;
  padding: 1rem 2rem;
  border: solid 0.1rem #ddd;
  text-align: center;
}
.membership_plan_sec01 .container .membership_plan_table_wrap .membership_plan_table thead tr th:first-of-type {
  width: 30%;
}
.membership_plan_sec01 .container .membership_plan_table_wrap .membership_plan_table thead tr th.free {
  color: #19396d;
}
.membership_plan_sec01 .container .membership_plan_table_wrap .membership_plan_table thead tr th.paid {
  color: #fff;
  background-color: #19396d;
}
.membership_plan_sec01 .container .membership_plan_table_wrap .membership_plan_table tbody tr:nth-of-type(even) {
  background-color: #f9f9f9;
}
.membership_plan_sec01 .container .membership_plan_table_wrap .membership_plan_table tbody tr td {
  height: 5.5rem;
  padding: 1rem 2rem;
  border: solid 0.1rem #ddd;
  text-align: center;
}
.membership_plan_sec01 .container .membership_plan_table_wrap .membership_plan_table tbody tr td.label {
  text-align: left;
  font-weight: 700;
}
.membership_plan_sec01 .container .membership_plan_note {
  margin-top: 1.5rem;
  text-align: right;
}

.membership_plan_sec02 {
  padding-top: 6rem;
  padding-bottom: 15rem;
  background-color: #f5f7fa;
}
.membership_plan_sec02 .membership_plan_cards {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 4rem;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.membership_plan_sec02 .membership_plan_cards .membership_plan_card {
  width: 46%;
  background-color: #fff;
  border: solid 0.1rem #ddd;
  border-radius: 0.8rem;
  padding: 4rem 3.5rem;
}
.membership_plan_sec02 .membership_plan_cards .membership_plan_card.paid {
  border-color: #19396d;
  border-width: 0.2rem;
}
.membership_plan_sec02 .membership_plan_cards .membership_plan_card .membership_plan_card_ttl {
  font-size: 2.6rem;
}
.membership_plan_sec02 .membership_plan_cards .membership_plan_card .membership_plan_card_price {
  text-align: center;
  font-size: 2.4rem;
  font-weight: 700;
  color: #19396d;
  margin-top: 2rem;
}
.membership_plan_sec02 .membership_plan_cards .membership_plan_card .membership_plan_card_price span {
  font-size: 1.4rem;
  font-weight: 400;
}
.membership_plan_sec02 .membership_plan_cards .membership_plan_card .membership_plan_card_desc {
  margin-top: 3rem;
}
.membership_plan_sec02 .membership_plan_cards .membership_plan_card .membership_plan_card_desc dt {
  font-weight: 700;
  margin-top: 2rem;
}
.membership_plan_sec02 .membership_plan_cards .membership_plan_card .membership_plan_card_desc dt.center {
  text-align: center;
}
.membership_plan_sec02 .membership_plan_cards .membership_plan_card .membership_plan_card_desc dt:first-of-type {
  margin-top: 0;
}
.membership_plan_sec02 .membership_plan_cards .membership_plan_card .membership_plan_card_desc dd {
  margin-top: 0.8rem;
}
.membership_plan_sec02 .membership_plan_cards .membership_plan_card .membership_plan_card_btn {
  margin-top: 4rem;
  text-align: center;
}
.membership_plan_sec02 .membership_plan_upgrade {
  margin-top: 6rem;
  text-align: center;
}
.membership_plan_sec02 .membership_plan_upgrade .membership_plan_upgrade_btn {
  margin-top: 5rem;
}

/*----------------------------------------------------------------------------
******************************************************************************
** sitemap
******************************************************************************
----------------------------------------------------------------------------*/
.sitemap_sec {
  padding-top: 6rem;
  padding-bottom: 6rem;
}
.sitemap_sec .container .sitemap_block {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 3rem;
}
.sitemap_sec .container .sitemap_block .sitemap_pages,
.sitemap_sec .container .sitemap_block .sitemap_posts {
  width: 100%;
  margin-top: 0;
}
.sitemap_sec .container .sitemap_block .sitemap_pages .sitemap_block_ttl,
.sitemap_sec .container .sitemap_block .sitemap_posts .sitemap_block_ttl {
  width: 100%;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  margin-bottom: 2rem;
}
.sitemap_sec .container .sitemap_block .sitemap_pages .sitemap_block_ttl a,
.sitemap_sec .container .sitemap_block .sitemap_posts .sitemap_block_ttl a {
  color: #19396d;
  display: inline-block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.sitemap_sec .container .sitemap_block .sitemap_pages .sitemap_block_ttl a:hover,
.sitemap_sec .container .sitemap_block .sitemap_posts .sitemap_block_ttl a:hover {
  opacity: 0.7;
}
.sitemap_sec .container .sitemap_block .sitemap_pages ul,
.sitemap_sec .container .sitemap_block .sitemap_posts ul {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1rem;
  margin-top: 1rem;
}
.sitemap_sec .container .sitemap_block .sitemap_pages ul li,
.sitemap_sec .container .sitemap_block .sitemap_posts ul li {
  width: 100%;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.625;
  letter-spacing: 0.05em;
  position: relative;
  padding-left: 1em;
}
.sitemap_sec .container .sitemap_block .sitemap_pages ul li::before,
.sitemap_sec .container .sitemap_block .sitemap_posts ul li::before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
}
.sitemap_sec .container .sitemap_block .sitemap_pages ul li a,
.sitemap_sec .container .sitemap_block .sitemap_posts ul li a {
  text-decoration: underline;
  text-decoration-color: #19396d;
  text-underline-offset: 0.4rem;
  display: inline-block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.sitemap_sec .container .sitemap_block .sitemap_pages ul li a:hover,
.sitemap_sec .container .sitemap_block .sitemap_posts ul li a:hover {
  opacity: 0.7;
}

/*----------------------------------------------------------------------------
******************************************************************************
** footer
******************************************************************************
----------------------------------------------------------------------------*/
.grecaptcha-badge {
  bottom: 7rem !important;
}

.common_form {
  width: 100%;
}
.common_form .wpcf7-checkbox {
  width: 100%;
  display: grid;
  gap: 1.5rem;
  margin-bottom: 0.8rem;
}
.common_form .wpcf7-checkbox .wpcf7-list-item label input {
  display: none;
}
.common_form .wpcf7-checkbox .wpcf7-list-item label input:checked + .wpcf7-list-item-label::after {
  display: block;
}
.common_form .wpcf7-checkbox .wpcf7-list-item label .wpcf7-list-item-label {
  padding-left: 3.9rem;
  display: inline-block;
  position: relative;
}
.common_form .wpcf7-checkbox .wpcf7-list-item label .wpcf7-list-item-label::before {
  content: "";
  width: 2.4rem;
  aspect-ratio: 1/1;
  border: solid 0.1rem #cccccc;
  background-color: #fff;
  border-radius: 0.3rem;
  position: absolute;
  top: 0.2rem;
  left: 0;
}
.common_form .wpcf7-checkbox .wpcf7-list-item label .wpcf7-list-item-label::after {
  content: "";
  width: 1.4rem;
  aspect-ratio: 1/0.5;
  border-bottom: solid 0.2rem #19396d;
  border-left: solid 0.2rem #19396d;
  position: absolute;
  top: 0.9rem;
  left: 0.5rem;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  display: none;
}
.common_form dl {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
  display: grid;
  grid-template-columns: 15rem auto;
  border-top: solid 0.1rem #cccccc;
}
.common_form dl dt {
  font-weight: 700;
  padding: 3rem 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-bottom: solid 0.1rem #cccccc;
}
.common_form dl dt.fs {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.common_form dl dd {
  padding: 3rem 0 3rem 2.4rem;
  border-bottom: solid 0.1rem #cccccc;
}
.common_form dl dd .input_box input[type=text],
.common_form dl dd .input_box input[type=email] {
  width: 100%;
  height: 6rem;
  padding: 0.5rem 1.9rem;
  border: solid 0.1rem #cccccc;
  border-radius: 0.4rem;
}
.common_form .catalog_modal_btn {
  margin-top: 1.8rem;
}
.common_form .catalog_modal_btn .wrap {
  width: 100%;
  max-width: 35rem;
  height: 6.6rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background-color: #f2f238;
  border-radius: 5rem;
  position: relative;
  margin: 0 auto;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_form .catalog_modal_btn .wrap::before {
  content: "";
  width: 4.6rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: -webkit-image-set(url(../images/common/common_arrow01_y.png) 1x, url(../images/common/common_arrow01_y@2x.png) 2x) no-repeat center/1.6rem, #19396d;
  background: image-set(url(../images/common/common_arrow01_y.png) 1x, url(../images/common/common_arrow01_y@2x.png) 2x) no-repeat center/1.6rem, #19396d;
  position: absolute;
  top: 50%;
  right: 1rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.common_form .catalog_modal_btn .wrap input {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 100%;
  height: 100%;
  font-size: 2rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: 0.05em;
  padding: 1rem 7rem;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.common_form .catalog_modal_btn .wrap:hover::before {
  right: 0;
}
.common_form .catalog_modal_btn .wpcf7-spinner {
  display: none;
}

.treatment_modal {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  opacity: 0;
  pointer-events: none;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.treatment_modal.modal_show {
  opacity: 1;
  pointer-events: auto;
}
.treatment_modal .modal_close_trigger {
  cursor: pointer;
}
.treatment_modal .treatment_modal_block {
  width: calc(100% - 4rem);
  max-width: 120rem;
  height: calc(100vh - 10rem);
  max-height: 78.1rem;
  background-color: #fff;
  border-radius: 1rem;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.treatment_modal .treatment_modal_block .modal_close_btn {
  width: 4rem;
  aspect-ratio: 1/1;
  position: absolute;
  top: -2.6rem;
  right: 0.5rem;
  -webkit-transform: translateY(-100%);
          transform: translateY(-100%);
}
.treatment_modal .treatment_modal_block .modal_close_btn::before, .treatment_modal .treatment_modal_block .modal_close_btn::after {
  content: "";
  width: 4.4rem;
  height: 0.2rem;
  background-color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
}
.treatment_modal .treatment_modal_block .modal_close_btn::after {
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
          transform: translate(-50%, -50%) rotate(-45deg);
}
.treatment_modal .treatment_modal_block .treatment_modal_form_scroll {
  width: 100%;
  height: 100%;
  padding: 6.5rem 2rem;
  overflow-y: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.treatment_modal .treatment_modal_block .treatment_modal_form_scroll::-webkit-scrollbar {
  display: none;
}
.treatment_modal .treatment_modal_block .treatment_modal_form_scroll .treatment_modal_ttl {
  width: 100%;
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  text-align: center;
}
.treatment_modal .treatment_modal_block .treatment_modal_form_scroll .treatment_modal_products {
  width: 100%;
  max-width: 104rem;
  display: grid;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  grid-template-columns: repeat(3, minmax(auto, 30rem));
  gap: 7rem 2rem;
  margin: 5.6rem auto 0;
}
.treatment_modal .treatment_modal_block .treatment_modal_form_scroll .treatment_modal_products .treatment_modal_products_box a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.treatment_modal .treatment_modal_block .treatment_modal_form_scroll .treatment_modal_products .treatment_modal_products_box a:hover .treatment_modal_products_btn > span {
  background-color: #19396d;
}
.treatment_modal .treatment_modal_block .treatment_modal_form_scroll .treatment_modal_products .treatment_modal_products_box a:hover .treatment_modal_products_btn > span::before {
  background: -webkit-image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #f2f238;
  background: image-set(url(../images/common/common_arrow01.png) 1x, url(../images/common/common_arrow01@2x.png) 2x) no-repeat center/1.6rem, #f2f238;
  right: 0;
}
.treatment_modal .treatment_modal_block .treatment_modal_form_scroll .treatment_modal_products .treatment_modal_products_box a:hover .treatment_modal_products_btn > span span {
  color: #f2f238;
}
.treatment_modal .treatment_modal_block .treatment_modal_form_scroll .treatment_modal_products .treatment_modal_products_box a .treatment_modal_products_name {
  width: 100%;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.05em;
  text-align: center;
  margin-top: 1.3rem;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.treatment_modal .treatment_modal_block .treatment_modal_form_scroll .treatment_modal_products .treatment_modal_products_box a .treatment_modal_products_pic {
  width: 100%;
  height: 16rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.treatment_modal .treatment_modal_block .treatment_modal_form_scroll .treatment_modal_products .treatment_modal_products_box a .treatment_modal_products_pic picture {
  width: 100%;
  height: 100%;
  display: block;
  text-align: center;
}
.treatment_modal .treatment_modal_block .treatment_modal_form_scroll .treatment_modal_products .treatment_modal_products_box a .treatment_modal_products_pic picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.treatment_modal .treatment_modal_block .treatment_modal_form_scroll .treatment_modal_products .treatment_modal_products_box a .treatment_modal_products_btn {
  margin-top: 1.5rem;
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
  pointer-events: none;
}
.treatment_modal .treatment_modal_bg {
  width: 100%;
  height: 100%;
  background-color: rgba(38, 38, 38, 0.8);
}

.catalog_modal {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  opacity: 0;
  pointer-events: none;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.catalog_modal.modal_show {
  opacity: 1;
  pointer-events: auto;
}
.catalog_modal .modal_close_trigger {
  cursor: pointer;
}
.catalog_modal .catalog_modal_block {
  width: calc(100% - 4rem);
  max-width: 96rem;
  height: calc(100vh - 10rem);
  max-height: 113.4rem;
  background-color: #fff;
  border-radius: 1rem;
  position: absolute;
  top: 10rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.catalog_modal .catalog_modal_block .modal_close_btn {
  width: 4rem;
  aspect-ratio: 1/1;
  position: absolute;
  top: -1rem;
  right: 0.5rem;
  -webkit-transform: translateY(-100%);
          transform: translateY(-100%);
}
.catalog_modal .catalog_modal_block .modal_close_btn::before, .catalog_modal .catalog_modal_block .modal_close_btn::after {
  content: "";
  width: 4.4rem;
  height: 0.2rem;
  background-color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
}
.catalog_modal .catalog_modal_block .modal_close_btn::after {
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
          transform: translate(-50%, -50%) rotate(-45deg);
}
.catalog_modal .catalog_modal_block .catalog_modal_form_scroll {
  width: 100%;
  height: 100%;
  padding: 6.5rem 2rem;
  overflow-y: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.catalog_modal .catalog_modal_block .catalog_modal_form_scroll::-webkit-scrollbar {
  display: none;
}
.catalog_modal .catalog_modal_block .catalog_modal_form_scroll .catalog_modal_ttl {
  width: 100%;
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  text-align: center;
}
.catalog_modal .catalog_modal_block .catalog_modal_form_scroll .catalog_modal_form_block {
  width: 100%;
  max-width: 80rem;
  border-radius: 1rem;
  padding: 5rem 2rem 6.1rem;
  background-color: #edf0f5;
  margin: 5rem auto 0;
}
.catalog_modal .catalog_modal_block .catalog_modal_form_scroll .catalog_modal_form_block .catalog_modal_form_ttl {
  width: 100%;
  font-size: 3rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
  text-align: center;
}
.catalog_modal .catalog_modal_block .catalog_modal_form_scroll .catalog_modal_form_block .catalog_modal_form {
  max-width: 62.4rem;
  margin: 1.8rem auto 0;
}
.catalog_modal .catalog_modal_block .catalog_modal_form_scroll .catalog_modal_form_block .catalog_modal_form .common_form dd {
  padding-left: 0.5rem;
}
.catalog_modal .catalog_modal_block .catalog_modal_form_scroll .catalog_modal_form_block .catalog_modal_form .common_form dd .wpcf7-list-item {
  margin: 0;
}
.catalog_modal .catalog_modal_block .catalog_modal_form_scroll .catalog_modal_form_block .catalog_modal_form .common_form dd .wpcf7-list-item .wpcf7-list-item-label span {
  font-size: 1.4rem;
}
.catalog_modal .catalog_modal_bg {
  width: 100%;
  height: 100%;
  background-color: rgba(38, 38, 38, 0.8);
}

.modal_overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.85);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 10000;
}
.modal_overlay .modal_content {
  background: #fff;
  padding: 3rem 2rem;
  border-radius: 1rem;
  max-width: 50rem;
  text-align: center;
}
.modal_overlay .modal_content .modal_content_ttl {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.modal_overlay .modal_content .modal_content_txt {
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.625;
  letter-spacing: 0.05em;
  margin-top: 1rem;
}
.modal_overlay .modal_btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2rem;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 2rem;
}
.modal_overlay .modal_btn .btn {
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
  padding: 1rem 3rem;
  cursor: pointer;
  border: none;
}
.modal_overlay .modal_btn .btn.btn_primary {
  background: #004098;
  color: #fff;
}
.modal_overlay .modal_btn .btn.btn_secondary {
  background: #ccc;
  color: #333;
}

.aside_navi {
  width: 8.2rem;
  border-top-left-radius: 1rem;
  border-bottom-left-radius: 1rem;
  overflow: hidden;
  position: fixed;
  top: calc(50% - 6.6rem);
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  z-index: 99;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  --border-color: transparent;
}
.aside_navi.change_color {
  --border-color: #fff;
}
.aside_navi {
  border: solid 0.2rem var(--border-color);
  border-right: none;
}
.aside_navi nav {
  width: 100%;
}
.aside_navi nav .aside_site_navi {
  width: 100%;
}
.aside_navi nav .aside_site_navi li {
  width: 8rem;
  border-top: solid 0.2rem var(--border-color);
  --bgc: #19396d;
  --color: #fff;
  --filter: brightness(0) invert(1);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.aside_navi nav .aside_site_navi li.catalog {
  --bgc: #f2f238;
  --color: #19396d;
  --filter: none;
}
.aside_navi nav .aside_site_navi li:first-of-type {
  border-top: none;
}
.aside_navi nav .aside_site_navi li a,
.aside_navi nav .aside_site_navi li > span {
  width: 100%;
  height: 10rem;
  padding: 1.6rem 1rem 1rem;
  background-color: var(--bgc);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
  cursor: pointer;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.aside_navi nav .aside_site_navi li a:hover,
.aside_navi nav .aside_site_navi li > span:hover {
  opacity: 0.7;
}
.aside_navi nav .aside_site_navi li a .icon,
.aside_navi nav .aside_site_navi li > span .icon {
  display: inline-block;
}
.aside_navi nav .aside_site_navi li a .icon picture,
.aside_navi nav .aside_site_navi li > span .icon picture {
  -webkit-filter: var(--filter);
          filter: var(--filter);
  display: inline-block;
}
.aside_navi nav .aside_site_navi li a .txt,
.aside_navi nav .aside_site_navi li > span .txt {
  width: 100%;
  font-size: 1.4rem;
  color: var(--color);
  font-weight: 700;
  line-height: 1.2857142857;
  letter-spacing: 0.05em;
  text-align: center;
  display: inline-block;
  margin-top: 0.6rem;
}
.aside_navi nav .aside_site_navi li a .txt.small,
.aside_navi nav .aside_site_navi li > span .txt.small {
  letter-spacing: 0;
}

.ft {
  padding-top: 8rem;
  padding-bottom: 4.6rem;
  background-color: #edf0f5;
}
.ft .container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.ft .container .ft_company_data {
  width: 37rem;
}
.ft .container .ft_company_data .logo {
  width: 29.6rem;
}
.ft .container .ft_company_data .logo a {
  display: inline-block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.ft .container .ft_company_data .logo a:hover {
  opacity: 0.7;
}
.ft .container .ft_company_data .address {
  width: 100%;
  margin-top: 2.8rem;
}
.ft .container .ft_company_data .tel {
  padding-top: 1.8rem;
}
.ft .container .ft_company_data .tel a {
  display: inline-block;
}
.ft .container .ft_company_data .tel a .num {
  font-family: "Jost";
  font-size: 4.2rem;
  color: #19396d;
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: -0.02em;
  padding-left: 5rem;
  position: relative;
}
.ft .container .ft_company_data .tel a .num::before {
  content: "";
  width: 4.5rem;
  height: 3rem;
  background: url(../images/common/tel_icon.png) no-repeat center/contain;
  background: url(../images/common/tel_icon.svg) no-repeat center/contain;
  position: absolute;
  top: 3.1rem;
  left: 0.1rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.ft .container .ft_company_data .tel a .num .mr-20 {
  margin-right: -2rem;
}
.ft .container .ft_company_data .tel a .num rt {
  font-family: YakuHanJP, "Noto Sans JP";
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -1.2em;
  position: relative;
  top: -0.3rem;
  left: -0.9rem;
}
.ft .container .ft_company_data .tel a .num rt.ls {
  letter-spacing: 0.1em;
  position: relative;
  left: 0.5rem;
  left: 0;
}
.ft .container .ft_company_data .tel a .txt {
  display: block;
  margin-top: -0.7rem;
}
.ft .container .ft_navi {
  width: calc(100% - 37rem);
  max-width: 68.3rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 2rem;
}
@media screen and (max-width: 1000px) {
  .ft .container .ft_navi {
    display: block;
    max-width: 47rem;
  }
}
.ft .container .ft_navi .ft_navi_list {
  width: calc(100% - 16rem);
  max-width: 45.3rem;
  height: 26rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.8rem 6.3rem;
  padding-top: 2.2rem;
}
@media screen and (max-width: 1100px) {
  .ft .container .ft_navi .ft_navi_list {
    gap: 0.8rem 1rem;
  }
}
@media screen and (max-width: 1100px) and (max-width: 800px) {
  .ft .container .ft_navi .ft_navi_list {
    width: 100%;
  }
}
.ft .container .ft_navi .ft_navi_list a {
  display: inline-block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.ft .container .ft_navi .ft_navi_list a:hover {
  opacity: 0.7;
}
.ft .container .ft_navi .ft_cert {
  width: 16rem;
  padding-top: 3rem;
}
.ft .container .copyright {
  width: 100%;
  font-family: "Jost";
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.625;
  letter-spacing: 0.05em;
  margin-top: 2.9rem;
}

.pagetop {
  width: 5rem;
  height: 5rem;
  background-color: #19396d;
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  cursor: pointer;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  opacity: 0;
  pointer-events: none;
  z-index: 100;
}
.pagetop::before {
  content: "";
  width: 2rem;
  height: 2rem;
  border-top: solid 0.2rem #fff;
  border-right: solid 0.2rem #fff;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -14.65%) rotate(-45deg);
          transform: translate(-50%, -14.65%) rotate(-45deg);
  /**45degの中央揃え**/
  /**45deg=141.4%**/
  /**75% 斜めなので 半分の半分**/
  /**41.4%の半分20.7%の半分50%(斜めによって生じた%なので斜め計算(75%)ではなく半分(50%)) = 10.35%**/
  /**75% + 10.35% = 85.35% **/
}
.pagetop.show {
  opacity: 1;
  pointer-events: auto;
}
.pagetop.show:hover {
  opacity: 0.7;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

/**webp非対応デバイス用class
.no-webp {

}
**/
/**background webp
background: image-set(url(../webp) 1x, url(../@2x.webp) 2x) no-repeat center / cover;
**/
/**IE用css
@media all and (-ms-high-contrast: none) {

}
**/
/* ---- 固定値（必要に応じて変更） ----------------------------------- */
:root {
  --bar-h: 5px;
  --core: 200px;
  /* コア幅 */
  --tail: 780px;
  /* テール長（テール起点→コア中心） */
  --intensity: 0.85;
  /* 光彩（控えめ） */
  --glow: 10px;
  /* 近距離グロウ */
  --aura-glow: 32px;
  /* 遠距離オーラ */
  --aura-opacity: 0.28;
  /* イージング & 所要時間（CSSのみなので固定値） */
  --ease: cubic-bezier(0.445, 0.05, 0.55, 0.95);
  /* ≒ easeInOutSine */
  --dur: 1.4s;
  /* ← ここを調整（幅により速度は相対変化） */
  /* CSSのみで使う開始/終了位置（長さの式はCSS内で計算） */
  /* ここはダミー。実値は keyframes 内で calc() します */
  --start-x: 0px;
  --end-x: 0px;
}

/* ------------------------------------------------------------------ */
/* ホスト：コンテナクエリ有効化で cqw（Container Query Units）を利用 */
.running-light {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: visible;
  /* 光を少し外へにじませる */
  pointer-events: none;
  isolation: isolate;
  /* これで 1cqw = 親コンテナ（= この要素）の幅の1% になる */
  container-type: inline-size;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 100;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.running-light .beam {
  width: calc(var(--tail) + var(--core) * 0.6);
  height: 0.5rem;
  background: -webkit-gradient(linear, left top, right top, from(rgba(var(--color-r), var(--color-g), var(--color-b), 0)), color-stop(25%, rgba(var(--color-r), var(--color-g), var(--color-b), calc(0.09 * var(--intensity)))), color-stop(55%, rgba(var(--color-r), var(--color-g), var(--color-b), calc(0.18 * var(--intensity)))), color-stop(80%, rgba(var(--color-r), var(--color-g), var(--color-b), calc(0.35 * var(--intensity)))), to(rgba(var(--color-r), var(--color-g), var(--color-b), calc(0.9 * var(--intensity)))));
  background: linear-gradient(90deg, rgba(var(--color-r), var(--color-g), var(--color-b), 0) 0%, rgba(var(--color-r), var(--color-g), var(--color-b), calc(0.09 * var(--intensity))) 25%, rgba(var(--color-r), var(--color-g), var(--color-b), calc(0.18 * var(--intensity))) 55%, rgba(var(--color-r), var(--color-g), var(--color-b), calc(0.35 * var(--intensity))) 80%, rgba(var(--color-r), var(--color-g), var(--color-b), calc(0.9 * var(--intensity))) 100%);
  mix-blend-mode: screen;
  -webkit-filter: blur(0px);
          filter: blur(0px);
  -webkit-transform: translateX(200px);
          transform: translateX(200px);
  -webkit-animation: none;
          animation: none;
  /* 既定は停止（active 時にだけ当てる） */
  -webkit-animation-fill-mode: both;
          animation-fill-mode: both;
  background: #2a7b9b;
  background: -webkit-gradient(linear, left top, right top, from(rgb(42, 123, 155)), color-stop(0%, rgba(255, 255, 255, 0)), color-stop(80%, rgb(55, 120, 190)));
  background: linear-gradient(90deg, rgb(42, 123, 155) 0%, rgba(255, 255, 255, 0) 0%, rgb(55, 120, 190) 80%);
  border-top-right-radius: 2rem;
  border-bottom-right-radius: 2rem;
  opacity: 0.8;
  /* 停止中は見せない（お好みで外してOK） */
}
.running-light .beam::before {
  content: "";
  width: 100%;
  background: inherit;
  -webkit-filter: blur(var(--glow));
          filter: blur(var(--glow));
  opacity: 1;
  mix-blend-mode: screen;
  position: absolute;
  inset: 0;
  will-change: transform, filter, opacity;
}
.running-light .beam {
  /* 遠距離オーラ */
}
.running-light .beam::after {
  content: "";
  width: 100%;
  background: inherit;
  -webkit-filter: blur(var(--aura-glow));
          filter: blur(var(--aura-glow));
  opacity: var(--aura-opacity);
  mix-blend-mode: screen;
  margin-top: calc(var(--aura-glow) * -0.35);
  margin-bottom: calc(var(--aura-glow) * -0.35);
  position: absolute;
  inset: 0;
  will-change: transform, filter, opacity;
}

.swiper-slide-active .running-light .beam {
  -webkit-animation: run-once var(--dur) var(--ease) 0s 1 both;
          animation: run-once var(--dur) var(--ease) 0s 1 both;
  visibility: visible;
}

/* キーフレーム
   - 開始位置：完全に左外 => -(tail + core*0.6)
   - 終了位置：完全に右外 => 100cqw + (tail + core*0.6)
   ※ cqw は .running-light の“その時点の幅”に追従するので、スライド幅にも対応
*/
@-webkit-keyframes run-once {
  from {
    -webkit-transform: translateX(calc(-1 * (var(--tail) + var(--core) * 0.6)));
            transform: translateX(calc(-1 * (var(--tail) + var(--core) * 0.6)));
  }
  to {
    -webkit-transform: translateX(calc(100cqw + var(--tail) + var(--core) * 0.6));
            transform: translateX(calc(100cqw + var(--tail) + var(--core) * 0.6));
  }
}
@keyframes run-once {
  from {
    -webkit-transform: translateX(calc(-1 * (var(--tail) + var(--core) * 0.6)));
            transform: translateX(calc(-1 * (var(--tail) + var(--core) * 0.6)));
  }
  to {
    -webkit-transform: translateX(calc(100cqw + var(--tail) + var(--core) * 0.6));
            transform: translateX(calc(100cqw + var(--tail) + var(--core) * 0.6));
  }
}
.wpcf7-response-output {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding: 1rem 2rem;
}

.wc-block-components-button {
  background-color: #f2f238 !important;
  border-radius: 0.5rem;
  -webkit-transition: 0.2s !important;
  transition: 0.2s !important;
}
.wc-block-components-button:hover {
  opacity: 0.7;
}
.wc-block-components-button div {
  font-size: 1.4rem;
  color: #19396d;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
}

.woocommerce-MyAccount-navigation ul {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
  margin-bottom: 2rem;
}
.woocommerce-MyAccount-navigation ul li a {
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.625;
  letter-spacing: 0.05em;
  padding: 2rem;
  border: solid 0.1rem #dddddd;
  display: block;
}

.woocommerce-EditAccountForm fieldset {
  margin-bottom: 2rem;
}

.add_cart_btn {
  text-align: center;
  margin-top: 5rem;
}
.add_cart_btn a {
  width: auto;
}
.add_cart_btn a span {
  color: #262626;
}

.continue-shopping {
  width: 100%;
  margin-top: 1rem;
}
.continue-shopping a {
  width: 100%;
  min-height: 4.8rem;
  font-size: 1.4rem;
  color: #fff;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
  background-color: #19396d;
  border-radius: 0.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.continue-shopping a:hover {
  opacity: 0.7;
}

.ig_lb {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  -webkit-transition: opacity 0.2s, visibility 0.2s;
  transition: opacity 0.2s, visibility 0.2s;
  word-break: break-all;
}
.ig_lb.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.ig_lb .ig_lb_overlay {
  width: 100%;
  height: 100%;
  cursor: pointer;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 1;
}
.ig_lb .ig_lb_x {
  font-size: 4rem;
  color: #fff;
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 1;
}
.ig_lb .ig_lb_card {
  width: 100%;
  max-width: 110rem;
  max-height: calc(100% - 10rem);
  padding: 2rem;
  background-color: #fff;
  border-radius: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
  z-index: 1;
}
.ig_lb .ig_lb_card .ig_lb_prev,
.ig_lb .ig_lb_card .ig_lb_next {
  width: 4rem;
  aspect-ratio: 1/1;
  font-size: 1.6rem;
  color: #19396d;
  border-radius: 50%;
  padding: 0 0.3rem 0.3rem 0;
  background-color: #fff;
  position: absolute;
  top: 50%;
  left: -6rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.ig_lb .ig_lb_card .ig_lb_next {
  padding: 0 0 0.3rem 0.3rem;
  left: auto;
  right: -6rem;
}
.ig_lb .ig_lb_card .ig_lb_media {
  width: 56%;
  background-color: #eef1f7;
}
.ig_lb .ig_lb_card .ig_lb_media .ig_lb_swiper {
  height: 100%;
}
.ig_lb .ig_lb_card .ig_lb_media .ig_lb_swiper.has-dot {
  height: calc(100% - 2.7rem);
}
.ig_lb .ig_lb_card .ig_lb_media .ig_lb_swiper .swiper-wrapper {
  height: 100%;
}
.ig_lb .ig_lb_card .ig_lb_media .ig_lb_swiper .swiper-wrapper .swiper-slide {
  height: 100%;
}
.ig_lb .ig_lb_card .ig_lb_media .ig_lb_swiper .swiper-wrapper .swiper-slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.ig_lb .ig_lb_card .ig_lb_media .ig_lb_swiper .swiper-pagination {
  position: static;
  margin-top: 0.5rem;
}
.ig_lb .ig_lb_card .ig_lb_media .ig_lb_swiper .swiper-button-prev,
.ig_lb .ig_lb_card .ig_lb_media .ig_lb_swiper .swiper-button-next {
  display: none;
}
.ig_lb .ig_lb_card .ig_lb_side {
  width: 44%;
  padding-left: 3rem;
}
.ig_lb .ig_lb_card .ig_lb_side .ig_lb_head {
  width: 100%;
  padding-bottom: 1rem;
  border-bottom: solid 0.1rem #ddd;
}
.ig_lb .ig_lb_card .ig_lb_side .ig_lb_head .ig_lb_logo {
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.ig_lb .ig_lb_card .ig_lb_side .ig_lb_head .ig_lb_logo:hover {
  opacity: 0.7;
}
.ig_lb .ig_lb_card .ig_lb_side .ig_lb_caption {
  height: calc(100% - 6.5rem);
  overflow-y: scroll;
  padding: 2rem 0;
}
.ig_lb .ig_lb_card .ig_lb_side .ig_lb_caption .ig_tags {
  width: 100%;
  margin-top: 1rem;
  font-size: 1.4rem;
}
.ig_lb .ig_lb_card .ig_lb_side .ig_lb_caption a {
  color: #0081ff;
}/*# sourceMappingURL=pc.css.map */