:root {
  --keycolor01: #00888F;
  --keycolor02: #00888F;

  --keycolor03: #00888F;
}


/* ---------------- */
.headerTabs ul li:nth-of-type(1) a.current {
  background-color: #00888F;
}

/* ---------------- */
.headerTabs ul li:nth-of-type(2) a {
  background-color: #C3D3E5;
  color: #004B9D;
}
.headerTabs ul li:nth-of-type(2) a:hover {
  background-color: #004B9D;
}

/* ---------------- */
.headerTabs ul li:nth-of-type(3) a {
  background-color: #E1D8C1;
  color: #705c21;
}
.headerTabs ul li:nth-of-type(3) a:hover {
  background-color: #705c21;
}




/* FV
______________________________________ */

.fvInner [class^='fv_img'] {
  position: absolute;
}

.fvInner .fv_img01 { 
  bottom: 1%;
  left: 0;
  right: 0;
  margin: auto;
  width: min(29vw, 580px);
}
@media (min-width: 920px) {
  .fvInner .fv_img01 {
    width: min(44vw, 570px);
  }
}
.fvInner .fv_img01_01 { 
  right: 82%;
  top: 3%;
  width: min(17vw, 340px);
}
.fvInner .fv_img01_02 { 
  left: 15%;
  top: 60%;
  width: min(10vw, 213px);
}
.fvInner .fv_img01_03 { 
  right: 67%;
  top: 33%;
  width: min(10vw, 217px);
}
.fvInner .fv_img01_04 { 
  right: 24%;
  top: 31%;
  width: min(12vw, 290px);
}
.fvInner .fv_img01_05 { 
  right: 11%;
  top: 24%;
  width: min(14vw, 226px);
}







/* 
.fraudInfo {
  font-size: min(4vw, 1rem);
  background-color: var(--color01);
  border: 3px solid var(--color05);
  color: var(--color05);
  font-weight: 700;
  font-size: min(4vw, 22px);
  letter-spacing: .1em;
  border-radius: 16px;
  padding: min(4vw, 3rem) min(4vw, 4rem);
  position: relative;
  width: fit-content;
  margin: 3rem 4vw;
}
@media (min-width: 920px) {
  .fraudInfo {
    margin: 3rem auto;
  }
}
.fraudInfo::before {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 74%;
  margin: auto;
  content: '';
  width: min(10vw, 71px);
  height: min(10vw, 62px);
  background: url(../img/ico-caution.png) no-repeat;
  background-size: contain;
}
.fraudInfo p {
  display: grid;
  grid-template-columns: 3em 1fr;
  column-gap: 1rem;
  align-items: center;
  justify-content: center;
}
.fraudInfo p::before {
  content: '';
  width: 3em;
  height: 3em;
  background: url(../img/ico-fraud.png) no-repeat;
  background-size: cover;
} */



.sec:nth-of-type(odd) {
  background: var(--color03);
}



.sec00 .secInner > p {
  font-size: min(4.5vw, 1.875rem);
  text-align: center;
  letter-spacing: .1em;
  font-weight: 700;
}

.localAnchor {
  list-style: none;
  display: grid;
  grid-template-columns: 1fr;
  gap: min(3vw, 1.5rem);
}
@media (min-width: 920px) {
  .localAnchor {
    grid-template-columns: 1fr 1fr 1fr;
  }
}
.localAnchor li a {
  border: 2px solid var(--keycolor01);
  background-color: var(--color01);
  color: #033653;
  border-radius: 5px;
  display: grid;
  grid-template-columns: 3rem 1fr 1rem;
  column-gap: .5rem;
  align-items: center;
  position: relative;
  padding: 1rem 1rem 1rem 1.5rem;
  font-size: min(4vw, 20px);
  font-weight: 700;
}
.localAnchor li a em {
  color: var(--keycolor01);
  font-style: normal;
}
@media (min-width: 920px) {
  .localAnchor li a {
    
  }
}

.localAnchor li:nth-of-type(1) a::before {
  content: '';
  width: 3rem;
  height: 3rem;
  background: url(../img/ico-bulb.png) no-repeat;
  background-size: contain;
}
.localAnchor li:nth-of-type(2) a::before {
  content: '';
  width: 3rem;
  height: 3rem;
  background: url(../img/ico-gear.png) no-repeat;
  background-size: contain;
}
.localAnchor li:nth-of-type(3) a::before {
  content: '';
  width: 3rem;
  height: 3rem;
  background: url(../img/ico-calc.png) no-repeat;
  background-size: contain;
}

.localAnchor li a::after {
  content: '▼';
  right: min(2vw, 1em);
  font-size: min(2vw, 18px);
  color: var(--keycolor01);
}






/* CALC
______________________________________________ */
.calcWrap {
  display: flex;
  background: var(--color07);
  padding: min(3vw, 52px) 3vw;
  border-radius: 5px;
  flex-direction: column;
}
@media (min-width: 920px) {
  .calcWrap {
    display: block;
    padding: min(3vw, 52px) 4vw;
  }
}

.calc {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  grid-template-rows: repeat(4, 1fr);
  gap: 3px;
  margin-bottom: 3px;
}
@media (min-width: 920px) {
  .calc {
    margin-bottom: 1rem;
  }
}
.calc label {
  width: 100%;
  cursor: pointer;
  line-height: 1;
  position: relative;
}
.calc label:nth-of-type(2) {
  grid-column-start: 1;
  grid-row-start: 2;
}
.calc label:nth-of-type(3) {
  grid-column-start: 1;
  grid-row-start: 3;
}
.calc label:nth-of-type(4) {
  grid-column-start: 1;
  grid-row-start: 4;
}
.calc label:nth-of-type(5) {
  grid-row: span 4 / span 4;
  grid-column-start: 2;
  grid-row-start: 1;
}

.calc label #type {
  outline: none;
  border: none;
  appearance: none;
  cursor: pointer;
  font-size: 16px;
  padding: 1.9rem 1rem 1.9rem 1rem;
  width: 100%;
}
.calc label:has(#type)::after {
  content: '▼';
  color: #ccc;
  position: absolute;
  font-size: 16px;
  right: 1rem;
  top: calc(50% - .65em);
}
.calc label input[type="number"] {
  outline: none;
  font-weight: 700;
  border: none;
  text-align: right;
  padding: 1rem 1rem 1rem 1rem;
  font-size: 38px;
  width: 100%;
  font-family: 'Montserrat';
  line-height: 1;
  background: var(--color08);
  color: var(--keycolor01);
}
.calc label input[type="number"]::placeholder {
  font-size: 16px;
  font-weight: 400;
  text-align: left;
  color: var(--color07)
}
.calc label input[type="number"]::-webkit-input-placeholder {
  position: relative;
  top: -.3em;
}
.calc label#unit {
  width: 4em;
  color: var(--color01);
  font-size: min(4vw, 18px);
  padding: 0 .45em;
  white-space: nowrap;
  font-weight: 700;
  align-content: center;
}
@media (min-width: 920px) {
  .calc {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 3px;
    width: 100%;
  }
  .calc label {
    display: flex;
    align-items: center;
    justify-content: center;
    /* width: auto; */
    width: 22%;
    font-size: 24px;
    padding: 0;
    min-height: 6.05rem;
  }
  .calc label:has(#type) {
    padding: 0;
    width: 27%;
  }
  .calc label #type {
    font-size: 22px;
    padding: 2.28rem 3rem 2.28rem 1.25rem;
    text-align-last: center;
  }
  .calc label:has(#type)::after {
    content: '▼';
    color: #ccc;
    position: absolute;
    font-size: 16px;
    right: 1rem;
  }
  .calc label input[type="number"] {
    font-size: 66px;
    /* width: 3.2em; */
    width: 100%;
    text-align: right;
    padding: .5rem;
  }
  .calc label input[type="number"]::-webkit-input-placeholder {
    top: -1em;
  }
  .calc label#unit {
    background: var(--color01);
    color: var(--color07);
    padding: 0 .45em;
    width: 66px;
  }
}

.result {
  width: 100%;
  background: var(--color01);
  padding: 1rem;
}
.result #monthly {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
.result #monthly > div {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: nowrap;
}
.result #monthly > div em {
  color: var(--color05);
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-size: min(9vw, 54px);
}
.result #monthly > div span {
  font-weight: 700;
  font-size: min(3vw, 1.5rem);
  display: inline-block;
}
.result #monthly > div span:nth-of-type(odd) {
  margin-right: .25em;
}
.result #monthly > div span:nth-of-type(even) {
  width: 2em;
  margin-right: .25em;
  text-align: left;
}
.result #total {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1rem;
  margin-bottom: 2rem;
  padding-top: 1rem;
  border-top: 1px solid var(--color07);
}
.result #total em {
  color: var(--color05);
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-size: min(9vw, 52px);
}
.result #total span {
  font-weight: 700;
  font-size: min(3vw, 1.5rem);
  display: inline-block;
  padding: 0 .25em;
}

.result > p {
  font-size: min(3vw, 20px);
  line-height: 1.6;
}
@media (min-width: 920px) {
  .result {
    width: 100%;
    border-radius: 0;
  }
  .result #monthly {
    flex-direction: row;
  }
}


/* 
______________________________________________ */
.sec08 .secInner {
  max-width: var(--innerwidth-narrow);
}
.targetInfo {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
@media (min-width: 920px) {
  .targetInfo {
    flex-direction: row;
  }
}
.targetInfo .forLPG {
  width: 100%;
  background: var(--color01);
  padding: min(4vw, 4rem) min(4vw, 3rem) min(4vw, 2rem) min(4vw, 3rem);
  position: relative;
}
@media (min-width: 920px) {
  .targetInfo .forLPG {
    width: 50%;
  }
}
.targetInfo .forLPG::before {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 89%;
  margin: auto;
  content: '';
  width: min(10vw, 82px);
  height: min(10vw, 82px);
  background: url(../img/ico-question_fill.png) no-repeat;
  background-size: contain;
}
.targetInfo .forLPG > div {
  display: flex;
  align-items: center;
  column-gap: 1.25rem;
  width: fit-content;
  margin: auto;
}

.targetInfo .forLPG > div:nth-of-type(1) {
  margin-bottom: min(4vw, 4rem);
}
.targetInfo .forLPG > div:nth-of-type(1) > p {
  color: var(--keycolor01);
  font-weight: 700;
  font-size: min(4vw, 26px);
}

.targetInfo .forLPG > div:nth-of-type(2) > p {
  font-size: min(2.75vw, 20px);
  font-weight: 700;
  white-space: nowrap;
  line-height: 1.7;
  color: #033653;
}
.targetInfo .forLPG > div:nth-of-type(2) > p span {
  color: var(--color05);
}
@media (min-width: 920px) {
  .targetInfo .forLPG > div:nth-of-type(2) > p {
      font-size: min(4vw, 16px);
  }
}



.targetInfo .forBizBtns {
  width: 100%;
  height: min(56vw, 280px);
  display: grid;
  grid-template-rows: 1fr 1fr;
  gap: 1rem;
}
@media (min-width: 920px) {
  .targetInfo .forBizBtns {
    width: 50%;
    height: auto;
    gap: 2rem;
  }
}
.targetInfo .forBizBtns .btn::after {
  content: '\0025b6';
  font-size: 70%;
  position: absolute;
  right: 2em;
}
@media (min-width: 920px) {
  .targetInfo .forBizBtns .btn::after {
    right: 1em;
  }
}
.forAdopt {
  color: var(--color01);
  background: var(--color09);
  box-shadow: inset 0 0 0 4px var(--color09), inset 0 0 0 6px #fff;
}
.forBusiness {
  color: var(--color01);
  background: var(--color10);
  box-shadow: inset 0 0 0 4px var(--color10), inset 0 0 0 6px #fff;
}