@charset "UTF-8";
.l-header {
  position: fixed;
  left: 0;
  width: 100%;
  padding-left: 3rem;
  margin-left: auto;
  margin-right: auto;
  padding-top: 0;
  height: 6.6rem;
  box-sizing: content-box;
  display: flex;
  align-items: center;
  letter-spacing: normal;
  z-index: 97;
  pointer-events: none;
  line-height: 1.3;
  background: #fff;
}
@media screen and (max-width: 768px), print {
  .l-header {
    padding-top: 0;
    padding-left: 0;
    background: none;
    top: 3rem;
    left: 2rem;
    height: auto;
    width: 12.4rem;
    margin: 0;
  }
}
.l-header__spOverlay {
  position: fixed;
  top: 0;
  left: 0;
  height: 8.5rem;
  width: 100%;
  background: #fff;
  z-index: 97;
  pointer-events: none;
  opacity: 0;
  transition: 0.3s;
}
.l-header__spOverlay.is-active {
  opacity: 1;
}
.is-drawer .l-header__spOverlay {
  opacity: 0;
}

.l-header__logo {
  width: 14rem;
  pointer-events: auto;
  z-index: 98;
}
.l-header__nav {
  position: absolute;
  width: 100%;
  left: 0;
  top: 0;
  padding-right: 14rem;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
.l-header__el {
  transition: 0.3s;
  background: rgba(255, 255, 255, 0);
  z-index: 99;
  cursor: pointer;
}
.l-header__el:hover {
  opacity: 0.7;
}
.l-header__el.is-active {
  background: #fff;
}
.l-header__el.is-hidden, .l-header__el.is-hidden * {
  pointer-events: none;
}
.l-header__elLink {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 1.2rem;
  height: 6.6rem;
  pointer-events: auto;
}
.l-header-megaMenu {
  opacity: 0;
  pointer-events: none;
  position: absolute;
  left: 50%;
  bottom: 1px;
  transform: translate(-50%, 100%) translateX(-2rem);
  width: calc(100% - 10rem);
  height: calc(100vh - 17rem);
  background: #fff;
  display: flex;
  border-radius: 1rem 1rem 0 0;
  padding: 5rem;
  transition: 0.3s opacity;
  letter-spacing: 0.1em;
  z-index: 99;
  overflow-y: auto;
}
.l-header-megaMenu.is-active {
  opacity: 1;
  pointer-events: auto;
}
.l-header-megaMenu__left {
  width: 24rem;
  flex-shrink: 0;
  padding-right: 3rem;
}
.l-header-megaMenu__right {
  position: relative;
  width: 100%;
  height: 100%;
  padding-left: 5rem;
}
.l-header-megaMenu__right::before {
  content: "";
  position: absolute;
  width: 1px;
  height: 66rem;
  background: #001A4C;
  left: 0;
  top: 0;
}
.l-header-megaMenu__tag span {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-height: 3rem;
  min-width: 11rem;
  padding: 0 1rem;
  border-radius: 9999px;
  border: 2px solid #001A4C;
}
.l-header-megaMenu__ttl {
  margin-top: 1rem;
  font-size: 1.8rem;
}
.l-header-megaMenu__link {
  margin-top: 2.4rem;
  font-size: 1.4rem;
}
.l-header-megaMenu .js-tab-area {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
.l-header-megaMenu .js-tab-area li {
  position: relative;
  cursor: pointer;
  font-size: 1.6rem;
  font-weight: bold;
  color: #A3A3A3;
  padding-bottom: 1.4rem;
  width: 100%;
  text-align: center;
  transition: 0.3s all;
}
.l-header-megaMenu .js-tab-area li::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 3px;
  background: #A3A3A3;
  left: 0;
  bottom: 0;
  transition: 0.3s all;
}
.l-header-megaMenu .js-tab-area li.is-active {
  color: #004EA2;
}
.l-header-megaMenu .js-tab-area li.is-active::after {
  background: #004EA2;
}
@media screen and (min-width: 768px), print {
  .l-header-megaMenu .js-tab-area li:hover {
    color: #004EA2;
  }
  .l-header-megaMenu .js-tab-area li:hover::after {
    background: #004EA2;
  }
}
.l-header-megaMenu__top {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(0, max-content));
  -moz-column-gap: 3.2rem;
       column-gap: 3.2rem;
}
.l-header-megaMenu__top > div > h4 {
  font-size: 1.4rem;
  font-weight: bold;
}
.l-header-megaMenu__top > div > ul {
  display: flex;
  flex-direction: column;
  margin-top: 1.6rem;
  row-gap: 1rem;
}
.l-header-megaMenu__middle {
  margin-top: 3.2rem;
  width: 100%;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(0, max-content));
  -moz-column-gap: 3.2rem;
       column-gap: 3.2rem;
}
.l-header-megaMenu__middle > div > h4 {
  font-size: 1.4rem;
  font-weight: bold;
}
.l-header-megaMenu__middle > div > ul {
  display: flex;
  flex-direction: column;
  margin-top: 1.6rem;
  row-gap: 1rem;
}
.l-header-megaMenu__bottom {
  margin-top: 3.2rem;
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  -moz-column-gap: 1.5rem;
       column-gap: 1.5rem;
}
.l-header-megaMenu__bottom > div {
  border-top: 1px solid rgba(0, 26, 76, 0.2);
  padding-top: 1.6rem;
}
.l-header-megaMenu__bottom > div > h4 {
  font-size: 1.4rem;
  font-weight: bold;
}
.l-header-megaMenu__bottom > div > ul {
  display: flex;
  flex-direction: column;
  margin-top: 1.6rem;
  row-gap: 1rem;
}
.l-header-megaMenu .c-h-nav {
  position: relative;
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  padding-left: 1.7rem;
  padding-left: 2rem;
  display: inline-block;
}
.l-header-megaMenu .c-h-nav::before {
  content: "";
  position: absolute;
  left: 0;
  top: 1rem;
  width: 0.9rem;
  height: 1px;
  background: #004EA2;
}
.l-header-megaMenu-ttl {
  font-size: 1.4rem;
  font-weight: bold;
}
.l-header-megaMenu-imgList {
  margin-top: 1.4rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem 1.2rem;
}
.l-header-megaMenu-imgList__link {
  display: inline-flex;
  align-items: center;
  gap: 1.5rem;
}
.l-header-megaMenu-imgList__link p {
  font-size: 1.4rem;
}
.l-header-megaMenu-imgList__img {
  width: 7.2rem;
  height: 6.2rem;
  background: #EDEDED;
  padding: 1rem;
  border-radius: 0.6rem;
  flex-shrink: 0;
}
.l-header-megaMenu-imgList__img img {
  height: 100%;
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.l-header-megaMenu-list {
  margin-top: 2rem;
  display: grid;
  align-items: flex-end;
  gap: 1rem 1.5rem;
  grid-template-columns: repeat(3, 1fr);
}
.l-header-megaMenu-list__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-right: 1rem;
  padding-top: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid #D7D7D7;
  font-size: 1.2rem;
}
.l-header-megaMenu-list__link img, .l-header-megaMenu-list__link svg {
  width: 1.4rem;
}
.l-header-megaMenu__overlay {
  width: calc(100vw + 3rem);
  height: calc(100vh + 3rem);
  position: absolute;
  left: -3rem;
  top: -3rem;
  background: rgba(0, 26, 76, 0.9019607843);
  opacity: 0;
  transition: 0.3s opacity;
  z-index: 98;
  pointer-events: none;
}
.l-header-megaMenu__overlay.is-active {
  opacity: 1;
  pointer-events: auto;
}
.l-header-megaMenu__close {
  position: absolute;
  top: calc(100vh - 10.6rem);
  width: calc(100% - 10rem);
  height: 7rem;
  padding-top: 1.6rem;
  border-radius: 0 0 1rem 1rem;
  left: 50%;
  transform: translateX(-50%) translateX(-2rem);
  z-index: 100;
  background: #fff;
  text-align: center;
  opacity: 0;
  transition: 0.3s;
}
.l-header-megaMenu__close.is-active {
  opacity: 1;
  pointer-events: auto;
}
.l-header-megaMenu__close::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  height: 1px;
  width: calc(100% - 10rem);
  background: #001A4C;
}
.l-header-megaMenu__close > div {
  background: #ECF2FA;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 1.5rem;
  font-size: 1.4rem;
  border-radius: 9999px;
  color: #001A4C;
  gap: 0.7rem;
  cursor: pointer;
}
.l-header-megaMenu__close > div span {
  position: relative;
  width: 1.4rem;
  height: 1.4rem;
  flex-shrink: 0;
}
.l-header-megaMenu__close > div span::before, .l-header-megaMenu__close > div span::after {
  content: "";
  width: 1px;
  height: 100%;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
  background: #001A4C;
}
.l-header-megaMenu__close > div span::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}
.l-header__right {
  position: fixed;
  right: 0;
  top: 0;
  width: 10rem;
  overflow: hidden;
  height: 6.6rem;
  z-index: 98;
}
@media screen and (max-width: 767px), print {
  .l-header__right {
    grid-template-columns: 1fr;
    top: 2rem;
    right: 2rem;
    height: 4.4rem;
  }
}
.l-header__right * {
  position: relative;
  z-index: 1;
}
.is-drawer .l-header__right {
  z-index: 100;
}
@media screen and (min-width: 768px), print {
  .is-drawer .l-header__right {
    background: none;
  }
  .is-drawer .l-header__right a {
    opacity: 0;
  }
}

@media screen and (max-width: 767px), print {
  .l-header__right a {
    display: none;
  }
}
.l-header__rightEl {
  position: relative;
  z-index: 1;
  width: 10rem;
  height: 100%;
}
.l-header__line {
  width: 2px;
  height: 3.6rem;
}
.l-header__link {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  pointer-events: auto;
}
@media screen and (min-width: 768px), print {
  .l-header__link {
    transition: 0.3s;
  }
  .l-header__link .stroke, .l-header__link .fill, .l-header__link p {
    transition: 0.3s;
  }
  .l-header__link:hover {
    background: #004EA2;
  }
  .l-header__link:hover svg .stroke {
    stroke: #fff;
  }
  .l-header__link:hover svg .fill {
    fill: #fff;
  }
  .l-header__link:hover p {
    color: #fff;
  }
}
.l-header__link > div {
  display: flex;
  flex-direction: column;
}
.l-header__link > div img, .l-header__link > div svg {
  height: 2.1rem;
  margin-bottom: 0.3rem;
}
.l-header__link > div p {
  font-size: 1.2rem;
  font-weight: bold;
}
.l-header__drawer {
  position: relative;
  height: 100%;
  padding-bottom: 0.3rem;
  opacity: 0;
}
.l-header__drawer--true {
  position: relative;
  height: 6.6rem;
  opacity: 1;
  background: #004EA2;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  cursor: pointer;
  z-index: 4;
  transition: 0.3s background;
  z-index: 97;
  border-radius: 0.5rem;
}
@media screen and (max-width: 767px), print {
  .l-header__drawer--true {
    height: 4.4rem;
    width: 10rem;
  }
}
.is-drawer .l-header__drawer--true {
  z-index: 99;
}
@media screen and (min-width: 768px), print {
  .is-drawer .l-header__drawer--true {
    background: none;
  }
}

.l-header__drawer--true > div {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media screen and (max-width: 767px), print {
  .l-header__drawer--true > div {
    flex-direction: row-reverse;
    align-items: center;
    gap: 0.5rem;
  }
}
.l-header__drawer--true svg {
  padding-top: 0.2rem;
}
.l-header__drawer--true svg, .l-header__drawer--true svg * {
  transition: 0.3s;
}
.is-drawer .l-header__drawer--true svg {
  transform: translateX(-0.4rem);
}
.is-drawer .l-header__drawer--true svg .drawer-notActive {
  opacity: 0;
}
.is-drawer .l-header__drawer--true svg .drawer-active {
  opacity: 1 !important;
}

.l-header__drawer--true img, .l-header__drawer--true svg {
  width: 3.6rem;
}
@media screen and (min-width: 768px), print {
  .l-header__drawer--true img, .l-header__drawer--true svg {
    height: 2.2rem;
  }
}
@media screen and (max-width: 767px), print {
  .l-header__drawer--true img, .l-header__drawer--true svg {
    margin-top: 0;
  }
}
.l-header__drawer--true p {
  font-size: 1.2rem;
  color: #fff;
  font-weight: bold;
  margin-top: 0.5rem;
  line-height: 1;
}
@media screen and (max-width: 767px), print {
  .l-header__drawer--true p {
    margin-top: 0;
  }
}
.l-header__overlay {
  height: 100vh;
  width: 100vw;
  position: fixed;
  left: 0;
  top: -3rem;
  background: rgba(255, 255, 255, 0.8);
  transition: 0.3s;
  opacity: 0;
  pointer-events: none;
  z-index: 97;
}
.is-drawer .l-header__overlay {
  opacity: 1;
}

.l-header .circle_link {
  margin-top: 4rem;
}
.l-header .circle_link * {
  transition: 0.3s all;
}
.l-header .circle_link li:nth-child(n+2) {
  margin-top: 1rem;
}
.l-header .circle_link li:hover {
  opacity: 0.6;
  pointer-events: painted;
}
.l-header .circle_link li a {
  padding: 0.8rem 0;
  padding-left: 1.4rem;
  min-width: 21.1rem;
  border: 1px solid #001A4C;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  justify-content: start;
  gap: 0.5rem;
}
.l-header .circle_link li a figure {
  width: 1.8rem;
  height: 1.8rem;
  border-radius: 9999px;
  background: #001A4C;
  display: flex;
  justify-content: center;
  align-items: center;
}
.l-header .circle_link li a figure img {
  transform: translateX(0.1rem);
  width: 45%;
  height: 45%;
}
.l-header .circle_link li a p {
  font-size: 1.4rem;
}
.l-header .text-link {
  margin-top: 5rem;
  padding-bottom: 5rem;
}
.l-header .text-link * {
  transition: 0.3s all;
}
.l-header .text-link p {
  width: -moz-fit-content;
  width: fit-content;
}
.l-header .text-link p:hover {
  opacity: 0.6;
}
.l-header .text-link p:nth-child(n+2) {
  margin-top: 0.8rem;
}
.l-header .text-link p a {
  font-size: 1.2rem;
  color: #001A4C;
  font-weight: 500;
  letter-spacing: 0.04em;
  padding-left: 1.2rem;
  line-height: 1.3;
  position: relative;
  padding-left: 1em;
  display: inline-block;
}
.l-header .text-link p a::after {
  position: absolute;
  content: "";
  width: 0.4rem;
  height: 0.4rem;
  border-right: 1px solid #001A4C;
  border-bottom: 1px solid #001A4C;
  transform: translateY(190%) rotate(-45deg);
  top: 0;
  left: 0;
}

.l-drawer {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: #004EA2;
  display: grid;
  align-items: center;
  overflow: auto;
  padding: 12rem 0;
  opacity: 0;
  pointer-events: none;
  transition: 0.3s;
  z-index: 98;
  line-height: 1.3;
}
.l-drawer__bg {
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
}
@media screen and (max-width: 767px), print {
  .l-drawer {
    display: block;
    width: calc(100vw - 2rem);
    left: 1rem;
    height: calc(100svh - 2rem);
    top: 1rem;
    border-radius: 0.5rem;
    padding: 8rem 0 4rem;
  }
}
.is-drawer .l-drawer {
  opacity: 1;
  pointer-events: inherit;
}

.l-drawer * {
  color: #fff;
}
.l-drawer-pc__logo {
  position: absolute;
  left: 0;
  top: 0;
  width: 20rem;
  top: 3.4rem;
  left: 3.4rem;
}
.l-drawer-pc__inner {
  width: 100rem;
  margin-left: auto;
  margin-right: auto;
}
.l-drawer-pc__side {
  display: grid;
  align-items: flex-start;
  grid-template-columns: 22rem 31rem 15.7rem 1fr;
  gap: 2.7rem;
}
.l-drawer-pc__side-inner {
  display: grid;
  gap: 1.6rem;
}
.l-drawer-pc__side-inner--link {
  border-top: 1px solid #FFFFFF;
  gap: 0;
}
.l-drawer-pc__side-inner--arwLink {
  border-top: 1px solid #FFFFFF;
  padding-top: 2rem;
  gap: 2.5rem;
}
.l-drawer-pc-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3019607843);
  padding-block: 1.5rem;
  padding-inline: 1rem;
  font-size: 1.5rem;
  transition: 0.3s;
}
.l-drawer-pc-link.is-opacity {
  opacity: 0.3;
}
.l-drawer-pc-link:hover .l-drawer-pc-link__ic img:last-of-type, .l-drawer-pc-link:hover .l-drawer-pc-link__ic svg:last-of-type {
  opacity: 0;
}
.l-drawer-pc-link__ic {
  width: 2.8rem;
  height: 2.8rem;
  position: relative;
}
.l-drawer-pc-link__ic img, .l-drawer-pc-link__ic svg {
  position: absolute;
  left: 0;
  top: 0;
  transition: 0.3s;
}
.l-drawer-pc-link__left {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.l-drawer-pc-link__kinds {
  background: white;
  font-size: 1.2rem;
  border-radius: 9999px;
  padding: 0.2rem 0.7rem;
  color: #004EA2;
}
.l-drawer-pc-arwLink {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding-inline: 1rem;
}
.l-drawer-pc-arwLink img, .l-drawer-pc-arwLink svg {
  width: 1rem;
}
.l-drawer-pc__bottom {
  display: grid;
  align-items: flex-start;
  grid-template-columns: 22rem 1fr;
  gap: 2.7rem;
  padding-top: 2.5rem;
}
.l-drawer-pc__sns {
  display: flex;
  justify-content: center;
  gap: 1.2rem;
  align-items: center;
}
.l-drawer-pc__sns img, .l-drawer-pc__sns svg {
  width: 3.8rem;
}
.l-drawer-pc__sns img circle, .l-drawer-pc__sns svg circle {
  fill: none;
  stroke: white;
}
.l-drawer-pc__sns img path, .l-drawer-pc__sns svg path {
  fill: white;
}
.l-drawer-pc__txtLink {
  margin-top: 2rem;
  gap: 1rem 2rem;
}
.l-drawer-pc__txtLink a {
  display: inline-block;
  font-size: 1.4rem;
  margin: 0.5rem 1rem;
}
.l-drawer-sp__inner {
  display: grid;
}
.l-drawer-sp-top {
  height: 36rem;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 3rem 4rem;
}
@media screen and (max-width: 767px), print {
  .l-drawer-sp-top {
    height: auto;
    gap: 0;
    margin: 0 -2rem;
  }
}
.l-drawer-sp-top__el {
  order: 2;
}
.l-drawer-sp-top__el.sp-top {
  order: 1;
}
.l-drawer-sp-top__ttl {
  font-size: 1.5rem;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid #fff;
  padding-bottom: 1rem;
  margin-bottom: 1.5rem;
}
.l-drawer-sp-top__ttl span {
  background: #fff;
  color: #00438B;
  font-size: 1.2rem;
  padding: 0 0.5rem;
  border-radius: 9999px;
}
.l-drawer-sp-top__ttl .js-aco-trigger {
  height: 3rem;
  width: 3rem;
  position: absolute;
  right: 2.2rem;
  top: 50%;
  transform: translateY(-50%);
}
.l-drawer-sp-top__ttl .js-aco-trigger::after, .l-drawer-sp-top__ttl .js-aco-trigger::before {
  content: "";
  position: absolute;
  width: 1.8rem;
  height: 1px;
  background: #fff;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.l-drawer-sp-top__ttl .js-aco-trigger::before {
  transform: translate(-50%, -50%) rotate(90deg);
  transition: 0.3s;
}
@media screen and (max-width: 767px), print {
  .l-drawer-sp-top__ttl {
    position: relative;
    flex-direction: row-reverse;
    justify-content: flex-end;
    gap: 1rem;
    padding: 0;
    height: 4.8rem;
    padding-left: 3rem;
    font-size: 1.5rem;
    margin-bottom: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
    transition: 0.3s;
  }
  .l-drawer-sp-top__ttl.is-active {
    background: #001A4C;
  }
  .l-drawer-sp-top__ttl.is-active .js-aco-trigger::before {
    transform: translate(-50%, -50%) rotate(180deg);
  }
}
.l-drawer-sp-top__ttl .arrow {
  width: 1.2rem;
  position: absolute;
  right: 3rem;
  top: 50%;
  transform: translateY(-50%);
}
.l-drawer-sp-top__list {
  display: grid;
  gap: 0.6rem;
  font-weight: 400;
}
@media screen and (max-width: 767px), print {
  .l-drawer-sp-top__list {
    padding: 1.5rem 3rem;
    gap: 0.8rem;
    display: none;
    transition: 0.3s background;
  }
  .l-drawer-sp-top__list.is-active {
    background: #001A4C;
  }
}
.l-drawer-sp-top__list .inner {
  display: flex;
  flex-direction: column;
  row-gap: 1.5rem;
}
.l-drawer-sp-top__list-child {
  display: grid;
  gap: 0.7rem;
  margin-top: 1rem;
}
.l-drawer-sp-top__list-link {
  font-size: 1.3rem;
}
.l-drawer-sp-top__list-link .c-h-nav {
  display: inline-block;
  position: relative;
  font-size: 1.3rem;
  padding-left: 1.7rem;
}
.l-drawer-sp-top__list-link .c-h-nav::before {
  content: "";
  position: absolute;
  left: 0;
  top: 1rem;
  width: 0.9rem;
  height: 1px;
  background: #FFF;
  opacity: 0.6;
}
.l-drawer-sp-top__cList {
  padding-top: 0.7rem;
  line-height: 2;
}
.l-drawer-sp-top__cLink {
  color: rgba(255, 255, 255, 0.6);
  position: relative;
  display: inline-block;
  padding-left: 2em;
}
.l-drawer-sp-top__cLink::before {
  content: "";
  position: absolute;
  width: 0.8rem;
  height: 0.1rem;
  background: #fff;
  top: 50%;
  transform: translateY(-50%);
  left: 0.8rem;
}
.l-drawer-sp-bottom {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2rem;
}
@media screen and (max-width: 767px), print {
  .l-drawer-sp-bottom {
    margin-top: 2rem;
    gap: 0;
  }
}
.l-drawer-sp-bottom > ul {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  -moz-column-gap: 0.8rem;
       column-gap: 0.8rem;
  row-gap: 1.2rem;
}
.l-drawer-sp-bottom > ul > li > a {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  padding-left: 2.4rem;
  height: 3.2rem;
  background: #FFF;
  border-radius: 1.8rem;
}
.l-drawer-sp-bottom > ul > li > a span {
  font-size: 1.2rem;
  font-weight: 500;
  color: #004EA2;
}
.l-drawer-sp-bottom > ul > li > a img, .l-drawer-sp-bottom > ul > li > a svg {
  position: absolute;
  left: 0.8rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1.4rem;
  overflow: inherit;
}
.l-drawer-sp-bottom .s-nav {
  margin-top: 2.4rem;
  border-radius: 0.6rem;
  width: 100%;
  padding: 1.6rem;
  background: rgba(0, 26, 76, 0.2);
}
.l-drawer-sp-bottom .s-nav > ul {
  display: flex;
  flex-wrap: wrap;
  -moz-column-gap: 1.2rem;
       column-gap: 1.2rem;
  row-gap: 0.8rem;
}
.l-drawer-sp-bottom .s-nav > ul li {
  font-size: 1.2rem;
  letter-spacing: 0.04em;
}
.l-drawer-sp-bottom__top {
  background: rgba(0, 26, 76, 0.2);
  padding: 2rem 2rem 2.6rem;
  border-radius: 0.5rem;
  width: 74rem;
}
@media screen and (max-width: 767px), print {
  .l-drawer-sp-bottom__top {
    width: 100%;
    padding: 2rem;
  }
}
.l-drawer-sp-bottom__ttl {
  font-size: 1.5rem;
  padding-bottom: 1.2rem;
  margin-bottom: 1.2rem;
  border-bottom: 1px solid #FFFFFF;
}
.l-drawer-sp-bottom__list {
  display: flex;
  gap: 2rem;
  font-size: 1.3rem;
}
@media screen and (max-width: 767px), print {
  .l-drawer-sp-bottom__list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.8rem;
  }
}
.l-drawer-sp-bottom__bottom {
  width: 74rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.3rem;
}
@media screen and (max-width: 767px), print {
  .l-drawer-sp-bottom__bottom {
    width: 100%;
    margin-top: 2rem;
    grid-template-columns: 1fr;
    padding: 0 4rem;
  }
}
.l-drawer-sp-bottom__btn {
  border-radius: 0.5rem !important;
}
@media screen and (max-width: 767px), print {
  .l-drawer-sp-bottom__btn {
    padding-left: 2rem !important;
  }
}
.l-drawer-sp-bottom__links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem 1.2rem;
  font-size: 1.2rem;
  margin-top: 2rem;
}
.l-drawer-sp-bottom__links a {
  color: rgba(255, 255, 255, 0.6);
}
.l-drawer-sp-bottom__logos {
  display: flex;
  align-items: center;
  width: 100%;
  justify-content: space-between;
  margin-top: 4.3rem;
}
.l-drawer-sp-bottom__logos .logo {
  width: 18rem;
}
.l-drawer-sp-bottom__logos .logo .logo-text {
  fill: #fff;
}
.l-drawer-sp-bottom__logos .sns {
  display: flex;
  gap: 1rem;
}
.l-drawer-sp-bottom__logos .sns a {
  width: 3.6rem;
}
.l-drawer-sp-sns {
  display: flex;
  gap: 1rem;
  margin-top: 2.3rem;
  margin: 0;
  order: 5;
  justify-content: flex-end;
  align-items: center;
  margin-top: 2.4rem;
}
.l-drawer-sp-sns p {
  color: #fff;
}
.l-drawer-sp-sns a, .l-drawer-sp-sns div, .l-drawer-sp-sns label {
  width: 3.1rem;
  height: 3.1rem;
}
.l-drawer-sp-sns a circle, .l-drawer-sp-sns div circle, .l-drawer-sp-sns label circle {
  fill: #004EA2;
  stroke: #fff;
}
.l-drawer-sp-sns a path, .l-drawer-sp-sns div path, .l-drawer-sp-sns label path {
  fill: #fff;
}
.l-drawer-sp-sns a line, .l-drawer-sp-sns div line, .l-drawer-sp-sns label line {
  stroke: #fff;
}

.js-header-change {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 10px;
  pointer-events: none;
}

.l-footer__sitemap {
  background: #004EA2;
  padding-top: 8.2rem;
  padding-bottom: 4rem;
}
@media screen and (max-width: 767px), print {
  .l-footer__sitemap {
    padding-top: 4rem;
    display: grid;
    justify-content: center;
  }
}
.l-footer__sitemapInner {
  display: grid;
  grid-template-columns: 21rem 1fr;
  gap: 8rem;
}
@media screen and (max-width: 767px), print {
  .l-footer__sitemapInner {
    display: contents;
    padding: 0 !important;
  }
}
.l-footer__sitemapLogo {
  width: 18rem;
  margin-left: 1rem;
}
@media screen and (max-width: 767px), print {
  .l-footer__sitemapLogo {
    order: 1;
    margin-left: auto;
    margin-right: auto;
  }
}
.l-footer__sitemapLogo .logo-text {
  fill: #fff;
}
@media screen and (max-width: 767px), print {
  .l-footer__left {
    display: contents;
  }
}
@media screen and (max-width: 767px), print {
  .l-footer__logoWrap {
    display: contents;
  }
}
.l-footer__btnWrap {
  display: grid;
  align-items: flex-start;
  gap: 1rem;
  width: 21rem;
}
@media screen and (max-width: 767px), print {
  .l-footer__btnWrap {
    order: 3;
    margin-top: 2.4rem;
    grid-template-columns: repeat(2, 1fr);
    width: 100%;
    padding-inline: 2.6rem;
    white-space: nowrap;
  }
  .l-footer__btnWrap .c-btnA {
    font-size: 1.1rem !important;
    height: 3rem !important;
    padding-left: 0.4rem !important;
  }
}
.l-footer__sns {
  margin-top: 2.3rem;
  margin-bottom: 2.4rem;
  display: flex;
  gap: 1rem;
}
@media screen and (max-width: 767px), print {
  .l-footer__sns {
    margin: 0;
    order: 5;
    justify-content: flex-end;
    align-items: center;
    padding-right: 2.6rem;
    margin-top: 2.4rem;
  }
  .l-footer__sns p {
    color: #fff;
  }
}
.l-footer__sns a, .l-footer__sns div, .l-footer__sns label {
  width: 3.6rem;
  height: 3.6rem;
}
@media screen and (max-width: 767px), print {
  .l-footer__sns a, .l-footer__sns div, .l-footer__sns label {
    width: 3.1rem;
    height: 3.1rem;
  }
  .l-footer__sns a circle, .l-footer__sns div circle, .l-footer__sns label circle {
    fill: #004EA2;
    stroke: #fff;
  }
  .l-footer__sns a path, .l-footer__sns div path, .l-footer__sns label path {
    fill: #fff;
  }
  .l-footer__sns a line, .l-footer__sns div line, .l-footer__sns label line {
    stroke: #fff;
  }
}
@media screen and (min-width: 768px), print {
  .l-footer-right {
    margin-top: -4rem;
  }
}
@media screen and (max-width: 767px), print {
  .l-footer-right {
    display: contents;
  }
}
.l-footer-right__txt {
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
}
.l-footer-right__txt--bottom {
  margin-top: 3rem;
}
.l-footer-right__close {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  width: 22.2rem;
  height: 3.3rem;
  border: 1px solid #fff;
  position: relative;
  border-radius: 0.4rem;
  overflow: hidden;
}
.l-footer-right__close span {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  cursor: pointer;
  transition: 0.3s;
}
.l-footer-right__close span.js-footer-allOpen {
  background: white;
  color: #004EA2;
}
.l-footer-right__close span.js-footer-allClose {
  color: white;
}
.l-footer-right__close span:hover {
  opacity: 0.7;
}
.l-footer-right__ttl {
  display: grid;
  grid-template-columns: 1fr 2.5rem;
  border-bottom: 1px solid #fff;
  padding-bottom: 0.7rem;
  cursor: pointer;
}
@media screen and (max-width: 767px), print {
  .l-footer-right__ttl {
    padding-inline: 2rem;
    padding-block: 1.5rem;
    padding-top: 1rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.4);
  }
}
.l-footer-right__link {
  display: flex;
  align-items: center;
  gap: 1rem;
  color: #fff;
}
.l-footer-right__link span {
  color: #00438B;
  background: #fff;
  padding-inline: 0.8rem;
  padding-block: 0;
  font-size: 1.2rem;
  border-radius: 9999px;
}
.l-footer-right__plus {
  width: 100%;
  height: 2.5rem;
  position: relative;
}
.l-footer-right__plus span {
  width: 80%;
  height: 1px;
  background: #fff;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
.l-footer-right__plus span:last-of-type {
  transform: translate(-50%, -50%) rotate(90deg);
}
.l-footer-right__inner {
  padding-top: 1rem;
  display: none;
}
@media screen and (max-width: 767px), print {
  .l-footer-right__inner {
    padding-inline: 2rem;
    padding-block: 1rem;
    padding-bottom: 1.4rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.4);
  }
}
.l-footer-right__inner-mass {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem 2rem;
}
@media screen and (max-width: 767px), print {
  .l-footer-right__inner-mass {
    gap: 1.4rem;
    grid-template-columns: 1fr;
  }
}
.l-footer-right__primary, .l-footer-right__primary a {
  color: rgba(255, 255, 255, 0.7019607843);
  font-size: 1.3rem;
}
.l-footer-right__secondary-mass {
  padding-left: 2rem;
  font-size: 1.2rem;
  margin-top: 0.3rem;
  display: grid;
  gap: 0.3rem;
}
@media screen and (max-width: 767px), print {
  .l-footer-right__secondary-mass {
    padding-left: 0;
  }
}
.l-footer-right__secondary a {
  color: #ffffff;
}
@media screen and (max-width: 767px), print {
  .l-footer-right__secondary a {
    padding-left: 2rem;
    position: relative;
  }
  .l-footer-right__secondary a::before {
    content: "";
    position: absolute;
    height: 1px;
    width: 1rem;
    background: rgba(255, 255, 255, 0.4);
    left: 0;
    top: 0.9rem;
  }
}
.l-footer-right__container {
  margin-top: 2rem;
  display: grid;
  gap: 3rem;
}
@media screen and (max-width: 767px), print {
  .l-footer-right__container {
    order: 2;
    margin-top: 3.7rem;
    gap: 0;
  }
}
.l-footer-right__links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 2rem;
  margin-top: 4rem;
  padding-top: 2rem;
  border-top: 1px solid #fff;
}
@media screen and (max-width: 767px), print {
  .l-footer-right__links {
    order: 4;
    margin-top: 2.4rem;
    border-top: 0;
    padding-top: 0;
    width: calc(100% - 5.2rem);
    margin-left: auto;
    margin-right: auto;
    gap: 0.4rem 1rem;
    background: rgba(0, 26, 76, 0.2);
    padding: 1.6rem;
    border-radius: 0.7rem;
  }
}
.l-footer-right__links a {
  font-size: 1.2rem;
  color: #FFFFFF;
}
.l-footer-list__ttl {
  font-size: 1.5rem;
  border-bottom: 1px solid #fff;
  padding-bottom: 1rem;
  margin-bottom: 1rem;
}
@media screen and (max-width: 767px), print {
  .l-footer-list__ttl {
    position: relative;
    margin-bottom: 0;
    border-bottom: none;
    padding: 1.3rem 2rem;
    transition: 0.3s;
  }
  .l-footer-list__ttl.is-active {
    background: #001A4C;
  }
}
.l-footer-list__ttl a {
  display: flex;
  justify-content: space-between;
  align-content: center;
  color: #fff;
}
@media screen and (max-width: 767px), print {
  .l-footer-list__ttl a {
    flex-direction: row-reverse;
    justify-content: flex-end;
    gap: 1.2rem;
  }
}
.l-footer-list__ttl a span {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  color: #00438B;
  padding: 0 0.8rem;
  font-size: 1.2rem;
  border-radius: 9999px;
}
.l-footer-list__ttl .js-aco-trigger {
  height: 3rem;
  width: 3rem;
  position: absolute;
  right: 2rem;
  top: 50%;
  transform: translateY(-50%);
}
.l-footer-list__ttl .js-aco-trigger::after, .l-footer-list__ttl .js-aco-trigger::before {
  content: "";
  position: absolute;
  width: 1.8rem;
  height: 1px;
  background: #fff;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.l-footer-list__ttl .js-aco-trigger::before {
  transform: translate(-50%, -50%) rotate(90deg);
  transition: 0.3s;
}
.l-footer-list__ttl .arrow {
  position: absolute;
  width: 1.7rem;
  right: 2.7rem;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (max-width: 767px), print {
  .l-footer-list__ttl {
    transition: 0.3s;
  }
  .l-footer-list__ttl.is-active .js-aco-trigger::before {
    transform: translate(-50%, -50%) rotate(180deg);
  }
}
.l-footer-list__list {
  line-height: 1.6;
}
@media screen and (max-width: 767px), print {
  .l-footer-list__list {
    transition: 0.3s background;
    display: none;
    padding: 0 2rem 2rem;
    line-height: 1.8;
  }
  .l-footer-list__list.is-active {
    background: #001A4C;
  }
}
.l-footer-list__pLink {
  color: #fff;
  font-size: 1.3rem;
}
.l-footer-list__cList {
  padding-left: 1em;
  line-height: 1.5;
  padding-bottom: 0.5rem;
}
@media screen and (max-width: 767px), print {
  .l-footer-list__cList {
    line-height: 1.6;
    padding-top: 0.5rem;
    padding-left: 0.7rem;
  }
}
.l-footer-list__cLink {
  font-size: 1.2rem;
  color: rgba(255, 255, 255, 0.6);
  display: inline-block;
}
@media screen and (max-width: 767px), print {
  .l-footer-list__cLink {
    display: inline-flex;
    position: relative;
    padding-left: 2rem;
  }
  .l-footer-list__cLink::before {
    content: "";
    width: 1rem;
    height: 1px;
    background: rgba(255, 255, 255, 0.6);
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
  }
}
.l-footer-rightMiddle {
  background: rgba(0, 26, 76, 0.2);
  padding: 2rem 2rem 2.6rem;
  border-radius: 0.5rem;
  width: 100%;
}
@media screen and (max-width: 767px), print {
  .l-footer-rightMiddle {
    margin-top: 2rem;
    width: calc(100% - 4rem);
    margin-left: auto;
    margin-right: auto;
  }
}
.l-footer-rightMiddle * {
  color: #fff;
}
.l-footer-rightMiddle__ttl {
  font-size: 1.5rem;
  padding-bottom: 1.2rem;
  margin-bottom: 1.2rem;
  border-bottom: 1px solid #FFFFFF;
}
@media screen and (max-width: 767px), print {
  .l-footer-rightMiddle__ttl {
    padding-bottom: 1.2rem;
    line-height: 1;
  }
}
.l-footer-rightMiddle__list {
  display: flex;
  gap: 2rem;
  font-size: 1.3rem;
}
@media screen and (max-width: 767px), print {
  .l-footer-rightMiddle__list {
    gap: 0.4rem 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
}
.l-footer-rightMiddle__bottom {
  width: 74rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.3rem;
}
.l-footer-rightMiddle__btn {
  border-radius: 0.5rem !important;
}
.l-footer-rightbottom {
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
  flex-direction: column;
  gap: 0.4rem;
  margin-top: -2rem;
}
@media screen and (max-width: 767px), print {
  .l-footer-rightbottom {
    margin-top: 2rem;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: flex-start;
    padding: 0 2rem;
    gap: 0.4rem 1.5rem;
  }
}
.l-footer-rightbottom__wrap {
  display: flex;
  gap: 1.6rem;
}
@media screen and (max-width: 767px), print {
  .l-footer-rightbottom__wrap {
    display: contents;
  }
}
.l-footer-rightbottom__link {
  font-size: 1.2rem;
  color: rgba(255, 255, 255, 0.6);
}
.l-footer .b-group {
  padding: 5rem 0 7rem;
  background: #004289;
}
@media screen and (max-width: 767px), print {
  .l-footer .b-group {
    padding: 3.5rem 0 2rem;
  }
}
.l-footer .b-group__ttl {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #fff;
  border-bottom: 1px solid #fff;
  padding-bottom: 0.8rem;
  margin-bottom: 2rem;
}
.l-footer .b-group__ttl a {
  display: flex;
  font-size: 1.5rem;
  gap: 0.8rem;
  color: rgba(255, 255, 255, 0.6);
  font-weight: 400;
}
.l-footer .b-group__ttl a img, .l-footer .b-group__ttl a svg {
  width: 1.3rem;
}
@media screen and (min-width: 768px), print {
  .l-footer .b-group-inner {
    display: grid;
    grid-template-columns: 18rem 1fr;
    -moz-column-gap: 7rem;
         column-gap: 7rem;
  }
}
@media screen and (max-width: 767px), print {
  .l-footer .b-group-inner .logo {
    width: 15rem;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 3rem;
  }
}
.l-footer .b-group-inner dl {
  display: grid;
  flex-direction: column;
  row-gap: 0.6rem;
}
@media screen and (max-width: 767px), print {
  .l-footer .b-group-inner dl {
    row-gap: 0.8rem;
    margin-top: 1.5rem;
  }
}
.l-footer .b-group-inner dl div {
  display: grid;
  grid-template-columns: 11rem 1fr;
  -moz-column-gap: 1.5rem;
       column-gap: 1.5rem;
  align-items: center;
}
@media screen and (max-width: 767px), print {
  .l-footer .b-group-inner dl div {
    -moz-column-gap: 1rem;
         column-gap: 1rem;
  }
}
.l-footer .b-group-inner dl div dt {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  padding: 0.5rem 0;
  font-size: 1.2rem;
  font-weight: bold;
  line-height: 1.5;
  color: #fff;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px), print {
  .l-footer .b-group-inner dl div dt {
    font-size: 1.4rem;
    letter-spacing: 0.05em;
  }
}
.l-footer .b-group-inner dl div dt span {
  position: relative;
  z-index: 1;
  text-align: center;
}
.l-footer .b-group-inner dl div dt::after {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  content: "";
  background-color: rgba(255,255,255,0.15);
}
.l-footer .b-group-inner dl div dd ul {
  display: flex;
  flex-wrap: wrap;
  row-gap: 0.5rem;
  -moz-column-gap: 1.5rem;
       column-gap: 1.5rem;
}
@media screen and (max-width: 767px), print {
  .l-footer .b-group-inner dl div dd ul {
    row-gap: 0;
    line-height: 1.1;
  }
}
.l-footer .b-group-inner dl div dd ul li {
  font-size: 1.4rem;
  font-weight: 500;
  color: white;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px), print {
  .l-footer .b-group-inner dl div dd ul li {
    align-items: flex-start;
    font-size: 1.1rem;
    white-space: nowrap;
  }
}
.l-footer .b-group-inner dl div dd ul a {
  display: flex;
  -moz-column-gap: 0.8rem;
       column-gap: 0.8rem;
  align-items: center;
  transition: 0.3s all;
  color: #ffffff;
  font-weight: 400;
}
.l-footer .b-group-inner dl div dd ul a span {
  flex-shrink: 0;
  margin-top: 0.3rem;
}
@media screen and (max-width: 767px), print {
  .l-footer .b-group-inner dl div dd ul a span {
    margin-top: 0.8rem;
  }
}
.l-footer .b-group-inner dl div dd ul a span svg {
  width: 1.2rem;
  height: auto;
  opacity: 0.6;
}
.l-footer__cr {
  text-align: center;
  color: #001A4C;
  padding-top: 1rem;
  padding-bottom: 1.5rem;
  font-size: 1.2rem;
  font-family: "roboto";
}
@media screen and (max-width: 767px), print {
  .l-footer__cr {
    padding-top: 0.2rem;
    padding-bottom: 0.2rem;
    font-weight: bold;
  }
}

.roboto {
  font-family: "Roboto", sans-serif;
}

.c-inner {
  max-width: 100%;
  width: 104rem;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 767px), print {
  .c-inner {
    width: 100%;
    padding: 0 2rem;
  }
}

.c-side-inner {
  width: 87rem;
  margin-left: auto;
  padding-bottom: 15rem;
}
@media screen and (max-width: 767px), print {
  .c-side-inner {
    width: 100%;
    padding-left: 2rem;
    padding-right: 2rem;
    padding-bottom: 7rem;
  }
}

.c-btnA {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: 2px solid #007DA2;
  background: #007DA2;
  height: 4.8rem;
  font-size: 1.3rem;
  padding-left: 2.5rem;
  padding-right: 1rem;
  border-radius: 9999px;
  transition: 0.3s;
  color: #fff;
}
.c-btnA img, .c-btnA svg {
  width: 2.8rem;
}
.c-btnA img *, .c-btnA svg * {
  transition: 0.3s;
}
.c-btnA__drawer {
  justify-content: flex-start;
  background: white;
  border-color: white;
  color: #004EA2;
  padding-left: 1rem;
  gap: 0.5rem;
  height: 3.6rem;
}
.c-btnA__drawer img, .c-btnA__drawer svg {
  width: 2rem;
}
.c-btnA__drawer img circle, .c-btnA__drawer svg circle {
  fill: #004EA2;
}
.c-btnA__drawer:hover {
  background: #004EA2 !important;
  color: #fff !important;
}
.c-btnA__drawer:hover circle {
  fill: #fff !important;
}
.c-btnA__drawer:hover path {
  stroke: #004EA2 !important;
}
.c-btnA__search input {
  border: none;
  font-size: 1.4rem;
  color: #004EA2;
}
.c-btnA__search:hover {
  background: white !important;
  color: #004EA2 !important;
}
.c-btnA__search:hover path {
  stroke: none !important;
}
@media screen and (min-width: 768px), print {
  .c-btnA:hover {
    background: #fff;
    color: #007DA2;
  }
  .c-btnA:hover circle {
    fill: #007DA2;
  }
  .c-btnA:hover line, .c-btnA:hover path {
    stroke: #fff;
  }
}
.c-btnA__skyblue {
  border: 2px solid #007DA2;
  background: #007DA2;
}
@media screen and (min-width: 768px), print {
  .c-btnA__skyblue:hover {
    color: #007DA2;
  }
  .c-btnA__skyblue:hover circle {
    fill: #007DA2;
  }
}
.c-btnA__blue {
  border: 2px solid #004EA2;
  background: #004EA2;
}
@media screen and (min-width: 768px), print {
  .c-btnA__blue:hover {
    color: #004EA2;
  }
  .c-btnA__blue:hover circle {
    fill: #004EA2;
  }
}
.c-btnA__green {
  border: 2px solid #29B187;
  background: #29B187;
}
@media screen and (min-width: 768px), print {
  .c-btnA__green:hover {
    color: #29B187;
  }
  .c-btnA__green:hover circle {
    fill: #29B187;
  }
}

.c-btnB a {
  display: inline-flex;
  gap: 0.6rem;
  cursor: pointer;
}
.c-btnB a img {
  width: 2rem;
}

.c-ttlA {
  line-height: 0.9;
}
.c-ttlA span {
  font-family: "Roboto", sans-serif;
  font-size: 10.2rem;
  font-weight: 300;
  font-style: italic;
  display: inline-flex;
}
@media screen and (max-width: 767px), print {
  .c-ttlA span {
    font-size: 5.2rem;
  }
}
.c-ttlA small {
  font-size: 3.2rem;
  display: inline-flex;
  font-weight: 500;
}
@media screen and (max-width: 767px), print {
  .c-ttlA small {
    font-size: 1.5rem;
  }
}
.c-ttlA__medium {
  line-height: 1.1;
}
.c-ttlA__medium span {
  font-size: 5.3rem;
}
.c-ttlA__medium small {
  font-size: 2.3rem;
}
.c-ttlA__small span {
  font-size: 3.6rem;
}
.c-ttlA__small small {
  font-size: 1.5rem;
}

@media screen and (min-width: 768px), print {
  .c-hover-opacity {
    cursor: pointer;
    transition: 0.3s opacity !important;
  }
  .c-hover-opacity:hover {
    opacity: 0.6;
  }
  .c-hover-scale {
    transition: 0.3s !important;
  }
  .c-hover-scale:hover {
    transform: scale(1.02);
  }
}
.c-sidemenu__inner {
  height: calc(100vh - 7rem);
  position: sticky;
  top: 7rem;
  overflow: auto;
  background: #F4F4F4;
  border-radius: 1rem 0 0 1rem;
  font-size: 1.4rem;
  padding-top: 1.4rem;
  padding-bottom: 2.4rem;
}
.c-sidemenu__nav {
  margin-bottom: 4rem;
}
.c-sidemenu-primary {
  border-bottom: 1px solid #D9D9D9;
}
.c-sidemenu-primary * {
  color: #004EA2 !important;
}
.c-sidemenu-primary__ttl {
  display: inline-grid;
  grid-template-columns: 2.4rem 1fr;
  gap: 0.6rem;
  padding-right: 2rem;
  padding-left: 1.5rem;
  padding-bottom: 1.1rem;
  padding-top: 1rem;
  width: 100%;
  border-bottom: 1px solid #D9D9D9;
}
.c-sidemenu-primary__ttl--bottom {
  border-bottom: none;
  grid-template-columns: 1fr;
}
.c-sidemenu-primary__ttl--bottom span {
  position: relative;
  display: block;
  border-bottom: 2px solid #A3A3A3;
  padding-bottom: 0.5rem;
  font-weight: bold;
  font-size: 1.6rem;
}
.c-sidemenu-primary__ttl--bottom span::after {
  content: "";
  position: absolute;
  width: 6rem;
  height: 2px;
  background: #004EA2;
  left: 0;
  bottom: -2px;
}
.c-sidemenu-secondary {
  padding-top: 1.7rem;
  padding-left: 2rem;
  padding-right: 2rem;
  display: grid;
  gap: 2rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid #D9D9D9;
}
.c-sidemenu-secondary--bottom {
  gap: 0.5rem;
}
.c-sidemenu-tertiary__wrap {
  padding-left: 0.6rem;
}
.c-sidemenu-tertiary__linkWrap {
  margin-top: -0.3rem;
}
.c-sidemenu-tertiary__link {
  display: inline-flex;
  -moz-column-gap: 0.5rem;
       column-gap: 0.5rem;
  font-size: 1.3rem;
  line-height: 1.4;
  margin-top: -0.2rem;
}
.c-sidemenu-tertiary__link::before {
  content: "";
  width: 0.6rem;
  height: 0.8rem;
  -webkit-clip-path: polygon(0 0, 0% 100%, 100% 50%);
          clip-path: polygon(0 0, 0% 100%, 100% 50%);
  flex-shrink: 0;
  background: #004EA2;
  transform: translateY(0.6rem);
}
.c-sidemenu-customer--after {
  margin-top: 4rem;
}
.c-sidemenu-customer--blue {
  margin-top: -1rem;
}
.c-sidemenu-customer__ttl {
  font-size: 1.6rem;
  height: 5.3rem;
  display: flex;
  align-items: center;
  padding-left: 1.2rem;
  -moz-column-gap: 1rem;
       column-gap: 1rem;
  background: #007DA2;
  color: #fff;
  position: relative;
  padding-right: 5rem;
}
.c-sidemenu-customer__ttl::before {
  content: "";
  width: 0.7rem;
  height: 2.6rem;
  flex-shrink: 0;
  background: #fff;
  border-radius: 9999px;
}
.c-sidemenu-customer__ttl-img {
  position: absolute;
  width: 5.5rem;
  bottom: 0;
  right: 0;
}
.c-sidemenu-customer__ttl--after {
  background: #0EA295;
}
.c-sidemenu-customer__txt {
  padding-inline: 1.6rem;
  padding-top: 0.6rem;
  font-size: 1.2rem;
}
.c-sidemenu-customer__btnWrap {
  margin-top: 1.6rem;
  padding-inline: 1.5rem;
  display: grid;
  gap: 1rem;
}
.c-sidemenu-customer__btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  height: 3.6rem;
  padding-inline: 1.4rem;
  background: #007DA2;
  border-radius: 9999px;
  color: #fff;
  transition: 0.3s;
  border: 2px solid #007DA2;
}
.c-sidemenu-customer__btn img, .c-sidemenu-customer__btn svg {
  width: 1.8rem;
  flex-shrink: 0;
}
.c-sidemenu-customer__btn img path, .c-sidemenu-customer__btn svg path {
  transition: 0.3s;
}
.c-sidemenu-customer__btn:hover {
  background: #fff;
  color: #007DA2;
}
.c-sidemenu-customer__btn:hover path:first-of-type {
  fill: #007DA2;
}
.c-sidemenu-customer__btn:hover path:nth-of-type(n + 2) {
  stroke: #fff;
}
.c-sidemenu-customer__btn--after {
  background: #0EA295;
  border-color: #0EA295;
}
.c-sidemenu-customer__btn--after:hover {
  color: #0EA295;
}
.c-sidemenu-customer__btn--after:hover path:first-of-type {
  fill: #0EA295;
}
.c-sidemenu-customer__btn--blue {
  background: #004EA2;
  border-color: #004EA2;
}
.c-sidemenu-customer__btn--blue:hover {
  color: #004EA2;
}
.c-sidemenu-customer__btn--blue:hover path:first-of-type {
  fill: #004EA2;
}

.c-separate {
  display: grid;
  grid-template-columns: 75.834% 1fr;
  gap: 4rem;
  padding-top: 7rem;
  padding-left: calc(50% - 60rem);
}
@media screen and (max-width: 767px), print {
  .c-separate {
    padding-top: 8rem;
    grid-template-columns: 1fr;
  }
}

.c-breadcrumbs {
  display: flex;
  align-items: center;
  white-space: nowrap;
  font-size: 1.3rem;
  gap: 0.6rem;
  font-weight: normal;
}
@media screen and (max-width: 767px), print {
  .c-breadcrumbs {
    overflow: auto;
    width: 36rem;
    gap: 1rem;
  }
}
.c-breadcrumbs hr {
  margin: 0;
  width: 1px;
  height: 1.1rem;
  background: #001A4C;
  border: none;
  transform: rotate(20deg) translateY(0.1rem);
  flex-shrink: 0;
}
.c-breadcrumbs a {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-shrink: 0;
}
.c-breadcrumbs a img {
  width: 1.6rem;
}
.c-breadcrumbs span {
  color: rgba(0, 26, 76, 0.3019607843);
  flex-shrink: 0;
}

.c-mainTtl {
  height: 9.8rem;
  background: #004EA2;
  display: flex;
  align-items: center;
  padding-left: 3.4rem;
  border-radius: 1rem;
  margin-top: 1.3rem;
  margin-bottom: 5rem;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 767px), print {
  .c-mainTtl {
    min-height: 7.7rem;
    margin-inline: -1rem;
    padding-left: 1.4rem;
    margin-bottom: 3rem;
  }
}
.c-mainTtl.farm {
  background: #29B187;
}
.c-mainTtl.saag {
  background: #007DA2;
}
.c-mainTtl h1 {
  color: #fff;
  font-size: 2.4rem;
  font-weight: normal;
  line-height: 1.3;
  padding-bottom: 1rem;
}
@media screen and (max-width: 767px), print {
  .c-mainTtl h1 {
    font-size: 1.8rem;
  }
}
.c-mainTtl h1 small {
  font-size: 1.2rem;
}
@media screen and (max-width: 767px), print {
  .c-mainTtl h1 small {
    font-size: 1rem;
  }
}
.c-mainTtl h1 .sub {
  color: #004EA2;
  font-size: 1.3rem;
  display: inline-block;
  background-color: #fff;
  padding: 0.1rem 1.2rem;
  vertical-align: middle;
  margin-left: 1.4rem;
  margin-top: -0.5rem;
}
.c-mainTtl__bg {
  position: absolute;
  right: 0;
  width: 30.7rem;
}
@media screen and (max-width: 767px), print {
  .c-mainTtl__bg {
    width: auto;
    height: 100%;
  }
}

.c-pagination {
  margin-top: 4.4rem;
  display: flex;
}
@media screen and (max-width: 767px), print {
  .c-pagination {
    justify-content: center;
  }
}
.c-pagination .prev, .c-pagination .next {
  width: 2.8rem;
  height: 2.8rem;
  border: 1px solid #004EA2;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.c-pagination .prev svg, .c-pagination .next svg {
  width: 0.6rem;
}
.c-pagination .prev {
  transform: scaleX(-1);
  margin-right: 3rem;
  margin-left: 0 !important;
}
.c-pagination .next {
  margin-left: 3rem;
  margin-right: 0 !important;
}
.c-pagination .link {
  transition: 0.3s;
}
@media screen and (min-width: 768px), print {
  .c-pagination .link:hover {
    opacity: 0.7;
  }
}
.c-pagination .link, .c-pagination .current {
  margin-inline: 1.2rem;
}
@media screen and (max-width: 767px), print {
  .c-pagination .link, .c-pagination .current {
    margin-inline: 0.8rem;
  }
}
.c-pagination .current {
  width: 2.8rem;
  height: 2.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #004EA2;
  border-radius: 9999px;
  color: white;
}

[id*=anchor] {
  padding-top: 8rem;
  margin-top: -8rem;
  display: block;
  pointer-events: none;
}
@media screen and (max-width: 767px), print {
  [id*=anchor] {
    padding-top: 5rem;
    margin-top: -5rem;
  }
}

.txt-link {
  color: #0070c9;
  text-decoration: underline;
  transition: 0.3s;
}
.txt-link:hover {
  opacity: 0.7;
}

.link-icon::after {
  content: "\f152";
  font-family: "Font Awesome 5 free";
  font-size: 1em;
  font-weight: 900;
  padding-left: 0.5rem;
  opacity: 0.5;
}

.plus {
  position: relative;
  height: 2.5rem;
  width: 2.5rem;
  position: relative;
  cursor: pointer;
}
.plus span {
  width: 80%;
  height: 1px;
  background: #fff;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
.plus span:last-of-type {
  transform: translate(-50%, -50%) rotate(90deg);
  transition: 0.3s;
}
.plus.is-active span:last-of-type {
  transform: translate(-50%, -50%) rotate(180deg);
}

.c-onecolumn {
  padding-top: 7rem;
}
@media screen and (max-width: 767px), print {
  .c-onecolumn {
    padding-top: 8rem;
    padding-bottom: 7rem;
  }
}

/*--------------------------------------
  c-productDetail
--------------------------------------*/
/*--------------------------------------
  TOP
--------------------------------------*/
.c-productDetail__menu {
  margin-bottom: 2.6rem;
  background-color: #ECF2FA;
  display: flex;
  align-items: end;
  justify-content: center;
  gap: 1.6rem;
  padding: 2.5rem 1.5rem 1.5rem;
  width: 100%;
}
.c-productDetail__menu > p {
  font-family: "Roboto", sans-serif;
  font-style: italic;
  font-size: 4.3rem;
  line-height: 1;
  font-weight: 300;
}
.c-productDetail__menu .list {
  display: flex;
  flex-wrap: wrap;
  gap: 2.4rem;
}
.c-productDetail__menu .list li {
  font-size: 1.3rem;
}
.c-productDetail__menu .list li a {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
@media screen and (min-width: 768px), print {
  .c-productDetail__menu .list li a {
    cursor: pointer;
    transition: 0.3s opacity !important;
  }
  .c-productDetail__menu .list li a:hover {
    opacity: 0.8;
  }
}
.c-productDetail__menu .list li img, .c-productDetail__menu .list li svg {
  width: 1.4rem;
  transform: rotate(90deg);
}
@media screen and (max-width: 767px) {
  .c-productDetail__menu {
    padding: 2rem 1.6rem;
    margin-bottom: 3rem;
  }
  .c-productDetail__menu > p {
    display: none;
  }
  .c-productDetail__menu .list {
    gap: 1.2rem 1.5rem;
  }
  .c-productDetail__menu .list li {
    flex-grow: 1;
    border-bottom: 1px solid;
  }
  .c-productDetail__menu .list li a {
    flex-direction: row-reverse;
    justify-content: left;
  }
}
.c-productDetail__box h2.ttl {
  background-color: #004EA2;
  border-radius: 0.6rem;
  padding: 1.4rem 1.6rem;
  font-size: 2.4rem;
  color: #fff;
  display: flex;
  gap: 1.3rem;
  line-height: 1.3;
}
.c-productDetail__box h2.ttl::before {
  content: "";
  border-left: 7px solid #fff;
  border-radius: 5rem;
  height: 2.5rem;
  margin-top: 0.4rem;
}
.c-productDetail__box h3.ttl {
  position: relative;
  color: #004EA2;
  font-size: 2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  border-bottom: 2px solid #A3A3A3;
  padding-bottom: 1.4rem;
}
.c-productDetail__box h3.ttl::before {
  content: "";
  position: absolute;
  bottom: -2px;
  width: 15.2rem;
  height: 2px;
  background: #004EA2;
}
.c-productDetail__box h4.ttl {
  font-size: 1.6rem;
  color: #004EA2;
  display: flex;
  gap: 0.75rem;
}
.c-productDetail__box h4.ttl::before {
  content: "●";
  font-size: 1.1rem;
  margin-top: 5px;
}
.c-productDetail__box .txt {
  font-size: 1.4rem;
}
.c-productDetail__box .txt iframe {
  width: 66%;
  height: 38rem;
  display: block;
  margin: 0 auto;
}
@media screen and (max-width: 767px), print {
  .c-productDetail__box .txt iframe {
    width: 100%;
    height: 20rem;
  }
}
.c-productDetail__box .txt.productTable {
  overflow: auto;
}
.c-productDetail__box .txt.productTable table {
  width: 100%;
  border: 1px solid #A3A3A3;
  border-collapse: collapse;
}
@media screen and (max-width: 767px), print {
  .c-productDetail__box .txt.productTable table {
    white-space: nowrap;
  }
}
.c-productDetail__box .txt.productTable table td, .c-productDetail__box .txt.productTable table th {
  border: 1px solid #A3A3A3;
  padding: 1.2rem 1.6rem;
}
.c-productDetail__box .txt.productTable table thead td, .c-productDetail__box .txt.productTable table th {
  background-color: #004EA2;
  color: #fff;
  font-size: 1.6rem;
}
.c-productDetail__box.frameSet {
  border: 1px solid #001A4C;
  border-radius: 1rem;
  padding: 3rem 4rem;
}
.c-productDetail__box.frameSet .p-product-top__box:first-of-type {
  margin-top: 0;
}
.c-productDetail__box.imgSet {
  display: grid;
  grid-template-columns: 20rem 1fr;
  gap: 3rem;
}
.c-productDetail__box.imgSet .imgArea {
  text-align: center;
}
.c-productDetail__box .p-product-top__boxImg {
  margin: 1.6rem 0;
}
.c-productDetail__box .p-product-top__boxImg img {
  -o-object-fit: contain;
     object-fit: contain;
}
.c-productDetail__box blockquote {
  margin: 0;
  padding: 1rem 2rem;
  background: #f3f3f3;
}
.c-productDetail__box ul {
  padding-left: 1em;
}
.c-productDetail__box ul li {
  list-style: disc;
}
.c-productDetail__box ol {
  padding-left: 1em;
}
.c-productDetail__box ol li {
  list-style: auto;
}
.c-productDetail__boxImg {
  display: flex;
  justify-content: center;
}
.c-productDetail__boxImg img {
  -o-object-fit: contain;
     object-fit: contain;
  width: 100%;
}
@media screen and (min-width: 768px), print {
  .c-productDetail__boxImg a {
    transition: 0.3s;
  }
  .c-productDetail__boxImg a:hover {
    opacity: 0.7;
  }
}
.c-productDetail__btnArea {
  text-align: center;
  display: flex;
  justify-content: center;
}
.c-productDetail__btnArea .c-btnA {
  min-width: 17.7rem;
  margin: 1.8rem auto;
  flex-direction: row-reverse;
  padding-left: 1.4rem;
  padding-right: 1.4rem;
  gap: 0.5rem;
  text-align: left;
  height: 3.6rem;
  font-size: 1.4rem;
}
.c-productDetail__btnArea .c-btnA span {
  width: 100%;
}
.c-productDetail__btnArea .c-btnA img, .c-productDetail__btnArea .c-btnA svg {
  width: 1.8rem;
}
.c-productDetail__btnArea .txt-link {
  display: flex;
  align-items: center;
  justify-self: center;
  gap: 0.5rem;
  text-decoration: none;
  border-bottom: 1px solid #004EA2;
  padding-bottom: 0.4rem;
  font-size: 1.6rem;
  color: #004EA2;
}
.c-productDetail__btnArea .txt-link img, .c-productDetail__btnArea .txt-link svg {
  width: 1.4rem;
}
.c-productDetail__btnArea .txt-link img circle, .c-productDetail__btnArea .txt-link svg circle {
  fill: #004EA2;
}
.c-productDetail__btnArea .txt-link img line, .c-productDetail__btnArea .txt-link img path, .c-productDetail__btnArea .txt-link svg line, .c-productDetail__btnArea .txt-link svg path {
  stroke: #fff;
}
.c-productDetail__col02 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4rem;
}
.c-productDetail__col03 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 3.2rem;
}
.c-productDetail__col04 {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 2.6rem;
}
.c-productDetail__separate {
  display: grid;
  grid-template-columns: 32.7rem 1fr;
  gap: 3.3rem;
}
.c-productDetail__separate .p-product-top__boxImg {
  height: 21.1rem;
}
.c-productDetail__separate .p-product-top__boxImg img {
  -o-object-fit: contain;
     object-fit: contain;
  height: 100%;
  width: 100%;
}
.c-productDetail__separate.separate_right {
  grid-template-columns: 1fr 32.7rem;
}
@media screen and (max-width: 767px) {
  .c-productDetail__box h2.ttl {
    font-size: 1.8rem;
  }
  .c-productDetail__box h2.ttl::before {
    margin-top: 0.2rem;
  }
  .c-productDetail__box h3.ttl {
    font-size: 1.6rem;
  }
  .c-productDetail__box.frameSet {
    padding: 2rem 1.6rem;
  }
  .c-productDetail__box.imgSet {
    grid-template-columns: auto;
  }
  .c-productDetail__box.imgSet .imgArea {
    width: 20rem;
    margin: auto;
    text-align: center;
  }
  .c-productDetail__col02 {
    grid-template-columns: auto;
    gap: 2.6rem;
  }
  .c-productDetail__col03 {
    grid-template-columns: auto;
  }
  .c-productDetail__col04 {
    grid-template-columns: auto;
  }
  .c-productDetail__separate {
    grid-template-columns: auto;
  }
  .c-productDetail__separate.separate_right {
    grid-template-columns: auto;
  }
}

.c-productDetail__mainWrap {
  width: 100%;
  max-width: 120rem;
  margin: auto;
}

.c-productDetail__main {
  background: url(/assets_renew/images/products_gyou/acc/acc_main_bg.png) no-repeat;
  background-size: cover;
  padding: 3rem 4rem 4rem;
  margin-left: 7rem;
  margin-top: 1.7rem;
  margin-bottom: 3.6rem;
  border-bottom-left-radius: 1rem;
  border-top-left-radius: 1rem;
}
.c-productDetail__main .leadtxt {
  font-size: 1.6rem;
  text-align: center;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 9999px;
  color: #fff;
  margin-bottom: 3.7rem;
  padding: 0.5rem 2rem;
}
.c-productDetail__main .mainBox {
  width: 80rem;
  margin: auto;
}
.c-productDetail__main .mainTtop {
  position: relative;
}
.c-productDetail__main .mainImg {
  position: absolute;
  top: 20%;
  right: -2rem;
}
.c-productDetail__main .mainImg .mainImgBox {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}
.c-productDetail__main .mainImg img {
  width: 22rem;
}
.c-productDetail__main .mainImg .complement {
  writing-mode: vertical-rl;
  text-orientation: upright;
  color: #fff;
  font-size: 1.4rem;
}
@media screen and (max-width: 767px), print {
  .c-productDetail__main .mainImg .complement {
    font-size: 1.6rem;
  }
}
.c-productDetail__main .annotation {
  font-size: 1rem;
  position: static;
  text-align: right;
  color: #fff;
  line-height: 1.4;
  margin-top: 1rem;
}
@media screen and (max-width: 767px), print {
  .c-productDetail__main .annotation {
    position: static;
    display: flex;
    justify-content: flex-end;
  }
}
.c-productDetail__main h1.ttl {
  font-size: 4.2rem;
  color: #fff;
  line-height: 1.3;
  margin-bottom: 2rem;
}
.c-productDetail__main h1.ttl .sub {
  display: block;
  font-size: 1.2rem;
  line-height: 1.3;
}
.c-productDetail__main h1.ttl .sub span {
  display: inline-block;
  border: 1px solid #fff;
  padding: 0.3rem 1rem;
}
.c-productDetail__main h1.ttl img {
  height: 4.6rem;
  display: block;
  margin-top: 2rem;
}
@media screen and (max-width: 767px), print {
  .c-productDetail__main h1.ttl img {
    height: 3.6rem;
    margin: 0 auto;
    margin-top: 1.4rem;
  }
}
.c-productDetail__main .price {
  display: flex;
  align-items: center;
  justify-content: end;
  font-size: 1.2rem;
  color: #fff;
  margin-top: 1rem;
}
@media screen and (max-width: 767px), print {
  .c-productDetail__main .price {
    gap: 0.7rem;
  }
  .c-productDetail__main .price .tax {
    opacity: 0.7;
  }
}
.c-productDetail__main .price .num {
  display: flex;
  align-items: center;
}
.c-productDetail__main .price .num em {
  font-size: 2.8rem;
  font-family: "Roboto", sans-serif;
  font-style: normal;
  line-height: 1;
}
.c-productDetail__main .txtBox {
  position: relative;
  background-color: #fff;
  padding: 2.4rem 3rem;
  border-radius: 1rem;
  width: 100%;
  max-width: 44rem;
}
@media screen and (max-width: 767px), print {
  .c-productDetail__main .txtBox {
    margin-top: 1.5rem;
  }
}
.c-productDetail__main .txtBox .txt01 {
  font-size: 1.4rem;
  font-weight: 700;
}
.c-productDetail__main .txtBox .txt02 {
  font-size: 1.3rem;
  margin-top: 0.4rem;
}
.c-productDetail__main .txtBox .btnArea {
  display: flex;
  justify-content: center;
  gap: 0.8rem;
  margin-top: 0.8rem;
}
.c-productDetail__main .txtBox .btnArea a {
  width: 50%;
}
.c-productDetail__main .txtBox .deco {
  position: absolute;
  top: -3.2rem;
  right: -3rem;
  width: 9.265rem;
}
.c-productDetail__mainBtn {
  background-color: #004EA2;
  color: #fff;
  font-size: 1.2rem;
  padding: 0.6rem 1.2rem;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  gap: 0.7rem;
  transition: 0.3s;
  border: 1px solid #004EA2;
}
.c-productDetail__mainBtn img, .c-productDetail__mainBtn svg {
  width: 1.4rem;
  transform: rotate(90deg);
  transition: 0.3s;
}
.c-productDetail__mainBtn circle, .c-productDetail__mainBtn line, .c-productDetail__mainBtn path {
  transition: 0.3s;
}
@media screen and (min-width: 768px), print {
  .c-productDetail__mainBtn:hover {
    background-color: #fff;
    color: #004EA2;
  }
  .c-productDetail__mainBtn:hover circle {
    fill: #004EA2;
  }
  .c-productDetail__mainBtn:hover line, .c-productDetail__mainBtn:hover path {
    stroke: #fff;
  }
}
.c-productDetail__mainBtn.mainBtn_w {
  background-color: #fff;
  border: 1px solid #001A4C;
  color: #001A4C;
}
.c-productDetail__mainBtn.mainBtn_w svg circle {
  fill: #001A4C;
}
.c-productDetail__mainBtn.mainBtn_w svg line, .c-productDetail__mainBtn.mainBtn_w svg path {
  stroke: #fff;
}
@media screen and (min-width: 768px), print {
  .c-productDetail__mainBtn.mainBtn_w:hover {
    background-color: #001A4C;
    color: #fff;
  }
  .c-productDetail__mainBtn.mainBtn_w:hover circle {
    fill: #fff;
  }
  .c-productDetail__mainBtn.mainBtn_w:hover line, .c-productDetail__mainBtn.mainBtn_w:hover path {
    stroke: #001A4C;
  }
}
@media screen and (max-width: 767px) {
  .c-productDetail__main {
    margin-left: 1rem;
    padding: 2rem 1.2rem;
  }
  .c-productDetail__main .leadtxt {
    font-size: 1.2rem;
    margin-bottom: 3rem;
  }
  .c-productDetail__main .mainBox {
    width: 100%;
  }
  .c-productDetail__main .mainBox .mainTtop {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 2rem;
    margin-bottom: 3rem;
  }
  .c-productDetail__main .mainBox .deco {
    top: auto;
    bottom: -3.3rem;
    right: -1rem;
    width: 9rem;
  }
  .c-productDetail__main .mainImg {
    position: static;
  }
  .c-productDetail__main .mainImg .mainImgBox {
    gap: 1rem;
    align-items: flex-start;
  }
  .c-productDetail__main .mainImg .mainImgBox img {
    width: 20rem;
  }
  .c-productDetail__main .mainImg .mainImgBox .complement {
    font-size: 1.2rem;
  }
  .c-productDetail__main .mainImg .mainImgBox .num em {
    font-size: 2rem;
  }
  .c-productDetail__main .mainImg .mainImgBox .tax {
    opacity: 0.6;
    margin-right: 0.6rem;
  }
  .c-productDetail__main .mainImg .spRightWrap {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .c-productDetail__main .ttlArea .ttl {
    font-size: 4.2rem;
    margin-bottom: 1rem;
  }
  .c-productDetail__main .ttlArea .ttl .sub {
    margin-bottom: 0.6rem;
  }
  .c-productDetail__main .ttlArea .ttl-sp {
    display: flex;
    justify-content: center;
    font-size: 2.5rem;
    text-align: center;
  }
  .c-productDetail__main .ttlArea .ttl-sp .price {
    justify-content: center;
  }
  .c-productDetail__main .ttlArea .price .num em {
    font-size: 2rem;
  }
  .c-productDetail__main .txtBox {
    padding: 1.6rem;
  }
  .c-productDetail__main .txtBox .btnArea {
    flex-wrap: wrap;
  }
  .c-productDetail__main .txtBox .btnArea a {
    width: 20rem;
  }
}

/*--------------------------------------
  details
--------------------------------------*/
.c-mainTtl.c-productDetail {
  background: #29B187;
}

/*--------------------------------------
  bottom-parts
--------------------------------------*/
.c-productBottomParts {
  background-color: #004EA2;
  padding: 6.3rem 0 4.7rem;
}
.c-productBottomParts .linkBox {
  width: 100%;
  max-width: 76rem;
  margin: auto;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.8rem 1.2rem;
}
.c-productBottomParts .linkBoxBig .c-btnA {
  height: 12.2rem;
  border-radius: 0.5rem;
}
.c-productBottomParts .linkBoxBig .c-btnA .txt {
  font-size: 2.4rem;
}
.c-productBottomParts .linkBoxBig .c-btnA .txt .sub {
  font-size: 1.4rem;
  display: block;
}
.c-productBottomParts .linkBoxBig .c-btnA img, .c-productBottomParts .linkBoxBig .c-btnA svg {
  width: 4rem;
}
.c-productBottomParts .linkBoxBig .c-btnA.btn-user {
  grid-column: 1/3;
  border-color: #fff;
}
.c-productBottomParts .linkBoxBig .c-btnA.btn-user .txt {
  display: flex;
  align-items: center;
  gap: 3.6rem;
  width: 90%;
}
.c-productBottomParts .linkBoxBig .c-btnA.btn-user .txt .sub {
  width: 70%;
}
.c-productBottomParts .linkBoxSmall {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.3rem;
  margin-top: 1.6rem;
}
.c-productBottomParts .linkBoxSmall .c-btnA {
  border-color: #fff;
  padding-left: 1rem;
  padding-right: 1rem;
  font-size: 1.2rem;
  gap: 0.7rem;
  letter-spacing: 0;
  min-height: 3.2rem;
  height: auto;
  line-height: 1;
  padding-block: 0.4rem;
}
.c-productBottomParts .linkBoxSmall .c-btnA .txt {
  width: 100%;
  text-align: left;
}
.c-productBottomParts .linkBoxSmall .c-btnA img, .c-productBottomParts .linkBoxSmall .c-btnA svg {
  width: 1.4rem;
}
@media screen and (max-width: 767px) {
  .c-productBottomParts {
    padding: 4rem 2rem 2rem;
  }
  .c-productBottomParts .linkBox {
    grid-template-columns: auto;
  }
  .c-productBottomParts .linkBox .c-btnA.btn-user {
    grid-column: auto;
  }
  .c-productBottomParts .linkBox .c-btnA.btn-user .txt {
    flex-wrap: wrap;
    gap: 0.4rem;
  }
  .c-productBottomParts .linkBox .c-btnA.btn-user .txt .sub {
    width: 90%;
    font-size: 1rem;
  }
  .c-productBottomParts .linkBoxSmall {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.c-productBottomParts02 {
  background-color: #ECF2FA;
  padding: 6rem 8rem;
}
.c-productBottomParts02 .linkBox {
  background-color: #fff;
  padding: 6rem 10.5rem;
  border-radius: 6rem;
}
@media screen and (max-width: 767px) {
  .c-productBottomParts02 {
    padding: 4rem 1rem;
  }
  .c-productBottomParts02 .linkBox {
    padding: 2rem 2rem;
    border-radius: 0.5rem;
  }
}

.c-text-editor {
  margin-top: 4rem;
}
@media screen and (max-width: 767px), print {
  .c-text-editor {
    padding-inline: 0;
    margin-top: 2rem;
  }
}
.c-text-editor p {
  margin: 3rem 0;
  font-size: 1.4rem;
}
.c-text-editor h2[id], .c-text-editor h3[id], .c-text-editor h4[id], .c-text-editor h5[id], .c-text-editor h6[id] {
  scroll-margin-top: 10rem;
}
.c-text-editor h2 {
  background-color: #004EA2;
  border-radius: 0.6rem;
  padding: 1.4rem 1.6rem;
  font-size: 2.4rem;
  color: #fff;
  display: flex;
  gap: 1.3rem;
  margin-block: 2.4rem;
  line-height: 1.3;
}
@media screen and (max-width: 767px), print {
  .c-text-editor h2 {
    font-size: 2rem;
  }
}
.c-text-editor h3 {
  font-size: 2rem;
  margin-top: 3rem;
  margin-block: 2rem;
  border-bottom: 1px solid transparent;
  -o-border-image: linear-gradient(to right, #004EA2 20%, #D9D9D9 20%) 1;
     border-image: linear-gradient(to right, #004EA2 20%, #D9D9D9 20%) 1;
  font-weight: normal;
  padding-bottom: 0.7rem;
}
.c-text-editor h4 {
  font-size: 1.6rem;
  color: #004EA2;
  display: flex;
  gap: 0.75rem;
  margin-bottom: 1.2rem;
  margin-top: 3rem;
}
.c-text-editor h4::before {
  content: "●";
  font-size: 1.1rem;
  margin-top: 5px;
}
.c-text-editor ul, .c-text-editor ol {
  padding-left: 1em;
}
.c-text-editor ul li, .c-text-editor ol li {
  list-style: auto;
  margin: 2rem 0;
}
.c-text-editor ul li {
  list-style: disc;
}
.c-text-editor a {
  text-decoration: underline;
  color: #004EA2;
  transition: 0.3s;
  word-break: break-word;
}
.c-text-editor a:hover {
  opacity: 0.7;
}
.c-text-editor table {
  width: 100%;
  border: 1px solid #A3A3A3;
  border-collapse: collapse;
  margin-block: 3rem;
}
.c-text-editor table td, .c-text-editor table th {
  border: 1px solid #A3A3A3;
  padding: 1.2rem 1.6rem;
}
@media screen and (max-width: 767px), print {
  .c-text-editor table td, .c-text-editor table th {
    padding: 0.8rem 0.8rem;
  }
}
.c-text-editor table thead td, .c-text-editor table th {
  background-color: #004EA2;
  color: #fff;
  font-size: 1.6rem;
}
.c-text-editor .marker_lightyellow {
  background: linear-gradient(transparent 70%, #ffff66 70%);
}
.c-text-editor .marker_lightgreen {
  background: linear-gradient(transparent 70%, #90EE90 70%);
}
.c-text-editor .marker_lightskyblue {
  background: linear-gradient(transparent 70%, #87CEFA 70%);
}
.c-text-editor .background_01 {
  background-color: #f5f5f5;
  padding: 10px;
  margin: 0 0 20px 0;
}
.c-text-editor .horizon {
  padding: 30px 0 30px 0;
  border-bottom: 1px solid #ECECEC;
}
.c-text-editor .waku {
  padding: 20px;
  border: 1px solid #CCC;
}
.c-text-editor .indent-1 {
  padding-left: 1em;
  text-indent: -1em;
}
.c-text-editor * {
  max-width: 100%;
}
.c-text-editor .aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.c-marquee {
  box-sizing: border-box;
  display: flex;
  width: 100%;
  overflow: hidden;
  white-space: nowrap;
}
.c-marquee__content {
  display: inline-flex;
  align-items: center;
  animation: marquee 150s linear infinite;
}
.c-marquee__item {
  width: 150rem;
}
@media (--large) {
  .c-marquee__item {
    width: 45rem;
  }
}
.c-marquee-reverse__content {
  animation: marqueeReverse 200s linear infinite;
}
.c-marquee-vertical__content {
  flex-direction: column;
  animation: marqueeVertical 200s linear infinite;
}
.c-marquee-vertical__item {
  display: block;
  width: 22rem;
  padding: 0;
  margin: 1rem 0;
}
.c-marquee-vertical-reverse__content {
  flex-direction: column;
  animation: marqueeVerticalReverse 200s linear infinite;
}

@keyframes marquee {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
@keyframes marqueeReverse {
  0% {
    transform: translateX(-50%);
  }
  100% {
    transform: translateX(0%);
  }
}
@keyframes marqueeVertical {
  0% {
    transform: translateY(-50%);
  }
  100% {
    transform: translateY(0%);
  }
}
@keyframes marqueeVerticalReverse {
  0% {
    transform: translateY(0%);
  }
  100% {
    transform: translateY(-50%);
  }
}
.p-top .s-mv {
  height: 100vh;
  box-sizing: content-box;
  position: relative;
  opacity: 0;
}
@media screen and (min-width: 768px), print {
  .p-top .s-mv {
    min-height: 65rem;
    padding-bottom: 2rem;
  }
}
@media screen and (max-width: 767px), print {
  .p-top .s-mv {
    min-height: 72rem;
    padding-bottom: 6rem;
  }
}
.p-top .s-mv-left {
  width: 53vw;
  position: absolute;
  bottom: 0;
  left: 0;
}
@media screen and (max-width: 767px), print {
  .p-top .s-mv-left {
    width: 36rem;
    left: auto;
    right: 0;
    bottom: 22rem;
  }
}
.p-top .s-mv-left__bg {
  width: 100%;
}
.p-top .s-mv-left__pc {
  position: absolute;
  width: 31vw;
  left: 6.5vw;
  top: -5vw;
}
@media screen and (max-width: 767px), print {
  .p-top .s-mv-left__pc {
    width: 18rem;
    left: 1rem;
    top: 2.5rem;
  }
}
.p-top .s-mv-left__logo {
  position: absolute;
  width: 4.8vw;
  left: 19vw;
  top: 8.6vw;
}
@media screen and (max-width: 767px), print {
  .p-top .s-mv-left__logo {
    width: 6rem;
    left: 6rem;
    top: 7rem;
  }
}
.p-top .s-mv-left__human01 {
  position: absolute;
  width: 5vw;
  right: 4vw;
  top: 7vw;
}
@media screen and (max-width: 767px), print {
  .p-top .s-mv-left__human01 {
    width: 4.2rem;
    top: 7.4rem;
    right: 6.6rem;
  }
}
.p-top .s-mv-left__human02 {
  position: absolute;
  width: 5vw;
  right: 10vw;
  top: 12vw;
}
@media screen and (max-width: 767px), print {
  .p-top .s-mv-left__human02 {
    width: 4.5rem;
    transform: scaleX(-1);
    top: -27rem;
    right: 10rem;
  }
}
.p-top .s-mv-left__human03 {
  position: absolute;
  width: 7vw;
  right: 41vw;
  top: 14vw;
}
@media screen and (max-width: 767px), print {
  .p-top .s-mv-left__human03 {
    width: 6rem;
    right: 5rem;
    transform: scaleX(-1);
    top: -18rem;
  }
}
.p-top .s-mv-left__human04 {
  position: absolute;
  width: 3.8rem;
  top: -7rem;
  left: 2rem;
}
.p-top .s-mv-right {
  position: absolute;
  right: 0;
  top: 0;
  width: 28.5vw;
}
@media screen and (max-width: 767px), print {
  .p-top .s-mv-right {
    left: 0;
    width: 18.6rem;
    padding-top: 1rem;
    background: #ffca74;
    border-radius: 0 0 2rem;
  }
}
.p-top .s-mv-right__pc {
  position: absolute;
  width: 15vw;
  bottom: 0;
  left: 4.5vw;
  z-index: 1;
}
@media screen and (max-width: 767px), print {
  .p-top .s-mv-right__pc {
    width: 6.6rem;
    left: auto;
    right: 3.6rem;
    bottom: 0.1rem;
  }
}
.p-top .s-mv-right__logo {
  position: absolute;
}
.p-top .s-mv-right__logo01 {
  left: 1.6vw;
  bottom: 6.6vw;
  width: 4vw;
}
@media screen and (max-width: 767px), print {
  .p-top .s-mv-right__logo01 {
    width: 2.3rem;
    left: 6rem;
  }
}
.p-top .s-mv-right__logo02 {
  left: 5.3vw;
  bottom: 8.8vw;
  width: 4vw;
}
@media screen and (max-width: 767px), print {
  .p-top .s-mv-right__logo02 {
    width: 2.3rem;
    left: 8rem;
    bottom: 3.9rem;
  }
}
.p-top .s-mv-right__logo03 {
  left: 19vw;
  bottom: 5.2vw;
  width: 4vw;
}
@media screen and (max-width: 767px), print {
  .p-top .s-mv-right__logo03 {
    width: 2.3rem;
    left: 14.9rem;
    bottom: 2.7rem;
  }
}
.p-top .s-mv-right__logo04 {
  left: 22vw;
  bottom: 3.8vw;
  width: 4vw;
}
@media screen and (max-width: 767px), print {
  .p-top .s-mv-right__logo04 {
    width: 2.3rem;
    left: 15.6rem;
    bottom: 0.7rem;
  }
}
.p-top .s-mv-logo {
  position: absolute;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: absolute;
  gap: 1.5vw;
  right: 14vw;
  top: 30vw;
}
@media screen and (max-width: 767px), print {
  .p-top .s-mv-logo {
    left: 2rem;
    top: 17rem;
    align-items: flex-start;
    gap: 1.5rem;
  }
}
.p-top .s-mv-logo img, .p-top .s-mv-logo svg {
  width: 18vw;
}
@media screen and (max-width: 767px), print {
  .p-top .s-mv-logo img, .p-top .s-mv-logo svg {
    width: 15.7rem;
    height: auto;
  }
}
.p-top .s-mv-logo p {
  font-size: 1.5vw;
  color: #001A4C;
}
@media screen and (max-width: 767px), print {
  .p-top .s-mv-logo p {
    font-size: 1.4rem;
  }
}
.p-top .s-mvBnr {
  padding: 2.4rem 0 2.4rem 1.4rem;
  width: calc(50% + 53rem);
  margin: 0 0 0 auto;
  border-radius: 1rem 0 0 1rem;
  margin-top: -18rem;
  background: #fff;
  position: relative;
  z-index: 1;
  opacity: 0;
}
@media screen and (max-width: 767px), print {
  .p-top .s-mvBnr {
    margin-top: -20rem;
    width: 100%;
  }
}
.p-top .s-mvBnr .swiper-slide {
  padding: 0 0.5rem;
}
.p-top .s-mvBnr .js-mvBnrSwiper-next {
  cursor: pointer;
  position: absolute;
  z-index: 1;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 3.3rem;
}
.p-top .s-service {
  padding-top: 7rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service {
    padding-top: 9rem;
    overflow: hidden;
  }
}
.p-top .s-service-top {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 6rem;
  padding-left: 3rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service-top {
    display: block;
    padding: 0 0.5rem;
  }
}
.p-top .s-service-top__txt {
  width: 45rem;
  padding-top: 6rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service-top__txt {
    padding-top: 2.6rem;
    width: auto;
  }
}
.p-top .s-service-top__imgTxt {
  position: absolute;
  z-index: -1;
  right: 0;
  bottom: -2rem;
  width: 92rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service-top__imgTxt {
    width: 130%;
    max-width: inherit;
    bottom: auto;
    top: 0;
    left: 50%;
    transform: translateX(-50%) translateX(2rem);
  }
}
.p-top .s-service__box {
  margin-top: 6rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service__box {
    margin-top: 4rem;
  }
}
.p-top .s-service__box .b-product:nth-of-type(n + 2) {
  margin-top: 12rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service__box .b-product:nth-of-type(n + 2) {
    margin-top: 8rem;
  }
}
.p-top .s-service__box .b-product__top {
  background: #004EA2;
  color: #fff;
  height: 28rem;
  border-radius: 1rem;
  padding-top: 6rem;
  position: relative;
  width: 112rem;
  margin-left: -4rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service__box .b-product__top {
    width: 100%;
    margin: 0 -2rem;
    width: calc(100% + 4rem);
    border-radius: 0;
    padding: 4rem 3rem 0 3rem;
  }
}
.p-top .s-service__box .b-product__ttl {
  display: flex;
  justify-content: center;
  font-weight: 400;
  gap: 1rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service__box .b-product__ttl {
    justify-content: flex-start;
    gap: 2rem;
    padding-left: 1.5rem;
  }
}
.p-top .s-service__box .b-product__ttl img {
  width: 4.3rem;
}
.p-top .s-service__box .b-product__ttl p {
  font-size: 3.2rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service__box .b-product__ttl p {
    display: block;
    line-height: 1.4;
    font-size: 2rem;
  }
}
.p-top .s-service__box .b-product__ttl p small {
  font-size: 2.4rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service__box .b-product__ttl p small {
    font-size: 1.6rem;
  }
}
.p-top .s-service__box .b-product__list {
  display: flex;
  justify-content: center;
  gap: 1rem;
  margin-top: 1rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service__box .b-product__list {
    margin-top: 1.6rem;
    gap: 0.3rem;
    justify-content: flex-start;
  }
}
.p-top .s-service__box .b-product__el {
  height: 3.2rem;
  padding: 0 1.3rem;
  background: rgba(0, 26, 76, 0.2);
  border-radius: 9999px;
  font-size: 1.4rem;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service__box .b-product__el {
    font-size: 1.2rem;
  }
}
.p-top .s-service__box .b-product__allLink {
  position: absolute;
  right: 9.3rem;
  bottom: 11.7rem;
  display: flex;
  gap: 1.4rem;
  align-items: center;
  white-space: nowrap;
  color: #fff;
  font-weight: 400;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service__box .b-product__allLink {
    right: 0;
    height: 7.6rem;
    bottom: auto;
    top: 3rem;
    text-indent: -9999px;
    width: 100%;
    justify-content: flex-end;
    padding-right: 3rem;
  }
}
.p-top .s-service__box .b-product__allLink img, .p-top .s-service__box .b-product__allLink svg {
  width: 6.6rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service__box .b-product__allLink img, .p-top .s-service__box .b-product__allLink svg {
    width: 3.8rem;
  }
}
.p-top .s-service__box .b-product .js-productSwiper .swiper-wrapper.is-center {
  justify-content: center;
}
.p-top .s-service__box .b-product__next {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%) translateX(50%);
  width: 4.8rem;
  height: 4.8rem;
  z-index: 1;
  transition: 0.3s;
  cursor: pointer;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service__box .b-product__next {
    width: 4.3rem;
    height: 4.3rem;
    right: 2rem;
  }
}
.p-top .s-service__box .b-product__next circle {
  fill: #001A4C;
}
.p-top .s-service__box .b-product__next line, .p-top .s-service__box .b-product__next path {
  stroke: #fff;
}
.p-top .s-service__box .b-product__next.swiper-button-disabled {
  opacity: 0.4;
  pointer-events: none;
}
.p-top .s-service__box .b-product__bar {
  position: relative;
  height: 0.5rem;
  width: 100%;
  background: #EDEDED;
  border-radius: 9999px;
  width: calc(100% - 2rem);
  margin: 0.8rem auto 0;
  overflow: hidden;
}
.p-top .s-service__box .b-product__bar span {
  width: 0;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background: #004EA2;
  transition: 0.3s;
}
.p-top .s-service__box .b-product__pList {
  padding: 1rem 0;
}
.p-top .s-service__box .b-product__pListFrame {
  position: relative;
  margin-top: -8rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service__box .b-product__pListFrame {
    margin-top: -11rem;
  }
}
@media screen and (max-width: 767px), print {
  .p-top .s-service__box .b-product__pListWrap {
    margin: 0 -2rem;
    padding-left: 2rem;
    padding-right: 5rem;
  }
}
.p-top .s-service__box .b-product__pEl {
  padding: 0 0.5rem;
}
.p-top .s-service__box .b-product__pBox {
  background: #fff;
  border-radius: 0.5rem;
  border: 1px solid #004EA2;
  padding: 1.5rem 1.5rem 2rem;
  transition: 0.3s;
}
@media screen and (min-width: 768px), print {
  .p-top .s-service__box .b-product__pBox:hover {
    transform: scale(1.05);
  }
}
.p-top .s-service__box .b-product__pImg {
  position: relative;
  background: #EDEDED;
  border-radius: 0.5rem;
}
.p-top .s-service__box .b-product__pCaption {
  position: absolute;
  right: 0;
  top: -0.8rem;
  transform: translateX(50%);
  writing-mode: vertical-rl;
  text-orientation: upright;
  border-radius: 0.2rem;
  background: #004EA2;
  color: #fff;
  border-radius: 0.2rem;
  width: 1.8rem;
  padding: 0.5rem 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  white-space: nowrap;
}
.p-top .s-service__box .b-product__pCaption--small {
  font-size: 1.1rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service__box .b-product__pCaption--small {
    font-size: 1rem;
  }
}
.p-top .s-service__box .b-product__pCaption--verySmall {
  font-size: 1rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service__box .b-product__pCaption--verySmall {
    font-size: 0.9rem;
  }
}
.p-top .s-service__box .b-product__pTtl {
  margin-top: 1.4rem;
  font-weight: 400;
  white-space: nowrap;
  text-align: center;
}
.p-top .s-service__box .b-product__pTtl--small {
  font-size: 1.5rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service__box .b-product__pTtl--small {
    font-size: 1.4rem;
  }
}
.p-top .s-service__box .b-product__pDetail {
  margin-top: 1rem;
  padding-left: 1rem;
  padding-right: 0.4rem;
  height: 3.2rem;
  width: 12rem;
  margin-left: auto;
  margin-right: auto;
  background: #fff;
  border-color: #001A4C;
  color: #001A4C;
  transition: 0.3s;
  border-width: 1px;
}
.p-top .s-service__box .b-product__pDetail img, .p-top .s-service__box .b-product__pDetail svg {
  width: 2rem;
}
@media screen and (min-width: 768px), print {
  .p-top .s-service__box .b-product__pDetail:hover {
    background: #001A4C;
    color: #fff;
  }
  .p-top .s-service__box .b-product__pDetail:hover circle {
    fill: #fff;
  }
  .p-top .s-service__box .b-product__pDetail:hover path {
    stroke: #001A4C;
  }
}
.p-top .s-service__box .b-product__separate {
  display: grid;
  grid-template-columns: repeat(3, 26rem);
  gap: 1.6rem;
  justify-content: center;
  margin-top: 4rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-service__box .b-product__separate {
    grid-template-columns: 1fr;
    width: 26rem;
    margin-left: auto;
    margin-right: auto;
    gap: 1.2rem;
    margin-top: 2.4rem;
  }
}
.p-top .s-service__box .b-product--local .b-product__top, .p-top .s-service__box .b-product--local .b-product__pCaption {
  background: #29B187;
}
.p-top .s-service__box .b-product--local .b-product__pBox {
  border-color: #29B187;
}
.p-top .s-service__box .b-product--accounting .b-product__top, .p-top .s-service__box .b-product--accounting .b-product__pCaption {
  background: #007DA2;
}
.p-top .s-service__box .b-product--accounting .b-product__pBox {
  border-color: #007DA2;
}
.p-top .b-bg-skyblue {
  background: #ECF2FA;
  padding-top: 6rem;
  padding-bottom: 6rem;
  margin-top: 12rem;
}
@media screen and (max-width: 767px), print {
  .p-top .b-bg-skyblue {
    margin-top: 8rem;
    padding-bottom: 4rem;
  }
}
.p-top .b-bg-skyblue__btn {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 767px), print {
  .p-top .b-bg-skyblue__btn {
    flex-direction: column;
    gap: 1.2rem;
  }
}
.p-top .b-bg-skyblue__btn .c-btnA {
  position: relative;
  width: 50rem;
  height: 8rem;
  justify-content: center;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px), print {
  .p-top .b-bg-skyblue__btn .c-btnA {
    width: 100%;
    justify-content: space-between;
    height: 6rem;
  }
}
.p-top .b-bg-skyblue__btn .c-btnA img, .p-top .b-bg-skyblue__btn .c-btnA svg {
  position: absolute;
  right: 3rem;
  top: 50%;
  transform: translateY(-50%);
  width: 4.1rem;
}
@media screen and (max-width: 767px), print {
  .p-top .b-bg-skyblue__btn .c-btnA img, .p-top .b-bg-skyblue__btn .c-btnA svg {
    right: 1rem;
    width: 3.5rem;
  }
}
.p-top .b-bg-skyblue__separate {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4rem;
}
@media screen and (max-width: 767px), print {
  .p-top .b-bg-skyblue__separate {
    display: block;
  }
}
.p-top .b-bg-skyblue .s-articles {
  position: relative;
  background: #FFFFFF;
  padding: 4rem 4rem 4rem 0;
  border-radius: 1rem;
  overflow: hidden;
}
@media screen and (max-width: 767px), print {
  .p-top .b-bg-skyblue .s-articles {
    padding: 3rem 2rem 4rem 0;
  }
  .p-top .b-bg-skyblue .s-articles:nth-of-type(n + 2) {
    margin-top: 1.2rem;
  }
}
.p-top .b-bg-skyblue .s-articles__ttl {
  padding-left: 4rem;
}
@media screen and (max-width: 767px), print {
  .p-top .b-bg-skyblue .s-articles__ttl {
    padding-left: 3rem !important;
    line-height: 1;
  }
}
.p-top .b-bg-skyblue .s-articles__ttl span {
  position: relative;
}
@media screen and (max-width: 767px), print {
  .p-top .b-bg-skyblue .s-articles__ttl span {
    font-size: 3.6rem;
  }
}
.p-top .b-bg-skyblue .s-articles__ttl span::after {
  content: "";
  position: absolute;
  width: 3.3rem;
  height: 3.3rem;
  top: 50%;
  transform: translateY(-50%) translateX(-50%);
  background: #1D4F91;
  border-radius: 9999px;
  left: -4rem;
}
@media screen and (max-width: 767px), print {
  .p-top .b-bg-skyblue .s-articles__ttl span::after {
    left: -3rem;
    width: 4.4rem;
    height: 4.4rem;
  }
}
@media screen and (max-width: 767px), print {
  .p-top .b-bg-skyblue .s-articles__ttl small {
    font-size: 1.5rem;
  }
}
.p-top .b-bg-skyblue .s-articles__list {
  padding-left: 4rem;
  margin-top: 0.5rem;
}
@media screen and (max-width: 767px), print {
  .p-top .b-bg-skyblue .s-articles__list {
    padding-left: 2rem;
  }
}
.p-top .b-bg-skyblue .s-articles__el {
  display: block;
  padding-top: 1.8rem;
  padding-bottom: 1.8rem;
  border-bottom: 1px solid rgba(0, 26, 76, 0.6);
}
.p-top .b-bg-skyblue .s-articles__date {
  font-size: 1.6rem;
  color: rgba(0, 26, 76, 0.6);
}
.p-top .b-bg-skyblue .s-articles__aTTl {
  font-size: 1.8rem;
  margin-top: 0.3rem;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  font-weight: 500;
}
.p-top .b-bg-skyblue .s-articles__allBtn {
  display: flex;
  justify-content: flex-end;
  margin-top: 1.4rem;
  font-size: 1.4rem;
}
@media screen and (max-width: 767px), print {
  .p-top .b-bg-skyblue .s-articles__allBtn {
    justify-content: center;
    margin-top: 2.4rem;
  }
}
.p-top .b-bg-skyblue .s-articles__allBtn img, .p-top .b-bg-skyblue .s-articles__allBtn svg {
  width: 2rem;
}
.p-top .b-bg-skyblue .s-pickup {
  display: flex;
  flex-direction: column;
  grid-column: 1/3;
  gap: 3rem;
}
.p-top .b-bg-skyblue .s-pickup__ttl span {
  position: relative;
}
.p-top .b-bg-skyblue .s-pickup__ttl span::after {
  width: 4.4rem;
  height: 4.4rem;
}
@media screen and (min-width: 768px), print {
  .p-top .b-bg-skyblue .s-pickup__right {
    width: 100%;
    padding-left: 4rem;
  }
}
.p-top .b-bg-skyblue .s-pickup-article {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3rem 5rem;
  width: 100%;
}
.p-top .b-bg-skyblue .s-pickup-article:nth-of-type(n + 2) {
  padding-top: 3rem;
}
@media screen and (max-width: 767px), print {
  .p-top .b-bg-skyblue .s-pickup-article {
    padding-left: 2rem;
    display: block;
  }
}
.p-top .b-bg-skyblue .s-pickup-article__el {
  display: flex;
  gap: 1.4rem;
}
@media screen and (max-width: 767px), print {
  .p-top .b-bg-skyblue .s-pickup-article__el {
    flex-direction: column;
    gap: 0.5rem;
    position: relative;
    margin-bottom: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(0, 26, 76, 0.6);
  }
}
@media screen and (min-width: 768px), print {
  .p-top .b-bg-skyblue .s-pickup-article__el:hover .s-pickup-article__img img {
    transform: scale(1.05);
  }
}
.p-top .b-bg-skyblue .s-pickup-article__img {
  width: 18rem;
  height: 13.5rem;
  border-radius: 0.5rem;
  overflow: hidden;
  flex-shrink: 0;
}
@media screen and (max-width: 767px), print {
  .p-top .b-bg-skyblue .s-pickup-article__img {
    width: 7rem;
    height: 5.2rem;
  }
}
.p-top .b-bg-skyblue .s-pickup-article__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: 0.3s;
}
.p-top .b-bg-skyblue .s-pickup-article__ttl {
  font-size: 1.8rem;
  font-weight: 500;
  border-bottom: 1px solid #001A4C;
  padding-bottom: 0.7rem;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-height: 1.5;
}
@media screen and (max-width: 767px), print {
  .p-top .b-bg-skyblue .s-pickup-article__ttl {
    border: none;
    position: absolute;
    top: 0.3rem;
    right: 0;
    width: 24rem;
    font-size: 1.5rem;
    padding-bottom: 0;
  }
}
.p-top .b-bg-skyblue .s-pickup-article__txt {
  margin-top: 0.8rem;
  color: rgba(0, 26, 76, 0.6);
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  font-size: 1.5rem;
}
@media screen and (max-width: 767px), print {
  .p-top .b-bg-skyblue .s-pickup-article__txt {
    margin-top: 0;
  }
}
.p-top .b-bg-skyblue .s-pickup-articleWrap {
  display: none;
}
@media screen and (min-width: 768px), print {
  .p-top .b-bg-skyblue .s-pickup-articleWrap {
    padding-top: 3rem;
  }
}
.p-top .b-bg-skyblue .s-pickup__allBtn {
  display: flex;
  justify-content: flex-end;
  margin-top: 1.4rem;
  font-size: 1.4rem;
}
.p-top .b-bg-skyblue .s-pickup__allBtn img, .p-top .b-bg-skyblue .s-pickup__allBtn svg {
  width: 2rem;
  transform: rotate(90deg);
}
.p-top .b-bg-skyblue .s-pickup__allBtn .is-active img, .p-top .b-bg-skyblue .s-pickup__allBtn .is-active svg {
  transform: rotate(-90deg);
}
.p-top .s-bnrArea {
  padding: 6rem 0;
}
@media screen and (max-width: 767px), print {
  .p-top .s-bnrArea {
    padding: 4rem 0 8rem;
  }
}
.p-top .s-bnrArea__inner {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-bnrArea__inner {
    display: block;
  }
}
.p-top .s-bnrArea-common {
  position: relative;
  border-radius: 1rem;
  overflow: hidden;
}
@media screen and (max-width: 767px), print {
  .p-top .s-bnrArea-common {
    display: block;
    height: 17.4rem;
  }
  .p-top .s-bnrArea-common:nth-of-type(n + 2) {
    margin-top: 1.2rem;
  }
}
.p-top .s-bnrArea-common__bg {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-top .s-bnrArea-common__ttl {
  position: absolute;
  left: 3.2rem;
  top: 3.5rem;
  z-index: 1;
  color: #fff;
}
@media screen and (max-width: 767px), print {
  .p-top .s-bnrArea-common__ttl {
    left: 2rem;
    top: 3rem;
    line-height: 1;
  }
}
.p-top .s-bnrArea-common__arrow {
  position: absolute;
  right: 2rem;
  bottom: 2rem;
  z-index: 1;
  width: 5.4rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-bnrArea-common__arrow {
    right: 1.5rem;
    bottom: 1.5rem;
    width: 3.9rem;
  }
}
@media screen and (min-width: 768px), print {
  .p-top .s-bnrArea-media, .p-top .s-bnrArea-cm {
    height: 24rem;
  }
}
.p-top .s-bnrArea-recruit {
  grid-column: 1/3;
}
@media screen and (min-width: 768px), print {
  .p-top .s-bnrArea-recruit {
    height: 37.6rem;
  }
  .p-top .s-bnrArea-recruit__ttl {
    top: 8.4rem;
    left: 6rem;
    line-height: 1.3;
  }
  .p-top .s-bnrArea-recruit__ttl span {
    font-size: 5.3rem;
  }
  .p-top .s-bnrArea-recruit__ttl small {
    font-size: 2.3rem;
  }
  .p-top .s-bnrArea-recruit__txtWrap {
    position: absolute;
    z-index: 1;
    top: 10rem;
    right: 7.5rem;
    width: 45rem;
  }
  .p-top .s-bnrArea-recruit__txtWrap * {
    color: #fff;
  }
  .p-top .s-bnrArea-recruit__subTtl {
    font-size: 3.6rem;
    font-weight: 500;
  }
  .p-top .s-bnrArea-recruit__txt {
    margin-top: 0.5rem;
    width: 40rem;
  }
  .p-top .s-bnrArea-recruit__arrow {
    width: 6.6rem;
    right: 3rem;
    bottom: 3rem;
  }
}
.p-top .s-bnrArea-sdgs {
  border: 0.3rem solid #004EA2;
  grid-column: 1/3;
  height: 28rem;
}
@media screen and (max-width: 767px), print {
  .p-top .s-bnrArea-sdgs {
    height: 15.8rem;
  }
}
@media screen and (min-width: 768px), print {
  .p-top .s-bnrArea-sdgs__arrow {
    width: 6.6rem;
    right: 3rem;
    bottom: 3rem;
  }
}
.p-top .s-bnrArea-contact {
  height: 22.7rem;
  grid-column: 1/3;
  background: #004EA2;
}
@media screen and (max-width: 767px), print {
  .p-top .s-bnrArea-contact {
    height: 15.8rem;
  }
}
@media screen and (min-width: 768px), print {
  .p-top .s-bnrArea-contact__ttl {
    top: 5.7rem;
    left: 6rem;
    line-height: 1.3;
  }
  .p-top .s-bnrArea-contact__ttl span {
    font-size: 5.3rem;
  }
  .p-top .s-bnrArea-contact__ttl small {
    font-size: 2.3rem;
  }
  .p-top .s-bnrArea-contact__arrow {
    width: 6.6rem;
    right: 3rem;
    bottom: 3rem;
  }
}
.p-top .s-fixedArea {
  position: relative;
}
.p-top .s-fixedArea__container {
  position: absolute;
  width: 4.4rem;
  height: 100%;
  right: 0;
  z-index: 95;
  pointer-events: none;
}
.p-top .s-fixedArea__btnArea {
  position: sticky;
  right: 0;
  top: calc(100vh - 53.7rem);
  width: 4.4rem;
  display: grid;
  gap: 0.2rem;
}
.p-top .s-fixedArea__btn {
  width: 100%;
  height: 14.7rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  pointer-events: auto;
  padding-top: 1.2rem;
  padding-bottom: 1.2rem;
  background: #004EA2;
  border-radius: 0.5rem 0 0 0.5rem;
  border: 1px solid #fff;
  transition: 0.3s;
}
.p-top .s-fixedArea__btn:hover {
  background: #fff;
  border: 1px solid #004EA2;
}
.p-top .s-fixedArea__btn:hover span {
  color: #004EA2;
}
.p-top .s-fixedArea__btn:hover circle {
  fill: #004EA2;
}
.p-top .s-fixedArea__btn:hover path {
  stroke: #fff;
}
.p-top .s-fixedArea__btn--zoom, .p-top .s-fixedArea__btn--onlineShop {
  background: #007DA2;
}
.p-top .s-fixedArea__btn--zoom:hover, .p-top .s-fixedArea__btn--onlineShop:hover {
  border: 1px solid #007DA2;
}
.p-top .s-fixedArea__btn--zoom:hover span, .p-top .s-fixedArea__btn--onlineShop:hover span {
  color: #007DA2;
}
.p-top .s-fixedArea__btn--zoom:hover circle, .p-top .s-fixedArea__btn--onlineShop:hover circle {
  fill: #007DA2;
}
.p-top .s-fixedArea__btn--online {
  height: 19.3rem;
  background: #007DA2;
}
.p-top .s-fixedArea__btn--online:hover {
  border: 1px solid #007DA2;
}
.p-top .s-fixedArea__btn--online:hover span {
  color: #007DA2;
}
.p-top .s-fixedArea__btn--online:hover circle {
  fill: #007DA2;
}
.p-top .s-fixedArea__btn--onlineShop {
  height: 18.7rem;
}
.p-top .s-fixedArea__btn span {
  line-height: 1;
  text-align: center;
  font-size: 1.5rem;
  transition: 0.3s;
  color: #fff;
}
.p-top .s-fixedArea__btn img {
  opacity: 0;
}
.p-top .s-fixedArea__btn img, .p-top .s-fixedArea__btn svg {
  width: 2rem;
  height: 2rem;
}
.p-top .s-fixedArea__btn img circle, .p-top .s-fixedArea__btn svg circle {
  fill: #fff;
  transition: 0.3s;
}
.p-top .s-fixedArea__btn img path, .p-top .s-fixedArea__btn svg path {
  stroke: #001A4C;
  transition: 0.3s;
}

/*--------------------------------------
  about
--------------------------------------*/
.p-about {
  /* .make__wrap */
  /* .make__img */
  /* .pickup */
  /* .pickup__list */
  /* .recruit */
  /*--------------------------------------
    Media Queries
  --------------------------------------*/
}
.p-about .make__wrap {
  text-align: center;
  background: url("../images/about/message.png") no-repeat center/79.75rem;
}
.p-about .make__wrap h2 {
  font-size: 3.2rem;
  font-weight: 500;
  line-height: 1.5;
  color: #001A4C;
  margin-bottom: 3.2rem;
}
.p-about .make__wrap p {
  width: 70rem;
  margin-left: auto;
  margin-right: auto;
  font-size: 1.6rem;
  margin-top: 1.4rem;
  text-align: left;
}
.p-about .make__wrap h3 {
  width: 70rem;
  margin-top: 2rem;
  margin-left: auto;
  margin-right: auto;
  color: #001A4C;
  font-weight: bold;
  font-size: 2.4rem;
  line-height: 1.7;
  text-align: left;
}
.p-about .make__img {
  width: 100%;
  display: block;
  margin-top: 12rem;
  position: relative;
}
.p-about .make__img::before {
  content: "";
  width: 100vw;
  position: absolute;
  right: -4rem;
  top: 0;
  height: 100%;
  background: #004EA2;
}
@media screen and (max-width: 767px), print {
  .p-about .make__img::before {
    display: none;
  }
}
.p-about .make__img::after {
  content: "";
  width: 100vw;
  position: absolute;
  right: -4rem;
  top: 0;
  height: 27.9rem;
  background: #fff;
}
@media screen and (max-width: 767px), print {
  .p-about .make__img::after {
    display: none;
  }
}
.p-about .make__img img {
  width: 100%;
  display: block;
  position: relative;
  z-index: 1;
}
.p-about .make__bg {
  position: absolute;
  right: 86rem;
  width: 100vw;
  background: url(../images/about/bg.png) repeat center center/contain;
  height: 24.6rem;
  top: 13.3rem;
  z-index: 9;
}
.p-about .pickup {
  padding-top: 10.3rem;
  padding-bottom: 3rem;
  background: #004EA2;
  position: relative;
}
.p-about .pickup::before {
  content: "";
  width: 100vw;
  position: absolute;
  right: -4rem;
  top: 0;
  height: 100%;
  background: #004EA2;
}
@media screen and (max-width: 767px), print {
  .p-about .pickup::before {
    display: none;
  }
}
.p-about .pickup h2 {
  text-align: center;
  position: relative;
  z-index: 1;
}
.p-about .pickup__list {
  position: relative;
  z-index: 1;
}
.p-about .pickup .s-ttl-primary * {
  color: #fff;
}
.p-about .pickup .s-ttl-primary b {
  display: block;
  font-family: "Roboto", sans-serif;
  font-weight: 300;
  font-size: 8rem;
  font-style: italic;
  line-height: 1;
}
.p-about .pickup .s-ttl-primary small {
  display: block;
  font-weight: normal;
  font-size: 1.6rem;
}
.p-about .pickup__list {
  display: grid;
  flex-direction: column;
  gap: 3rem;
  grid-template-columns: repeat(2, 1fr);
  width: 100%;
  max-width: 79rem;
  padding: 0 1.25rem;
  margin-left: auto;
  margin-right: auto;
  margin-top: 3.125rem;
  align-items: stretch;
}
.p-about .pickup__list li {
  background: #fff;
  padding: 3rem;
  border-radius: 1rem;
  display: flex;
  flex-direction: column;
}
.p-about .pickup__list li h3 {
  text-align: center;
  color: #004EA2;
}
.p-about .pickup__list li h3 * {
  display: block;
}
.p-about .pickup__list li h3 b {
  font-size: 2.4rem;
  line-height: 1.2;
}
.p-about .pickup__list li h3 small {
  font-weight: 500;
  font-size: 1.4rem;
}
.p-about .pickup__list li figure {
  width: 100%;
  margin-top: 1.2rem;
}
.p-about .pickup__list li figure img {
  display: block;
  width: 100%;
}
.p-about .pickup__list li p {
  font-size: 1.4rem;
  text-align: left;
  margin-top: 1.5rem;
  font-weight: 400;
  margin-bottom: 2rem;
}
.p-about .pickup__list li a {
  display: flex;
  max-width: 27rem;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  color: #fff;
  background: #004EA2;
  border-radius: 9999rem;
  height: 4.2rem;
  transition: 0.3s;
  font-size: 1.4rem;
  margin-top: auto;
}
.p-about .pickup__list li a:hover {
  opacity: 0.7;
}
.p-about .pickup__list li a:hover img {
  opacity: 1 !important;
}
.p-about .pickup__list li a span {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
}
.p-about .pickup__list li a span img {
  width: 2rem;
}
.p-about .recruit {
  padding-top: 9.6rem;
  padding-bottom: 13.5rem;
}
.p-about .recruit h2 {
  text-align: center;
}
.p-about .recruit .s-ttl-primary b {
  display: block;
  font-family: "Roboto", sans-serif;
  font-weight: 300;
  font-size: 8rem;
  font-style: italic;
  line-height: 1;
}
.p-about .recruit .s-ttl-primary small {
  display: block;
  font-weight: 500;
  font-size: 1.6rem;
}
.p-about .recruit video {
  display: block;
  margin-top: 2rem;
  margin-left: auto;
  margin-right: auto;
  width: 76rem;
}
@media screen and (max-width: 767px), print {
  .p-about .make__wrap {
    margin-top: 4rem;
    background: url("../images/about/message.png") no-repeat center 4.5rem/46rem;
  }
  .p-about .make__wrap p {
    width: auto;
    padding: 0 1.25rem;
  }
  .p-about .make__wrap h2 {
    font-size: 2.2rem;
    margin-bottom: 1.2rem;
  }
  .p-about .make__wrap h3 {
    width: auto;
    padding: 0 1.25rem;
    font-size: 1.9rem;
    text-align: center;
  }
  .p-about .make__img {
    margin-left: -2rem;
    margin-right: -2rem;
    width: calc(100% + 4rem);
    margin-top: 8.1rem;
  }
  .p-about .pickup {
    margin-left: -2rem;
    margin-right: -2rem;
    width: calc(100% + 4rem);
    padding-top: 9.3rem;
    padding-bottom: 3.125rem;
  }
  .p-about .pickup .s-ttl-primary b {
    font-size: 5.5rem;
  }
  .p-about .pickup .s-ttl-primary small {
    font-size: 1.4rem;
  }
  .p-about .pickup__list {
    margin-top: 1.75rem;
    grid-template-columns: repeat(1, 1fr);
    padding: 0 2rem;
  }
  .p-about .pickup__list li a {
    max-width: 19rem;
  }
  .p-about .recruit {
    padding-top: 6.5rem;
    padding-bottom: 3.75rem;
  }
  .p-about .recruit .s-ttl-primary b {
    font-size: 5.5rem;
  }
  .p-about .recruit .s-ttl-primary small {
    font-size: 1.6rem;
  }
  .p-about .recruit video {
    width: calc(100% - 1.5rem);
  }
}

/*--------------------------------------
  about/information
--------------------------------------*/
table.hightech {
  /* ======== PC・共通スタイル ======== */
  width: calc(100% - 4rem);
  border-collapse: collapse;
  text-align: justify;
  text-justify: inter-ideograph;
  font-size: 1.4rem;
  line-height: 1.6;
  margin: 0 auto;
}
table.hightech th {
  padding: 2rem 1.5rem;
  font-weight: 500;
  color: #004EA2;
  border-bottom: 1px solid #004EA2;
  vertical-align: top;
}
table.hightech th.t_top {
  border-top: 1px solid #004EA2;
}
table.hightech td {
  text-align: left;
  padding: 2rem 1.5rem;
  border-bottom: 1px solid #e3e3e3;
  color: #001A4C;
}
table.hightech td.t_top {
  border-top: 1px solid #e3e3e3;
}
table.hightech td .link {
  border: 1px solid #004EA2;
  border-radius: 50px;
  padding: 0.4rem;
  padding-top: 0;
  margin-left: 0.5rem;
}
table.hightech td .link .icon {
  width: 1.3rem;
  vertical-align: middle;
  margin-right: 0.5rem;
}
table.hightech td .link a {
  color: #004EA2;
}
table.hightech ul {
  margin: 0;
  padding: 0;
}
table.hightech ul li {
  margin-bottom: 5px;
  list-style: none;
}
table.hightech dl {
  margin: 0;
  padding: 0;
}
table.hightech dl dt {
  font-family: "Noto Sans Japanese", sans-serif;
  font-weight: 700;
  margin-bottom: 0.5rem;
}
table.hightech dl dd {
  margin-bottom: 1.5rem;
}
@media screen and (max-width: 767px) {
  table.hightech {
    width: 100%;
    /* テーブルの各セルを縦並びにする */
    /* .spクラス用（設立・資本金などを横並びに） */
    /* 行頭に線を表示する装飾（必要な行のみ） */
    /* thの線や余白を再調整 */
    /* 上部線などを消す */
    /* 下部線や余白を再調整 */
    /* 地図リンクを右寄せに */
  }
  table.hightech th {
    display: block;
    width: 100%;
    border: none;
    padding-top: 0;
    padding-bottom: 0;
    border-top: none;
  }
  table.hightech td {
    display: block;
    width: 100%;
    padding-top: 0;
    padding-bottom: 0;
    border: none;
  }
  table.hightech .sp th[colspan="2"] {
    display: block;
    width: 100%;
    font-weight: 700;
    color: #004EA2;
    padding: 0;
    padding-top: 1rem;
    border-top: 1px solid #e3e3e3;
  }
  table.hightech .sp td {
    display: inline-block;
    width: 50%;
    box-sizing: border-box;
    vertical-align: top;
    padding: 0;
    padding-bottom: 1rem;
  }
  table.hightech tr {
    position: relative;
  }
  table.hightech tr::before {
    content: "";
    border-top: 1px solid #004EA2;
    height: 1px;
    width: 5rem;
    position: absolute;
    top: 0;
    left: 0;
  }
  table.hightech tr.line_no::before {
    content: none;
  }
  table.hightech th {
    display: block;
    width: 100%;
    border: none;
    padding: 1rem 0;
    border-top: 1px solid #e3e3e3;
  }
  table.hightech td.t_top {
    border: none;
  }
  table.hightech td {
    border: none;
    padding: 0;
    padding-bottom: 1rem;
  }
  table.hightech td .link {
    display: block;
    margin-top: 1rem;
    margin-left: auto;
    margin-right: 0;
    max-width: 12.2rem;
    padding-top: 0.4rem;
  }
}
table.hightech ol {
  padding-left: 1em;
}
table.hightech ol li {
  list-style: auto;
}

.p-about-office-list .hightech th {
  width: 18rem !important;
}
@media screen and (max-width: 767px), print {
  .p-about-office-list .hightech td {
    font-size: 1.2rem;
  }
}
.p-about-office-list .frame {
  display: inline-flex;
  gap: 1rem;
}
.p-about-office-list .frame span {
  display: flex;
  align-items: center;
  font-size: 1.2rem;
  padding: 0 0.4rem;
  border-radius: 0.2rem;
  color: #FFF;
}
@media screen and (max-width: 767px), print {
  .p-about-office-list .frame span {
    font-size: 1rem;
  }
}
.p-about-office-list .frame span.dev {
  background-color: #06F;
}
.p-about-office-list .frame span.smb {
  background-color: #F33;
}
.p-about-office-list .frame span.farm {
  background-color: #096;
}

.p-about-isms .overview {
  margin-bottom: 6rem;
}
.p-about-isms .overview img {
  width: 50%;
  margin-left: auto;
  margin-right: auto;
  display: block;
  margin-top: 5rem;
}
@media screen and (max-width: 767px), print {
  .p-about-isms .overview img {
    width: 100%;
  }
}

/*--------------------------------------
  about/history
--------------------------------------*/
.p-about-history {
  /* IE10対策 */
  /* ======== iPad用スタイル（768px以上 - 1400px以下） ======== */
  /* ======== SP用スタイル（767px以下） ======== */
}
.p-about-history .history {
  padding-bottom: 8rem;
  text-align: center;
  margin-top: 8.8rem;
}
.p-about-history table {
  width: calc(100% - 4rem);
  text-align: left;
  vertical-align: top;
  overflow: hidden;
  margin: 0 auto;
}
.p-about-history table tr th {
  width: 8rem;
  font-size: 1.4rem;
  color: #004EA2;
  position: relative;
  text-align: left;
  vertical-align: top;
}
.p-about-history table tr th:before {
  content: " ";
  display: block;
  width: 1px;
  background: #004EA2;
  height: 100%;
  position: absolute;
  top: 17px;
  right: 44px;
}
.p-about-history table tr th:after {
  content: " ";
  display: block;
  width: 11px;
  height: 11px;
  background: #004EA2;
  border-radius: 5.5px;
  position: absolute;
  top: 14px;
  right: 39px;
}
.p-about-history table tr td {
  width: 610px;
  padding-bottom: 1rem;
}
.p-about-history table tr td dl {
  margin-bottom: 0.8rem;
}
.p-about-history table tr td dl dt {
  width: 5rem;
  padding: 0;
  display: table-cell;
  font-size: 1.4rem;
}
.p-about-history table tr td dl dd {
  padding-left: 2rem;
  display: table-cell;
  border-left: 1px solid #DDD;
  line-height: 140%;
}
.p-about-history table tr td dl dd ul {
  list-style: none;
}
.p-about-history table tr td dl dd ul li {
  position: relative;
  margin-bottom: 1rem;
  font-size: 1.4rem;
}
.p-about-history table tr td dl dd ul li:before {
  content: "";
  position: absolute;
  padding-right: 4px;
  left: 0;
}
@media all and (-ms-high-contrast: none) {
  .p-about-history table tr th:before {
    height: 200px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .p-about-history table tr th {
    width: 6rem;
  }
  .p-about-history table tr th:before {
    top: 0;
    right: 1rem;
  }
  .p-about-history table tr th:after {
    top: 0;
    right: 0.5rem;
  }
  .p-about-history table tr td {
    width: 50rem;
    padding-bottom: 1rem;
  }
}
@media screen and (max-width: 767px) {
  .p-about-history .history {
    margin: 0 auto;
    padding-bottom: 2rem;
    text-align: center;
    margin-top: 3.5rem;
  }
  .p-about-history table {
    width: 100%;
    text-align: left;
    vertical-align: top;
    overflow: hidden;
  }
  .p-about-history table tr th {
    font-size: 1.6rem;
    color: #004EA2;
    text-align: left;
    display: block;
    border-bottom: 1px solid #004EA2;
    padding-bottom: 0.8rem;
    width: 100%;
  }
  .p-about-history table tr th:before, .p-about-history table tr th:after {
    content: none;
  }
  .p-about-history table tr td {
    padding-bottom: 1.5rem;
    display: block;
    padding-top: 0.8rem;
    width: 100%;
  }
  .p-about-history table tr td dl {
    margin-bottom: 0.8rem;
  }
  .p-about-history table tr td dl dt {
    padding: 0;
    color: #777;
    display: block;
    width: 100%;
  }
  .p-about-history table tr td dl dd {
    line-height: 1.8;
    padding: 0;
    border: none;
    display: block;
  }
  .p-about-history table tr td dl dd ul {
    list-style: none;
  }
  .p-about-history table tr td dl dd ul li {
    position: relative;
    margin-bottom: 1rem;
  }
  .p-about-history table tr td dl dd ul li:before {
    content: none;
  }
}

/*--------------------------------------
  about/tokutei01
--------------------------------------*/
.tokutei01 .parentheses-txt {
  text-indent: 0;
}
.tokutei01 .mt-1 {
  margin-top: 1rem !important;
}
.tokutei01 .mt-2 {
  margin-top: 2rem !important;
}
.tokutei01 .mt-3 {
  margin-top: 3rem !important;
}
.tokutei01 .tokutei01 {
  width: calc(100% - 4rem);
  margin: 0 auto;
}
.tokutei01 .dotted-box {
  margin-bottom: 12rem;
}
.tokutei01 .dotted-box h2 {
  font-size: 1.9rem;
  margin-bottom: 1.8rem;
  font-weight: bold;
  color: #004EA2;
}
.tokutei01 .dotted-box ul {
  list-style-type: "● ";
  padding-left: 2rem;
  margin: 0 0 2rem;
}
.tokutei01 .info-list {
  max-width: 96%;
  margin: 0 auto;
  border-top: 1px solid #ddd;
}
.tokutei01 .info-block {
  padding: 2rem 0;
  border-bottom: 1px solid #ddd;
}
.tokutei01 .info-block.line-no {
  border: none;
}
.tokutei01 .info-label {
  font-weight: bold;
  color: #004EA2;
  font-size: 1.4rem;
  position: relative;
  margin-bottom: 1rem;
}
.tokutei01 .info-label::before {
  content: "●";
  color: #004EA2;
  font-size: 1.6rem;
  display: inline-block;
  margin-right: 0.5rem;
}
.tokutei01 .info-label.num {
  padding-left: 1.3em;
  text-indent: -1.3em;
}
.tokutei01 .info-label.num::before {
  display: none !important;
}
.tokutei01 .info-value {
  font-size: 1.4rem;
  display: grid;
  gap: 1rem;
}
.tokutei01 .txt02nmb {
  font-size: 1.4rem;
  position: relative;
  text-indent: -1rem;
  padding-left: 2rem;
}
.tokutei01 .txt02nmb::before {
  content: "◇";
  font-size: 1.4rem;
  display: inline-block;
}
.tokutei01 ul {
  margin-top: 2rem;
  padding-left: 1em;
  display: grid;
  gap: 0.8rem;
}
.tokutei01 ul > li {
  list-style-type: disc;
}
.tokutei01 ul.pdf {
  margin-top: 5rem;
}
.tokutei01 ul.desc {
  padding-left: 2rem;
}
.tokutei01 ul.desc > li {
  list-style-type: disc;
  text-indent: 0em;
}
.tokutei01 ul.desc.pdf {
  margin-top: 5rem;
}
.tokutei01 ol.parentheses {
  counter-reset: item;
  display: grid;
  gap: 0.8rem;
}
.tokutei01 ol.parentheses > li {
  padding-left: 2em;
  position: relative;
}
.tokutei01 ol.parentheses > li::before {
  left: 0;
  position: absolute;
  counter-increment: item;
  content: "（" counter(item) "） ";
}
.tokutei01 ol.caution {
  counter-reset: item;
  display: grid;
  gap: 0.8rem;
  font-size: 1.2rem;
  opacity: 0.7;
  margin-top: 2rem;
  padding-left: 2rem;
}
.tokutei01 ol.caution > li {
  padding-left: 2em;
  text-indent: -2em;
}
.tokutei01 ol.caution > li::before {
  counter-increment: item;
  content: "※" counter(item) " ";
}
.tokutei01 .text-date {
  text-align: right;
  font-size: 1.4rem;
  opacity: 0.7;
  margin-top: 1rem;
}
.tokutei01 .author {
  text-align: right;
  font-style: italic;
  margin-top: 1rem;
  font-size: 1.4rem;
}
@media screen and (max-width: 767px) {
  .tokutei01 .tokutei01 {
    width: 100%;
  }
}
.tokutei01 .rihgt-text {
  text-align: right;
  font-size: 1.3rem;
}
@media screen and (max-width: 767px) {
  .tokutei01 .rihgt-text {
    font-size: 1.3rem;
  }
}

/*--------------------------------------
  about/certified
--------------------------------------*/
.p-about-certified {
  /* 余白のクリアやフロート解除が必要な場合に使用 */
  /* ======== SP用スタイル（767px以下） ======== */
}
.p-about-certified .panel {
  width: calc(100% - 4rem);
  margin: 0 auto;
}
.p-about-certified .certified-block {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 5rem;
  align-items: flex-start;
  gap: 3rem;
}
.p-about-certified .certified-text {
  flex: 1;
  min-width: 0;
  margin-top: -0.5rem;
}
.p-about-certified .certified-text h3 {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  color: #004EA2;
}
.p-about-certified .certified-text p {
  font-size: 1.4rem;
  font-weight: 400;
}
.p-about-certified .certified-text a {
  color: #fff;
  background: #004EA2;
  max-width: 20.4rem;
  line-height: 4.2rem;
  text-align: center;
  border-radius: 50px;
  display: block;
  margin-top: 1rem;
  position: relative;
  font-size: 1.4rem;
}
.p-about-certified .certified-text a::after {
  content: "";
  background: url(../images/about/certified/ic-link.svg) no-repeat;
  width: 16px;
  height: 14px;
  display: inline-block;
  vertical-align: middle;
  margin-left: 0.1rem;
  background-size: cover;
  margin-bottom: 0.3rem;
}
.p-about-certified .certified-text a:hover {
  text-decoration: none;
}
.p-about-certified .clearfix::after {
  content: "";
  display: block;
  clear: both;
}
.p-about-certified .certified-image {
  width: 15rem;
  border: 1px solid #ccc;
  text-align: center;
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
}
.p-about-certified .certified-image img {
  max-height: 8rem;
}
@media screen and (max-width: 767px) {
  .p-about-certified .panel {
    width: 100%;
  }
  .p-about-certified .certified-block {
    border-bottom: 1px solid #ccc;
    padding-bottom: 3rem;
    margin-bottom: 3rem;
  }
  .p-about-certified .certified-text {
    flex: auto;
    min-width: 0;
  }
  .p-about-certified .certified-image {
    width: 50%;
    margin: auto;
  }
  .p-about-certified .certified-text a {
    max-width: 20rem;
    margin: auto;
    margin-top: 1.5rem;
  }
}

/*--------------------------------------
  about/faceup
--------------------------------------*/
.p-about-faceup {
  /* ======== SP用スタイル（767px以下） ======== */
}
.p-about-faceup .faceup h2.ttl {
  color: #004EA2;
  font-size: 2rem;
  padding-left: 1.5rem;
  margin-bottom: 1rem;
  position: relative;
}
.p-about-faceup .faceup h2.ttl::before {
  content: "";
  border: 5px solid #004EA2;
  border-radius: 30px;
  height: 27px;
  position: absolute;
  left: 0;
  top: 0.3rem;
  bottom: 0;
  margin: auto;
}
.p-about-faceup .faceup .leadWrap {
  max-width: 700px;
  margin: auto;
  margin-bottom: 9.2rem;
}
.p-about-faceup .faceup .leadWrap .lead_txt {
  font-size: 1.4rem;
  margin-bottom: 3rem;
}
.p-about-faceup .faceup .leadWrap .fv {
  text-align: center;
}
.p-about-faceup .faceup .pointWrap {
  margin-bottom: 6rem;
}
.p-about-faceup .faceup .pointWrap h2 {
  max-width: 50rem;
}
.p-about-faceup .faceup .pointWrap .lead_txt {
  font-size: 1.4rem;
  margin-bottom: 2rem;
}
.p-about-faceup .faceup .pointWrap h2 {
  margin-bottom: 1rem;
}
.p-about-faceup .faceup .pointWrap .box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 2rem;
  margin-bottom: 1.5rem;
}
.p-about-faceup .faceup .pointWrap .box .img {
  max-width: 22rem;
}
.p-about-faceup .faceup .pointWrap .box .txt_area {
  max-width: 63rem;
}
.p-about-faceup .faceup .pointWrap .box .txt_area .ttl_area {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
}
.p-about-faceup .faceup .pointWrap .box .txt_area .ttl_area .icon {
  max-width: 62px;
}
.p-about-faceup .faceup .pointWrap .box .txt_area .ttl_area h3 {
  color: #004EA2;
  font-size: 2rem;
  line-height: 120%;
}
.p-about-faceup .faceup .pointWrap .box .txt_area .ttl_area h3 span {
  display: block;
  font-size: 1.4rem;
  font-weight: 400;
}
.p-about-faceup .faceup .pointWrap .box .txt_area .txt {
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 180%;
}
.p-about-faceup .faceup .contentsWrap {
  margin-bottom: 6rem;
}
.p-about-faceup .faceup .contentsWrap .txt {
  font-size: 1.4rem;
  font-weight: 400;
}
.p-about-faceup .faceup .contents02Wrap {
  margin-bottom: 6rem;
}
.p-about-faceup .faceup .contents02Wrap .flex_box {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
}
.p-about-faceup .faceup .contents02Wrap .flex_box .box {
  width: calc(33.3333333333% - 1.34rem);
}
.p-about-faceup .faceup .contents02Wrap .flex_box .box .img {
  margin-bottom: 1rem;
}
.p-about-faceup .faceup .contents02Wrap .flex_box .box .ttl {
  font-size: 1.6rem;
  margin-bottom: 0.5rem;
  color: #004EA2;
  font-weight: 700;
}
.p-about-faceup .faceup .contents02Wrap .flex_box .box .txt {
  font-size: 1.4rem;
  font-weight: 400;
}
.p-about-faceup .faceup .contents03Wrap {
  margin-bottom: 5rem;
}
.p-about-faceup .faceup .contents03Wrap .flex_box {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
}
.p-about-faceup .faceup .contents03Wrap .flex_box .box {
  width: calc(33.3333333333% - 1.34rem);
}
.p-about-faceup .faceup .contents03Wrap .flex_box .box .img {
  margin-bottom: 1rem;
}
.p-about-faceup .faceup .contents03Wrap .flex_box .box .ttl {
  font-size: 1.6rem;
  margin-bottom: 0.5rem;
  color: #004EA2;
  font-weight: 700;
}
.p-about-faceup .faceup .contents03Wrap .flex_box .box .txt {
  font-size: 1.4rem;
}
@media screen and (max-width: 767px) {
  .p-about-faceup .faceup h2.ttl {
    padding-left: 1.8rem;
  }
  .p-about-faceup .faceup h2.ttl::before {
    content: "";
    border: 3px solid #004EA2;
  }
  .p-about-faceup .faceup .lead_txt {
    margin-bottom: 1.2rem;
  }
  .p-about-faceup .faceup .leadWrap {
    margin-bottom: 6rem;
  }
  .p-about-faceup .faceup .pointWrap {
    margin-bottom: 4rem;
  }
  .p-about-faceup .faceup .pointWrap .box {
    gap: 2rem;
    margin-bottom: 3.2rem;
  }
  .p-about-faceup .faceup .pointWrap .box .img {
    max-width: 100%;
    text-align: center;
    margin: auto;
    margin-bottom: 0rem;
  }
  .p-about-faceup .faceup .pointWrap .box .txt_area .ttl_area {
    margin-bottom: 0;
  }
  .p-about-faceup .faceup .pointWrap .box .txt_area .ttl_area .icon {
    max-width: 5rem;
  }
  .p-about-faceup .faceup .contentsWrap {
    margin-bottom: 4rem;
  }
  .p-about-faceup .faceup .contents02Wrap {
    margin-bottom: 0rem;
  }
  .p-about-faceup .faceup .contents02Wrap .flex_box .box {
    width: 100%;
    border-bottom: 1px solid #ccc;
    padding-bottom: 2rem;
    margin-bottom: 1rem;
  }
  .p-about-faceup .faceup .contents02Wrap .flex_box .box:last-child {
    border: none;
  }
  .p-about-faceup .faceup .contents02Wrap .flex_box .box .ttl {
    font-size: 1.8rem;
  }
  .p-about-faceup .faceup .contents02Wrap .flex_box .box .ttl_area {
    display: flex;
    gap: 1rem;
    align-items: center;
  }
  .p-about-faceup .faceup .contents02Wrap .flex_box .box .ttl_area .img {
    max-width: 8rem;
  }
  .p-about-faceup .faceup .contents03Wrap {
    margin-bottom: 5rem;
  }
  .p-about-faceup .faceup .contents03Wrap .flex_box .box {
    width: 100%;
    border-bottom: 1px solid #ccc;
    padding-bottom: 2rem;
    margin-bottom: 1rem;
  }
  .p-about-faceup .faceup .contents03Wrap .flex_box .box:last-child {
    border: none;
  }
  .p-about-faceup .faceup .contents03Wrap .flex_box .box .ttl {
    font-size: 1.8rem;
  }
  .p-about-faceup .faceup .contents03Wrap .flex_box .box .ttl_area {
    display: flex;
    gap: 1rem;
    align-items: center;
  }
  .p-about-faceup .faceup .contents03Wrap .flex_box .box .ttl_area .img {
    max-width: 8rem;
  }
}

/*--------------------------------------
  about/message
--------------------------------------*/
.p-about-message .fv {
  background: url(../images/about/message/message_fv_bg.png) no-repeat;
  background-size: cover;
  width: 100%;
  margin-bottom: 6rem;
  height: 40.8rem;
  position: relative;
}
.p-about-message .fv .txt_area {
  position: absolute;
  height: 30rem;
  top: 0;
  bottom: 0;
  margin: auto;
  left: 40rem;
  width: 43rem;
}
.p-about-message .fv .txt_area h2 {
  color: #fff;
  font-size: 2.6rem;
  margin-bottom: 1.5rem;
  font-weight: 700;
  line-height: 1.5;
}
.p-about-message .fv .txt_area h2 .sub {
  font-size: 1.8rem;
  display: block;
  margin-bottom: 0;
}
.p-about-message .fv .txt_area .txt {
  font-size: 1.4rem;
  color: #fff;
  margin-bottom: 1rem;
}
.p-about-message .story h2 {
  font-size: 1.6rem;
  margin-bottom: 3rem;
  font-weight: 500;
}
.p-about-message .story h2 span.en {
  font-size: 8rem;
  font-family: "Roboto", sans-serif;
  font-weight: 300;
  display: block;
  font-style: italic;
  line-height: 1;
}
.p-about-message .story .box {
  margin-bottom: 6rem;
  position: relative;
}
.p-about-message .story .box h3 {
  font-family: "Roboto", sans-serif;
  font-weight: 300;
  font-size: 4rem;
  margin-bottom: 1rem;
  font-style: italic;
  line-height: 1;
  color: #004EA2;
}
.p-about-message .story .box .in_box {
  max-width: 75rem;
  margin: auto;
  position: relative;
  padding-top: 1.5rem;
}
.p-about-message .story .box .in_box .ttl {
  color: #004EA2;
  font-size: 2rem;
  margin-bottom: 1rem;
  font-weight: 700;
}
.p-about-message .story .box .in_box .txt {
  font-size: 1.4rem;
  margin-bottom: 2rem;
}
.p-about-message .story .box .in_box .img {
  text-align: center;
}
.p-about-message .story .box .in_box::before {
  content: "";
  border-left: 1px solid #004EA2;
  position: absolute;
  top: 0rem;
  left: -5rem;
  height: 100%;
}
.p-about-message .story .box .in_box .flex_box {
  display: flex;
  gap: 3rem;
  margin-bottom: 1.5rem;
}
.p-about-message .story .box .in_box .flex_box .txt {
  max-width: 47rem;
}
.p-about-message .story .box.box01 .img {
  max-width: 50rem;
  margin: auto;
}
.p-about-message .story .box.box03 .img {
  max-width: 50rem;
  margin: auto;
}
.p-about-message .story .box.box06 .img {
  max-width: 50rem;
  margin: auto;
}
.p-about-message .story .box.box08 .img {
  max-width: 50rem;
  margin: auto;
}
.p-about-message .story .box.box09 .img {
  max-width: 65rem;
  margin: auto;
}
.p-about-message .story .box.box10 .img {
  max-width: 52rem;
  margin: auto;
}

/* ======== SP用スタイル（767px以下） ======== */
@media screen and (max-width: 767px) {
  .p-about-message .fv {
    background: url(../images/about/message/message_fv_bg_sp.png) no-repeat;
    background-size: cover;
    height: 40.8rem;
    position: relative;
  }
  .p-about-message .fv .txt_area {
    position: relative;
    height: auto;
    top: 0;
    bottom: 0;
    margin: auto;
    left: auto;
    width: 90%;
    padding-top: 2rem;
  }
  .p-about-message .fv .txt_area h2 {
    color: #fff;
    font-size: 2.6rem;
    margin-bottom: 0.5rem;
    font-weight: 700;
    line-height: 1.5;
  }
  .p-about-message .fv .txt_area h2 .sub {
    font-size: 1.4rem;
    display: block;
    margin-bottom: 0;
  }
  .p-about-message .fv .txt_area .txt {
    font-size: 1.4rem;
    color: #fff;
    margin-bottom: 0.5rem;
  }
  .p-about-message .fv .txt_area .name {
    font-size: 1.3rem;
    color: #fff;
    position: absolute;
    left: 15rem;
    top: 30rem;
  }
  .p-about-message .story .box .img {
    max-width: 100%;
  }
  .p-about-message .story .box.box01 .img {
    max-width: 100%;
    margin: auto;
  }
  .p-about-message .story .box.box03 .img {
    max-width: 100%;
    margin: auto;
  }
  .p-about-message .story .box.box06 .img {
    max-width: 100%;
    margin: auto;
  }
  .p-about-message .story .box.box08 .img {
    max-width: 100%;
    margin: auto;
  }
  .p-about-message .story .box.box09 .img {
    max-width: 100%;
    margin: auto;
  }
  .p-about-message .story .box.box10 .img {
    max-width: 100%;
    margin: auto;
  }
  .p-about-message .story .box .in_box {
    max-width: 100%;
    padding-top: 0;
  }
  .p-about-message .story .box .in_box .flex_box {
    gap: 0;
  }
  .p-about-message .story .box .in_box .flex_box .txt {
    max-width: 100%;
  }
  .p-about-message .story .box .in_box::before {
    content: none;
    left: 0;
    overflow: hidden;
  }
  .p-about-message .story .box .in_box .txt {
    margin-bottom: 1.5rem;
  }
  .p-about-message .story .box .in_box .txt .img {
    float: right;
    width: calc(45% - 1rem);
    padding-left: 1rem;
  }
}
.p-joint .b-inner {
  display: grid;
  align-items: center;
  grid-template-columns: 30rem 1fr;
  gap: 5rem;
}
@media screen and (max-width: 767px), print {
  .p-joint .b-inner {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}
.p-joint .b-inner h4 {
  margin-top: 1.5rem;
  font-weight: normal;
}

/*--------------------------------------
  products/srclub
--------------------------------------*/
.p-products-srclub .tokuten {
  padding: 0 20px;
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .tokuten {
    padding: 0 0px;
  }
}
.p-products-srclub .tokuten .flex_box {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  justify-content: center;
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .tokuten .flex_box {
    gap: 1rem;
  }
}
.p-products-srclub .tokuten .flex_box .box {
  background: #ECF2FA;
  padding: 20px 30px 35px 14px;
  display: flex;
  gap: 14px;
  align-items: center;
  width: calc(50% - 10px);
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .tokuten .flex_box .box {
    width: 100%;
    padding: 2rem 2rem 2rem 1rem;
  }
}
.p-products-srclub .tokuten .flex_box .box .icon p {
  width: 66px;
  height: 66px;
  background: #fff;
  border-radius: 100rem;
}
.p-products-srclub .tokuten .flex_box .box .icon p img {
  width: 40px;
  height: 50px;
  margin: auto;
  text-align: center;
  display: block;
  padding-top: 15px;
}
.p-products-srclub .tokuten .flex_box .box .txt_area h3 {
  font-size: 1.4rem;
  color: #29B187;
  margin-bottom: 5px;
  font-weight: 700;
}
.p-products-srclub .tokuten .flex_box .box .txt_area .txt {
  font-size: 1.2rem;
}
.p-products-srclub .p-product-top__box {
  margin-top: 2.4rem;
}
.p-products-srclub .program {
  padding: 0 20px;
}
.p-products-srclub .program.p-products_gyou__sec {
  margin-top: 6rem;
}
@media screen and (max-width: 767px) {
  .p-products-srclub .program.p-products_gyou__sec {
    margin-top: 4rem;
  }
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .program {
    padding: 0 0px;
  }
}
.p-products-srclub .program .notes {
  margin-top: 10px;
}
.p-products-srclub .program .notes li {
  color: #004EA2;
  font-size: 1rem;
}
.p-products-srclub .fee {
  padding: 0 20px;
}
.p-products-srclub .fee.p-products_gyou__sec {
  margin-top: 6rem;
}
@media screen and (max-width: 767px) {
  .p-products-srclub .fee.p-products_gyou__sec {
    margin-top: 4rem;
  }
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .fee {
    padding: 0 0px;
  }
}
.p-products-srclub .fee .p-product-top__box {
  margin-top: 0rem;
}
.p-products-srclub .fee .flex_box {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 15px;
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .fee .flex_box {
    gap: 1rem;
  }
}
.p-products-srclub .fee .flex_box .box {
  border: 1px solid #001A4C;
  border-radius: 10px;
  padding: 15px 25px;
  width: calc(33.3333333333% - 10px);
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .fee .flex_box .box {
    width: 100%;
    padding: 1rem 2rem;
    display: flex;
    align-items: center;
    gap: 1rem;
  }
}
.p-products-srclub .fee .flex_box .box .ttl {
  background: #29B187;
  width: 100%;
  padding: 5px 0;
  text-align: center;
  color: #fff;
  font-size: 1.4rem;
  margin-bottom: 10px;
  border-radius: 100rem;
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .fee .flex_box .box .ttl {
    width: 35%;
    margin: 0;
  }
}
.p-products-srclub .fee .flex_box .box .txt {
  text-align: center;
  font-size: 3.2rem;
  font-weight: 700;
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .fee .flex_box .box .txt {
    margin-left: auto;
    margin-right: auto;
  }
}
.p-products-srclub .fee .flex_box .box .txt span {
  font-size: 1.2rem;
  font-weight: 500;
  padding-right: 10px;
  vertical-align: middle;
  font-style: normal;
}
.p-products-srclub .fee .flex_box .box .txt em {
  font-size: 1.2rem;
  padding-left: 10px;
  vertical-align: middle;
  font-style: normal;
}
.p-products-srclub .step {
  padding: 0 20px;
}
.p-products-srclub .step.p-products_gyou__sec {
  margin-top: 6rem;
}
@media screen and (max-width: 767px) {
  .p-products-srclub .step.p-products_gyou__sec {
    margin-top: 4rem;
  }
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .step {
    padding: 0 0px;
  }
}
.p-products-srclub .step .p-product-top__box {
  margin-top: 0rem;
}
.p-products-srclub .step .flex_box {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  justify-content: center;
}
.p-products-srclub .step .flex_box .box {
  background: #ECF2FA;
  padding: 20px 0px 20px 30px;
  display: flex;
  gap: 20px;
  align-items: center;
  width: 100%;
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .step .flex_box .box {
    padding: 1.5rem 1rem;
    display: block;
  }
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .step .flex_box .box .icon {
    display: flex;
    gap: 1rem;
    align-items: center;
    margin-bottom: 1rem;
  }
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .step .flex_box .box .icon h3 {
    font-size: 1.8rem;
    color: #29B187;
    font-weight: 700;
  }
}
.p-products-srclub .step .flex_box .box .icon p {
  width: 46px;
  height: 46px;
  background: #29B187;
  border-radius: 100rem;
  color: #fff;
  font-size: 1.8rem;
  text-align: center;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .step .flex_box .box .icon p {
    width: 38px;
    height: 38px;
    line-height: 38px;
  }
}
.p-products-srclub .step .flex_box .box .txt_area h3 {
  font-size: 1.8rem;
  color: #29B187;
  margin-bottom: 5px;
  font-weight: 700;
}
.p-products-srclub .step .flex_box .box .txt_area .txt {
  font-size: 1.3rem;
}
.p-products-srclub .support {
  padding: 0 20px;
}
.p-products-srclub .support.p-products_gyou__sec {
  margin-top: 6rem;
}
@media screen and (max-width: 767px) {
  .p-products-srclub .support.p-products_gyou__sec {
    margin-top: 4rem;
  }
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .support {
    padding: 0 0px;
  }
}
.p-products-srclub .support .p-products_gyou__supportBtnArea {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .support .p-products_gyou__supportBtnArea {
    grid-template-columns: auto;
  }
}
.p-products-srclub .support .p-products_gyou__supportBtnArea .c-btnA__wh {
  background: #fff;
  border: 1px solid #004EA2;
  color: #001A4C;
  padding-left: 3rem;
  padding-right: 3rem;
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .support .p-products_gyou__supportBtnArea .c-btnA__wh {
    width: 100%;
  }
}
.p-products-srclub .support .p-products_gyou__supportBtnArea .c-btnA__wh:hover {
  background: #001A4C;
  border: 1px solid #001A4C;
  color: #fff;
}
.p-products-srclub .support .p-products_gyou__supportBtnArea .c-btnA__wh:hover circle {
  fill: #fff;
}
.p-products-srclub .support .p-products_gyou__supportBtnArea .c-btnA__wh:hover line, .p-products-srclub .support .p-products_gyou__supportBtnArea .c-btnA__wh:hover path {
  stroke: #001A4C;
}
.p-products-srclub .support .p-products_gyou__supportBtnArea .btn-user {
  grid-column: 1/3;
  border-color: #fff;
  height: 10rem;
  border-radius: 0.5rem;
  padding-left: 3rem;
  padding-right: 3rem;
  border: 1px solid #004EA2;
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .support .p-products_gyou__supportBtnArea .btn-user {
    grid-column: auto;
  }
}
.p-products-srclub .support .p-products_gyou__supportBtnArea .btn-user .txt {
  display: flex;
  align-items: center;
  gap: 6rem;
  width: 90%;
  font-size: 2.4rem;
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .support .p-products_gyou__supportBtnArea .btn-user .txt {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 1rem;
    width: 80%;
    font-size: 1.8rem;
  }
}
.p-products-srclub .support .p-products_gyou__supportBtnArea .btn-user .txt .sub {
  /*width: 70%; */
  font-size: 1.4rem;
  display: block;
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .support .p-products_gyou__supportBtnArea .btn-user .txt .sub {
    font-size: 1.2rem;
  }
}
.p-products-srclub .support .p-products_gyou__supportBtnArea .btn-user svg {
  width: 3.5rem;
}
@media screen and (max-width: 767px), print {
  .p-products-srclub .support .p-products_gyou__supportBtnArea .btn-user svg {
    width: 2.8rem;
  }
}

/*--------------------------------------
  products/info/academy
--------------------------------------*/
.p-products-info-academy .p-product-details__box {
  margin-top: 4rem;
}
.p-products-info-academy .p-product-details__box .p-caseSingle__info {
  margin-bottom: 1rem;
}
.p-products-info-academy .p-product-details__box .hightech {
  width: 100%;
  margin-bottom: 1rem;
}
@media screen and (max-width: 767px), print {
  .p-products-info-academy .p-product-details__box .hightech {
    border-bottom: 1px solid #e3e3e3;
  }
}
.p-products-info-academy .p-product-details__box .hightech th {
  width: 20%;
}
@media screen and (max-width: 767px), print {
  .p-products-info-academy .p-product-details__box .hightech th {
    width: 100%;
  }
  .p-products-info-academy .p-product-details__box .hightech th.t_top {
    border-top: 1px solid #e3e3e3;
  }
}
.p-products-info-academy .p-product-details__box .notes {
  margin-left: 20px;
}
@media screen and (max-width: 767px), print {
  .p-products-info-academy .p-product-details__box .notes {
    margin-left: 2rem;
  }
}
.p-products-info-academy .p-product-details__box .notes li {
  font-size: 1.4rem;
  list-style: disc;
}
.p-products-info-academy .p-product-details__box .sub_txt {
  font-size: 1.2rem;
  margin-top: 10px;
  color: #004EA2;
  margin-left: 20px;
}
@media screen and (max-width: 767px), print {
  .p-products-info-academy .p-product-details__box .sub_txt {
    margin-left: 0px;
  }
}

/*--------------------------------------
  products_gyou/purchase
--------------------------------------*/
.p-purchase__lead {
  padding: 0 20px;
  margin-bottom: 4rem;
}
.p-purchase__lead .ttl {
  font-size: 1.6rem;
  color: #004EA2;
  display: flex;
  gap: 0.75rem;
  margin-bottom: 1.6rem;
}
.p-purchase__lead .ttl::before {
  content: "●";
  font-size: 1.1rem;
  margin-top: 5px;
}
.p-purchase__lead .txt {
  font-size: 1.4rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px) {
  .p-purchase__lead {
    padding: 0 1rem;
    margin-bottom: 2.4rem;
  }
  .p-purchase__lead .ttl {
    font-size: 1.6rem;
  }
}

.p-purchase__block {
  background-color: #ECF2FA;
  padding: 4rem;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4rem 3rem;
}

.p-purchase__box .ttl {
  position: relative;
  font-size: 2.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  border-bottom: 2px solid #A3A3A3;
  padding-bottom: 0.6rem;
  margin-bottom: 2.4rem;
}
.p-purchase__box .ttl::before {
  content: "";
  position: absolute;
  bottom: -2px;
  width: 7.2rem;
  height: 2px;
  background: #004EA2;
}
.p-purchase__box .txt {
  font-size: 1.4rem;
  letter-spacing: 0.1em;
}
.p-purchase__box .btn {
  width: 26rem;
  margin: auto;
  margin-top: 2.4rem;
  text-align: center;
}
.p-purchase__box .c-btnA span {
  width: 100%;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .p-purchase__block {
    padding: 3rem 2rem;
    grid-template-columns: none;
    gap: 3.2rem;
  }
  .p-purchase__box .ttl {
    font-size: 2rem;
    margin-bottom: 1.6rem;
  }
  .p-purchase__box .btn {
    margin-top: 1.6rem;
  }
}
/*--------------------------------------
  products_gyou/solution
--------------------------------------*/
.p-solution__lead {
  padding: 0 20px;
  margin-bottom: 4rem;
}
.p-solution__lead .main_ttl {
  position: relative;
  color: #004EA2;
  font-size: 2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  border-bottom: 2px solid #A3A3A3;
  padding-bottom: 1.4rem;
  margin-bottom: 2.4rem;
}
.p-solution__lead .main_ttl::before {
  content: "";
  position: absolute;
  bottom: -2px;
  width: 12.1rem;
  height: 2px;
  background: #004EA2;
}
.p-solution__lead .ttl {
  font-size: 1.6rem;
  color: #004EA2;
  display: flex;
  gap: 0.75rem;
  margin-bottom: 1.6rem;
}
.p-solution__lead .ttl::before {
  content: "●";
  font-size: 1.1rem;
  margin-top: 5px;
}
.p-solution__lead .txt {
  font-size: 1.4rem;
  letter-spacing: 0.1em;
}
.p-solution__lead .txt a {
  text-decoration: underline;
  color: #004EA2;
}
@media screen and (min-width: 768px), print {
  .p-solution__lead .txt a {
    cursor: pointer;
    transition: 0.3s opacity !important;
  }
  .p-solution__lead .txt a:hover {
    opacity: 0.6;
  }
}
@media screen and (max-width: 767px) {
  .p-solution__lead {
    padding: 0 1rem;
    margin-bottom: 2.4rem;
  }
  .p-solution__lead .ttl {
    font-size: 1.6rem;
  }
}

.p-solution__block {
  display: flex;
  flex-wrap: wrap;
  gap: 3.2rem;
}

.p-solution__box {
  border: 1px solid #001A4C;
  border-radius: 1rem;
  padding: 4rem;
}

.p-solution__box_top {
  display: grid;
  grid-template-rows: 1fr;
  grid-template-columns: 1fr 18rem;
  -moz-column-gap: 3rem;
       column-gap: 3rem;
}
.p-solution__box_top .ttl {
  grid-row: 1/2;
  grid-column: 1/2;
  font-size: 2rem;
  margin-bottom: 1rem;
}
.p-solution__box_top .ttl a {
  display: flex;
  justify-content: space-between;
  gap: 2rem;
}
@media screen and (min-width: 768px), print {
  .p-solution__box_top .ttl a {
    cursor: pointer;
    transition: 0.3s opacity !important;
  }
  .p-solution__box_top .ttl a:hover {
    opacity: 0.6;
  }
}
.p-solution__box_top .ttl .sub {
  display: block;
  font-size: 1.2rem;
  opacity: 0.8;
}
.p-solution__box_top .ttl svg {
  width: 4rem;
  height: 4rem;
  color: #004EA2;
}
.p-solution__box_top .ttl svg circle {
  fill: #004EA2;
}
.p-solution__box_top .ttl svg line, .p-solution__box_top .ttl svg path {
  stroke: #fff;
}
.p-solution__box_top .txt {
  grid-row: 2/3;
  grid-column: 1/2;
  font-size: 1.4rem;
}
.p-solution__box_top .txt .img {
  display: block;
  margin-top: 1rem;
}
.p-solution__box_top .img {
  grid-row: 1/3;
  grid-column: 2/3;
}
.p-solution__box_top .img .imgInner {
  width: 18rem;
  height: 12rem;
  border: 1px solid #E2E2E2;
  border-radius: 1rem;
  padding: 2rem;
}
@media screen and (max-width: 767px), print {
  .p-solution__box_top .img .imgInner {
    width: 100%;
    height: 6rem;
    padding: 0.8rem;
  }
}
.p-solution__box_top .img .imgInner img {
  height: 100%;
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.p-solution__product_box {
  margin-top: 1.3rem;
}
.p-solution__product_box > dt {
  display: flex;
  align-items: center;
  font-size: 1.4rem;
  font-weight: 700;
}
.p-solution__product_box > dt span {
  flex-shrink: 0;
}
.p-solution__product_box > dt::after {
  content: "";
  border-top: 1px solid rgba(0, 26, 76, 0.3);
  width: 100%;
  margin-left: 1rem;
}
.p-solution__product_box > dd {
  margin-top: 0.8rem;
}
.p-solution__product_box > dd > ul {
  padding-left: 1.4rem;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 2rem;
}
.p-solution__product_box > dd > ul li {
  font-size: 1.2rem;
  color: #004EA2;
  display: flex;
  align-items: center;
  gap: 0.2rem;
}
.p-solution__product_box > dd > ul li::before {
  content: "";
  background: url(/assets_renew/images/common/ic-arrow-circle-right-blue02.svg) no-repeat;
  background-size: contain;
  width: 1.4rem;
  height: 1.4rem;
  flex-shrink: 0;
}
@media screen and (min-width: 768px), print {
  .p-solution__product_box > dd > ul li a {
    cursor: pointer;
    transition: 0.3s opacity !important;
  }
  .p-solution__product_box > dd > ul li a:hover {
    opacity: 0.6;
  }
}

@media screen and (max-width: 767px) {
  .p-solution__block {
    width: 100vw;
    margin: 0 calc(50% - 50vw);
    gap: 0;
    border-top: 1px solid #001A4C;
  }
  .p-solution__box {
    border-top: none;
    border-left: none;
    border-right: none;
    border-radius: 0;
    padding: 3rem 2rem;
  }
  .p-solution__box_top {
    grid-template-rows: 1fr;
    grid-template-columns: 9rem 1fr;
    gap: 1.6rem;
  }
  .p-solution__box_top .ttl {
    font-size: 1.8rem;
    grid-row: 1/2;
    grid-column: 1/3;
    margin-bottom: 0;
  }
  .p-solution__box_top .ttl a {
    align-items: center;
  }
  .p-solution__box_top .txt {
    font-size: 1.2rem;
    grid-row: 2/3;
    grid-column: 2/3;
  }
  .p-solution__box_top .img {
    grid-row: 2/3;
    grid-column: 1/2;
  }
  .p-solution__product_box {
    display: grid;
    grid-template-columns: 9rem 1fr;
    gap: 1.6rem;
    align-items: start;
  }
  .p-solution__product_box dt {
    justify-content: space-between;
    position: relative;
  }
  .p-solution__product_box dt::after {
    border-top: none;
    border-right: 1px solid rgba(0, 26, 76, 0.3);
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    margin-left: 0;
  }
  .p-solution__product_box dd {
    margin-top: 0;
  }
  .p-solution__product_box dd > ul {
    flex-wrap: wrap;
    padding: 0;
    gap: 0.8rem;
  }
  .p-solution__product_box dd > ul > li {
    width: 100%;
    align-items: normal;
  }
  .p-solution__product_box dd > ul > li::before {
    margin-top: 0.4rem;
  }
}
.p-solution__telWrap {
  background-color: #ECF2FA;
  padding: 2.4rem 2.4rem 3.6rem;
  text-align: center;
  margin-top: 6rem;
}
.p-solution__telWrap .ttl {
  background-color: #004EA2;
  border-radius: 70px;
  width: 100%;
  max-width: 58.4rem;
  margin: auto;
  font-size: 1.6rem;
  color: #fff;
  padding: 0.6rem 0;
  margin-bottom: 1.7rem;
}
.p-solution__telWrap .name {
  font-size: 1.4rem;
  color: #004EA2;
  font-weight: 700;
}
.p-solution__telWrap .tel {
  font-size: 2.8rem;
  font-family: "Roboto", sans-serif;
}
.p-solution__telWrap .info {
  font-size: 1.4rem;
}

@media screen and (max-width: 767px) {
  .p-solution__telWrap {
    margin-top: 3rem;
    padding: 1.6rem 1rem 2.8rem;
  }
  .p-solution__telWrap .tel {
    line-height: 1.3;
  }
}
/*--------------------------------------
  products_gyou/brochure
--------------------------------------*/
.p-brochure__lead {
  padding: 0 20px;
  margin-bottom: 4rem;
}
.p-brochure__lead .main_ttl {
  position: relative;
  color: #004EA2;
  font-size: 2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  border-bottom: 2px solid #A3A3A3;
  padding-bottom: 1.4rem;
  margin-bottom: 2.4rem;
}
.p-brochure__lead .main_ttl::before {
  content: "";
  position: absolute;
  bottom: -2px;
  width: 12.1rem;
  height: 2px;
  background: #004EA2;
}
.p-brochure__lead .ttl {
  font-size: 1.6rem;
  color: #004EA2;
  display: flex;
  gap: 0.75rem;
  margin-bottom: 1.6rem;
}
.p-brochure__lead .ttl::before {
  content: "●";
  font-size: 1.1rem;
  margin-top: 5px;
}
.p-brochure__lead .txt {
  font-size: 1.4rem;
  letter-spacing: 0.1em;
}
.p-brochure__lead .txt a {
  text-decoration: underline;
  color: #004EA2;
}
@media screen and (min-width: 768px), print {
  .p-brochure__lead .txt a {
    cursor: pointer;
    transition: 0.3s opacity !important;
  }
  .p-brochure__lead .txt a:hover {
    opacity: 0.6;
  }
}
@media screen and (max-width: 767px) {
  .p-brochure__lead {
    padding: 0 1rem;
    margin-bottom: 2.4rem;
  }
  .p-brochure__lead .ttl {
    font-size: 1.6rem;
  }
}

.p-brochure__block {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 4rem 2rem;
}

.p-brochure__box {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}
.p-brochure__box .imgArea {
  width: 100%;
  height: 16rem;
  border: 1px solid #e2e2e2;
  padding: 1rem;
  border-radius: 1rem;
}
@media screen and (max-width: 767px), print {
  .p-brochure__box .imgArea {
    height: 9.6rem;
  }
}
.p-brochure__box .imgArea img {
  height: 100%;
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center center;
     object-position: center center;
}
.p-brochure__box .txtArea {
  flex-grow: 1;
}
.p-brochure__box .txtArea h3.ttl {
  font-size: 1.2rem;
  color: #004EA2;
  margin-bottom: 0.6rem;
}
.p-brochure__box .txtArea h3.ttl em {
  font-size: 1.4rem;
  display: block;
  font-style: normal;
}
.p-brochure__box .txtArea .txt {
  font-size: 1.2rem;
  opacity: 0.8;
}
.p-brochure__box .btnArea {
  border-top: 1px solid rgba(0, 26, 76, 0.3);
  padding-top: 1rem;
}
.p-brochure__box .btnArea .btnBox {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}
.p-brochure__box .btnArea .btnBox a {
  width: 100%;
}
.p-brochure__box .btnArea .btn_txt {
  text-align: center;
  font-size: 1.2rem;
  opacity: 0.8;
  margin-top: 0.5rem;
}

@media screen and (max-width: 767px) {
  .p-brochure__block {
    grid-template-columns: auto;
    gap: 2.4rem;
  }
  .p-brochure__box {
    width: 100%;
    display: grid;
    grid-template-rows: 1fr;
    grid-template-columns: 11.5rem 1fr;
    border-top: 1px solid rgba(0, 26, 76, 0.3);
    padding-top: 1.3rem;
  }
  .p-brochure__box .imgArea {
    grid-row: 1/2;
    grid-column: 1/2;
  }
  .p-brochure__box .txtArea {
    grid-row: 1/2;
    grid-column: 2/3;
  }
  .p-brochure__box .btnArea {
    grid-row: 2/3;
    grid-column: 1/3;
    border-top: none;
  }
  .p-brochure__box .btnArea .btnBox {
    flex-wrap: nowrap;
    gap: 0.4rem;
  }
  .p-brochure__box .btnArea .btn_txt {
    text-align: right;
  }
}
.p-brochure__catarogBtn {
  background-color: #004EA2;
  color: #fff;
  font-size: 1.2rem;
  padding: 0.6rem 1.2rem;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  gap: 0.7rem;
  transition: 0.3s;
  border: 1px solid #004EA2;
}
.p-brochure__catarogBtn img, .p-brochure__catarogBtn svg {
  width: 1.4rem;
  transform: rotate(90deg);
  transition: 0.3s;
}
.p-brochure__catarogBtn circle, .p-brochure__catarogBtn line, .p-brochure__catarogBtn path {
  transition: 0.3s;
}
@media screen and (min-width: 768px), print {
  .p-brochure__catarogBtn:hover {
    background-color: #fff;
    color: #004EA2;
  }
  .p-brochure__catarogBtn:hover circle {
    fill: #004EA2;
  }
  .p-brochure__catarogBtn:hover line, .p-brochure__catarogBtn:hover path {
    stroke: #fff;
  }
}
.p-brochure__catarogBtn.catarogBtn_w {
  background-color: #fff;
  border: 1px solid #001A4C;
  color: #001A4C;
}
.p-brochure__catarogBtn.catarogBtn_w svg circle {
  fill: #001A4C;
}
.p-brochure__catarogBtn.catarogBtn_w svg line, .p-brochure__catarogBtn.catarogBtn_w svg path {
  stroke: #fff;
}
@media screen and (min-width: 768px), print {
  .p-brochure__catarogBtn.catarogBtn_w:hover {
    background-color: #001A4C;
    color: #fff;
  }
  .p-brochure__catarogBtn.catarogBtn_w:hover circle {
    fill: #fff;
  }
  .p-brochure__catarogBtn.catarogBtn_w:hover line, .p-brochure__catarogBtn.catarogBtn_w:hover path {
    stroke: #001A4C;
  }
}

/*--------------------------------------
  products_gyou/case
--------------------------------------*/
/*--------------------------------------
  archive
--------------------------------------*/
.p-case__searchBox {
  background-color: #ECF2FA;
  padding: 3rem 4rem;
}

.p-case__searcForm .ttl {
  position: relative;
  font-size: 2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  border-bottom: 2px solid #A3A3A3;
  padding-bottom: 0.6rem;
  margin-bottom: 2.4rem;
}
.p-case__searcForm .ttl::before {
  content: "";
  position: absolute;
  bottom: -2px;
  width: 14rem;
  height: 2px;
  background: #004EA2;
}
.p-case__searcForm .searchBox {
  display: grid;
  grid-template-columns: 11.9rem 1fr;
  gap: 2rem;
}
.p-case__searcForm .searchBox dt {
  display: flex;
  gap: 0.5rem;
  font-size: 1.6rem;
}
.p-case__searcForm .searchBox dt img, .p-case__searcForm .searchBox dt svg {
  width: 2rem;
  height: 2rem;
  margin-top: 0.5rem;
}
.p-case__searcForm .searchBox .labelBox {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
}
.p-case__searcForm .searchBox .checkbox-label {
  cursor: pointer;
}
.p-case__searcForm .searchBox .checkbox-label .hidden-checkbox {
  display: none;
}
.p-case__searcForm .searchBox .checkbox-label .hidden-checkbox:checked + .checkbox-text {
  background-color: #004EA2;
  border-color: #004EA2;
  color: #fff;
}
.p-case__searcForm .searchBox .checkbox-label .checkbox-text {
  font-size: 1.4rem;
  background-color: #fff;
  border: 1px solid #A3A3A3;
  border-radius: 9999px;
  padding: 0.4rem 2rem;
  display: block;
}
.p-case__searcForm .searchBox + .searchBox {
  margin-top: 4rem;
}
.p-case__searcForm .btnArea {
  margin-top: 4rem;
  display: flex;
  justify-content: center;
  gap: 2rem;
}
.p-case__searcForm .btnArea button {
  cursor: pointer;
}
.p-case__searcForm .btnArea .submitBtn {
  width: 23rem;
}
.p-case__searcForm .btnArea .submitBtn span {
  width: 100%;
}
.p-case__searcForm .btnArea .resetBtn {
  width: 17rem;
  text-align: center;
  padding: 0 1rem;
  justify-content: center;
  background-color: #fff;
  color: #004EA2;
}
.p-case__searcForm .btnArea .resetBtn:hover {
  opacity: 0.7;
}

@media screen and (max-width: 767px) {
  .p-case__searchMask {
    background-color: rgba(0, 26, 76, 0.9019607843);
    opacity: 0;
    z-index: 100;
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    pointer-events: none;
    transition: 0.3s opacity !important;
  }
  html.is-caseSearch .p-case__searchMask {
    pointer-events: auto;
    opacity: 1;
  }
  .js-caseSearch-close {
    position: absolute;
    right: 1.8rem;
    top: 1.6rem;
    z-index: 2;
  }
  .p-case__searchBox {
    border-radius: 2rem 2rem 0 0;
    padding: 1.6rem 2.4rem 4.2rem;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
  }
  .p-case__searcForm .ttl {
    text-align: center;
    font-size: 1.8rem;
    margin-bottom: 1.6rem;
  }
  .p-case__searcForm .ttl::before {
    content: none;
  }
  .p-case__searcForm .searchBox {
    grid-template-columns: auto;
    gap: 1.2rem;
  }
  .p-case__searcForm .searchBox + .searchBox {
    margin-top: 3rem;
  }
  .p-case__searcForm .btnArea {
    gap: 0.8rem;
  }
  .p-case__searcForm .btnArea .submitBtn, .p-case__searcForm .btnArea .resetBtn {
    width: 50%;
  }
  .p-case__searchDrawer {
    position: fixed;
    bottom: 1rem;
    left: 0;
    right: 0;
    z-index: 10;
    transition: 0.3s;
  }
  .p-case__searchDrawer.is-hidden {
    opacity: 0;
    pointer-events: none;
  }
  .js-caseSearch-trigger {
    width: 38rem;
    margin: auto;
    padding: 0.8rem;
    background-color: #ECF2FA;
    border-radius: 9999px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-align: center;
  }
  .js-caseSearch-trigger span {
    width: 100%;
  }
  .js-caseSearch-trigger img, .js-caseSearch-trigger svg {
    width: 3.6rem;
  }
}
.p-case__listWrap {
  margin-top: 2rem;
}

.p-case__number {
  font-size: 1.4rem;
  border-bottom: 2px solid #A3A3A3;
  margin-bottom: 2rem;
  display: flex;
  align-items: center;
  gap: 0.8rem;
  margin-top: -6.6rem;
  padding-top: 6.6rem;
}
.p-case__number .num {
  font-size: 1.4rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.p-case__number .num em {
  font-size: 2.8rem;
  font-style: normal;
  font-family: "Roboto", sans-serif;
  line-height: 1.3;
}

.p-case__list {
  display: flex;
  flex-wrap: wrap;
  gap: 1.6rem;
}
.p-case__list .listBox {
  width: 100%;
  border: 1px solid #001A4C;
  border-radius: 1rem;
}
.p-case__list .listBox > a {
  padding: 2rem 4rem;
  display: block;
  width: 100%;
  height: 100%;
}
@media screen and (min-width: 768px), print {
  .p-case__list .listBox > a {
    cursor: pointer;
    transition: 0.3s opacity !important;
  }
  .p-case__list .listBox > a:hover {
    opacity: 0.8;
  }
}
.p-case__list .listBox .tagList {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
}
.p-case__list .listBox .tagList > li {
  background-color: #004EA2;
  border-radius: 9999px;
  color: #fff;
  font-size: 1.4rem;
  padding: 0.4rem 2rem;
}
.p-case__list .listBox .box {
  margin-top: 2rem;
  display: grid;
  grid-template-rows: auto;
  grid-template-columns: 12rem 1fr;
  gap: 0 2rem;
}
.p-case__list .listBox .box .imgArea {
  grid-row: 1/4;
  grid-column: 1/2;
}
.p-case__list .listBox .box .txtTop {
  grid-row: 1/2;
  grid-column: 2/3;
  font-size: 1.2rem;
  opacity: 0.8;
}
.p-case__list .listBox .box .ttlArea {
  grid-row: 2/3;
  grid-column: 2/3;
  border-bottom: 1px solid;
  padding-bottom: 1rem;
}
.p-case__list .listBox .box .ttlArea .ttl {
  font-size: 2.2rem;
}
.p-case__list .listBox .box .ttlArea .addressTag {
  background-color: #ECF2FA;
  border-radius: 0.2rem;
  font-size: 1.2rem;
  opacity: 0.8;
  padding: 0 0.8rem;
  display: inline-block;
  margin-top: 0.6rem;
}
.p-case__list .listBox .box .txt {
  grid-row: 3/4;
  grid-column: 2/3;
  font-size: 1.4rem;
  margin-top: 1.6rem;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.p-case__notfound {
  text-align: center;
}

@media screen and (max-width: 767px) {
  .p-case__number .num {
    letter-spacing: 0;
  }
  .p-case__number .num em {
    font-size: 2rem;
  }
  .p-case__list .listBox > a {
    padding: 1.6rem;
  }
  .p-case__list .listBox .tagList {
    gap: 0.4rem;
  }
  .p-case__list .listBox .tagList li {
    font-size: 1.2rem;
    padding: 0.2rem 1.2rem;
  }
  .p-case__list .listBox .box {
    grid-template-columns: 7.7rem 1fr;
    gap: 0 0.8rem;
    margin-top: 0.8rem;
  }
  .p-case__list .listBox .box .txttop {
    grid-row: 1/2;
    grid-column: 1/3;
    font-size: 1.2rem;
    margin-bottom: 0.8rem;
  }
  .p-case__list .listBox .box .ttlArea {
    grid-row: 2/3;
    grid-column: 2/3;
    border-bottom: none;
  }
  .p-case__list .listBox .box .ttlArea .ttl {
    font-size: 1.6rem;
    line-height: 1.5;
  }
  .p-case__list .listBox .box .txt {
    display: none;
  }
  .p-case__list .listBox .box .imgArea {
    grid-row: 2/3;
    grid-column: 1/2;
  }
}
/*--------------------------------------
  single
--------------------------------------*/
.p-caseSingle__ttl {
  background-color: #004EA2;
  border-radius: 0.6rem;
  padding: 1.4rem 1.6rem;
  font-size: 2.4rem;
  color: #fff;
  display: flex;
  gap: 1.3rem;
  margin-bottom: 4rem;
}
.p-caseSingle__ttl::before {
  content: "";
  border-left: 7px solid #fff;
  border-radius: 5rem;
  height: 2.5rem;
  margin-top: 0.9rem;
}

.p-caseSingle__maimimg {
  width: 100%;
  max-width: 55rem;
  margin: auto;
  margin-bottom: 2.4rem;
}

.p-caseSingle__txt {
  font-size: 1.4rem;
  margin-bottom: 4rem;
  letter-spacing: 0.1em;
}

.p-caseSingle__info {
  display: grid;
  grid-template-columns: 15.5rem 1fr;
  margin-bottom: 6.7rem;
}
.p-caseSingle__info .el {
  padding: 2rem 1.5rem;
  font-size: 1.4rem;
}
.p-caseSingle__info dt {
  color: #004EA2;
  font-weight: 700;
  border-bottom: 1px solid #004EA2;
}
.p-caseSingle__info dt:first-of-type {
  border-top: 1px solid #004EA2;
}
.p-caseSingle__info dd {
  border-bottom: 1px solid rgba(0, 26, 76, 0.2);
}
.p-caseSingle__info dd:first-of-type {
  border-top: 1px solid rgba(0, 26, 76, 0.2);
}

.p-caseSingle__imgArea {
  margin-bottom: 6rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 3.3rem;
}
.p-caseSingle__box {
  margin-top: 6rem;
}
.p-caseSingle__box h3.ttl {
  position: relative;
  color: #004EA2;
  font-size: 2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  border-bottom: 2px solid #A3A3A3;
  padding-bottom: 1.4rem;
  margin-bottom: 2.4rem;
}
.p-caseSingle__box h3.ttl::before {
  content: "";
  position: absolute;
  bottom: -2px;
  width: 12.1rem;
  height: 2px;
  background: #004EA2;
}
.p-caseSingle__box h4.sub_ttl {
  font-size: 1.6rem;
  color: #004EA2;
  display: flex;
  gap: 0.75rem;
  margin-bottom: 1.6rem;
}
.p-caseSingle__box h4.sub_ttl::before {
  content: "●";
  font-size: 1.1rem;
  margin-top: 5px;
}
.p-caseSingle__box .txtArea .txt {
  font-size: 1.4rem;
  margin-bottom: 2rem;
}
.p-caseSingle__box .txtArea .txt iframe {
  width: 66%;
  height: 38rem;
  display: block;
  margin: 0 auto;
}
@media screen and (max-width: 767px), print {
  .p-caseSingle__box .txtArea .txt iframe {
    width: 100%;
    height: 20rem;
  }
}
.p-caseSingle__box .txtArea.imgSet {
  display: flex;
  gap: 2rem;
}
.p-caseSingle__box .txtArea.imgSet .img {
  width: 100%;
  max-width: 18.8rem;
  flex-shrink: 0;
}
.p-caseSingle__btnArea {
  display: flex;
  justify-content: center;
  gap: 2rem;
  margin-top: 4.3rem;
}
.p-caseSingle__btnArea .c-btnA {
  min-width: 26rem;
  gap: 1rem;
}
.p-caseSingle__btnArea .c-btnA span {
  width: 100%;
  text-align: center;
}
.p-caseSingle__btnArea .c-btnA:first-of-type {
  min-width: 17.2rem;
  background-color: #fff;
  color: #001A4C;
  flex-direction: row-reverse;
  padding-left: 1rem;
  padding-right: 2.5rem;
}
.p-caseSingle__btnArea .c-btnA:first-of-type img, .p-caseSingle__btnArea .c-btnA:first-of-type svg {
  transform: rotate(180deg);
}
.p-caseSingle__btnArea .c-btnA:first-of-type img circle, .p-caseSingle__btnArea .c-btnA:first-of-type svg circle {
  fill: #fff;
  stroke: #004EA2;
  stroke-width: 1px;
}
.p-caseSingle__btnArea .c-btnA:first-of-type img line, .p-caseSingle__btnArea .c-btnA:first-of-type img path, .p-caseSingle__btnArea .c-btnA:first-of-type svg line, .p-caseSingle__btnArea .c-btnA:first-of-type svg path {
  stroke: #004EA2;
}
@media screen and (min-width: 768px), print {
  .p-caseSingle__btnArea .c-btnA:first-of-type:hover {
    background-color: #004EA2;
    color: #fff;
  }
}

.p-case__interview {
  border: 1px solid #001A4C;
  border-radius: 1rem;
  padding: 2.4rem 4rem;
  margin-top: 6rem;
}
@media screen and (max-width: 767px), print {
  .p-case__interview {
    padding: 2.4rem 1.5rem 2rem;
  }
}
.p-case__interview h4 {
  background: #ECF2FA;
  border-radius: 9999px;
  text-align: center;
  font-size: 1.2rem;
  min-height: 3.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #004EA2;
}
.p-case__interview h3 {
  margin-top: 1.2rem;
  color: #004EA2;
  font-size: 2rem;
}
@media screen and (max-width: 767px), print {
  .p-case__interview h3 {
    font-size: 1.6rem;
  }
}
.p-case__interview p {
  margin-top: 1.2rem;
  font-size: 1.4rem;
}
.p-case__interview .link {
  font-size: 1.4rem;
  margin-top: 1rem;
}
.p-case__interview .link a {
  color: #004EA2;
  text-decoration: underline;
  text-underline-offset: 0.5rem;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  transition: 0.3s;
  line-height: 1.8;
}
.p-case__interview .link a:hover {
  opacity: 0.7;
}
.p-case__interview .link a img, .p-case__interview .link a svg {
  width: 1.2rem;
}
.p-case__interview .link a img *, .p-case__interview .link a svg * {
  stroke: #004EA2 !important;
}
.p-case__interview .link a img path:first-of-type, .p-case__interview .link a svg path:first-of-type {
  fill: #004EA2 !important;
}

@media screen and (max-width: 767px) {
  .p-caseSingle__ttl {
    margin-bottom: 1.6rem;
  }
  .p-caseSingle__txt {
    margin-bottom: 2.4rem;
  }
  .p-caseSingle__info {
    grid-template-columns: 9rem 1fr;
    margin-bottom: 4rem;
  }
  .p-caseSingle__info .el {
    padding: 1.4rem 0.1rem;
  }
  .p-caseSingle__info dd {
    padding-left: 2rem;
  }
  .p-caseSingle__imgArea {
    grid-template-columns: auto;
    gap: 1.2rem;
  }
  .p-caseSingle__box {
    margin-top: 4rem;
  }
  .p-caseSingle__box h3.ttl {
    margin-bottom: 1.8rem;
  }
  .p-caseSingle__box h4.sub_ttl {
    margin-bottom: 1.8rem;
  }
  .p-caseSingle__box .txtArea.imgSet {
    flex-wrap: wrap;
  }
  .p-caseSingle__box .txtArea.imgSet .img {
    width: 100%;
    max-width: none;
  }
  .p-caseSingle__btnArea {
    flex-wrap: wrap;
    margin-top: 4rem;
  }
}
/*--------------------------------------
  products_gyou/top
--------------------------------------*/
.p-products_gyou__sec .secttl {
  position: relative;
  font-size: 2.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  border-bottom: 2px solid #A3A3A3;
  padding-bottom: 0.6rem;
  margin-bottom: 2.7rem;
  line-height: 1.7;
}
.p-products_gyou__sec .secttl::before {
  content: "";
  position: absolute;
  bottom: -2px;
  width: 12.1rem;
  height: 2px;
  background: #004EA2;
}
.p-products_gyou__sec .products_box {
  position: relative;
  border: 1px solid;
  border-radius: 1rem;
  overflow: hidden;
}
@media screen and (max-width: 767px), print {
  .p-products_gyou__sec .products_box {
    transition: 0.3s;
    height: 55rem;
  }
}
.p-products_gyou__sec .products_box .linkWrap {
  padding: 2rem 0 2.3rem;
  display: block;
  transition: 0.3s;
}
.p-products_gyou__sec .products_box a.linkWrap:hover {
  opacity: 0.8;
}
.p-products_gyou__sec .products_box .top_txt {
  background-color: #ECF2FA;
  color: #004EA2;
  border-radius: 9999px;
  font-size: 1.4rem;
  text-align: center;
  margin: 0 4rem;
  margin-bottom: 1.2rem;
  padding: 0.3rem 2rem;
}
.p-products_gyou__sec .products_box .ttlArea {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid;
  padding-bottom: 1rem;
  margin: 0 4rem;
  margin-bottom: 1.5rem;
}
.p-products_gyou__sec .products_box .ttlArea .ttl {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  line-height: 1.3;
}
.p-products_gyou__sec .products_box .ttlArea .ttl .sub {
  font-size: 1.2rem;
  background-color: #004EA2;
  color: #fff;
  padding: 0.3rem 1rem;
}
.p-products_gyou__sec .products_box .ttlArea .ttl .main_ttl {
  font-size: 2.6rem;
}
.p-products_gyou__sec .products_box .ttlArea .price {
  display: flex;
  align-items: center;
  justify-content: end;
  gap: 0.5rem;
  font-size: 1.2rem;
  margin-top: 1rem;
}
.p-products_gyou__sec .products_box .ttlArea .price .num {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.p-products_gyou__sec .products_box .ttlArea .price .num em {
  font-size: 2.8rem;
  font-family: "Roboto", sans-serif;
  font-style: normal;
  line-height: 1;
  letter-spacing: 0;
}
.p-products_gyou__sec .products_box .box {
  display: grid;
  grid-template-columns: 20rem 1fr;
  gap: 3rem;
  margin: 0 4rem;
}
.p-products_gyou__sec .products_box .box .imgArea {
  position: relative;
  margin-top: 0.5rem;
  width: 20rem;
  height: 16.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #EDEDED;
  border-radius: 1rem;
}
.p-products_gyou__sec .products_box .box .imgArea img {
  width: 11rem;
  max-height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.p-products_gyou__sec .products_box .box .imgArea.full {
  width: 100%;
  background: none;
  height: auto;
}
.p-products_gyou__sec .products_box .box .imgArea.full img {
  width: 100%;
}
.p-products_gyou__sec .products_box .box .imgArea .deco {
  position: absolute;
  top: -1rem;
  left: -2rem;
  width: 6.8rem;
}
.p-products_gyou__sec .products_box .box .txtArea .tagList {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem 1.8rem;
  margin-bottom: 0.9rem;
}
.p-products_gyou__sec .products_box .box .txtArea .tagList li {
  color: #007DA2;
  font-size: 1.1rem;
}
.p-products_gyou__sec .products_box .box .txtArea h3.ttl {
  font-size: 1.4rem;
  font-weight: 700;
  margin-bottom: 0.4rem;
}
.p-products_gyou__sec .products_box .box .txtArea .txt {
  font-size: 1.3rem;
  opacity: 0.8;
}
.p-products_gyou__sec .products_box .box .txtArea .btnArea {
  margin-top: 1.6rem;
  display: flex;
  gap: 1.2rem;
}
.p-products_gyou__sec .products_box .box .txtArea .btnArea a {
  width: 19rem;
}
.p-products_gyou__sec .products_box .products_boxBottom {
  background-color: #001A4C;
  padding: 1rem 3rem;
}
.p-products_gyou__sec .products_box .nextBtnWrap {
  position: absolute;
  height: 10rem;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0), #ffffff 70%);
}
.p-products_gyou__sec .products_box .linkList {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.4rem;
}
.p-products_gyou__sec .products_box .linkList li {
  color: #fff;
  font-size: 1.3rem;
}
.p-products_gyou__sec .products_box .linkList li a {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  color: #fff;
}
.p-products_gyou__sec .products_box .linkList li a img, .p-products_gyou__sec .products_box .linkList li a svg {
  width: 1.4rem;
}
.p-products_gyou__sec .products_box .linkList li a img circle, .p-products_gyou__sec .products_box .linkList li a svg circle {
  fill: #fff;
}
.p-products_gyou__sec .products_box .linkList li a img path, .p-products_gyou__sec .products_box .linkList li a svg path {
  stroke: #001A4C;
}
@media screen and (min-width: 768px), print {
  .p-products_gyou__sec .products_box .linkList li a {
    cursor: pointer;
    transition: 0.3s opacity !important;
  }
  .p-products_gyou__sec .products_box .linkList li a:hover {
    opacity: 0.6;
  }
}
.p-products_gyou__sec .products_box.new::after {
  content: "NEW";
  position: absolute;
  top: -3rem;
  left: -3rem;
  background-color: #FFDC41;
  color: #004EA2;
  font-size: 1.8rem;
  font-weight: 700;
  padding: 3rem 4rem;
  padding-top: 4rem;
  border-bottom-right-radius: 9999px;
}
.p-products_gyou__sec .products_box + .products_box {
  margin-top: 3.2rem;
}
.p-products_gyou__sec .p-product-top__mainBtn {
  background-color: #004EA2;
  color: #fff;
  font-size: 1.2rem;
  letter-spacing: 0;
  padding: 0.6rem 1.2rem;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  gap: 0.7rem;
  transition: 0.3s;
  border: 1px solid #004EA2;
}
.p-products_gyou__sec .p-product-top__mainBtn img, .p-products_gyou__sec .p-product-top__mainBtn svg {
  width: 1.4rem;
  transform: rotate(90deg);
  transition: 0.3s;
}
.p-products_gyou__sec .p-product-top__mainBtn circle, .p-products_gyou__sec .p-product-top__mainBtn line, .p-products_gyou__sec .p-product-top__mainBtn path {
  transition: 0.3s;
}
@media screen and (min-width: 768px), print {
  .p-products_gyou__sec .p-product-top__mainBtn:hover {
    background-color: #fff;
    color: #004EA2;
  }
  .p-products_gyou__sec .p-product-top__mainBtn:hover circle {
    fill: #004EA2;
  }
  .p-products_gyou__sec .p-product-top__mainBtn:hover line, .p-products_gyou__sec .p-product-top__mainBtn:hover path {
    stroke: #fff;
  }
}
.p-products_gyou__sec .p-product-top__mainBtn.mainBtn_w {
  background-color: #fff;
  border: 1px solid #001A4C;
  color: #001A4C;
  border-color: #004EA2;
}
.p-products_gyou__sec .p-product-top__mainBtn.mainBtn_w svg circle {
  fill: #001A4C;
}
.p-products_gyou__sec .p-product-top__mainBtn.mainBtn_w svg line, .p-products_gyou__sec .p-product-top__mainBtn.mainBtn_w svg path {
  stroke: #fff;
}
@media screen and (min-width: 768px), print {
  .p-products_gyou__sec .p-product-top__mainBtn.mainBtn_w:hover {
    background-color: #001A4C;
    color: #fff;
  }
  .p-products_gyou__sec .p-product-top__mainBtn.mainBtn_w:hover circle {
    fill: #fff;
  }
  .p-products_gyou__sec .p-product-top__mainBtn.mainBtn_w:hover line, .p-products_gyou__sec .p-product-top__mainBtn.mainBtn_w:hover path {
    stroke: #001A4C;
  }
}
.p-products_gyou__sec + .p-products_gyou__sec {
  margin-top: 4rem;
}
@media screen and (max-width: 767px) {
  .p-products_gyou__sec .secttl {
    font-size: 2rem;
  }
  .p-products_gyou__sec .products_box .top_txt {
    font-size: 1.2rem;
    margin: 0 2rem;
    margin-bottom: 1.5rem;
  }
  .p-products_gyou__sec .products_box .ttlArea {
    flex-wrap: wrap;
    border-bottom: none;
    margin: 0 2rem;
    margin-bottom: 1.5rem;
  }
  .p-products_gyou__sec .products_box .ttlArea .ttl {
    width: 100%;
    flex-wrap: wrap;
    border-bottom: 1px solid;
    gap: 0.3rem;
    padding-bottom: 0.5rem;
  }
  .p-products_gyou__sec .products_box .ttlArea .ttl .sub {
    font-size: 1.2rem;
  }
  .p-products_gyou__sec .products_box .ttlArea .ttl .main_ttl {
    font-size: 2rem;
    display: block;
    width: 100%;
  }
  .p-products_gyou__sec .products_box .ttlArea .price {
    width: 100%;
    text-align: right;
    align-items: end;
    font-size: 1.2rem;
  }
  .p-products_gyou__sec .products_box .ttlArea .price .num {
    align-items: end;
  }
  .p-products_gyou__sec .products_box .ttlArea .price .num em {
    font-size: 2.4rem;
  }
  .p-products_gyou__sec .products_box .box {
    grid-template-columns: auto;
    margin: 0 2rem;
  }
  .p-products_gyou__sec .products_box .box .imgArea {
    width: 20rem;
    margin: auto;
    text-align: center;
  }
  .p-products_gyou__sec .products_box .box .btnArea {
    flex-wrap: wrap;
    justify-content: center;
  }
  .p-products_gyou__sec .products_box .box .btnArea a {
    width: 18rem;
  }
  .p-products_gyou__sec .products_box .products_boxBottom {
    background-color: #001A4C;
    padding: 1rem 2rem;
  }
  .p-products_gyou__sec .products_box.is-active .js-productsGyou__box-Open {
    display: none;
  }
  .p-products_gyou__sec .products_box .hiddenArea {
    transition: 1s opacity !important;
    animation: show 0.3s linear 0s;
  }
  @keyframes show {
    from {
      opacity: 0;
    }
    to {
      opacity: 1;
    }
  }
  .p-products_gyou__sec .js-productsGyou__box-Btn {
    height: 3.2rem;
    margin-left: 2rem;
    margin-right: 2rem;
    border-radius: 9999px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 1.2rem;
    width: 16rem;
  }
  .p-products_gyou__sec .js-productsGyou__box-Btn span {
    width: 100%;
    text-align: center;
    font-size: 1.2rem;
  }
  .p-products_gyou__sec .js-productsGyou__box-Btn img, .p-products_gyou__sec .js-productsGyou__box-Btn svg {
    width: 1.4rem;
    flex-shrink: 0;
  }
  .p-products_gyou__sec .js-productsGyou__box-BtnWrap {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 6rem;
  }
  .p-products_gyou__sec .js-productsGyou__box-Open {
    animation: show 0.3s linear 0s;
    background-color: #004EA2;
    color: #fff;
  }
  .p-products_gyou__sec .js-productsGyou__box-Open img, .p-products_gyou__sec .js-productsGyou__box-Open svg {
    transform: rotate(-90deg);
  }
  .p-products_gyou__sec .js-productsGyou__box-Open img circle, .p-products_gyou__sec .js-productsGyou__box-Open svg circle {
    fill: #fff;
  }
  .p-products_gyou__sec .js-productsGyou__box-Open img line, .p-products_gyou__sec .js-productsGyou__box-Open img path, .p-products_gyou__sec .js-productsGyou__box-Open svg line, .p-products_gyou__sec .js-productsGyou__box-Open svg path {
    stroke: #001A4C;
  }
  .p-products_gyou__sec .js-productsGyou__box-Close {
    border: 1px solid;
    background-color: #fff;
    color: #001A4C;
    margin-left: 0;
    margin-right: 0;
  }
  .p-products_gyou__sec .js-productsGyou__box-Close img, .p-products_gyou__sec .js-productsGyou__box-Close svg {
    transform: rotate(90deg);
  }
}
.p-products_gyou__sec .p-products_gyou__relatedLinkArea {
  display: grid;
  align-items: flex-start;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.6rem;
}
.p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox {
  border: 1px solid;
  border-radius: 1rem;
  padding-top: 2rem;
  overflow: hidden;
}
.p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .top_txt {
  background-color: rgb(236, 242, 250);
  color: #004EA2;
  border-radius: 9999px;
  font-size: 1.2rem;
  font-weight: 700;
  text-align: center;
  padding: 0.3rem 1rem;
  margin: 0 1.5rem;
  margin-bottom: 2.3rem;
}
.p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box {
  display: flex;
  justify-content: space-between;
  align-items: end;
  margin: 0 2rem;
}
.p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box .ttlArea .ttl .sub {
  background-color: #004EA2;
  color: #fff;
  font-size: 1.2rem;
  font-weight: 700;
  padding: 0.3rem 1rem;
  display: inline-block;
}
.p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box .ttlArea .ttl .main_ttl {
  font-size: 2.6rem;
  display: block;
}
.p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box .ttlArea .txt {
  font-size: 1.4rem;
}
.p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box svg, .p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box img {
  width: 4.9rem;
}
.p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box svg circle, .p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box img circle {
  fill: #001A4C;
}
.p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box svg path, .p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box svg line, .p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box img path, .p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box img line {
  stroke: #fff;
}
@media screen and (min-width: 768px), print {
  .p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box {
    cursor: pointer;
    transition: 0.3s opacity !important;
  }
  .p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box:hover {
    opacity: 0.6;
  }
}
.p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .btnArea {
  background-color: #001A4C;
  padding: 0.8rem 2rem;
  display: flex;
  gap: 0.8rem;
  margin-top: 2rem;
}
.p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .btnArea a {
  width: 50%;
}
.p-products_gyou__sec .p-products_gyou__relatedLinkArea .c-btnA {
  border: 2px solid #001A4C;
  background: #001A4C;
  border-radius: 0.5rem;
  padding-left: 2rem;
  padding-right: 2rem;
  height: 8rem;
}
.p-products_gyou__sec .p-products_gyou__relatedLinkArea .c-btnA .txt {
  font-size: 2rem;
  line-height: 1.3;
}
.p-products_gyou__sec .p-products_gyou__relatedLinkArea .c-btnA .txt .sub {
  display: block;
  font-size: 1.4rem;
}
@media screen and (min-width: 768px), print {
  .p-products_gyou__sec .p-products_gyou__relatedLinkArea .c-btnA:hover {
    background-color: #fff;
    color: #001A4C;
  }
  .p-products_gyou__sec .p-products_gyou__relatedLinkArea .c-btnA:hover circle {
    fill: #001A4C;
  }
  .p-products_gyou__sec .p-products_gyou__relatedLinkArea .c-btnA:hover line, .p-products_gyou__sec .p-products_gyou__relatedLinkArea .c-btnA:hover path {
    stroke: #fff;
  }
}
@media screen and (max-width: 767px) {
  .p-products_gyou__sec .p-products_gyou__relatedLinkArea {
    grid-template-columns: auto;
    gap: 0.8rem;
  }
  .p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .top_txt {
    font-size: 1.2rem;
    margin-bottom: 1.8rem;
  }
  .p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box .ttlArea h3.ttl .sub {
    font-size: 1.2rem;
  }
  .p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box .ttlArea h3.ttl .main_ttl {
    font-size: 2.6rem;
  }
  .p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box .ttlArea .txt {
    font-size: 1.4rem;
  }
  .p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .btnArea {
    padding: 0.8rem 0.6rem;
    gap: 0.4rem;
  }
  .p-products_gyou__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .btnArea a {
    padding: 0.6rem 0.8rem;
    letter-spacing: 0;
    font-size: 1.1rem;
  }
  .p-products_gyou__sec .p-products_gyou__relatedLinkArea .c-btnA {
    height: 6.8rem;
  }
  .p-products_gyou__sec .p-products_gyou__relatedLinkArea .c-btnA .txt {
    font-size: 1.8rem;
  }
  .p-products_gyou__sec .p-products_gyou__relatedLinkArea .c-btnA .txt .sub {
    font-size: 1.2rem;
  }
}
.p-products_gyou__sec .p-products_gyou__infoLinkArea {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.6rem 1rem;
}
.p-products_gyou__sec .p-products_gyou__infoLinkArea .c-btnA {
  border-radius: 0.5rem;
  padding-left: 1.7rem;
  padding-right: 1.7rem;
  height: 6rem;
}
.p-products_gyou__sec .p-products_gyou__infoLinkArea .c-btnA .txt {
  font-size: 1.6rem;
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .p-products_gyou__sec .p-products_gyou__infoLinkArea {
    grid-template-columns: auto;
    gap: 0.4rem;
  }
  .p-products_gyou__sec .p-products_gyou__infoLinkArea .c-btnA {
    height: 4.8rem;
  }
}
.p-products_gyou__sec .p-products_gyou__supportLinkArea {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.6rem;
  margin-bottom: 2.4rem;
}
.p-products_gyou__sec .p-products_gyou__supportLinkArea .s-bnrArea-common {
  position: relative;
  border-radius: 1rem;
  overflow: hidden;
  height: 17rem;
}
.p-products_gyou__sec .p-products_gyou__supportLinkArea .enname {
  font-family: "Roboto", sans-serif;
  font-size: 4.1rem;
  color: #fff;
  font-style: italic;
  font-weight: 300;
  opacity: 0.6;
  position: absolute;
  top: 2.4rem;
  right: 2.3rem;
  z-index: 1;
}
.p-products_gyou__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__ttlWrap {
  position: absolute;
  top: 7.4rem;
  left: 3.2rem;
  z-index: 1;
  width: 26rem;
}
.p-products_gyou__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__ttl {
  font-size: 2rem;
  color: #fff;
  font-weight: 500;
}
.p-products_gyou__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__txt {
  font-size: 1.3rem;
  color: #fff;
}
.p-products_gyou__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__arrow {
  position: absolute;
  right: 2rem;
  bottom: 2rem;
  z-index: 1;
  width: 4rem;
}
.p-products_gyou__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__bg {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media screen and (max-width: 767px) {
  .p-products_gyou__sec .p-products_gyou__supportLinkArea {
    grid-template-columns: auto;
    gap: 0.8rem;
    margin-bottom: 1.6rem;
  }
  .p-products_gyou__sec .p-products_gyou__supportLinkArea .s-bnrArea-common {
    height: 16.2rem;
  }
  .p-products_gyou__sec .p-products_gyou__supportLinkArea .enname {
    top: 1.4rem;
    right: 1.9rem;
  }
  .p-products_gyou__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__ttlWrap {
    width: 26rem;
    top: 6.6rem;
    left: 1.6rem;
  }
  .p-products_gyou__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__ttl {
    font-size: 2rem;
  }
  .p-products_gyou__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__txt {
    font-size: 1.3rem;
  }
  .p-products_gyou__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__arrow {
    bottom: 1.4rem;
    right: 1.6rem;
  }
  .p-products_gyou__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__bg img {
    height: 100%;
    max-height: none;
  }
}
.p-products_gyou__sec .p-products_gyou__supportBtnArea {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.6rem 1rem;
}
.p-products_gyou__sec .p-products_gyou__supportBtnArea .c-btnA {
  border-radius: 0.5rem;
  padding-left: 1.7rem;
  padding-right: 1.7rem;
  height: 6rem;
}
.p-products_gyou__sec .p-products_gyou__supportBtnArea .c-btnA .txt {
  font-size: 1.6rem;
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .p-products_gyou__sec .p-products_gyou__supportBtnArea {
    grid-template-columns: auto;
    gap: 0.4rem;
  }
  .p-products_gyou__sec .p-products_gyou__supportBtnArea .c-btnA {
    height: 4.8rem;
  }
}

/*--------------------------------------
  farm/top
--------------------------------------*/
.p-farm-top .c-mainTtl {
  background: #29B187;
}
.p-farm-top .p-farm__sec .secttl {
  position: relative;
  font-size: 2.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  border-bottom: 2px solid #A3A3A3;
  padding-bottom: 0.6rem;
  margin-bottom: 2.7rem;
  line-height: 1.7;
}
.p-farm-top .p-farm__sec .secttl::before {
  content: "";
  position: absolute;
  bottom: -2px;
  width: 12.1rem;
  height: 2px;
  background: #004EA2;
}
.p-farm-top .p-farm__sec .products_box {
  position: relative;
  border: 1px solid;
  border-radius: 1rem;
  padding: 2rem 0 0;
  overflow: hidden;
}
.p-farm-top .p-farm__sec .products_box .top_txt {
  background-color: #ECF2FA;
  color: #004EA2;
  border-radius: 9999px;
  font-size: 1.4rem;
  text-align: center;
  margin: 0 4rem;
  margin-bottom: 1.2rem;
  padding: 0.3rem 2rem;
}
.p-farm-top .p-farm__sec .products_box .top_txt.grn {
  color: #29B187;
}
.p-farm-top .p-farm__sec .products_box .ttlArea {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid;
  padding-bottom: 1rem;
  margin: 0 4rem;
  margin-bottom: 1.5rem;
}
.p-farm-top .p-farm__sec .products_box .ttlArea .ttl {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  line-height: 1.3;
}
.p-farm-top .p-farm__sec .products_box .ttlArea .ttl .sub {
  font-size: 1.2rem;
  background-color: #29B187;
  color: #fff;
  padding: 0.3rem 1rem;
}
.p-farm-top .p-farm__sec .products_box .ttlArea .ttl .main_ttl {
  font-size: 2.6rem;
}
.p-farm-top .p-farm__sec .products_box .ttlArea .price {
  display: flex;
  align-items: center;
  justify-content: end;
  gap: 0.5rem;
  font-size: 1.2rem;
  margin-top: 1rem;
}
.p-farm-top .p-farm__sec .products_box .ttlArea .price .num {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.p-farm-top .p-farm__sec .products_box .ttlArea .price .num em {
  font-size: 2.8rem;
  font-family: "Roboto", sans-serif;
  font-style: normal;
  line-height: 1;
  letter-spacing: 0;
}
.p-farm-top .p-farm__sec .products_box .box {
  display: grid;
  grid-template-columns: 20rem 1fr;
  gap: 3rem;
  margin: 0 4rem;
}
.p-farm-top .p-farm__sec .products_box .box .imgArea {
  position: relative;
  margin-top: 0.5rem;
}
.p-farm-top .p-farm__sec .products_box .box .imgArea .deco {
  position: absolute;
  top: -1rem;
  left: -2rem;
  width: 6.8rem;
}
.p-farm-top .p-farm__sec .products_box .box .txtArea .tagList {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem 1.8rem;
  margin-bottom: 0.9rem;
}
.p-farm-top .p-farm__sec .products_box .box .txtArea .tagList li {
  color: #007DA2;
  font-size: 1.1rem;
}
.p-farm-top .p-farm__sec .products_box .box .txtArea h3.ttl {
  font-size: 1.4rem;
  font-weight: 700;
  margin-bottom: 0.4rem;
}
.p-farm-top .p-farm__sec .products_box .box .txtArea .txt {
  font-size: 1.3rem;
  opacity: 0.8;
}
.p-farm-top .p-farm__sec .products_box .box .txtArea .btnArea {
  margin-top: 1.6rem;
  display: flex;
  gap: 1.2rem;
}
.p-farm-top .p-farm__sec .products_box .box .txtArea .btnArea a {
  width: 19rem;
}
.p-farm-top .p-farm__sec .products_box .products_boxBottom {
  background-color: #001A4C;
  margin-top: 2.3rem;
  padding: 1rem 3rem;
}
.p-farm-top .p-farm__sec .products_box .linkList {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem 1.4rem;
}
.p-farm-top .p-farm__sec .products_box .linkList li {
  color: #fff;
  font-size: 1.3rem;
}
.p-farm-top .p-farm__sec .products_box .linkList li a {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  color: #fff;
}
.p-farm-top .p-farm__sec .products_box .linkList li a img, .p-farm-top .p-farm__sec .products_box .linkList li a svg {
  width: 1.4rem;
}
.p-farm-top .p-farm__sec .products_box .linkList li a img circle, .p-farm-top .p-farm__sec .products_box .linkList li a svg circle {
  fill: #fff;
}
.p-farm-top .p-farm__sec .products_box .linkList li a img path, .p-farm-top .p-farm__sec .products_box .linkList li a svg path {
  stroke: #001A4C;
}
@media screen and (min-width: 768px), print {
  .p-farm-top .p-farm__sec .products_box .linkList li a {
    cursor: pointer;
    transition: 0.3s opacity !important;
  }
  .p-farm-top .p-farm__sec .products_box .linkList li a:hover {
    opacity: 0.6;
  }
}
.p-farm-top .p-farm__sec .products_box.new::after {
  content: "NEW";
  position: absolute;
  top: -3rem;
  left: -3rem;
  background-color: #FFDC41;
  color: #004EA2;
  font-size: 1.8rem;
  font-weight: 700;
  padding: 3rem 4rem;
  padding-top: 4rem;
  border-bottom-right-radius: 9999px;
}
.p-farm-top .p-farm__sec .products_box + .products_box {
  margin-top: 3.2rem;
}
.p-farm-top .p-farm__sec .p-product-top__mainBtn {
  background-color: #004EA2;
  color: #fff;
  font-size: 1.2rem;
  letter-spacing: 0;
  padding: 0.6rem 1.2rem;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  gap: 0.7rem;
  transition: 0.3s;
  border: 1px solid #004EA2;
}
.p-farm-top .p-farm__sec .p-product-top__mainBtn img, .p-farm-top .p-farm__sec .p-product-top__mainBtn svg {
  width: 1.4rem;
  transform: rotate(90deg);
  transition: 0.3s;
}
.p-farm-top .p-farm__sec .p-product-top__mainBtn circle, .p-farm-top .p-farm__sec .p-product-top__mainBtn line, .p-farm-top .p-farm__sec .p-product-top__mainBtn path {
  transition: 0.3s;
}
@media screen and (min-width: 768px), print {
  .p-farm-top .p-farm__sec .p-product-top__mainBtn:hover {
    background-color: #fff;
    color: #004EA2;
  }
  .p-farm-top .p-farm__sec .p-product-top__mainBtn:hover circle {
    fill: #004EA2;
  }
  .p-farm-top .p-farm__sec .p-product-top__mainBtn:hover line, .p-farm-top .p-farm__sec .p-product-top__mainBtn:hover path {
    stroke: #fff;
  }
}
.p-farm-top .p-farm__sec .p-product-top__mainBtn.grn {
  background-color: #29B187;
  border: 1px solid #29B187;
}
.p-farm-top .p-farm__sec .p-product-top__mainBtn.grn line, .p-farm-top .p-farm__sec .p-product-top__mainBtn.grn path {
  stroke: #29B187;
}
@media screen and (min-width: 768px), print {
  .p-farm-top .p-farm__sec .p-product-top__mainBtn.grn:hover {
    background-color: #fff;
    color: #29B187;
  }
  .p-farm-top .p-farm__sec .p-product-top__mainBtn.grn:hover circle {
    fill: #29B187;
  }
  .p-farm-top .p-farm__sec .p-product-top__mainBtn.grn:hover line, .p-farm-top .p-farm__sec .p-product-top__mainBtn.grn:hover path {
    stroke: #fff;
  }
}
.p-farm-top .p-farm__sec .p-product-top__mainBtn.mainBtn_w {
  background-color: #fff;
  border: 1px solid #001A4C;
  color: #001A4C;
  border-color: #fff;
}
.p-farm-top .p-farm__sec .p-product-top__mainBtn.mainBtn_w svg circle {
  fill: #001A4C;
}
.p-farm-top .p-farm__sec .p-product-top__mainBtn.mainBtn_w svg line, .p-farm-top .p-farm__sec .p-product-top__mainBtn.mainBtn_w svg path {
  stroke: #fff;
}
@media screen and (min-width: 768px), print {
  .p-farm-top .p-farm__sec .p-product-top__mainBtn.mainBtn_w:hover {
    background-color: #001A4C;
    color: #fff;
  }
  .p-farm-top .p-farm__sec .p-product-top__mainBtn.mainBtn_w:hover circle {
    fill: #fff;
  }
  .p-farm-top .p-farm__sec .p-product-top__mainBtn.mainBtn_w:hover line, .p-farm-top .p-farm__sec .p-product-top__mainBtn.mainBtn_w:hover path {
    stroke: #001A4C;
  }
}
.p-farm-top .p-farm__sec .p-product-top__mainBtn.mainBtn_g {
  background-color: #fff;
  border: 1px solid #29B187;
  color: #29B187;
  border-color: #fff;
}
.p-farm-top .p-farm__sec .p-product-top__mainBtn.mainBtn_g circle {
  fill: #29B187;
}
.p-farm-top .p-farm__sec .p-product-top__mainBtn.mainBtn_g line, .p-farm-top .p-farm__sec .p-product-top__mainBtn.mainBtn_g path {
  stroke: #fff;
}
@media screen and (min-width: 768px), print {
  .p-farm-top .p-farm__sec .p-product-top__mainBtn.mainBtn_g:hover {
    background-color: #29B187;
    color: #fff;
  }
  .p-farm-top .p-farm__sec .p-product-top__mainBtn.mainBtn_g:hover circle {
    fill: #fff;
  }
  .p-farm-top .p-farm__sec .p-product-top__mainBtn.mainBtn_g:hover line, .p-farm-top .p-farm__sec .p-product-top__mainBtn.mainBtn_g:hover path {
    stroke: #29B187;
  }
}
.p-farm-top .p-farm__sec + .p-products_gyou__sec {
  margin-top: 4rem;
}
.p-farm-top .p-farm__sec + .p-farm__sec {
  margin-top: 4rem;
}
@media screen and (max-width: 767px) {
  .p-farm-top .p-farm__sec .secttl {
    font-size: 2rem;
  }
  .p-farm-top .p-farm__sec .products_box .top_txt {
    font-size: 1.2rem;
    margin: 0 2rem;
    margin-bottom: 1.5rem;
  }
  .p-farm-top .p-farm__sec .products_box .ttlArea {
    flex-wrap: wrap;
    border-bottom: none;
    margin: 0 2rem;
    margin-bottom: 1.5rem;
  }
  .p-farm-top .p-farm__sec .products_box .ttlArea .ttl {
    width: 100%;
    flex-wrap: wrap;
    border-bottom: 1px solid;
    gap: 0.3rem;
    padding-bottom: 0.5rem;
  }
  .p-farm-top .p-farm__sec .products_box .ttlArea .ttl .sub {
    font-size: 1.2rem;
  }
  .p-farm-top .p-farm__sec .products_box .ttlArea .ttl .main_ttl {
    font-size: 2rem;
    display: block;
    width: 100%;
  }
  .p-farm-top .p-farm__sec .products_box .ttlArea .price {
    width: 100%;
    text-align: right;
    align-items: end;
    font-size: 1.2rem;
  }
  .p-farm-top .p-farm__sec .products_box .ttlArea .price .num {
    align-items: end;
  }
  .p-farm-top .p-farm__sec .products_box .ttlArea .price .num em {
    font-size: 2.4rem;
  }
  .p-farm-top .p-farm__sec .products_box .box {
    grid-template-columns: auto;
    margin: 0 2rem;
  }
  .p-farm-top .p-farm__sec .products_box .box .imgArea {
    width: 20rem;
    margin: auto;
    text-align: center;
  }
  .p-farm-top .p-farm__sec .products_box .box .btnArea {
    flex-wrap: wrap;
    justify-content: center;
  }
  .p-farm-top .p-farm__sec .products_box .box .btnArea a {
    width: 18rem;
  }
  .p-farm-top .p-farm__sec .products_box .products_boxBottom {
    background-color: #001A4C;
    margin-top: 2.3rem;
    padding: 1rem 2rem;
  }
  .p-farm-top .p-farm__sec .products_box.is-active .js-productsGyou__box-Open {
    display: none;
  }
  .p-farm-top .p-farm__sec .products_box .hiddenArea {
    transition: 1s opacity !important;
    animation: show 0.3s linear 0s;
  }
  .p-farm-top .p-farm__sec .products_box .hiddenArea.hidden {
    display: none !important;
  }
  @keyframes show {
    from {
      opacity: 0;
    }
    to {
      opacity: 1;
    }
  }
  .p-farm-top .p-farm__sec .js-productsGyou__box-Btn {
    height: 3.2rem;
    margin: 2rem 0;
    margin-left: 2rem;
    margin-right: 2rem;
    border-radius: 9999px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 1.2rem;
  }
  .p-farm-top .p-farm__sec .js-productsGyou__box-Btn span {
    width: 100%;
    text-align: center;
    font-size: 1.2rem;
  }
  .p-farm-top .p-farm__sec .js-productsGyou__box-Btn img, .p-farm-top .p-farm__sec .js-productsGyou__box-Btn svg {
    width: 1.4rem;
    flex-shrink: 0;
  }
  .p-farm-top .p-farm__sec .js-productsGyou__box-Open {
    animation: show 0.3s linear 0s;
    background-color: #004EA2;
    color: #fff;
  }
  .p-farm-top .p-farm__sec .js-productsGyou__box-Open img, .p-farm-top .p-farm__sec .js-productsGyou__box-Open svg {
    transform: rotate(-90deg);
  }
  .p-farm-top .p-farm__sec .js-productsGyou__box-Open img circle, .p-farm-top .p-farm__sec .js-productsGyou__box-Open svg circle {
    fill: #fff;
  }
  .p-farm-top .p-farm__sec .js-productsGyou__box-Open img line, .p-farm-top .p-farm__sec .js-productsGyou__box-Open img path, .p-farm-top .p-farm__sec .js-productsGyou__box-Open svg line, .p-farm-top .p-farm__sec .js-productsGyou__box-Open svg path {
    stroke: #001A4C;
  }
  .p-farm-top .p-farm__sec .js-productsGyou__box-Close {
    border: 1px solid;
    background-color: #fff;
    color: #001A4C;
    margin-left: 0;
    margin-right: 0;
  }
  .p-farm-top .p-farm__sec .js-productsGyou__box-Close img, .p-farm-top .p-farm__sec .js-productsGyou__box-Close svg {
    transform: rotate(90deg);
  }
}
.p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.6rem;
}
.p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox {
  border: 1px solid;
  border-radius: 1rem;
  padding-top: 2rem;
  overflow: hidden;
}
.p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .top_txt {
  background-color: rgb(236, 242, 250);
  color: #004EA2;
  border-radius: 9999px;
  font-size: 1.2rem;
  font-weight: 700;
  text-align: center;
  padding: 0.3rem 1rem;
  margin: 0 1.5rem;
  margin-bottom: 2.3rem;
}
.p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box {
  display: flex;
  justify-content: space-between;
  align-items: end;
  margin: 0 2rem;
}
.p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box .ttlArea .ttl .sub {
  background-color: #004EA2;
  color: #fff;
  font-size: 1.2rem;
  font-weight: 700;
  padding: 0.3rem 1rem;
  display: inline-block;
}
.p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box .ttlArea .ttl .main_ttl {
  font-size: 2.6rem;
  display: block;
}
.p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box .ttlArea .txt {
  font-size: 1.4rem;
}
.p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box svg, .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box img {
  width: 4.9rem;
}
.p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box svg circle, .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box img circle {
  fill: #001A4C;
}
.p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box svg path, .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box svg line, .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box img path, .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box img line {
  stroke: #fff;
}
@media screen and (min-width: 768px), print {
  .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box {
    cursor: pointer;
    transition: 0.3s opacity !important;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box:hover {
    opacity: 0.6;
  }
}
.p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .btnArea {
  background-color: #001A4C;
  padding: 0.8rem 2rem;
  display: flex;
  gap: 0.8rem;
  margin-top: 2rem;
}
.p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .btnArea a {
  width: 50%;
}
.p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .c-btnA {
  border: 2px solid #001A4C;
  background: #001A4C;
  border-radius: 0.5rem;
  padding-left: 2rem;
  padding-right: 2rem;
  height: 8rem;
}
.p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .c-btnA .txt {
  font-size: 2rem;
  line-height: 1.3;
}
.p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .c-btnA .txt .sub {
  display: block;
  font-size: 1.4rem;
}
@media screen and (min-width: 768px), print {
  .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .c-btnA:hover {
    background-color: #fff;
    color: #001A4C;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .c-btnA:hover circle {
    fill: #001A4C;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .c-btnA:hover line, .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .c-btnA:hover path {
    stroke: #fff;
  }
}
@media screen and (max-width: 767px) {
  .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea {
    grid-template-columns: auto;
    gap: 0.8rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .top_txt {
    font-size: 1.2rem;
    margin-bottom: 1.8rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box .ttlArea h3.ttl .sub {
    font-size: 1.2rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box .ttlArea h3.ttl .main_ttl {
    font-size: 2.6rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .box .ttlArea .txt {
    font-size: 1.4rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .btnArea {
    padding: 0.8rem 0.6rem;
    gap: 0.4rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .relatedLinkBox .btnArea a {
    padding: 0.6rem 0.8rem;
    letter-spacing: 0;
    font-size: 1.1rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .c-btnA {
    height: 6.8rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .c-btnA .txt {
    font-size: 1.8rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__relatedLinkArea .c-btnA .txt .sub {
    font-size: 1.2rem;
  }
}
.p-farm-top .p-farm__sec .p-products_gyou__infoLinkArea {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.6rem 1rem;
}
.p-farm-top .p-farm__sec .p-products_gyou__infoLinkArea .c-btnA {
  border-radius: 0.5rem;
  padding-left: 1.7rem;
  padding-right: 1.7rem;
  height: 6rem;
}
.p-farm-top .p-farm__sec .p-products_gyou__infoLinkArea .c-btnA .txt {
  font-size: 1.6rem;
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .p-farm-top .p-farm__sec .p-products_gyou__infoLinkArea {
    grid-template-columns: auto;
    gap: 0.4rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__infoLinkArea .c-btnA {
    height: 4.8rem;
  }
}
.p-farm-top .p-farm__sec .p-products_gyou__supportLinkArea {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.6rem;
  margin-bottom: 2.4rem;
}
.p-farm-top .p-farm__sec .p-products_gyou__supportLinkArea .s-bnrArea-common {
  position: relative;
  border-radius: 1rem;
  overflow: hidden;
  height: 17rem;
}
.p-farm-top .p-farm__sec .p-products_gyou__supportLinkArea .enname {
  font-family: "Roboto", sans-serif;
  font-size: 4.1rem;
  color: #fff;
  font-style: italic;
  font-weight: 300;
  opacity: 0.6;
  position: absolute;
  top: 2.4rem;
  right: 2.3rem;
  z-index: 1;
}
.p-farm-top .p-farm__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__ttlWrap {
  position: absolute;
  top: 7.4rem;
  left: 3.2rem;
  z-index: 1;
  width: 26rem;
}
.p-farm-top .p-farm__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__ttl {
  font-size: 2rem;
  color: #fff;
  font-weight: 500;
}
.p-farm-top .p-farm__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__txt {
  font-size: 1.3rem;
  color: #fff;
}
.p-farm-top .p-farm__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__arrow {
  position: absolute;
  right: 2rem;
  bottom: 2rem;
  z-index: 1;
  width: 4rem;
}
.p-farm-top .p-farm__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__bg {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media screen and (max-width: 767px) {
  .p-farm-top .p-farm__sec .p-products_gyou__supportLinkArea {
    grid-template-columns: auto;
    gap: 0.8rem;
    margin-bottom: 1.6rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__supportLinkArea .s-bnrArea-common {
    height: 16.2rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__supportLinkArea .enname {
    top: 1.4rem;
    right: 1.9rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__ttlWrap {
    width: 26rem;
    top: 6.6rem;
    left: 1.6rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__ttl {
    font-size: 2rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__txt {
    font-size: 1.3rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__arrow {
    bottom: 1.4rem;
    right: 1.6rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__supportLinkArea .s-bnrArea-common__bg img {
    height: 100%;
    max-height: none;
  }
}
.p-farm-top .p-farm__sec .p-products_gyou__supportBtnArea {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.6rem 1rem;
}
.p-farm-top .p-farm__sec .p-products_gyou__supportBtnArea .c-btnA {
  border-radius: 0.5rem;
  padding-left: 1.7rem;
  padding-right: 1.7rem;
  height: 6rem;
}
.p-farm-top .p-farm__sec .p-products_gyou__supportBtnArea .c-btnA .txt {
  font-size: 1.6rem;
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .p-farm-top .p-farm__sec .p-products_gyou__supportBtnArea {
    grid-template-columns: auto;
    gap: 0.4rem;
  }
  .p-farm-top .p-farm__sec .p-products_gyou__supportBtnArea .c-btnA {
    height: 4.8rem;
  }
}

/*--------------------------------------
  files_pdf/feature
--------------------------------------*/
.p-files_pdf-feature .p-list .flex_box {
  display: flex;
  flex-wrap: wrap;
  gap: 50px 30px;
  padding: 0 20px;
}
.p-files_pdf-feature .p-list .flex_box img {
  height: auto;
}
.p-files_pdf-feature .p-list .flex_box article {
  width: calc(33.3333333333% - 20px);
}
.p-files_pdf-feature .p-list .flex_box article a {
  transition: 0.3s;
}
.p-files_pdf-feature .p-list .flex_box article a:hover {
  opacity: 0.7;
}
.p-files_pdf-feature .p-list .flex_box .tle {
  color: #004EA2;
  display: block;
  font-weight: bold;
  font-size: 1.4rem;
  margin-bottom: 5px;
  margin-top: 10px;
}
.p-files_pdf-feature .p-list .flex_box .headline {
  display: block;
  font-size: 1.2rem;
  margin-bottom: 10px;
}
.p-files_pdf-feature .p-list .flex_box .name {
  display: block;
  text-align: right;
  font-size: 1.1rem;
}

@media screen and (max-width: 767px) {
  .p-files_pdf-feature .p-list .flex_box {
    gap: 3rem 2rem;
    padding: 0;
    justify-content: space-between;
  }
  .p-files_pdf-feature .p-list .flex_box article {
    width: calc(50% - 1rem);
  }
  .p-files_pdf-feature .p-list .flex_box .name {
    text-align: left;
  }
}
/*--------------------------------------
  partner/top
--------------------------------------*/
.partner-top {
  overflow: hidden;
}

.p-partner__top {
  padding: 0 20px;
}
@media screen and (max-width: 767px), print {
  .p-partner__top {
    padding: 0px;
  }
}
.p-partner__top .frameSet {
  margin-bottom: 5rem;
}
.p-partner__top .frameSet h5 {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 1rem;
}
.p-partner__top .frameSet .txt_link {
  color: #004EA2;
  font-size: 1.2rem;
  display: flex;
  align-items: center;
  gap: 0.2rem;
  border-bottom: 1px solid #004EA2;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  width: -moz-max-content;
  width: max-content;
}
.p-partner__top .frameSet .txt_link::before {
  content: "";
  background: url(/assets_renew/images/common/ic-arrow-circle-right-blue02.svg) no-repeat;
  background-size: contain;
  width: 1.4rem;
  height: 1.4rem;
  flex-shrink: 0;
}
.p-partner__top .page_link_box {
  margin-bottom: 5rem;
}
.p-partner__top .page_link_box .flex_box {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}
.p-partner__top .page_link_box .flex_box .box {
  background: #ECF2FA;
  border-radius: 8px;
  padding: 1.5rem;
  min-height: 250px;
  width: calc(33.3333333333% - 10px);
}
@media screen and (max-width: 767px), print {
  .p-partner__top .page_link_box .flex_box .box {
    width: 100%;
    min-height: 100%;
  }
}
.p-partner__top .page_link_box .flex_box .box .ttl {
  font-size: 1.6rem;
  font-weight: 700;
  margin-bottom: 1rem;
  border-bottom: 2px solid #001A4C;
  padding-bottom: 0.5rem;
  position: relative;
  line-height: 1.5;
}
.p-partner__top .page_link_box .flex_box .box .ttl::after {
  content: "";
  background: url(/assets_renew/images/common/ic-arrow-circle-right-blue03.svg) no-repeat;
  width: 25px;
  height: 24px;
  background-size: cover;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  right: 0.5rem;
}
@media screen and (max-width: 767px), print {
  .p-partner__top .page_link_box .flex_box .box .ttl::after {
    width: 21px;
    height: 20px;
  }
}
.p-partner__top .page_link_box .flex_box .box .txt {
  font-size: 1.2rem;
  margin-bottom: 1rem;
}
.p-partner__top .page_link_box .flex_box .box .logo_area {
  background: #EDEDED;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.8rem;
  margin-bottom: 0.5rem;
}
.p-partner__top .page_link_box .flex_box .box .logo_area .logo {
  width: 130px;
}
@media screen and (max-width: 767px), print {
  .p-partner__top .page_link_box .flex_box .box .logo_area .logo {
    width: 10rem;
  }
}
.p-partner__top .page_link_box .flex_box .box .logo_area .sub_ttl {
  font-size: 1.2rem;
  width: 210px;
  line-height: 1.2;
}
@media screen and (max-width: 767px), print {
  .p-partner__top .page_link_box .flex_box .box .logo_area .sub_ttl {
    width: 20rem;
  }
}
.p-partner__top .page_link_box .flex_box .box .logo_area:last-child {
  margin-bottom: 0;
}
.p-partner__top .page_link_box .flex_box .box.box02 .txt {
  margin-bottom: 1rem;
}
@media screen and (max-width: 767px), print {
  .p-partner__top .page_link_box .flex_box .box.box02 .txt {
    margin-bottom: 1rem;
  }
}
.p-partner__top .page_link_box .lead_txt {
  background: #ECF2FA;
  text-align: center;
  padding: 1rem 0;
  color: #001A4C;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 8px;
  font-size: 1.3rem;
  line-height: 1.5;
}
@media screen and (max-width: 767px), print {
  .p-partner__top .page_link_box .lead_txt {
    text-align: left;
    padding: 1rem;
  }
}
.p-partner__top .page_link_box .lead_txt::after {
  content: "";
  background: url(/assets_renew/images/common/ic-arrow-circle-right-blue.svg) no-repeat;
  width: 20px;
  height: 20px;
  margin-left: 0.5rem;
  vertical-align: middle;
  transform: rotate(90deg);
}
.p-partner__top .secttl {
  color: #004EA2;
}
.p-partner__top .p-products_gyou__sec .products_box .top_txt {
  font-weight: 700;
}
.p-partner__top .p-products_gyou__sec .products_box .ttlArea .ttl {
  align-items: baseline;
}
.p-partner__top .p-products_gyou__sec .products_box .ttlArea .sub_txt {
  font-size: 1.4rem;
}
.p-partner__top .p-products_gyou__sec .products_box .btnArea .p-product-top__mainBtn {
  border: 2px solid #004EA2 !important;
}
.p-partner__top .p-products_gyou__sec .products_box .btnArea .p-product-top__mainBtn svg {
  transform: none;
}
.p-partner__top .p-products_gyou__sec .products_box .btnArea .p-product-top__mainBtn svg circle {
  fill: #fff;
}
.p-partner__top .p-products_gyou__sec .products_box .btnArea .p-product-top__mainBtn svg path,
.p-partner__top .p-products_gyou__sec .products_box .btnArea .p-product-top__mainBtn svg line {
  stroke: #004EA2;
}
.p-partner__top .p-products_gyou__sec .products_box .btnArea .p-product-top__mainBtn:hover circle {
  fill: #004EA2;
}
.p-partner__top .p-products_gyou__sec .products_box .btnArea .p-product-top__mainBtn:hover path,
.p-partner__top .p-products_gyou__sec .products_box .btnArea .p-product-top__mainBtn:hover line {
  stroke: #fff;
}
.p-partner__top .p-products_gyou__sec .products_box .imgArea {
  max-width: 200px;
}
@media screen and (max-width: 767px), print {
  .p-partner__top .p-products_gyou__sec .products_box .imgArea {
    margin-bottom: 2rem;
  }
}
.p-partner__top .p-products_gyou__sec .products_box .box {
  grid-template-columns: auto 1fr;
}
@media screen and (max-width: 767px), print {
  .p-partner__top .p-products_gyou__sec .products_box .box {
    grid-template-columns: auto;
    gap: 0;
  }
}
.p-partner__top .p-products_gyou__sec .products_box .box .txtArea .btnArea a {
  border: none;
}
.p-partner__top .p-products_gyou__supportLinkArea {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media screen and (max-width: 767px), print {
  .p-partner__top .p-products_gyou__supportLinkArea {
    grid-template-columns: auto;
  }
}
.p-partner__top .p-products_gyou__supportLinkArea .s-bnrArea-common {
  height: 10rem;
}
@media screen and (max-width: 767px), print {
  .p-partner__top .p-products_gyou__supportLinkArea .s-bnrArea-common {
    height: 10rem;
  }
}
.p-partner__top .p-products_gyou__supportLinkArea .s-bnrArea-common .s-bnrArea-common__ttl {
  font-size: 1.5rem;
  line-height: 1;
}
.p-partner__top .p-products_gyou__supportLinkArea .s-bnrArea-common.blue .s-bnrArea-common__bg {
  /*filter: hue-rotate(50deg) saturate(1.1) brightness(0.8);*/
}
.p-partner__top .p-products_gyou__supportLinkArea .s-bnrArea-common.blue .s-bnrArea-common__ttl {
  font-size: 2.2rem;
  line-height: 1;
}
.p-partner__top .p-products_gyou__supportLinkArea .s-bnrArea-common.blue .s-bnrArea-common__ttlWrap {
  top: 4.5rem;
  left: 1rem;
}
@media screen and (max-width: 767px), print {
  .p-partner__top .p-products_gyou__supportLinkArea .s-bnrArea-common.blue .s-bnrArea-common__ttlWrap {
    top: 4.5rem;
  }
}
.p-partner__top .p-products_gyou__supportLinkArea .s-bnrArea-common .s-bnrArea-common {
  height: 12rem;
}
@media screen and (max-width: 767px), print {
  .p-partner__top .p-products_gyou__supportLinkArea .s-bnrArea-common .s-bnrArea-common {
    height: 10rem;
  }
}
.p-partner__top .p-products_gyou__supportLinkArea .s-bnrArea-common .s-bnrArea-common__ttlWrap {
  top: 4.8rem;
  left: 1rem;
}
.p-partner__top .p-products_gyou__supportLinkArea .s-bnrArea-common .s-bnrArea-common__bg img {
  height: 100%;
  max-height: 10rem;
  width: 100%;
}
.p-partner__top .p-products_gyou__supportLinkArea .enname {
  top: -0.5rem;
  right: 1rem;
}

/*--------------------------------------
  shop/businessLow
--------------------------------------*/
.p-shop-businessLow .c-productDetail__menu {
  padding: 2rem !important;
  border-radius: 1rem !important;
  justify-content: flex-start;
}
.p-shop-businessLow .c-mainTtl {
  margin-bottom: 2rem;
}
.p-shop-businessLow .p-product-top__menu {
  padding: 2rem;
  border-radius: 10px;
  justify-content: left;
}
.p-shop-businessLow .p-product-top__menu ul {
  padding: 0;
  margin: 0;
}
.p-shop-businessLow .p-product-top__menu ul li {
  list-style: none;
}
.p-shop-businessLow .parentheses-txt {
  text-indent: 0;
}
.p-shop-businessLow .mt-1 {
  margin-top: 1rem !important;
}
.p-shop-businessLow .mt-2 {
  margin-top: 2rem !important;
}
.p-shop-businessLow .mt-3 {
  margin-top: 3rem !important;
}
.p-shop-businessLow .dotted-box {
  margin-bottom: 6rem;
  padding: 0 20px;
}
.p-shop-businessLow .dotted-box h2 {
  font-size: 1.9rem;
  margin-bottom: 1.8rem;
  font-weight: bold;
  color: #004EA2;
}
.p-shop-businessLow .dotted-box ul {
  list-style-type: "● ";
  padding-left: 2rem;
  margin: 0 0 2rem;
}
.p-shop-businessLow .info-list {
  max-width: 96%;
  margin: 0 auto;
  border-top: 1px solid #ddd;
}
.p-shop-businessLow .info-block {
  padding: 2rem 0;
  border-bottom: 1px solid #ddd;
  margin-top: -6rem;
  padding-top: 8rem;
}
.p-shop-businessLow .info-block.line-no {
  border: none;
}
.p-shop-businessLow .info-label {
  font-weight: bold;
  color: #004EA2;
  font-size: 1.4rem;
  position: relative;
  margin-bottom: 1rem;
}
.p-shop-businessLow .info-label::before {
  content: "●";
  color: #004EA2;
  font-size: 1.6rem;
  display: inline-block;
  margin-right: 0.5rem;
}
.p-shop-businessLow .info-label.num {
  padding-left: 1.3em;
  text-indent: -1.3em;
}
.p-shop-businessLow .info-label.num::before {
  display: none !important;
}
.p-shop-businessLow .info-value {
  font-size: 1.4rem;
  display: grid;
  gap: 1rem;
}
.p-shop-businessLow .info-value a {
  color: #004EA2;
  text-decoration: underline;
}
.p-shop-businessLow .txt02nmb {
  font-size: 1.4rem;
  position: relative;
  text-indent: -1rem;
  padding-left: 2rem;
}
.p-shop-businessLow .txt02nmb::before {
  content: "◇";
  font-size: 1.4rem;
  display: inline-block;
}
.p-shop-businessLow .body ul {
  margin-top: 2rem;
  padding-left: 1em;
  display: grid;
  gap: 0.8rem;
}
.p-shop-businessLow .body ul > li {
  list-style-type: disc;
}
.p-shop-businessLow .body ul.pdf {
  margin-top: 5rem;
}
.p-shop-businessLow .body ul.desc {
  padding-left: 2rem;
}
.p-shop-businessLow .body ul.desc > li {
  list-style-type: disc;
  text-indent: 0em;
}
.p-shop-businessLow .body ul.desc.pdf {
  margin-top: 5rem;
}
.p-shop-businessLow .body ol.parentheses {
  counter-reset: item;
  display: grid;
  gap: 0.8rem;
}
.p-shop-businessLow .body ol.parentheses > li {
  padding-left: 2em;
  position: relative;
}
.p-shop-businessLow .body ol.parentheses > li::before {
  left: 0;
  position: absolute;
  counter-increment: item;
  content: "（" counter(item) "） ";
}
.p-shop-businessLow ol.caution {
  counter-reset: item;
  display: grid;
  gap: 0.8rem;
  font-size: 1.2rem;
  opacity: 0.7;
  margin-top: 2rem;
  padding-left: 2rem;
}
.p-shop-businessLow ol.caution > li {
  padding-left: 2em;
  text-indent: -2em;
}
.p-shop-businessLow ol.caution > li::before {
  counter-increment: item;
  content: "※" counter(item) " ";
}
.p-shop-businessLow .text-date {
  text-align: right;
  font-size: 1.4rem;
  opacity: 0.7;
  margin-top: 1rem;
}
.p-shop-businessLow .author {
  text-align: right;
  font-style: italic;
  margin-top: 1rem;
  font-size: 1.4rem;
}
@media screen and (max-width: 767px) {
  .p-shop-businessLow .tokutei01 {
    width: 100%;
  }
}
.p-shop-businessLow .rihgt-text {
  text-align: right;
  font-size: 1.3rem;
}
@media screen and (max-width: 767px) {
  .p-shop-businessLow .rihgt-text {
    font-size: 1.3rem;
  }
}

.p-privacy .body h1 span {
  display: block;
  text-align: right;
  font-size: 1.4rem;
  margin-top: 1rem;
}
.p-privacy .body a {
  color: -webkit-link;
  cursor: pointer;
  text-decoration: underline;
}
.p-privacy .body h2 {
  display: block;
  font-size: 1.5em;
  margin-block-start: 0.83em;
  margin-block-end: 0.83em;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
  font-weight: bold;
  unicode-bidi: isolate;
}
.p-privacy .body p {
  display: block;
  margin-block-start: 1em;
  margin-block-end: 1em;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
  unicode-bidi: isolate;
}
.p-privacy .body p strong {
  display: block;
}
.p-privacy .body ol {
  display: block;
  list-style-type: decimal !important;
  margin-block-start: 1em;
  margin-block-end: 1em;
  padding-inline-start: 40px;
  unicode-bidi: isolate;
}
.p-privacy .body ol li {
  display: list-item;
  text-align: -webkit-match-parent;
  unicode-bidi: isolate;
  list-style: auto !important;
}
.p-privacy .body ul {
  display: block;
  list-style-type: decimal !important;
  margin-block-start: 1em;
  margin-block-end: 1em;
  padding-inline-start: 40px;
  unicode-bidi: isolate;
}
.p-privacy .body ul li {
  display: list-item;
  text-align: -webkit-match-parent;
  unicode-bidi: isolate;
  list-style: disc !important;
}

/*--------------------------------------
  letter/top
--------------------------------------*/
/*--------------------------------------
  archive
--------------------------------------*/
.p-letter-top .js-pickupSwiper {
  border-radius: 0 0 2rem 2rem;
  border-top: 0.4rem solid #001A4C;
}
@media screen and (max-width: 767px), print {
  .p-letter-top .js-pickupSwiper {
    width: 36rem;
  }
}
.p-letter-top .js-pickupSwiper .swiper-slide {
  transition: 0.3s;
  height: 31rem;
}
.p-letter-top .js-pickupSwiper .swiper-slide:hover {
  opacity: 0.7;
}
@media screen and (max-width: 767px), print {
  .p-letter-top .js-pickupSwiper .swiper-slide {
    height: 50rem;
  }
}
.p-letter-top .js-pickupSwiper .swiper-slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-letter-top .js-pickupSwiper .swiper-slide .txtBox {
  width: 30rem;
  height: 90%;
  background: #fff;
  position: absolute;
  left: 5rem;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding-inline: 3rem;
}
@media screen and (max-width: 767px), print {
  .p-letter-top .js-pickupSwiper .swiper-slide .txtBox {
    height: 54%;
    width: 90%;
    left: 50%;
    transform: translateX(-50%);
    top: auto;
    bottom: 2rem;
  }
}
.p-letter-top .js-pickupSwiper .swiper-slide .txtBox__tag {
  color: #004EA2;
  font-size: 1.4rem;
}
.p-letter-top .js-pickupSwiper .swiper-slide .txtBox__ttl {
  font-size: 1.6rem;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  line-height: 1.5;
  margin-top: 1rem;
}
.p-letter-top .js-pickupSwiper .swiper-slide .txtBox__txt {
  font-size: 1.4rem;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  margin-top: 1rem;
}
.p-letter-top .swiper__wrap {
  padding-inline: 1rem;
}
@media screen and (max-width: 767px), print {
  .p-letter-top .swiper__wrap {
    padding: 0;
    position: relative;
  }
}
.p-letter-top .swiper__ttl {
  font-weight: 400;
  font-style: italic;
  display: flex;
  align-items: center;
  border-bottom: 1px solid #023F80;
  margin-bottom: -0.4rem;
}
.p-letter-top .swiper__ttl img {
  width: 4.3rem;
}
@media screen and (max-width: 767px), print {
  .p-letter-top .swiper__ttl {
    font-size: 2.8rem;
  }
}
.p-letter-top .swiper__inner {
  position: relative;
}
@media screen and (max-width: 767px), print {
  .p-letter-top .swiper__arrowWrap {
    position: absolute;
    top: -2rem;
    right: 2rem;
    width: 2rem;
  }
}
.p-letter-top .swiper__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%) translateX(-80%);
  left: 0;
  width: 3rem;
  height: 3rem;
  z-index: 3;
  cursor: pointer;
  transition: 0.3s;
}
.p-letter-top .swiper__arrow:hover {
  opacity: 0.7;
}
.p-letter-top .swiper__arrow::after {
  content: "";
  width: 80%;
  height: 80%;
  border-top: 3px solid #004EA2;
  border-left: 3px solid #004EA2;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-45deg);
}
@media screen and (max-width: 767px), print {
  .p-letter-top .swiper__arrow::after {
    width: 60%;
    height: 60%;
  }
}
.p-letter-top .swiper__next {
  transform: translateY(-50%) translateX(80%);
  left: auto;
  right: 0;
}
.p-letter-top .swiper__next::after {
  transform: translate(-50%, -50%) rotate(135deg);
}
.p-letter-top .swiper__dot {
  display: flex;
  justify-content: center;
  gap: 0.8rem;
  margin-top: 1.4rem;
}
.p-letter-top .swiper__dot span {
  margin: 0 !important;
  width: 1.6rem;
  height: 1.6rem;
}
.p-letter-top .slider__img {
  position: relative;
}
.p-letter-top .slider__img img {
  width: 100%;
}
.p-letter-top .slider__img::after {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.2);
  opacity: 0;
  transition: 0.3s;
}
.p-letter-top .slider__txtWrap * {
  color: #fff;
}
.p-letter-top .slider__ttl {
  font-size: 2.2rem;
  line-height: 1.5;
}
.p-letter-top .slider__txt {
  margin-top: 1.5rem;
  display: grid;
  gap: 1rem;
  font-size: 1.4rem;
}
.p-letter-top .slider:hover .slider__img::after {
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .p-letter-top .c-separate {
    display: block;
  }
}
.p-letter-top .p-case__searchBox {
  background-color: #ECF2FA;
  padding: 3rem 4rem;
}
.p-letter-top .searchBox .labelBox {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
  display: none;
}
.p-letter-top .searchBox .labelBox.is-active {
  display: flex;
}
.p-letter-top .searchBox .labelBox .checkbox-label {
  cursor: pointer;
}
.p-letter-top .searchBox .labelBox .checkbox-label.is-active span, .p-letter-top .searchBox .labelBox .checkbox-label.is-all-active span {
  background: #004EA2;
  color: #FFFFFF;
}
.p-letter-top .searchBox .labelBox .checkbox-label .hidden-checkbox {
  display: none;
}
.p-letter-top .searchBox .labelBox .checkbox-label .hidden-checkbox:checked + .checkbox-text {
  background-color: #004EA2;
  border-color: #004EA2;
  color: #fff;
}
.p-letter-top .searchBox .labelBox .checkbox-label .checkbox-text {
  font-size: 1.4rem;
  background-color: #fff;
  border: 1px solid #A3A3A3;
  border-radius: 9999px;
  padding: 0.4rem 2rem;
  display: block;
}
.p-letter-top .searchBox .labelBox + .searchBox {
  margin-top: 4rem;
}
.p-letter-top .searchBox .btnArea {
  margin-top: 4rem;
  display: flex;
  justify-content: center;
  gap: 2rem;
}
.p-letter-top .searchBox .btnArea button {
  cursor: pointer;
}
.p-letter-top .searchBox .btnArea .submitBtn {
  width: 23rem;
}
.p-letter-top .searchBox .btnArea .submitBtn span {
  width: 100%;
}
.p-letter-top .searchBox .btnArea .resetBtn {
  width: 17rem;
  text-align: center;
  padding: 0 1rem;
  justify-content: center;
  background-color: #fff;
  color: #004EA2;
}
.p-letter-top .searchBox .btnArea .resetBtn:hover {
  opacity: 0.7;
}
@media screen and (max-width: 767px) {
  .p-letter-top .p-case__searchMask {
    background-color: rgba(0, 26, 76, 0.9019607843);
    opacity: 0;
    z-index: 100;
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    pointer-events: none;
    transition: 0.3s opacity !important;
  }
  html.is-caseSearch .p-letter-top .p-case__searchMask {
    pointer-events: auto;
    opacity: 1;
  }
  .p-letter-top .js-caseSearch-close {
    position: absolute;
    right: 1.8rem;
    top: 1.6rem;
    z-index: 2;
  }
  .p-letter-top .p-case__searchBox {
    border-radius: 2rem 2rem 0 0;
    padding: 1.6rem 2.4rem 4.2rem;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
  }
  .p-letter-top .p-case__searcForm .ttl {
    text-align: center;
    font-size: 1.8rem;
    margin-bottom: 1.6rem;
  }
  .p-letter-top .p-case__searcForm .ttl::before {
    content: none;
  }
  .p-letter-top .p-case__searcForm .searchBox {
    grid-template-columns: auto;
    gap: 1.2rem;
  }
  .p-letter-top .p-case__searcForm .searchBox + .searchBox {
    margin-top: 3rem;
  }
  .p-letter-top .p-case__searcForm .btnArea {
    gap: 0.8rem;
  }
  .p-letter-top .p-case__searcForm .btnArea .submitBtn,
  .p-letter-top .p-case__searcForm .btnArea .resetBtn {
    width: 50%;
  }
  .p-letter-top .p-case__searchDrawer {
    position: fixed;
    bottom: 1rem;
    left: 0;
    right: 0;
    z-index: 10;
  }
  .p-letter-top .js-caseSearch-trigger {
    width: 38rem;
    margin: auto;
    padding: 0.8rem;
    background-color: #ECF2FA;
    border-radius: 9999px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-align: center;
  }
  .p-letter-top .js-caseSearch-trigger span {
    width: 100%;
  }
  .p-letter-top .js-caseSearch-trigger img,
  .p-letter-top .js-caseSearch-trigger svg {
    width: 3.6rem;
  }
}
.p-letter-top .p-case__listWrap {
  margin-top: 2rem;
}
.p-letter-top .p-case__number {
  font-size: 1.4rem;
  border-bottom: 2px solid #A3A3A3;
  margin-bottom: 2rem;
  display: flex;
  align-items: center;
  gap: 0.8rem;
}
.p-letter-top .p-case__number .num {
  font-size: 1.4rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.p-letter-top .p-case__number .num em {
  font-size: 2.8rem;
  font-style: normal;
  font-family: "Roboto", sans-serif;
  line-height: 1.3;
}
.p-letter-top .p-letter__list {
  display: flex;
  flex-wrap: wrap;
  gap: 1.6rem;
}
.p-letter-top .p-letter__list .listBox {
  position: relative;
  width: 100%;
  border: none;
}
.p-letter-top .p-letter__list .listBox > a {
  padding: 0;
  display: block;
  width: 100%;
  height: 100%;
}
@media screen and (min-width: 768px), print {
  .p-letter-top .p-letter__list .listBox > a {
    cursor: pointer;
    transition: 0.3s opacity !important;
  }
  .p-letter-top .p-letter__list .listBox > a:hover {
    opacity: 0.8;
  }
}
.p-letter-top .p-letter__list .listBox .box {
  display: grid;
  grid-template-columns: 28rem 1fr;
  border-bottom: 2px solid #ECF2FA;
  padding-bottom: 1rem;
  gap: 0 2rem;
}
@media screen and (max-width: 767px), print {
  .p-letter-top .p-letter__list .listBox .box {
    grid-template-columns: 13rem 1fr;
  }
}
.p-letter-top .p-letter__list .listBox .box .imgArea {
  width: 100%;
  height: 20rem;
}
.p-letter-top .p-letter__list .listBox .box .imgArea img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  height: 100%;
}
.p-letter-top .p-letter__list .listBox .box .txtTop {
  font-size: 1.2rem;
  opacity: 0.8;
}
.p-letter-top .p-letter__list .listBox .box .ttlArea {
  grid-row: 2/3;
  grid-column: 2/3;
}
.p-letter-top .p-letter__list .listBox .box .ttlArea .ttl {
  font-size: 2rem;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-height: 1.5;
}
.p-letter-top .p-letter__list .listBox .box .ttlArea .addressTag {
  background-color: #ECF2FA;
  border-radius: 0.2rem;
  font-size: 1.2rem;
  opacity: 0.8;
  padding: 0 0.8rem;
  display: inline-block;
  margin-top: 0.6rem;
}
.p-letter-top .p-letter__list .listBox .box .tagArea {
  display: flex;
  gap: 0.8rem;
  flex-wrap: wrap;
  margin-top: 0.6rem;
  font-size: 1.2rem;
}
.p-letter-top .p-letter__list .listBox .box .tagArea a {
  color: #818DA5;
  transition: 0.3s;
}
.p-letter-top .p-letter__list .listBox .box .tagArea a:hover {
  opacity: 0.7;
}
.p-letter-top .p-letter__list .listBox .box .txt {
  grid-row: 3/4;
  grid-column: 2/3;
  font-size: 1.4rem;
  margin-top: 0.5rem;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: none;
  overflow: hidden;
  -webkit-line-clamp: 4;
}
.p-letter-top .p-letter__list .listBox .box .txt .con {
  color: #004EA2;
}
.p-letter-top .p-letter__list .listBox .box .date {
  font-size: 1.2rem;
  color: #001A4C;
  opacity: 0.5;
}
.p-letter-top .p-letter__list .listBox .box .date span {
  color: #004EA2;
  padding-left: 1rem;
  opacity: 0.5;
}
.p-letter-top .rankingWrap .swiper-wrapper {
  padding: 2rem 0;
}
.p-letter-top .rankingWrap .ranking-swiper-container {
  position: relative;
  padding: 0 2rem;
  margin-inline: -2rem;
  overflow: visible;
  /* ← スライダー内に余白 */
}
.p-letter-top .rankingWrap .ranking-swiper-container .ranking-swiper {
  /*overflow: visible; /* ← これで矢印がはみ出せる */
}
.p-letter-top .rankingWrap .ranking-swiper-container .ranking {
  padding: 2rem 0;
}
.p-letter-top .rankingWrap .ranking-swiper-container .ranking-item {
  position: relative;
}
.p-letter-top .rankingWrap .ranking-swiper-container .ranking-item .ranking-number {
  position: absolute;
  top: -1rem;
  left: 0rem;
  padding: 0;
  border-radius: 100rem;
  font-weight: bold;
  width: 2.4rem;
  height: 2.4rem;
  text-align: center;
  font-size: 1.4rem;
  background: #ECF2FA;
  color: #004EA2;
}
.p-letter-top .rankingWrap .ranking-swiper-container .ranking-item.swiper-slide-active .ranking-number {
  background: #003a76;
  color: #fff;
}
.p-letter-top .rankingWrap .ranking-swiper-container .ranking-item img {
  width: 100%;
  height: auto;
  display: block;
}
.p-letter-top .rankingWrap .ranking-swiper-container .ranking-title {
  font-size: 1.4rem;
  font-weight: bold;
  margin-top: 0.5rem;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}
.p-letter-top .rankingWrap .ranking-swiper-container .ranking-tagArea {
  display: flex;
  gap: 0.8rem;
  flex-wrap: wrap;
  margin-top: 0.3rem;
  font-size: 1.2rem;
}
.p-letter-top .rankingWrap .ranking-swiper-container .ranking-tagArea a {
  color: #818DA5;
  transition: 0.3s;
}
.p-letter-top .rankingWrap .ranking-swiper-container .ranking-tagArea a:hover {
  opacity: 0.7;
}
.p-letter-top .rankingWrap .ranking-swiper-container .ranking-meta {
  font-size: 1.2rem;
  color: #001A4C;
  opacity: 0.5;
}
.p-letter-top .rankingWrap .ranking-swiper-container .ranking-meta span {
  color: #004EA2;
  padding-left: 0.5rem;
  opacity: 0.5;
}
.p-letter-top .rankingWrap .ranking-swiper-container .swiper-button-prev::after,
.p-letter-top .rankingWrap .ranking-swiper-container .swiper-button-next::after {
  font-size: 2rem;
}
.p-letter-top .rankingWrap .ranking-swiper-container .swiper-button-prev {
  left: -0.5rem;
  /* ← 赤枠より外に出す */
  z-index: 10;
}
.p-letter-top .rankingWrap .ranking-swiper-container .swiper-button-next {
  right: -0.5rem;
  /* ← 赤枠より外に出す */
  z-index: 10;
}
@media screen and (max-width: 767px) {
  .p-letter-top .p-case__number .num {
    letter-spacing: 0;
  }
  .p-letter-top .p-case__number .num em {
    font-size: 2rem;
  }
  .p-letter-top .p-letter__list .listBox .tagList {
    gap: 0.4rem;
  }
  .p-letter-top .p-letter__list .listBox .tagList li {
    font-size: 1.2rem;
    padding: 0.2rem 1.2rem;
  }
  .p-letter-top .p-letter__list .listBox .box {
    gap: 0 1.5rem;
    display: flex;
    flex-wrap: wrap;
  }
  .p-letter-top .p-letter__list .listBox .box .txttop {
    font-size: 1.2rem;
    margin-bottom: 0.8rem;
  }
  .p-letter-top .p-letter__list .listBox .box .ttlArea {
    width: 100%;
    border-bottom: none;
  }
  .p-letter-top .p-letter__list .listBox .box .ttlArea .ttl {
    font-size: 1.6rem;
    line-height: 1.5;
    overflow: hidden;
    display: -webkit-box;
    text-overflow: ellipsis;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
  }
  .p-letter-top .p-letter__list .listBox .box .txt {
    display: none;
  }
  .p-letter-top .p-letter__list .listBox .box .imgArea {
    width: 100%;
    margin-bottom: 1rem;
  }
}
.p-letter-top .searchBox__tab {
  display: flex;
  justify-content: center;
  gap: 1rem;
}
.p-letter-top .searchBox__el {
  border-radius: 2rem 2rem 0 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 21rem;
  height: 5.6rem;
  gap: 0.6rem;
  font-weight: normal;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  border: 1px solid #004EA2;
  background: #fff;
  color: #004EA2;
  cursor: pointer;
}
@media screen and (max-width: 767px), print {
  .p-letter-top .searchBox__el {
    height: 4.6rem;
    border-radius: 1rem 1rem 0 0;
  }
}
.p-letter-top .searchBox__el.is-active {
  pointer-events: none;
  color: #fff;
  background: #004EA2;
}
.p-letter-top .searchBox__el.is-active .searchBox__arrow {
  background: #fff;
}
.p-letter-top .searchBox__el.is-active .searchBox__arrow svg path, .p-letter-top .searchBox__el.is-active .searchBox__arrow img path {
  stroke: #004EA2;
}
.p-letter-top .searchBox__arrow {
  background: #004EA2;
  border-radius: 9999px;
  transform: rotate(90deg);
  width: 1.8rem;
  height: 1.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.p-letter-top .searchBox__arrow svg, .p-letter-top .searchBox__arrow img {
  width: 1rem;
  transform: translateX(0.1rem);
}
.p-letter-top .searchBox__arrow svg path, .p-letter-top .searchBox__arrow img path {
  stroke: #fff;
}
.p-letter-top .searchBox__inner {
  background: #ECF2FA;
  padding: 3rem 4rem;
  border-top: 0.4rem solid #004EA2;
  display: flex;
}
@media screen and (max-width: 767px), print {
  .p-letter-top .searchBox__inner {
    padding: 2rem;
  }
}

/*--------------------------------------
  letter/dx
--------------------------------------*/
.p-letter-dx .toc-wrapper {
  background: #ECF2FA;
  padding: 2.4rem;
  border-radius: 1rem;
  justify-self: auto;
  overflow: hidden;
  position: relative;
}
.p-letter-dx .toc-wrapper .toc-title {
  margin-top: 0;
  background: none;
  font-size: 4.3rem;
  font-family: "Roboto", sans-serif;
  font-weight: normal;
  color: #004EA2;
  margin-bottom: 2.4rem;
  padding: 0;
  font-style: italic;
  color: #001A4C;
}
@media screen and (max-width: 767px), print {
  .p-letter-dx .toc-wrapper .toc-title {
    font-size: 3.8rem;
    margin-bottom: 1rem;
  }
}
.p-letter-dx .toc-wrapper li {
  list-style-type: none;
}
.p-letter-dx .toc-wrapper li a {
  font-size: 1.4rem;
  color: #001A4C;
  text-decoration: none;
  line-height: 1.4;
  display: inline-block;
}
.p-letter-dx .toc-wrapper .toc-list {
  padding-left: 0;
}
.p-letter-dx .toc-wrapper .toc-sublist {
  padding-left: 0;
}
.p-letter-dx .toc-wrapper .toc-item {
  margin: 0 !important;
}
.p-letter-dx .toc-wrapper .toc-sublist .toc-item + .toc-item {
  margin-top: 1.2rem;
}
.p-letter-dx .toc-wrapper .toc-level-2 .toc-sublist {
  margin-top: -0.3em;
}
.p-letter-dx .toc-wrapper .toc-level-2 + .toc-level-2 {
  margin-top: 1rem !important;
}
.p-letter-dx .toc-wrapper .toc-level-2 .toc-sublist .toc-item a {
  display: inline-flex;
  padding-left: 1em;
}
.p-letter-dx .toc-wrapper .toc-level-2 .toc-sublist .toc-item a::before {
  content: "";
  font-size: 0.5rem;
  display: inline-block;
  margin-right: 0.5rem;
  vertical-align: middle;
  transform: translateY(0.8rem);
  width: 0.5rem;
  height: 0.9rem;
  background: url(/assets_renew/images/common/ic-arrow-normal.png) no-repeat center center/contain;
}
@media screen and (max-width: 767px), print {
  .p-letter-dx .toc-wrapper .toc-level-2 .toc-sublist .toc-item a::before {
    transform: translateY(0.5rem);
  }
}
.p-letter-dx .toc-wrapper .toc-level-3 + .toc-level-3 {
  margin-top: -0.4em !important;
}
.p-letter-dx .toc-wrapper .toc-more {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 9rem;
  color: #fff;
  background: linear-gradient(to top, #ECF2FA 0%, #ECF2FA 30%, rgba(236, 242, 250, 0));
  opacity: 0;
  pointer-events: none;
}
.p-letter-dx .toc-wrapper .toc-more button {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 2rem;
  background: #fff;
  border: none;
  color: #001A4C;
  font-size: 1.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding-inline: 2.5rem;
  padding-block: 0.3rem;
  font-weight: 500;
  border-radius: 9999px;
  transition: 0.3s;
  cursor: pointer;
}
.p-letter-dx .toc-wrapper .toc-more button:hover {
  opacity: 0.7;
}
.p-letter-dx .toc-wrapper .toc-more button span {
  position: relative;
  width: 1.5rem;
  height: 1.5rem;
}
.p-letter-dx .toc-wrapper .toc-more button span::before, .p-letter-dx .toc-wrapper .toc-more button span::after {
  content: "";
  background: #001A4C;
  position: absolute;
  width: 3px;
  height: 1rem;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.p-letter-dx .toc-wrapper .toc-more button span::after {
  transform: translate(-50%, -50%) rotate(90deg);
}
@media screen and (max-width: 767px) {
  .p-letter-dx .c-separate {
    display: block;
  }
}
.p-letter-dx .writer {
  border: 1px solid #CCC;
  margin-top: 30px;
  margin-bottom: 30px;
  padding-top: 15px;
  padding-right: 30px;
  padding-bottom: 30px;
  padding-left: 30px;
}
.p-letter-dx .writer h5 {
  font-family: "Roboto", "Noto Sans Japanese", sans-serif;
  font-weight: 600;
  font-size: 1.6rem;
  margin-top: 0px;
  margin-bottom: 1rem;
}
.p-letter-dx .writer h5 span.about {
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-size: 3rem;
  margin-right: 2.5rem;
}
.p-letter-dx .writer p.profile {
  overflow: hidden;
  zoom: 1;
  margin-block: 1rem;
}
.p-letter-dx .writer .name {
  font-family: "Roboto", "Noto Sans Japanese", sans-serif;
  font-weight: 600;
  font-size: 2.2rem;
  line-height: 1.4;
  margin: 0 0 2rem 0;
}
.p-letter-dx .writer .name span:first-of-type {
  font-size: 1.4rem !important;
}
.p-letter-dx .writer .article {
  background-color: #ECECEC;
  padding: 1.5rem;
}
.p-letter-dx .writer .article span {
  margin-right: 2.5rem;
  font-size: 110%;
  font-family: "Roboto", "Noto Sans Japanese", sans-serif;
  font-weight: 600;
}
.p-letter-dx .writer img {
  max-width: 100%;
  height: auto;
}

.p-letter__dx {
  /*漫画用*/
}
@media screen and (max-width: 767px) {
  .p-letter__dx {
    padding: 0;
  }
}
.p-letter__dx .tagArea {
  display: flex;
  gap: 0.8rem;
  flex-wrap: wrap;
  margin-top: 0.6rem;
  font-size: 1.2rem;
}
.p-letter__dx .tagArea a {
  color: #818DA5;
  transition: 0.3s;
}
.p-letter__dx .tagArea a:hover {
  opacity: 0.7;
}
.p-letter__dx .ttlWrap {
  margin-top: 5rem;
  margin-bottom: 2rem;
}
@media screen and (max-width: 767px), print {
  .p-letter__dx .ttlWrap {
    margin-top: 2rem;
  }
}
.p-letter__dx .ttlWrap .date {
  color: #004EA2;
  font-size: 1.4rem;
  display: block;
  margin-top: 1rem;
  opacity: 0.5;
}
.p-letter__dx .ttlWrap .date span {
  color: #001A4C;
  padding-right: 1rem;
  opacity: 0.5;
}
.p-letter__dx .ttlWrap h2 {
  font-size: 2.6rem;
  margin-bottom: 0.5rem;
  line-height: 1.5;
  margin-top: 0.5rem;
}
@media screen and (max-width: 767px), print {
  .p-letter__dx .ttlWrap h2 {
    font-size: 2.2rem;
  }
}
.p-letter__dx .thumbnailWrap {
  margin-top: 3rem;
}
.p-letter__dx .p-product-details__tableWrap .p-product-details__table tbody tr th.left {
  width: 40%;
}
.p-letter__dx .p-product-details__tableWrap .p-product-details__table tbody tr th.left02 {
  width: 20%;
}
.p-letter__dx .p-product-details__tableWrap .p-product-details__table tbody tr td ul li {
  margin-bottom: 0.3rem;
  text-indent: -0.55rem;
  margin-left: 1.5rem;
  margin-right: 1.5rem;
}
.p-letter__dx .p-product-details__tableWrap .p-product-details__table tbody tr td ul li::before {
  content: "●";
  font-size: 0.5rem;
  display: inline-block;
  margin-right: 0.5rem;
  vertical-align: middle;
}
.p-letter__dx .sourceWrap {
  background: #ECF2FA;
  padding: 1.5rem 2rem;
  margin-top: 1rem;
}
.p-letter__dx .sourceWrap p {
  font-size: 1.2rem;
}
.p-letter__dx .sourceWrap p a {
  color: #004EA2;
}
.p-letter__dx .frameSet {
  margin-top: 2.4rem;
}
.p-letter__dx .frameSet + .txtArea {
  margin-top: 2.4rem;
}
.p-letter__dx .frameSet ul li {
  margin-bottom: 1rem;
  text-indent: -0.55rem;
  margin-left: 2rem;
}
.p-letter__dx .frameSet ul li::before {
  content: "●";
  font-size: 0.5rem;
  display: inline-block;
  margin-right: 1rem;
  vertical-align: middle;
}
.p-letter__dx .frameSet .profile_box {
  display: flex;
  gap: 2rem;
  margin-bottom: 1.5rem;
}
@media screen and (max-width: 767px) {
  .p-letter__dx .frameSet .profile_box {
    justify-content: center;
    flex-wrap: wrap;
  }
}
.p-letter__dx .frameSet .profile_box .imgWrap {
  width: 100%;
  max-width: 18rem;
}
@media screen and (max-width: 767px) {
  .p-letter__dx .frameSet .profile_box .imgWrap {
    max-width: 100%;
  }
}
.p-letter__dx .frameSet .profile_box .txtWrap .sub_name {
  background: #004EA2;
  padding: 0.5rem 1.5rem;
  border-radius: 5px;
  color: #fff;
  text-align: center;
  margin-bottom: 0.5rem;
  width: -moz-max-content;
  width: max-content;
  font-size: 1.4rem;
}
.p-letter__dx .frameSet .profile_box .txtWrap .name {
  font-size: 1.4rem;
  color: #000;
  margin-bottom: 0.5rem;
}
.p-letter__dx .frameSet .profile_box .txtWrap .name span {
  font-size: 2rem;
  padding-left: 0.5rem;
  font-weight: 700;
}
.p-letter__dx .frameSet .profile_box .txtWrap .company {
  color: #004EA2;
  margin-bottom: 0.5rem;
  font-size: 1.4rem;
}
.p-letter__dx .certified-block {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 5rem;
  align-items: flex-start;
  gap: 3rem;
}
.p-letter__dx .certified-block .certified-image {
  width: 26.8rem;
}
@media screen and (max-width: 767px) {
  .p-letter__dx .certified-block .certified-image {
    width: 100%;
  }
}
.p-letter__dx .certified-block .certified-text {
  flex: 1;
  min-width: 0;
  margin-top: -0.5rem;
}
.p-letter__dx .certified-block .c-productDetail__btnArea {
  display: flex;
  gap: 1rem;
  margin-top: 2rem;
  justify-content: flex-start;
}
@media screen and (max-width: 767px) {
  .p-letter__dx .certified-block .c-productDetail__btnArea {
    flex-wrap: wrap;
  }
}
.p-letter__dx .certified-block .c-productDetail__btnArea .c-btnA {
  width: 24rem;
  margin: 0;
}
@media screen and (max-width: 767px) {
  .p-letter__dx .certified-block .c-productDetail__btnArea .c-btnA {
    width: 100%;
  }
}
.p-letter__dx .certified-block .c-productDetail__btnArea .c-btnA.mainBtn_w {
  background-color: #fff;
  border: 1px solid #004EA2;
  color: #004EA2;
}
.p-letter__dx .certified-block .c-productDetail__btnArea .c-btnA.mainBtn_w svg circle {
  fill: #004EA2;
}
.p-letter__dx .certified-block .c-productDetail__btnArea .c-btnA.mainBtn_w svg line,
.p-letter__dx .certified-block .c-productDetail__btnArea .c-btnA.mainBtn_w svg path {
  stroke: #fff;
}
@media screen and (min-width: 768px), print {
  .p-letter__dx .certified-block .c-productDetail__btnArea .c-btnA.mainBtn_w:hover {
    background-color: #004EA2;
    color: #fff;
  }
  .p-letter__dx .certified-block .c-productDetail__btnArea .c-btnA.mainBtn_w:hover circle {
    fill: #fff;
  }
  .p-letter__dx .certified-block .c-productDetail__btnArea .c-btnA.mainBtn_w:hover line,
  .p-letter__dx .certified-block .c-productDetail__btnArea .c-btnA.mainBtn_w:hover path {
    stroke: #004EA2;
  }
}
.p-letter__dx ul.list {
  margin-bottom: 3rem;
}
.p-letter__dx ul.list li {
  display: flex;
}
.p-letter__dx ul.list li a {
  color: #004EA2;
  margin-bottom: 0.5rem;
  font-size: 1.4rem;
}
.p-letter__dx ul.list li::before {
  content: "●";
  color: #004EA2;
  font-size: 0.5rem;
  display: inline-block;
  margin-right: 1rem;
  vertical-align: middle;
  transform: translateY(0.8rem);
}
.p-letter__dx .p-products_gyou__sec .p-products_gyou__infoLinkArea {
  grid-template-columns: auto;
}
.p-letter__dx .p-products_gyou__sec .p-products_gyou__infoLinkArea .c-btnA {
  padding-left: 3rem;
  height: 10rem;
}
.p-letter__dx .p-products_gyou__sec .p-products_gyou__infoLinkArea .c-btnA .txt {
  font-size: 1.8rem;
}
.p-letter__dx .p-products_gyou__sec .p-products_gyou__infoLinkArea .c-btnA img, .p-letter__dx .p-products_gyou__sec .p-products_gyou__infoLinkArea .c-btnA svg {
  width: 4rem;
  padding-right: 2rem;
}
.p-letter__dx .kaiwa {
  display: grid;
  grid-template-columns: 11rem 1fr;
  gap: 3rem;
  align-items: center;
}
.p-letter__dx .kaiwa .kaiwa-text {
  margin: 0;
}
.p-letter__dx .img-float ul {
  margin: 0;
}
.p-letter__dx .img-float li {
  width: 50%; /* 画像の横幅（２つなので） */
  float: left; /* 画像の左寄せ */
  list-style: none; /* リストマークを削除 */
  margin: 0; /* 画像の周りの余白を削除 */
  box-sizing: border-box;
}
.p-letter__dx .img-float li img {
  width: 100%;
}
.p-letter__dx .img-float ul:after {
  content: "";
  clear: both; /* 画像の回り込みを解除 */
  display: block;
}
.p-letter__dx .sign {
  width: 200px;
}

.img_rwd_l {
  float: left;
  margin-right: 50px;
  margin-bottom: 20px;
  overflow: auto;
  zoom: 1;
}

.img_rwd_img_cent {
  display: block;
  padding-bottom: 40px;
  overflow: auto;
  zoom: 1;
  text-align: center;
  margin: auto;
}

.clear {
  clear: both;
  height: 0;
}

.p-support-center {
  overflow-x: clip;
}
.p-support-center .wrap {
  overflow: hidden;
  position: relative;
}
.p-support-center .c-ttl {
  text-transform: uppercase;
  line-height: 1.8;
  text-align: center;
}
.p-support-center .c-ttl b {
  font-family: "Poppins", sans-serif;
  font-size: 5rem;
  line-height: 1;
  font-weight: normal;
}
@media screen and (max-width: 767px), print {
  .p-support-center .c-ttl b {
    font-size: 3.6rem;
  }
}
.p-support-center .c-ttl small {
  font-size: 1.6rem !important;
  display: block;
}
@media screen and (max-width: 767px), print {
  .p-support-center .c-ttl small {
    margin-top: 0.7rem;
  }
}
.p-support-center .c-inner {
  max-width: 97rem;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}
.p-support-center .lp-header {
  position: relative;
  z-index: 99;
}
.p-support-center .lp-header .logo {
  width: 28rem;
  position: absolute;
  left: 4rem;
  top: 4rem;
  min-height: -moz-max-content;
  min-height: max-content;
}
@media screen and (max-width: 767px), print {
  .p-support-center .lp-header .logo {
    left: 2rem;
    top: 2.3rem;
    width: 20.3rem;
  }
}
.p-support-center .drawer {
  position: fixed;
  top: 3rem;
  right: 4rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .drawer {
    top: 1.3rem;
    right: 1.6rem;
  }
}
.p-support-center .drawer-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.6rem;
  background: #1D4F91;
  width: 10rem;
  height: 4.4rem;
  border-radius: 0.4rem;
  color: #fff;
  font-size: 1.2rem;
  cursor: pointer;
  transition: 0.3s;
}
@media screen and (min-width: 768px), print {
  .p-support-center .drawer-btn:hover {
    opacity: 0.7;
  }
}
.p-support-center .drawer img {
  height: 2rem;
}
.p-support-center .drawer-overlay {
  position: fixed;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background: rgba(173, 208, 255, 0.8);
  z-index: 98;
  opacity: 0;
  pointer-events: none;
  transition: 0.3s;
}
.p-support-center .drawer-overlay.is-active {
  opacity: 1;
  pointer-events: inherit;
}
.p-support-center .drawer-inner {
  position: absolute;
  width: 30rem;
  height: 48rem;
  right: -1rem;
  top: -1rem;
  background: #1D4F91;
  z-index: -1;
  padding-top: 9rem;
  padding-bottom: 4.5rem;
  border-radius: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: 0.3s;
}
@media screen and (max-width: 767px), print {
  .p-support-center .drawer-inner {
    width: 36rem;
    right: -1.6rem;
    top: -1.3rem;
    border-radius: 0 0 0 0.5rem;
  }
}
.p-support-center .drawer-inner.is-active {
  opacity: 1;
  pointer-events: auto;
}
.p-support-center .drawer-inner__nav {
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 767px), print {
  .p-support-center .drawer-inner__nav {
    width: 20rem;
  }
}
.p-support-center .drawer-inner__list {
  display: grid;
  gap: 1rem;
  font-size: 1.6rem;
}
.p-support-center .drawer-inner__list li a {
  position: relative;
  color: #fff;
  padding-left: 1.5rem;
}
.p-support-center .drawer-inner__list li a::before {
  content: "";
  position: absolute;
  top: calc(50% - 0.2rem);
  transform: translateY(-50%);
  width: 0.5rem;
  height: 0.5rem;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  left: 0;
  transform: rotate(45deg);
}
.p-support-center .drawer-inner__btn {
  margin-top: 2.4rem;
  display: grid;
  gap: 1rem;
}
.p-support-center .drawer-inner__btn a {
  padding-inline: 1.6rem;
  border-radius: 0.5rem;
  height: 5.4rem;
  background: #fff;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 20rem;
  font-size: 1.6rem;
  color: #004EA2;
  font-weight: bold;
}
@media screen and (max-width: 767px), print {
  .p-support-center .drawer-inner__btn a {
    width: 26rem;
  }
}
.p-support-center .drawer-inner__btn a div {
  position: relative;
  width: 1.8rem;
  height: 1.8rem;
  background: #004EA2;
  border-radius: 9999px;
}
.p-support-center .drawer-inner__btn a div::after {
  content: "";
  position: absolute;
  top: 50%;
  left: calc(50% - 0.1rem);
  transform: translate(-50%, -50%) rotate(45deg);
  height: 0.5rem;
  width: 0.5rem;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}
.p-support-center .s-mv {
  position: relative;
  height: 65rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-mv {
    height: 100vh;
  }
}
.p-support-center .s-mv__img {
  position: absolute;
  right: 0;
  top: 0;
  width: calc(50% + 40rem);
  height: 100%;
  border-radius: 0 0 0 12rem;
  overflow: hidden;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-mv__img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    border-radius: 0 0 12rem 0;
  }
}
.p-support-center .s-mv__img img {
  -o-object-fit: cover;
     object-fit: cover;
  height: 100%;
  width: 100%;
}
.p-support-center .s-mv__ttl {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-47rem);
  z-index: 1;
  line-height: 1.3;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-mv__ttl {
    top: 10rem;
    left: 2.5rem;
    transform: none;
  }
}
.p-support-center .s-mv__ttl h1 {
  font-size: 5rem !important;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-mv__ttl h1 {
    font-size: 3.6rem !important;
    line-height: 1.5;
    letter-spacing: 0.1em;
  }
}
.p-support-center .s-mv__ttl p {
  margin-top: 1.5rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-mv__ttl p {
    letter-spacing: 0.15em;
  }
}
.p-support-center .s-mv__ttl * {
  color: #386081;
}
.p-support-center .s-mv__marquee {
  font-size: 15rem;
  position: absolute;
  bottom: 0;
  left: 0;
  transform: translateY(50%);
  color: #fff;
  opacity: 0.7;
  font-family: "Outfit", sans-serif;
  mix-blend-mode: soft-light;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-mv__marquee {
    font-size: 8rem;
  }
  .p-support-center .s-mv__marquee .c-marquee__item {
    width: 81rem;
  }
}
.p-support-center .s-professional {
  padding-top: 12rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional {
    padding-top: 4.5rem;
  }
}
.p-support-center .s-professional__ttl {
  text-align: center;
  font-size: 3.6rem;
  line-height: 1.5;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__ttl {
    font-size: 2.8rem;
  }
}
.p-support-center .s-professional__ttl small {
  font-size: 2rem;
  font-weight: normal;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__ttl small {
    font-size: 1.6rem;
  }
}
.p-support-center .s-professional__txt {
  text-align: center;
  margin-top: 3.4rem;
  font-size: 1.8rem;
  line-height: 2;
  display: grid;
  gap: 3rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__txt {
    padding-inline: 3rem;
    margin-top: 2.4rem;
    font-size: 1.6rem;
    line-height: 1.7;
    text-align: left;
  }
}
.p-support-center .s-professional__gallery {
  margin-top: 3rem;
  display: block;
}
.p-support-center .s-professional__top {
  display: grid;
  align-items: center;
  grid-template-columns: 21rem 1fr;
  gap: 6.8rem;
  margin-top: 5rem;
  padding-left: 3.5rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__top {
    grid-template-columns: 1fr;
    padding-left: 0;
    gap: 2rem;
    margin-top: 2rem;
  }
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__top-left {
    display: grid;
    grid-template-columns: 9.4rem 1fr;
    align-items: center;
    width: 26rem;
    margin-left: auto;
    margin-right: auto;
    gap: 1.5rem;
  }
}
.p-support-center .s-professional__top-left h4 {
  background: #001A4C;
  border-radius: 0.3rem;
  color: #fff;
  text-align: center;
  padding-block: 0.2rem;
  position: relative;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__top-left h4 {
    line-height: 1.2;
    padding-block: 0.5rem;
  }
}
.p-support-center .s-professional__top-left h4::after {
  content: "";
  position: absolute;
  bottom: 1px;
  left: 50%;
  transform: translateX(-50%) translateY(100%);
  background-color: #001A4C;
  width: 1.5rem;
  height: 0.7rem;
  -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0%);
          clip-path: polygon(0 0, 50% 100%, 100% 0%);
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__top-left h4::after {
    bottom: auto;
    top: 50%;
    left: auto;
    right: 1px;
    transform: translate(100%, -50%);
    width: 0.8rem;
    height: 1.5rem;
    -webkit-clip-path: polygon(0% 0%, 0% 100%, 100% 50%);
            clip-path: polygon(0% 0%, 0% 100%, 100% 50%);
  }
}
.p-support-center .s-professional__top-left p {
  font-size: 14.8rem;
  font-family: "Outfit", sans-serif;
  font-weight: normal;
  line-height: 0.75;
  margin-top: 0.5rem;
  display: flex;
  align-items: flex-end;
  white-space: nowrap;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__top-left p {
    font-size: 11rem;
    margin-top: 0;
  }
}
.p-support-center .s-professional__top-left p em {
  width: 19rem;
  display: inline-block;
  text-align: right;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__top-left p em {
    width: 12rem;
  }
}
.p-support-center .s-professional__top-left p span {
  font-size: 6.6rem;
  position: relative;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__top-left p span {
    font-size: 5.2rem;
  }
}
.p-support-center .s-professional__top-left p span::after {
  content: "";
}
.p-support-center .s-professional__top-right h4 {
  font-size: 2.4rem;
}
.p-support-center .s-professional__top-right p {
  margin-top: 1.6rem;
}
.p-support-center .s-professional__3culumn {
  margin-top: 5rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 5rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__3culumn {
    margin-top: 3.5rem;
    grid-template-columns: 1fr;
    gap: 3rem;
  }
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__3culumn-side {
    display: grid;
    grid-template-columns: 8rem 1fr;
    align-items: center;
    gap: 2rem;
  }
}
.p-support-center .s-professional__3culumn-img {
  width: 9.4rem;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__3culumn-img {
    width: 100%;
  }
}
.p-support-center .s-professional__3culumn-left {
  line-height: 1.2;
  font-size: 1.5rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__3culumn-left {
    font-size: 1.8rem;
    padding-bottom: 0.3rem;
  }
}
.p-support-center .s-professional__3culumn-ttl {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  text-align: center;
  line-height: 1;
  gap: 0.6rem;
  margin-top: 2rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__3culumn-ttl {
    display: block;
    text-align: left;
    margin-top: 0;
  }
}
.p-support-center .s-professional__3culumn-ttl small {
  font-size: 2.4rem;
}
.p-support-center .s-professional__3culumn-ttl b {
  font-size: 5.6rem;
  font-family: "Outfit", sans-serif;
  font-weight: normal;
  line-height: 0.8;
  transform: translateY(0.3rem);
  display: inline-block;
  text-align: right;
}
.p-support-center .s-professional__3culumn-ttl b.a {
  width: 5.8rem;
}
.p-support-center .s-professional__3culumn-ttl b.b {
  width: 9rem;
}
.p-support-center .s-professional__3culumn-ttl b.c {
  width: 9.6rem;
}
.p-support-center .s-professional__3culumn-ttl span:not(.pc) {
  font-size: 3rem;
}
.p-support-center .s-professional__3culumn-ttl em {
  font-size: 3.6rem;
  font-style: normal;
  font-family: "Outfit", sans-serif;
}
.p-support-center .s-professional__3culumn-txt {
  margin-top: 1.5rem;
  font-size: 1.5rem;
}
.p-support-center .s-professional-other {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 5.8rem;
  margin-top: 6rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional-other {
    grid-template-columns: 1fr;
    gap: 3rem;
    margin-top: 4rem;
  }
}
.p-support-center .s-professional-other__el {
  display: grid;
  grid-template-columns: 23rem 1fr;
  gap: 2rem;
  align-items: center;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional-other__el {
    grid-template-columns: 16rem 1fr;
    gap: 1.2rem;
  }
}
.p-support-center .s-professional-other__el h4 {
  font-size: 2.4rem;
  font-weight: normal;
  display: flex;
  align-items: center;
  font-weight: 500;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional-other__el h4 {
    font-size: 2rem;
  }
}
.p-support-center .s-professional-other__el h4 small {
  font-size: 1.3rem;
}
.p-support-center .s-professional-other__el h4 b {
  font-size: 4rem;
  font-family: "Outfit", sans-serif;
  font-weight: normal;
  padding-left: 0.5rem;
  line-height: 1;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional-other__el h4 b {
    font-size: 3rem;
  }
}
.p-support-center .s-professional-other__el h4 span {
  font-size: 2.4rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional-other__el h4 span {
    font-size: 2rem;
  }
}
.p-support-center .s-professional-other__el p {
  margin-top: 0.7rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional-other__el p {
    margin-top: 0.5rem;
    font-size: 1.4rem;
  }
}
.p-support-center .s-professional__bottom {
  text-align: center;
  margin-top: 7rem;
  margin-inline: auto;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__bottom {
    margin-top: 5rem;
  }
}
.p-support-center .s-professional__bottom .js-mama-modalTrigger {
  position: relative;
  text-align: center;
  max-width: 45rem;
  width: 100%;
  height: 7rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: auto;
  background: #1D4F91;
  color: #fff;
  border-radius: 0.8rem;
  font-size: 2rem;
  font-weight: bold;
  transition: 0.3s;
  cursor: pointer;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__bottom .js-mama-modalTrigger {
    height: 6rem;
  }
}
.p-support-center .s-professional__bottom .js-mama-modalTrigger:hover {
  opacity: 0.7;
}
.p-support-center .s-professional__bottom .js-mama-modalTrigger img {
  width: 4rem;
  position: absolute;
  top: 50%;
  right: 4rem;
  transform: translateY(-50%);
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-professional__bottom .js-mama-modalTrigger img {
    width: 3rem;
  }
}
.p-support-center .s-welfare {
  margin-top: 10rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-welfare {
    margin-top: 8rem;
  }
}
.p-support-center .s-welfare__ttl {
  font-size: 3.2rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-welfare__ttl {
    font-size: 2.4rem;
  }
}
.p-support-center .s-welfare__wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 7rem;
  margin-top: 3.2rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-welfare__wrap {
    grid-template-columns: 1fr;
    gap: 5rem;
  }
}
.p-support-center .s-welfare__txt {
  margin-top: 1rem;
}
.p-support-center .s-welfare__txt h4 {
  font-size: 2.4rem;
  font-weight: 500;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-welfare__txt h4 {
    font-size: 2rem;
  }
}
.p-support-center .s-welfare__txt p {
  font-size: 1.5rem;
}
.p-support-center .s-study {
  padding-top: 8rem;
  padding-bottom: 12rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-study {
    padding-top: 7rem;
    padding-bottom: 6rem;
  }
}
.p-support-center .s-study__outer {
  padding-inline: 4rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-study__outer {
    padding-inline: 2rem;
  }
}
.p-support-center .s-study__frame {
  background: #EAF0F9;
  padding-top: 5.8rem;
  padding-bottom: 5.8rem;
  border-radius: 6rem;
  max-width: 130rem;
  margin-inline: auto;
  display: grid;
  gap: 6rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-study__frame {
    border-radius: 2rem;
    padding-top: 3rem;
    padding-bottom: 3rem;
  }
}
.p-support-center .s-study__figure {
  display: grid;
  align-items: center;
  grid-template-columns: 46rem 1fr;
  gap: 4rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-study__figure {
    grid-template-columns: 1fr;
    gap: 1.2rem;
  }
  .p-support-center .s-study__figure img {
    width: 80%;
    margin-inline: auto;
  }
}
.p-support-center .s-study__figure h4 {
  font-size: 2.4rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-study__figure h4 {
    font-size: 2rem;
  }
}
.p-support-center .s-study__figure p {
  font-size: 1.5rem;
}
.p-support-center .s-study__ttl {
  text-align: center;
  font-size: 3.2rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-study__ttl {
    font-size: 2.4rem;
  }
}
.p-support-center .s-study__wrap {
  display: grid;
  align-items: flex-start;
  grid-template-columns: repeat(2, 1fr);
  margin-top: 2rem;
  gap: 3rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-study__wrap {
    grid-template-columns: 1fr;
    gap: 1.2rem;
  }
}
.p-support-center .s-study__inner {
  display: grid;
  gap: 2rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-study__inner {
    gap: 1.2rem;
  }
}
.p-support-center .s-study__inner dl {
  background: #fff;
  box-shadow: 0 0.2rem 0.4rem rgba(0, 26, 76, 0.1019607843);
  font-size: 1.5rem;
  border-radius: 0.8rem;
}
.p-support-center .s-study__inner dl dt {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-block: 2rem;
  padding-inline: 3rem;
  cursor: pointer;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-study__inner dl dt {
    padding-inline: 1.8rem;
  }
}
.p-support-center .s-study__inner dl dt span {
  width: 2rem;
  height: 2rem;
  position: relative;
}
.p-support-center .s-study__inner dl dt span hr {
  border: none;
  margin: 0 !important;
  width: 100%;
  height: 1px;
  background: #001A4C;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: 0.3s;
}
.p-support-center .s-study__inner dl dt span hr:last-of-type {
  transform: translate(-50%, -50%) rotate(90deg);
}
.p-support-center .s-study__inner dl dt span.is-active hr:last-of-type {
  transform: translate(-50%, -50%) rotate(0deg);
}
.p-support-center .s-study__inner dl dd {
  padding-inline: 3rem;
  padding-bottom: 2.8rem;
  display: none;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-study__inner dl dd {
    padding-inline: 1.8rem;
  }
}
.p-support-center .s-daily {
  padding-inline: 4rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-daily {
    padding-inline: 1rem;
  }
  .p-support-center .s-daily .c-inner {
    padding: 0;
  }
}
.p-support-center .s-daily__inner {
  max-width: 130rem;
  width: 100%;
  border-radius: 6rem;
  padding: 8rem 8.5rem;
  background: #fff;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-daily__inner {
    padding: 4rem 0;
    border-radius: 4rem;
  }
}
.p-support-center .s-daily__figure {
  display: block;
}
.p-support-center .s-daily__separate {
  display: grid;
  justify-content: center;
  grid-template-columns: 28rem 31.7rem;
  gap: 10.4rem;
  margin-top: 6rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-daily__separate {
    grid-template-columns: 1fr;
    margin-top: 3rem;
    gap: 5rem;
  }
}
.p-support-center .s-daily__separate-inner {
  display: grid;
  gap: 1.6rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-daily__separate-inner {
    gap: 1rem;
    grid-template-columns: 1fr 1fr;
  }
}
.p-support-center .s-daily__swiper {
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-daily__swiper {
    padding-inline: 2rem;
  }
}
.p-support-center .s-daily__swiper-nav {
  width: 115%;
  position: absolute;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  top: 50%;
  pointer-events: none;
  z-index: 2;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-daily__swiper-nav {
    width: 94%;
  }
}
.p-support-center .s-daily__swiper-nav .daily-swiper-button-prev, .p-support-center .s-daily__swiper-nav .daily-swiper-button-next {
  width: 5rem;
  pointer-events: auto;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  transition: 0.3s;
  cursor: pointer;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-daily__swiper-nav .daily-swiper-button-prev, .p-support-center .s-daily__swiper-nav .daily-swiper-button-next {
    width: 4rem;
  }
}
@media screen and (min-width: 768px), print {
  .p-support-center .s-daily__swiper-nav .daily-swiper-button-prev:hover, .p-support-center .s-daily__swiper-nav .daily-swiper-button-next:hover {
    opacity: 0.7;
  }
}
.p-support-center .s-daily__swiper-nav .daily-swiper-button-prev.swiper-button-disabled, .p-support-center .s-daily__swiper-nav .daily-swiper-button-next.swiper-button-disabled {
  opacity: 0.5;
}
.p-support-center .s-daily__swiper-nav .daily-swiper-button-next {
  left: auto;
  right: 0;
  transform: scaleX(-1) translateY(-50%);
}
.p-support-center .s-daily__swiper .swiper-slide {
  padding-inline: 1rem;
}
.p-support-center .s-daily__swiperWrap {
  position: relative;
  margin-top: 3.2rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-daily__swiperWrap {
    margin-inline: -2rem;
  }
}
.p-support-center .s-daily__swiper-el {
  background: #EAF0F9;
  border-radius: 0.8rem;
  padding: 2rem 2rem 2rem;
}
.p-support-center .s-daily__swiper-el .time {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1rem;
  font-size: 2rem;
}
.p-support-center .s-daily__swiper-el .time img {
  width: 2.9rem;
  margin-top: 0;
}
.p-support-center .s-daily__swiper-el .ttl {
  text-align: center;
  font-size: 1.8rem;
  font-weight: 500;
  margin-top: 0;
}
.p-support-center .s-daily__swiper-el img {
  width: 100%;
  margin-top: 1rem;
}
.p-support-center .s-daily__swiper-el .txt {
  margin-top: 1rem;
  font-size: 1.4rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-daily__swiper-el .txt {
    min-height: 7.4rem;
  }
}
.p-support-center .s-interview {
  margin-top: 12rem;
  padding-bottom: 21rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-interview {
    margin-top: 6rem;
    padding-bottom: 8rem;
  }
}
.p-support-center .s-interview__inner {
  margin-top: 4rem;
  display: grid;
  align-items: flex-start;
  grid-template-columns: repeat(3, 1fr);
  -moz-column-gap: 3rem;
       column-gap: 3rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-interview__inner {
    margin-top: 2rem;
    grid-template-columns: 1fr 1fr;
    row-gap: 1rem;
    -moz-column-gap: 1rem;
         column-gap: 1rem;
  }
}
.p-support-center .s-interview__el {
  position: relative;
  border-radius: 0.8rem;
  overflow: hidden;
  cursor: pointer;
  transition: 0.3s;
}
@media screen and (min-width: 768px), print {
  .p-support-center .s-interview__el:hover {
    opacity: 0.7;
  }
}
.p-support-center .s-interview__el::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  background: linear-gradient(197.92deg, rgba(255, 255, 255, 0) 32.22%, #004EA2 85.56%);
}
@media screen and (min-width: 767px), print {
  .p-support-center .s-interview__el:nth-of-type(2), .p-support-center .s-interview__el:nth-of-type(5) {
    margin-top: 3rem;
  }
  .p-support-center .s-interview__el:nth-of-type(3), .p-support-center .s-interview__el:nth-of-type(6) {
    margin-top: 6rem;
  }
}
.p-support-center .s-interview__el h4 {
  position: absolute;
  left: 2rem;
  bottom: 1rem;
  z-index: 2;
  color: #fff;
  display: flex;
  align-items: flex-end;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-interview__el h4 {
    left: 1.5rem;
    bottom: 1.2rem;
    align-items: flex-end;
    flex-wrap: wrap;
  }
}
.p-support-center .s-interview__el h4 b {
  font-family: "Poppins", sans-serif;
  font-weight: normal;
  font-size: 2.6rem;
  line-height: 1;
}
.p-support-center .s-interview__el h4 span {
  font-size: 1.6rem;
  font-weight: lighter;
  line-height: 1.3;
}
.p-support-center .s-interview__el h4 small {
  font-weight: normal;
  padding-left: 0.8rem;
  font-size: 1.2rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-interview__el h4 small {
    padding-left: 0;
  }
}
.p-support-center .s-interview__el-plus {
  display: none;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-interview__el-plus {
    display: block;
    position: absolute;
    right: 1.3rem;
    top: 1.3rem;
    height: 2.2rem;
    width: 2.2rem;
    background: #fff;
    border-radius: 9999px;
    z-index: 2;
  }
  .p-support-center .s-interview__el-plus::after, .p-support-center .s-interview__el-plus::before {
    position: absolute;
    content: "";
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    height: 50%;
    width: 1px;
    background: #001A4C;
  }
  .p-support-center .s-interview__el-plus::before {
    transform: translate(-50%, -50%) rotate(90deg);
  }
}
.p-support-center .s-about {
  padding-top: 18rem;
  padding-bottom: 12rem;
  background: #004EA2;
  position: relative;
  color: #fff;
  line-height: 2;
}
.p-support-center .s-about::before {
  pointer-events: none;
  position: absolute;
  content: "";
  background: radial-gradient(50% 50% at 50% 50%, rgba(194, 219, 255, 0.4) 0%, rgba(255, 255, 255, 0) 100%);
  width: 201.2rem;
  height: 201.2rem;
  top: -149rem;
  left: 50%;
  transform: translateX(-169rem);
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-about::before {
    width: 99.3rem;
    height: 99.3rem;
    top: -60rem;
    left: 50%;
    transform: translateX(-78rem);
  }
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-about {
    padding-top: 6rem;
    padding-bottom: 4rem;
  }
  .p-support-center .s-about .c-inner {
    padding-inline: 3rem;
  }
}
.p-support-center .s-about__img {
  position: absolute;
  left: -10rem;
  top: 10rem;
  width: 60rem;
  pointer-events: none;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-about__img {
    top: 0;
    right: -11rem;
    left: auto;
  }
}
.p-support-center .s-about__marquee {
  font-size: 15rem;
  position: absolute;
  top: 0;
  left: 0;
  transform: translateY(-50%);
  color: #C6DEFF;
  opacity: 0.7;
  font-family: "Outfit", sans-serif;
  pointer-events: none;
}
.p-support-center .s-about__marquee .c-marquee__item {
  width: 190rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-about__marquee {
    font-size: 8rem;
  }
  .p-support-center .s-about__marquee .c-marquee__item {
    width: 100rem;
  }
}
.p-support-center .s-about__ttl {
  font-size: 3.6rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-about__ttl {
    font-size: 2.4rem;
  }
}
.p-support-center .s-about__txt {
  margin-top: 0.7rem;
  display: grid;
  gap: 1rem;
}
.p-support-center .s-about-imgWrap {
  margin-top: 6rem;
  padding-top: 6rem;
  border-top: 1px solid #fff;
  display: grid;
  grid-template-columns: 52rem 1fr;
  gap: 6rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-about-imgWrap {
    margin-top: 4rem;
    padding-top: 4rem;
    grid-template-columns: 1fr;
    gap: 1rem;
  }
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-about-imgWrap__txt {
    display: contents;
  }
}
.p-support-center .s-about-imgWrap__txt h4 {
  font-size: 2.2rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-about-imgWrap__txt h4 {
    order: 1;
  }
}
.p-support-center .s-about-imgWrap__txt > div {
  margin-top: 1.5rem;
  display: grid;
  gap: 1.5rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-about-imgWrap__txt > div {
    order: 3;
  }
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-about-imgWrap img {
    width: 80%;
    order: 2;
    margin-inline: auto;
  }
}
.p-support-center .s-about-link {
  display: grid;
  margin-top: 6rem;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.2rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-about-link {
    grid-template-columns: repeat(2, 1fr);
  }
}
.p-support-center .s-about__bottom {
  text-align: center;
  margin-top: 7rem;
  margin-inline: auto;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-about__bottom {
    margin-top: 5rem;
  }
}
.p-support-center .s-about__bottom a {
  position: relative;
  text-align: center;
  max-width: 45rem;
  width: 100%;
  height: 7rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: auto;
  background: #fff;
  color: #004EA2;
  border-radius: 0.8rem;
  font-size: 2rem;
  font-weight: bold;
  transition: 0.3s;
  cursor: pointer;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-about__bottom a {
    height: 6rem;
  }
}
.p-support-center .s-about__bottom a:hover {
  opacity: 0.7;
}
.p-support-center .s-about__bottom a img {
  width: 4rem;
  position: absolute;
  top: 50%;
  right: 4rem;
  transform: translateY(-50%);
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-about__bottom a img {
    width: 3rem;
    right: 2rem;
  }
}
.p-support-center .s-recruit {
  padding-top: 12rem;
  padding-bottom: 5rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-recruit {
    padding-top: 5rem;
  }
}
.p-support-center .s-recruit__inner {
  width: 83rem;
  margin-left: auto;
  margin-right: auto;
  margin-top: 4rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-recruit__inner {
    width: 100%;
    padding-inline: 3rem;
    margin-top: 0;
    border-bottom: 1px solid #CAD8E4;
  }
}
.p-support-center .s-recruit__target {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.6rem;
  margin-top: 4rem;
  margin-bottom: 4rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-recruit__target {
    gap: 1rem;
  }
}
.p-support-center .s-recruit__target button {
  height: 5rem;
  border-radius: 0.8rem;
  border: 2px solid #004EA2;
  background: #fff;
  font-size: 1.8rem;
  font-weight: bold;
  color: #004EA2;
  position: relative;
  transition: 0.3s;
  cursor: pointer;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-recruit__target button {
    height: 4rem;
    font-size: 1.6rem;
    border-radius: 0.4rem;
  }
}
.p-support-center .s-recruit__target button::after {
  content: "";
  position: absolute;
  transform: translateY(100%) translateX(-50%);
  left: 50%;
  bottom: 0;
  width: 2rem;
  height: 1rem;
  -webkit-clip-path: polygon(0% 0%, 50% 100%, 100% 0%);
          clip-path: polygon(0% 0%, 50% 100%, 100% 0%);
  background: #004EA2;
  opacity: 0;
  transition: 0.3s;
}
.p-support-center .s-recruit__target button.is-active {
  background: #004EA2;
  color: #fff;
  pointer-events: none;
}
.p-support-center .s-recruit__target button.is-active::after {
  opacity: 1;
}
.p-support-center .s-recruit__el dl {
  display: grid;
  grid-template-columns: 15.5rem 1fr;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-recruit__el dl {
    grid-template-columns: 1fr;
  }
}
.p-support-center .s-recruit__el dl dt, .p-support-center .s-recruit__el dl dd {
  padding-inline: 1.5rem;
  padding-block: 2.2rem;
  margin-top: -1px;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-recruit__el dl dt, .p-support-center .s-recruit__el dl dd {
    padding-block: 0;
    padding-inline: 0;
  }
}
.p-support-center .s-recruit__el dl dt {
  color: #004EA2;
  border-top: 1px solid #004EA2;
  border-bottom: 1px solid #004EA2;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-recruit__el dl dt {
    position: relative;
    border-top: 1px solid #CAD8E4;
    border-bottom: none;
    padding-top: 2rem;
  }
  .p-support-center .s-recruit__el dl dt::after {
    content: "";
    position: absolute;
    width: 4rem;
    height: 1px;
    top: 0;
    left: 0;
    background: #004EA2;
  }
}
@media screen and (min-width: 768px), print {
  .p-support-center .s-recruit__el dl dd {
    border-top: 1px solid #CAD8E4;
    border-bottom: 1px solid #CAD8E4;
  }
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-recruit__el dl dd {
    border: none;
    padding-bottom: 2rem;
    font-size: 1.4rem;
  }
}
.p-support-center .s-recruit__el dl dd ul {
  padding-left: 1em;
}
.p-support-center .s-recruit__el dl dd ul li {
  list-style: disc;
}
.p-support-center .s-recruit__el dl dd ol {
  padding-left: 1em;
}
.p-support-center .s-recruit__el dl dd ol li {
  list-style: auto;
}
.p-support-center .s-link {
  margin-top: 8rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  width: 110rem;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-link {
    width: 100%;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    margin-top: 3rem;
    padding: 1.4rem;
  }
}
.p-support-center .s-link__el {
  position: relative;
  border-radius: 0.8rem;
  overflow: hidden;
}
.p-support-center .s-link__el::after {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  background: linear-gradient(332.01deg, rgba(255, 255, 255, 0.8) -10.93%, rgba(64, 84, 121, 0.8) 29.57%, rgba(0, 26, 76, 0.9) 89.15%);
  opacity: 0.5;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-link__el {
    height: 16rem;
  }
  .p-support-center .s-link__el img {
    position: absolute;
    height: 100%;
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
.p-support-center .s-link__ttl {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 8.5rem;
  color: #fff;
  z-index: 1;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-link__ttl {
    left: 3rem;
  }
}
.p-support-center .s-link__ttl h3 {
  font-family: "Poppins", sans-serif;
  font-size: 6.8rem;
  font-weight: normal;
  line-height: 1;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-link__ttl h3 {
    font-size: 4.6rem;
  }
}
.p-support-center .s-link__ttl small {
  font-size: 1.8rem;
}
.p-support-center .s-link__arrow {
  position: absolute;
  width: 5rem;
  height: 5rem;
  bottom: 3rem;
  right: 3rem;
  border-radius: 9999px;
  background: #fff;
  z-index: 1;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-link__arrow {
    width: 3rem;
    height: 3rem;
    bottom: 1.5rem;
    right: 1.5rem;
  }
}
.p-support-center .s-link__arrow::after {
  content: "";
  height: 1rem;
  width: 1rem;
  border-top: 1px solid #001A4C;
  border-right: 1px solid #001A4C;
  position: absolute;
  top: 50%;
  left: calc(50% - 0.5rem);
  transform: rotate(45deg) translate(-50%, -25%);
  transform-origin: center center;
}
@media screen and (max-width: 767px), print {
  .p-support-center .s-link__arrow::after {
    height: 0.5rem;
    width: 0.5rem;
    left: calc(50% - 0.3rem);
  }
}
.p-support-center .l-footer .b-group {
  padding: 5rem 0;
  background: #004289;
}
@media screen and (max-width: 767px), print {
  .p-support-center .l-footer .b-group {
    padding: 3.5rem 0 2rem;
  }
}
.p-support-center .l-footer .b-group__ttl {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #fff;
  border-bottom: 1px solid #fff;
  padding-bottom: 0.8rem;
  margin-bottom: 2rem;
}
.p-support-center .l-footer .b-group__ttl a {
  display: flex;
  font-size: 1.5rem;
  gap: 0.8rem;
  color: rgba(255, 255, 255, 0.6);
  font-weight: 400;
}
.p-support-center .l-footer .b-group__ttl a img, .p-support-center .l-footer .b-group__ttl a svg {
  width: 1.3rem;
}
@media screen and (min-width: 768px), print {
  .p-support-center .l-footer .b-group-inner {
    display: grid;
    grid-template-columns: 18rem 1fr;
    -moz-column-gap: 7rem;
         column-gap: 7rem;
  }
}
@media screen and (max-width: 767px), print {
  .p-support-center .l-footer .b-group-inner .logo {
    width: 15rem;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 3rem;
  }
}
.p-support-center .l-footer .b-group-inner dl {
  display: grid;
  flex-direction: column;
  row-gap: 0.6rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .l-footer .b-group-inner dl {
    row-gap: 0.8rem;
    margin-top: 1.5rem;
  }
}
.p-support-center .l-footer .b-group-inner dl div {
  display: grid;
  grid-template-columns: 11rem 1fr;
  -moz-column-gap: 1.5rem;
       column-gap: 1.5rem;
  align-items: center;
}
@media screen and (max-width: 767px), print {
  .p-support-center .l-footer .b-group-inner dl div {
    -moz-column-gap: 1rem;
         column-gap: 1rem;
  }
}
.p-support-center .l-footer .b-group-inner dl div dt {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  padding: 0.5rem 0;
  font-size: 1.2rem;
  font-weight: bold;
  line-height: 1.5;
  color: #fff;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px), print {
  .p-support-center .l-footer .b-group-inner dl div dt {
    font-size: 1.4rem;
    letter-spacing: 0.05em;
  }
}
.p-support-center .l-footer .b-group-inner dl div dt span {
  position: relative;
  z-index: 1;
  text-align: center;
}
.p-support-center .l-footer .b-group-inner dl div dt::after {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  content: "";
  background-color: rgba(255,255,255,0.15);
}
.p-support-center .l-footer .b-group-inner dl div dd ul {
  display: flex;
  flex-wrap: wrap;
  row-gap: 0.5rem;
  -moz-column-gap: 1.5rem;
       column-gap: 1.5rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .l-footer .b-group-inner dl div dd ul {
    row-gap: 0;
    line-height: 1.1;
  }
}
.p-support-center .l-footer .b-group-inner dl div dd ul li {
  font-size: 1.4rem;
  font-weight: 500;
  color: white;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px), print {
  .p-support-center .l-footer .b-group-inner dl div dd ul li {
    align-items: flex-start;
    font-size: 1.1rem;
    white-space: nowrap;
  }
}
.p-support-center .l-footer .b-group-inner dl div dd ul a {
  display: flex;
  -moz-column-gap: 0.8rem;
       column-gap: 0.8rem;
  align-items: center;
  transition: 0.3s all;
  color: #ffffff;
  font-weight: 400;
}
.p-support-center .l-footer .b-group-inner dl div dd ul a span {
  flex-shrink: 0;
  margin-top: 0.3rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .l-footer .b-group-inner dl div dd ul a span {
    margin-top: 0.8rem;
  }
}
.p-support-center .l-footer .b-group-inner dl div dd ul a span svg {
  width: 1.2rem;
  height: auto;
  opacity: 0.6;
}
.p-support-center .modal {
  height: 100%;
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99;
  display: none;
}
.p-support-center .modal > div {
  display: grid;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 767px), print {
  .p-support-center .modal > div {
    overflow: auto;
    padding: 2rem 1rem;
  }
}
.p-support-center .modal-overlay {
  position: fixed;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background: rgba(173, 208, 255, 0.8);
}
.p-support-center .modal-arw {
  width: 7rem;
  height: 7rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%) translateX(-100%);
  left: -2rem;
  border-radius: 9999px;
  background: #fff;
  border: 2px solid #004EA2;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.p-support-center .modal-arw::after {
  content: "";
  position: relative;
  left: 0.2rem;
  height: 1.5rem;
  width: 1.5rem;
  border-top: 2px solid #004EA2;
  border-left: 2px solid #004EA2;
  transform: rotate(-45deg);
}
.p-support-center .modal-prev {
  left: auto;
  right: -2rem;
  transform: translateY(-50%) translateX(100%) scaleX(-1);
}
.p-support-center .modal-inner {
  position: relative;
  z-index: 2;
  background: #fff;
  border-radius: 6rem;
  padding: 7rem;
  width: 95rem;
  height: 90vh;
  display: none;
}
@media screen and (max-width: 767px), print {
  .p-support-center .modal-inner {
    width: 100%;
    height: auto;
    padding: 4rem 2rem;
    border-radius: 4rem;
  }
}
.p-support-center .modal-inner-inner {
  display: grid;
  height: 100%;
  grid-template-rows: auto 1fr;
  gap: 5rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .modal-inner-inner {
    display: block;
  }
}
.p-support-center .modal-top {
  display: grid;
  grid-template-columns: 19rem 1fr;
  align-items: center;
  gap: 4rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .modal-top {
    display: block;
  }
  .p-support-center .modal-top__img {
    width: 100%;
    height: auto;
  }
}
@media screen and (max-width: 767px) and (max-width: 767px), print {
  .p-support-center .modal-top__img {
    height: 24rem;
  }
  .p-support-center .modal-top__img img {
    height: 100%;
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
@media screen and (max-width: 767px), print {
  .p-support-center .modal-top__right {
    margin-top: 1.6rem;
  }
  .p-support-center .modal-top__top {
    display: flex;
    align-items: flex-end;
    gap: 2rem;
  }
}
.p-support-center .modal-top__name {
  font-size: 4rem;
  font-family: "Outfit", sans-serif;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px), print {
  .p-support-center .modal-top__name {
    font-size: 3.2rem;
  }
}
.p-support-center .modal-top__name small {
  font-size: 2.4rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .modal-top__name small {
    font-size: 1.6rem;
  }
}
.p-support-center .modal-top__date {
  font-size: 1.8rem;
  margin-top: 0.5rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .modal-top__date {
    font-size: 1.6rem;
    position: relative;
    top: 0.3rem;
  }
}
.p-support-center .modal-top__txt {
  margin-top: 1.5rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .modal-top__txt {
    font-size: 1.5rem;
  }
}
.p-support-center .modal-top__txt span {
  display: inline-flex;
  padding-left: 0.7em;
  text-indent: -0.7em;
  font-size: 1.4rem;
}
.p-support-center .modal-txt {
  display: grid;
  gap: 4rem;
  overflow: auto;
  padding-right: 2rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .modal-txt {
    margin-top: 3rem;
    padding-right: 0;
    overflow: inherit;
  }
}
.p-support-center .modal-txt h4 {
  font-size: 2rem;
  color: #004EA2;
}
@media screen and (max-width: 767px), print {
  .p-support-center .modal-txt h4 {
    font-size: 1.6rem;
  }
}
.p-support-center .modal-txt p {
  margin-top: 1rem;
}
@media screen and (max-width: 767px), print {
  .p-support-center .modal-txt p {
    font-size: 1.4rem;
  }
}
.p-support-center .modal-close {
  position: absolute;
  right: 3rem;
  top: 3rem;
  width: 6rem;
  height: 6rem;
  background: #004EA2;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  cursor: pointer;
  transition: 0.3s;
}
@media screen and (min-width: 768px), print {
  .p-support-center .modal-close:hover {
    opacity: 0.7;
  }
}
@media screen and (max-width: 767px), print {
  .p-support-center .modal-close {
    position: fixed;
    top: 1rem;
    right: 1rem;
    width: 4rem;
    height: 4rem;
  }
}
.p-support-center .modal-close__txt {
  font-family: "Outfit", sans-serif;
  color: #fff;
  font-size: 1.2rem;
}
.p-support-center .modal-close__batsu {
  margin-left: auto;
  margin-right: auto;
  width: 1.6rem;
  height: 1.6rem;
  display: block;
  position: relative;
}
.p-support-center .modal-close__batsu span {
  height: 100%;
  width: 1px;
  background: #fff;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
}
.p-support-center .modal-close__batsu span:last-of-type {
  transform: translate(-50%, -50%) rotate(-45deg);
}
.p-support-center .bg01 {
  position: absolute;
  top: 20rem;
  z-index: -1;
}
@media screen and (max-width: 767px), print {
  .p-support-center .bg01 {
    top: 47rem;
  }
}
.p-support-center .bg02 {
  background: radial-gradient(50% 50% at 50% 50%, #D7F5FF 0%, rgba(255, 255, 255, 0) 100%);
  width: 243.5rem;
  height: 243.5rem;
  position: absolute;
  top: 312rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
@media screen and (max-width: 767px), print {
  .p-support-center .bg02 {
    background: radial-gradient(54.42% 54.42% at 50% 45.58%, #D7F5FF 0%, rgba(255, 255, 255, 0) 100%);
    width: 197rem;
    height: 197rem;
    top: 232rem;
    left: -785.5px;
  }
}
.p-support-center .bg03 {
  position: absolute;
  width: 201.2rem;
  height: 201.2rem;
  top: 294.3rem;
  left: 50%;
  background: radial-gradient(50% 50% at 50% 50%, #C2DBFF 0%, rgba(255, 255, 255, 0) 100%);
  z-index: -1;
}
@media screen and (max-width: 767px), print {
  .p-support-center .bg03 {
    background: radial-gradient(50% 50% at 50% 50%, #C2DBFF 0%, rgba(255, 255, 255, 0) 100%);
    width: 132.1rem;
    height: 132.1rem;
    top: 461.7rem;
    left: -19rem;
  }
}
.p-support-center .bg04 {
  position: absolute;
  width: 201.2rem;
  height: 201.2rem;
  top: 340rem;
  left: 50%;
  transform: translateX(-170rem);
  background: radial-gradient(50% 50% at 50% 50%, rgba(194, 219, 255, 0.4) 0%, rgba(255, 255, 255, 0) 100%);
  z-index: -1;
}
@media screen and (max-width: 767px), print {
  .p-support-center .bg04 {
    background: radial-gradient(50% 50% at 50% 50%, #D7F5FF 0%, rgba(255, 255, 255, 0) 100%);
    width: 117.9rem;
    height: 117.9rem;
    top: 741rem;
    left: 50%;
    transform: translateX(-50%);
  }
}
.p-support-center .bg05 {
  position: absolute;
  width: 201.2rem;
  height: 201.2rem;
  top: 592.2rem;
  left: 50%;
  transform: translateX(-30rem);
  background: radial-gradient(50% 50% at 50% 50%, rgba(194, 219, 255, 0.4) 0%, rgba(255, 255, 255, 0) 100%);
  z-index: -1;
}
@media screen and (max-width: 767px), print {
  .p-support-center .bg05 {
    background: radial-gradient(50% 50% at 50% 50%, #C2DBFF 0%, rgba(255, 255, 255, 0) 100%);
    width: 117.9rem;
    height: 117.9rem;
    top: 841rem;
    left: 50%;
    transform: translateX(-50%) translateX(50rem);
  }
}
.p-support-center .bg06 {
  position: absolute;
  width: 243.5rem;
  height: 243.5rem;
  top: 482rem;
  left: 50%;
  transform: translateX(-50%);
  background: radial-gradient(50% 50% at 50% 50%, rgba(194, 219, 255, 0.4) 0%, rgba(255, 255, 255, 0) 100%);
  z-index: -1;
}
@media screen and (max-width: 767px), print {
  .p-support-center .bg06 {
    display: none;
    background: radial-gradient(50% 50% at 50% 50%, #C2DBFF 0%, rgba(255, 255, 255, 0) 100%);
    width: 117.9rem;
    height: 117.9rem;
    top: 1061rem;
    left: 50%;
    transform: translateX(-50%) translateX(-40rem);
  }
}
.p-support-center .bg07 {
  position: absolute;
  width: 201.2rem;
  height: 201.2rem;
  top: 678.9rem;
  left: 50%;
  transform: translateX(-172rem);
  background: radial-gradient(50% 50% at 50% 50%, rgba(194, 219, 255, 0.4) 0%, rgba(255, 255, 255, 0) 100%);
  z-index: -1;
}
.p-support-center .countUp {
  display: flex;
  gap: 4px;
  font-size: 2em;
  line-height: 1em;
  overflow: hidden;
}
.p-support-center .digit-container {
  position: relative;
  width: 1ch;
  height: 1em;
  overflow: hidden;
}
.p-support-center .digit-strip {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  transition: transform 0.3s ease-out;
}
.p-support-center .digit-strip span {
  display: block;
  height: 1em;
  text-align: center;
}

/*--------------------------------------
  shop/top
--------------------------------------*/
.p-shop__top {
  padding: 0 20px;
  /* ======== SP用スタイル（767px以下） ======== */
}
@media screen and (max-width: 767px), print {
  .p-shop__top {
    padding: 0;
  }
}
.p-shop__top .certified-block {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 5rem;
  align-items: flex-start;
  gap: 2.4rem;
}
.p-shop__top .certified-image {
  width: 25rem;
}
.p-shop__top .certified-text {
  flex: 1;
  min-width: 0;
  margin-top: -0.5rem;
}
.p-shop__top .certified-text .ttl {
  font-size: 1.5rem;
  font-weight: 500;
}
.p-shop__top .certified-text ul {
  display: flex;
  flex-wrap: wrap;
}
.p-shop__top .certified-text ul li {
  width: 23rem;
  font-size: 1.2rem;
  position: relative;
  margin-left: 1rem;
}
.p-shop__top .certified-text ul li::after {
  content: "●";
  font-size: 0.8rem;
  color: #004EA2;
  position: absolute;
  left: -1.3rem;
  top: 0.4rem;
}
.p-shop__top .certified-text .c-productDetail__btnArea {
  margin: 2rem 0 0;
  justify-content: flex-start;
}
.p-shop__top .certified-text .c-productDetail__btnArea .c-btnA {
  margin: 0;
  min-width: 20rem;
  max-width: -moz-max-content !important;
  max-width: max-content !important;
}
.p-shop__top .certified-text h3 {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  color: #004EA2;
}
.p-shop__top .certified-text p {
  font-size: 1.4rem;
  font-weight: 400;
}
.p-shop__top .certified-text .mark_list {
  counter-reset: item;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.p-shop__top .certified-text .mark_list li {
  position: relative;
  padding-left: 2.5em;
  line-height: 1.8;
  margin: 0;
}
.p-shop__top .certified-text .mark_list li::before {
  counter-increment: item;
  content: counter(item);
  position: absolute;
  top: 0.1em;
  left: 0;
  width: 2em;
  height: 2em;
  background-color: #ECF2FA;
  color: #001A4C;
  font-weight: bold;
  font-size: 1rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.p-shop__top .certified-block.login {
  display: grid;
  grid-template-columns: 1fr auto;
}
@media screen and (max-width: 767px), print {
  .p-shop__top .certified-block.login {
    grid-template-columns: auto;
  }
}
.p-shop__top .certified-block.login .certified-image {
  width: 31.8rem;
}
@media screen and (max-width: 767px), print {
  .p-shop__top .certified-block.login .certified-image {
    width: 100%;
  }
}
.p-shop__top .certified-block.login .certified-text {
  margin-top: 0;
}
.p-shop__top .certified-block.login .certified-text ul li {
  width: auto;
}
.p-shop__top .certified-block.login .certified-text ul li::after {
  content: none;
}
.p-shop__top .payment .flex {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 100px;
}
@media screen and (max-width: 767px), print {
  .p-shop__top .payment .flex {
    grid-template-columns: auto;
    gap: 2rem;
  }
}
.p-shop__top .payment .flex .ttl {
  font-size: 1.8rem;
  font-weight: 700;
  margin-bottom: 10px;
}
.p-shop__top .payment .flex .list li {
  font-size: 1.4rem;
}
.p-shop__top .payment .txt_box {
  margin-bottom: 3rem;
}
.p-shop__top .payment .txt_box .ttl {
  font-size: 1.8rem;
  font-weight: 700;
  margin-bottom: 10px;
}
.p-shop__top .payment .txt_box .list li {
  font-size: 1.4rem;
}
.p-shop__top .payment .law_txt a {
  color: #004EA2;
}
.p-shop__top .p-solution__telWrap .flex {
  display: grid;
  justify-content: center;
  grid-template-columns: 1fr 1fr;
  width: 100%;
  max-width: 58.4rem;
  margin: auto;
  margin-bottom: 2rem;
}
@media screen and (max-width: 767px), print {
  .p-shop__top .p-solution__telWrap .flex {
    grid-template-columns: auto;
  }
}
.p-shop__top .p-solution__telWrap .flex .name {
  text-align: left;
  font-size: 1.6rem;
}
.p-shop__top .p-solution__telWrap .flex .tel {
  text-align: left;
  line-height: 1.5;
}
.p-shop__top .p-solution__telWrap .flex .right .tel:last-child {
  line-height: 1;
}
.p-shop__top .clearfix::after {
  content: "";
  display: block;
  clear: both;
}
@media screen and (max-width: 767px) {
  .p-shop__top .panel {
    width: 100%;
  }
  .p-shop__top .certified-block {
    border-bottom: 1px solid #ccc;
    padding-bottom: 3rem;
    margin-bottom: 3rem;
  }
  .p-shop__top .certified-text {
    flex: auto;
    min-width: 0;
  }
  .p-shop__top .certified-image {
    width: 50%;
    margin: auto;
  }
  .p-shop__top .certified-text a {
    max-width: 20rem;
    margin-right: auto;
    margin-top: 1.5rem;
    justify-content: flex-end;
    flex-direction: row-reverse;
    height: 3.8rem;
    padding-left: 1.5rem;
    gap: 0.8rem;
  }
  .p-shop__top .certified-text a img, .p-shop__top .certified-text a svg {
    width: 1.8rem !important;
  }
}

/*--------------------------------------
  ouenSeminar/top
--------------------------------------*/
.p-ouenSeminar__top {
  padding: 0 20px;
}
@media screen and (max-width: 767px), print {
  .p-ouenSeminar__top {
    padding: 0;
  }
}
@media screen and (max-width: 767px), print {
  .p-ouenSeminar__top .p-products_gyou__sec .products_box {
    height: auto;
  }
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .box {
  grid-template-columns: 22rem 1fr;
}
@media screen and (max-width: 767px), print {
  .p-ouenSeminar__top .p-products_gyou__sec .products_box .box {
    grid-template-columns: 1fr;
  }
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .box .txtArea h3.ttl {
  font-size: 2rem;
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .box .txtArea .tagList {
  gap: 0 0.5rem;
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .top_txt {
  font-weight: 700;
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box.pickup::after {
  content: "";
  position: absolute;
  top: -3rem;
  left: -3rem;
  background-color: #FFDC41;
  color: #004EA2;
  font-size: 1.8rem;
  font-weight: 700;
  padding: 6rem;
  padding-top: 4rem;
  border-bottom-right-radius: 9999px;
}
@media screen and (max-width: 767px), print {
  .p-ouenSeminar__top .p-products_gyou__sec .products_box.pickup::after {
    padding: 5.5rem;
  }
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box.pickup::before {
  content: "";
  background: url(/assets_renew/images/ouen-seminar/pickup-ic.svg) no-repeat;
  width: 4.2rem;
  height: 3.4rem;
  background-size: cover;
  position: absolute;
  top: 1.2rem;
  left: 1rem;
  z-index: 10;
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .products_boxBottom {
  background: none;
  margin: 0;
  padding: 0;
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box.is-active .js-productsGyou__box-Open {
  display: none;
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .hiddenArea.hidden {
  display: none;
}
@keyframes show {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-productsGyou__box-Btn, .p-ouenSeminar__top .p-products_gyou__sec .products_box .js-ouenSeminar-Btn {
  height: 3.2rem;
  border-radius: 9999px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 1.2rem;
  min-width: 20rem;
  cursor: pointer;
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-productsGyou__box-BtnWrap, .p-ouenSeminar__top .p-products_gyou__sec .products_box .js-ouenSeminar-BtnWrap {
  display: flex;
  justify-content: center;
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-productsGyou__box-Btn span, .p-ouenSeminar__top .p-products_gyou__sec .products_box .js-ouenSeminar-Btn span {
  width: 100%;
  text-align: center;
  font-size: 1.2rem;
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-productsGyou__box-Btn img,
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-productsGyou__box-Btn svg, .p-ouenSeminar__top .p-products_gyou__sec .products_box .js-ouenSeminar-Btn img,
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-ouenSeminar-Btn svg {
  width: 1.4rem;
  flex-shrink: 0;
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-productsGyou__box-Open, .p-ouenSeminar__top .p-products_gyou__sec .products_box .js-ouenSeminar-Open {
  animation: show 0.3s linear 0s;
  background-color: #001A4C;
  color: #fff;
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-productsGyou__box-Open img,
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-productsGyou__box-Open svg, .p-ouenSeminar__top .p-products_gyou__sec .products_box .js-ouenSeminar-Open img,
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-ouenSeminar-Open svg {
  transform: rotate(90deg);
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-productsGyou__box-Open img circle,
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-productsGyou__box-Open svg circle, .p-ouenSeminar__top .p-products_gyou__sec .products_box .js-ouenSeminar-Open img circle,
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-ouenSeminar-Open svg circle {
  fill: #fff;
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-productsGyou__box-Open img line,
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-productsGyou__box-Open img path,
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-productsGyou__box-Open svg line,
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-productsGyou__box-Open svg path, .p-ouenSeminar__top .p-products_gyou__sec .products_box .js-ouenSeminar-Open img line,
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-ouenSeminar-Open img path,
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-ouenSeminar-Open svg line,
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-ouenSeminar-Open svg path {
  stroke: #001A4C;
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-productsGyou__box-Close, .p-ouenSeminar__top .p-products_gyou__sec .products_box .js-ouenSeminar-Close {
  border: 1px solid;
  background-color: #fff;
  color: #001A4C;
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-productsGyou__box-Close img,
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-productsGyou__box-Close svg, .p-ouenSeminar__top .p-products_gyou__sec .products_box .js-ouenSeminar-Close img,
.p-ouenSeminar__top .p-products_gyou__sec .products_box .js-ouenSeminar-Close svg {
  transform: rotate(-90deg);
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box {
  margin: 0 4rem;
  border-top: 2px solid #ECF2FA;
  padding-top: 2rem;
}
@media screen and (max-width: 767px), print {
  .p-ouenSeminar__top .p-products_gyou__sec .profile_box {
    margin: 0 2rem;
  }
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .name_box {
  display: grid;
  grid-template-columns: 20rem 1fr;
  gap: 3rem;
  margin-bottom: 2rem;
}
@media screen and (max-width: 767px), print {
  .p-ouenSeminar__top .p-products_gyou__sec .profile_box .name_box {
    grid-template-columns: auto;
    gap: 2rem;
  }
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .name_box .name .sub_ttl {
  color: #000;
  margin-bottom: 0.5rem;
  font-size: 1.2rem;
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .name_box .name .ttl {
  font-size: 2.6rem;
  font-weight: 700;
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .name_box .txt_box .txt {
  font-size: 1.3rem;
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .name_box .txt_box .txt a {
  color: #004EA2;
  text-decoration: underline;
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .txt_area {
  margin-bottom: 1.5rem;
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .txt_area .txt {
  font-size: 1.4rem;
  margin-bottom: 1.5rem;
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .txt_area .txt:last-child {
  margin-bottom: 0;
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .download {
  background: #ECF2FA;
  padding: 2rem;
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .download .flex {
  display: grid;
  grid-template-columns: 44.4rem 1fr;
  gap: 2rem;
}
@media screen and (max-width: 767px), print {
  .p-ouenSeminar__top .p-products_gyou__sec .profile_box .download .flex {
    grid-template-columns: auto;
    gap: 2rem;
  }
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .download .flex p {
  font-size: 1.4rem;
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .download .flex .btnArea .p-product-top__mainBtn {
  margin-bottom: 1rem;
  font-size: 1.4rem;
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .download .flex .btnArea .p-product-top__mainBtn svg {
  transform: none;
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .download .flex .btnArea .p-product-top__mainBtn.mainBtn_w svg {
  transform: rotate(90deg);
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .download .flex .btnArea .p-product-top__mainBtn.mainBtn_w svg circle {
  fill: #004EA2;
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .download .flex .btnArea .p-product-top__mainBtn.mainBtn_w:hover {
  background-color: #004EA2;
  color: #fff;
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .download .flex .btnArea .p-product-top__mainBtn.mainBtn_w:hover circle {
  fill: #fff;
}
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .download .flex .btnArea .p-product-top__mainBtn.mainBtn_w:hover line,
.p-ouenSeminar__top .p-products_gyou__sec .profile_box .download .flex .btnArea .p-product-top__mainBtn.mainBtn_w:hover path {
  stroke: #004EA2;
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .box {
  align-items: flex-start;
}
.p-ouenSeminar__top .p-products_gyou__sec .products_box .box img {
  margin-top: 0;
  border-radius: 0.5rem;
  overflow: hidden;
  -o-object-position: top;
     object-position: top;
}
.p-ouenSeminar__top .archive_box {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 3rem 2rem;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px), print {
  .p-ouenSeminar__top .archive_box {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 2rem;
  }
}
.p-ouenSeminar__top .archive_box .box .img {
  margin-bottom: 1rem;
}
.p-ouenSeminar__top .archive_box .box .img img {
  height: auto !important;
  border-radius: 0.5rem;
  overflow: hidden;
}
.p-ouenSeminar__top .archive_box .box .txt {
  line-height: 1.1;
  margin-bottom: 0.5rem;
}
.p-ouenSeminar__top .archive_box .box .txt .date {
  color: #001A4C;
  font-size: 1.2rem;
  padding-right: 0.5rem;
  opacity: 0.5;
}
.p-ouenSeminar__top .archive_box .box .txt .dag {
  color: #004EA2;
  font-size: 1.2rem;
  opacity: 0.5;
}
.p-ouenSeminar__top .archive_box .box .ttl {
  font-size: 1.4rem;
  color: #001A4C;
  font-weight: 700;
  margin-bottom: 0.5rem;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
@media screen and (max-width: 767px), print {
  .p-ouenSeminar__top .archive_box .box .ttl {
    font-size: 1.4rem;
  }
}
.p-ouenSeminar__top .archive_box .box .name {
  font-size: 1.2rem;
  min-height: 50px;
  opacity: 0.8;
}
.p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn {
  background-color: #004EA2;
  color: #fff;
  font-size: 1.2rem;
  letter-spacing: 0;
  padding: 0.6rem 1.2rem;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  gap: 0.7rem;
  transition: 0.3s;
  border: 1px solid #004EA2;
  margin-bottom: 0.5rem;
}
.p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn img,
.p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn svg {
  width: 1.4rem;
  transform: none;
  transition: 0.3s;
}
.p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn circle,
.p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn line,
.p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn path {
  transition: 0.3s;
}
@media screen and (min-width: 768px), print {
  .p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn:hover {
    background-color: #fff;
    color: #004EA2;
  }
  .p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn:hover circle {
    fill: #004EA2;
  }
  .p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn:hover line,
  .p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn:hover path {
    stroke: #fff;
  }
}
.p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn.mainBtn_w {
  background-color: #fff;
  border: 1px solid #001A4C;
  color: #001A4C;
}
.p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn.mainBtn_w svg {
  transform: rotate(90deg);
}
.p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn.mainBtn_w svg circle {
  fill: #001A4C;
}
.p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn.mainBtn_w svg line,
.p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn.mainBtn_w svg path {
  stroke: #fff;
}
@media screen and (min-width: 768px), print {
  .p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn.mainBtn_w:hover {
    background-color: #001A4C;
    color: #fff;
  }
  .p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn.mainBtn_w:hover circle {
    fill: #fff;
  }
  .p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn.mainBtn_w:hover line,
  .p-ouenSeminar__top .archive_box .box .p-product-top__mainBtn.mainBtn_w:hover path {
    stroke: #001A4C;
  }
}
.p-ouenSeminar__top .point_box {
  margin-top: 2rem;
  margin-bottom: 3rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 2rem;
}
@media screen and (max-width: 767px), print {
  .p-ouenSeminar__top .point_box {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 2rem;
  }
}
.p-ouenSeminar__top .point_box .box .img {
  text-align: center;
  margin-bottom: 0.5rem;
}
.p-ouenSeminar__top .point_box .box .ttl {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  text-align: center;
}
@media screen and (max-width: 767px), print {
  .p-ouenSeminar__top .point_box .box .ttl {
    font-size: 1.4rem;
  }
}
.p-ouenSeminar__top .point_box .box .txt {
  font-size: 1.4rem;
}
@media screen and (max-width: 767px), print {
  .p-ouenSeminar__top .point_box .box .txt {
    font-size: 1.2rem;
  }
}
.p-ouenSeminar__top .faq-title {
  font-size: 1.8rem;
  font-weight: bold;
  margin-bottom: 1.5rem;
  color: #003366;
}
.p-ouenSeminar__top .faq-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.p-ouenSeminar__top .faq-item {
  border-bottom: 2px solid #ECF2FA;
  padding-bottom: 1.5rem;
}
.p-ouenSeminar__top .faq-item dd {
  position: relative;
  line-height: 1.6;
  padding-left: 2.6rem;
  font-weight: 700;
}
.p-ouenSeminar__top .faq-item dd::before {
  content: "A.";
  position: absolute;
  left: 0;
  top: 0;
  font-weight: bold;
  color: #003366;
}
.p-ouenSeminar__top .faq-item dt {
  position: relative;
  line-height: 1.6;
  padding-left: 2.6rem;
}
.p-ouenSeminar__top .faq-item dt::before {
  content: "Q.";
  margin-right: 0.5em;
  font-weight: bold;
  color: #003366;
  position: absolute;
  left: 0;
  top: 0;
}

.p-newsrelease-archive .container {
  display: grid;
  grid-template-columns: 12rem 1fr;
  gap: 6rem;
}
@media screen and (max-width: 767px), print {
  .p-newsrelease-archive .container {
    display: flex;
    flex-direction: column-reverse;
  }
}
.p-newsrelease-archive .container .list {
  display: grid;
}
.p-newsrelease-archive .container .list.media {
  margin-top: -3rem;
}
.p-newsrelease-archive .container .list .ttl {
  text-align: center;
  padding-bottom: 2rem;
}
.p-newsrelease-archive .container .list .ttl:nth-child(n+2) {
  padding-top: 4rem;
}
.p-newsrelease-archive .container .list .link {
  display: grid;
  grid-template-columns: 10.7rem 1fr;
}
@media screen and (max-width: 767px), print {
  .p-newsrelease-archive .container .list .link {
    grid-template-columns: 1fr;
    border-top: 1px solid transparent;
    border-bottom: 1px solid transparent;
    -o-border-image: linear-gradient(to right, #004EA2 30%, #D9D9D9 30%) 1;
       border-image: linear-gradient(to right, #004EA2 30%, #D9D9D9 30%) 1;
    padding-block: 1.5rem;
    padding-inline: 1rem;
  }
}
.p-newsrelease-archive .container .list .link:nth-child(n+2) {
  margin-top: -1px;
}
.p-newsrelease-archive .container .list .link time {
  border-top: 1px solid #004EA2;
  border-bottom: 1px solid #004EA2;
  padding-block: 2rem;
  padding-left: 1rem;
  font-size: 1.4rem;
  color: rgba(0, 26, 76, 0.7019607843);
}
@media screen and (max-width: 767px), print {
  .p-newsrelease-archive .container .list .link time {
    padding: 0;
    border: none;
  }
}
.p-newsrelease-archive .container .list .link h4 {
  border-top: 1px solid #D9D9D9;
  border-bottom: 1px solid #D9D9D9;
  padding-block: 2rem;
  padding-left: 2rem;
  font-weight: 500;
}
@media screen and (max-width: 767px), print {
  .p-newsrelease-archive .container .list .link h4 {
    padding: 0;
    border: none;
  }
}
.p-newsrelease-archive .container .list .text-link {
  color: #0078C8;
}
@media screen and (max-width: 767px), print {
  .p-newsrelease-archive .sidebar {
    width: 100%;
  }
}
@media screen and (min-width: 768px), print {
  .p-newsrelease-archive .sidebar__inner {
    position: sticky;
    top: 11rem;
  }
}
.p-newsrelease-archive .sidebar h3 {
  font-weight: 400;
  font-style: italic;
  display: flex;
  align-items: center;
  border-bottom: 1px solid #001A4C;
}
.p-newsrelease-archive .sidebar h3 img {
  width: 3.3rem;
}
.p-newsrelease-archive .sidebar ul {
  margin-top: 2rem;
  display: grid;
  gap: 0.7rem;
  margin-left: 0.7rem;
}
@media screen and (max-width: 767px), print {
  .p-newsrelease-archive .sidebar ul {
    grid-template-columns: repeat(3, 1fr);
  }
}
.p-newsrelease-archive .sidebar ul a {
  font-weight: normal;
  padding-left: 2rem;
  position: relative;
  transition: 0.3s;
}
.p-newsrelease-archive .sidebar ul a:hover {
  opacity: 0.7;
}
.p-newsrelease-archive .sidebar ul a::before {
  content: "";
  position: absolute;
  width: 1rem;
  height: 1rem;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  background: url(/assets_renew/images/common/ic-arrow-right.svg);
}

.p-newsrelease-single .container {
  display: grid;
  grid-template-columns: 12rem 1fr;
  gap: 6rem;
}
@media screen and (max-width: 767px), print {
  .p-newsrelease-single .container {
    display: flex;
    flex-direction: column-reverse;
  }
}
.p-newsrelease-single .container .ttlArea {
  margin-bottom: 2rem;
}
.p-newsrelease-single .container .ttlArea__time {
  font-size: 1.4rem;
  color: #001A4C;
}
.p-newsrelease-single .container .ttlArea__ttl {
  font-size: 2.4rem;
}
@media screen and (max-width: 767px), print {
  .p-newsrelease-single .container .ttlArea__ttl {
    font-size: 2rem;
  }
}
.p-newsrelease-single .container .thumbnail {
  width: 100%;
  margin-top: 2.3rem;
}
.p-newsrelease-single .container .post-thumbnail img {
  height: auto !important;
}
.p-newsrelease-single .container .text-editor {
  margin-top: 4rem;
}
@media screen and (max-width: 767px), print {
  .p-newsrelease-single .container .text-editor {
    padding-inline: 0;
    margin-top: 2rem;
  }
}
.p-newsrelease-single .container .text-editor p {
  margin: 3rem 0;
}
.p-newsrelease-single .container .text-editor h2 {
  background-color: #004EA2;
  border-radius: 0.6rem;
  padding: 1.4rem 1.6rem;
  font-size: 2.4rem;
  color: #fff;
  display: flex;
  gap: 1.3rem;
  margin-bottom: 2.4rem;
  line-height: 1.3;
}
.p-newsrelease-single .container .text-editor h3 {
  font-size: 2rem;
  margin-top: 3rem;
  margin-bottom: 2rem;
  border-bottom: 1px solid transparent;
  -o-border-image: linear-gradient(to right, #004EA2 20%, #D9D9D9 20%) 1;
     border-image: linear-gradient(to right, #004EA2 20%, #D9D9D9 20%) 1;
  font-weight: normal;
  padding-bottom: 0.7rem;
}
.p-newsrelease-single .container .text-editor h4 {
  font-size: 1.6rem;
  color: #004EA2;
  display: flex;
  gap: 0.75rem;
  margin-bottom: 1.2rem;
}
.p-newsrelease-single .container .text-editor h4::before {
  content: "●";
  font-size: 1.1rem;
  margin-top: 5px;
}
.p-newsrelease-single .container .text-editor ul, .p-newsrelease-single .container .text-editor ol {
  padding-left: 1em;
}
.p-newsrelease-single .container .text-editor ul li, .p-newsrelease-single .container .text-editor ol li {
  list-style: auto;
  margin: 2rem 0;
}
.p-newsrelease-single .container .text-editor a {
  text-decoration: underline;
  color: #004EA2;
  transition: 0.3s;
  word-break: break-word;
}
.p-newsrelease-single .container .text-editor a:hover {
  opacity: 0.7;
}
.p-newsrelease-single .container .share {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #F0F0F0;
  height: 10.8rem;
  border-radius: 0.7rem;
  border: 1px solid #DFDFDF;
  gap: 1.7rem;
  margin-top: 6rem;
}
.p-newsrelease-single .container .share__inner {
  display: flex;
  gap: 0.8rem;
}
.p-newsrelease-single .container .share a {
  width: 4.6rem;
  height: 4.6rem;
  background: #fff;
  border: 1px solid #004EA2;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.p-newsrelease-single .container .share a.fb img, .p-newsrelease-single .container .share a.fb svg {
  height: 50%;
}
.p-newsrelease-single .container .share a.x img, .p-newsrelease-single .container .share a.x svg {
  height: 50%;
}
.p-newsrelease-single .container .share a.line img, .p-newsrelease-single .container .share a.line svg {
  height: 56%;
}
.p-newsrelease-single .container .share a.mail img, .p-newsrelease-single .container .share a.mail svg {
  height: 42%;
}
.p-newsrelease-single .container .share a.plus img, .p-newsrelease-single .container .share a.plus svg {
  height: 45%;
}
.p-newsrelease-single .container .prevNext {
  display: grid;
  align-items: center;
  grid-template-columns: repeat(3, 1fr);
  font-size: 1.4rem;
  color: #444444;
  padding-inline: 2rem;
  margin-top: 5rem;
}
@media screen and (max-width: 767px), print {
  .p-newsrelease-single .container .prevNext {
    padding-inline: 0;
  }
}
.p-newsrelease-single .container .prevNext__link {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
}
.p-newsrelease-single .container .prevNext__link span {
  width: 2.8rem;
  height: 2.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #004EA2;
  border-radius: 9999px;
  transition: 0.3s;
}
.p-newsrelease-single .container .prevNext__link span img, .p-newsrelease-single .container .prevNext__link span svg {
  width: 0.7rem;
}
.p-newsrelease-single .container .prevNext__prev span {
  transform: scaleX(-1);
}
.p-newsrelease-single .container .prevNext__list {
  text-align: center;
}
.p-newsrelease-single .container .prevNext__nextWrap {
  text-align: right;
}
@media screen and (max-width: 767px), print {
  .p-newsrelease-single .sidebar {
    width: 100%;
  }
}
@media screen and (min-width: 768px), print {
  .p-newsrelease-single .sidebar__inner {
    position: sticky;
    top: 11rem;
  }
}
.p-newsrelease-single .sidebar h3 {
  font-weight: 400;
  font-style: italic;
  display: flex;
  align-items: center;
  border-bottom: 1px solid #001A4C;
}
.p-newsrelease-single .sidebar h3 img {
  width: 3.3rem;
}
.p-newsrelease-single .sidebar ul {
  margin-top: 2rem;
  display: grid;
  gap: 0.7rem;
  margin-left: 0.7rem;
}
@media screen and (max-width: 767px), print {
  .p-newsrelease-single .sidebar ul {
    grid-template-columns: repeat(3, 1fr);
  }
}
.p-newsrelease-single .sidebar ul a {
  font-weight: normal;
  padding-left: 2rem;
  position: relative;
  transition: 0.3s;
}
.p-newsrelease-single .sidebar ul a:hover {
  opacity: 0.7;
}
.p-newsrelease-single .sidebar ul a::before {
  content: "";
  position: absolute;
  width: 1rem;
  height: 1rem;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  background: url(/assets_renew/images/common/ic-arrow-right.svg);
}

.p-movie .js-pickupSwiper {
  background: #004EA2;
  padding: 2.6rem;
  border-radius: 0 0 2rem 2rem;
  border-top: 0.4rem solid #001A4C;
}
@media screen and (max-width: 767px), print {
  .p-movie .js-pickupSwiper {
    width: 36rem;
  }
}
.p-movie .js-pickupSwiper .swiper-slide {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4rem;
  align-items: center;
}
@media screen and (max-width: 767px), print {
  .p-movie .js-pickupSwiper .swiper-slide {
    grid-template-columns: 1fr;
    width: 100% !important;
    gap: 2rem;
  }
}
.p-movie .swiper__wrap {
  padding-inline: 1rem;
}
@media screen and (max-width: 767px), print {
  .p-movie .swiper__wrap {
    padding: 0;
    position: relative;
  }
}
.p-movie .swiper__ttl {
  font-weight: 400;
  font-style: italic;
  display: flex;
  align-items: center;
  border-bottom: 1px solid #023F80;
  margin-bottom: -0.4rem;
}
.p-movie .swiper__ttl img {
  width: 4.3rem;
}
@media screen and (max-width: 767px), print {
  .p-movie .swiper__ttl {
    font-size: 2.8rem;
  }
}
.p-movie .swiper__inner {
  position: relative;
}
@media screen and (max-width: 767px), print {
  .p-movie .swiper__arrowWrap {
    position: absolute;
    top: -2rem;
    right: 2rem;
    width: 2rem;
  }
}
.p-movie .swiper__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%) translateX(-80%);
  left: 0;
  width: 3rem;
  height: 3rem;
  z-index: 3;
  cursor: pointer;
  transition: 0.3s;
}
.p-movie .swiper__arrow:hover {
  opacity: 0.7;
}
.p-movie .swiper__arrow::after {
  content: "";
  width: 80%;
  height: 80%;
  border-top: 3px solid #004EA2;
  border-left: 3px solid #004EA2;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-45deg);
}
@media screen and (max-width: 767px), print {
  .p-movie .swiper__arrow::after {
    width: 60%;
    height: 60%;
  }
}
.p-movie .swiper__next {
  transform: translateY(-50%) translateX(80%);
  left: auto;
  right: 0;
}
.p-movie .swiper__next::after {
  transform: translate(-50%, -50%) rotate(135deg);
}
.p-movie .swiper__dot {
  display: flex;
  justify-content: center;
  gap: 0.8rem;
  margin-top: 1.4rem;
}
.p-movie .swiper__dot span {
  margin: 0 !important;
  width: 1.6rem;
  height: 1.6rem;
}
.p-movie .slider__img {
  position: relative;
}
.p-movie .slider__img img {
  width: 100%;
}
.p-movie .slider__img::after {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.2);
  opacity: 0;
  transition: 0.3s;
}
.p-movie .slider__txtWrap * {
  color: #fff;
}
.p-movie .slider__ttl {
  font-size: 2.2rem;
  line-height: 1.5;
}
.p-movie .slider__txt {
  margin-top: 1.5rem;
  display: grid;
  gap: 1rem;
  font-size: 1.4rem;
}
.p-movie .slider:hover .slider__img::after {
  opacity: 1;
}
.p-movie .tab {
  display: flex;
  justify-content: center;
  gap: 1rem;
  margin-top: 6rem;
  border-bottom: 0.5rem solid #004EA2;
}
@media screen and (max-width: 767px), print {
  .p-movie .tab {
    margin-top: 4rem;
    justify-content: flex-start;
    box-sizing: content-box;
    min-width: 0;
    overflow: auto;
    width: 36rem;
  }
}
.p-movie .tab__el {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1.4rem;
  height: 5.6rem;
  border-radius: 2rem 2rem 0 0;
  padding: 0 4rem;
  padding-top: 0.5rem;
  color: #004EA2;
  border: 2px solid #004EA2;
  border-bottom: none;
  background: #fff;
  cursor: pointer;
  transition: 0.3s;
}
@media screen and (max-width: 767px), print {
  .p-movie .tab__el {
    flex-shrink: 0;
    white-space: nowrap;
    padding-left: 2rem;
    padding-right: 2rem;
    height: 4rem;
    border-radius: 1rem 1rem 0 0;
  }
}
.p-movie .tab__el:hover {
  opacity: 0.7;
}
.p-movie .tab__el .arrow {
  width: 1.8rem;
  height: 1.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transform: rotate(90deg);
  background: #004EA2;
  border-radius: 9999px;
}
.p-movie .tab__el .arrow img, .p-movie .tab__el .arrow svg {
  width: 0.6rem;
}
.p-movie .tab__el .arrow img path, .p-movie .tab__el .arrow img line, .p-movie .tab__el .arrow svg path, .p-movie .tab__el .arrow svg line {
  stroke: #fff;
}
.p-movie .tab__el.is-active {
  background: #004EA2;
  color: #fff;
  pointer-events: none;
}
.p-movie .tab__el.is-active .arrow {
  background: #fff;
}
.p-movie .tab__el.is-active .arrow path, .p-movie .tab__el.is-active .arrow line {
  stroke: #004EA2;
}
.p-movie .article {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 5rem;
  gap: 2.5rem 3.6rem;
}
@media screen and (max-width: 767px), print {
  .p-movie .article {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem 2rem;
    margin-top: 2rem;
  }
}
.p-movie .article__el .img {
  position: relative;
}
.p-movie .article__el .img img {
  aspect-ratio: 260/195;
  -o-object-fit: contain;
     object-fit: contain;
}
.p-movie .article__el .img::after {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.2);
  opacity: 0;
  transition: 0.3s;
}
.p-movie .article__el .ttl {
  font-size: 1.4rem;
  margin-top: 1rem;
}
.p-movie .article__el .tag {
  color: #808CA5;
  font-size: 1.2rem;
}
.p-movie .article__el:hover .img::after {
  opacity: 1;
}
.p-movie .not-article {
  margin-top: 3rem;
  grid-template-columns: 1fr;
}

.mt-0 {
  margin-top: 0rem !important;
}

.mt-1 {
  margin-top: 1rem !important;
}

.mt-2 {
  margin-top: 2rem !important;
}

.mt-3 {
  margin-top: 3rem !important;
}

.mt-4 {
  margin-top: 4rem !important;
}

.mt-5 {
  margin-top: 5rem !important;
}

.mt-6 {
  margin-top: 6rem !important;
}

.mt-7 {
  margin-top: 7rem !important;
}

.mt-8 {
  margin-top: 8rem !important;
}

.mt-9 {
  margin-top: 9rem !important;
}

.mt-10 {
  margin-top: 10rem !important;
}

.mt-11 {
  margin-top: 11rem !important;
}

.mt-12 {
  margin-top: 12rem !important;
}

.mt-13 {
  margin-top: 13rem !important;
}

.mt-14 {
  margin-top: 14rem !important;
}

.mt-15 {
  margin-top: 15rem !important;
}

.mt-16 {
  margin-top: 16rem !important;
}

.mt-17 {
  margin-top: 17rem !important;
}

.mt-18 {
  margin-top: 18rem !important;
}

.mt-19 {
  margin-top: 19rem !important;
}

.mt-20 {
  margin-top: 20rem !important;
}

.mb-0 {
  margin-bottom: 0rem !important;
}

.mb-1 {
  margin-bottom: 1rem !important;
}

.mb-2 {
  margin-bottom: 2rem !important;
}

.mb-3 {
  margin-bottom: 3rem !important;
}

.mb-4 {
  margin-bottom: 4rem !important;
}

.mb-5 {
  margin-bottom: 5rem !important;
}

.mb-6 {
  margin-bottom: 6rem !important;
}

.mb-7 {
  margin-bottom: 7rem !important;
}

.mb-8 {
  margin-bottom: 8rem !important;
}

.mb-9 {
  margin-bottom: 9rem !important;
}

.mb-10 {
  margin-bottom: 10rem !important;
}

.mb-11 {
  margin-bottom: 11rem !important;
}

.mb-12 {
  margin-bottom: 12rem !important;
}

.mb-13 {
  margin-bottom: 13rem !important;
}

.mb-14 {
  margin-bottom: 14rem !important;
}

.mb-15 {
  margin-bottom: 15rem !important;
}

.mb-16 {
  margin-bottom: 16rem !important;
}

.mb-17 {
  margin-bottom: 17rem !important;
}

.mb-18 {
  margin-bottom: 18rem !important;
}

.mb-19 {
  margin-bottom: 19rem !important;
}

.mb-20 {
  margin-bottom: 20rem !important;
}

.ml-0 {
  margin-left: 0rem !important;
}

.ml-1 {
  margin-left: 1rem !important;
}

.ml-2 {
  margin-left: 2rem !important;
}

.ml-3 {
  margin-left: 3rem !important;
}

.ml-4 {
  margin-left: 4rem !important;
}

.ml-5 {
  margin-left: 5rem !important;
}

.ml-6 {
  margin-left: 6rem !important;
}

.ml-7 {
  margin-left: 7rem !important;
}

.ml-8 {
  margin-left: 8rem !important;
}

.ml-9 {
  margin-left: 9rem !important;
}

.ml-10 {
  margin-left: 10rem !important;
}

.ml-11 {
  margin-left: 11rem !important;
}

.ml-12 {
  margin-left: 12rem !important;
}

.ml-13 {
  margin-left: 13rem !important;
}

.ml-14 {
  margin-left: 14rem !important;
}

.ml-15 {
  margin-left: 15rem !important;
}

.ml-16 {
  margin-left: 16rem !important;
}

.ml-17 {
  margin-left: 17rem !important;
}

.ml-18 {
  margin-left: 18rem !important;
}

.ml-19 {
  margin-left: 19rem !important;
}

.ml-20 {
  margin-left: 20rem !important;
}

.mr-0 {
  margin-right: 0rem !important;
}

.mr-1 {
  margin-right: 1rem !important;
}

.mr-2 {
  margin-right: 2rem !important;
}

.mr-3 {
  margin-right: 3rem !important;
}

.mr-4 {
  margin-right: 4rem !important;
}

.mr-5 {
  margin-right: 5rem !important;
}

.mr-6 {
  margin-right: 6rem !important;
}

.mr-7 {
  margin-right: 7rem !important;
}

.mr-8 {
  margin-right: 8rem !important;
}

.mr-9 {
  margin-right: 9rem !important;
}

.mr-10 {
  margin-right: 10rem !important;
}

.mr-11 {
  margin-right: 11rem !important;
}

.mr-12 {
  margin-right: 12rem !important;
}

.mr-13 {
  margin-right: 13rem !important;
}

.mr-14 {
  margin-right: 14rem !important;
}

.mr-15 {
  margin-right: 15rem !important;
}

.mr-16 {
  margin-right: 16rem !important;
}

.mr-17 {
  margin-right: 17rem !important;
}

.mr-18 {
  margin-right: 18rem !important;
}

.mr-19 {
  margin-right: 19rem !important;
}

.mr-20 {
  margin-right: 20rem !important;
}

.-mt-0 {
  margin-top: -0rem !important;
}

.-mt-1 {
  margin-top: -1rem !important;
}

.-mt-2 {
  margin-top: -2rem !important;
}

.-mt-3 {
  margin-top: -3rem !important;
}

.-mt-4 {
  margin-top: -4rem !important;
}

.-mt-5 {
  margin-top: -5rem !important;
}

.-mt-6 {
  margin-top: -6rem !important;
}

.-mt-7 {
  margin-top: -7rem !important;
}

.-mt-8 {
  margin-top: -8rem !important;
}

.-mt-9 {
  margin-top: -9rem !important;
}

.-mt-10 {
  margin-top: -10rem !important;
}

.-mt-11 {
  margin-top: -11rem !important;
}

.-mt-12 {
  margin-top: -12rem !important;
}

.-mt-13 {
  margin-top: -13rem !important;
}

.-mt-14 {
  margin-top: -14rem !important;
}

.-mt-15 {
  margin-top: -15rem !important;
}

.-mt-16 {
  margin-top: -16rem !important;
}

.-mt-17 {
  margin-top: -17rem !important;
}

.-mt-18 {
  margin-top: -18rem !important;
}

.-mt-19 {
  margin-top: -19rem !important;
}

.-mt-20 {
  margin-top: -20rem !important;
}

.-mb-0 {
  margin-bottom: -0rem !important;
}

.-mb-1 {
  margin-bottom: -1rem !important;
}

.-mb-2 {
  margin-bottom: -2rem !important;
}

.-mb-3 {
  margin-bottom: -3rem !important;
}

.-mb-4 {
  margin-bottom: -4rem !important;
}

.-mb-5 {
  margin-bottom: -5rem !important;
}

.-mb-6 {
  margin-bottom: -6rem !important;
}

.-mb-7 {
  margin-bottom: -7rem !important;
}

.-mb-8 {
  margin-bottom: -8rem !important;
}

.-mb-9 {
  margin-bottom: -9rem !important;
}

.-mb-10 {
  margin-bottom: -10rem !important;
}

.-mb-11 {
  margin-bottom: -11rem !important;
}

.-mb-12 {
  margin-bottom: -12rem !important;
}

.-mb-13 {
  margin-bottom: -13rem !important;
}

.-mb-14 {
  margin-bottom: -14rem !important;
}

.-mb-15 {
  margin-bottom: -15rem !important;
}

.-mb-16 {
  margin-bottom: -16rem !important;
}

.-mb-17 {
  margin-bottom: -17rem !important;
}

.-mb-18 {
  margin-bottom: -18rem !important;
}

.-mb-19 {
  margin-bottom: -19rem !important;
}

.-mb-20 {
  margin-bottom: -20rem !important;
}

.-ml-0 {
  margin-left: -0rem !important;
}

.-ml-1 {
  margin-left: -1rem !important;
}

.-ml-2 {
  margin-left: -2rem !important;
}

.-ml-3 {
  margin-left: -3rem !important;
}

.-ml-4 {
  margin-left: -4rem !important;
}

.-ml-5 {
  margin-left: -5rem !important;
}

.-ml-6 {
  margin-left: -6rem !important;
}

.-ml-7 {
  margin-left: -7rem !important;
}

.-ml-8 {
  margin-left: -8rem !important;
}

.-ml-9 {
  margin-left: -9rem !important;
}

.-ml-10 {
  margin-left: -10rem !important;
}

.-ml-11 {
  margin-left: -11rem !important;
}

.-ml-12 {
  margin-left: -12rem !important;
}

.-ml-13 {
  margin-left: -13rem !important;
}

.-ml-14 {
  margin-left: -14rem !important;
}

.-ml-15 {
  margin-left: -15rem !important;
}

.-ml-16 {
  margin-left: -16rem !important;
}

.-ml-17 {
  margin-left: -17rem !important;
}

.-ml-18 {
  margin-left: -18rem !important;
}

.-ml-19 {
  margin-left: -19rem !important;
}

.-ml-20 {
  margin-left: -20rem !important;
}

.-mr-0 {
  margin-right: -0rem !important;
}

.-mr-1 {
  margin-right: -1rem !important;
}

.-mr-2 {
  margin-right: -2rem !important;
}

.-mr-3 {
  margin-right: -3rem !important;
}

.-mr-4 {
  margin-right: -4rem !important;
}

.-mr-5 {
  margin-right: -5rem !important;
}

.-mr-6 {
  margin-right: -6rem !important;
}

.-mr-7 {
  margin-right: -7rem !important;
}

.-mr-8 {
  margin-right: -8rem !important;
}

.-mr-9 {
  margin-right: -9rem !important;
}

.-mr-10 {
  margin-right: -10rem !important;
}

.-mr-11 {
  margin-right: -11rem !important;
}

.-mr-12 {
  margin-right: -12rem !important;
}

.-mr-13 {
  margin-right: -13rem !important;
}

.-mr-14 {
  margin-right: -14rem !important;
}

.-mr-15 {
  margin-right: -15rem !important;
}

.-mr-16 {
  margin-right: -16rem !important;
}

.-mr-17 {
  margin-right: -17rem !important;
}

.-mr-18 {
  margin-right: -18rem !important;
}

.-mr-19 {
  margin-right: -19rem !important;
}

.-mr-20 {
  margin-right: -20rem !important;
}

.pt-0 {
  padding-top: 0rem !important;
}

.pt-1 {
  padding-top: 1rem !important;
}

.pt-2 {
  padding-top: 2rem !important;
}

.pt-3 {
  padding-top: 3rem !important;
}

.pt-4 {
  padding-top: 4rem !important;
}

.pt-5 {
  padding-top: 5rem !important;
}

.pt-6 {
  padding-top: 6rem !important;
}

.pt-7 {
  padding-top: 7rem !important;
}

.pt-8 {
  padding-top: 8rem !important;
}

.pt-9 {
  padding-top: 9rem !important;
}

.pt-10 {
  padding-top: 10rem !important;
}

.pt-11 {
  padding-top: 11rem !important;
}

.pt-12 {
  padding-top: 12rem !important;
}

.pt-13 {
  padding-top: 13rem !important;
}

.pt-14 {
  padding-top: 14rem !important;
}

.pt-15 {
  padding-top: 15rem !important;
}

.pt-16 {
  padding-top: 16rem !important;
}

.pt-17 {
  padding-top: 17rem !important;
}

.pt-18 {
  padding-top: 18rem !important;
}

.pt-19 {
  padding-top: 19rem !important;
}

.pt-20 {
  padding-top: 20rem !important;
}

.pb-0 {
  padding-bottom: 0rem !important;
}

.pb-1 {
  padding-bottom: 1rem !important;
}

.pb-2 {
  padding-bottom: 2rem !important;
}

.pb-3 {
  padding-bottom: 3rem !important;
}

.pb-4 {
  padding-bottom: 4rem !important;
}

.pb-5 {
  padding-bottom: 5rem !important;
}

.pb-6 {
  padding-bottom: 6rem !important;
}

.pb-7 {
  padding-bottom: 7rem !important;
}

.pb-8 {
  padding-bottom: 8rem !important;
}

.pb-9 {
  padding-bottom: 9rem !important;
}

.pb-10 {
  padding-bottom: 10rem !important;
}

.pb-11 {
  padding-bottom: 11rem !important;
}

.pb-12 {
  padding-bottom: 12rem !important;
}

.pb-13 {
  padding-bottom: 13rem !important;
}

.pb-14 {
  padding-bottom: 14rem !important;
}

.pb-15 {
  padding-bottom: 15rem !important;
}

.pb-16 {
  padding-bottom: 16rem !important;
}

.pb-17 {
  padding-bottom: 17rem !important;
}

.pb-18 {
  padding-bottom: 18rem !important;
}

.pb-19 {
  padding-bottom: 19rem !important;
}

.pb-20 {
  padding-bottom: 20rem !important;
}

.pl-0 {
  padding-left: 0rem !important;
}

.pl-1 {
  padding-left: 1rem !important;
}

.pl-2 {
  padding-left: 2rem !important;
}

.pl-3 {
  padding-left: 3rem !important;
}

.pl-4 {
  padding-left: 4rem !important;
}

.pl-5 {
  padding-left: 5rem !important;
}

.pl-6 {
  padding-left: 6rem !important;
}

.pl-7 {
  padding-left: 7rem !important;
}

.pl-8 {
  padding-left: 8rem !important;
}

.pl-9 {
  padding-left: 9rem !important;
}

.pl-10 {
  padding-left: 10rem !important;
}

.pl-11 {
  padding-left: 11rem !important;
}

.pl-12 {
  padding-left: 12rem !important;
}

.pl-13 {
  padding-left: 13rem !important;
}

.pl-14 {
  padding-left: 14rem !important;
}

.pl-15 {
  padding-left: 15rem !important;
}

.pl-16 {
  padding-left: 16rem !important;
}

.pl-17 {
  padding-left: 17rem !important;
}

.pl-18 {
  padding-left: 18rem !important;
}

.pl-19 {
  padding-left: 19rem !important;
}

.pl-20 {
  padding-left: 20rem !important;
}

.pr-0 {
  padding-right: 0rem !important;
}

.pr-1 {
  padding-right: 1rem !important;
}

.pr-2 {
  padding-right: 2rem !important;
}

.pr-3 {
  padding-right: 3rem !important;
}

.pr-4 {
  padding-right: 4rem !important;
}

.pr-5 {
  padding-right: 5rem !important;
}

.pr-6 {
  padding-right: 6rem !important;
}

.pr-7 {
  padding-right: 7rem !important;
}

.pr-8 {
  padding-right: 8rem !important;
}

.pr-9 {
  padding-right: 9rem !important;
}

.pr-10 {
  padding-right: 10rem !important;
}

.pr-11 {
  padding-right: 11rem !important;
}

.pr-12 {
  padding-right: 12rem !important;
}

.pr-13 {
  padding-right: 13rem !important;
}

.pr-14 {
  padding-right: 14rem !important;
}

.pr-15 {
  padding-right: 15rem !important;
}

.pr-16 {
  padding-right: 16rem !important;
}

.pr-17 {
  padding-right: 17rem !important;
}

.pr-18 {
  padding-right: 18rem !important;
}

.pr-19 {
  padding-right: 19rem !important;
}

.pr-20 {
  padding-right: 20rem !important;
}

@media screen and (max-width: 767px), print {
  .mt-sp-0 {
    margin-top: 0rem !important;
  }
  .mt-sp-1 {
    margin-top: 1rem !important;
  }
  .mt-sp-2 {
    margin-top: 2rem !important;
  }
  .mt-sp-3 {
    margin-top: 3rem !important;
  }
  .mt-sp-4 {
    margin-top: 4rem !important;
  }
  .mt-sp-5 {
    margin-top: 5rem !important;
  }
  .mt-sp-6 {
    margin-top: 6rem !important;
  }
  .mt-sp-7 {
    margin-top: 7rem !important;
  }
  .mt-sp-8 {
    margin-top: 8rem !important;
  }
  .mt-sp-9 {
    margin-top: 9rem !important;
  }
  .mt-sp-10 {
    margin-top: 10rem !important;
  }
  .mt-sp-11 {
    margin-top: 11rem !important;
  }
  .mt-sp-12 {
    margin-top: 12rem !important;
  }
  .mt-sp-13 {
    margin-top: 13rem !important;
  }
  .mt-sp-14 {
    margin-top: 14rem !important;
  }
  .mt-sp-15 {
    margin-top: 15rem !important;
  }
  .mt-sp-16 {
    margin-top: 16rem !important;
  }
  .mt-sp-17 {
    margin-top: 17rem !important;
  }
  .mt-sp-18 {
    margin-top: 18rem !important;
  }
  .mt-sp-19 {
    margin-top: 19rem !important;
  }
  .mt-sp-20 {
    margin-top: 20rem !important;
  }
  .mb-sp-0 {
    margin-bottom: 0rem !important;
  }
  .mb-sp-1 {
    margin-bottom: 1rem !important;
  }
  .mb-sp-2 {
    margin-bottom: 2rem !important;
  }
  .mb-sp-3 {
    margin-bottom: 3rem !important;
  }
  .mb-sp-4 {
    margin-bottom: 4rem !important;
  }
  .mb-sp-5 {
    margin-bottom: 5rem !important;
  }
  .mb-sp-6 {
    margin-bottom: 6rem !important;
  }
  .mb-sp-7 {
    margin-bottom: 7rem !important;
  }
  .mb-sp-8 {
    margin-bottom: 8rem !important;
  }
  .mb-sp-9 {
    margin-bottom: 9rem !important;
  }
  .mb-sp-10 {
    margin-bottom: 10rem !important;
  }
  .mb-sp-11 {
    margin-bottom: 11rem !important;
  }
  .mb-sp-12 {
    margin-bottom: 12rem !important;
  }
  .mb-sp-13 {
    margin-bottom: 13rem !important;
  }
  .mb-sp-14 {
    margin-bottom: 14rem !important;
  }
  .mb-sp-15 {
    margin-bottom: 15rem !important;
  }
  .mb-sp-16 {
    margin-bottom: 16rem !important;
  }
  .mb-sp-17 {
    margin-bottom: 17rem !important;
  }
  .mb-sp-18 {
    margin-bottom: 18rem !important;
  }
  .mb-sp-19 {
    margin-bottom: 19rem !important;
  }
  .mb-sp-20 {
    margin-bottom: 20rem !important;
  }
  .ml-sp-0 {
    margin-left: 0rem !important;
  }
  .ml-sp-1 {
    margin-left: 1rem !important;
  }
  .ml-sp-2 {
    margin-left: 2rem !important;
  }
  .ml-sp-3 {
    margin-left: 3rem !important;
  }
  .ml-sp-4 {
    margin-left: 4rem !important;
  }
  .ml-sp-5 {
    margin-left: 5rem !important;
  }
  .ml-sp-6 {
    margin-left: 6rem !important;
  }
  .ml-sp-7 {
    margin-left: 7rem !important;
  }
  .ml-sp-8 {
    margin-left: 8rem !important;
  }
  .ml-sp-9 {
    margin-left: 9rem !important;
  }
  .ml-sp-10 {
    margin-left: 10rem !important;
  }
  .ml-sp-11 {
    margin-left: 11rem !important;
  }
  .ml-sp-12 {
    margin-left: 12rem !important;
  }
  .ml-sp-13 {
    margin-left: 13rem !important;
  }
  .ml-sp-14 {
    margin-left: 14rem !important;
  }
  .ml-sp-15 {
    margin-left: 15rem !important;
  }
  .ml-sp-16 {
    margin-left: 16rem !important;
  }
  .ml-sp-17 {
    margin-left: 17rem !important;
  }
  .ml-sp-18 {
    margin-left: 18rem !important;
  }
  .ml-sp-19 {
    margin-left: 19rem !important;
  }
  .ml-sp-20 {
    margin-left: 20rem !important;
  }
  .mr-sp-0 {
    margin-right: 0rem !important;
  }
  .mr-sp-1 {
    margin-right: 1rem !important;
  }
  .mr-sp-2 {
    margin-right: 2rem !important;
  }
  .mr-sp-3 {
    margin-right: 3rem !important;
  }
  .mr-sp-4 {
    margin-right: 4rem !important;
  }
  .mr-sp-5 {
    margin-right: 5rem !important;
  }
  .mr-sp-6 {
    margin-right: 6rem !important;
  }
  .mr-sp-7 {
    margin-right: 7rem !important;
  }
  .mr-sp-8 {
    margin-right: 8rem !important;
  }
  .mr-sp-9 {
    margin-right: 9rem !important;
  }
  .mr-sp-10 {
    margin-right: 10rem !important;
  }
  .mr-sp-11 {
    margin-right: 11rem !important;
  }
  .mr-sp-12 {
    margin-right: 12rem !important;
  }
  .mr-sp-13 {
    margin-right: 13rem !important;
  }
  .mr-sp-14 {
    margin-right: 14rem !important;
  }
  .mr-sp-15 {
    margin-right: 15rem !important;
  }
  .mr-sp-16 {
    margin-right: 16rem !important;
  }
  .mr-sp-17 {
    margin-right: 17rem !important;
  }
  .mr-sp-18 {
    margin-right: 18rem !important;
  }
  .mr-sp-19 {
    margin-right: 19rem !important;
  }
  .mr-sp-20 {
    margin-right: 20rem !important;
  }
  .-mt-sp-0 {
    margin-top: -0rem !important;
  }
  .-mt-sp-1 {
    margin-top: -1rem !important;
  }
  .-mt-sp-2 {
    margin-top: -2rem !important;
  }
  .-mt-sp-3 {
    margin-top: -3rem !important;
  }
  .-mt-sp-4 {
    margin-top: -4rem !important;
  }
  .-mt-sp-5 {
    margin-top: -5rem !important;
  }
  .-mt-sp-6 {
    margin-top: -6rem !important;
  }
  .-mt-sp-7 {
    margin-top: -7rem !important;
  }
  .-mt-sp-8 {
    margin-top: -8rem !important;
  }
  .-mt-sp-9 {
    margin-top: -9rem !important;
  }
  .-mt-sp-10 {
    margin-top: -10rem !important;
  }
  .-mt-sp-11 {
    margin-top: -11rem !important;
  }
  .-mt-sp-12 {
    margin-top: -12rem !important;
  }
  .-mt-sp-13 {
    margin-top: -13rem !important;
  }
  .-mt-sp-14 {
    margin-top: -14rem !important;
  }
  .-mt-sp-15 {
    margin-top: -15rem !important;
  }
  .-mt-sp-16 {
    margin-top: -16rem !important;
  }
  .-mt-sp-17 {
    margin-top: -17rem !important;
  }
  .-mt-sp-18 {
    margin-top: -18rem !important;
  }
  .-mt-sp-19 {
    margin-top: -19rem !important;
  }
  .-mt-sp-20 {
    margin-top: -20rem !important;
  }
  .-mb-sp-0 {
    margin-bottom: -0rem !important;
  }
  .-mb-sp-1 {
    margin-bottom: -1rem !important;
  }
  .-mb-sp-2 {
    margin-bottom: -2rem !important;
  }
  .-mb-sp-3 {
    margin-bottom: -3rem !important;
  }
  .-mb-sp-4 {
    margin-bottom: -4rem !important;
  }
  .-mb-sp-5 {
    margin-bottom: -5rem !important;
  }
  .-mb-sp-6 {
    margin-bottom: -6rem !important;
  }
  .-mb-sp-7 {
    margin-bottom: -7rem !important;
  }
  .-mb-sp-8 {
    margin-bottom: -8rem !important;
  }
  .-mb-sp-9 {
    margin-bottom: -9rem !important;
  }
  .-mb-sp-10 {
    margin-bottom: -10rem !important;
  }
  .-mb-sp-11 {
    margin-bottom: -11rem !important;
  }
  .-mb-sp-12 {
    margin-bottom: -12rem !important;
  }
  .-mb-sp-13 {
    margin-bottom: -13rem !important;
  }
  .-mb-sp-14 {
    margin-bottom: -14rem !important;
  }
  .-mb-sp-15 {
    margin-bottom: -15rem !important;
  }
  .-mb-sp-16 {
    margin-bottom: -16rem !important;
  }
  .-mb-sp-17 {
    margin-bottom: -17rem !important;
  }
  .-mb-sp-18 {
    margin-bottom: -18rem !important;
  }
  .-mb-sp-19 {
    margin-bottom: -19rem !important;
  }
  .-mb-sp-20 {
    margin-bottom: -20rem !important;
  }
  .-ml-sp-0 {
    margin-left: -0rem !important;
  }
  .-ml-sp-1 {
    margin-left: -1rem !important;
  }
  .-ml-sp-2 {
    margin-left: -2rem !important;
  }
  .-ml-sp-3 {
    margin-left: -3rem !important;
  }
  .-ml-sp-4 {
    margin-left: -4rem !important;
  }
  .-ml-sp-5 {
    margin-left: -5rem !important;
  }
  .-ml-sp-6 {
    margin-left: -6rem !important;
  }
  .-ml-sp-7 {
    margin-left: -7rem !important;
  }
  .-ml-sp-8 {
    margin-left: -8rem !important;
  }
  .-ml-sp-9 {
    margin-left: -9rem !important;
  }
  .-ml-sp-10 {
    margin-left: -10rem !important;
  }
  .-ml-sp-11 {
    margin-left: -11rem !important;
  }
  .-ml-sp-12 {
    margin-left: -12rem !important;
  }
  .-ml-sp-13 {
    margin-left: -13rem !important;
  }
  .-ml-sp-14 {
    margin-left: -14rem !important;
  }
  .-ml-sp-15 {
    margin-left: -15rem !important;
  }
  .-ml-sp-16 {
    margin-left: -16rem !important;
  }
  .-ml-sp-17 {
    margin-left: -17rem !important;
  }
  .-ml-sp-18 {
    margin-left: -18rem !important;
  }
  .-ml-sp-19 {
    margin-left: -19rem !important;
  }
  .-ml-sp-20 {
    margin-left: -20rem !important;
  }
  .-mr-sp-0 {
    margin-right: -0rem !important;
  }
  .-mr-sp-1 {
    margin-right: -1rem !important;
  }
  .-mr-sp-2 {
    margin-right: -2rem !important;
  }
  .-mr-sp-3 {
    margin-right: -3rem !important;
  }
  .-mr-sp-4 {
    margin-right: -4rem !important;
  }
  .-mr-sp-5 {
    margin-right: -5rem !important;
  }
  .-mr-sp-6 {
    margin-right: -6rem !important;
  }
  .-mr-sp-7 {
    margin-right: -7rem !important;
  }
  .-mr-sp-8 {
    margin-right: -8rem !important;
  }
  .-mr-sp-9 {
    margin-right: -9rem !important;
  }
  .-mr-sp-10 {
    margin-right: -10rem !important;
  }
  .-mr-sp-11 {
    margin-right: -11rem !important;
  }
  .-mr-sp-12 {
    margin-right: -12rem !important;
  }
  .-mr-sp-13 {
    margin-right: -13rem !important;
  }
  .-mr-sp-14 {
    margin-right: -14rem !important;
  }
  .-mr-sp-15 {
    margin-right: -15rem !important;
  }
  .-mr-sp-16 {
    margin-right: -16rem !important;
  }
  .-mr-sp-17 {
    margin-right: -17rem !important;
  }
  .-mr-sp-18 {
    margin-right: -18rem !important;
  }
  .-mr-sp-19 {
    margin-right: -19rem !important;
  }
  .-mr-sp-20 {
    margin-right: -20rem !important;
  }
  .pt-sp-0 {
    padding-top: 0rem !important;
  }
  .pt-sp-1 {
    padding-top: 1rem !important;
  }
  .pt-sp-2 {
    padding-top: 2rem !important;
  }
  .pt-sp-3 {
    padding-top: 3rem !important;
  }
  .pt-sp-4 {
    padding-top: 4rem !important;
  }
  .pt-sp-5 {
    padding-top: 5rem !important;
  }
  .pt-sp-6 {
    padding-top: 6rem !important;
  }
  .pt-sp-7 {
    padding-top: 7rem !important;
  }
  .pt-sp-8 {
    padding-top: 8rem !important;
  }
  .pt-sp-9 {
    padding-top: 9rem !important;
  }
  .pt-sp-10 {
    padding-top: 10rem !important;
  }
  .pt-sp-11 {
    padding-top: 11rem !important;
  }
  .pt-sp-12 {
    padding-top: 12rem !important;
  }
  .pt-sp-13 {
    padding-top: 13rem !important;
  }
  .pt-sp-14 {
    padding-top: 14rem !important;
  }
  .pt-sp-15 {
    padding-top: 15rem !important;
  }
  .pt-sp-16 {
    padding-top: 16rem !important;
  }
  .pt-sp-17 {
    padding-top: 17rem !important;
  }
  .pt-sp-18 {
    padding-top: 18rem !important;
  }
  .pt-sp-19 {
    padding-top: 19rem !important;
  }
  .pt-sp-20 {
    padding-top: 20rem !important;
  }
  .pb-sp-0 {
    padding-bottom: 0rem !important;
  }
  .pb-sp-1 {
    padding-bottom: 1rem !important;
  }
  .pb-sp-2 {
    padding-bottom: 2rem !important;
  }
  .pb-sp-3 {
    padding-bottom: 3rem !important;
  }
  .pb-sp-4 {
    padding-bottom: 4rem !important;
  }
  .pb-sp-5 {
    padding-bottom: 5rem !important;
  }
  .pb-sp-6 {
    padding-bottom: 6rem !important;
  }
  .pb-sp-7 {
    padding-bottom: 7rem !important;
  }
  .pb-sp-8 {
    padding-bottom: 8rem !important;
  }
  .pb-sp-9 {
    padding-bottom: 9rem !important;
  }
  .pb-sp-10 {
    padding-bottom: 10rem !important;
  }
  .pb-sp-11 {
    padding-bottom: 11rem !important;
  }
  .pb-sp-12 {
    padding-bottom: 12rem !important;
  }
  .pb-sp-13 {
    padding-bottom: 13rem !important;
  }
  .pb-sp-14 {
    padding-bottom: 14rem !important;
  }
  .pb-sp-15 {
    padding-bottom: 15rem !important;
  }
  .pb-sp-16 {
    padding-bottom: 16rem !important;
  }
  .pb-sp-17 {
    padding-bottom: 17rem !important;
  }
  .pb-sp-18 {
    padding-bottom: 18rem !important;
  }
  .pb-sp-19 {
    padding-bottom: 19rem !important;
  }
  .pb-sp-20 {
    padding-bottom: 20rem !important;
  }
  .pl-sp-0 {
    padding-left: 0rem !important;
  }
  .pl-sp-1 {
    padding-left: 1rem !important;
  }
  .pl-sp-2 {
    padding-left: 2rem !important;
  }
  .pl-sp-3 {
    padding-left: 3rem !important;
  }
  .pl-sp-4 {
    padding-left: 4rem !important;
  }
  .pl-sp-5 {
    padding-left: 5rem !important;
  }
  .pl-sp-6 {
    padding-left: 6rem !important;
  }
  .pl-sp-7 {
    padding-left: 7rem !important;
  }
  .pl-sp-8 {
    padding-left: 8rem !important;
  }
  .pl-sp-9 {
    padding-left: 9rem !important;
  }
  .pl-sp-10 {
    padding-left: 10rem !important;
  }
  .pl-sp-11 {
    padding-left: 11rem !important;
  }
  .pl-sp-12 {
    padding-left: 12rem !important;
  }
  .pl-sp-13 {
    padding-left: 13rem !important;
  }
  .pl-sp-14 {
    padding-left: 14rem !important;
  }
  .pl-sp-15 {
    padding-left: 15rem !important;
  }
  .pl-sp-16 {
    padding-left: 16rem !important;
  }
  .pl-sp-17 {
    padding-left: 17rem !important;
  }
  .pl-sp-18 {
    padding-left: 18rem !important;
  }
  .pl-sp-19 {
    padding-left: 19rem !important;
  }
  .pl-sp-20 {
    padding-left: 20rem !important;
  }
  .pr-sp-0 {
    padding-right: 0rem !important;
  }
  .pr-sp-1 {
    padding-right: 1rem !important;
  }
  .pr-sp-2 {
    padding-right: 2rem !important;
  }
  .pr-sp-3 {
    padding-right: 3rem !important;
  }
  .pr-sp-4 {
    padding-right: 4rem !important;
  }
  .pr-sp-5 {
    padding-right: 5rem !important;
  }
  .pr-sp-6 {
    padding-right: 6rem !important;
  }
  .pr-sp-7 {
    padding-right: 7rem !important;
  }
  .pr-sp-8 {
    padding-right: 8rem !important;
  }
  .pr-sp-9 {
    padding-right: 9rem !important;
  }
  .pr-sp-10 {
    padding-right: 10rem !important;
  }
  .pr-sp-11 {
    padding-right: 11rem !important;
  }
  .pr-sp-12 {
    padding-right: 12rem !important;
  }
  .pr-sp-13 {
    padding-right: 13rem !important;
  }
  .pr-sp-14 {
    padding-right: 14rem !important;
  }
  .pr-sp-15 {
    padding-right: 15rem !important;
  }
  .pr-sp-16 {
    padding-right: 16rem !important;
  }
  .pr-sp-17 {
    padding-right: 17rem !important;
  }
  .pr-sp-18 {
    padding-right: 18rem !important;
  }
  .pr-sp-19 {
    padding-right: 19rem !important;
  }
  .pr-sp-20 {
    padding-right: 20rem !important;
  }
}
html {
  scroll-behavior: smooth;
}
@media screen and (min-width: 1600px) {
  html {
    font-size: 13.3333333333px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1599px) {
  html {
    font-size: 0.8333333333vw;
  }
}
@media screen and (max-width: 767px) {
  html {
    font-size: 2.5vw;
  }
}
html.is-hidden {
  position: fixed;
  right: 0;
  left: 0;
  overflow: hidden;
}
html * {
  outline: none;
}

[x-cloak] {
  display: none !important;
}

body {
  font-size: 1.6rem;
  font-feature-settings: "palt";
  margin: 0;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  color: #001A4C;
  letter-spacing: 0.05em;
  line-height: 1.7;
}

.l-container {
  overflow: hidden;
}

a {
  color: #001A4C;
  text-decoration: none;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

h1,
h2,
h3,
h4,
h5,
h6,
div,
dl,
dt,
dd,
p {
  padding: 0;
  margin: 0;
}

ul,
ol,
li {
  padding: 0;
  margin: 0;
}

li {
  list-style: none;
}

img {
  vertical-align: bottom;
}

figure {
  padding: 0;
  margin: 0;
}

input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button {
  -webkit-appearance: none;
          appearance: none;
  margin: 0;
}

input[type=number] {
  -webkit-appearance: textfield;
     -moz-appearance: textfield;
          appearance: textfield;
}

.l-main {
  line-height: 1.2;
}

svg,
img {
  max-width: 100%;
}

svg {
  overflow: visible;
}

@media (max-width: 767px) {
  html,
  body {
    width: 100%;
    height: 100%;
  }
  h1,
  h2,
  h3,
  h4,
  h5,
  h6,
  div,
  dl,
  dt,
  dd,
  p {
    padding: 0;
    margin: 0;
  }
  img {
    width: auto;
    max-width: 100%;
    height: auto;
    max-height: 100%;
  }
}
@media (max-width: 767px) {
  .pc {
    display: none !important;
  }
}
@media (min-width: 768px) {
  [href*="tel:"] {
    pointer-events: none;
  }
  .sp {
    display: none !important;
  }
}
.js-inview[data-inview=fade-top] {
  opacity: 0;
  transition: opacity 1s, transform 1s;
  transform: translateY(30px);
}
.js-inview[data-inview=fade-top].is-inview {
  opacity: 1;
  transform: translateY(0);
}/*# sourceMappingURL=style.css.map */