/********************
* Project
********************/
.p-mv {
  position: relative;
  width: 100%;
  padding-top: min(12vw,80px);
  overflow: hidden;
}

@media only screen and (min-width: 960px) {
  .p-mv {
    padding-top: min(1.8vw,32px);
  }
}

.p-mv__img {
  width: 108vw;
  position: relative;
  right: -5vw;
  top: -12vw;
  margin: 0;
}

@media only screen and (min-width: 960px) {
  .p-mv__img {
    width: min(36vw, 780px);
    height: min(23vw, 380px);
    position: relative;
    right: 3vw;
    top: 0.2vw;
    margin-left: auto;
  }
}

.p-mv__img img {
  width: 100%;
}

.p-mv__img path {
  opacity: 0;
}

.p-mv__ttl {
  position: absolute;
  bottom: min(16.8vw, 78px);
  left: min(5.8vw, 40px);
  z-index: 1;
  width: 100%;
}

@media only screen and (min-width: 960px) {
  .p-mv__ttl {
    display: flex;
    flex-direction: column;
    left: min(12vw, 80px);
    bottom: min(2.8vw, 60px);
    gap: min(0.8vw, 12px);
    width: auto;
  }
}

.p-mv__ttlMain {
  font-size: min(9.4vw,50px);
  font-weight: 500;
  line-height: 0;
  font-family: var(--font_family--en);
}

@media only screen and (min-width: 960px) {
  .p-mv__ttlMain {
    font-size: min(5.2vw,70px);
    line-height: 0;
  }
}

.p-mv__ttlMain br {
  display: none;
}

@media only screen and (min-width: 960px) {
  .p-mv__ttlMain br {
    display: block;
  }
}

.p-mv__ttlMain span {
  overflow: hidden;
  display: block;
}

@media only screen and (min-width: 960px) {
  .p-mv__ttlMain span {
    display: inline-block;
  }
}

.p-mv__ttlMain span b {
  display: block;
  line-height: 1.3;
  letter-spacing: 0.07em;
  opacity: 0;      /* 透明 */
  visibility: hidden; /* 完全に非表示 */
}

.p-mv__ttlSub {
  font-size: min(3.6vw,18px);
  overflow: hidden;
}

@media only screen and (min-width: 960px) {
  .p-mv__ttlSub {
    font-size: min(2vw,36px);
  }
}

.p-mv__ttlSub b {
  display: block;
  opacity: 0;      /* 透明 */
  visibility: hidden; /* 完全に非表示 */
  width: 100%;
}

.p-mv__catch {
  position: absolute;
  bottom: -15vw;
  right: inherit;
  left: 1vw;
  font-size: min(3.4vw,18px);
  font-weight: 500;
  overflow: hidden;
}

@media only screen and (min-width: 960px) {
  .p-mv__catch {
    position: absolute;
    bottom: min(3.8vw, 60px);
    right: min(5.8vw,68px);
    left: inherit;
    font-size: min(1.3vw,24px);
    font-weight: 500;
    overflow: hidden;
  }
}

.p-mv__catch b {
  display: block;
  opacity: 0;      /* 透明 */
  visibility: hidden; /* 完全に非表示 */
}

@media only screen and (min-width: 960px) {
  .p-mv__catch b {
  }
}


.p-group {
  margin: min(2.8vw,20px) 0;
  padding: min(6.8vw,60px) 0;
  overflow: hidden;
}

@media only screen and (min-width: 960px) {
  .p-group {
    margin: 0;
    padding: 0 0  min(4.2vw,83px);
    overflow: inherit;
  }
}

.p-group__inner {
  padding: 0;
}

@media only screen and (min-width: 960px) {
  .p-group__inner {
    padding: 0 min(12vw,80px);
  }
}

.p-group__list .swiper-slide {
  width: 80%; /* 中央寄せ + 両端チラ見せ */
}

@media only screen and (min-width: 960px) {
  .p-group__list .swiper-slide {
    width: calc((100% - min(11.6vw,80px)) / 3);
    margin: 0 !important;
  }
}

@media only screen and (min-width: 960px) {
  .p-group__list .swiper-wrapper {
    gap: min(5.8vw,40px);
    transform: translate3d(0px, 0px, 0px) !important;
  }
}

.p-group__link {
  position: relative;
  display: block;
  padding: min(5.8vw,40px);
  transition-duration: 0.3s;
  border: 2px solid var(--color_main);
  border-radius: 12px;
}

@media only screen and (min-width: 960px) {
  .p-group__link {
    padding: min(1.8vw,40px);
  }
}

.p-group__ttl {
  position: absolute;
  left: 50%;
  transform: translate(-50%,0);
  width: min(55%,200px);
  margin-top: max(-9.98vw, -56px);
  padding: min(0.4vw,8px) min(10vw,32px);
  background: var(--color_bg);
  border-radius: 4px;
  border: 1px solid var(--color_bg);
}

@media only screen and (min-width: 960px) {
  .p-group__ttl {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: max(-3.7vw, -66px);
    padding: min(0.2vw, 2px) min(8vw, 28px);
    width: 54%;
    height: min(4.2vw, 58px);
    text-align: center;
  }
}

.p-group__ttl img {
  display: block;
  width: 90%;
  margin: 0 auto; 
}

@media only screen and (min-width: 960px) {
  .p-group__ttl img {
    width: 80%;
    max-width: 200px;
  }
}

.p-group__link.is-solare .p-group__ttl img {
  width: 91%;
}

@media only screen and (min-width: 960px) {
  .p-group__link.is-solare .p-group__ttl img {
    width: 82%;
    max-width: 200px;
  }
}

.p-group__link.is-yui .p-group__ttl img {
  width: 79%;
}

@media only screen and (min-width: 960px) {
  .p-group__link.is-yui .p-group__ttl img {
    width: 64%;
    max-width: 170px;
  }
}

.p-group__link.is-techno:hover {
  background: #EAF0FF;
  border: 2px solid #EAF0FF;
}

.p-group__link.is-solare:hover {
  background: #E2FAF0;
  border: 2px solid #E2FAF0;
}

.p-group__link.is-yui:hover {
  background: #F6E6E5;
  border: 2px solid #F6E6E5;
}

.p-group__link.is-techno:hover .p-group__ttl {
  border: 1px solid #EAF0FF;
}

.p-group__link.is-solare:hover .p-group__ttl {
  border: 1px solid #E2FAF0;
}

.p-group__link.is-yui:hover .p-group__ttl {
  border: 1px solid #F6E6E5;
}

.p-group__img {
  position: relative;
  margin: 0;
  padding-top: 68%;
  border-radius: 12px;
  overflow: hidden;
}

@media only screen and (max-height: 880px) {
  .p-group__img {
    padding-top: 50%;
  }
}

.p-group__img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  vertical-align: middle;
}

@media only screen and (min-width: 960px) {
  .p-group__img img {
    position: absolute;
    vertical-align: middle;
  }
}

.p-group__txt {
  position: relative;
  min-height: min(22vw);
}

@media only screen and (min-width: 960px) {
  .p-group__txt {
    padding: min(1.6vw,20px) 0 0;
    min-height: min(10vw, 140px);
  }
}

@media only screen and (min-width: 1400px) {
  .p-group__txt {
    min-height: min(10vw, 120px);
  }
}

.p-group__catch {
  display: none;
  color: var(--color_bg);
  background: var(--color_main);
  line-height: 1.6;
  padding: 2px min(2.8vw,12px);
  border-radius: 4px;
  font-size: min(3.6vw,16px);
  transition-duration: 0.3s;
}

@media only screen and (min-width: 960px) {
  .p-group__catch {
    position: absolute;
    top: max(-2.8vw, -21px);
    left: max(-0.8vw, -8px);
    display: block;
    padding: min(0.3vw,7px) min(1.2vw,16px);
    color: var(--color_bg);
    background: var(--color_main);
    font-size: min(1.2vw, 16px);
  }
}

.p-group__link.is-techno:hover .p-group__catch {
  background: #2B4FAD;
}

.p-group__link.is-solare:hover .p-group__catch {
  background: #3DBF86;
}

.p-group__link.is-yui:hover .p-group__catch {
  background: #CC453C;
}


.p-group__desc {
  margin-top: min(3.2vw,40px);
  font-size: min(3.4vw,16px);
}

@media only screen and (min-width: 960px) {
  .p-group__desc {
    margin-top: 0;
    font-size: min(1vw,16px);
  }
}

.p-group__name {
  position: absolute;
  bottom: max(-2.8vw, -18px);
  left: 50%;
  padding: 0 5vw;
  transform: translate(-50%,0);
  /*background: var(--color_bg);*/
  font-size: min(3.4vw, 16px);
  font-weight: 600;
  font-family: var(--font_family--en);
  white-space: nowrap;
  z-index: 1;
}

@media only screen and (min-width: 960px) {
  .p-group__name {
    padding: 0 min(3.2vw,40px);
    font-size: min(1.2vw, 16px);
  }
}

.p-group__link:hover .p-group__name {
  background: none;
}

.p-group__link:after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 50%;
  width: 70%;
  height: 2px;
  background: var(--color_bg);
  transform: translate(-50%,0);
  transition-duration: 0.3s;
}

@media only screen and (min-width: 960px) {
  .p-group__link:after {
    width: 60%;
  }
}
.p-group__link:hover:after {
  width: 0;
}

.p-info {
  overflow: hidden;
  color: var(--color_bg);
  background: var(--color_main);
}

.p-info__list {
  padding: min(2.8vw,10px) min(5.8vw,40px);
}

@media only screen and (min-width: 960px) {
  .p-info__list {
    padding: min(2.8vw,12px) min(5.8vw,40px);
  }
}

.p-info__list .swiper-wrapper {
  transition-timing-function: linear;
}

/* スライダー全体 */
.p-info__list {
  overflow: hidden;
  width: 100%;
}

/* スライドを横並び */
.p-info__list .swiper-wrapper {
  display: flex;
  gap: min(3.8vw,28px);      /* スライド間の隙間 */
}

/* スライド個別 */
.p-info__list .swiper-slide {
  flex-shrink: 0; /* サイズ違いでも縮まない */
  width: auto;
  max-width: 300px;
}

@media only screen and (min-width: 960px) {
  .p-info__list .swiper-slide {
    max-width: 400px;
  }
}

/* スライドを横並び */
.p-info__list .swiper-wrapper {
  display: flex;
  gap: min(3.8vw,28px);      /* スライド間の隙間 */
}

/* オプション：リンクやタイトルのスタイル調整 */
.p-info__link {
  display: flex;
  flex-direction: row;
  align-items: center;
  text-align: center;
}

.p-info__link {
  display: flex;
  align-items: center;
  gap: min(2.8vw,20px);
}

@media only screen and (min-width: 960px) {
  .p-info__link {
    display: flex;
    align-items: center;
    gap: min(1.8vw,20px);
  }
}


.p-info__link i {
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(12vw,60px);
  min-width:  min(12vw,60px);
  height: min(12vw,60px);
  background: var(--color_bg);
  border-radius:  min(12vw,60px);
}

@media only screen and (min-width: 960px) {
  .p-info__link i {
    width: min(3.8vw,60px);
    min-width:  min(3.8vw,60px);
    height: min(3.8vw,60px);
  }
}

.p-info__link i img {
  width: 60%;
}

.p-about__img {
  position: relative;
  overflow: hidden;
  border-radius: min(5vw,16px);
  padding-top: 168%;
}

@media only screen and (min-width: 960px) {
  .p-about__img {
    border-radius: min(2.8vw,12px);
    padding-top: 68%;
  }
}

.p-about__overlay {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.35);
  z-index: 1;
}

@media only screen and (min-width: 960px) {
  .p-about__overlay {
    display: none;
  }
}

.p-about__img picture {
  width: 100%;
  height: 100%;
  display: block;
}

.p-about__img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  vertical-align: middle;
}

.p-info__ttl {
  font-size: min(3.4vw, 16px);
  display: -webkit-box;             
  -webkit-box-orient: vertical;      /* 垂直方向に配置 */
  overflow: hidden;                  /* 溢れた部分を隠す */
  text-overflow: ellipsis;           /* 溢れた部分に「...」を表示 */
  -webkit-line-clamp: 2;             /* 最大行数を2行に設定 */
  text-align: left;
}

@media only screen and (min-width: 960px) {
  .p-info__ttl {
    font-size: min(1.2vw, 16px);
    line-height: 1.4;
    -webkit-line-clamp: 1; 
  }
}

.p-about__inner {
  position: relative;
  padding: min(8.8vw,50px) min(5.8vw,40px) min(6vw,40px);
}

@media only screen and (min-width: 960px) {
  .p-about__inner {
    position: relative;
    padding: min(6vw,80px) 0 min(2vw,40px);
  }
}

.p-about__desc {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 80%;
  line-height: 2.2;
  color: var(--color_bg);
  transform: translate(-50%,-50%);
  font-size: min(3.4vw, 16px);
}

@media only screen and (min-width: 960px) {
  .p-about__desc {
    top: calc(24% + min(6vw, 80px));
            left: calc(11% + min(6vw, 40px));
            font-size: min(1.2vw, 16px);
            transform: translate(0, -50%);
  }
}

.p-about__row {
  position: relative;
  display: block;
}

.p-about__rowTop {
  margin-top: min(4.8vw,48px);
}

@media only screen and (min-width: 960px) {
  .p-about__rowTop {
    margin-top: min(2.8vw,28px);
  }
}

.p-about__row b.is-white {
  position: absolute;
}

.p-about__row b.is-dummy {
  opacity: 0.5;
}

.p-service__inner {
  position: relative;
  padding: min(6vw,40px) min(5.8vw,40px);
}

@media only screen and (min-width: 960px) {
  .p-service__inner {
    position: relative;
    padding: min(6vw,40px) min(12vw,80px);
  }
}

.p-service__inner .c-contTtl {
  display: flex;
  flex-direction: column;
}

@media only screen and (min-width: 960px) {
  .p-service__inner .c-contTtl {
    align-items: flex-end;
    flex-direction: row;
    justify-content: space-between;
    margin-bottom: min(2vw,40px);
    gap:  min(5.8vw,40px);
  }
}

.p-service__nav {
  margin: min(2.8vw,40px) 0 ;  
}

@media only screen and (min-width: 960px) {
  .p-service__nav {
    display: flex;
    gap: min(2vw,12px);
    margin: 0 0 min(1.2vw,20px);
  }
}

.p-service__navItem {
  font-size: min(3.6vw,16px);
  padding: min(0.4vw,6px) min(2.8vw,20px);
  background: #F6F6F6;
  border: 2px solid #F6F6F6;
  border-radius: min(0.8vw, 6px);
  cursor: pointer;
}

@media only screen and (min-width: 960px) {
  .p-service__navItem {
    font-size: min(1.2vw,16px);
    padding: min(0.8vw,8px) min(1.2vw,20px) min(0.9vw,9px);
    border-radius: min(0.4vw, 4px);
    line-height: 1.2;
  }
}

.p-service__navItem.is-active {
  background: var(--color_bg);
  border: 2px solid var(--color_main);
}

.p-service__select {
  margin: min(2.8vw,20px) 0 min(8.8vw,60px);  
}

@media only screen and (min-width: 960px) {
  .p-service__select {
    margin: min(5.8vw,40px) 0 min(8.8vw,60px);  
  }
}

.p-service__select select {
  width: 100%;
  height: min(10vw,60px);
  padding: 0 min(3.8vw,28px);
  color: var(--color_bg);
  background: var(--color_main);
  border-radius: min(1.2vw, 12px);
  border: 0;
  appearance: none;
  font-size: min(4vw, 17px);
}

.p-service__tab {
  margin: 0 calc(50% - 50vw);
  width: 100vw;
}

.p-service__list {
  display: none;
}

@media only screen and (min-width: 960px) {
  .p-service__list {
    border-top: 1px solid var(--color_main);
    border-bottom: 1px solid var(--color_main);
  }
}

.p-service__list.is-active {
  display: block;
}

@media only screen and (min-width: 960px) {
  .p-service__list.is-active {
    display: flex;
    flex-wrap: wrap;
  }
}

.p-service__item {
  position: relative;
  border-top: 1px solid #E1E1E4;
}

@media only screen and (min-width: 960px) {
  .p-service__item {
    width: calc((100% - 3px) / 4);
    border-top: 0;
    border-right: 1px solid var(--color_main);
  }
}

.p-service__item:after {
}

@media only screen and (min-width: 960px) {
  .p-service__item:after {
    content: "";
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 100%;
    height: 1px;
    background:var(--color_main);
  }
}


@media only screen and (min-width: 960px) {
  .p-service__item:nth-child(4n) {
    border-right: 0;
  }
}

.p-service__item:last-child {
  border-bottom: 1px solid #E1E1E4;
}

@media only screen and (min-width: 960px) {
  .p-service__item:last-child {
    border-bottom: 0;
  }
}

.p-service__link {
  display: flex;
  align-items: flex-end;
  gap: min(5.8vw,20px);
  padding: min(5.2vw,40px) min(5.8vw,40px);
  transition-duration: 0.3s;
} 

@media only screen and (min-width: 960px) {
  .p-service__link {
    flex-direction: column;
    gap: min(1.8vw,32px);
    height: 100%;
    padding: min(2.4vw,40px) min(2.8vw,40px);
  } 
}

.p-service__link.is-techno:hover {
  background: #EAF0FF;
}

.p-service__link.is-solare:hover {
  background: #E2FAF0;
}

.p-service__link.is-yui:hover {
  background: #F6E6E5;
}

.p-service__img {
  position: relative;
  width: 47%;
  min-width: 47%;
  margin: 0;
  padding-top: 30%;
  border-radius: min(1.2vw,12px);
  overflow: hidden;
}

@media only screen and (min-width: 960px) {
  .p-service__img {
    width: 100%;
    min-width: 100%;
    padding-top: 66%;
    border-radius: min(0.4vw,4px);
  } 
}

.p-service__img img {
  position: absolute;
  top: 0;
  left: 0;
  vertical-align: middle;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition-duration: 0.6s;
}

@media only screen and (min-width: 960px) {
  .p-service__img img {
    width: 100%;
    min-width: 100%;
  } 
}

.p-service__link:hover .p-service__img img {
  transform: scale(1.016);  
}

@media only screen and (min-width: 960px) {
  .p-service__txt {
    position: relative;
    width: 100%;
  } 
}

.p-service__name {
  position: absolute;
  top: -1px;
  right: min(5.8vw,40px);
  padding: min(0.8vw,8px) min(2vw,12px) min(1vw,10px);
  font-size: min(3vw, 14px);
  border: 1px solid var(--color_main);
  border-radius: 0 0 5px 5px;
}

@media only screen and (min-width: 960px) {
  .p-service__name.s-pc {
    position: static;
    display: inline-block;
    padding: min(0.5vw,5px) min(0.5vw,20px) min(0.6vw,6px);
    font-size: min(0.85vw, 14px);
    line-height: 1.2;
    border-radius: 5px;
  } 
}

.p-service__name.is-techno {
  color: #2B4FAD;
  border: 1px solid #2B4FAD;
}

.p-service__name.is-solare {
  color: #3DBF86;
  border: 1px solid #3DBF86;
}

.p-service__name.is-yui {
  color: #CC453C;
  border: 1px solid #CC453C;
}

.p-service__box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: min(2.8vw,20px);
  gap: min(2vw,20px);
}

@media only screen and (min-width: 960px) {
  .p-service__box {
    margin-top: min(1.8vw,32px);
    gap: min(1.2vw,20px);
  }
}

.p-service__desc {
  font-size: min(3.4vw, 16px);
  display: -webkit-box;             
  -webkit-box-orient: vertical;      /* 垂直方向に配置 */
  overflow: hidden;                  /* 溢れた部分を隠す */
  text-overflow: ellipsis;           /* 溢れた部分に「...」を表示 */
  -webkit-line-clamp: 2;             /* 最大行数を2行に設定 */
  min-height: min(3.8vw, 54px);
}

@media only screen and (min-width: 960px) {
  .p-service__desc {
    line-height: 1.6;
    font-size: min(1.2vw, 16px);

  } 
}

.p-service__time {
  color: #888888;
  font-size: min(3vw, 14px);
  font-family: var(--font_family--en);
}

@media only screen and (min-width: 960px) {
  .p-service__time {
    font-size: min(1vw, 14px);
  } 
}

.p-news__inner {
  position: relative;
  padding: min(10vw,40px) min(5.8vw,40px) 0;
}

@media only screen and (min-width: 960px) {
  .p-news__inner {
    position: relative;
    padding: min(10vw,80px) min(12vw,80px) min(2.4vw,32px) ;
  }
  .l-second .p-news__inner {
    padding: 0 min(12vw, 80px) min(3.6vw, 32px);
  }
}
@media only screen and (min-width: 960px)  {
  .p-news__box {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
    align-items: flex-start;
    gap: min(5.8vw,40px);
    margin-top: min(5.8vw,68px);
  }
}

.p-news__list {
  margin: min(8.8vw,40px) calc(50% - 50vw);
  width: 100vw;
}

@media only screen and (min-width: 960px) {
  .p-news__list {
    margin: 0;
    width: calc(100% - 380px);
  }
  .p-news__list--l {
    width: 100%;
    max-width: 1167px;
    margin: 0 auto;
  }
}

.p-news__item {
  position: relative;
  border-top: 1px solid #E1E1E4;
}

@media only screen and (min-width: 960px) {
  .p-news__item {
    border-top: 1px solid var(--color_main);
  }
}

.p-news__item:last-child {
  border-bottom: 1px solid #E1E1E4;
}

@media only screen and (min-width: 960px) {
  .p-news__item:last-child {
    border-bottom: 1px solid var(--color_main);
  }
}

.p-news__link {
  position: relative;
  display: flex;
  align-items: center;
  gap: min(4.8vw,20px);
  padding: min(5.2vw,40px) min(5.8vw,40px);
  transition-duration: 0.3s;
}

@media only screen and (min-width: 960px) {
  .p-news__link {
    gap: min(2.8vw,20px);
    padding: min(2.8vw,20px) min(6.8vw,60px) min(2.8vw,20px)  min(5.8vw,40px);
  }
}

.p-news__item.is-ngi .p-news__link:hover {
  background: #eee;
}

.p-news__item.is-solare .p-news__link:hover {
  background: #E2FAF0;
}

.p-news__item.is-techno .p-news__link:hover {
  background: #EAF0FF;
}

.p-news__item.is-yui .p-news__link:hover {
  background: #F6E6E5;
}

.p-news__arrow  {
  display: none;
  position: absolute;
  right: min(5.8vw,40px);
  width: min(1.2vw,16px);
  height: min(1.2vw,16px);
  transform: translate(0,-50%);
  transition-duration: 0.3s;
}

@media only screen and (min-width: 960px) {
  .p-news__arrow  {
    display: block;
  }
}

.p-news__link:hover .p-news__arrow {
  transform: translate(4px,-58%);
}


.p-news__arrow svg path {
  fill: var(--color_main);
}

.p-news__item.is-techno .p-news__arrow svg path {
  fill: #2B4FAD;
}

.p-news__item.is-solare .p-news__arrow svg path {
  fill: #46C38D;
}

.p-news__item.is-yui .p-news__arrow svg path {
  fill: #D75249;
}

.p-news__desc {
  font-size: min(3.4vw, 16px);
  display: -webkit-box;             
  -webkit-box-orient: vertical;      /* 垂直方向に配置 */
  overflow: hidden;                  /* 溢れた部分を隠す */
  text-overflow: ellipsis;           /* 溢れた部分に「...」を表示 */
  -webkit-line-clamp: 2;             /* 最大行数を2行に設定 */
}

@media only screen and (min-width: 960px) {
  .p-news__desc {
    font-size: min(1.2vw, 16px);
    line-height: 1.6;
  }
}

.p-news__time {
  color: #888888;
  font-size: min(3vw, 14px);
  font-family: var(--font_family--en);
}

@media only screen and (min-width: 960px) {
  .p-news__time {
    color: #888888;
    font-size: min(1vw, 12px);
  }
}

.p-news__img {
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(21vw,90px);
  min-width: min(21vw,90px);
  height: min(21vw,90px);;
  border-radius: min(1.2vw,12px);
  overflow: hidden;
  border: 1px solid var(--color_main);
  margin-bottom: 0;
}

@media only screen and (min-width: 960px) {
  .p-news__img {
    width: min(8vw,70px);
    min-width: min(8vw,70px);
    height: min(8vw,70px);;
    border-radius: min(0.6vw,6px);
    margin-bottom: 0;
  }
}

.p-news__img.is-techno {
  border: 1px solid #2B4FAD;
}

.p-news__img.is-solare {
  border: 1px solid #46C38D;
}

.p-news__img.is-yui {
  border: 1px solid #D75249;
}

.p-news__img img {
  width: 60%;
  vertical-align: middle;
}

@media only screen and (min-width: 960px) {
  .p-news__img img {
    width: 68%;
  }
}


.p-news__btn {
  margin-top: min(8.8vw,60px);
  text-align: right;
}

@media only screen and (min-width: 960px) {
  .p-news__btn {
    margin-top: 0;
  }
}

.p-news__btn a {
  justify-content: space-between;
  padding: min(3.8vw, 20px) min(6.4vw, 40px) min(4vw, 18px);
  width: min(48vw, 340px);
}

@media only screen and (min-width: 960px) {
  .p-news__btn a {
    justify-content: space-between;
    padding: min(1.1vw, 16px) min(2.8vw, 28px) min(1.1vw, 16px);
    width: min(17vw, 200px);

  }
}

.p-company {
  position: relative;
  z-index: 1;
}

.p-company__deco {
  display: none;
  position: absolute;
  bottom: 182vw;
  right: 0;
  z-index: -1;
  width: 100%;
}

@media only screen and (min-width: 960px) {
  .p-company__deco {
    bottom: -24vw;
  }
}

.p-company__inner {
  position: relative;
  padding: min(12vw,80px) min(5.8vw,40px);
}

@media only screen and (min-width: 960px) {
  .p-company__inner {
    position: relative;
    padding: min(5.8vw,40px) min(12vw,80px);
  }
}

.p-company__main {
  display: flex;
  flex-direction: column;
  gap: min(2.8vw,12px);  
  margin-top: min(5.8vw,64px);
}

@media only screen and (min-width: 960px) {
  .p-company__main {
    flex-direction: row;
    gap: min(5.8vw,40px);  
  }
}

.p-company__list {
  display: flex;
  flex-direction: column;
  gap: min(2.8vw,12px);
}

@media only screen and (min-width: 960px) {
  .p-company__list {
    gap: min(2.8vw,20px);
    width: 50%;
  }
}

.p-company__item {
  height: 100%;
  padding: min(5.2vw,40px) min(5.8vw,40px);
  border: 1px solid var(--color_main);
  border-radius: min(1.2vw, 12px);
}

@media only screen and (min-width: 960px) {
  .p-company__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: min(1.8vw,20px) min(5.8vw,40px);
    border-radius: min(0.8vw, 5px);
  }
}

@media only screen and (min-width: 960px) {
  .p-company__item dl {
    display: flex;
    align-items: center;
    gap: min(2vw,20px);
    width: 100%;
  }
}

@media only screen and (min-width: 960px) {
  .p-company__item.is-top dl {
    align-items: flex-start;
  }
}


.p-company__item dt {
  margin-bottom: min(2vw,20px);
  font-size: min(3vw, 14px); 
}

@media only screen and (min-width: 960px) {
  .p-company__item dt {
    margin-bottom: 0;
    width: 43%;
    min-width: 43%; 
    font-size: min(1vw, 14px); 
  }
}

.p-company__item dd {
  font-size: min(3.4vw, 16px);
}

@media only screen and (min-width: 960px) {
  .p-company__item dd {
    line-height: 1.6;
    font-size: min(1.2vw, 16px); 
  }
}

.p-link {
  position: relative;
  padding: 0 0 min(8vw,40px) ;
  background: #EEEEEE;
  z-index: 1;
}

@media only screen and (min-width: 960px) {
  .p-link {
    padding: 0 0 min(4vw,80px);
    background: inherit;
  }
}

.p-link__inner {
  position: relative;
  padding: min(12vw,80px) min(5.8vw,40px);
}

@media only screen and (min-width: 960px) {
  .p-link__inner {
    padding: min(4vw,60px) min(12vw,80px) min(4vw,80px);
    background: inherit;
  }
}

.p-link__list {
  display: flex;
  flex-direction: column;
  gap: min(4vw,32px);
}

@media only screen and (min-width: 960px) {
  .p-link__list {
    flex-direction: row;
    gap: min(5.8vw,40px);
  }
}

.p-link__item {
  flex: 1;
  border: 1px solid var(--color_main);
  border-radius: min(1.2vw, 12px);
  overflow: hidden;
  background: var(--color_bg);
} 

@media only screen and (min-width: 960px) {
  .p-link__item {
    border-radius: min(0.8vw, 5px);
  }
}

.p-link__item a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: min(40vw,400px);
}

@media only screen and (min-width: 960px) {
  .p-link__item a {
    height: 17vw;
  }
}

.p-link__item a:after {
  position: absolute;
  top: min(2.8vw,32px);
  right: min(2.8vw,32px);
  content: "";
  width: min(3.8vw,32px);
  height: min(3.8vw,32px);
  background: url(../img/common/icon-external.svg) no-repeat;
  background-size: 100%;
}

@media only screen and (min-width: 960px) {
  .p-link__item a:after {
    top: min(2.8vw,14px);
    right: min(2.8vw,14px);
    width: min(3vw,16px);
    height: min(3vw,16px)
  }
}

.p-link__item a img {
  width: 60%;
}

.p-blog__inner {
  position: relative;
  padding: min(8vw,60px) min(5.8vw,40px) 0;
}

@media only screen and (min-width: 960px) {
  .p-blog__inner {
    position: relative;
    padding: 0 min(12vw,80px) min(3.6vw,32px) ;
  }
}

.p-blog__fig {
  border-radius: 12px;
  overflow: hidden;
  margin: 0 0 min(5.8vw,32px);
}

.p-blog__fig img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}

.p-blog__box {
  max-width: 1000px;
  margin: 0 auto;
}

.p-blog__ttl {
  margin-bottom: min(2.8vw,40px);
}

.p-blog__ttlMain {
  font-size: min(5.8vw,28px);
  font-weight: 500;
  line-height: 1.5;
}

@media only screen and (min-width: 960px) {
  .p-blog__ttlMain {
    font-size: min(2.6vw,28px);
  }
}

.p-blog__ttlDate {
  display: inline-block;
  margin: min(7.8vw,28px) 0 min(6.3vw,22px);
  font-size: min(3.4vw,14px);
  font-family: var(--font_family--en);
}

@media only screen and (min-width: 960px) {
  .p-blog__ttlDate {
    display: inline-block;
    margin: min(2.8vw,40px) 0 min(1.2vw,20px);
    font-size: min(1vw,14px);
    font-family: var(--font_family--en);
  }
}

.p-blog__btn {
  margin: min(10vw,80px) 0;
  text-align: center;
}

@media only screen and (min-width: 960px) {
  .p-blog__btn a {
    
  }

  .p-blog__btn a i {
    margin: 2px 0 0 min(4vw, 30px);
  }
}

.p-blog__desc {
  margin-top: min(2.8vw,40px);
}

.p-blog__desc p {
  font-size: min(3.6vw,16px);
}

.p-blog__desc h1 {
  font-size: min(3.6vw,28px);
}

.p-blog__desc h2 {
  font-size: min(3.6vw,24px);
}

.p-blog__desc h3 {
  font-size: min(3.6vw,20px);
}

.p-blog__desc h4 {
  font-size: min(3.6vw,18px);
}

.p-blog__desc h5 {
  font-size: min(3.6vw,16px);
}

.p-blog__desc h6 {
  font-size: min(3.6vw,16px);
}

.p-page__inner {
  position: relative;
  padding: 0 min(5.8vw,40px) min(5.8vw,40px) ;
}

@media only screen and (min-width: 960px) {
  .p-page__inner {
    position: relative;
    padding: 0 min(12vw,80px) min(3.6vw,32px) ;
  }
}

.p-page__box {
  max-width: 1000px;
  margin: 0 auto min(8vw,40px);
}

.p-page__sec {
  margin-bottom: min(8vw,40px);
}

.p-page__secTtl {
  font-size: min(3.6vw,16px);
  font-weight: 500;
}

@media only screen and (min-width: 960px) {
  .p-page__secTtl {
    font-size: min(1.2vw,16px);
  }
}

.p-page__secDesc {
  font-size: min(3.6vw,16px);
}


@media only screen and (min-width: 960px) {
  .p-page__secDesc {
    font-size: min(1.2vw,16px);
  }
}

.p-form {
  padding: 0 0 min(10vw, 112px);
}

@media screen and (min-width: 960px) {
  .p-form {
    padding: 0 0 min(10vw, 112px);
  }
}

.p-form__inner {
  position: relative;
  padding: 0 min(5.8vw,40px);
}

.p-form__box {
  max-width: 1000px;
  margin: 0 auto;
}

.p-form__desc {
  margin-bottom: min(8.3vw, 80px);
}

@media screen and (min-width: 960px) {
  .p-form__desc {
    margin-bottom: min(8.3vw, 80px);
  }
}

.p-form__item {
  margin-bottom: min(3.2vw, 32px);
  display: flex;
  flex-direction: column;
  gap: min(3.2vw, 32px);
}

@media screen and (min-width: 960px) {
  .p-form__item {
    margin-bottom: min(4vw, 40px);
  }
}

.p-form__item dt {
  min-width: 314px;
  padding-top: 16px;
  font-weight: 600;
}

.p-form__item dd {
  width: 100%;
}

@media screen and (min-width: 960px) {
  .p-form__item {
    flex-direction: row;
  }
}

.p-form__item select {
  width: 100%;
  height: 60px;
  padding: 0 24px;
  border: 1px solid #eee;
  background-color: #F9F9F9;
  background-image: url(../img/common/icon-select.svg);
  background-repeat: no-repeat;
  background-size: 12px;
  background-position: calc(100% - 20px) center;
  border-radius: 4px;
  appearance: none;
  color: var(--color_main);
  font-size: min(3.4vw, 16px);
}

@media screen and (min-width: 960px) {
  .p-form__item select {
    height: 60px;
    padding: 0 38px;
    font-size: min(1.2vw, 16px);
  }
}

.p-form__item input[type=text],
.p-form__item input[type=tel],
.p-form__item input[type=email] {
  width: 100%;
  height: 60px;
  padding: 0 24px;
  border: 1px solid #eee;
  background: #F9F9F9;
  border-radius: 4px;
  font-size: min(3.4vw, 16px);
}

@media screen and (min-width: 960px) {
  .p-form__item input[type=text],
  .p-form__item input[type=tel],
  .p-form__item input[type=email], {
    height: 60px;
    padding: 0 38px;
    font-size: min(1.2vw, 16px);
  }
}

.p-form__item textarea {
  width: 100%;
  padding: 20px 24px;
  height: 280px;
  border: 1px solid #eee;
  background: #F9F9F9;
  border-radius: 4px;
  font-size: min(3.4vw, 16px);
}

@media screen and (min-width: 960px) {
  .p-form__item textarea {
    padding: 20px 24px;
    height: 280px;
    font-size: min(1.2vw, 16px);
  }
}

.p-form__item label {
  display: block;
  position: relative;
  padding-left: 36px;
  margin: 4px 0;
  cursor: pointer;
}

@media screen and (min-width: 960px) {
  .p-form__item label {
    padding-left: 40px;
  }
}

.p-form__item label input[type=checkbox] {
  display: none;
}

.p-form__item label span:after {
  content: "";
  display: block;
  width: 16px;
  height: 16px;
  position: absolute;
  top: 50%;
  left: 5px;
  transform: translateY(-50%);
  background: #EEEEEE;
  border-radius: 50px;
}

.p-form__item label span:before {
  content: "";
  display: block;
  width: 6px;
  height: 10px;
  position: absolute;
  top: 50%;
  left: 6px;
  transform: rotate(37deg) skewY(21deg) translateY(-50%);
  transform-origin: center right;
  border-right: 2px solid #25408F;
  border-bottom: 2px solid #25408F;
  opacity: 0;
  z-index: 1;
}

.p-form__item label input[type=checkbox]:checked + span:before {
  opacity: 1;
}

.p-form__item ::placeholder {
  color: #888888;
}

.p-form__item small {
  display: inline-block;
  margin-top: 10px;
  color: #888888;
  font-size: min(3.2vw, 14px);
}

.p-form__item .is-small {
  max-width: 568px;
}

.p-form__required {
  margin-left: min(3.2vw, 24px);
  padding: min(0.6vw,6px) min(2.4vw,18px) min(0.7vw,7px);
  border-radius: 4px;
  border: 1px solid #DD3B3D;
  color: #DD3B3D;
  font-size: min(3.2vw, 14px);
}

@media screen and (min-width: 960px) {
  .p-form__required {
    margin-left: min(2vw, 20px);
    padding: 2px 16px;
    font-size: min(1vw, 14px);
  }
}

.p-form__check {
  display: flex;
  flex-direction: column;
  justify-self: center;
  width: 100%;
  gap: 3.2vw;
  padding: min(4vw, 40px) 0;
  margin: min(3.2vw, 40px) 0;
}

@media screen and (min-width: 960px) {
  .p-form__check {
    gap: 20px;
    padding-top: min(6vw, 60px);
    margin: min(3.2vw, 40px) 0;
    border-top: 1px solid #eee;
  }
}

.p-form__check label {
  position: relative;
  padding-left: 36px;
  font-size: min(3.4vw, 16px);
  cursor: pointer;
}

@media screen and (min-width: 960px) {
  .p-form__check label {
    padding-left: 32px;
  }
}

.p-form__check label input[type=checkbox] {
  display: none;
}

.p-form__check label span:after {
  content: "";
  display: block;
  width: 16px;
  height: 16px;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  background: #eee;
}

.p-form__check label span:before {
  content: "";
  display: block;
  width: 6px;
  height: 10px;
  position: absolute;
  top: 50%;
  left: 1px;
  transform: rotate(37deg) skewY(21deg) translateY(-50%);
  transform-origin: center right;
  border-right: 2px solid var(--color_main);
  border-bottom: 2px solid var(--color_main);
  opacity: 0;
  z-index: 1;
}

.p-form__check label input[type=checkbox]:checked + span:before {
  opacity: 1;
}

.p-form__check p {
  font-size: min(3.4vw, 16px);
}

.p-form__check a {
  text-decoration: underline;
}

.p-form__btn {
  display: block;
  max-width: 360px;
  width: 100%;
  margin: min(6vw,60px) auto;
  padding: min(3.6vw,28px) 0;
  color: #fff;
  background: var(--color_main);
  text-align: center;
  border-radius: 40px;
  font-size: min(3.4vw, 16px);
}

@media screen and (min-width: 960px) {
  .p-form__btn {
    width: 100%;
    max-width: 320px;
    margin: min(4vw,48px) auto;
    padding: min(1.6vw,20px) 0;
    font-size: min(1.2vw, 16px);
  }
}
