@charset "UTF-8";
/* ---------------------------------- Base ---------------------------------- */
/* color */
/* font-weight */
/* 余白 */
/* コンテンツ幅 */
/* 基本余白 */
/* タイトルサイズ */
img,
picture,
svg,
video {
  display: block;
  max-width: 100%;
  height: auto;
  object-fit: cover;
}

sup{
  font-size: 0.5em;
  top: -1em;
}

/* --------------------------------- Common --------------------------------- */
body {
  min-width: 1200px;
  color: #000000;
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: 0em;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
}

main {
  min-height: 70vh;
  overflow: hidden;
}

[class*=__wrapper-xl] {
  width: min(100%, 1920px);
  margin-inline: auto;
}

[class*=__wrapper-m] {
  width: min(100%, 1100px);
  margin-inline: auto;
}

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

a {
  transition: all 0.3s;
}

img,
picture,
svg,
video {
  display: block;
  max-width: 100%;
  height: auto;
  object-fit: cover;
}

.sp {
  display: none !important;
}

.pc {
  display: block;
}

.cmn-py {
  padding-block: 80px 40px;
}

.cmn-mb {
  margin-bottom: 40px;
}

.cmn-hl {
  background: linear-gradient(to bottom, transparent 60%, #e8e428 60%, #e8e428 100%, transparent 100%);
}

.cmn-hover:hover {
  opacity: 0.6;
}

.cmn-header {
  margin-bottom: 40px;
}
.cmn-header h3 {
  text-align: center;
  font-weight: 700;
  font-size: 32px;
  line-height: 46px;
  letter-spacing: 4%;
}
.cmn-header h3 span {
  background: linear-gradient(to bottom, transparent 0%, #e8e428 0%, #e8e428 100%, transparent 100%);
  padding-inline: 4px;
}

.cmn-header2 {
  letter-spacing: 4%;
  text-align: center;
}
.cmn-header2 h3 {
  font-size: 24px;
  font-weight: 700;
}
.cmn-header2 h3 em {
  font-size: 40px;
  color: #103e76;
  font-style: normal;
  margin-right: 1ch;
}

.cmn-header3 {
  margin-bottom: 24px;
  position: relative;
}
.cmn-header3::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  background-color: #1f294a;
  width: 5px;
  height: 100%;
  border-radius: 15px;
  margin-block: auto;
  transform: translateY(2px);
}
.cmn-header3 h4 {
  color: #1f294a;
  font-size: 24px;
  font-weight: 700;
  padding-inline: 15px;
}

.cmn-line {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-flow: row nowrap;
  gap: 16px;
}
.cmn-line::before, .cmn-line::after {
  content: "";
  flex-grow: 1;
  height: 5px;
  border-block: 1px solid;
}

.cmn-tel span {
  position: relative;
  white-space: nowrap;
  font-size: 25px;
  font-weight: 700;
  padding-left: 35px;
}
.cmn-tel span::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  margin-block: auto;
  width: 30px;
  height: 30px;
  border-radius: 0;
  background: no-repeat center/contain url("../img/icon_tel.png");
}

.cmn-mail {
  width: 206px;
  height: 65px;
  border-radius: 41px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #ff544b;
  filter: drop-shadow(0 4px 0 rgba(16, 62, 118, 0.25));
}
.cmn-mail:hover {
  background-color: #ff847e;
}
.cmn-mail span {
  color: #ffffff;
  font-size: 14px;
  font-weight: 700;
  padding-left: 20px;
  position: relative;
}
.cmn-mail span::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  margin-block: auto;
  width: 16px;
  height: 16px;
  border-radius: 0;
  background: no-repeat center/contain url("../img/icon_mail.png");
}

.cmn-textbox p {
  line-height: 150%;
}
.cmn-textbox p:not(:last-child) {
  margin-bottom: 16px;
}
.cmn-textbox p em {
  font-weight: 700;
  font-style: normal;
}
.cmn-textbox--left {
  text-align: left;
}
.cmn-textbox--center {
  text-align: center;
}
.cmn-textbox--right {
  text-align: right;
}
.cmn-textbox--justify {
  text-align: justify;
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
既存パーツ調整 パートナーのコード
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝*/
/* インナー */
.inner {
  width: 1100px;
  margin: 0 auto;
  padding: 96px 0;
}

/* =======================================
breadcrumb
 ======================================= */
.bc_bg {
  zoom: 80%;
  font-family: YuGothic, 'Yu Gothic', '游ゴシック体', YuGothicM, 'メイリオ', Meiryo, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', sans-serif, Helvetica, Arial;
  font-size: 15px;
  background-color: #f8f8f8;
}

.bc_bg > .ddf_cw {
  /* width: 1100px; */
  width: 1375px;
  width: calc(1100px / 0.8);
}

.bc_wrap {
  padding: 15px 0;
  line-height: 2;
  letter-spacing: -0.2px;
}

.bc_wrap a {
  color: rgb(10, 100, 190);
}

/* =======================================
CTA
 ======================================= */
.sec_cta > * {
  line-height: 1;
}

.sec_cta .title {
  text-align: center;
  font-size: var(--h5-fz);
  margin-bottom: var(--sp-5);
  color: var(--clr-sub01);
}

.sec_cta .title span {
  position: relative;
  width: fit-content;
  display: block;
  margin: 0 auto;
}

.sec_cta .title span::before {
  position: absolute;
  content: "";
  top: calc(50% - 11px);
  left: -42.5px;
  display: block;
  width: 32.5px;
  height: 22px;
  background: url("../img/icon_tr.png") no-repeat;
  background-size: contain;
}

.sec_cta .title span::after {
  position: absolute;
  content: "";
  top: calc(50% - 11px);
  right: -42.5px;
  display: block;
  width: 32.5px;
  height: 22px;
  background: url("../img/icon_tr.png") no-repeat;
  background-size: contain;
}

.sec_cta .title2 {
  width: fit-content;
  margin-inline: auto;
  color: #103e76;
  font-weight: 700;
  margin-bottom: 32px;
  font-size: 24px;
  line-height: 150%;
  letter-spacing: 2%;
  text-align: center;
}
.sec_cta .title2::before, .sec_cta .title2::after {
  content: "▼";
}

.mb-120 {
  margin-bottom: 120px;
}