@charset "UTF-8";
/* placeholder color */
@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@600&family=Noto+Sans+JP:wght@500;700&family=Roboto:ital,wght@0,500;0,700;1,700&display=swap");
/**********************************************************************************************

　全体

**********************************************************************************************/
#wrap {
  font-size: 1.4rem;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 500;
  overflow: hidden;
  letter-spacing: .05em; }
  @media (min-width: 751px) {
    #wrap {
      min-width: 1280px; } }
  @media (max-width: 750px) {
    #wrap {
      font-size: 3.2vw; } }

img[src$=".svg"] {
  width: 100%; }

/* common */
img {
  max-width: 100%;
  height: auto; }

.inner {
  max-width: 1024px;
  margin: auto;
  position: relative; }
  @media (max-width: 750px) {
    .inner {
      max-width: 85vw; } }

main {
  display: block;
  position: relative; }

@media (min-width: 751px) {
  .fadelink {
    transition: .4s opacity; }
    .fadelink:hover {
      opacity: 0.6; } }

.en {
  font-family: 'Roboto', sans-serif; }

@media (min-width: 751px) {
  .u-sp {
    display: none !important; }

  a[href^="tel:"] {
    pointer-events: none; } }
@media (max-width: 750px) {
  .u-pc {
    display: none !important; } }
/**********************************************************************************************

　header

**********************************************************************************************/
header {
  position: fixed;
  width: 100%;
  left: 0;
  top: 0;
  min-width: 1280px;
  z-index: 2000;
  /*background:url("../img/common/head_bg.png") no-repeat;
  background-size: 100% 100%;
  padding: 30px 40px 50px;
  border-radius: 0 0 50% 50%;*/
  background: #fff;
/*   padding: 20px;  */
	padding: 35px 0;
}
  @media (max-width: 750px) {
    header {
		background-size: 100% 100%;
		border-radius: 0 0 50% 50%;
		background: url("../img/common/head_bg_sp.png") no-repeat;
		min-width: 1px;
		padding: 4vw 0 2.6vw;
/* 		padding:5.867vw 0 4.267vw; */
	  } }

.head_inner {
  display: flex;
  align-content: center;
/*   justify-content: space-between;  */
    justify-content: left;
    margin: 0 auto;
    width: fit-content;
}
  @media (max-width: 750px) {
    .head_inner {
      display: block; } }

.head_logo {
	width: 222px;
	margin-right:35px;
	display: block; }
  @media (max-width: 750px) {
    .head_logo {
      display: none; } }

@media (min-width: 751px) {
  .headNav {
    display: flex !important;
    text-align: center;
    justify-content: center;
    align-items: center; } }
@media (max-width: 750px) {
  .headNav {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #fff;
    padding: 25vw 0 13vw;
    display: none;
    z-index: 100;
    overflow: auto;
    text-align: center; } }

.headNav_list {
  display: flex;
  justify-content: center;
  font-weight: 700;
  line-height: 1;
/*   margin: 15px 0 0;  */
}
  @media (min-width: 1400px) {
    .headNav_list {
      font-size: 1.7rem; } }
  @media (max-width: 750px) {
    .headNav_list {
      display: block;
      margin: 0;
      text-align: center;
      font-size: 4.6vw; } }
  @media (max-width: 750px) {
    .headNav_list > li {
      margin: 0 0 6vw; } }
  @media (min-width: 751px) {
    .headNav_list > li:not(:last-child) {
      margin: 0 20px 0 0; } }
  @media (min-width: 1400px) {
    .headNav_list > li:not(:last-child) {
/*       margin: 0 40px 0 0; */
		margin: 0 30px 0 0;
	  } }
  .headNav_list a {
    display: inline-block;
    position: relative; }
    @media (min-width: 751px) {
      .headNav_list a::before {
        content: "";
        position: absolute;
        left: 0;
        bottom: -7px;
        width: 100%;
        height: 2px;
        background: #d3d2d5;
        transform: scale(0, 1);
        transition: 0.4s; }
      .headNav_list a:hover {
        opacity: 1; }
        .headNav_list a:hover::before {
          transform: scale(1); } }

.head_contactBtn {
  display: inline-block;
  background: #e72420;
  color: #fff;
  font-weight: 700;
  border-radius: 100px;
  padding: 12px 30px;
  transition: .4s;
  min-width: 200px;
  text-align: center; }
  @media (min-width: 751px) {
    .head_contactBtn:hover {
      opacity: 1;
      background: #23202d; } }
  @media (max-width: 750px) {
    .head_contactBtn {
      margin: 0;
      padding: 1.3vw 0;
      width: 60vw;
      font-size: 4.3vw; } }

.menuArea {
  text-align: center;
  position: relative;
  z-index: 1000; }

.menuBtn,
.menuBtn span {
  display: inline-block;
  transition: all .4s;
  cursor: pointer;
  z-index: 1000; }

.menuBtn {
  width: 10vw;
  height: 6vw;
  position: relative; }
  .menuBtn span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 3px;
    background: #e72420; }
    .menuBtn span:nth-of-type(1) {
      top: 0; }
    .menuBtn span:nth-of-type(2) {
      top: calc(50% - 1px);
      width: calc(100% - 1.4vw);
      left: 0.7vw; }
    .menuBtn span:nth-of-type(3) {
      bottom: 0; }
  .menuBtn.active span:nth-of-type(1) {
    transform: translateY(2.8vw) rotate(-45deg); }
  .menuBtn.active span:nth-of-type(2) {
    opacity: 0; }
  .menuBtn.active span:nth-of-type(3) {
    transform: translateY(-2.4vw) rotate(45deg); }

.menu_tit {
  color: #e72420;
  font-size: 3vw;
  margin: 1vw 0 0; }

.headNav_contactList {
  display: flex;
  margin: 0 0 0 40px; }
  @media (max-width: 750px) {
    .headNav_contactList {
      display: block;
      margin: 0; } }
  .headNav_contactList li:not(:last-child) {
    margin: 0 20px 0 0; }
    @media (max-width: 750px) {
      .headNav_contactList li:not(:last-child) {
        margin: 0 0 5vw; } }

.headNav_contactList_tit {
  font-size: 1.3rem;
  margin: 0 0 2px;
  font-weight: 700; }
  @media (max-width: 750px) {
    .headNav_contactList_tit {
      font-size: 3.2vw; } }

/**********************************************************************************************

　footer

**********************************************************************************************/
footer {
  position: relative; }

.foot_contact {
  background: #23202d;
  color: #fff;
  display: block;
  text-align: center;
  font-weight: 700;
  padding: 60px 0 50px; }
  @media (max-width: 750px) {
    .foot_contact {
      padding: 10vw 0; } }

.foot_contact_illust {
  position: absolute;
  z-index: 10; }
  @media (max-width: 750px) {
    .foot_contact_illust {
      display: none; } }

.foot_contact_illust01 {
  right: 100%;
  width: 125px;
  bottom: -65px; }

.foot_contact_illust02 {
  left: 100%;
  width: 150px;
  bottom: -50px; }

.foot_contact_tit {
  font-size: 2.6rem;
  display: flex;
  justify-content: center;
  align-items: center;
  white-space: nowrap;
  position: relative; }
  @media (max-width: 750px) {
    .foot_contact_tit {
      font-size: 6vw;
      line-height: 1.4;
      margin: 0 0 7vw;
      display: inline-block; } }
  .foot_contact_tit::after {
    content: "";
    display: block;
    background: url("../img/common/contact_arrow.svg") no-repeat;
    background-size: contain;
    width: 20px;
    height: 20px;
    margin: 0 0 0 8px; }
    @media (max-width: 750px) {
      .foot_contact_tit::after {
        width: 5vw;
        height: 5vw;
        margin: 0;
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        left: calc(100% + 5vw); } }

@media (max-width: 750px) {
  .foot_contact_txt {
    line-height: 2.1; } }

.foot_content {
  padding: 20px 0; }
  @media (max-width: 750px) {
    .foot_content {
      padding: 8vw 0; } }
  .foot_content .inner {
    display: flex;
    align-items: center;
    justify-content: center; }
    @media (max-width: 750px) {
      .foot_content .inner {
        display: block; } }

.foot_logo {
  display: block;
  width: 230px;
  margin: 0 60px 0 0; }
  @media (max-width: 750px) {
    .foot_logo {
      width: 61vw;
      margin: 0 auto 9vw; } }

.footNav_list {
  font-weight: 700;
  display: flex; }
  @media (max-width: 750px) {
    .footNav_list {
		flex-wrap: wrap;
		justify-content: center;
		display: grid;
		grid-template-columns: repeat(4, auto);
		padding: 0 5vw;
		text-align: center; } 
}
  .footNav_list li:not(:last-child) {
    margin: 0 30px 0 0; }
    @media (max-width: 750px) {
      .footNav_list li:not(:last-child) {
/*         margin: 0 6vw 5vw 0;  */
		  margin:0 5.333vw 2.933vw 0;
		}
		.footNav_list li:nth-child(4n) {
			margin: 0 0 2.933vw 0;
		}
	}
  .footNav_list a {
    display: inline-block;
    position: relative; }
    @media (min-width: 751px) {
      .footNav_list a::before {
        content: "";
        position: absolute;
        left: 0;
        bottom: -7px;
        width: 100%;
        height: 2px;
        background: #d3d2d5;
        transform: scale(0, 1);
        transition: 0.4s; }
      .footNav_list a:hover {
        opacity: 1; }
        .footNav_list a:hover::before {
          transform: scale(1); } }

.copyright {
  display: block;
  font-weight: 700;
  text-align: center;
  padding: 20px 0;
  margin: 10px 0 0;
  font-size: 1.2rem; }
  @media (max-width: 750px) {
    .copyright {
      padding: 8vw 0;
      margin: 0;
      font-size: 3vw; } }

.pagetop {
  position: fixed;
  z-index: 90;
  width: 140px;
  bottom: 20px;
  right: 20px;
  font-weight: 700;
  text-align: center; }
  @media (max-width: 750px) {
    .pagetop {
      width: 20vw;
      bottom: 5.3vw;
      right: 0; } }
  .pagetop a {
    display: block; }

.pagetop_arrow {
  width: 17px;
  margin: 0 auto 15px;
  transform: translateX(-10px); }
  @media (max-width: 750px) {
    .pagetop_arrow {
      width: 2.6vw;
      margin: 0 auto 2.6vw;
      transform: translateX(-1.5vw); } }

.pagetop_tit {
  font-size: 1.2rem;
  opacity: 0; }
  @media (max-width: 750px) {
    .pagetop_tit {
      display: none; } }

.foot_contactList {
  display: flex;
  max-width: 654px;
  justify-content: space-between;
  margin: auto; }
  @media (max-width: 750px) {
    .foot_contactList {
      max-width: 100%; } }
  .foot_contactList li {
    width: 46%;
    text-align: center; }
    @media (max-width: 750px) {
      .foot_contactList li {
        width: 48%; } }

.foot_contactList_tit {
  color: #fff;
  font-weight: 700;
  font-size: 1.7rem;
  margin: 0 0 3px; }
  @media (max-width: 750px) {
    .foot_contactList_tit {
/*       font-size: 3.2vw;  */
		font-size: 2.133vw;
		margin: 0 0 0.8vw;
	  } }

.foot_contactList_btn {
  color: #e72420;
  display: block;
  padding: 15px;
  border-radius: 100px;
  background: #fff;
  font-size: 2rem;
  position: relative; }
  @media (max-width: 750px) {
    .foot_contactList_btn {
/*       font-size: 4vw; */
		font-size: 2.667vw;
		padding: 3vw 0; } }
  .foot_contactList_btn::after {
    content: "";
    display: block;
    width: 20px;
    height: 20px;
    background: url("../img/common/foot_btn_arrow.png") no-repeat;
    background-size: contain;
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%); }
    @media (max-width: 750px) {
      .foot_contactList_btn::after {
/*         display: none;  */
		  content: "";
		  display: block;
		  width: 2.667vw;
		  height: 2.667vw;
		  background: url("https://kouhousentai.com/wp/wp-content/themes/koho//img/common/foot_btn_arrow.png") no-repeat;
		  background-size: auto;
		  background-size: contain;
		  position: absolute;
		  right: 4.533vw;
		  top: 50%;
		  transform: translateY(-50%);
		} }

.foot_bnr {
  display: block;
  max-width: 654px;
  margin: auto; }
  @media (max-width: 750px) {
    .foot_bnr {
      max-width: 100%; } }
