@charset "UTF-8";
/*
 * Sass    : Dart sass
 * 命名規則 : BEM ベース
 *   [接頭辞]
 *   .-****  : Variant
 *   ._****  : Helpers
 *   .c-**** : 汎用コンポーネント
 *   .l-**** : レイアウト
 *   .f-**** : フォーム系コンポーネント
 */
@import url("https://use.fontawesome.com/releases/v5.15.1/css/all.css");
:root {
  --heading-sub-color: #1A416C;
}

/**************************************************/
/* helpers */
/**************************************************/
._disp-ib {
  display: inline-block !important;
}

@media (max-width: 1249px) {
  ._view-cw-high {
    display: none !important;
  }
}
@media (min-width: 1250px) {
  ._view-cw-low {
    display: none !important;
  }
}
@media (max-width: 1279px) {
  ._view-xl-high {
    display: none !important;
  }
}
@media (min-width: 1280px) {
  ._view-xl-low {
    display: none !important;
  }
}
@media (max-width: 1023px) {
  ._view-lg-high {
    display: none !important;
  }
}
@media (min-width: 1024px) {
  ._view-lg-low {
    display: none !important;
  }
}
@media (max-width: 767px) {
  ._view-md-high {
    display: none !important;
  }
}
@media (min-width: 768px) {
  ._view-md-low {
    display: none !important;
  }
}
@media (max-width: 479px) {
  ._view-sm-high {
    display: none !important;
  }
}
@media (min-width: 480px) {
  ._view-sm-low {
    display: none !important;
  }
}
._clearfix {
  zoom: 1;
}
._clearfix:after {
  content: "";
  display: block;
  clear: both;
  overflow: auto;
}

._center {
  text-align: center !important;
}

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

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

._float-l {
  float: left !important;
}

._float-r {
  float: right !important;
}

._clear {
  clear: both !important;
}

._hidden {
  display: none !important;
}

._disp-ib {
  display: inline-block !important;
}

._margin0 {
  margin: 0 !important;
}

._padding0 {
  padding: 0 !important;
}

._border0 {
  border: none !important;
}

._fixed {
  position: fixed !important;
}

._absolute {
  position: absolute !important;
}

._static {
  position: static !important;
}

._xsmall {
  font-size: 75% !important;
}

._small {
  font-size: 88% !important;
}

._large {
  font-size: 113% !important;
}

._xlarge {
  font-size: 133% !important;
}

._nowrap {
  white-space: nowrap !important;
}

._nobg {
  background: none !important;
}

._full {
  width: 100% !important;
}

/**************************************************/
/* base */
/**************************************************/
:root {
  font-size: min(16px, 1.1713030747vw);
}
@media (max-width: 767px) {
  :root {
    font-size: 4.2666666667vw;
  }
}

html {
  -webkit-font-smoothing: antialiased;
}

body {
  min-width: 320px;
  padding: 0;
  color: #333333;
  background: #F6F2E6 url(../img/bg_pattern.png) repeat;
  font-family: "Zen Kaku Gothic New", "游ゴシック体", "YuGothic", "游ゴシック", "Yu Gothic", sans-serif;
  font-size: 1rem;
  line-height: 1.5;
}
body.-fixed {
  position: fixed;
  width: 100%;
  height: 100%;
}

input,
textarea {
  font-size: 16px;
}

input,
textarea,
select,
button {
  font-family: "Zen Kaku Gothic New", "游ゴシック体", "YuGothic", "游ゴシック", "Yu Gothic", sans-serif;
}

button,
input[type=button],
input[type=submit] {
  transition: opacity 0.15s ease-out;
}
button:hover,
input[type=button]:hover,
input[type=submit]:hover {
  opacity: 0.7;
}

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

a {
  color: #1A416C;
  text-decoration: underline;
  transition: opacity 0.15s ease-out;
}
a:hover {
  opacity: 0.7;
}
a:hover {
  text-decoration: none;
}

em {
  font-style: normal;
}

a.-telink,
a.js-telink {
  cursor: default;
  opacity: 1 !important;
}

body._ios a:hover {
  opacity: 1;
}

/**************************************************/
/* pages */
/**************************************************/
/**************************************************/
/* Header */
/**************************************************/
.l-header {
  box-sizing: border-box;
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  height: 8.125rem;
  border-top: 0.5rem solid #1A416C;
  z-index: 100;
}
.l-header__inner {
  max-width: 75rem;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-sizing: border-box;
  position: relative;
  height: 100%;
  margin: 0 auto;
}
.l-header__logo {
  width: 20.5rem;
  margin: 0;
  color: #000;
  line-height: 0;
}
.l-header__logo a {
  display: inline-block;
  color: inherit;
  text-decoration: none;
}
.l-header__logo img {
  display: block;
  width: 100%;
}
@media (max-width: 767px) {
  .l-header {
    height: 3.875rem;
    padding: 0.75rem 1rem;
    border-top-width: 0.375rem;
  }
  .l-header__logo {
    width: 14rem;
  }
}

.l-headerUtility {
  display: flex;
  flex-flow: row nowrap;
  justify-content: flex-end;
  list-style: none;
  padding-left: 0;
  align-items: center;
  margin: 0;
}
.l-headerUtility__tel, .l-headerUtility__line, .l-headerUtility__mail {
  position: relative;
}
.l-headerUtility__tel {
  align-self: flex-end;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  color: #1A416C;
  line-height: 1.5;
}
.l-headerUtility__tel-sub {
  display: block;
  font-size: 0.6875rem;
  font-weight: 700;
}
.l-headerUtility__tel-number {
  display: block;
  position: relative;
  padding-left: 1.5rem;
  font-family: "Montserrat", sans-serif;
  font-size: 1.375rem;
  font-weight: 600;
  line-height: 1;
}
.l-headerUtility__tel-number::before {
  display: block;
  position: absolute;
  left: 0;
  top: calc(50% - 0.5625rem);
  width: 1.125rem;
  height: 1.125rem;
  background: currentColor;
  content: "";
  -webkit-mask: url(../img/icon_tel.svg) no-repeat center/contain;
          mask: url(../img/icon_tel.svg) no-repeat center/contain;
}
.l-headerUtility__line, .l-headerUtility__mail {
  border: none;
  display: inline-block;
  box-sizing: border-box;
  position: relative;
  border-radius: 0;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  display: block;
  width: 8.75rem;
  padding: 0.5625rem 0.5rem 0.5rem;
  border: 0.125rem solid transparent;
  border-radius: 6.25rem;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.5;
  transition: all 0.1s ease;
}
.l-headerUtility__line:hover, .l-headerUtility__mail:hover {
  opacity: 1;
}
.l-headerUtility__line {
  margin-left: 1.25rem;
  background: #18BC45;
  color: #fff;
}
.l-headerUtility__line:hover {
  border-color: #18BC45;
  background: #fff;
  color: #18BC45;
}
.l-headerUtility__mail {
  margin-left: 0.5rem;
  background: #E86B78;
  color: #fff;
}
.l-headerUtility__mail:hover {
  border-color: #E86B78;
  background: #fff;
  color: #E86B78;
}
.l-headerUtility__line-label, .l-headerUtility__mail-label {
  display: inline-block;
  position: relative;
  padding-left: 1.625rem;
}
.l-headerUtility__line-label::before, .l-headerUtility__mail-label::before {
  display: block;
  position: absolute;
  left: 0;
  top: calc(50% - 0.5625rem);
  width: 1.125rem;
  height: 1.125rem;
  background: currentColor;
  content: "";
  -webkit-mask: no-repeat center/contain;
          mask: no-repeat center/contain;
}
.l-headerUtility__line-label::before {
  -webkit-mask-image: url(../img/icon_contact.svg);
          mask-image: url(../img/icon_contact.svg);
}
.l-headerUtility__mail-label::before {
  -webkit-mask-image: url(../img/icon_mail.svg);
          mask-image: url(../img/icon_mail.svg);
}
@media (max-width: 767px) {
  .l-headerUtility {
    display: none;
  }
}

.l-gnav {
  display: flex;
  flex-flow: row nowrap;
  justify-content: flex-start;
  list-style: none;
  padding-left: 0;
  align-items: center;
  gap: 0.5rem 1.25rem;
  margin: 1rem 0 0;
}
.l-gnav > li {
  display: block;
  position: relative;
  line-height: 1.5;
  text-align: center;
}
.l-gnav__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  color: inherit;
  font-size: 0.9375rem;
  font-weight: 700;
  text-decoration: none;
}
.l-gnav__btn:hover, .l-gnav__btn.-current {
  color: #1A416C;
  opacity: 1;
}
@media (max-width: 767px) {
  .l-gnav {
    display: none;
  }
}

.l-spnav {
  display: none;
  position: fixed;
  top: 3.875rem;
  right: 0;
  width: 100%;
  height: calc(100% - 3.875rem);
  background: rgba(0, 0, 0, 0.5);
  z-index: 100;
}
.l-spnav__container {
  scrollbar-width: none;
  -ms-overflow-style: none;
  -webkit-overflow-scrolling: touch;
  max-height: 100%;
  overflow-y: auto;
}
.l-spnav__container::-webkit-scrollbar {
  display: none;
}
.l-spnav__list {
  margin: 0 auto;
  padding-left: 0;
  list-style: none;
  background: #000;
  color: #fff;
}
.l-spnav__list > li {
  display: block;
}
.l-spnav__list > li:not(:last-child) {
  border-bottom: 1px solid #cccccc;
}
.l-spnav__btn {
  display: block;
  padding: 1.25rem 0.9375rem;
  color: inherit;
}
@media (min-width: 768px) {
  .l-spnav {
    display: none !important;
  }
}

.l-menuBtn {
  display: none;
  position: absolute;
  top: 0;
  right: 0;
  width: 3.875rem;
  height: 3.875rem;
  margin: 0;
  cursor: pointer;
}
.l-menuBtn__bar {
  top: 50%;
  left: 50%;
  margin-top: -0.0625rem;
  margin-left: -0.75rem;
}
.l-menuBtn__bar, .l-menuBtn__bar::before, .l-menuBtn__bar::after {
  display: block;
  position: absolute;
  width: 1.5rem;
  height: 0.125rem;
  border-radius: 0.125rem;
  background: #1A416C;
  content: "";
  transition: all 0.2s ease-out;
}
.l-menuBtn__bar::before {
  top: -0.5rem;
}
.l-menuBtn__bar::after {
  top: 0.5rem;
}
.l-menuBtn.-open {
  background: #000;
}
.l-menuBtn.-open .l-menuBtn__bar {
  background-color: transparent;
}
.l-menuBtn.-open .l-menuBtn__bar::before {
  top: 0;
  background-color: #fff;
  transform: rotate(135deg);
}
.l-menuBtn.-open .l-menuBtn__bar::after {
  top: 0;
  background-color: #fff;
  transform: rotate(-135deg);
}
@media (max-width: 767px) {
  .l-menuBtn {
    display: block;
  }
}

/**************************************************/
/* Footer */
/**************************************************/
.l-pagetop {
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 5;
}
.l-pagetop__btn {
  display: block;
  width: 3.125rem;
  height: 3.125rem;
  background: url(../img/pagetop.svg) no-repeat center/contain;
}
@media (max-width: 767px) {
  .l-pagetop {
    bottom: -0.625rem;
  }
  .l-pagetop__btn {
    width: 2.75rem;
    height: 2.75rem;
  }
}

.l-footer {
  position: relative;
  padding: 5rem 0 2.5rem;
  background: #fff;
  z-index: 5;
}
.l-footer__inner {
  max-width: 75rem;
  margin-left: auto;
  margin-right: auto;
  position: relative;
}
.l-footer__content {
  display: flex;
  justify-content: space-between;
}
.l-footer__logo {
  width: 22.125rem;
  margin: 0;
}
.l-footer__address {
  margin: 1.25rem 0 0;
  line-height: 2;
}
.l-footer__right {
  width: 30rem;
}
.l-footer__right > *:first-child {
  margin-top: 0 !important;
}
.l-footer__copyright {
  margin: 3.75rem 0 0;
  font-size: 0.875rem;
  line-height: 1.5;
}
@media (max-width: 767px) {
  .l-footer {
    padding: 1.875rem 1rem;
  }
  .l-footer__content {
    display: none;
  }
  .l-footer__copyright {
    margin-top: 0;
  }
}

.l-fnav {
  display: flex;
  gap: 1.25rem;
}
.l-fnav a[href="#"] {
  opacity: 0.3 !important;
  pointer-events: none !important;
}
.l-fnav a {
  color: inherit;
  text-decoration: none;
}
.l-fnav__unit {
  display: block;
  box-sizing: border-box;
  width: calc((100% - 2.5rem) / 3);
}
.l-fnav__primary {
  margin: 1rem 0 0;
  font-weight: 700;
  line-height: 1.5;
}
.l-fnav__secondary {
  list-style: none;
  margin: 0.5rem 0 0;
  padding-left: 0;
  font-size: 0.875rem;
  line-height: 1.5;
}
.l-fnav__secondary > li {
  display: block;
}
.l-fnav__secondary > li + li {
  margin-top: 0.5rem;
}

.l-footerUtility {
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-start;
  list-style: none;
  padding-left: 0;
  gap: 0.5rem 1.75rem;
  margin: 2rem 0 0;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.5;
}
.l-footerUtility a[href="#"] {
  opacity: 0.3 !important;
  pointer-events: none !important;
}
.l-footerUtility a {
  color: inherit;
  text-decoration: none;
}
.l-footerUtility > li {
  display: block;
}

.l-footer-contact {
  position: relative;
  padding: 6.25rem 0 7.5rem;
  background: url(../img/bg_contact.png) repeat-x center 75%;
  background-size: auto max(100%, 50rem);
  color: #fff;
}
.l-footer-contact__inner {
  max-width: 75rem;
  margin-left: auto;
  margin-right: auto;
}
.l-footer-contact__head {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: center;
}
.l-footer-contact__ttl {
  --heading-sub-color: $white;
  margin: 0;
}
.l-footer-contact__ttl-sub {
  display: block;
  position: relative;
  margin-bottom: 0.5rem;
  padding-left: 1.5rem;
  color: var(--heading-sub-color);
  font-family: "Montserrat", sans-serif;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
}
.l-footer-contact__ttl-sub::before {
  display: block;
  position: absolute;
  top: calc(50% - 0.5rem);
  left: 0;
  width: 1rem;
  height: 1rem;
  background: currentColor;
  content: "";
  -webkit-mask: url(../img/icon_heading.svg) no-repeat center/contain;
          mask: url(../img/icon_heading.svg) no-repeat center/contain;
}
@media (max-width: 767px) {
  .l-footer-contact__ttl-sub {
    margin-bottom: 0.375rem;
    padding-left: 1.25rem;
    font-size: 0.8125rem;
  }
  .l-footer-contact__ttl-sub::before {
    top: calc(50% - 0.375rem);
    width: 0.75rem;
    height: 0.75rem;
  }
}
.l-footer-contact__ttl-main {
  display: block;
  font-size: 2.375rem;
  letter-spacing: 0.06em;
}
@media (max-width: 767px) {
  .l-footer-contact__ttl-main {
    font-size: 1.5rem;
  }
}
.l-footer-contact__lead {
  margin: 0;
  line-height: 2;
}
.l-footer-contact__merit {
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
  list-style: none;
  padding-left: 0;
  gap: 0.75rem;
  margin: 0;
}
.l-footer-contact__merit > li {
  display: block;
}
.l-footer-contact__merit > li img {
  display: block;
  width: 100%;
}
@media (max-width: 767px) {
  .l-footer-contact {
    padding: 3.75rem 1rem;
  }
  .l-footer-contact__head {
    display: block;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }
  .l-footer-contact__lead {
    margin-top: 1.25rem;
    font-size: 0.875rem;
    line-height: 1.75;
  }
  .l-footer-contact__merit {
    gap: 0.5625rem;
    margin-top: 1.5rem;
  }
}

.l-footer-contactBox {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  gap: 1.5rem;
  margin: 3.75rem 0 0;
  padding: 3.75rem;
  border-radius: 1.25rem;
  background: #fff;
  color: #333333;
}
.l-footer-contactBox__tel {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
}
.l-footer-contactBox__tel-number {
  display: block;
  position: relative;
  padding-left: 2.75rem;
  font-family: "Montserrat", sans-serif;
  color: inherit;
  font-size: 2.625rem;
  font-weight: 600;
  text-decoration: none;
  line-height: 1.25;
  letter-spacing: 0.04em;
}
.l-footer-contactBox__tel-number::before {
  display: block;
  position: absolute;
  left: 0;
  top: calc(50% - 1.125rem);
  width: 2.25rem;
  height: 2.25rem;
  background: #1A416C;
  content: "";
  -webkit-mask: url(../img/icon_tel.svg) no-repeat center/contain;
          mask: url(../img/icon_tel.svg) no-repeat center/contain;
}
.l-footer-contactBox__tel-sub {
  display: block;
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: 0.04em;
}
.l-footer-contactBox__line, .l-footer-contactBox__mail {
  width: 20rem;
}
.l-footer-contactBox__line-btn, .l-footer-contactBox__mail-btn {
  border: none;
  display: inline-block;
  box-sizing: border-box;
  position: relative;
  border-radius: 0;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  display: block;
  padding: 1.5rem 1.25rem 1.4375rem;
  border: 0.125rem solid transparent;
  border-radius: 6.25rem;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.5;
  transition: all 0.1s ease;
}
.l-footer-contactBox__line-btn:hover, .l-footer-contactBox__mail-btn:hover {
  opacity: 1;
}
.l-footer-contactBox__line-btn {
  background: #18BC45;
  color: #fff;
}
.l-footer-contactBox__line-btn:hover {
  border-color: #18BC45;
  background: #fff;
  color: #18BC45;
}
.l-footer-contactBox__mail-btn {
  background: #E86B78;
  color: #fff;
}
.l-footer-contactBox__mail-btn:hover {
  border-color: #E86B78;
  background: #fff;
  color: #E86B78;
}
.l-footer-contactBox__line-label, .l-footer-contactBox__mail-label {
  display: inline-block;
  position: relative;
  padding-left: 2.125rem;
}
.l-footer-contactBox__line-label::before, .l-footer-contactBox__mail-label::before {
  display: block;
  position: absolute;
  left: 0;
  top: calc(50% - 0.8125rem);
  width: 1.625rem;
  height: 1.625rem;
  background: currentColor;
  content: "";
  -webkit-mask: no-repeat center/contain;
          mask: no-repeat center/contain;
}
.l-footer-contactBox__line-label::before {
  -webkit-mask-image: url(../img/icon_contact.svg);
          mask-image: url(../img/icon_contact.svg);
}
.l-footer-contactBox__mail-label::before {
  -webkit-mask-image: url(../img/icon_mail.svg);
          mask-image: url(../img/icon_mail.svg);
}
@media (max-width: 767px) {
  .l-footer-contactBox {
    flex-direction: column;
    gap: 0;
    margin-top: 2.5rem;
    padding: 2.5rem 1.25rem;
  }
  .l-footer-contactBox__tel-number {
    padding-left: 2.375rem;
    font-size: 2.125rem;
  }
  .l-footer-contactBox__tel-number::before {
    top: calc(50% - 0.9375rem);
    width: 1.875rem;
    height: 1.875rem;
  }
  .l-footer-contactBox__tel-sub {
    font-size: 0.875rem;
  }
  .l-footer-contactBox__line, .l-footer-contactBox__mail {
    width: 100%;
  }
  .l-footer-contactBox__line {
    margin-top: 1.5rem;
  }
  .l-footer-contactBox__mail {
    margin-top: 1rem;
  }
  .l-footer-contactBox__line-btn, .l-footer-contactBox__mail-btn {
    padding: 1.375rem 1.25rem 1.3125rem;
    font-size: 1rem;
  }
  .l-footer-contactBox__line-label, .l-footer-contactBox__mail-label {
    padding-left: 1.875rem;
  }
  .l-footer-contactBox__line-label::before, .l-footer-contactBox__mail-label::before {
    top: calc(50% - 0.6875rem);
    width: 1.375rem;
    height: 1.375rem;
  }
}

/**************************************************/
/* contents */
/**************************************************/
.l-wrapper {
  overflow: clip;
}

.l-page-container {
  position: relative;
}

.l-pagehdr {
  position: relative;
  overflow: hidden;
}
.l-pagehdr__inner {
  max-width: 75rem;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
  position: relative;
  padding: 3rem 0 4.875rem;
  background: url(../img/bg_pattern.png) repeat;
  border-bottom: 1px solid #C7BFB0;
}
.l-pagehdr__inner::before, .l-pagehdr__inner::after {
  display: block;
  position: absolute;
  content: "";
}
.l-pagehdr__inner::before {
  bottom: -7rem;
  right: 0;
  width: 45.375rem;
  background: url(../img/pagehdr_mark.png) no-repeat;
  background-size: contain;
  aspect-ratio: 726/356;
  mix-blend-mode: multiply;
}
.l-pagehdr__inner::after {
  bottom: -1px;
  left: 0;
  width: 3.75rem;
  height: 1px;
  background: #1A416C;
}
.l-pagehdr__ttl {
  margin: 0;
}
.l-pagehdr__ttl-sub {
  display: block;
  position: relative;
  margin-bottom: 0.5rem;
  padding-left: 1.5rem;
  color: var(--heading-sub-color);
  font-family: "Montserrat", sans-serif;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
}
.l-pagehdr__ttl-sub::before {
  display: block;
  position: absolute;
  top: calc(50% - 0.5rem);
  left: 0;
  width: 1rem;
  height: 1rem;
  background: currentColor;
  content: "";
  -webkit-mask: url(../img/icon_heading.svg) no-repeat center/contain;
          mask: url(../img/icon_heading.svg) no-repeat center/contain;
}
@media (max-width: 767px) {
  .l-pagehdr__ttl-sub {
    margin-bottom: 0.375rem;
    padding-left: 1.25rem;
    font-size: 0.8125rem;
  }
  .l-pagehdr__ttl-sub::before {
    top: calc(50% - 0.375rem);
    width: 0.75rem;
    height: 0.75rem;
  }
}
.l-pagehdr__ttl-main {
  display: block;
  font-size: 2.375rem;
  letter-spacing: 0.06em;
}
@media (max-width: 767px) {
  .l-pagehdr__ttl-main {
    font-size: 1.5rem;
  }
}
@media (max-width: 767px) {
  .l-pagehdr {
    padding: 0 1rem;
  }
  .l-pagehdr__inner {
    padding: 2rem 0 3.125rem;
  }
  .l-pagehdr__inner::before {
    bottom: -1.875rem;
    right: -1.5rem;
    width: 19.125rem;
  }
}

.l-breadcrumb {
  position: relative;
  margin: 2rem 0 0;
}
.l-breadcrumb__list {
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-start;
  list-style: none;
  padding-left: 0;
  align-items: center;
  margin: 0;
}
.l-breadcrumb__list > li {
  display: block;
  position: relative;
  font-size: 0.875rem;
  line-height: 1.5;
}
.l-breadcrumb__list > li:not(:first-child) {
  padding-left: 2em;
}
.l-breadcrumb__list > li:not(:first-child)::after {
  display: block;
  position: absolute;
  top: calc(50% - 0.3125rem);
  left: calc(1em - 0.25rem);
  width: 0.625rem;
  height: 0.625rem;
  background: #1A416C;
  content: "";
  -webkit-mask: url(../img/breadcrumb_arrow.svg) no-repeat center/contain;
          mask: url(../img/breadcrumb_arrow.svg) no-repeat center/contain;
}
.l-breadcrumb__list a {
  display: block;
  color: inherit;
}
/**************************************************/
/* components */
/**************************************************/
/**************************************************/
/* components - basic */
/**************************************************/
/**************************************************/
/* components - form */
/**************************************************/
:root {
  --form-border-color: #ccc;
  --form-required-color: #E80000;
  --form-alert-color: #F00;
  --form-alert-bg-color: #FFF0F0;
  --form-btn-bg-color: #1A416C;
  --form-btn-edit-color: #6F6F6F;
}

form label {
  cursor: pointer;
}
form textarea {
  line-height: 1.25;
  resize: vertical;
}

*:-moz-placeholder-shown {
  color: #aaa;
}

*:placeholder-shown {
  color: #aaa;
}
*::-webkit-input-placeholder {
  color: #aaa;
}
*:-moz-placeholder {
  color: #aaa;
  opacity: 1;
}
*::-moz-placeholder {
  color: #aaa;
  opacity: 1;
}
*:-ms-input-placeholder {
  color: #aaa;
}

:focus::-webkit-input-placeholder {
  color: transparent;
}

:focus::-moz-placeholder {
  color: transparent;
}

.f-error {
  display: block;
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0.625rem 0 0;
  padding: 0.5em 1em;
  border-radius: 0.1875rem;
  background: var(--form-alert-bg-color);
  color: var(--form-alert-color);
  font-weight: 700;
}

.f-errorMsg {
  display: block;
  margin-bottom: 2.5rem;
  padding: 1em;
  background: var(--form-alert-bg-color);
  color: var(--form-alert-color);
  font-weight: 700;
}
.f-errorMsg__text {
  display: block;
  margin: 0;
  background-color: transparent;
}

.f-field {
  display: inline-block;
  box-sizing: border-box;
  width: 100%;
  padding: 0.625em 0.75em;
  border: 1px solid var(--form-border-color);
  border-radius: 0;
  line-height: 1.25em;
}

textarea.f-field {
  display: block;
  line-height: 1.25;
}

.f-checkbox {
  display: inline-block;
  cursor: pointer;
}
.f-checkbox > input[type=checkbox] {
  position: absolute;
  opacity: 0;
}
.f-checkbox__in {
  display: block;
  position: relative;
  padding: 0.125rem 0.125rem 0.125rem 1.75rem;
  font-size: 1rem;
  line-height: 1.5;
}
.f-checkbox__in::after {
  display: block;
  box-sizing: border-box;
  position: absolute;
  top: 0.25rem;
  left: 0;
  width: 1.25rem;
  height: 1.25rem;
  border: 1px solid var(--form-border-color);
  border-radius: 0;
  background: #fff no-repeat center/1.125rem 1.125rem;
  content: "";
}
.f-checkbox input[type=checkbox]:checked ~ .f-checkbox__in::after {
  background-image: url(../img/icon-checkbox-checked.svg);
}

.f-radio {
  display: inline-block;
  cursor: pointer;
}
.f-radio > input[type=radio] {
  position: absolute;
  opacity: 0;
}
.f-radio__in {
  display: block;
  position: relative;
  padding: 0.125rem 0.125rem 0.125rem 1.75rem;
  font-size: 1rem;
  line-height: 1.5;
}
.f-radio__in::after {
  display: block;
  box-sizing: border-box;
  position: absolute;
  top: 0.25rem;
  left: 0;
  width: 1.25rem;
  height: 1.25rem;
  border: 1px solid var(--form-border-color);
  border-radius: 50%;
  background: #fff no-repeat center/0.625rem 0.625rem;
  content: "";
}
.f-radio input[type=radio]:checked ~ .f-radio__in::after {
  background-image: url(../img/icon-radio-checked.svg);
}

.f-selectbox {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  position: relative;
  padding: 0.625em 2.625em 0.625em 0.75em;
  border: 1px solid var(--form-border-color);
  border-radius: 0.25em;
  background: url(../img/icon-select.svg) no-repeat right 0.5625em top 50%, linear-gradient(to bottom, #eee 0%, #ddd 100%) no-repeat right -1px top 50%, #fff;
  background-size: 0.75em 0.75em, 2em 100%;
  line-height: 1.25em;
}
.f-selectbox::-ms-expand {
  display: none;
}
.f-selectbox.-full {
  width: 100%;
}
.f-selectbox.-short {
  width: 100%;
  max-width: 8.75rem;
}
.f-selectbox.-middle {
  width: 100%;
  max-width: 15.625rem;
}
.f-selectbox.-long {
  width: 100%;
  max-width: 25rem;
}

.f-btn {
  border: none;
  display: inline-block;
  box-sizing: border-box;
  position: relative;
  border-radius: 0;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  display: block;
  width: 100%;
  margin: 0 auto;
  padding: 1em;
  background: var(--form-btn-bg-color);
  color: #fff;
  font-weight: 700;
}
.f-btn__label {
  display: inline-block;
  position: relative;
}

.f-input {
  margin: 1rem 0 0;
}
.f-input.-short {
  max-width: 8.75rem;
}
.f-input.-middle {
  max-width: 15rem;
}
.f-input.-long {
  max-width: 25rem;
}

.f-input-columns {
  list-style: none;
  margin: 1rem 0 0;
  padding-left: 0;
  line-height: 1.5;
}
.f-input-columns > li + li {
  padding-top: 0.5rem;
}

.f-input-rows {
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-start;
  list-style: none;
  padding-left: 0;
  margin: 1rem 0 -0.5rem -1rem;
  line-height: 1.5;
}
.f-input-rows > li {
  display: block;
  box-sizing: border-box;
  margin: 0 0 0.5rem 1rem;
}
.f-input-units {
  display: flex;
  flex-flow: row nowrap;
  justify-content: flex-start;
  list-style: none;
  padding-left: 0;
  align-items: center;
  margin: 1rem 0 -0.5rem -1rem;
  line-height: 1.5;
}
.f-input-units__unit {
  display: block;
  box-sizing: border-box;
  margin: 0 0 0.5rem 1rem;
}
.f-input-units.-name .f-input-units {
  flex-wrap: nowrap;
  margin-left: -1rem;
}
.f-input-units.-name .f-input-units__unit {
  width: calc(50% - 1rem);
  margin-left: 1rem;
}
.f-input-units.-zip .f-input-units {
  flex-wrap: nowrap;
  align-items: center;
  margin-left: -0.5rem;
}
.f-input-units.-zip .f-input-units__unit {
  margin-left: 0.5rem;
}
.f-input-units.-zip .f-input-units__unit:nth-child(2) {
  width: 6.25rem;
}
.f-input-units.-zip .f-input-units__unit:nth-child(4) {
  width: 8.75rem;
}
.f-toConfirm {
  max-width: 15rem;
  margin: 2.5rem auto 0;
}

.f-toSend {
  display: flex;
  justify-content: center;
  gap: 1.25rem;
  margin: 2.5rem auto 0;
}
.f-toSend__unit {
  display: block;
  width: 15rem;
}

.f-table {
  table-layout: fixed;
  border-collapse: collapse;
  width: 100%;
  margin: 0;
}
.f-table th, .f-table td {
  padding: 1.25rem 1em;
  border-bottom: 1px solid var(--form-alert-bg-color);
  font-size: 1rem;
  font-weight: 400;
  text-align: left;
  line-height: 2;
}
.f-table th > *:first-child, .f-table td > *:first-child {
  margin-top: 0 !important;
}
.f-table th {
  vertical-align: top;
  white-space: nowrap;
}
.f-table__required {
  display: block;
  position: relative;
  padding-right: 4.375rem;
}
.f-table__required::after {
  display: inline-block;
  content: "必須";
  position: absolute;
  top: 0.375rem;
  right: 0;
  padding: 0.25rem 1.5em;
  background: var(--form-required-color);
  font-size: 0.75em;
  color: #fff;
  line-height: 1;
  letter-spacing: 0;
  vertical-align: inherit;
}
.f-table.-confirm th {
  font-weight: 700;
}
@media (max-width: 1023px) {
  .f-table {
    display: block;
  }
  .f-table tbody, .f-table tr, .f-table th, .f-table td {
    display: block;
  }
  .f-table th, .f-table td {
    padding: 0;
    border-bottom: none;
    line-height: 1.75;
  }
  .f-table tr + tr {
    margin-top: 2rem;
  }
  .f-table th {
    width: auto;
  }
  .f-table td {
    margin-top: 0.5rem;
  }
  .f-table__required {
    padding-right: 0;
  }
  .f-table__required::after {
    position: relative;
    top: auto;
    margin-left: 1em;
    padding: 0.1875rem 1em;
  }
}

/**************************************************/
/* pages */
/**************************************************/
/**************************************************/
/* Home */
/**************************************************/
.p-home-mv {
  position: relative;
  padding: 0.625rem 0 6.25rem;
  z-index: 2;
}
.p-home-mv__inner {
  max-width: 75rem;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 767px) {
  .p-home-mv {
    padding: 0.625rem 1rem 3.125rem;
  }
  .p-home-mv::before {
    display: block;
    position: absolute;
    top: -1.875rem;
    right: -0.875rem;
    width: 15.0625rem;
    background: url(../../images/home/mv_mark_sp.png) no-repeat center/contain, url(../img/bg_pattern.png) repeat;
    z-index: -1;
    content: "";
    aspect-ratio: 241/245;
    background-blend-mode: multiply;
    pointer-events: none;
  }
}

.p-home-mvSlider {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  position: relative;
}
.p-home-mvSlider__textarea {
  box-sizing: border-box;
  width: 26.25rem;
  padding-bottom: 3.125rem;
}
.p-home-mvSlider__copy {
  margin: 0;
  color: #1A416C;
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0.1em;
}
.p-home-mvSlider__copy strong {
  color: #E86B78;
}
.p-home-mvSlider__copy-dotted {
  display: inline-block;
  background: url(../../images/home/mv_dotted.svg) repeat-x left bottom;
}
.p-home-mvSlider__text {
  margin: 1.25rem 0 0;
  font-weight: 700;
  line-height: 2;
  letter-spacing: 0.04em;
}
.p-home-mvSlider__services {
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-start;
  list-style: none;
  padding-left: 0;
  gap: 0.5rem 1.375rem;
  margin: 1rem 0 0;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.25;
  overflow: hidden;
}
.p-home-mvSlider__services > li {
  display: block;
  position: relative;
}
.p-home-mvSlider__services > li::before {
  display: block;
  position: absolute;
  left: -0.6875rem;
  top: 0.125rem;
  bottom: 0.125rem;
  width: 0.125rem;
  margin: auto;
  background: #C7BFB0;
  content: "";
}
.p-home-mvSlider__merit {
  display: flex;
  flex-flow: row nowrap;
  justify-content: flex-start;
  list-style: none;
  padding-left: 0;
  gap: 0.875rem;
  margin: 2rem 0 0;
}
.p-home-mvSlider__merit > li {
  display: block;
  width: 7.25rem;
}
.p-home-mvSlider__merit > li img {
  display: block;
  width: 100%;
}
.p-home-mvSlider__slider {
  width: 46.625rem;
}
@media (max-width: 767px) {
  .p-home-mvSlider {
    display: block;
    padding-bottom: 1.875rem;
  }
  .p-home-mvSlider__textarea {
    width: auto;
    padding-bottom: 0;
  }
  .p-home-mvSlider__copy {
    font-size: 2rem;
  }
  .p-home-mvSlider__text {
    margin-top: 1rem;
    font-size: 0.875rem;
    line-height: 1.75;
    letter-spacing: 0;
  }
  .p-home-mvSlider__services {
    margin-top: 0.5rem;
    font-size: 0.75rem;
  }
  .p-home-mvSlider__merit {
    gap: 0.5625rem;
    margin-top: 1.25rem;
  }
  .p-home-mvSlider__merit > li {
    width: calc((100% - 1.125rem) / 3);
  }
  .p-home-mvSlider__slider {
    width: auto;
    margin-top: 1.25rem;
  }
}

.mv-swiper-controls {
  --swiper-pagination-color: #1A416C;
  --swiper-pagination-bullet-inactive-color: #C7BFB0;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.5rem;
  position: absolute;
  bottom: 0;
  left: 0;
  max-width: 26.25rem;
}
.mv-swiper-controls .mv-autoplay {
  border: none;
  display: inline-block;
  box-sizing: border-box;
  position: relative;
  border-radius: 0;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  flex: 0 0 auto;
  display: block;
  width: 1.25rem;
  height: 1.25rem;
  background: url(../../images/home/icon_stop.svg) no-repeat center/contain;
}
.mv-swiper-controls .mv-autoplay.is-stop {
  background-image: url(../../images/home/icon_play.svg);
}
.mv-swiper-controls .mv-swiper-pagination {
  display: flex;
  flex-wrap: nowrap;
  gap: 0.5rem;
}
.mv-swiper-controls .mv-swiper-bullet {
  flex: 0 1 auto;
  display: block;
  position: relative;
  width: 5rem;
  height: 0.1875rem;
  border-radius: 0.1875rem;
  background: var(--swiper-pagination-bullet-inactive-color);
  overflow: hidden;
  opacity: 0.3;
}
.mv-swiper-controls .mv-swiper-bullet::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 100%;
  background: var(--swiper-pagination-color);
  content: "";
  opacity: 0;
  transition: opacity 0.1s ease;
}
.mv-swiper-controls .mv-swiper-bullet.swiper-pagination-bullet-active {
  opacity: 1;
}
.mv-swiper-controls .mv-swiper-bullet.swiper-pagination-bullet-active::before {
  width: calc(var(--percentage) * 100%);
  opacity: 1;
}
@media (max-width: 767px) {
  .mv-swiper-controls {
    justify-content: flex-end;
    left: auto;
    right: 0;
    max-width: 100%;
  }
  .mv-swiper-controls .mv-swiper-pagination {
    justify-content: flex-end;
  }
  .mv-swiper-controls .mv-swiper-bullet {
    width: 2.875rem;
  }
}

.p-home-mvLead {
  margin: 5rem 0 0;
}
.p-home-mvLead__lead {
  font-size: 2rem;
  font-weight: 700;
  text-align: center;
}
.p-home-mvLead__list {
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
  list-style: none;
  padding-left: 0;
  gap: 1.25rem;
  margin: 2.5rem 0 0;
}
.p-home-mvLead__balloon {
  flex: 1 1 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-sizing: border-box;
  position: relative;
  padding: 1.25rem;
  border-radius: 1.25rem;
  background: #fff;
  z-index: 0;
  filter: drop-shadow(0 0 1rem rgba(198, 191, 176, 0.3));
}
.p-home-mvLead__balloon::after {
  display: block;
  position: absolute;
  top: calc(100% - 0.9375rem);
  left: calc(50% - 0.75rem);
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 0.1875rem;
  background: #fff;
  content: "";
  z-index: -1;
  transform: rotate(45deg) matrix(1, 0.1, 0.1, 1, 0, 0);
}
.p-home-mvLead__balloon-text {
  display: block;
  font-size: 0.9375rem;
  font-weight: 700;
}
.p-home-mvLead__balloon-img {
  width: 5.75rem;
}
.p-home-mvLead__balloon-img img {
  display: block;
  width: 100%;
}
.p-home-mvLead__phrase {
  margin: 2.5rem 0 0;
  font-size: 2rem;
  font-weight: 700;
  line-height: 2.25;
  text-align: center;
  letter-spacing: 0.08em;
}
.p-home-mvLead__phrase-dotted {
  display: inline-block;
  background: url(../../images/home/mv_dotted.svg) repeat-x left bottom;
}
@media (max-width: 767px) {
  .p-home-mvLead {
    margin-top: 2rem;
  }
  .p-home-mvLead__lead {
    font-size: 1.25rem;
  }
  .p-home-mvLead__list {
    flex-wrap: wrap;
    gap: 1.25rem 0.9375rem;
    margin-top: 1rem;
  }
  .p-home-mvLead__balloon {
    flex: 0 1 auto;
    flex-direction: column;
    gap: 0.5rem;
    width: calc((100% - 0.9375rem) / 2);
  }
  .p-home-mvLead__balloon::after {
    top: calc(100% - 1.125rem);
  }
  .p-home-mvLead__balloon-text {
    font-size: 0.8125rem;
    text-align: center;
  }
  .p-home-mvLead__balloon-img {
    order: -1;
    width: 5rem;
  }
  .p-home-mvLead__phrase {
    margin-top: 1.875rem;
    font-size: 1.25rem;
  }
}

.p-home-reason {
  position: relative;
  padding: 7.5rem 0 8.75rem;
  border-radius: 0 7.5rem 0 7.5rem;
  background: #fff;
}
.p-home-reason::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 0 7.5rem 0 7.5rem;
  content: "";
  pointer-events: none;
  mix-blend-mode: multiply;
  box-shadow: 0 0 20rem #F8F4EC;
}
.p-home-reason::after {
  display: block;
  position: absolute;
  top: -14.375rem;
  right: -10rem;
  width: 27.75rem;
  background: url(../../images/home/bg_mark.png) no-repeat center/contain;
  z-index: 1;
  content: "";
  aspect-ratio: 444/338;
  mix-blend-mode: multiply;
  pointer-events: none;
}
.p-home-reason__inner {
  max-width: 75rem;
  margin-left: auto;
  margin-right: auto;
}
.p-home-reason__head {
  position: relative;
  box-sizing: border-box;
  max-width: 65rem;
  margin: auto;
  padding-right: 35rem;
  min-height: 22.5rem;
}
.p-home-reason__ttl {
  margin: 0;
}
.p-home-reason__ttl-sub {
  display: block;
  position: relative;
  margin-bottom: 0.5rem;
  padding-left: 1.5rem;
  color: var(--heading-sub-color);
  font-family: "Montserrat", sans-serif;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
}
.p-home-reason__ttl-sub::before {
  display: block;
  position: absolute;
  top: calc(50% - 0.5rem);
  left: 0;
  width: 1rem;
  height: 1rem;
  background: currentColor;
  content: "";
  -webkit-mask: url(../img/icon_heading.svg) no-repeat center/contain;
          mask: url(../img/icon_heading.svg) no-repeat center/contain;
}
@media (max-width: 767px) {
  .p-home-reason__ttl-sub {
    margin-bottom: 0.375rem;
    padding-left: 1.25rem;
    font-size: 0.8125rem;
  }
  .p-home-reason__ttl-sub::before {
    top: calc(50% - 0.375rem);
    width: 0.75rem;
    height: 0.75rem;
  }
}
.p-home-reason__ttl-main {
  display: block;
  font-size: 2.375rem;
  letter-spacing: 0.06em;
}
@media (max-width: 767px) {
  .p-home-reason__ttl-main {
    font-size: 1.5rem;
  }
}
.p-home-reason__lead {
  margin: 2.5rem 0 0;
  line-height: 2.25;
}
.p-home-reason__img {
  box-sizing: border-box;
  position: absolute;
  top: -1.25rem;
  right: 0;
  width: 26.125rem;
  padding: 0 0.75rem;
  aspect-ratio: 1/1;
}
.p-home-reason__img img {
  display: block;
  position: relative;
  width: 100%;
  z-index: 4;
}
.p-home-reason__img .ripple {
  display: block;
  position: absolute;
  inset: 0;
  width: 100%;
  margin: auto;
  border-radius: 50%;
  background: #F2EDE4;
  aspect-ratio: 1/1;
  mix-blend-mode: multiply;
  content: "";
}
.p-home-reason__img .ripple-1 {
  opacity: 0.32;
  z-index: 1;
}
.p-home-reason__img .ripple-2 {
  opacity: 0.4;
  z-index: 2;
  transform: scale(0.9);
}
.p-home-reason__img .ripple-3 {
  opacity: 0.7;
  z-index: 3;
  transform: scale(0.8);
}
.p-home-reason__btn {
  border: none;
  display: inline-block;
  box-sizing: border-box;
  position: relative;
  border-radius: 0;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  display: block;
  padding: 1.125rem 3rem 1.125rem 1.625rem;
  border: 0.125rem solid transparent;
  border-radius: 6.25rem;
  background: #1A416C;
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: left;
  max-width: 16.25rem;
  margin: 2.5rem 0 0;
}
.p-home-reason__btn::after {
  display: block;
  position: absolute;
  top: calc(50% - 0.5rem);
  right: 1.375rem;
  width: 1rem;
  height: 1rem;
  background: currentColor;
  content: "";
  -webkit-mask: url(../img/icon_arrow_right.svg) no-repeat center/contain;
          mask: url(../img/icon_arrow_right.svg) no-repeat center/contain;
}
.p-home-reason__btn.-external::after {
  -webkit-mask-image: url(../img/icon_blank.svg);
          mask-image: url(../img/icon_blank.svg);
}
.p-home-reason__btn:hover {
  border-color: #1A416C;
  background-color: #fff;
  color: #1A416C;
}
.p-home-reason__merit {
  display: flex;
  list-style: none;
  margin: 5rem 0 0;
  padding: 0;
  border-radius: 1.25rem;
  background: #F6F2E6 url(../img/bg_pattern.png) repeat;
}
.p-home-reason__merit > li {
  display: block;
  box-sizing: border-box;
  position: relative;
  width: 33.3333333333%;
  padding: 3.125rem;
}
.p-home-reason__merit > li:not(:nth-child(3n+1))::after {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 1px;
  margin: auto;
  background: #C7BFB0;
  content: "";
}
.p-home-reason__merit-ttl {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.5;
}
.p-home-reason__merit-sub {
  display: block;
  color: #1A416C;
  font-family: "Montserrat", sans-serif;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: 0.06em;
}
.p-home-reason__merit-main {
  display: block;
  margin: 1rem 0 0;
  letter-spacing: 0.04em;
}
.p-home-reason__merit-text {
  margin: 1.25rem 0 0;
  font-size: 0.875rem;
  line-height: 1.75;
}
.p-home-reason__marquee {
  display: flex;
  margin: 5.625rem 0 0;
  white-space: nowrap;
  overflow: hidden;
}
.p-home-reason__marquee-item {
  flex: 0 0 auto;
  display: block;
  width: 115.625rem;
  background: url(../../images/home/reason_marquee.png) no-repeat left center/contain;
  aspect-ratio: 1850/120;
}
@media (max-width: 767px) {
  .p-home-reason {
    padding: 3.75rem 0 3.75rem;
    border-radius: 0 3.75rem 0 3.75rem;
  }
  .p-home-reason::before {
    border-radius: 0 3.75rem 0 3.75rem;
    box-shadow: 0 0 10rem #F8F4EC;
  }
  .p-home-reason::after {
    top: -7.1875rem;
    right: -5rem;
    width: 13.875rem;
  }
  .p-home-reason__inner {
    padding-left: 1rem;
    padding-right: 1rem;
  }
  .p-home-reason__head {
    max-width: 65rem;
    padding-right: 0;
    min-height: 0;
  }
  .p-home-reason__img {
    position: relative;
    top: auto;
    right: auto;
    width: 17.5rem;
    margin: 1.875rem auto 0;
  }
  .p-home-reason__lead {
    margin-top: 1.5rem;
    font-size: 0.875rem;
    line-height: 2;
  }
  .p-home-reason__merit {
    flex-direction: column;
    margin-top: 2.5rem;
  }
  .p-home-reason__merit > li {
    width: 100%;
    padding: 2.25rem 1.5rem;
  }
  .p-home-reason__merit > li:not(:nth-child(3n+1))::after {
    bottom: auto;
    right: 0;
    width: auto;
    height: 1px;
  }
  .p-home-reason__merit-ttl {
    margin-top: 0.75rem;
    font-size: 1.125rem;
  }
  .p-home-reason__merit-sub {
    font-size: 0.75rem;
  }
  .p-home-reason__merit-text {
    margin-top: 1rem;
    font-size: 0.8125rem;
  }
  .p-home-reason__marquee {
    margin-top: 2.5rem;
  }
  .p-home-reason__marquee-item {
    width: 77.125rem;
  }
}

.p-home-service {
  position: relative;
  padding: 7.5rem 0 8.75rem;
  z-index: 2;
}
.p-home-service__inner {
  max-width: 75rem;
  margin-left: auto;
  margin-right: auto;
}
.p-home-service__ttl {
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-home-service__ttl-sub {
  display: block;
  position: relative;
  margin-bottom: 0.5rem;
  padding-left: 1.5rem;
  color: var(--heading-sub-color);
  font-family: "Montserrat", sans-serif;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
}
.p-home-service__ttl-sub::before {
  display: block;
  position: absolute;
  top: calc(50% - 0.5rem);
  left: 0;
  width: 1rem;
  height: 1rem;
  background: currentColor;
  content: "";
  -webkit-mask: url(../img/icon_heading.svg) no-repeat center/contain;
          mask: url(../img/icon_heading.svg) no-repeat center/contain;
}
@media (max-width: 767px) {
  .p-home-service__ttl-sub {
    margin-bottom: 0.375rem;
    padding-left: 1.25rem;
    font-size: 0.8125rem;
  }
  .p-home-service__ttl-sub::before {
    top: calc(50% - 0.375rem);
    width: 0.75rem;
    height: 0.75rem;
  }
}
.p-home-service__ttl-main {
  display: block;
  font-size: 2.375rem;
  letter-spacing: 0.06em;
}
@media (max-width: 767px) {
  .p-home-service__ttl-main {
    font-size: 1.5rem;
  }
}
.p-home-service__lead {
  margin: 2.5rem 0 0;
  line-height: 1.75;
  text-align: center;
}
.p-home-service__btn {
  border: none;
  display: inline-block;
  box-sizing: border-box;
  position: relative;
  border-radius: 0;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  display: block;
  padding: 1.125rem 3rem 1.125rem 1.625rem;
  border: 0.125rem solid transparent;
  border-radius: 6.25rem;
  background: #1A416C;
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: left;
  max-width: 16.25rem;
  margin: 4.5rem auto 0;
}
.p-home-service__btn::after {
  display: block;
  position: absolute;
  top: calc(50% - 0.5rem);
  right: 1.375rem;
  width: 1rem;
  height: 1rem;
  background: currentColor;
  content: "";
  -webkit-mask: url(../img/icon_arrow_right.svg) no-repeat center/contain;
          mask: url(../img/icon_arrow_right.svg) no-repeat center/contain;
}
.p-home-service__btn.-external::after {
  -webkit-mask-image: url(../img/icon_blank.svg);
          mask-image: url(../img/icon_blank.svg);
}
.p-home-service__btn:hover {
  border-color: #1A416C;
  background-color: #fff;
  color: #1A416C;
}
@media (max-width: 767px) {
  .p-home-service {
    padding: 3.75rem 1rem;
  }
  .p-home-service__lead {
    margin-top: 1.5rem;
    font-size: 0.875rem;
  }
}

.p-home-serviceList {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  list-style: none;
  padding-left: 0;
  gap: 4.5rem 6.25rem;
  margin: 3.75rem auto 0;
}
.p-home-serviceList__card {
  display: block;
  position: relative;
}
.p-home-serviceList__card:not(:nth-child(3n+1))::after {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: -3.125rem;
  width: 1px;
  margin: auto 0;
  background: #C7BFB0;
  content: "";
}
.p-home-serviceList__card-img {
  display: block;
  border-radius: 1.25rem;
  overflow: hidden;
}
.p-home-serviceList__card-img img {
  display: block;
  width: 100%;
}
.p-home-serviceList__card-ttl {
  margin: 1.5rem 0 0;
  font-size: 1.625rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
}
.p-home-serviceList__card-text {
  margin: 1rem 0 0;
  line-height: 1.75;
}
.p-home-serviceList__card-list {
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-start;
  list-style: none;
  padding-left: 0;
  gap: 0.25rem 1.375rem;
  margin: 1.25rem 0 0;
  font-size: 0.875rem;
  line-height: 1.25;
  overflow: hidden;
}
.p-home-serviceList__card-list > li {
  display: block;
  position: relative;
}
.p-home-serviceList__card-list > li::before {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: -0.6875rem;
  width: 1px;
  margin: auto 0;
  background: #C7BFB0;
  content: "";
}
.p-home-serviceList__card-list > li a {
  color: inherit;
}
@media (min-width: 768px) {
  .p-home-serviceList__card {
    width: calc((100% - 12.5rem) / 3);
  }
  .p-home-serviceList__card:not(:nth-child(3n+1))::after {
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    left: -3.125rem;
    width: 1px;
    margin: auto 0;
    background: #C7BFB0;
    content: "";
  }
}
@media (max-width: 767px) {
  .p-home-serviceList {
    flex-direction: column;
    gap: 3.75rem;
    margin-top: 2.5rem;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }
  .p-home-serviceList__card {
    width: 100%;
  }
  .p-home-serviceList__card-ttl {
    margin-top: 1rem;
    font-size: 1.5rem;
  }
  .p-home-serviceList__card-text {
    margin-top: 0.625rem;
    font-size: 0.875rem;
  }
  .p-home-serviceList__card-list {
    margin-top: 0.625rem;
  }
}

.p-home-serviceOthers {
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-start;
  list-style: none;
  padding-left: 0;
  max-width: 65rem;
  margin: 5rem auto 0;
  border: solid #C7BFB0;
  border-width: 1px 0;
}
.p-home-serviceOthers__card {
  display: flex;
  align-items: center;
  box-sizing: border-box;
  position: relative;
  width: 50%;
}
.p-home-serviceOthers__card-img {
  display: block;
  border-radius: 0.75rem;
  overflow: hidden;
}
.p-home-flow {
  position: relative;
  padding: 7.5rem 0 8.75rem;
  border-radius: 0 7.5rem 0 0;
  background: #fff;
}
.p-home-flow::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 0 7.5rem 0 0;
  content: "";
  pointer-events: none;
  mix-blend-mode: multiply;
  box-shadow: 0 0 20rem #F8F4EC;
}
.p-home-flow::after {
  display: block;
  position: absolute;
  top: -14.375rem;
  right: -10rem;
  width: 27.75rem;
  background: url(../../images/home/bg_mark.png) no-repeat center/contain;
  z-index: 1;
  content: "";
  aspect-ratio: 444/338;
  mix-blend-mode: multiply;
  pointer-events: none;
}
.p-home-flow__inner {
  max-width: 75rem;
  margin-left: auto;
  margin-right: auto;
}
.p-home-flow__ttl {
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-home-flow__ttl-sub {
  display: block;
  position: relative;
  margin-bottom: 0.5rem;
  padding-left: 1.5rem;
  color: var(--heading-sub-color);
  font-family: "Montserrat", sans-serif;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
}
.p-home-flow__ttl-sub::before {
  display: block;
  position: absolute;
  top: calc(50% - 0.5rem);
  left: 0;
  width: 1rem;
  height: 1rem;
  background: currentColor;
  content: "";
  -webkit-mask: url(../img/icon_heading.svg) no-repeat center/contain;
          mask: url(../img/icon_heading.svg) no-repeat center/contain;
}
@media (max-width: 767px) {
  .p-home-flow__ttl-sub {
    margin-bottom: 0.375rem;
    padding-left: 1.25rem;
    font-size: 0.8125rem;
  }
  .p-home-flow__ttl-sub::before {
    top: calc(50% - 0.375rem);
    width: 0.75rem;
    height: 0.75rem;
  }
}
.p-home-flow__ttl-main {
  display: block;
  font-size: 2.375rem;
  letter-spacing: 0.06em;
}
@media (max-width: 767px) {
  .p-home-flow__ttl-main {
    font-size: 1.5rem;
  }
}
.p-home-flow__list {
  display: flex;
  flex-flow: row nowrap;
  justify-content: space-between;
  list-style: none;
  padding-left: 0;
  gap: 1.25rem 5.375rem;
  margin: 6.25rem auto 0;
}
.p-home-flow__card {
  display: block;
  box-sizing: border-box;
  position: relative;
  width: 10.625rem;
}
.p-home-flow__card + .p-home-flow__card::before {
  display: block;
  position: absolute;
  top: 4.5625rem;
  left: -3.25rem;
  border: solid transparent;
  border-width: 0.75rem 0 0.75rem 1.125rem;
  border-left-color: #1A416C;
  content: "";
}
.p-home-flow__card-img {
  display: block;
}
.p-home-flow__card-img img {
  display: block;
  width: 100%;
}
.p-home-flow__card-body {
  display: block;
  margin: 1.25rem 0 0;
}
.p-home-flow__card-ttl {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
}
.p-home-flow__card-text {
  margin: 0.75rem 0 0;
  font-size: 0.9375rem;
  line-height: 1.8;
}
.p-home-flow__card-balloon {
  box-sizing: border-box;
  position: absolute;
  bottom: calc(100% + 1.125rem);
  left: 0.375rem;
  right: 0.375rem;
  margin: 0 auto;
  padding: 0.5rem 1em;
  border-radius: 6.25rem;
  background: #1A416C;
  color: #fff;
  font-weight: 700;
  text-align: center;
  z-index: 2;
}
.p-home-flow__card-balloon::before {
  display: block;
  position: absolute;
  bottom: -0.625rem;
  left: calc(50% - 0.625rem);
  border: solid transparent;
  border-width: 0.75rem 0.625rem 0 0.625rem;
  border-top-color: #1A416C;
  content: "";
}
@media (max-width: 767px) {
  .p-home-flow {
    padding: 3.75rem 0 3.75rem;
    border-radius: 0 3.75rem 0 0;
  }
  .p-home-flow::before {
    border-radius: 0 3.75rem 0 0;
    box-shadow: 0 0 10rem #F8F4EC;
  }
  .p-home-flow::after {
    top: -7.1875rem;
    right: -5rem;
    width: 13.875rem;
  }
  .p-home-flow__inner {
    padding-left: 1rem;
    padding-right: 1rem;
  }
  .p-home-flow__list {
    flex-direction: column;
    gap: 3.5rem;
    margin-top: 2rem;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }
  .p-home-flow__card {
    display: flex;
    gap: 0.875rem;
    width: 100%;
  }
  .p-home-flow__card + .p-home-flow__card::before {
    top: -2.5rem;
    left: calc(50% - 0.75rem);
    transform: rotate(90deg);
  }
  .p-home-flow__card-img {
    flex: 0 0 auto;
    width: 6.875rem;
  }
  .p-home-flow__card-body {
    margin: 0;
  }
  .p-home-flow__card-ttl {
    font-size: 1.125rem;
    text-align: left;
  }
  .p-home-flow__card-text {
    margin-top: 0.375rem;
    font-size: 0.875rem;
  }
  .p-home-flow__card-balloon {
    bottom: calc(100% - 1rem);
    left: 0.3125rem;
    right: auto;
    width: 6.25rem;
    padding: 0.25rem 0.25em;
    font-size: 0.75rem;
  }
  .p-home-flow__card-balloon::before {
    bottom: -0.5rem;
  }
}

.p-home-visual {
  display: block;
  position: relative;
}
.p-home-visual img {
  display: block;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (max-width: 767px) {
  .p-home-visual img {
    aspect-ratio: 375/218;
  }
}

.p-home-news {
  position: relative;
  padding: 7.5rem 0 8.75rem;
  z-index: 2;
}
.p-home-news__inner {
  max-width: 75rem;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
}
.p-home-news__left {
  box-sizing: border-box;
  width: 21.25rem;
}
.p-home-news__right {
  box-sizing: border-box;
  width: 50rem;
}
.p-home-news__ttl {
  margin: 0;
}
.p-home-news__ttl-sub {
  display: block;
  position: relative;
  margin-bottom: 0.5rem;
  padding-left: 1.5rem;
  color: var(--heading-sub-color);
  font-family: "Montserrat", sans-serif;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
}
.p-home-news__ttl-sub::before {
  display: block;
  position: absolute;
  top: calc(50% - 0.5rem);
  left: 0;
  width: 1rem;
  height: 1rem;
  background: currentColor;
  content: "";
  -webkit-mask: url(../img/icon_heading.svg) no-repeat center/contain;
          mask: url(../img/icon_heading.svg) no-repeat center/contain;
}
@media (max-width: 767px) {
  .p-home-news__ttl-sub {
    margin-bottom: 0.375rem;
    padding-left: 1.25rem;
    font-size: 0.8125rem;
  }
  .p-home-news__ttl-sub::before {
    top: calc(50% - 0.375rem);
    width: 0.75rem;
    height: 0.75rem;
  }
}
.p-home-news__ttl-main {
  display: block;
  font-size: 2.375rem;
  letter-spacing: 0.06em;
}
@media (max-width: 767px) {
  .p-home-news__ttl-main {
    font-size: 1.5rem;
  }
}
.p-home-news__btn {
  border: none;
  display: inline-block;
  box-sizing: border-box;
  position: relative;
  border-radius: 0;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  display: block;
  padding: 0.875rem 3rem 0.8125rem 1.375rem;
  border: 0.125rem solid transparent;
  border-radius: 6.25rem;
  background: #1A416C;
  color: #fff;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: left;
  transition: all 0.1s ease;
  max-width: 15rem;
}
.p-home-news__btn::after {
  display: block;
  position: absolute;
  top: calc(50% - 0.5rem);
  right: 1.375rem;
  width: 1rem;
  height: 1rem;
  background: currentColor;
  content: "";
  -webkit-mask: url(../img/icon_arrow_right.svg) no-repeat center/contain;
          mask: url(../img/icon_arrow_right.svg) no-repeat center/contain;
}
.p-home-news__btn.-external::after {
  -webkit-mask-image: url(../img/icon_blank.svg);
          mask-image: url(../img/icon_blank.svg);
}
.p-home-news__btn:hover {
  border-color: #1A416C;
  background-color: #fff;
  color: #1A416C;
  opacity: 1;
}
@media (max-width: 767px) {
  .p-home-news {
    padding: 3.75rem 1rem;
  }
  .p-home-news__inner {
    flex-direction: column;
  }
  .p-home-news__left {
    width: 100%;
  }
  .p-home-news__right {
    width: 100%;
    margin-top: 2rem;
  }
}

.p-home-newsList {
  list-style: none;
  margin: 0;
  padding: 0;
}
.p-home-newsList > li {
  display: block;
  padding-bottom: 2rem;
  border-bottom: 1px solid #C7BFB0;
}
.p-home-newsList > li + li {
  margin-top: 2rem;
}
.p-home-newsList__card {
  display: flex;
  flex-wrap: nowrap;
  gap: 2.5rem;
  box-sizing: border-box;
}
.p-home-newsList__card-img {
  flex: 0 0 auto;
  display: block;
  width: 12.5rem;
  border-radius: 0.25rem;
  overflow: hidden;
}
.p-home-newsList__card-img img {
  display: block;
  width: 100%;
  aspect-ratio: 200/140;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-home-newsList__card-info {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.25rem 1rem;
  margin: 0;
}
.p-home-newsList__card-date {
  display: block;
  box-sizing: border-box;
  padding-top: 0.2em;
  color: #1A416C;
  font-family: "Montserrat", sans-serif;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.25;
}
.p-home-newsList__card-cat {
  display: block;
  box-sizing: border-box;
  padding: 0.1875rem 0.75em;
  border: 1px solid #1A416C;
  border-radius: 4em;
  color: #1A416C;
  font-size: 0.75rem;
  line-height: 1.25;
}
.p-home-newsList__card-ttl {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  max-height: 6em;
  text-overflow: ellipsis;
  overflow: hidden;
  -webkit-line-clamp: 3;
  margin: 0.75rem 0 0;
  font-weight: 700;
  line-height: 2;
}
@media (max-width: 767px) {
  .p-home-newsList__card {
    gap: 0.875rem;
  }
  .p-home-newsList__card-img {
    width: 6.875rem;
  }
  .p-home-newsList__card-info {
    gap: 0.25rem 0.5rem;
  }
  .p-home-newsList__card-ttl {
    max-height: 3.5em;
    -webkit-line-clamp: 2;
    margin-top: 0.5rem;
    font-size: 0.875rem;
    line-height: 1.75;
  }
}

.p-home-office {
  position: relative;
  padding: 7.5rem 0 8.75rem;
  border-radius: 7.5rem 7.5rem 0 0;
  background: #fff;
}
.p-home-office::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 7.5rem 7.5rem 0 0;
  content: "";
  pointer-events: none;
  mix-blend-mode: multiply;
  box-shadow: 0 0 20rem #F8F4EC;
}
.p-home-office__inner {
  max-width: 65rem;
  margin-left: auto;
  margin-right: auto;
}
.p-home-office__ttl {
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-home-office__ttl-sub {
  display: block;
  position: relative;
  margin-bottom: 0.5rem;
  padding-left: 1.5rem;
  color: var(--heading-sub-color);
  font-family: "Montserrat", sans-serif;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
}
.p-home-office__ttl-sub::before {
  display: block;
  position: absolute;
  top: calc(50% - 0.5rem);
  left: 0;
  width: 1rem;
  height: 1rem;
  background: currentColor;
  content: "";
  -webkit-mask: url(../img/icon_heading.svg) no-repeat center/contain;
          mask: url(../img/icon_heading.svg) no-repeat center/contain;
}
@media (max-width: 767px) {
  .p-home-office__ttl-sub {
    margin-bottom: 0.375rem;
    padding-left: 1.25rem;
    font-size: 0.8125rem;
  }
  .p-home-office__ttl-sub::before {
    top: calc(50% - 0.375rem);
    width: 0.75rem;
    height: 0.75rem;
  }
}
.p-home-office__ttl-main {
  display: block;
  font-size: 2.375rem;
  letter-spacing: 0.06em;
}
@media (max-width: 767px) {
  .p-home-office__ttl-main {
    font-size: 1.5rem;
  }
}
.p-home-office__wrap {
  display: flex;
  justify-content: space-between;
  margin: 3.75rem auto 0;
}
.p-home-office__gmap {
  order: 2;
  box-sizing: border-box;
  position: relative;
  width: 28.75rem;
  overflow: hidden;
  aspect-ratio: 460/360;
}
.p-home-office__gmap iframe, .p-home-office__gmap object, .p-home-office__gmap embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.p-home-office__details {
  width: 31.25rem;
}
.p-home-office__logo {
  width: 23.75rem;
  margin: 0;
}
.p-home-office__address {
  margin: 1rem 0 0;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid #C7BFB0;
  line-height: 1.75;
}
.p-home-office__ul {
  margin: 1.25rem 0 0;
  padding-left: 1.5em;
  line-height: 1.75;
}
.p-home-office__ul > li::marker {
  color: #1A416C;
}
.p-home-office__ul > li + li {
  margin-top: 0.5rem;
}
.p-home-office__btn {
  border: none;
  display: inline-block;
  box-sizing: border-box;
  position: relative;
  border-radius: 0;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  display: block;
  padding: 0.875rem 3rem 0.8125rem 1.375rem;
  border: 0.125rem solid transparent;
  border-radius: 6.25rem;
  background: #1A416C;
  color: #fff;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: left;
  transition: all 0.1s ease;
  max-width: 15rem;
}
.p-home-office__btn::after {
  display: block;
  position: absolute;
  top: calc(50% - 0.5rem);
  right: 1.375rem;
  width: 1rem;
  height: 1rem;
  background: currentColor;
  content: "";
  -webkit-mask: url(../img/icon_arrow_right.svg) no-repeat center/contain;
          mask: url(../img/icon_arrow_right.svg) no-repeat center/contain;
}
.p-home-office__btn.-external::after {
  -webkit-mask-image: url(../img/icon_blank.svg);
          mask-image: url(../img/icon_blank.svg);
}
.p-home-office__btn:hover {
  border-color: #1A416C;
  background-color: #fff;
  color: #1A416C;
  opacity: 1;
}
@media (max-width: 767px) {
  .p-home-office {
    padding: 3.75rem 0 3.75rem;
    border-radius: 3.75rem 3.75rem 0 0;
  }
  .p-home-office::before {
    border-radius: 3.75rem 3.75rem 0 0;
    box-shadow: 0 0 10rem #F8F4EC;
  }
  .p-home-office__inner {
    padding-left: 1rem;
    padding-right: 1rem;
  }
  .p-home-office__wrap {
    flex-direction: column;
    margin-top: 2.5rem;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }
  .p-home-office__gmap {
    order: -1;
    width: 100%;
  }
  .p-home-office__details {
    width: auto;
    margin-top: 2rem;
  }
  .p-home-office__logo {
    width: 15.875rem;
  }
  .p-home-office__address {
    font-size: 0.875rem;
  }
  .p-home-office__ul {
    font-size: 0.875rem;
  }
  .p-home-office__ul > li + li {
    margin-top: 0.25rem;
  }
}

.p-home-books {
  max-width: 65rem;
  margin: 4.375rem auto 0;
  padding: 3.125rem;
  border-radius: 1.25rem;
  background: url(../../images/home/books_bg.png) no-repeat, url(../img/bg_pattern.png) repeat;
  background-position: right -3.625rem bottom -10.5rem, center;
  background-size: 42.6875rem auto, auto;
  background-blend-mode: multiply;
}
.p-home-books__ttl {
  position: relative;
  margin: 0;
  padding-left: 1.625rem;
  font-size: 0.9375rem;
  font-weight: 700;
}
.p-home-books__ttl::before {
  display: block;
  position: absolute;
  top: calc(50% - 0.5625rem);
  left: 0;
  width: 1.125rem;
  height: 1.125rem;
  background: currentColor;
  content: "";
  -webkit-mask: url(../../images/home/icon_book.svg) no-repeat center/contain;
          mask: url(../../images/home/icon_book.svg) no-repeat center/contain;
}
.p-home-books__wrap {
  display: flex;
  justify-content: space-between;
  margin: -1.5rem 0 0;
  padding: 0;
}
.p-home-books__img {
  flex: 0 0 auto;
  display: block;
  width: 10.3125rem;
}
.p-home-books__img img {
  display: block;
  width: 100%;
}
.p-home-books__body {
  display: block;
  padding-top: 1.5rem;
}
.p-home-books__name {
  margin: 1.25rem 0 0;
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0.04em;
}
.p-home-books__author {
  margin: 1rem 0 0;
  line-height: 1.5;
}
.p-home-books__btn {
  border: none;
  display: inline-block;
  box-sizing: border-box;
  position: relative;
  border-radius: 0;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  display: block;
  padding: 0.875rem 3rem 0.8125rem 1.375rem;
  border: 0.125rem solid transparent;
  border-radius: 6.25rem;
  background: #1A416C;
  color: #fff;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: left;
  transition: all 0.1s ease;
  max-width: 15rem;
  margin: 2rem 0 0;
}
.p-home-books__btn::after {
  display: block;
  position: absolute;
  top: calc(50% - 0.5rem);
  right: 1.375rem;
  width: 1rem;
  height: 1rem;
  background: currentColor;
  content: "";
  -webkit-mask: url(../img/icon_arrow_right.svg) no-repeat center/contain;
          mask: url(../img/icon_arrow_right.svg) no-repeat center/contain;
}
.p-home-books__btn.-external::after {
  -webkit-mask-image: url(../img/icon_blank.svg);
          mask-image: url(../img/icon_blank.svg);
}
.p-home-books__btn:hover {
  border-color: #1A416C;
  background-color: #fff;
  color: #1A416C;
  opacity: 1;
}
@media (max-width: 767px) {
  .p-home-books {
    margin-top: 3.125rem;
    padding: 2.5rem 1.5rem;
    background-position: right 0 bottom -6.6875rem, center;
    background-size: 27.375rem auto, auto;
  }
  .p-home-books__ttl {
    font-size: 0.875rem;
  }
  .p-home-books__wrap {
    flex-direction: column;
    margin-top: 1.5rem;
  }
  .p-home-books__img {
    order: -1;
    margin: 0 auto;
  }
  .p-home-books__body {
    display: block;
    padding-top: 1.25rem;
  }
  .p-home-books__name {
    margin-top: 0;
    font-size: 1.125rem;
  }
  .p-home-books__author {
    margin-top: 0.5rem;
    font-size: 0.875rem;
  }
  .p-home-books__btn {
    margin-left: auto;
    margin-right: auto;
  }
}