@charset "UTF-8";

/* 電気代にお悩みの事業者様へ SP
--------------------------------------*/
.worry-wrap{
  padding: 5rem 1.5rem 3.5rem;
  background: #f5f5f5;
}
.worry-wrap section{
  max-width: 120rem;
  margin: 0 auto;
}
.worry-wrap section h2{
  padding: 0 0 3.5rem;
}
.worry-content{
  display: flex;
  flex-wrap: wrap;
  justify-content:center;
  flex-direction: column;
}
.worry-content article{
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  width: auto;
  margin: 0 0 1.5rem;
  padding: 2rem 0 0;
  background: #fff;
  border-radius: 1rem;
  position: relative;
}
.worry-content article::before{
  content: url('../img/worry-icon-check.svg');
  display: block;
  width: 4rem;
  height: 4rem;
  background: var(--gn);
  border-radius: 0 0 2rem 0; 
  position: absolute;
  left: 0;
  top:0;
}

.worry-content article figure{
  width: 15rem;
  height: auto;
}
.worry-content article figure img{
  display: block;
  width: 8rem;
  margin: 0 0 0 4rem;
}
.worry-content article:first-child figure img{
  width: 8rem;
}
.worry-content article:last-child figure img{
  width: 11rem;
  padding: 1rem 0 0;
}
.worry-content article p{
  width: calc(100% - 15rem);
  padding: 0 1rem 2rem 0;
  font-size: 1.6rem;
  font-weight: bold;
  text-align: left;
}
.worry-content article p.w-sp{display: block;}
.worry-content article p.w-pc{display: none;}

.worry-content article p.w-sp br{
  display: block;
}
@media screen and (min-width:480px) {
  .worry-content article p{
    padding: 0 3rem 2rem 0;
  }
  .worry-content article p.w-sp  br{
    display: none;
  }
}


/* エネパルで解決 SP
---------------------------------*/
.solution{
  padding: 8rem 1rem 0;
  background: #e8f3dd url(../img/solution-bg-pc.png) no-repeat center top;
  background-size: 75rem;  
  font-family: "Noto Sans JP", sans-serif;
}
.solution section h2{
  max-width: 30rem;
  margin: 0 auto;
  padding: 0 0 3rem;
}

.solution-content{
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  justify-content: space-between;
}
.solution-content article{
  max-width:60rem;
  margin: 0 auto 4rem;
  padding: 3rem 1.8rem;
  border-radius: 1rem;
  background: #fff;
  position: relative;
}
/* 吹き出し SP -------- */
.solution-content article p.solu-coment2{
  width: 31.5rem;
  position: absolute;
  top: -25px;
  right: 0;
}
.solution-content article p.solu-coment4{
  width: 11.2rem;
  position: absolute;
  top: -10px;
  right: 0;
}

/* 解決ナンバー SP ------------------------- */
.solution-content article dl.solu-no{
  display: flex;
  margin: 0 0 2rem;
}
.solution-content article dl.solu-no dt{
  padding: 0 1rem 0 0;  
  line-height: 1;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--dgn);
}
.solution-content article dl.solu-no dt span{
  display: block;
  padding: 0.5rem 0 0;
  font-family: 'Roboto', sans-serif;
  font-size: 3.6rem;
  font-weight: 500;
}
.solution-content article dl.solu-no dd{
  padding: 0.2rem 0 0 1rem;
  line-height: 0.8;
  border-left: 1px solid #bbb;
  font-size: 1.6rem;
  font-weight: bold;
}
.solution-content article dl.solu-no dd span{
  display: block;  
  padding: 1rem 0 0;
  line-height: 1.2;
  font-size: 2.4rem;
  color: var(--dgn);
}
.solution-content article dl.solu-no dd span span{
  display: inline;
  color: #000;
}
.solution-content article dl.solu-no dd span small{
  font-size: 2.2rem;  
}

/* 写真下テキスト SP ------------------------- */
.solution-content p.solu-ttl{
  padding: 2rem 0;
  text-align: center;
  font-size: 1.6rem;
}
.solution-content p.solu-ttl span{
  display: block;
  padding: 0.5rem 0 0;
  line-height: 1.6;
  font-size: 2rem;
  font-weight: bold;
  color: var(--dgn);
}
.solution-content article:nth-child(2) p.solu-ttl strong,
.solution-content article:nth-child(3) p.solu-ttl strong,
.solution-content article:last-child p.solu-ttl strong{
  padding:0 0.2rem;
  font-size: 1.8rem;
  font-weight: bold;
  color: var(--dgn);
}
.solution-content article:last-child p.solu-ttl span{
  font-size: 1.98rem;
}


/* 内容-共通 SP ------------------------- */
.solu-bg{
  background: var(--lgn);
}
/* 内容-01 SP ------------------------- */
.solu-01{
  padding: 1.5rem;
}
.solu-01 h3{
  width: 24.4rem;
  margin: 0 auto;
  padding: 0 0 2rem;
}
.solu-01 ol li{  
  display: flex;
  align-items: center;  
  margin: 0 0 1rem;
  border: 1px solid var(--dgn);
  background: #fff;
}
.solu-01 ol li span{
  display: block;
  font-family: 'Roboto', sans-serif;
  font-weight: bold;
}
.solu-01 ol li span:first-child{
  width: 5.4rem;
  padding: 1rem 0;
  text-align: center;
  color: #ff0;
  background: var(--dgn);
  font-size: 3.6rem;
}
.solu-01 ol li span:last-child{
  width: calc(100% - 5.4rem);
  line-height: 1.5;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-size: 1.6rem;
  padding: 0 1.5rem;
  color: var(--dgn);
}

/* 内容-02 SP ------------------------- */
.solu-02{
  display: flex;
  flex-direction: column;  
  align-items: stretch;
  padding: 2rem;
}
.solu-02 p{
  width: auto;
}
.solu-02 p:first-child span{
  display: block;
  width: auto;
  height: auto;
  padding: 1rem;
  border-radius: 1rem;
  background: #fff;
}
.solu-02 p:first-child img{
  display: block;
  width: 10.8rem;
  margin: 0 auto;
}
.solu-02 p:last-child{
  padding: 1.5rem 0 0;
  line-height: 1.6;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-size: 1.6rem;
  font-weight: bold;
}

/* 内容-03 SP ------------------------- */
.solu-03 ol{
  padding: 3rem 2rem 1.5rem;
}
.solu-03 ol li{
  margin: 0 0 1.5rem;
  padding: 0 0 0 2rem;
  line-height: 1.6;
  font-size: 1.6rem;
  font-weight: bold;  
  position: relative;
}
.solu-03 ol li span {
  font-size: 1.4rem;
  color: #f00;
  margin-left: -0.5em;
}
.solu-03 ol li::before{
  content: "";
  width: 0.8rem;
  height: 0.8rem;
  border-radius: 50%;
  background: var(--dgn);
  position: absolute;
  left: 0;
}
.solu-03 ol li:first-child::before{
  top: 18%;
}
.solu-03 ol li:last-child::before{
  top: 30%;
}
.solu-03 ol + p{
  padding: 2rem 1.5rem 0;
  line-height: 1.5;
  font-size: 1.8rem;
  font-weight: bold;
  color: var(--gn);      
}
.solu-03 ol + p span{
  display: block;
  padding: 0.5rem 0 0;
  font-size: 1.2rem;
  font-weight: 500;
  color: #000;  
}
.solu-03 ol + p span small{
  color: #f00;
}

/* 内容-04 SP ------------------------- */
.solu-04 dl{
  display: flex;
  align-items: center;
  margin: 0 0 1rem;
  padding: 1.5rem 0;
  border: 1px solid #ccc;
  border-radius: 1rem;
}
.solu-04 dl:last-child{
  margin: 0;
}
.solu-04 dl dt{
  width: 10rem; 
}
.solu-04 dl dt img{
  display: block;
  margin: 0 auto;
}
.solu-04 dl:first-child dt img{
  width: 6.8rem;
}
.solu-04 dl:nth-child(2) dt img{
  width: 5.7rem;
}
.solu-04 dl:last-child dt img{
  width: 5rem;
}
.solu-04 dl dd{
  width: calc(100% - 10rem);
  padding: 0 1.5rem;
  border-left: 1px solid #ccc;
}
.solu-04 dl dd h3{
  font-size: 1.8rem;
  font-weight: bold;
  color: var(--dgn);
}
.solu-04 dl dd h3 span{
  display: block;
  padding: 0;
  line-height: 1;
  font-size: 1.4rem;
  font-weight: 400;
  color: #333;
}
.solu-04 dl dd p{
  padding: 1rem 0 0;  
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.5;
}
.solu-04 dl dd p br{
  display: block;
}
@media screen and (min-width:420px) {
  .solu-04 dl dt{
    width: 12rem; 
  }
  .solu-04 dl dd{
    width: calc(100% - 12rem);
    padding: 0 1.5rem;
    border-left: 1px solid #ccc;
  }
  .solu-04 dl dd p br{
    display: none;
  }
}


/* 開始6ヵ月で15000件 SP
---------------------------------*/
.solution-bnn{
  padding: 2.5rem 0;
}
.solution-bnn-bg{
  border-radius: 0;
  background: #44bd63;
}
.solution-bnn-content{
  display: flex;
  flex-direction: column;
  padding: 22.5rem 1.5rem 0;
  background: none;
  position: relative;
}
.solution-bnn-content figure.solu-graph{
  width: 100%;
  position: absolute;
  top: -5px;
  left: 0;
}
.solution-bnn-content figure.solu-graph img{
  display: block;
  width: 31.4rem;
  margin: 0 auto;
  padding: 0;
}

.solution-bnn-ttl{
  width: auto;
  margin: 0 1rem 2rem;
  padding: 7rem 0 0;
  position: relative; 
}
.solution-bnn-ttl figure{
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.solution-bnn-ttl figure img{
  display: block;
  max-width: 32.4rem;
  margin: 0 auto;  
}
.solution-bnn-ttl figure + p{
  display: block;
  max-width: 60rem;
  margin: 0 auto;
  padding: 2rem;
  border-radius: 0.5rem;
  text-align: left;
  color: #fff;
  font-size: 1.6rem;
  font-weight: bold;
  background: var(--dgn);
}
.solution-bnn-ttl figure + p span{
  color: #ff0;
}
.solution-bnn-ttl p.solu-anv{
  display: none;
}

.solution-bnn-ph{
  display: block;
  padding: 0 2rem 0 0;
  position: relative;
}
.solution-bnn-ph figure{
  max-width: 62rem;
  margin: 0 auto;
}
.solution-bnn-ph p{
  color: #fff;
  font-size: 1rem;
}
.solution-bnn-ph p:first-of-type{
  writing-mode: vertical-rl;
  position: absolute;
  bottom: 0;
  right: 0;
}
.solution-bnn-ph p:last-of-type{
  position: absolute;
  bottom: 0.5rem;
  right: 9%;
}
.solution-bnn-check{
  padding: 0.5rem 1rem 0;
  text-align: right;
  color: #444;
  font-size: 1.2rem;
  font-weight: 400;
  background: #fff;
}
@media screen and (min-width:600px) {
  .solution-bnn-content{
    padding: 30rem 1.5rem 0; 
  }
  .solution-bnn-content figure.solu-graph img{
    width: 42rem;
  }
  .solution-bnn-ttl{
    margin: 0 1rem 2rem;
    padding: 10rem 0 0;
  }
  .solution-bnn-ttl figure img{
    max-width: 42rem;
  }
  .solution-bnn-ttl figure + p{
    text-align: center;
  }

}

/* エネパルで解決 SP
-------------------------*/
#case {
  background: #e6f1fd url(../img/case-bg.png) no-repeat center bottom;
  background-size: cover;
  padding: 5rem 0;
}

.case {
  max-width: 143rem;
  margin: 0 auto;
  padding: 0 1.5rem;
}
.case h2 {
  line-height: 1.4;
}
.case h2 picture {
  display: block;
  max-width: 67rem;
  margin: 0 auto;;
}
.case h2 span {
  display: block;
  padding: 1.5rem 0 2rem;
}

.case-typeG h3 {
  text-align: center;
  margin-bottom: 2rem;
}
.case-typeG h3 span {
  display: inline-block;
  background: #fff;
  font-size: 1.8rem;
  color: var(--or);
  font-weight: 700;
  padding: 0.2rem 1.7rem 0;
  border: 0.1rem var(--or) solid;
}

.case-box {
  max-width: 40rem;
  background: #fff;
  padding: 3rem 1.5rem 4.5rem;
  border-radius: 0.5rem;
  box-shadow: 0 0.2rem 0.5rem #999;
  margin: 0 auto 2.3rem;
}
.case-box h4 {
  font-size: 2.1rem;
  text-align: center;
  line-height: 1;
  margin-bottom: 2.4rem;
}
.case-box figure {
  border-radius: 0.5rem;
  overflow: hidden;
  margin-bottom: 1.5rem;
}
.case-box p {
  text-align: center;
}
.case-box p.cut {
  max-width: 29rem;
  margin: 0 auto 0.5rem;
}
.case-box dl {
  display: flex;
  justify-content: space-around;
  align-items: center;
  font-size: 1.4rem;
  font-weight: 400;
  text-align: center;
  padding: 0.5rem 0;
  border-top: 0.1rem #ddd solid;
  border-bottom: 0.1rem #ddd solid;
  margin: 2rem 0 0;
}
.case-box dt {
  width: 38%;
}
.case-box dd {
  width: 62%;
  border-left: 0.1rem #ddd solid;
  padding-left: 2rem;
}
.case-box dd span {
  display: inline-block;
  text-align: left;
}

.case-note {
  text-align: right;
}
.case-note ul {
  display: inline-block;
  background: rgba(255, 255, 255, 0.7);
  text-align: left;
  padding: 2rem;
}
.case-note li {
  font-size: 1.2rem;
  padding-left: 1.1em;
  position: relative;
}
.case-note li::before {
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
}


/* ご利用状況にあったプラン例 SP
-----------------------------*/
.plan-wrapper {
  background: var(--lgn);
  padding: 5rem 0;
}
.plan h2 span {
  display: inline-block;
  background: var(--or);
  font-size: 1.8rem;
  color: #fff;
  padding: 0.2rem 0.7rem 0 1.2rem;
  border-radius: 2rem;
  margin-bottom: 1rem;
}

.plan .tab {
  margin-top: 3rem;
}

/* ----- タブリスト ----- */
.plan .tab-list {
  display: flex;
  justify-content: space-between;
  max-width: 143rem;
  text-align: center;
  border-bottom: 0.1rem #bbb solid;
  padding: 0 1.5rem;
  margin: 0 auto;
}
.plan .tab-list li {
  width: 32%;
  background: #fff;
  font-family: 'Zen Kaku Gothic Antique', sans-serif;
  font-size: 1.6rem;
  font-weight: 500;
  text-align: left;
  line-height: 1.4;
  vertical-align: bottom;
  padding: 0.5rem;
  border: 0.1rem #bbb solid;
  border-bottom: none;
  border-radius: 0.5rem 0.5rem 0 0;
  cursor: pointer;
  position: relative;
}
.plan .tab-list li span {
  display: block;
  font-size: 1.2rem;
}
.plan .tab-list li.active {
  background: var(--gn);
  color: #fff;
}
.plan .tab-list li::after {
  content: url(../img/plan-active.svg);
  display: block;
  width: 2rem;
  height: 50rem;
  position: absolute;
  left: 50%;
  transform: translate(-50% , -10%);
  opacity: 0;
  transition: .5s;
}
.plan .tab-list li.active::after {
  transform: translate(-50% , 1%);
  opacity: 1;
}


/* ----- タブコンテンツ ----- */
.plan .tab-contents-wrap {
  max-width: 143rem;
  margin: 2rem auto 0;
}

.plan .tab-content {
  display: none;
}
.plan .tab-content.open {
  display: block;
}
.plan .tab-content {
  background: #f8f8f8;
  padding: 5rem 2.5rem;
}
.plan .tab-content .content-head-lead {
  padding-left: 1.5rem;
  border-left: 0.3rem var(--gn) solid;
}
.plan .tab-content .content-head-lead h3 {
  font-size: 2.2rem;
  color: var(--gn);
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: 1.5rem;
}
.plan .tab-content .content-head-lead p {
  line-height: 1.5;
}
.plan .tab-content .customer-type {
  display: flex;
  background: #fff;
  border: 0.2rem #d2dfc6 solid;
  margin-top: 1.5rem;
}
.plan .tab-content .customer-type figure {
  width: 40%;
  text-align: center;
  align-content: center;
  padding: 1rem;
}
.plan .tab-content .head01 .customer-type figure img {
  width: 8rem;
}
.plan .tab-content .head02 .customer-type figure img {
  width: 8.3rem;
}
.plan .tab-content .head03 .customer-type figure img {
  width: 10rem;
}
.plan .tab-content .customer-type p {
  width: 60%;
  background: var(--lgn);
  text-align: center;
  align-content: center;
  line-height: 1.5;
  padding: 1rem 1.5rem;
}
.plan .tab-content .customer-type p span {
  display: inline-block;
  text-align: left;
}
.plan .tab-content .head01 .customer-type p span {
  padding: 1.7rem 0;
}

.plan .tab-content .plan-detail {
  max-width: 120rem;
  margin: 0 auto;
}
.plan .tab-content .plan-detail .suggest {
  background: #fff;
  margin-top: 3.5rem;
  padding: 4.5rem 1.5rem 1.5rem;
  border: 0.1rem #ccc solid;
  text-align: center;
  position: relative;
}
.plan .tab-content .plan-detail .suggest h4 {
  background: #2eae9c;
  color: #fff;
  font-weight: 700;
  white-space: nowrap;
  padding: 0.5rem 1.7rem;
  position: absolute;
  top: -1.5rem;
  left: 50%;
  transform: translateX(-50%);
}
.plan .tab-content .plan-detail .suggest.suggest02 h4 {
  background: var(--dgn);
}
.plan .tab-content .plan-detail .suggest h4 strong {
  font-size: 1.8rem;
  color: #ff0;
  margin: 0 0.5em;
  border-bottom: 0.2rem #ff0 dashed;
}
.plan .tab-content .plan-detail .suggest dt {
  font-size: 1.8rem;
  font-weight: 700;
}
.plan .tab-content .plan-detail .suggest dd {
  font-size: 2.1rem;
  color: var(--or);
  font-weight: 700;
}
.plan .tab-content .suggest .cost-image figure {
  width: 24rem;
  margin: 2rem auto 1rem;
}
.plan .tab-content .suggest.suggest02 .cost-image figure {
  width: 26rem;
}
.plan .tab-content .suggest .cost-image p {
  font-size: 1.8rem;
  border-radius: 0.5rem;
  margin-bottom: 0.5rem;
}
.plan .tab-content .suggest .cost-image .cost-reasonable {
  background: var(--gn);
  color: #fff;
  padding: 0.2rem 0 0;
}
.plan .tab-content .suggest .cost-image .cost-regular {
  background: var(--lgn);
  color: var(--gn);
  padding: 2.5rem 0;
}
.plan .tab-content .suggest .cost-image .cost-other {
  color: var(--gn);
  padding: 0.2rem 0 0;
  border: 0.1rem #d1e2d5 solid;
}

.plan .tab-content .plan-detail .note {
  padding-top: 0.5rem;
}
.plan .tab-content .plan-detail .note li {
  font-size: 1.2rem;
  line-height: 1.6;
  margin-top: 1.5rem;
  padding-left: 1.2em;
  position: relative;
}
.plan .tab-content .plan-detail .note li::before {
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
}
.plan .tab-content .plan-detail figure {
  margin: 2.5rem 0 3.5rem;
}

.plan .tab-content .plan-detail .balloon-box {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 3.5rem;
}
.plan .tab-content .plan-detail .balloon-box figure {
  width: 12rem;
  margin: 0;
}
.plan .tab-content .plan-detail .balloon {
  display: inline-block;
  background: #fff;
  margin-left: 4rem;
  padding: 2.5rem 1.5rem;
  border: 0.1rem solid #bbb;
  border-radius: 0.5rem;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
}
.plan .tab-content .plan-detail .balloon::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  border-style: solid;
  border-width: 2rem 2.4rem 0 0;
  border-color: transparent #bbb transparent transparent;
  translate: -100% -50%;
}
.plan .tab-content .plan-detail .balloon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  border-style: solid;
  border-width: 1.77rem 2.12rem 0 0;
  border-color: transparent #fff transparent transparent;
  translate: -100% calc(-50% + 0.02rem);
}
.plan .tab-content .plan-detail .balloon p {
  text-align: center;
}
.plan .tab-content .plan-detail .balloon p span {
  display: block;
  text-align: left;
}

.plan .tab-content .plan-detail > dl {
  border-bottom: 0.1rem #ccc solid;
}
.plan .tab-content .plan-detail > dl dt {
  background: var(--lgn);
  text-align: center;
  padding: 1rem 1.5rem 0.5rem;
  border: 0.1rem #ccc solid;
}
.plan .tab-content .plan-detail > dl dd {
  background: #fff;
  font-size: 1.5rem;
  padding: 2rem;
  border-left: 0.1rem #ccc solid;
  border-right: 0.1rem #ccc solid;
}
.plan .tab-content .plan-detail > p {
  margin: 2rem 0 3rem;
}
.plan .tab-content .plan-detail > p a {
  position: relative;
}
.plan .tab-content .plan-detail > p a::after {
  content: "";
  display: block;
  width: 100%;
  height: 0.1rem;
  background: #cecece;
  position: absolute;
  bottom: 0.2rem;
  left: 0;
}
.plan .tab-content .plan-detail > p a:hover {
  color: var(--dgn);
}
.plan .tab-content .plan-detail > p a:hover::after {
  background: var(--dgn);
}

.plan .plan-set-wrap {
  padding: 3rem 1.5rem 0;
}
.plan .plan-set {
  max-width: 120rem;
  text-align: center;
  margin: 0 auto;
}
.plan .plan-set figure {
  background: #88d21c;
  padding: 3rem 5rem 2.5rem;
  border-radius: 1rem 1rem 0 0;
}
.plan .plan-set figure img {
  width: 24.5rem;
}
.plan .plan-set p {
  background: var(--gn);
  font-size: 2.6rem;
  color: #ff0;
  font-weight: 700;
  line-height: 1.5;
  padding: 3rem 3rem 4rem;
  border-radius: 0 0 1rem 1rem;
}
.plan .plan-set p span {
  display: block;
  font-size: 1.6rem;
  color: #fff;
  line-height: 1.8;
}


/* ご契約までの流れ SP
-------------------------*/
.flow-wrapper {
  background: #f5f5f5;
  padding: 5rem 1.5rem;
}
.flow {
  max-width: 140rem;
  margin: 0 auto;
}
.flow h2{
  padding: 0 0 7rem;
}

.flow .step-wrap {
  max-width: 60rem;
  margin: 0 auto;
}
.flow .step-box {
  background: #fff no-repeat center 5rem;
  background-size: 16rem;
  padding: 23.5rem 2rem 3.5rem;
  border-radius: 2rem;
  margin-bottom: 6.5rem;
  position: relative;
}
.flow .step-box:nth-child(1) {
  background-image: url(../img/flow-img01.svg);
}
.flow .step-box:nth-child(2) {
  background-image: url(../img/flow-img02.svg);
}
.flow .step-box:nth-child(3) {
  background-image: url(../img/flow-img03.svg);
  margin-bottom: 0;
}
.flow .step-box p.step-num {
  width: 14rem;
  height: 4.5rem;
  background: var(--gn);
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2.1rem;
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-align: center;
  line-height: 1;
  padding: 1.2rem 3rem;
  border-radius: 2.5rem;
  position: absolute;
  top: -2.2rem;
  left: 50%;
  transform: translateX(-50%);
}
.flow .step-box h3 {
  font-size: 2.1rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 1rem;
}
.flow .step-box::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border: 2.4rem transparent solid;
  border-top: 1.5rem #8cc456 solid;
  position: absolute;
  top: 104%;
  left: 50%;
  transform: translateX(-50%);
}
.flow .step-box:nth-child(3)::after {
  display: none;
}


/* よくある質問 SP
-------------------------*/
.faq-wrapper {
  background: var(--lgn);
  padding: 5rem 1.5rem;
}
.faq-wrapper section{
  max-width: 120rem;
  margin: 0 auto;
}
.faq-wrapper section h2{
  padding: 0 0 3rem;
}

#faq {
  max-width: 120rem;
  margin: 0 auto;
}
.faq-box {
  background: #fff;
  margin: 0 0 1rem;
  border-radius:1rem;
  overflow: hidden;
}

/* 質問 SP ----------------- */
.question {
  padding: 2.5rem 5rem 2.5rem 4.5rem;
  line-height: 1.6;
  cursor: pointer;
  background: #fff;
  font-size: 1.6rem;
  position: relative;
}
.question p {
  margin: 0 0 0 1rem;
  padding: 0 0 0 0.5rem;
  position: relative;
}
/* Q SP-------------------- */
.question p::before {
  content: "";
  display: block;
  width: 3rem;
  height: 3rem;
  text-align: center;
  background: var(--gn);
  border-radius: 50%;
  position: absolute;
  top: -0.2rem;
  left: -3.8rem;
}
.question p::after {
  content: "Q";
  color: #fff;
  font-size: 2.1rem;
  font-weight: bold;
  position: absolute;
  top: -0.5rem;
  left: -3.1rem;
}

/* +（開く） SP-------------------- */
.question::before, .question::after {
  content: "";
  display: block;
  background: var(--dgn);
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.question::before {
  width: 15px;
  height: 3px;
  right: 1.5rem;
}
.question::after {
  width: 3px;
  height: 15px;
  right: 2.1rem;
  opacity: 1;
  transition: .3s;
}
.question.active::after {
  opacity: 0;
}
/* 回答 SP ----------------- */
.answer {
  display: none;
  padding: 2rem 1.5rem 3rem;
  font-size: 1.6rem;
  background: #fff;
}
.answer p strong {
  color: #fcfc71;
  font-size: 1.4rem;
  font-weight: bold;
}

/* A SP-------------------- */
.answer {
  padding: 2.5rem 3.5rem 2.5rem 4.5rem;
  border-top: 1px solid #ccc;
  cursor: pointer;
  font-size: 1.6rem;
  position: relative;
}
.answer p {
  margin: 0 0 0 1rem;
  padding: 0 0 0 0.5rem;
  position: relative;
}
.answer p:first-child::before {
  content: "";
  display: block;
  width: 3rem;
  height: 3rem;
  text-align: center;
  background: var(--or);
  border-radius: 50%;
  position: absolute;
  top: -0.2rem;
  left: -3.8rem;
}
.answer p::after {
  content: "A";
  color: #fff;
  font-size: 2.1rem;
  font-weight: bold;
  position: absolute;
  top: -0.5rem;
  left: -3rem;
}
/* +（開く） SP-------------------- 
.answer::before, .answer::after {
  content: "";
  display: block;
  background: #fff;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}*/
.answer p span{
  display: block;
  font-size: 1.4rem;
}
.answer p span.qatime{
  font-size: 1.4rem;
}
.answer p a{
  display: block;
  padding: 0.5rem 0 0;
  text-decoration: underline;
  color: #000
}
.answer p a:hover{
  opacity: 1;
  color: var(--dgn);
}
.answer p:nth-child(n+2) {
  margin-top: 0.5em;
}

/* 電力ガイド SP ------- */
.answer p.qa-pdf{
  max-width: 54rem;
  padding: 1.5rem 0; 
}
.answer p.qa-pdf a img{
  display: block;
  border: 0.1rem solid #ccc;
  box-shadow: 0.5rem 0.5rem 0.5rem rgba(0, 0, 0, 0.1);
}
.answer p.qa-pdf a img{
  transition-duration: .2s;
}
.answer p.qa-pdf a:hover img{
   transform: scale(1.1);
}


/* ボタン SP -------------*/
.qa-btn{
  padding: 2rem 0 0;
}
.qa-btn a{
  display: block;
  width: 32rem;
  margin: 0 auto;
  padding: 1rem 0;
  text-align: center;
  border-radius: 0.5rem;
  border: 3px solid var(--red); 
  color: #fff;
  font-size: 1.6rem;
  font-weight: bold;
  background: var(--red) url(../img/icon-triangle-w.svg) no-repeat 94% center;
  background-size: 0.8rem;
  transition: 0.5s;
}
.qa-btn a:hover{
  color: var(--red);
  background: #fff url(../img/icon-triangle-red.svg) no-repeat 95% center;
  background-size: 0.8rem;
}


/* ご利用開始の流れ SP
-------------------------*/
.flow-wrap{
  padding: 5rem 3rem;
  background: var(--egray);  
}
.flow-wrap section h2{
  padding: 0 0 2rem;
  text-align: center;
  font-size: 2.4rem;
  font-weight: bold;  
}
/* 内容 SP --------------- */
.flow-content{
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border-top: 1px solid #ccc;
}
.flow-content article{
  width: auto;
  padding: 3rem;
  border-bottom: 1px solid #ccc;
  border-right: none;
  position: relative;
}
.flow-content article dl{
  display: flex;
  align-items: flex-end;
  margin: 0 0 2rem;
  padding: 0;
}
.flow-content article dl dt{
  line-height: 1;
  letter-spacing: 0.075em;
  font-family: "Outfit", sans-serif;
  font-size: 1.6rem;
}
.flow-content article dl dt span{
  display: block;
  letter-spacing: 0;
  font-size: 3rem;
  color: var(--red);
}
.flow-content article dl dd{
  line-height: 1;
  padding: 0 0 0.2rem 1rem;
  font-size: 2.1rem;
  font-weight: bold;
}
/* 画像 SP -------------*/
.flow-content figure{
  display: flex;
  align-items: stretch;  
  width: auto;
  height: auto;
  margin: 0 0 2rem;
  padding: 1.5rem 0;
  border-radius: 2rem;
  background: #fff;
}
.flow-content article figure img{
  display: block;
  margin: 0 auto;
}
.flow-content article:first-child figure img{
  width: 7.2rem;
}
.flow-content article:nth-child(2) figure img{
  width: 14rem;
}
.flow-content article:nth-child(3) figure img{
  width: 9rem;
}
.flow-content article:nth-child(4) figure img{
  width: 9rem;
}
.flow-content article:last-child figure img{
  width: 8rem;
}

/* 画像下テキスト SP -------------*/
.flow-content article figure + p{
  padding: 0 1.5rem;
  font-size: 1.6rem;
}
.flow-content article:first-child figure + p,
.flow-content article:nth-child(2) figure + p{
  padding: 0 2rem;
}
.flow-content figure + p span{
  color: var(--red);
  padding-block-end: 2px;  
  border-bottom: 1px solid var(--red);  
}
/* 進行矢印 SP --------------- */
.flow-content article p.flow-arr{
  width: 100%;
  position: absolute;
  bottom: -1rem;
  left: 0;
}
.flow-content article p.flow-arr img{
  display: block;
  width: 1.8rem;
  margin: 0 auto;
  text-align: center;
  transform: rotate(90deg);
}

/*----------------------------------------------------
SP用 374以下- 
----------------------------------------------------*/
@media screen and (max-width:374px) {

  .solution-content article dl.solu-no dd{
    font-size: 1.4rem;
  }

  /* ご利用状況にあったプラン例 SP374↓
  -------------------------*/
  .plan .tab-list li {
    font-size: 1.4rem;
  }
  .plan .tab-content .customer-type p {
    font-size: 1.4rem;
  }


}

/*----------------------------------------------------
SP用 400- 
----------------------------------------------------*/
@media screen and (min-width:400px) {

  /* ご利用状況にあったプラン例 SP400
  -------------------------*/
  .plan .tab-list li {
    padding: 0.5rem 1rem;
  }
  .plan .tab-content .content-head-lead h3 {
    font-size: 2.4rem;
  }

}

/*----------------------------------------------------
SP / タブレット用 600- 
----------------------------------------------------*/
@media screen and (min-width:600px) {

  /* エネパルで電気代が削減 600
  -------------------------*/
  .case-box-wrap {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .case-box {
    width: 49%;
  }

}

/*----------------------------------------------------
PC / タブレット用 750- 
----------------------------------------------------*/
@media screen and (min-width:750px) {

  /* 電気代にお悩みの事業者様へ 750
  --------------------------------------*/
  .worry-wrap{
    padding: 5rem 1.5rem 2rem;
  }
  .worry-content{
    flex-direction: row;
  }
  .worry-content article{
    flex-direction: column;
    align-items: stretch;
    width: 30%;
    margin: 0 1.66% 3rem;
    padding: 5rem 2.5rem;
  }

  .worry-content article figure{
    width: auto;
    height: 17rem;
  }
  .worry-content article figure img{
    width: 10rem;
    margin: 0 auto;
  }
  .worry-content article:first-child figure img{
    width: 10.6rem;
  }
  .worry-content article:last-child figure img{
    width: 13rem;
    padding: 0;
  }
  .worry-content article p{
    width: 100%;
    padding: 0;
    text-align: center;
  }

 /* エネパルで解決 750
  ---------------------------------*/
  .solution{
    background: #e8f3dd url(../img/solution-bg-pc.png) no-repeat center top;
    background-size: 100rem;  
  }

  /* 吹き出し SP -------- */
  .solution-content article p.solu-coment2{
    width:38rem;
    position: absolute;
    top: -15px;
    right: 0;
  }
  .solution-content article p.solu-coment4{
    width: 18rem;
    position: absolute;
    top: -10px;
    right: 0;
  }


/* ご利用状況にあったプラン例 750
  -------------------------*/
  .plan .tab-list li::after {
    transform: translate(-50% , -5%);
  }
  .plan .tab-list li.active::after {
    transform: translate(-50% , 1%);
  }
  .plan .tab-content .plan-detail .suggest-box {
    display: flex;
    justify-content: space-between;
  }
  .plan .tab-content .plan-detail .suggest {
    width: 48%;
  }
  
  .plan .tab-content .plan-detail .balloon-box figure {
    width: 15rem;
  }
  .plan .tab-content .plan-detail .balloon-box .balloon {
    flex-grow: 1;
    font-size: 2.1rem;
    text-align: left;
    padding: 3.5rem 5rem;
  }
  .plan .tab-content .plan-detail > dl {
    display: flex;
    flex-wrap: wrap;
    border-bottom: 0.1rem #ccc solid;
  }
  .plan .tab-content .plan-detail > dl dt {
    width: 19rem;
    text-align: left;
    align-content: center;
    border-bottom: none;
  }
  .plan .tab-content .plan-detail > dl dd {
    width: calc(100% - 19rem);
    font-size: 1.5rem;
    padding: 2rem;
    border-top: 0.1rem #ccc solid;
    border-left: none;
    border-right: 0.1rem #ccc solid;
  }
  .plan .tab-content .plan-detail > p {
    margin: 2rem 0 3rem;
  }
  .plan .tab-content .plan-detail > p a {
    position: relative;
  }
  .plan .tab-content .plan-detail > p a::after {
    content: "";
    display: block;
    width: 100%;
    height: 0.1rem;
    background: #cecece;
    position: absolute;
    bottom: 0.2rem;
    left: 0;
  }

  
  /* よくある質問 750
  -------------------------*/
  .faq-wrapper {
    padding: 10rem 1.5rem;
  }
  .faq-wrapper section h2{
    padding: 0 0 8rem;
    font-size: 3.6rem;
  }

  /* 質問 750 ----------------- */
  .question {
    padding: 3rem 7rem 3rem 5rem;
    font-size: 2.1rem;
  }
  .question p {
    margin: 0 1rem;
    padding: 0.6rem 0 0 2.5rem;
  }
  .question::before {
    width: 15px;
    height: 3px;
    right: 3rem;
  }
  .question::after {
    width: 3px;
    height: 15px;
    right: 3.6rem;
    opacity: 1;
    transition: .3s;
  }

  /* Q 750 ------------ */
  .question p::before {
    width: 4.6rem;
    height: 4.6rem;
    top: -0.2rem;
    left: -3.8rem;
  }
  .question p::after {
    font-size: 2.6rem;
    top: 0;
    left: -2.4rem;
  }

  /* 回答 750 ----------------- */
  .answer {
    padding: 3rem 7rem 3rem 5rem;
    font-size: 2.1rem;
  }
  .answer p {
    margin: 0 1rem;
    padding: 0.6rem 0 0 2.5rem;
  }
  .answer::before {
    width: 15px;
    height: 3px;
    right: 3rem;
  }
  .answer::after {
    width: 3px;
    height: 15px;
    right: 3.6rem;
    opacity: 1;
    transition: .3s;
  }

  .answer p span{
    font-size: 1.6rem;
  }
  .answer p span.qatime{
    display: inline;
    font-size: 1.6rem;
  }


  /* A 750 ------------ */
  .answer p:first-child::before {
    width: 4.6rem;
    height: 4.6rem;
    top: -0.2rem;
    left: -3.8rem;
  }
  .answer p::after {
    font-size: 2.6rem;
    top: 0;
    left: -2.4rem;
  }

  /* ボタン 750 -------------*/
  .qa-btn a{
    width: 34rem;
    margin: 0 0 0 auto;
    padding: 1rem 0;
    border: 3px solid var(--red);
    font-size: 1.8rem;
    background: var(--red) url(../img/icon-triangle-w.svg) no-repeat 96% center;
    background-size: 0.8rem;
  }
  .qa-btn a:hover{
    color: var(--red);
    background: #fff url(../img/icon-triangle-red.svg) no-repeat 97% center;
    background-size: 0.8rem;
  }

}


/*----------------------------------------------------
PC 1000- 
----------------------------------------------------*/
@media screen and (min-width:1000px) {

  /* 電気代にお悩みの事業者様へ 1000
  --------------------------------------*/
  .worry-wrap{
    padding: 10rem 1.5rem 0;
  }
  .worry-wrap section h2{
    padding: 0 0 8rem;
  }
  .worry-content article p.w-sp{display: none;}
  .worry-content article p.w-pc{display: block;}


  /* エネパルで解決 1000
  ---------------------------------*/
  .solution{
    padding: 12rem 1rem 0;
    background: #e8f3dd url(../img/solution-bg-pc.png) no-repeat center top;
    background-size: auto;  
  }

  .solution-content{
    flex-direction: row;
  }
  .solution-content article{
    max-width: 49%;
    margin: 0 0 5rem;
  }

  /* 開始6ヵ月で15000件 1000
  ---------------------------------*/
  .solution-bnn-content{
    flex-direction: row;
    padding: 0;
    background: url(../img/solution-bnn-ph.png) no-repeat 103% bottom;
    background-size: 30rem;
  }
  .solution-bnn-content figure.solu-graph{
    width: 31%;
    position: static;
  }
  .solution-bnn-content figure.solu-graph img{
    width: auto;
    margin: 0;
    padding: 2rem 0 0;
  }

  .solution-bnn-ttl{
    width: 46%;
    margin: 2.5% 0 0.5%;
    padding: 10.5rem 0 0;
  }
  .solution-bnn-ttl figure img{
    max-width: 100%;
    padding: 0 2%;
  }
  .solution-bnn-ttl figure + p{
    max-width: auto;
    margin: 0;
    padding: 1rem;
    font-size: 1.4rem;
  }
  .solution-bnn-ttl p.solu-anv{
    display: block;    
    padding: 0.5rem 0 0;
    line-height: 1.4;
    text-align: right;
    color: #fff;
    font-size: 1.2rem;
  }
  .solution-bnn-ph{
    display: none;
  }

  /* エネパルで電気代が削減 1000
  -------------------------*/
  #case {
    padding: 10rem 0;
  }
  .case-box-wrap {
    flex-wrap: nowrap;
  }
  .case-box {
    width: 24%;
  }
  .case-note li {
    font-size: 1.5rem;
  }

 /* ご利用状況にあったプラン例 1000
  -------------------------*/
  .plan-wrapper {
    padding: 10rem 0;
  }

  .plan .tab-list li {
    text-align: center;
  }
  .plan .tab-list li span {
    display: inline;
    font-size: 1.6rem;
    padding: 1rem;
  }

  .plan .tab-content .content-head {
    display: flex;
    justify-content: space-between;
  }
  .plan .tab-content .content-head-lead h3 {
    font-size: 3rem;
  }
  .plan .tab-content .customer-type {
    max-width: 28rem;
    width: 100%;
    margin: 0;
  }
  .plan .tab-content .head03 .customer-type {
    max-width: 35rem;
  }
  .plan .tab-content .customer-type figure {
    width: 35%;
  }
  .plan .tab-content .head03 .customer-type figure {
    width: 30%;
  }
  .plan .tab-content .customer-type p {
    width: 65%;
    padding: 1.2rem 1rem;
    font-size: 1.4rem;
  }
  .plan .tab-content .head03 .customer-type p {
    width: 70%;
    padding: 1.8rem 1rem
  }
  .plan .tab-content .customer-type p span {
    white-space: nowrap;
  }

  .plan .tab-content .plan-detail .suggest {
    margin-top: 7.5rem;
  }
  .plan .tab-content .plan-detail .note li {
    font-size: 1.4rem;
    font-weight: 400;
  }
  
  .plan .tab-content .plan-detail > dl dt {
    font-size: 1.8rem;
  }
  .plan .tab-content .plan-detail > dl dd {
    font-size: 1.7rem;
  }
  .plan .tab-content .plan-detail > p {
    font-size: 1.8rem;
  }


  .plan .plan-set-wrap {
    padding-top: 5rem;
  }
  .plan .plan-set {
    display: flex;
    justify-content: center;
  }
  .plan .plan-set figure {
    padding: 3rem 5rem 4rem;
    border-radius: 1rem 0 0 1rem;
  }
  .plan .plan-set figure img {
    max-width: 34rem;
  }
  .plan .plan-set p {
    font-size: 2.8rem;
    text-align: left;
    padding: 5rem;
    border-radius: 0 1rem 1rem 0;
  }

  /* ご契約までの流れ 1000
  -------------------------*/
  .flow-wrapper {
    padding: 10rem 1.5rem;
  }

  .flow .step-wrap {
    max-width: none;
    display: flex;
    justify-content: space-between;
  }
  .flow .step-box {
    width: 30%;
    margin-bottom: 0;
  }
  .flow .step-box::after {
    border-top: 2.4rem transparent solid;
    border-left: 1.5rem #8cc456 solid;
    position: absolute;
    top: 50%;
    left: 107%;
    transform: translateX(0);
    transform: translateY(-50%);
  }


  /* 電力ガイド 1000 ------- */
  .answer p.qa-pdf{
    max-width: 36rem;
    padding: 1.5rem 2.5rem;
  }



}



/*----------------------------------------------------
PC 1400- 
----------------------------------------------------*/
@media screen and (min-width:1200px) {

  .worry-wrap{
    padding: 10rem 0 0;
  }
  .worry-content article{
    margin: 0 1.66% 6rem;
  }

  /* 電気代にお悩みの事業者様へ 1200
  --------------------------------------*/
  .worry-content article p{
    font-size: 2.2rem;
  }

  /* 開始6ヵ月で15000件 1200
  ---------------------------------*/
  .solution-bnn-content{
    background: url(../img/solution-bnn-ph.png) no-repeat right bottom;
    background-size: 36rem;
  }
  .solution-bnn-ttl{
    padding: 12.5rem 0 0;
  }
  .solution-bnn-ttl figure + p{
    font-size: 1.6rem;
  }

 /* ご利用状況にあったプラン例 1200
  -------------------------*/
  .plan .tab-content .content-head-lead p {
    font-size: 1.8rem;
  }
  .plan .tab-content .customer-type p {
    padding: 1.4rem 1rem;
  }
  .plan .tab-content .head03 .customer-type p {
    padding: 2.1rem 1rem
  }
  .plan .tab-content .plan-detail .suggest {
    padding: 5.5rem 3rem 5rem;
  }
  .plan .tab-content .plan-detail .suggest h4 {
    font-size: 2rem;
  }
  .plan .tab-content .plan-detail .suggest h4 strong {
    font-size: 2.4rem;
  }
  .plan .tab-content .suggest .cost-image p {
    font-size: 2rem;
  }
  
  .plan .tab-content .plan-detail .balloon-box .balloon {
    font-size: 2.8rem;
    padding: 4.5rem 7rem;
  }

  .plan .plan-set p {
    font-size: 3.4rem;
    padding: 4rem 5rem;
  }
  .plan .plan-set p span {
    font-size: 2rem;
  }
 
 
}

/*----------------------------------------------------
PC 1400- 
----------------------------------------------------*/
@media screen and (min-width:1400px) {

  /* エネパルで解決 1400
  ---------------------------------*/
  .solution{
    padding: 16.5rem 1rem 5rem;
  }
  .solution section h2{
    max-width: 52rem;
    padding: 0 0 10rem;
  }
  .solution-content article{
    padding: 6rem 3rem;
  }

  /* 吹き出し 1400 -------- */
  .solution-content article p.solu-coment2{
    width: 54rem;
    position: absolute;
    top: -35px;
  }
  .solution-content article p.solu-coment4{
    width: 22.5rem;
    position: absolute;
    top: -10px;
  }
  
  /* 解決ナンバー 1400 ------------------------- */
  .solution-content article dl.solu-no{
    margin: 0 0 4rem;
  }
  .solution-content article dl.solu-no dt{
    padding: 0 1.5rem 0 0;  
    font-size: 1.8rem;
  }
  .solution-content article dl.solu-no dt span{
    padding: 0.5rem 0 0;
    font-size: 7rem;
  }
  .solution-content article dl.solu-no dd{
    padding: 0.2rem 0 0 2rem;
    font-size: 2.6rem;
  }
  .solution-content article dl.solu-no dd span{
    padding: 1rem 0 0;
    font-size: 4.2rem;
  }
  .solution-content article dl.solu-no dd span small{
    font-size: 4rem;  
  }

  /* 写真下テキスト 1400 ------------------------- */
  .solution-content p.solu-ttl{
    padding: 4rem 0;
    font-size: 2.4rem;
  }
  .solution-content p.solu-ttl span{
    padding: 0;
    line-height: 1.6;
    font-size: 3.2rem;
  }
  .solution-content article:nth-child(2) p.solu-ttl strong,
  .solution-content article:nth-child(3) p.solu-ttl strong,
  .solution-content article:last-child p.solu-ttl strong {
    font-size: 2.8rem;
  }
  .solution-content article:last-child p.solu-ttl span{
    font-size: 3.2rem;
  }

  /* 内容-01 1400 ------------------------- */
  .solu-01{
    padding: 2rem;
  }
  .solu-01 h3{
    width: 32.5rem;
    padding: 0 0 3rem;
  }
  .solu-01 ol li span:first-child{
    width: 5.4rem;
    padding: 0;
  }
  .solu-01 ol li span:last-child{
    font-size: 2.2rem;
    padding: 0 1rem;
  }

  /* 内容-02 SP ------------------------- */
  .solu-02{
    flex-direction: row;
    align-items: center;
    padding: 3rem 0 3rem 1.5rem;
  }
  .solu-02 p:first-child{
    width: 34%;
  }
  .solu-02 p:first-child span{
    width: 21rem;
    height: 21rem;
    padding: 3.5rem 0 0;
    border-radius: 50%;
  }
  .solu-02 p:first-child img{
    width: 15rem;
  }
  .solu-02 p:last-child{
    width: 66%;
    line-height: 1.8;
    padding: 1.5rem 0 0 3rem;
    font-size: 2.4rem;
  }

  /* 内容-03 1400 ------------------------- */
  .solu-03 ol{
    padding: 5rem 5rem 2rem;
  }
  .solu-03 ol li{
    margin: 0 0 3rem;
    padding: 0 0 0 3rem;
    line-height: 1.6;
    font-size: 2.4rem;
  }
  .solu-03 ol li span{
    font-size: 1.8rem;
  }
  .solu-03 ol li::before{
    width:1.2rem;
    height: 1.2rem;
  }
  .solu-03 ol li:first-child::before{
    top: 18%;
  }
  .solu-03 ol li:last-child::before{
    top: 30%;
  }
  .solu-03 ol + p{
    padding: 2rem 5rem 0;
    line-height: 1.8;
    font-size: 2.4rem;   
  }
  .solu-03 ol + p span{
    padding: 0;
    font-size: 1.4rem;
  }

  /* 内容-04 1400 ------------------------- */
  .solu-04 dl{
    margin: 0 0 1.5rem;
  }
  .solu-04 dl dt{
    width: 15rem; 
  }
  .solu-04 dl:first-child dt img{width: 8.4rem;}
  .solu-04 dl:nth-child(2) dt img{width: 7.2rem;}

  .solu-04 dl dd{
    width: calc(100% - 15rem);
    padding: 0 3.6rem;
  }
  .solu-04 dl dd h3{
    font-size: 2.1rem;
  }
  .solu-04 dl dd h3 span{
    display: inline;
    padding: 0 0 0 1rem;
    font-size: 1.4rem;
  }
  .solu-04 dl dd p{
    padding: 0;  
    font-size: 1.8rem;
    line-height: 1.5;
  }


  /* 開始6ヵ月で15000件 1400
  ---------------------------------*/
.solution-bnn{
  padding: 5rem 0;
}

  .solution-bnn-bg{
    border-radius: 0;
  }
  @media screen and (min-width:1420px) {
    .solution-bnn-bg{
      border-radius: 1rem;
    }
  }
  .solution-bnn-content{
    background: url(../img/solution-bnn-ph.png) no-repeat 103% bottom;
    background-size: 40rem;
  }
  .solution-bnn-content figure.solu-graph{
    width: 30%;
  }
  .solution-bnn-ttl{
    width: 47%;
    margin: 2.5% 0 0;
    padding: 14rem 0 0;
  }
  .solution-bnn-ttl figure + p{
    max-width: 60rem;
    margin: 0 auto;
    padding: 1.5rem;
    font-size: 1.8rem;
  }
  .solution-bnn-ttl p.solu-anv{
    padding: 1rem 0 0;
  }

/* ご利用状況にあったプラン例 1400
  -------------------------*/
  .plan .tab-list li, .plan .tab-list li span {
    font-size: 2.2rem;
  }
  .plan .tab-list li {
    padding: 1.5rem;
    border-radius: 2rem 2rem 0 0;
    margin: 0 0.5rem;
  }
  .plan .tab-list li::after {
    transform: translate(-50% , -5%);
  }
  .plan .tab-list li.active::after {
    transform: translate(-50% , 3%);
  }

  .plan .tab-content {
    padding: 6.5rem 10rem;
    border-radius: 2rem;
  }
  .plan .tab-content .content-head-lead h3 {
    font-size: 4rem;
  }
  .plan .tab-content .content-head-lead p {
    font-size: 2rem;
  }

  .plan .tab-content .head01 .customer-type {
    max-width: 37rem;
  }
  .plan .tab-content .customer-type p span {
    font-size: 1.6rem;
  }
  .plan .tab-content .head01 .customer-type p {
    padding: 2.2rem 1rem;
  }
  .plan .tab-content .head02 .customer-type {
    max-width: 32rem;
  }
  .plan .tab-content .head02 .customer-type p {
    padding: 1.8rem 1rem;
  }
  .plan .tab-content .head02 .customer-type p span {
    font-size: 1.6rem;
  }
  .plan .tab-content .head03 .customer-type {
    max-width: 40rem;
  }
  .plan .tab-content .head03 .customer-type p {
    padding: 2.6rem 1rem
  }

  .plan .tab-content .plan-detail .suggest {
      margin-top: 10.5rem;
      padding-top: 7rem;
  }
  .plan .tab-content .plan-detail .suggest h4 {
    font-size: 2.4rem;
  }
  .plan .tab-content .plan-detail .suggest h4 strong {
    font-size: 2.8rem;
  }
  .plan .tab-content .plan-detail .suggest dt {
    font-size: 2rem;
  }
  .plan .tab-content .plan-detail .suggest dd {
    font-size: 2.4rem;
  }
  .plan .tab-content .suggest .cost-image figure {
    width: 28rem;
  }
  .plan .tab-content .suggest.suggest02 .cost-image figure {
    width: 30rem;
  }
  .plan .tab-content .suggest .cost-image p {
    font-size: 2.4rem;
  }

  .plan .tab-content .plan-detail > dl dt {
    font-size: 2.1rem;
  }
  .plan .tab-content .plan-detail > dl dd {
    font-size: 2rem;
  }
  .plan .tab-content .plan-detail > p {
    font-size: 2.1rem;
  }


  /* ご契約までの流れ 1400
  -------------------------*/
  .flow .step-box {
    padding: 23.5rem 4.5rem 5rem;
  }

  /* よくある質問 1400
  -------------------------*/
  .faq-wrapper {
    padding: 10rem 0;
  }

}

/*----------------------------------------------------
PC 1600- 
----------------------------------------------------*/
@media screen and (min-width:1600px) {

  /* よくある質問 1600
  -------------------------*/
  .faq-wrapper {
    padding: 10rem 0rem;
  }

}