@charset "Shift_JIS";

/* Updated 2025/07/15 */
/* Updated 2025/07/01 */
/* Updated 2025/04/01 */
/* Updated 2023/02/17 */


/* add 02/17 common */
@media screen and (min-width: 768px) {
  .spOnly{
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .pcOnly{
    display: none;
  }
}


/* add 02/17 sec-apply-btn */

@media screen and (min-width: 768px) {
.contentsOlive .secApply .btnRound{
  margin-top: 30px;
}
}

/* add 02/17 serviceBoxCardAccordion */
.contentsOlive .serviceBoxCardAccordion{
  margin: 10px;
}
.contentsOlive .serviceBoxCardAccordion input{
  display: none;
}

.contentsOlive .serviceBoxCardAccordion .ttl{
  cursor :pointer;
  display: block;
  text-decoration: none;
  color: #333;
  line-height: 1;
  text-align: left;
  position: relative;
  margin: 0;
  padding: 10px 20px 10px 10px;
  border: 1px solid #ccc;
  border-radius: 8px;
  font-size: 3.33333vw;
}
.contentsOlive .serviceBoxCardAccordion .ac-body{
  height: 0;
  overflow-y: hidden;
  font-size: 0;
}

.contentsOlive .serviceBoxCardAccordion .ac-body .serviceBoxCardAccordionTxt-indent{
  padding-left: 1em;
  text-indent: -1em;
}
.contentsOlive .serviceBoxCardAccordion .ac-body a{
  text-decoration: underline;
}
.contentsOlive .serviceBoxCardAccordion .ac-body strong{
  font-weight: 700;
}

#serviceBoxCardAccordion01:checked ~ #serviceBoxCardAccordionBody01 .ac-body,
#serviceBoxCardAccordion02:checked ~ #serviceBoxCardAccordionBody02 .ac-body{
  height: auto;
  opacity: 1;
  font-size: 1.2rem;
  text-align: left;
  border: 1px solid #ccc;
  padding: 1.5rem;
  position: relative;
  background: #fff;
  top: -4px;
  line-height: 1.6;
}
#serviceBoxCardAccordion01:checked ~ #serviceBoxCardAccordionBody01 .ac-body p,
#serviceBoxCardAccordion02:checked ~ #serviceBoxCardAccordionBody02 .ac-body p{
  margin-bottom: 1em;
}
/* close */
.contentsOlive .serviceBoxCardAccordion label:after{
  content:"";
  display:block;
  width:8px;
  height:8px;
  border-top: #ccc 2px solid;
  border-right: #ccc 2px solid;
  transform: rotate(135deg);
  position:absolute;
  right: 2%;
  top: 0;
  bottom: 15%;
  margin: auto;
}
/* open */
.contentsOlive .serviceBoxCardAccordion input[type=checkbox]:checked + label:after{
  content:"";
  display:block;
  width:8px;
  height:8px;
  border-top: #ccc 2px solid;
  border-right: #ccc 2px solid;
  transform: rotate(-45deg);
  position:absolute;
  right: 2%;
  top: 7%;
  bottom: 0;
  margin: auto;
}

@media only screen and (min-width: 768px){
  .contentsOlive .serviceBoxCardAccordion .ttl{
    font-size: 1.4rem;
  }
}


/* add brand-LP newcard swipe */

.secService .serviceBoxImg {
  margin: 10px auto;
}

.newvalue-onecard-cards {
  margin: 60px auto 0;
  position: relative;
  aspect-ratio: 1.55/1;
  width: 270px;
}
@media screen and (min-width: 769px) {
  .newvalue-onecard-cards {
    width: 400px;
  }
}

.newvalue-onecard-card {
  width: 100%;
}
.newvalue-onecard-card img {
  opacity: 0;
  position: absolute;
  left: 0;
  top: 0;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-transform: rotateY(0deg);
  transform: rotateY(0deg);
  transition: opacity 0.5s ease, -webkit-transform 0.7s ease;
  transition: transform 0.7s ease, opacity 0.5s ease;
  transition: transform 0.7s ease, opacity 0.5s ease, -webkit-transform 0.7s ease;
}
.animation .newvalue-onecard-card img {
  -webkit-transform: rotateY(180deg);
  transform: rotateY(180deg);
}
.newvalue-onecard-card img:last-child {
  -webkit-transform: rotateY(180deg);
  transform: rotateY(180deg);
}
.animation .newvalue-onecard-card img:last-child {
  -webkit-transform: rotateY(0deg);
  transform: rotateY(0deg);
}
.newvalue-onecard-card.-current img {
  opacity: 1;
}

.newvalue-onecard-cards-nav {
  margin-top: 24px;
}
@media screen and (min-width: 769px) {
  .newvalue-onecard-cards-nav {
    margin-top: 32px;
  }
}
.newvalue-onecard-cards-nav ul {
  display: flex;
  justify-content: center;
}
.newvalue-onecard-cards-nav li {
  text-align: center;
  position: relative;
  padding-top: 20px;
  width: 100px;
  cursor: pointer;
}
@media screen and (min-width: 769px) {
  .newvalue-onecard-cards-nav li {
    width: 124px;
  }
}
.newvalue-onecard-cards-nav li.-current {
  pointer-events: none;
}
.newvalue-onecard-cards-nav li.-current::before {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  top: 0;
  margin-left: -6px;
  width: 10px;
  height: 10px;
  background-color: #004832;
  border-radius: 12px;
}
@media screen and (min-width: 769px) {
  .newvalue-onecard-cards-nav li.-current::before {
    width: 12px;
    height: 12px;
  }
}
.newvalue-onecard-cards-nav li img {
  width: 60px;
  transition: opacity 0.3s ease;
}
@media screen and (min-width: 769px) {
  .newvalue-onecard-cards-nav li img {
    width: 80px;
  }
}
@media (any-hover: hover) {
  .newvalue-onecard-cards-nav li:hover img {
    opacity: 0.8;
  }
}
.newvalue-onecard-cards-nav li p {
  -webkit-transform: rotate(0.05deg);
  transform: rotate(0.05deg);
  margin-top: 8px;
  font-size: 0.6875rem;
}
@media screen and (min-width: 769px) {
  .newvalue-onecard-cards-nav li p {
    font-size: 0.75rem;
  }
}

.newvalue-onecard-navtext {
  font-size: rem(14);
  margin-top: 20px;
  -webkit-transform: rotate(0.05deg);
  transform: rotate(0.05deg);
}
@media screen and (min-width: 769px) {
  .newvalue-onecard-navtext {
    font-size: 1rem;
    text-align: center;
  }
}

.newvalue-onecard-note {
  margin-top: 32px;
  -webkit-transform: rotate(0.05deg);
  transform: rotate(0.05deg);
  font-size: 0.75rem;
}
@media screen and (max-width: 768px) {
  .newvalue-onecard-note {
    text-indent: -1em;
    padding-left: 1em;
  }
}
@media screen and (min-width: 769px) {
  .newvalue-onecard-note {
    text-align: center;
  }
}

/* fpay-slider area */
.fpaySlider{
  position: relative;
  padding-bottom: 30px;
}
.fpaySlider:after{
  background: #EDF3B3;
  border-radius: 50%;
  content: "";
  position: absolute;
  z-index:1;
  width: 160px;
  height: 160px;
  top: 20px;
  left: 70px;
}
.fpaySliderWrap{
  position: relative;
  z-index:2;
  border: 6px solid #444;
  border-radius: 10px;
  width: 100px;
  left: 30px;
}
.fpaySliderWrap img{
  border-radius: 8px;
}
.fpaySliderSide{
  top: 85px;
  left: 145px;
  position: absolute;
  z-index:3;
}
.fpaySliderSide img{
  width: 20px;
  height: 20px;
}
.fpaySliderSide2{
  position: absolute;
  z-index:4;
  top: 65px;
  left: 180px;
}
.fpaySliderSide2 img{
  width: 100px !important;
}


@media only screen and (min-width: 768px){

.fpaySlider:after{
  width: 240px;
  height: 240px;
  top: 30px;
  left: 120px;
}

.fpaySliderWrap{
  width: 150px;
  left: 50px;
}
.fpaySliderSide{
  top: 130px;
  left: 220px;
}
.fpaySliderSide img{
  width: 50px;
  height: 50px;
}
.fpaySliderSide2{
  top: 110px;
  left: 290px;
}
.fpaySliderSide2 img{
  width: 150px !important;
}
}



/* tokuten(benefit)-slider area */

.serviceBoxImg.benfitImg{
  padding: 20px;
}

.benefitSlider{
  position: relative;
}

.benefitSliderWrap{
  border: 6px solid #444;
  border-radius: 10px;
  width: 110px;
  margin: 0 auto 50px;
}
.benefitSliderWrap img{
  border-radius: 8px;
}

@media only screen and (min-width: 768px){
  .serviceBoxImg.benfitImg{
    padding: 20px 40px;
  }

  .benefitSliderWrap{
    width: 150px;
  }
}

/* add 20240816 */
.contentsOlive .bnrMillefeuille {
  padding-bottom: 22px;
}
.contentsOlive .applyGetBnr.bgtp {
  margin-bottom: 40px;
}

@media screen and (min-width: 1024px) {
  .contentsOlive .applyGetBnr.bgtp {
    background-color: #edf3b3;
  }
  .contentsOlive .bnrMillefeuille a + a {
    margin-bottom: 16px;
  }
}

/* add 20250401 */
.cp_info .s-wrap {
  display: inline-block;
  line-height: 1.4;
}
.cp_info .s-wrap span {
  position: relative;
  display: inline-block;
  font-size: 165%;
}
.newOpening h5 {
  margin-bottom: 40px;
}

.contentsOlive .mvTtl {
  position: relative;
  top: auto;
  margin-top: 10px;
  margin-bottom: 82vw;
}

.contentsOlive .applyGet {
  padding-bottom: 5px;
}

.btmOliveFixed {
  padding-bottom: 18px;
}

@media screen and (min-width: 1024px) {
  .contentsOlive .mv {
    min-height: 640px;
  }
  .contentsOlive .mvTtl {
    margin-bottom: 420px;
  }
  .cp_info .s-wrap:before, .cp_info .s-wrap:after {
    width: 38px;
    top: 50%;
  }
  .cp_info .s-wrap:before { 
    left: -16%;
  }
  .cp_info .s-wrap:after {
    right: -16%;
  }
}

/* add 20250620 */

.secCampaign {
  background: #fff;
  position: relative;
  padding: 60px 4.8vw 0px 4.8vw;
}
.campaignTit {
  display: block;
  text-align: center;
  line-height: 2.8;
  position: relative;
  margin-bottom: 30px;
}
.campaignTitSub {
  color: #FA8200;
  font-size: 2.4rem;
  font-weight: bold;
  display: inline-block;
  position: relative;
}
.campaignTitSub::before,.campaignTitSub::after {
  content: "";
  display: block;
  position: absolute;
  width: 2px;
  height: 24px;
  background: #FA8200;
  top: 0;
}
.campaignTitSub::before {
  transform: rotate(-20deg);
  left: -0.5em;
}
.campaignTitSub::after {
  transform: rotate(20deg);
  right: -0.1em;
}
.campaignTitSmall {
  color: #004831;
  font-weight: bold;
  font-size: 1.7rem;
}
.campaignTitSmall.campaignTitNote {
  position: relative;
  top: -12px; 
}
.campaignTitPoint {
  color: #FA8200;
  font-size: 3.2rem;
  font-weight: bold;
  line-height: 1;
}
.campaignTitPoint em {
  font-size: 150%;
  display: inline-block;
  margin: 0 0.15em;
  padding: 20px 0 0 0;
}


.contentsOlive .otherSliderItemTxt small {
  font-weight: 400;
  font-size: 1.0rem;
  font-weight: normal;
  line-height: 1.3;
  display: inline-block;
  padding: 10px 0 0 0;
}

.contentsOlive .otherSliderItemCon {
  height: 52vw;
}
.contentsOlive .otherSliderItemTxt {
  position: relative;
  margin-left: -5vw;
  margin-right: -5vw;
}
.contentsOlive .secOther {
    background: #DEE881;
}
.contentsOlive .secOther::after {
    height: 480px;
    background: #EDF3B3;
    bottom: auto;
    top: 0;
}

@media screen and (min-width: 1024px) {
  .contentsOlive .otherSliderItemTxt {
      margin-left: -30px;
      margin-right: -30px;
  }
  .contentsOlive .otherSliderItemTxt small {
    font-size: 1.1rem;
  }
  .contentsOlive .otherSliderItemCon {
      height: 240px;
  }
  .contentsOlive .secOther {
    background: #DEE881;
  }
  .contentsOlive .secOther::after {
      height: 620px;
      background: #EDF3B3;
      bottom: auto;
      top: 0;
  }
}

.otherAttention {
  display: block;
  position: relative;
  z-index: 10;
  width: 85%;
  margin: 50px auto 15px auto;
}
.otherAttention dt {
  background: #004831;
  color: #fff;
  font-size: 1.8rem;
  position: relative;
  padding: 15px 0;
  cursor: pointer;
}
.otherAttention dt:after {
  content: "";
  display: block;
  position: absolute;
  width: 20px;
  height: 20px;
  top: calc(50% - 10px);
  right: 20px;
  background: url(../img/icon-toggle.svg) no-repeat center;
  background-size: contain;
  transform: rotate(180deg);
}
.otherAttention dt.active:after {
  transform: rotate(0deg);
}
.otherAttention dd {
  text-align: left;
  background: #F1F1F1;
  line-height: 1.6;
  padding: 35px 30px;
  display: none;
}

@media screen and (max-width: 1024px) {
  .campaignTit {
    line-height: 2.6;
  }
  .campaignTitSub {
    font-size: 2.2rem;
  }
  .campaignTitPoint {
    font-size: 2.4rem;
  }
  .campaignTitSmall {
    font-size: 1.7rem;
  }

}

