/*-------------------------------------------
   eneos_campaign
-------------------------------------------*/
div.main div.key-visual {
  background: #FDD000;
  background-image: repeating-linear-gradient(126deg, transparent, transparent 21px, rgba(242, 233, 199, 1) 21px, rgba(242, 233, 199, 1) 42px );
}
.key-visual-bc {
  background: #FDD000;
  height: 100%;
  width: 50vw;
  z-index: 100;
  position: absolute;
  top: 0;
  left: 63%;
}
.eneos-link {
  text-decoration: underline;
  color: #DB0066;
}
.eneos-link:hover {
  opacity: 0.5
}
div.main div#price-key-visual img {
  z-index: 1000;
  position: relative;
}
section.other-first,
section.other-third {
  background-color: #FBF6E2;
  padding: 1px;
}
section.other-second, 
section.other-second.guide {
  padding: 0px 0px 0px;
  background-color:#F3F3F3;
  padding: 0;
}

div.white-content-box-inner {
  margin: 108px auto 75px;
  position: relative;
}

.content-inner {
  max-width: 980px;
  width: 100%;
  margin: 0 auto;
}
.eneos-title-contaier {
  font-weight: bold;
  text-align: center;
}
.eneos-title-wrap {
  text-align: center;
  font-weight: bold;
  position: relative;
}
.eneos-title-box {
  display: flex;
  justify-content: center;
  align-items: center;
}
.eneos-logo-img {
  width: 232px;
}
.eneos-title-p {
  font-size: 3.5rem;
  font-weight: bold;
  padding-left: 10px;
}
.eneos-big-title {
  font-size: 3.5rem;
  margin: 23px 0;
}
.eneos-title-wrap .eneos-big-number {
  font-size: 4.5rem;
  margin-right: 5px;
}
.eneos-title-wrap .eneos-sub-title {
  display: block;
  font-size: 2rem;
}
.content-box-title p{
  position: relative;
  margin-bottom: 0;
}
.eneos-title-wrap::before{
  content: '';
  position: absolute;
  top: -35px;
  width: 180px;
  height: 10px;
  background: #FDD000;
  transform: translateX(-50%);
  left: 50%;
}

.eneos-summary-flex {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 35px auto;
  max-width: 980px;
  position: relative;
}
.eneos-summary-text-box .eneos-summary-text {
  font-size: 2.2rem;
  line-height: 1.5;
  font-weight: bold;
  text-align: center;
}
.eneos-summary-head {
  font-size: 2.6rem;
  font-weight: 800;
  background: #FDD000;
  padding: 0.6em 2.3em;
  border-radius: 10px;
  margin: 10px 0 0;
  line-height: 1;
  text-align: center;
}
.eneos-summary-head span{
  font-size: 2.3em;
  font-weight: bold;
  font-style: italic;
  padding-right: 6px;
}
.eneos-summary-text + .eneos-summary-text {
  margin-top: 20px;
}
.eneos-img1 {
  width: 20%;
  max-width: 164px;
  position: absolute;
  right: 0;
  top: 0;
  transform: translate(-30%, -0.7em);
}
.eneos-img2 {
  position: absolute;
  left: 15%;
  top: -87%;
  transform: translate(-50%, 0%);
  z-index: 1000;
  max-width: 165px;
}
.ss-pink-text {
  font-size: 2.7rem;
  color: #DB0066;
}
.ss-pink-text-big {
  font-size: 3rem;
  color: #DB0066;
  line-height: 1;
}
.ss-text-small {
  font-size: 0.6em;
}
.ss-sub-text {
  font-size: 1.7rem;
  margin-top: 20px;
  display: inline-block;
}
.ss-text-underline {
  border-bottom: 3px solid #DB0066;
}
.eneos-button {
  background-color: #000;
  color: #FFF;
  border-radius: 30px;
  font-size: 1.8rem;
  margin: 15px auto 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: fit-content;
  font-weight: bold;
  height: 47px;
  width: 375px;
  padding-right: 10px;
}
.eneos-button::after,
.eneos-set-button::after {
  content: "▶";
  color: #FDD000;
  position: absolute;
  left: 66.5%;
  transform: translate(-50%, 0%);
}
.eneos-set-button {
  background-color: #2e587d;
  color: #FFF;
  border-radius: 30px;
  font-size: 1.8rem;
  margin: 15px auto 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: fit-content;
  font-weight: bold;
  width: 375px;
  padding: .5em;
  line-height: 1.25;
}
.eneos-button:hover,
.eneos-set-button:hover {
  background-color: #FFE000;
  color: #000;
  transition: .3s all;
}
.eneos-button-arrow {
  color: #FFE000;
}
.eneos-button:hover .eneos-button-arrow {
  color: #000;
  transition: .3s all;
}
.eneos-step2-button a {
  margin: 10px 0;
}
.eneos-annotation {
  font-size: 1.1rem;
  text-align: center;
  font-weight: normal;
  margin-top: 10px;
  line-height: normal;
}
.eneos-3step-flow {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: bold;
}
.eneos-3step-flow > div {
  width: 32%;
  max-width: 310px;
  background-color: #FFF;
  box-shadow: 3px 3px 3px rgb(0,0,0,20%);
  transform: translateZ(0);
  border-radius: 10px;
  text-align: center;
  padding: 25px 16px 16px;
  box-sizing: border-box;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: column;
  height: 346px;
}
.eneos-3step-flow > div:not(:last-of-type)::after{
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 25px solid transparent;
  border-bottom: 25px solid transparent;
  border-left: 23px solid #535353;
  border-right: 0;
  position: absolute;
  top: 50%;
  right: -12px;
  transform: translate(50%, -50%);
}

.eneos-3step-flow-bottom {
  width: 100%;
}
.eneos-3step-flow .nav_type03 {
  text-align: center;
  letter-spacing: 0.11em;
  text-indent: -0.11em;
  list-style: none;
  width: 100%;
  filter: drop-shadow(4px 4px 4px rgb(0,0,0,20%));
  transform: translateZ(0);
}
.eneos-3step-flow .nav_type03 a {
  font-weight: bold;
  line-height: 1.4;
  display: block;
  transition: .3s all;
  letter-spacing: 0.1em;
  border-radius: 0.75em;
  background: #DB0066;
  color: #FFFFFF;
  font-size: 1.4rem;
  position: relative;
  padding: 14px 0;
}
.eneos-3step-flow .nav_type03 a:hover {
  background: #FFE000;
  color: #000000;
  transition: .3s all;
}
.eneos-3step-flow .nav_type03 a .sub-mess {
  background-color: #fff;
  padding: 5px 9px;
  border-radius: 100vh;
  font-size: 1.4rem;
  color: #000;
  margin-right: 10px;
  position: unset;
}
.eneos-3step-flow .nav_type03 a .sub-mess span {
  color: #ff0080;
}
.eneos-3step-contents {
  text-align: left;
  font-size: 1.5rem;
  line-height: 1.3;
}
.step-contents-adjust {
  margin-top: 40px;
  margin-bottom: 25px;
  height: 50px;
}
.marker_pink {
  background: linear-gradient(transparent 50%, #DB0066 50%);
}
.marker_blue {
  background: linear-gradient(transparent 50%, #3DBDDF 50%);
}
.marker_yellow {
  background: linear-gradient(transparent 50%, #FDD000 50%);
}
.eneos-3step-flow-top {
  font-size: 2.2rem;
  width: 100%;
}
.big-numer {
  font-size: 3rem;
}
.eneos-3step-title {
  padding: 5px 0;
  border-bottom: 1px solid #000000;
  width: 100%;
  margin-bottom: 10px;
  line-height: 1.3;
  height: 60px;
  margin-top: 7px;
  align-content: center;
}
.eneos-3step-flow .nav_type03.eneos-step2-button,
.eneos-3step-flow .nav_type03.eneos-step3-button {
  width: 100%;
}
.eneos-3step-flow .nav_type03.eneos-step2-button a,
.eneos-3step-flow .nav_type03.eneos-step3-button a {
  font-size: 1.3rem;
}
.eneos-3step-flow .nav_type03.eneos-step2-button a {
  background: #000000;
}
.eneos-3step-flow .nav_type03.eneos-step2-1-button a {
  background: #2e587d;
}
.eneos-3step-flow .nav_type03.eneos-step2-button a:hover,
.eneos-3step-flow .nav_type03.eneos-step2-1-button a:hover {
  background: #FFE000;
  transition: .3s all;
}
.eneos-3step-flow .nav_type03.eneos-step2-button a:hover .eneos-button-arrow,
.nav_type03 a:hover .eneos-button-arrow,
.eneos-button:hover::after,
.eneos-set-button:hover::after {
  color: #000;
  transition: .3s all;
}
.eneos-3step-flow .nav_type03.eneos-step3-button a {
  background: #FDD000;
  color: #000000;
}
.eneos-3step-flow .nav_type03.eneos-step3-button a:hover {
  background: #000000;
  color: #FFF;
  transition: .3s all;
}
.eneos-3step-flow .nav_type03.eneos-step3-button a .eneos-button-arrow {
  color: #000000;
}
.eneos-3step-flow .nav_type03.eneos-step3-button a:hover .eneos-button-arrow {
  color: #FFE000;
  transition: .3s all;
}
.eneos-3step-flow .nav_type03.eneos-step2-button a::before,
.eneos-3step-flow .nav_type03.eneos-step3-button a::before {
  content: unset;
}
.eneos-campaign-area {
  background-color: #FFF;
  border-radius: 20px;
  filter: drop-shadow(4px 4px 4px rgb(0,0,0,20%));
  transform: translateZ(0);
  padding: 40px;
}
.eneos-campaign-area table th,
.eneos-campaign-area table td {
  font-size: 1.5rem;
  font-weight: bold;
}
table, td, th {
  border-collapse: collapse;
  width: 100%;
  text-align: left;
  line-height: 1.3;
}
td, th {
  padding: 13px;
  border-bottom: 5px solid #FFFFFF;
}
th {
  background: #FDD000;
  color: #000;
  width: 18%;
}
td {
  background: #eeeeee;
  width: 82%;
}
.campaign-details-title,
.campaign-details-contents {
  font-size: 1.4rem;
}
.campaign-details-title {
  font-weight: bold;
  font-size: 2.2rem;
  margin-bottom: 10px;
  width: fit-content;
}
.campaign-details-title:not(:first-child) {
  margin-top: 30px;
}
.campaign-details-title-arrow {
  position: relative;
  cursor: pointer;
}

@media screen and (max-width: 500px) {
  div.section-container {
    padding: 0 4%;
  }
  .eneos-title-box .eneos-logo-img {
    width: 183px;
    margin-left: -6px;
  }
  .eneos-title-wrap .eneos-title-p {
    font-size: 2.6rem;
    padding-top: 3px;
    margin-left: -9px;
  }
}

@media screen and (min-width: 768px) and (max-width: 1280px) {
  .eneos-3step-flow > div {
    height: 328px;
  }
  div.main div#price-key-visual img {
    padding: 0 30px;
    box-sizing: border-box;
  }

  div.content-box-inner p.eneos-summary-text {
    font-size: 1.6rem;
  }
  .eneos-pc {
    display: none;
  }
  .ss-pink-text-big {
    font-size: 2.8rem;
  }
  .cp-cardimg1 {
    width: 35%;
  }
  .eneos-3step-contents {
    font-size: 1.6rem;
  }
  .eneos-3step-flow-top {
    font-size: 1.8rem;
  }
  .eneos-3step-title {
    height: 50px;
  }
  .eneos-3step-flow .nav_type03 a {
    padding: 7px 0
  }
  .eneos-3step-flow .nav_type03 a .sub-mess {
    padding: 0px 6px;
    font-size: 1.3rem;
  }
  .eneos-3step-flow > div {
    height: 412px;
  }
  .eneos-3step-flow > div:not(:last-of-type)::after {
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-top: 20px solid transparent;
    border-bottom: 21px solid transparent;
    border-left: 14px solid #535353;
    border-right: 0;
    position: absolute;
    top: 50%;
    right: -7px;
    transform: translate(50%, -50%);
  }
  .step-contents-adjust {
    height: 100px;
  }
  .eneos-summary-head {
    font-size: 2.8rem;
    font-weight: 800;
    background: #FDD000;
    padding: 8px 17px 8px;
    border-radius: 10px;
    margin: 9px 0px;
    line-height: 1.25;
    text-align: center;
    width: 73%;
  }
  .eneos-summary-text-box .eneos-summary-text {
    margin: 10px;
  }
  .eneos-summary-flex {
    margin: 35px 0;
  }
  .head-top {
    width: fit-content;
    margin: 0 auto;
  }
  .head-bottom {
    width: fit-content;
    margin-left: 40px;
    margin: 10px 0 auto;
  }
  .eneos-img1 {
    width: 140px;
    max-width: 164px;
    position: absolute;
    right: 0;
    top: 70px;
    transform: translate(25%, 0%);
  }
  .eneos-button::after, .eneos-set-button::after {
    left: 73.5%;
  }
}

@media screen and (max-width: 767px) {
  div.main div.key-visual {
    background-image: url(../img/kv-sub-cp-card-sp-3.webp);
    background-size: cover;
    background-repeat: no-repeat;
  }
  div.main div.key-visual img.img-mv-text-2,
  div.main div.key-visual img.img-mv-text-3 {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    margin: auto;
    z-index: 111;
  }
  div.main div.key-visual img.img-mv-text-1 {
    filter: drop-shadow(2px 2px 2px #252525);
  }
  div.main div.key-visual img.img-mv-text-3 {
    filter: drop-shadow(3px 2px 0px #252525);
  }
  div.white-content-box-inner {
    margin: 84px auto 50px;
  }
  .eneos-pc {
    display: none;
  }
  .eneos-title-p {
    font-size: 3.3rem;
    padding-top: 5px;
    margin-left: -9px;
  }
  .eneos-title-p span {
    font-size: 2rem;
  }
  .eneos-campaign-area {
    padding: 30px;
  }
  .eneos-logo-img {
    width: 218px;
  }
  .eneos-title-wrap .eneos-sub-title {
    font-size: 1.5rem;
  }
  .eneos-big-title {
    font-size: 2.5rem;
    margin: 9px 0 14px;
  }
  .eneos-summary-text-box .eneos-summary-text {
    font-size: 1.8rem;
    margin-bottom: 10px;
    text-align: left;
  }
  .eneos-summary-flex {
    align-items: flex-end;
    width: auto;
    position: relative;
    margin: 0 auto;
    padding: 0 0 40px;
  }
  .eneos-summary-head span {
    font-size: 1.8em;
  }
  .eneos-summary-head {
    width: fit-content;
    font-size: 3.5vw;
    padding: 0.4em 0.5em;
    border-radius: 5px;
  }
  .head-bottom{
    padding: 0.2em 0.4em;
    margin: 5px 0 0;
    font-size: 5vw;
  }
  .eneos-img1 {
    position: static;
    transform: none;
  }
  .eneos-img2 {
    position: absolute;
    left: 20%;
    top: 34%;
    transform: translate(-50%, 0%);
    z-index: 1000;
    max-width: 80px;
  }
  .text-space {
    margin-right: 65px;
  }
  .eneos-button,
  .eneos-set-button {
    width: fit-content;
    margin: 0 auto;
    line-height: 1.3;
    font-size: 1.3rem;
    box-sizing: border-box;
    min-width: 280px;
    margin-bottom: 6px;
    position: relative;
  }
  .eneos-button::after, .eneos-set-button::after {
    left: 91.5%;
  }
  .eneos-annotation {
    font-size: 1.1rem;
    line-height: normal;
  }
  div.content-box-title p {
    font-size: 2.1rem;
    line-height: 30px;
    text-align: center;
  }
  div.content-box-title p span.eneos-big-number {
    font-size: 3.1rem;
  }
  .eneos-3step-flow {
    display: block;
  }
  .eneos-3step-flow > div {
    width: 100%;
    height: unset;
    width: unset;
    max-width: unset;
  }
  div.content-box-inner p.eneos-3step-number {
    display: inline;
    margin-right: 10px;
  }
  div.content-box-inner p.eneos-3step-title {
    display: inline;
    border-bottom: unset;
  }
  div.content-box-inner p.eneos-3step-contents {
    width: 60%;
    padding-right: 5px;
    box-sizing: border-box;
    font-size: 1.3rem;
  }
  .eneos-3step-flow .nav_type03 a {
    margin: 8px 0 0;
    font-size: 1.3rem;
    padding: 14px 0;
  }
  .eneos-3step-flow .nav_type03 a .sub-mess {
    font-size: 1.2rem;
    padding: 3px 9px;
  }
  .eneos-3step-contents {
    height: auto;
    text-align: center;
    font-size: 1.5rem;
    line-height: 1.3;
    margin: auto;
    padding: 10px 0;
}
  .eneos-3step-number {
    font-size: 1.8rem;
  }
  .eneos-3step-title {
    font-size: 1.8rem;
    margin-top: 7px;
    height: unset;
  }
  .eneos-3step-flow > div:not(:first-child) {
    margin-top: 25px;
  }
  .eneos-3step-flow > div:not(:last-of-type)::after{
    content: "";
    border-right: 25px solid transparent;
    border-left: 25px solid transparent;
    border-top: 24px solid #535353;
    border-bottom: 0;
    bottom: -13px;
    top: auto;
    right: 50%;
    transform: translate(50%, 50%);
  }
  .eneos-3step-flow .nav_type03.eneos-step2-button a, 
  .eneos-3step-flow .nav_type03.eneos-step3-button a {
    font-size: 1.3rem;
  }
  table th,
  table td{
    width: 100%;
    display: block;
    box-sizing: border-box;
    padding: 7px 15px;
  }
  table td:not(:last-child) {
    margin-bottom: 10px;
  }
  .eneos-campaign-area table th {
    margin-top: 8px;
  }
  .eneos-campaign-area table th, .eneos-campaign-area table td {
    font-size: 1.4rem;
  }
  .eneos-campaign-area table td {
    font-weight: normal;
    line-height: 1.4;
  }
  .campaign-details-title {
    font-size: 1.5rem;
    margin-bottom: 0;
  }
  .campaign-details-contents {
    font-size: 1.3rem;
    margin-top: 5px;
  }
  .campaign-details-title:not(:first-child) {
    margin-top: 17px;
  }
  div.content-box-title.insurance-option-section-title p.sp-big-title {
    font-size: 2.4rem;
  }
  .eneos-campaign-area {
    padding: 30px 6%;
  }
}
