@charset "utf-8";
/*
Theme Name:mrp-child
Template:mrp
Version: 1.0.0
*/
/*
DesignCode CSS: ver 0.01
*/
/*------------------------------------------------------
Theme Material
------------------------------------------------------*/
/*------@import------*/
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500;1,600;1,700&display=swap');
:root {
	/*------▼基本設定▼------*/
	--color-background: #FFF;
	--color-font: #333;
	--color-primary: #B10607;
	--color-primary-shade: #7c0405;
	--color-primary-tint: #c85151;
	--color-secondary: #223E94;
	--color-secondary-tint: #6478b4;
	--color-table-border: #DDD;
	--body-font-size: min(calc(1.6rem + (1vw - 1.92rem) * 0.1294), 1.6rem);
	/* 1.6-1.4rem (1920-375) */
	--body-font-family: 'Noto Sans JP', sans-serif;
	--content-max-width: 1240px;
	/*------▼ヘッダー設定▼------*/
	--header-background: linear-gradient(90deg, #030B21 0%, #3E496E 100%);
	--header-color-font: #fff;
	--header-color-primary: #B10607;
	--header-color-primary-shade: #7c0405;
	--header-color-primary-tint: #c85151;
	/*------▼フッター設定▼------*/
	--footer-background: #fff;
	--footer-color-font: #333;
	--footer-color-primary: #333;
	/*------▼フォント設定▼------*/
	--font-family01: 'Noto Sans JP', sans-serif;
  --font-family02: 'Oswald', 'Noto Sans JP', sans-serif;
  --font-family03: YuMincho, serif;
  --font-family04: "Cormorant Garamond", serif;
}

/*--------------------------------------------------
	共通
--------------------------------------------------*/
.post, #foot-contact_pt01 {
  .ttl {
      &.ttl--primary {
          display: flex;
          flex-direction: column;
          margin-bottom: var(--rem30);
          position: relative;
          &::after {
            display: none;
          }
          .ttl--primary__en {
            color: #223E94;
            font-family: var(--font-family04);
            font-size: var(--rem24);
            font-weight: 700;
            line-height: 1.4;
            margin-bottom: var(--rem20);
            position: relative;
            &.color-common {
            color: var(--color-font);
            }
            &.color-white {
              color: #fff;
            }
            &.color-green {
              color: #387C45;
            }
            &.color-blue {
              color: #68ADFF;
            }
            &.color-pink {
              color: #EE7E98;
            }
            &.color-purple {
              color: #8E4593;
            }
          }
          .ttl--primary__ja {
            font-family: var(--font-family03);
            font-size: min(calc(6.4rem + (1vw - 1.92rem) * 1.6828), 6.4rem);
            font-weight: 500;
            line-height: 1.4;
            letter-spacing: .2em;
            @media screen and (max-width: 768px) {
              font-size: min(calc(5rem + (1vw - 1.92rem) * 1.6181), 5rem);
            }
            &.color-common {
              color: var(--color-font);
            }
            &.color-white {
              color: #fff;
            }
            &.color-green {
              color: #387C45;
            }
            &.color-blue {
              color: #68ADFF;
            }
            &.color-pink {
              color: #EE7E98;
            }
            &.color-purple {
              color: #8E4593;
            }
          }
          &:is(.ttl--primary-mod01) {
            .ttl--primary__en {
              color: rgba(255, 255, 255, .2);
              font-family: var(--font-family04);
              font-size: calc((110 / 1920) * 100vw);
              font-weight: 700;
              line-height: 1;
              position: relative;
              top: 0.5em;
            }
          }
      }
  &:is(.txt_c) {
    text-align: center;
    .ttl--primary__en {
      justify-content: center;
              &::after {
                  margin: 1.1em auto 0;
              }
    }
    &::after {
      margin: 1.1em auto 0;
    }
  }
  &:is(.color-white) {
    .ttl--primary__en, .ttl--primary__ja {
      color: #fff;
    }
  }
  }
  h2 {
  text-align: unset;
      letter-spacing: unset;
  }
  p {
      line-height:2.2;
  }
  .color-white {
      color: #fff;
  }
  .color-yellow {
      color: #EFF316;
  }
  .color-gradation {
    background: linear-gradient(263deg, #27B7EC 9%, #073190 97%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  }
  .m-auto {
      margin-left: auto !important;
      margin-right: auto !important;
  }
}

/**/
.bg_wide { position: relative; }
.bg_wide::before,
.bg_wide.bg_after::after {
position: absolute;
top: 0;
left: 0;
display: block;
width: 100vw;
height: 100%;
margin-left: calc(((100vw - 100%) / 2) * -1);
margin-right: calc(((100vw - 100%) / 2) * -1);
content: "";
z-index: -1;
}
.box_w2_sp {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
.box_w2_sp.rev { flex-direction: row-reverse; }
.box_w2_sp.vtop { align-items: flex-start; }
.box_w2_sp.vcen { align-items: center; }
.box_w2_sp.vbtm { align-items: flex-end; }
.box_pad { padding: 20px; box-sizing: border-box; }
.box_w2 .column2_50:not(.cen) { text-align: left; }
@media print, screen and (min-width: 641px){ /* PC用 */
.bg_fix::before { background-attachment: fixed !important; }
.box_w2 {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.box_w2.rev { flex-direction: row-reverse; }
.box_w2.vtop { align-items: flex-start; }
.box_w2.vcen { align-items: center; }
.box_w2.vbtm { align-items: flex-end; }
.box_pad { padding: 30px; }
.box_w2 .column3_33 { width: 32%; }
.box_w2 .column2_50 { width: 48.5%; }
.box_w2 .column2_60 { width: 57%; }
.box_w2 .column2_70 { width: 67%; }
.box_w2 .column2_80 { width: 77%; }
}
@media print, screen and (min-width:769px){ /* PCのみ */
.box_pad { padding: 50px; }
}
/**/
.box_w2 .column3_33 img, .box_w2 .column2_30 img,
.box_w2 .column2_40 img, .box_w2 .column2_50 img {
max-width: 100%;
}
/**/
.w100 {
width: 100vw;
margin-left: calc(((100vw - 100%) / 2) * -1) !important;
margin-right: calc(((100vw - 100%) / 2) * -1) !important;
}
.w600, .w800, .w900 {
width: 600px;
max-width: 100%;
margin: auto;
}
.w800 { width: 800px; }
.w900 { width: 900px; }
.max-w {
margin-left: auto;
margin-right: auto;
&.max-w--960 {
  max-width: 960px;
  
}
&.max-w--1000 {
  max-width: 1000px;
}
}

#content:has(.fw_contents), body:not(.home) #content:has(.fw_contents).wide {
  padding: 0;
}

.fw_contents {
    margin-top: 0;
    margin-bottom: 0;
}
#content:has(.fw_contents), body:not(.home) #content:has(.fw_contents).wide {
    padding: 0;
}

/* アンカーリンク 遷移後の表示位置調整 */
.anchorLink-view {
  padding-top: 120px;
  margin-top: -120px;
}


/*--カラムリスト--------------------------------------------*/

/*---------coln02-----------*/
  
.post .col2_list {
	position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
	flex-wrap: wrap;
}
.post .col2_list > li {
    width: 49%;
	margin-bottom: 2%;
}
@media print, screen and (max-width: 414px) {
	.post .col2_list > li {
		width: 100%;
	}
	.post .col2_list > li:last-child {
		margin-bottom: 0;
	}
}

/*---------col03-----------*/
  
.post .col3_list {
	position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
	flex-wrap: wrap;
}
.post .col3_list > li {
  display: flex;
  flex-direction: column;
  width: 32%;
	margin-bottom: 2%;
}
.post .col3_list::before {
    content: "";
    display: block;
    width: 32%;
    height: 0;
    order: 1;
}
.post .col3_list:after {
    content: "";
    display: block;
    width: 32%;
    height: 0;
}
@media print, screen and (max-width: 768px) {
	.post .col3_list > li {
		width: 49%;
	}
	.post .col3_list::before, .post .col3_list:after {
		content: none;
	}
}
@media print, screen and (max-width: 414px) {
	.post .col3_list > li {
		width: 100%;
	}
	.post .col3_list > li:last-child {
		margin-bottom: 0;
	}
}

/*---------col4-----------*/
  
.post .col4_list {
	position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
	flex-wrap: wrap;
}
.post .col4_list > li {
    width: 24%;
	margin-bottom: 1.5%
}
.post .col4_list::before {
    content: "";
    display: block;
    width: 24%;
    height: 0;
    order: 1;
}
.post .col4_list:after {
    content: "";
    display: block;
    width: 24%;
    height: 0;
}
@media print, screen and (max-width: 1240px) {
	.post .col4_list > li, .post .col4_list::before, .post .col4_list:after {
		width: 32%;
		margin-bottom: 2%;
	}
}
@media print, screen and (max-width: 768px) {
	.post .col4_list > li {
		width: 49%;
	}
	.post .col4_list::before, .post .col4_list:after {
		content: none;
	}
}
@media print, screen and (max-width: 414px) {
	.post .col4_list > li {
		width: 100%;
	}
	.post .col4_list > li:last-child {
		margin-bottom: 0;
	}
}

/*-----------------------------
column_01
------------------------------*/
.toptxtarea {
	max-width: 960px;
	width: 94%;
	margin: 0 auto;
	position: relative;
	z-index: 1;
}
.column01 {
	position: relative;
	margin: var(--px60) 0 0;
}
.column01_wrap {
	position: relative;
	max-width: 1600px;
	width: 94%;
    margin: 0 auto;
	z-index: 1;
}
.column01 .txtarea {
    background: transparent;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--px80) var(--px40);
    margin: 0;
}
.column01 .txtarea .txtinner {
    max-width: 540px;
}
.column01 .imgarea {
    overflow: hidden;
    line-height: 0;
    margin: 0;
}
.column01 .imgarea img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
	
/*---------txtstyle-----------*/
	
.post .txtstyle02, .txtstyle02 {
	font-family: var(--font-family02);
	font-size: var(--rem36);
	font-weight: 600;
	text-align: left;
	margin: var(--rem36) auto;
	background: transparent;
    color: #111;
    line-height: 1.4;
	padding: 0;
}
.post .txtstyle02:before, .post .txtstyle02:after, .txtstyle02:before, .txtstyle02:after {
	content: none;
}
.post .column01 .txtstyle02, .column01 .txtstyle02 {
	font-size: var(--rem20);
	margin: var(--rem20) 0;
}
.post .txtstyle04, .txtstyle04 {
	font-family: var(--font-family02);
	font-size: var(--rem36);
	font-weight: 600;
	text-align: left;
	margin: var(--rem36) auto;
	background: transparent;
	border: none;
    color: #111;
    line-height: 1.4;
	padding: 0;
}
.post .txtstyle04:before, .txtstyle04:before {
	content: none;
}
.post .column01 .txtstyle04, .column01 .txtstyle04 {
	font-size: var(--rem36);
}
.post .column01 .txtstyle04:after, .column01 .txtstyle04:after {
    content: '';
    position: relative;
    visibility: visible;
    display: block;
    width: var(--px80);
    height: 3px;
    background: #111;
    margin: var(--rem30) 0 0 0.5rem;
}

/*-----------------------------
.cardstyle
------------------------------*/
  
/*---------style02-------------*/
  
.card01_list.cardstyle02 > li .txtarea {
  flex-grow: 1;
  background: #fff;
  padding: 20px 20px 30px 20px;
/* 	box-shadow: 0 0 30px 0 rgba(0, 0, 0, .2); */
}
  
/*---------style03-------------*/
  
.card01_list.cardstyle03 > li {
    padding: 16px;
    background: #fff;
    box-shadow: 0 0 30px 0 rgba(0, 0, 0, .2);
}
  
/*---------style04-------------*/
  
.card01_list.cardstyle04 > li {
    padding: 16px;
    background: transparent;
    border: solid 1px;
}

/*---------style05-------------*/

.cardstyle05 > li {
    padding-bottom: 30px;
}
.card01_list.cardstyle05 > li .imgarea {
    position: relative;
}
.card01_list.cardstyle05 > li .txtarea {
    position: relative;
    background: #fff;
    padding: 20px 20px 30px 20px;
    max-width: 90%;
    margin: -30px auto;
}

/*-----------------------------
以下アウトラインデザイン
------------------------------*/
.card01_wrap {
  position: relative;
  margin: var(--px60) 0 0;
}
.card01_inner {
  max-width: 1600px;
  width: 94%;
  margin: 0 auto;
}
.cardstyle01 > li {
  position: relative;
  background: transparent;
}
.card01_list .imgarea {
  width: 100%;
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  line-height: 0;
}
.card01_list .imgarea img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.card01_list .txtarea {
  padding: 20px 0 0 0;
  line-height: 1.6;
  text-align: left;
  background: transparent;
}
  
/*---------txtstyle02 -----------*/
  
.post .txtstyle02, .txtstyle02 {
  font-family: var(--font-family02);
  font-size: var(--rem36);
  font-weight: 600;
  text-align: left;
  margin: var(--rem36) auto;
  background: transparent;
    color: #111;
    line-height: 1.4;
  padding: 0;
}
.post .txtstyle02:before, .post .txtstyle02:after, .txtstyle02:before, .txtstyle02:after {
  content: none;
}
.post .card01_list .txtstyle02, .card01_list .txtstyle02 {
  font-size: var(--rem20);
  margin: 0 0 2rem;
	text-align: center;
}

/*-----------------------------
    button
------------------------------*/
.linkBtn.linkBtn--mod01, .post .linkBtn.linkBtn--mod01, a.linkBtn.linkBtn--mod01 {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: 240px;
  font-family: var(--font-family04);
  font-size: var(--rem20);
  color: var(--color-font);
  line-height: 1.4;
  letter-spacing: .2em;
  text-align: left;
  background: transparent;
  font-weight: 700;
  padding: min(calc(10px + (1vw - 19.2px) * 0.5178), 10px) 10px 0;
  margin: var(--px40) auto 0;
  border: none;
  border-radius: 0;
  transition: all .25s ease-out;
  &::before {
    display: block;
    content: "";
    width: 100%;
    height: 2px;
    background: linear-gradient(90deg, rgba(254, 246, 241, 0) 0%, #E75C37 50%, #B00406 100%);
    transform: scale(0);
    transform-origin: bottom right;
    position: absolute;
    left: 0;
    bottom: -11px;
    transition: transform .25s ease-out;
  }
  &::after {
    display: none;
  }
  &:is(.linkColor-blue) {
    color: #fff;
    .fa-solid.fa-chevron-right {
      color: var(--color-secondary);
      background: #fff;
      border-color: #fff;
    }
    &:hover {
      .fa-solid.fa-chevron-right {
        color: #fff;
        background: var(--color-secondary);
        border-color: var(--color-secondary);
      }
    }
  }
  .fa-solid.fa-chevron-right {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: var(--rem12);
    letter-spacing: 0;
    width: min(calc(5rem + (1vw - 1.92rem) * 1.6181), 5rem);
    height: min(calc(5rem + (1vw - 1.92rem) * 1.6181), 5rem);
    background: var(--color-primary);
    border: 1px solid var(--color-primary);
    border-radius: 50vh;
    transition: all .25s ease-out;
  }
}
.linkBtn.linkBtn--mod01:hover, .post .linkBtn.linkBtn--mod01:hover, a.linkBtn.linkBtn--mod01:hover {
  background: transparent;
  &::before {
    transform: scale(1);
    transform-origin: bottom left;
  }
  .fa-solid.fa-chevron-right {
    color: var(--color-primary);
    background: #fff;
  }
}
.linkBtn.linkBtn--mod01 .arw, .post .linkBtn.linkBtn--mod01 .arw, a.linkBtn.linkBtn--mod01 .arw {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: absolute;
  width: var(--px50);
  height: var(--px50);
  background: var(--color-primary);
  border: 1px solid;
  border-color: var(--color-primary);
  border-radius: 50%;
  margin-right: 10px;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-transition: .4s;
  transition: .4s;
}
.linkBtn.linkBtn--mod01 .arw::after, .post .linkBtn.linkBtn--mod01 .arw::after, a.linkBtn.linkBtn--mod01 .arw::after {
  content: '';
  position: absolute;
  width: min(calc(8px + (1vw - 19.2px) * 0.2589), 8px);
  height: min(calc(8px + (1vw - 19.2px) * 0.2589), 8px);
  border-style: solid;
  border-width: 1px 1px 0 0;
  border-color: #fff;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-70%, -50%) rotate(45deg);
  transform: translate(-70%, -50%) rotate(45deg);
  -webkit-transition: .4s;
  transition: .4s;
}
.linkBtn.linkBtn--mod01:hover .arw, .post .linkBtn.linkBtn--mod01:hover .arw, a.linkBtn.linkBtn--mod01:hover .arw  {
  background: #fff;
}
.linkBtn.linkBtn--mod01:hover .arw::after, .post .linkBtn.linkBtn--mod01:hover .arw::after, a.linkBtn.linkBtn--mod01:hover .arw::after {
  border-color: var(--color-primary);
}

/*--------------------------------------------------
	ヘッダー
--------------------------------------------------*/
@media print, screen and (min-width: 1024px) {
  #header {
      height: 100px;
  }
  #header a.head_btn {
      color: #fff;
      padding-left: var(--rem28);
      padding-right: var(--rem28);
  }
  #header a.head_btn.tel_btn {
    font-family: var(--font-family03);
    font-weight: 500;
    background: transparent;
    &:hover {
      background: var(--color-primary);
    }
    .note {
      font-size: var(--rem14);
    }
  }
  #header a.head_btn.tel_btn::before {
      display: none;
  }
  #header a.head_btn .tel_btn__num::before {
      content: '\f095';
      position: relative;
      top: 2px;
      display: block;
      font-family: 'FontAwesome';
      font-size: .75em;
      font-weight: 400;
      line-height: 1;
      margin-bottom: .1em;
  }
  #header a.head_btn .tel_btn__num {
      display: flex;
      align-items: center;
      column-gap: min(calc(0.8rem + (1vw - 1.92rem) * 0.1294), .8rem);
      font-size: var(--rem24);
      font-weight: 700;
      margin-bottom: 3px;
  }
  #header a.head_btn.mail_btn {
      font-size: var(--rem16);
      flex-direction: row;
      align-items: center;
      padding-left: var(--rem24);
      padding-right: var(--rem24);
      &:hover {
        color: var(--color-primary);
        background: #fff;
      }
  }
  #header a.head_btn.mail_btn::before {
      display: none;
  }
  nav#mainNav ul li a {
    font-family: var(--font-family03);
    font-size: var(--rem20);
    font-weight: 500;
    padding: var(--px20) var(--px50);
}
  nav#mainNav ul li a b, nav#mainNav ul li a span {
      font-weight: 700;
  }
  nav#mainNav ul li.current-menu-item a b, nav#mainNav ul li.current-menu-parent a b {
      color: var(--header-color-font);
  }
  nav#mainNav ul li.current-menu-item a:hover b, nav#mainNav ul li.current-menu-parent a:hover b {
      color: #fff;
  }
  nav#mainNav ul li a:active, nav#mainNav ul li a:hover, nav#mainNav ul li.current-menu-ancestor a, nav#mainNav ul li.current-menu-item a, nav#mainNav ul li.current-menu-parent a {
    background: transparent;
  }
  nav#mainNav ul li a:active, nav#mainNav ul li a:hover {
    background: var(--color-primary);
  }
  nav#mainNav ul li a:hover b {
    color: #fff;
  }
  nav#mainNav ul li ul.sub-menu li a {
    color: var(--color-font);
    background: #fff;
  }
  nav#mainNav ul li ul.sub-menu li a:hover {
    color: #fff;
    background: var(--color-primary);
  }
  body:not(.home) {
    nav#mainNav ul li.current-menu-item a, nav#mainNav ul li.current-menu-parent a {
      color: var(--color-font);
      background: transparent;
      &:hover {
        background: var(--color-primary);
      }
    }
    nav#mainNav ul li.current-menu-item a b, nav#mainNav ul li.current-menu-parent a b {
        color: #fff;
    }
  }
  nav#mainNav ul li:hover ul.sub-menu {
    background: #fff;
  }
  .sticky-header #header > .inner {
    height: auto;
    background: linear-gradient(90deg, #030B21 0%, #3E496E 100%);
    box-shadow: 0 0 6px rgba(0, 0, 0, .2);
  }
}

/*------ヘッダー　レスポンシブ
--------------------------------------------*/
@media screen and (max-width: 1710px) {
	nav#mainNav ul li a b, nav#mainNav ul li a span {
		font-size: 1.6rem;
	}

	#header .head_btn.mail_btn {
		font-size: 1.6rem;
	}

	#header a.head_btn {
		padding: min(calc(10px + (1vw - 19.2px) * 0.2232), 10px) 15px;
	}

	nav#mainNav ul li a {
		padding: min(calc(15px + (1vw - 19.2px) * 0.5580), 15px) 15px;
	}
}

@media screen and (max-width: 1400px) {
	nav#mainNav ul, #header .header__nav-contact {
		flex-shrink: 0;
	}

	nav#mainNav ul li a b, nav#mainNav ul li a span {
		font-size: 1.4rem;
	}

	#header .head_btn.mail_btn {
		font-size: 1.4rem;
	}

	#header a.head_btn {
		padding: min(calc(10px + (1vw - 19.2px) * 0.2232), 10px) 10px;
	}

	#header a.head_btn.sns_btn {
		padding: min(calc(10px + (1vw - 19.2px) * 0.2232), 10px) 10px;
	}

	nav#mainNav ul li a {
		padding: min(calc(15px + (1vw - 19.2px) * 0.5580), 15px) 10px;
	}
}

@media print, screen and (max-width: 1240px) {
	#header a.headBtn span {
		display: none;
	}

	#header a.headBtn::before {
		margin-right: 0;
	}
}

@media print, screen and (max-width: 1023px) {
	#header-upper .header__socialicon, #header .sticky-logo, #header ul.header__contact {
		display: none;
	}

	#header h1, #header .description, #header-upper h1, #header-upper .description {
		display: block;
		float: none;
		text-align: center;
		padding: 20px 0 10px;
	}
}

@media screen and (max-width: 1023px) {
	body.mobile #header .logo .mark {
		justify-content: center;
	}

	nav#mainNav ul li ul.sub-menu li a, nav#mainNav ul li ul.sub-menu li a:hover, nav#mainNav ul li ul.sub-menu li.current-menu-item a, nav#mainNav ul li.current-menu-item ul.sub-menu li a {
		color: #4d4d4d;
		font-size: 1.4rem;
	}
    nav#mainNav ul li a b, nav#mainNav ul li a span {
		font-size: var(--rem16);
	}
	nav#mainNav ul li a {
    color: #4d4d4d;
		padding: min(calc(15px + (1vw - 19.2px) * 0.5580), 15px) 10px;
	}
	nav#mainNav ul li a, nav#mainNav ul li.current-menu-item li a {
		padding: 15px 10px;
	}
}

@media screen and (max-width: 1023px) {
	#thumbImg, header#h1Header {
		width: 100%;
		aspect-ratio: 1920 / 500;
		height: auto;
	}
}

/*--------------------------------------------------
	フッター
--------------------------------------------------*/
#footer {
  padding: var(--rem80) 0 var(--rem60);
  background: var(--footer-background);
}
#footer .footnav ul > li::before {
	content: "\f054";
	position: absolute;
    font-family: 'FontAwesome';
    font-size: var(--rem12);
	height: 100%;
	background: transparent;
	top: 2px;
}
@media screen and (max-width: 768px) {
    #footer .footnav ul > li::before {
        top: 0px;
        left: -3px;
    }
}
#footer .footnav ul > li::after {
	display: none;
}

#footer .footnav ul > li:first-child {
    padding-right: var(--px30);
}

#footer .footnav ul > li:last-child {
    padding-right: 0;
}
#footer .footnav ul > li:last-child::after {
    display: none;
}
#copyright {
  margin: var(--px50) auto 0;
}

/*--------------------------------------------------
	CTA
--------------------------------------------------*/
.home {
	#foot-contact_pt01.cta {
		display: none;
	}
}
#foot-contact_pt01 {
	clear: both;
	position: relative;
	backgrou.home {
		#foot-contact_pt01.cta {
			display: none;
		}
	}
}
#foot-contact_pt01 {
	clear: both;
	position: relative;
	background: url(/wp-content/uploads/cta_bg_01.png.webp) no-repeat center / cover;
	/*margin-top: min(calc(180px + (1vw - 19.2px) * 3.8835), 180px);*/
	margin-left: calc(((100vw - 100%) / 2) * -1);
	/*margin-bottom: max(calc(-180px + (1vw - 19.2px) * -3.8835), -180px);*/
	margin-right: calc(((100vw - 100%) / 2) * -1);
	padding: var(--rem120) calc((100vw - 100%) / 2);
}
#foot-contact_pt01::before, #foot-contact_pt01::after {
	content: '';
	position: absolute;
	width: 100%;
	height: 70%;
	top: 0;
	left: 0;
}
#foot-contact_pt01::after {
    display: none;
	/* background: url(/wp-content/uploads/bg_contact.jpg) no-repeat center / cover; */
}
#foot-contact_pt01.front_contact {
	background: none;
}
#foot-contact_pt01 .contactTtl {
	position: relative;
	color: #111;
	font-size: min(calc(2rem + (1vw - 19.2px) * 0.3883), 2rem);
	font-weight: 500;
	letter-spacing: .1rem;
	line-height: 1.6;
	text-align: center;
	margin-bottom: var(--rem48);
	z-index: 20;
}
#foot-contact_pt01 .contactTtl .en_ttl {
	display: block;
	font-size: min(calc(5.2rem + (1vw - 19.2px) * 1.5534), 5.2rem);
	font-family: var(--body-font-family-en);
	font-weight: 500;
	line-height: 1.2;
}
#foot-contact_pt01 .wrapper_content {
    width: 100%;
	padding: 0;
	@media screen and (max-width: 768px) {
		width: 94%;
	}
}
#foot-contact_pt01 .f-contact-read {
	position: relative;
	color: var(--color-font);
	line-height: 2;
    font-size: var(--rem20);
	font-weight: 500;
	text-align: center;
	letter-spacing: .1rem;
	z-index: 10;
	margin-bottom: var(--rem30);
}
#foot-contact_pt01 .f-contact-read .emTxt {
	font-size: calc(2.5rem + (1vw - 19.2px) * 0.4531);
	font-weight: 800;
	margin-bottom: 1em;
}
#foot-contact_pt01 a.f-contact_btn {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	color: #FFF;
	background: var(--color-primary);
	font-size: min(calc(1.6rem + (1vw - 19.2px) * 0.1294), 1.6rem);
	font-weight: 500;
	text-align: center;
	line-height: 1.6;
	padding: min(calc(20px + (1vw - 19.2px) * 0.5178), 20px) min(calc(30px + (1vw - 19.2px) * 0.9709), 30px);
	border: 1px solid var(--color-primary);
	transition: .3s;
}
#foot-contact_pt01 a.f-contact_btn:hover {
	color: var(--color-primary);
	background: #FFF;
}
#foot-contact_pt01 a.f-contact_btn::after {
	content: none;
}
#foot-contact_pt01 a.f-contact_btn .ico::before {
	display: inline-block;
	font-size: min(calc(3rem + (1vw - 19.2px) * 0.5825), 3rem);
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	margin-right: .4em;
}
#foot-contact_pt01 a.f-contact_btn.telBtn .ico {
	display: block;
	font-size: min(calc(3.2rem + (1vw - 19.2px) * 0.4531), 3.2rem);
}
#foot-contact_pt01 a.f-contact_btn .ico {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	font-size: min(calc(2.4rem + (1vw - 19.2px) * 0.5178), 2.4rem);
    line-height: 1;
}
#foot-contact_pt01 a.f-contact_btn.telBtn .ico::before {
	content: '\f095';
}
#foot-contact_pt01 a.f-contact_btn.lineBtn .ico::before {
	content: '\f3c0';
	font-family: 'Font Awesome 6 Brands';
	font-weight: 400;
}
#foot-contact_pt01 a.f-contact_btn.mailBtn .ico::before {
    position: relative;
    top: 2px;
	content: '\f0e0';
}
#foot-contact_pt01 a.f-contact_btn .note {
	font-size: var(--rem18);
	font-weight: 500;
}
#foot-contact_pt01 a.f-contact_btn .note > b {
	font-weight: 500;
}
#foot-contact_pt01 a.f-contact_btn .note > b::after {
	content: '：';
}
#foot-contact_pt01 ul.contactbtn_list {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-direction: row;
	flex-direction: row;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	justify-content: center;
	z-index: 10;
}
#foot-contact_pt01 ul.contactbtn_list > li {
	width: 100%;
}
#foot-contact_pt01 ul.contactbtn_list > li a.f-contact_btn {
	width: 100%;
	max-width: none;
	min-width: inherit;
	flex-grow: 1;
	padding: var(--px20) var(--px50) var(--px18) ;
}
#foot-contact_pt01 ul.contactbtn_list:first-child {
	margin-top: 0;
}
#foot-contact_pt01 ul.contactbtn_list:last-child {
	margin-bottom: 0;
}
/*レスポンシブ対応*/
@media print, screen and (min-width: 641px) {
	#foot-contact_pt01 ul.contactbtn_list > li {
		width: calc((100% - var(--px20)) / 2);
        max-width: 480px;
		display: flex;
        flex-direction: column;
        align-items: center;
		justify-content: center;	
	}
}
/* CTA調整用 */
#foot-contact_pt01 .foot-contact_ttl.txt_c {
  text-align: center;
}
#foot-contact_pt01 .foot-contact_ttl.ttl.ttl--primary {
  &::after {
    display: block;
    content: "";
    width: 2.2em;
    height: 3px;
    background: var(--color-primary);
    margin: 10px auto 0;
  }
}
#foot-contact_pt01 .foot-contact_read {
  color: #fff;
	text-align: center;
}
#foot-contact_pt01 .contactbtn_tel a.f-contact_btn.telBtn {
	color: #fff;
	background: transparent;
	border: 1px solid #fff;
	transition: all .3s;
    &:hover {
        background: var(--color-primary);
        border: 1px solid var(--color-primary);
        .ico::before {
          color: #fff;
        }
    }
}
#foot-contact_pt01::before, #foot-contact_pt01::after {
    display: none;
}
#foot-contact_pt01 .contactbtn_mail a.f-contact_btn.mailBtn {
    color: #fff;
	  background: transparent;
    border: 1px solid #fff;
	  transition: all .3s;
    .ico::before {
        color: var(--color-primary);
        transition: all .3s;
    }
}
#foot-contact_pt01 .contactTtl {
	color: var(--color-font);
    font-size: min(calc(4.5rem + (1vw - 1.92rem) * 1.3592), 4.5rem);
    font-weight: 700;
    line-height: 1.4;
    letter-spacing: .05em;
    position: relative;
    &::after {
        display: block;
        content: "";
        width: 1.8em;
        height: 3px;
        background: #FFED4C;
        margin-top: var(--rem16);
        margin-left: auto;
        margin-right: auto;
    }
}
#foot-contact_pt01 .contactbtn_mail {
	font-weight: 700;
}
#foot-contact_pt01 .contactbtn_tel .telbtn-ttl {
	font-size: var(--rem20);
    font-weight: 500;
}
#foot-contact_pt01 .contactbtn_tel a.f-contact_btn .note {
	font-size: var(--rem16);
    font-weight: 500
}
#foot-contact_pt01 .contactbtn_mail .mailbtn-ttl {
	font-size: var(--rem20);
	margin-bottom: 5px;
}
#foot-contact_pt01 .contactbtn_mail .note {
	font-size: min(calc(2.2rem + (1vw - 1.92rem) * 0.5178), 2.2rem);
	margin-top: 5px;
}
#foot-contact_pt01 .contactbtn_mail a.f-contact_btn.mailBtn:hover {
	color: #fff;
	background: var(--color-primary);
	border: 1px solid var(--color-primary);
    .ico {
        color: #fff;
        &::before {
            color: #fff;
        }
    }
}
#foot-contact_pt01 a.f-contact_btn.telBtn .ico {
    font-family: var(--font-family05);
    font-size: var(--rem36);
    line-height: 1.2;
}
#foot-contact_pt01 a.f-contact_btn.telBtn .ico::before {
    content: '\f095';
    position: relative;
    top: -3px;
    font-size: var(--rem28);
}
@media print, screen and (max-width: 768px)  {
	#foot-contact_pt01 ul.contactbtn_list:last-child {
		gap: var(--rem24);
	}
	#foot-contact_pt01 .contactbtn_mail {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
	}
}
#foot-contact_pt01 .foot-contact-bg {
    max-width: 1600px;
    width: 100%;
    background: transparent;
    border: 1px solid #fff;
    padding: var(--rem120) var(--rem40);
    margin: 0 auto;
    @media screen and (max-width: 768px) {
        padding: min(calc(90px + (1vw - 19.2px) * 1.9417), 90px) 10px;
    }
}
#foot-contact_pt01 a.f-contact_btn.telBtn .ico::before {
  color: var(--color-primary);
  content: '\f3cd';
  position: relative;
  top: 0;
  font-size: min(calc(3.2rem + (1vw - 1.92rem) * 0.3883), 3.2rem);
  transition: all .3s;
}

/*--------------------------------------------------
	TOPページ
--------------------------------------------------*/
.home, #editor-style {
	#wrapper {
		max-width: 1600px;
        width: 90%;
	}
  .page_footer-top {
    display: none;
  }
  .front_contents {
    padding-bottom: 0;
    .column01 {
      margin-top: 0;
      margin-bottom: min(calc(20rem + (1vw - 1.92rem) * 6.4725), 20rem);
      .column01_wrap {
        align-items: flex-end;
        width: 100%;
        .txtarea {
          justify-content: flex-start;
          padding: 0;
          .txtinner {
            max-width: 960px;
          }
        }
      }
    }
    img {
      width: 100%;
    }
  }
  .column01 .linkBtn.linkBtn--mod01 {
    margin-left: auto;
    margin-right: 0;
    @media screen and (max-width: 768px) {
      width: fit-content;
      gap: var(--px24);
    }
  }
}
/* CONTENT01 */
.top_concept {
  margin-bottom: 0;
}
/* CONTENT02 */
.top_service {
  .front_contents.sec02 {
    &.bg_wide::before {
      background: linear-gradient(90deg, #030B21 0%, #3E496E 100%);
    }
    .txtarea {
      p {
        line-height: 2.8;
      }
    }
  }
  .serviceList {
    display: flex;
    flex-wrap: wrap;
    & > li {
      width: calc(100% / 3);
      @media screen and (max-width: 640px) {
        width: 50%;
      }
      &:nth-child(1) {
        a::after {
          background: url(/wp-content/uploads/top_service_01.png.webp) no-repeat center / cover;
        }
      }
      &:nth-child(2) {
        a::after {
          background: url(/wp-content/uploads/top_service_02.png.webp) no-repeat center / cover;
        }
      }
      &:nth-child(3) {
        a::after {
          background: url(/wp-content/uploads/top_service_03.png.webp) no-repeat center / cover;
        }
      }
      &:nth-child(4) {
        a::after {
          background: url(/wp-content/uploads/top_service_04.png.webp) no-repeat center / cover;
        }
      }
      &:nth-child(5) {
        a::after {
          background: url(/wp-content/uploads/top_service_05.png.webp) no-repeat center / cover;
        }
      }
      &:nth-child(6) {
        a::after {
          background: url(/wp-content/uploads/top_service_06.png.webp) no-repeat center / cover;
        }
      }
      a {
        display: flex;
        align-items: flex-end;
        width: 100%;
        aspect-ratio: 640 / 752;
        padding: min(calc(5rem + (1vw - 1.92rem) * 1.6181), 5rem);
        position: relative;
        overflow: hidden;
        @media screen and (max-width: 768px) {
          padding: 10px 10px 20px;
        }
        &::after {
          display: block;
          content: "";
          width: 100%;
          height: 100%;
          position: absolute;
          top: 0;
          left: 0;
          z-index: -1;
          transition: all .25s ease-out;
        }
        &:hover {
          &::after {
            transform: scale(1.1);
          }
          .fa-solid.fa-chevron-right {
            color: #fff;
            background: var(--color-primary);
            border-color: var(--color-primary)
          }
        }
        & > span {
          display: flex;
          flex-direction: column;
          .en {
            color: rgba(255, 255, 255, .2);
            font-family: var(--font-family04);
            font-size: calc((110 / 1920) * 100vw);
            font-weight: 700;
            line-height: 1;
            position: relative;
            top: 0.25em;
            @media screen and (max-width: 768px) {
              font-size: var(--rem48);
            }
          }
          .ja {
            color: #fff;
            font-family: var(--font-family03);
            font-size: min(calc((50 / 1920) * 100vw), 5rem);
            font-weight: 700;
            line-height: 1;
            letter-spacing: .2em;
			font-feature-settings: "palt";
            @media screen and (max-width: 1080px) {
              font-size: var(--rem30);
            }
            @media screen and (max-width: 768px) {
              font-size: var(--rem28);
            }
          }
          .fa-solid.fa-chevron-right {
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--color-font);
            font-size: var(--rem12);
            width: min(calc(5rem + (1vw - 1.92rem) * 1.6181), 5rem);
            height: min(calc(5rem + (1vw - 1.92rem) * 1.6181), 5rem);
            background: #fff;
            border: 1px solid #fff;
            border-radius: 50vh;
            margin-top: var(--rem12);
            transition: all .25s ease-out;
          }
        }
      }
    }
  }
}
/* POST */
.news-wrapper.bg_wide {
  &::before {
    background: linear-gradient(90deg, #030B21 0%, #3E496E 100%);
  }
  img {
    width: 100%;
  }
}
.top_news {
	max-width: 1240px;
	padding: var(--px120) 0 var(--rem60);
  margin-left: auto;
  margin-right: auto;
  .linkBtn.linkBtn--mod01 {
    @media screen and (max-width: 768px) {
      width: fit-content;
      gap: var(--px24);
    }
  }
  .postlist {
    li:first-child {
      border-top: 1px solid var(--color-primary);
    }
    li {
      border-bottom: 1px solid var(--color-primary);
    }
    .time {
      background: #fff;
      a {
        color: var(--color-font);
      }
    }
    .date {
      color: #fff;
    }
    .ttls a {
      color: #fff;
    }
  }
}
.postlist {
    .post_text {
        color: #CCC;
        padding: 26px 0;
    }
    li {
        border-bottom: 1px solid #ccc;
    }
}
.postlist .ttls, .postlist .date {
    color: var(--color-font);
    font-size: 100%;
}
.post .time, .postlist .time, .post2b .time, .post4b .time {
    background: var(--color-primary);

}
.post .time, .postlist .time, .post2b .time, .post4b .time {
	line-height: 1.2 !important;
}

/*--------------------------------------------------
	下層ページ
--------------------------------------------------*/
body:not(.home) {
    #thumbImg::before, header#h1Header::before {
        display: none;
    }
    h1.title, .post h1, header#h1Header h1.title {
        color: #030B21;
        font-size: var(--rem48);
        font-family: var(--font-family03);
        font-weight: 600;
    }
    .page_footer-top {
      img {
        width: 100%;
      }
    }
    .post {
        .ttl {
            &.ttl--primary {
                display: flex;
                flex-direction: column;
                position: relative;
                &::after {
                    display: none;
                }
                .ttl--primary__en {
                    width: fit-content;
                    background: linear-gradient(90deg, #71DDD7 0%, #2E6BE1 100%);
                    -webkit-background-clip: text;
                    -webkit-text-fill-color: transparent;
                    font-family: var(--font-family01);
                    font-size: min(calc(10rem + (1vw - 1.92rem) * 3.2362), 10rem);
                    font-weight: 300;
                    line-height: 1.4;
                    margin-bottom: -0.2em;
                    margin-left: auto;
                    margin-right: auto;
                    position: relative;
                }
                .ttl--primary__ja {
                    font-size: min(calc(2.5rem + (1vw - 1.92rem) * 0.6472), 2.5rem);
                    font-weight: 700;
                    line-height: 1;
                    letter-spacing: .1em;
                    position: relative;
                    z-index: 1;
                }
            }
        }
        .ttl_block {
          padding-left: 1rem;
          -webkit-box-sizing: border-box;
          box-sizing: border-box;
          border-left: 10px solid #364164;
          padding-top: 5px;
          padding-bottom: 3px;
          margin-bottom: 4rem;
        }
        .ttl_block h2 {
          text-align: left;
        }
        h2.ttl_en {
          font-family: var(--font-family04);
          font-size: var(--rem36);
          font-weight: 700;
          padding: 0;
          margin: 0;
          line-height: 1;
          position: relative;
          &::after {
            content: none;
          }
        }
        h2.ttl_jp {
          font-family: var(--font-family01);
          background-color: transparent;
          padding: 5px 5px 5px 10px;
          -webkit-box-sizing: border-box;
          box-sizing: border-box;
          line-height: 1;
          color: var(--color-primary);
          display: inline-block;
          font-size:var(--rem16);
          font-weight: 400;
          letter-spacing: 0;
          margin: 5px 0 0 0;
          &::after {
            content: none;
          }
        }
        h2 {
          font-family: var(--font-family03);
          font-size: min(calc(3.2rem + (1vw - 1.92rem) * 0.3883), 3.2rem);
          &.txt_c {
            text-align: center !important;
          }
          &.txt_r {
            text-align: right !important;
          }
        }
        h3 {
            font-size: var(--rem30);
            font-weight: 700;
            padding: 0;
            border: none;
            margin-bottom: min(calc(10rem + (1vw - 1.92rem) * 3.2362), 10rem);;
        }
        ul {
            li {
              font-size: var(--rem18);
            }
        }
        table th, table td {
            font-size: var(--rem20);
            padding: var(--rem14) var(--rem24);
            line-height: 1.7;
        }
        table th {
            font-weight: 700;
            background: #E0E6FB;
        }
		.w-fit {
            width: fit-content;
            margin-left: auto;
            margin-right: auto;
        }
        .anchorLink-view {
            padding-top: 120px;
            margin-top: -120px;
        }
    }    
}

/*================================================
					お問い合わせ
================================================*/
.wpcf7 {
    table {
        th {
            width: 30%;
        }
    }
	.subimitarea {
		.linkBtn {
			margin-left: auto;
			margin-right: auto;
		}
	}
}