@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400&family=Noto+Serif+JP:wght@500&display=swap");
/* -----------------------------------------------------
	basic
----------------------------------------------------- */
html {
  font-size: 62.5%;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  -webkit-text-size-adjust: 100%;
  font-size: min(0.99vw,15px);
  font-weight: 500;
  line-height: 1.8;
  color: #333;
  letter-spacing: 0.1em;
  -webkit-font-feature-settings: "palt" 1;
  font-feature-settings: "palt" 1;
}

@media screen and (max-width: 768px) {
  body {
    font-size: 3.64583vw;
  }
}

main {
  width: 100%;
  position: relative;
}

#contents {
  background: #f8f8f8;
  padding-top: min(5.29vw,80px);
}

@media screen and (max-width: 768px) {
  #contents {
    padding-top: 19.53125vw;
  }
}

.inner {
  max-width: min(79.37vw,1200px);
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
  .inner {
    max-width: 100%;
    padding: 0 4.16667vw;
  }
}

a {
  opacity: 1;
  -webkit-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  transition: all 0.5s ease 0s;
  text-decoration: none;
}

a img {
  -webkit-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  transition: all 0.5s ease 0s;
}

a img:hover {
  opacity: .8;
}

@media screen and (max-width: 768px) {
  a img:hover {
    opacity: 1;
  }
}

.en {
  font-family: "Cormorant Garamond", serif;
  font-weight: 400;
}

.mt0 {
  margin-top: 0 !important;
}

/* -----------------------------------------------------
	br
----------------------------------------------------- */
br.pc {
  display: block;
}

@media screen and (max-width: 768px) {
  br.pc {
    display: none;
  }
}

br.sp {
  display: none;
}

@media screen and (max-width: 768px) {
  br.sp {
    display: block;
  }
}

/* -----------------------------------------------------
  page_ttl
----------------------------------------------------- */
.page_ttl {
  background: url(../img/service/solar-panel/page_ttl.png) center top/cover no-repeat;
}

/* -----------------------------------------------------
  solar-panel
----------------------------------------------------- */
.solar-panel .wrap {
  padding: 0 min(3.7vw,56px);
}

@media screen and (max-width: 768px) {
  .solar-panel .wrap {
    padding: 0;
  }
}

.solar-panel .sec_sub_ttl {
  font-size: min(1.32vw,20px) !important;
  margin: 0 0 min(1.59vw,24px) !important;
}

@media screen and (max-width: 768px) {
  .solar-panel .sec_sub_ttl {
    font-size: 3.64583vw !important;
    margin-bottom: 7.29167vw !important;
  }
}

.solar-panel .wrap_ttl {
  background: #2FA350;
  border-radius: min(0.66vw,10px);
  font-size: min(1.59vw,24px);
  font-weight: 700;
  line-height: min(3.7vw,56px);
  color: #fff;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .solar-panel .wrap_ttl {
    border-radius: 1.30208vw;
    font-size: 4.16667vw;
    line-height: 10.41667vw;
  }
}

.solar-panel .wrap_ttl span {
  position: relative;
}

.solar-panel .wrap_ttl span::before {
  content: '';
  display: inline-block;
  position: absolute;
  top: 50%;
  left: -128px;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  width: min(11.38vw,107px);
  height: min(10.53vw,99px);
}

@media screen and (max-width: 768px) {
  .solar-panel .wrap_ttl span::before {
    top: -15.625vw;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    -ms-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    width: 16.92708vw;
    height: 15.625vw;
  }
}

.solar-panel .anc {
  display: -webkit-box;
  /*Android4.3*/
  display: -ms-flexbox;
  /*IE10*/
  display: -webkit-flex;
  /*PC-Safari,iOS8.4*/
  display: flex;
  -ms-flex-pack: center;
  /*IE10*/
  -webkit-box-pack: center;
  /* Android4.3以下、Safari3.1〜6.0 */
  -webkit-justify-content: center;
  /* Safari6.1以降 */
  justify-content: center;
  margin-bottom: min(2.12vw,32px);
}

@media screen and (max-width: 768px) {
  .solar-panel .anc {
    display: block;
    margin-bottom: 5.20833vw;
  }
}

.solar-panel .anc li {
  width: 32%;
}

@media screen and (max-width: 768px) {
  .solar-panel .anc li {
    width: 100%;
  }
}

.solar-panel .anc li a {
  display: block;
  padding: 0 min(1.59vw,24px) min(0.53vw,8px);
  border-bottom: 2px solid #2FA350;
  font-weight: 700;
  position: relative;
}

@media screen and (max-width: 768px) {
  .solar-panel .anc li a {
    padding: 3.125vw 0 3.125vw 3.125vw;
    border-bottom: 0.39063vw solid #2FA350;
  }
}

.solar-panel .anc li a::after {
  content: '';
  display: inline-block;
  position: absolute;
  top: 50%;
  right: min(1.06vw,16px);
  width: min(0.79vw,12px);
  height: min(0.79vw,12px);
  border: 2px solid #2FA350;
  border-left: 0;
  border-bottom: 0;
  -webkit-transform: translate(-25%, -50%) rotate(135deg);
  -ms-transform: translate(-25%, -50%) rotate(135deg);
  transform: translate(-25%, -50%) rotate(135deg);
}

@media screen and (max-width: 768px) {
  .solar-panel .anc li a::after {
    right: 3.125vw;
    width: 3.125vw;
    height: 3.125vw;
    border: 0.39063vw solid #2FA350;
    border-left: 0;
    border-bottom: 0;
  }
}

.solar-panel .anc li + li {
  margin-left: min(1.59vw,24px);
}

@media screen and (max-width: 768px) {
  .solar-panel .anc li + li {
    margin-left: 0;
  }
}

.solar-panel .caution {
  background: #fff3cc;
  max-width: min(52.91vw,800px);
  margin: 0 auto;
  padding: min(2.65vw,40px);
  border-radius: min(0.66vw,10px);
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .solar-panel .caution {
    max-width: 100%;
    padding: 5.20833vw;
    border-radius: 1.30208vw;
  }
}

.solar-panel .caution .ttl {
  font-size: min(1.59vw,24px);
  padding-left: min(3.17vw,48px);
  position: relative;
}

@media screen and (max-width: 768px) {
  .solar-panel .caution .ttl {
    font-size: 4.6875vw;
    padding-left: 8.33333vw;
  }
}

.solar-panel .caution .ttl span {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(20%, #ffecae));
  background: -webkit-linear-gradient(transparent 60%, #ffecae 20%);
  background: -o-linear-gradient(transparent 60%, #ffecae 20%);
  background: linear-gradient(transparent 60%, #ffecae 20%);
}

.solar-panel .caution .ttl::before {
  content: '';
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  width: min(2.12vw,32px);
  height: min(1.85vw,28px);
  background: url(../img/service/solar-panel/icon_caution.png) left top/contain no-repeat;
}

@media screen and (max-width: 768px) {
  .solar-panel .caution .ttl::before {
    width: 6.25vw;
    height: 5.46875vw;
  }
}

.solar-panel .caution .text {
  margin-top: min(1.59vw,24px);
}

@media screen and (max-width: 768px) {
  .solar-panel .caution .text {
    margin-top: 3.125vw;
  }
}

.solar-panel .caution .text p span {
  color: #FF4B4B;
  text-decoration: underline;
}

.solar-panel .caution .text p.division {
  font-weight: 500;
}

.solar-panel .caution .text p + p {
  margin-top: min(1.59vw,24px);
}

@media screen and (max-width: 768px) {
  .solar-panel .caution .text p + p {
    margin-top: 3.125vw;
  }
}

.solar-panel .tokyo_plan {
  margin-top: min(3.7vw,56px);
}

@media screen and (max-width: 768px) {
  .solar-panel .tokyo_plan {
    margin-top: 10.41667vw;
  }
}

.solar-panel .tokyo_plan .col2 {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: start;
}

.solar-panel .tokyo_plan .col2 .text {
  width: 63.83%;
}

@media screen and (max-width: 768px) {
  .solar-panel .tokyo_plan .col2 .text {
    width: 100%;
  }
}

.solar-panel .tokyo_plan .col2 .text p.border_ttl {
  font-size: min(0.99vw,15px);
  font-weight: 500;
}

@media screen and (max-width: 768px) {
  .solar-panel .tokyo_plan .col2 .text p.border_ttl {
    font-size: 3.64583vw;
  }
}

.solar-panel .tokyo_plan .col2 .text p.border_ttl span {
  display: inline-block;
}

.solar-panel .tokyo_plan .col2 .text p span.red {
  font-size: min(1.12vw,17px);
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .solar-panel .tokyo_plan .col2 .text p span.red {
    font-size: 3.90625vw;
  }
}

.solar-panel .tokyo_plan .col2 .img {
  width: 29.79%;
}

@media screen and (max-width: 768px) {
  .solar-panel .tokyo_plan .col2 .img {
    width: 100%;
    text-align: center;
    margin-top: 5.20833vw;
  }
  .solar-panel .tokyo_plan .col2 .img img {
    width: 70%;
  }
}

@media screen and (max-width: 768px) {
  .solar-panel .tokyo_plan .img_price {
    margin-top: 5.20833vw;
  }
}

.solar-panel .tokyo_plan .img_price div + div {
  margin-top: min(1.59vw,24px);
}

@media screen and (max-width: 768px) {
  .solar-panel .tokyo_plan .img_price div + div {
    margin-top: 5.20833vw;
  }
}

.solar-panel .tokyo_plan .note {
  margin-top: min(1.59vw,24px);
  font-size: min(0.86vw,13px);
}

@media screen and (max-width: 768px) {
  .solar-panel .tokyo_plan .note {
    margin-top: 5.20833vw;
    font-size: 3.125vw;
  }
}

.solar-panel .tokyo_plan .note .ast li {
  text-indent: -2.2em;
  margin-left: 2.2em;
}

.solar-panel .tokyo_plan .note .disc {
  margin-top: min(1.06vw,16px);
}

@media screen and (max-width: 768px) {
  .solar-panel .tokyo_plan .note .disc {
    margin-top: 3.125vw;
  }
}

.solar-panel .tokyo_plan .note .disc li {
  list-style: disc;
  margin-left: 1.5em;
}

.solar-panel .tokyo_plan .note p {
  margin-top: min(1.06vw,16px);
}

@media screen and (max-width: 768px) {
  .solar-panel .tokyo_plan .note p {
    margin-top: 3.125vw;
  }
}

.solar-panel .tokyo_plan .step {
  margin-top: min(3.7vw,56px);
}

@media screen and (max-width: 768px) {
  .solar-panel .tokyo_plan .step {
    margin-top: 10.41667vw;
  }
}

.solar-panel .tokyo_plan .step .ttl {
  font-size: min(1.12vw,17px);
  font-weight: 700;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .solar-panel .tokyo_plan .step .ttl {
    font-size: 3.90625vw;
  }
}

.solar-panel .tokyo_plan .step .img {
  margin-top: min(1.06vw,16px);
}

@media screen and (max-width: 768px) {
  .solar-panel .tokyo_plan .step .img {
    margin-top: 3.125vw;
  }
}

.solar-panel .flyer {
  margin-top: min(3.7vw,56px);
}

@media screen and (max-width: 768px) {
  .solar-panel .flyer {
    margin-top: 10.41667vw;
  }
}

.solar-panel .flyer .ttl {
  font-size: min(1.32vw,20px);
  font-weight: 700;
  text-align: center;
  color: #2FA350;
}

@media screen and (max-width: 768px) {
  .solar-panel .flyer .ttl {
    font-size: 3.90625vw;
  }
}

.solar-panel .flyer .col3 {
  display: -webkit-box;
  /*Android4.3*/
  display: -ms-flexbox;
  /*IE10*/
  display: -webkit-flex;
  /*PC-Safari,iOS8.4*/
  display: flex;
  -ms-flex-pack: justify;
  /*IE10*/
  -webkit-box-pack: justify;
  /* Android4.3以下、Safari3.1〜6.0 */
  -webkit-justify-content: space-between;
  /* Safari6.1以降 */
  justify-content: space-between;
  max-width: min(52.91vw,800px);
  margin: min(1.06vw,16px) auto 0;
}

@media screen and (max-width: 768px) {
  .solar-panel .flyer .col3 {
    max-width: 100%;
    margin-top: 2.08333vw;
  }
}

.solar-panel .flyer .col3 li {
  width: 30%;
}

.solar-panel .flyer .col3 li a:hover img {
  -webkit-transform: scale(1.07);
  -ms-transform: scale(1.07);
  transform: scale(1.07);
}

@media screen and (max-width: 768px) {
  .solar-panel .flyer .col3 li a:hover img {
    -webkit-transform: inherit;
    -ms-transform: inherit;
    transform: inherit;
  }
}

.solar-panel .other_plan {
  border-top: 1px solid #eaeaea;
  margin-top: min(5.29vw,80px);
  padding-top: min(5.29vw,80px);
}

@media screen and (max-width: 768px) {
  .solar-panel .other_plan {
    border-top: 0.26042vw solid #eaeaea;
    margin-top: 10.41667vw;
    padding-top: 10.41667vw;
  }
}

.solar-panel .other_plan .text .border_ttl {
  font-weight: 500;
  margin: min(1.59vw,24px) 0 min(0.53vw,8px);
}

@media screen and (max-width: 768px) {
  .solar-panel .other_plan .text .border_ttl {
    margin: 5.20833vw 0 2.08333vw;
  }
}

.solar-panel .other_plan .text .border_ttl span {
  font-size: min(1.12vw,17px);
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .solar-panel .other_plan .text .border_ttl span {
    font-size: 3.90625vw;
  }
}

.solar-panel .other_plan .use {
  margin-top: min(5.29vw,80px);
}

@media screen and (max-width: 768px) {
  .solar-panel .other_plan .use {
    margin-top: 15.625vw;
  }
}

.solar-panel .other_plan .use .wrap_ttl span::before {
  background: url(../img/service/solar-panel/icon_other_plan.png) left top/contain no-repeat;
}

.solar-panel .other_plan .use .col2 {
  -ms-flex-wrap: wrap;
  /*IE10*/
  -webkit-flex-wrap: wrap;
  /*PC-Safari,iOS8.4*/
  flex-wrap: wrap;
  margin-top: min(3.7vw,56px);
}

@media screen and (max-width: 768px) {
  .solar-panel .other_plan .use .col2 {
    margin-top: 5.20833vw;
    padding: 0;
  }
}

.solar-panel .other_plan .use .col2 li {
  width: 48%;
}

@media screen and (max-width: 768px) {
  .solar-panel .other_plan .use .col2 li {
    width: 100%;
  }
}

.solar-panel .other_plan .use .col2 li .img {
  width: 100%;
}

.solar-panel .other_plan .use .col2 li .img + p {
  margin-top: min(0.53vw,8px);
  font-size: min(1.12vw,17px);
  font-weight: 700;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .solar-panel .other_plan .use .col2 li .img + p {
    margin-top: 1.04167vw;
    font-size: 3.64583vw;
  }
}

@media screen and (max-width: 768px) {
  .solar-panel .other_plan .use .col2 li + li {
    margin-top: 7.29167vw;
  }
}

.solar-panel .other_plan .use .col2 li:not(:last-child) {
  position: relative;
}

@media screen and (max-width: 768px) {
  .solar-panel .other_plan .use .col2 li:not(:last-child) {
    margin-bottom: 10.41667vw;
  }
}

.solar-panel .other_plan .use .col2 li:not(:last-child)::after {
  content: '';
  display: inline-block;
  position: absolute;
  top: 45%;
  right: -22px;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 8px 0px 8px 10px;
  border-color: transparent transparent transparent #2FA350;
}

@media screen and (max-width: 768px) {
  .solar-panel .other_plan .use .col2 li:not(:last-child)::after {
    top: inherit;
    right: inherit;
    bottom: -6.25vw;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    -ms-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    border-width: 4.16667vw 6.51042vw 0px 6.51042vw;
    border-color: #2FA350 transparent transparent transparent;
  }
}

.solar-panel .chikudenchi {
  border-top: 1px solid #eaeaea;
  margin-top: min(5.29vw,80px);
  padding-top: min(5.29vw,80px);
}

@media screen and (max-width: 768px) {
  .solar-panel .chikudenchi {
    border-top: 0.26042vw solid #eaeaea;
    margin-top: 10.41667vw;
    padding-top: 10.41667vw;
  }
}

.solar-panel .chikudenchi .wrap_ttl {
  margin-top: min(3.7vw,56px);
}

@media screen and (max-width: 768px) {
  .solar-panel .chikudenchi .wrap_ttl {
    margin-top: 15.625vw;
  }
}

.solar-panel .chikudenchi .wrap_ttl span::before {
  background: url(../img/service/solar-panel/icon_chikudenchi.png) left top/contain no-repeat;
}

.solar-panel .chikudenchi .col2 {
  margin-top: min(1.59vw,24px);
}

@media screen and (max-width: 768px) {
  .solar-panel .chikudenchi .col2 {
    margin-top: 3.125vw;
  }
}

.solar-panel .chikudenchi .col2 .text {
  width: 59.57%;
}

@media screen and (max-width: 768px) {
  .solar-panel .chikudenchi .col2 .text {
    width: 100%;
  }
}

.solar-panel .chikudenchi .col2 .text p span {
  font-weight: 700;
}

.solar-panel .chikudenchi .col2 .text p + p {
  margin-top: min(1.06vw,16px);
}

@media screen and (max-width: 768px) {
  .solar-panel .chikudenchi .col2 .text p + p {
    margin-top: 3.125vw;
  }
}

.solar-panel .chikudenchi .col2 .img {
  width: 38.3%;
}

@media screen and (max-width: 768px) {
  .solar-panel .chikudenchi .col2 .img {
    width: 100%;
  }
}

.solar-panel .contact {
  margin-top: min(2.65vw,40px);
}

@media screen and (max-width: 768px) {
  .solar-panel .contact {
    margin-top: 10.41667vw;
  }
}

.solar-panel .contact .contact_wrap {
  padding: min(2.65vw,40px) !important;
}

@media screen and (max-width: 768px) {
  .solar-panel .contact .contact_wrap {
    padding: 5.20833vw !important;
  }
}

.solar-panel .contact .contact_wrap .tel_ttl {
  font-size: min(1.12vw,17px);
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .solar-panel .contact .contact_wrap .tel_ttl {
    font-size: 3.64583vw;
  }
}

.solar-panel .contact .contact_wrap .tel {
  margin-top: min(0.53vw,8px) !important;
}

@media screen and (max-width: 768px) {
  .solar-panel .contact .contact_wrap .tel {
    margin-top: 1.04167vw !important;
  }
}

.solar-panel .contact .contact_wrap .division {
  font-weight: 700;
  margin-top: min(1.06vw,16px);
}

@media screen and (max-width: 768px) {
  .solar-panel .contact .contact_wrap .division {
    margin-top: 2.08333vw;
    font-size: 2.86458vw;
  }
}
