@charset "shift_jis";
/* Updated 2025/09/16.T */
@font-face {
  font-family: "noto-sans-black";
  src: url("/kojin/special/fonts/NotoSansJP-Black.woff") format("woff");
}
#footer-content {
  margin-top: 0;
}
._mt20{
  margin-top: 20px!important;
}
hr{
  margin: 40px 0;
}
sup{
  font-size: .8em;
}
.toggle-block01.card-normal01>.inner>.header[role=tab]::after{
  top: calc(50% - 13px);
  right: 14px;
  width: 26px;
  height:26px;
}
.tab-block01>.list{
  justify-content: center;
}
.tab-block01>.list>.item{
  width: 38.66%;
}
.tab-block01>.list>.item:not(:first-child){
  margin-left: 5px;
}
.tab-block01>.list>.item>.switch>.inner{
  min-height: 60px;
  font-size: 2rem;
}
#footer-area.footer-fixed:not(.-close) #footer-content .footer-logo {
  padding-bottom: 80px;
}
/*-----------------------
fixed-area
------------------------*/
#fixed-area .btn-list01>.item{
  max-width: 240px;
}
#fixed-area .btn-list01>.item:not(:first-child) {
  margin-left: 16px;
}
/*-----------------------
common parts
------------------------*/
.btn-type01.-orange01 {
  background: #fd5e04;
}
.sec-inr01 {
  width: 100%;
  margin: 0 auto;
  padding: 0 18px;
}
/*-----------------------
kv-area01
------------------------*/
.kv-head01{
  padding: 20px 0;
  background: #fff;
  text-align: center;
}
.kv-head01 img{
  max-width: 465px;
}
.kv-area01{
  padding: 30px 0 120px;
  background: #f5f9e6 url(/kojin/olive/special/campaign/sbi/CP04229/imgs/index_bg_01.png) no-repeat center 0 / cover;
}
.kv-area01>.inner{
  max-width: 1080px;
  margin: 0 auto;
  text-align: center;
}
.kv-area01>.inner>.ttl01{
  margin:  0 auto;
  max-width: 569px;
}
.kv-area01>.kv-cv01{
  max-width: 1080px;
  margin: 24px auto 0;
}
.kv-area01>.kv-cv01 .text01{
  margin-bottom: 10px;
}
.kv-area01>.kv-cv01>.btn-list01{
  align-items: flex-start;
}
.kv-area01>.kv-cv01 .btn-list01>.item,
.kv-area01>.kv-cv01 .btn-type01.-large01{
  max-width: 430px;
}
.kv-area01>.kv-cv01 .btn-type01.-large01{
  width: 100%;
}
.kv-area01>.kv-cv01 .btn-type01>.inner{
  min-height: 48px;
  font-size: 2rem;
}
.kv-area01>.kv-cv01 .btn-list01>.item._space{
  padding-top: calc(1.5em + 10px);
}
/*-----------------------
btn-text01
------------------------*/
.btn-text01{
  text-align: center;
}
.btn-text01>p{
  display: inline-block;
  position: relative;
  padding: 0 18px;
  font-weight: bold;
  color: #004831;
}
.btn-text01>p::before,
.btn-text01>p::after{
  display: block;
  content: '';
  position: absolute;
  top: 0.1em;
  width: 13px;
  height: 21px;
  background: url(/kojin/olive/special/campaign/sbi/CP04229/imgs/index_ico_10.svg) no-repeat 0 0 / 100%;
}
.btn-text01>p::before{
  left: 0;
}
.btn-text01>p::after{
  right: 0;
  transform: scale(-1 , 1);
}
/*-----------------------
bg-area01
------------------------*/
.bg-area01{
  margin-top: -60px;
  padding: 48px 10px 120px;
  border-radius: 60px 60px 0 0;
  background:#ECF6C9;
}
.bg-area01>.inner{
  max-width: 1180px;
  margin: 0 auto;
}
.bg-area01._color02{
  padding-bottom: 80px;
  background:#FFFCDD;
}
/*bg-img*/
.bg-img01{
  background-image: url(/kojin/olive/special/campaign/sbi/CP04229/imgs/index_bg_02.svg);
  background-position: center 0;
  background-repeat: no-repeat;
}
/*02*/
.bg-area02{
  margin-top: -60px;
  padding-bottom: 60px;
  border-radius: 60px 60px 0 0;
  background:#fff;
}
.bg-area02:last-child{
  padding-bottom: 0;
}
/*-----------------------
sec-ttl01
------------------------*/
.sec-ttl01{
  text-align: center;
}
.sec-ttl01 ._ttl01{
  width: 318px;
}
.sec-ttl01 ._ttl02{
  width: 271px;
}
.sec-ttl01 ._ttl03{
  width: 311px;
}
/*-----------------------
card-wrap01
------------------------*/
.card-wrap01{
  display: flex;
  justify-content: center;
  margin: 32px 0 0;
}
.card-wrap01>.item01{
  position: relative;
  width: 330px;
  max-width: 28%;
  border-radius: 16px;
  background: #fff;
}
.card-wrap01>.item01:not(:first-child){
  margin-left: 73px;
}
.card-wrap01>.item01:not(:first-child)::before{
  display: block;
  content: '';
  position: absolute;
  left: -50px;
  top: calc(50% - 44px);
  height: 88px;
  width: 33px;
  background: url(/kojin/olive/special/campaign/sbi/CP04229/imgs/index_ico_05.svg) no-repeat 0 0 / 100%;
}
.card-wrap01>.item01>.head01{
  border-radius: 16px 16px 0 0;
  padding: 8px;
  background: #017A4F;
  text-align: center;
}
.card-wrap01>.item01>.body01{
  padding: 16px 14px 24px;
}
.card-wrap01 .btn-type01>.inner{
  min-height: 48px;
}
.card-wrap01 [class*=icon-][class*=btn-type]{
  padding: 3px 10px;
}
.card-wrap01 [class*=icon-][class*=btn-type]>.inner {
  padding-right: 20px;
  padding-left: 20px;
}
.card-wrap01 [class*=icon-][class*=btn-type]>.inner .item {
  position: absolute;
  top: calc(50% - (22px / 2));
  right: 8px;
  left: auto;
  width: 22px;
  height: 22px;
}
/*-----------------------
hr-arrow01
------------------------*/
.hr-arrow01{
  display: block;
  position: relative;
  margin: 32px auto;
  height: 69px;
  border: none;
  overflow: initial;
}
.hr-arrow01::before,
.hr-arrow01::after{
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
  width:138px;
  height: 69px;
}
.hr-arrow01::before {
  -webkit-clip-path: polygon(0 0, 50.2% 55%, 50.2% 100%, 0 45%);
  clip-path: polygon(0 0, 50.2% 55%, 50.2% 100%, 0 45%);
  background-color: #C6DE78;
}
.hr-arrow01::after {
  -webkit-clip-path: polygon(100% 0, 100% 45%, 49.2% 100%, 49.2% 55%);
  clip-path: polygon(100% 0, 100% 45%, 49.2% 100%, 49.2% 55%);
  background-color: #A0C81E;
}
/*-----------------------
img-note01
------------------------*/
.img-note01{
  margin: 0 auto;
  max-width: 900px;
}
/*02*/
.img-note02{
  margin: 0 auto;
  max-width: 1080px;
}
/*-----------------------
content-area01
------------------------*/
.content-area01{
  max-width: 920px;
  margin: 0 auto;
  padding: 48px 10px 60px;
}
/*-----------------------
text-wrap01
------------------------*/
.text-wrap01{
  margin: 32px 0 0;
  text-align: center;
  font-weight: bold;
  color: #004831;
  font-size: 2.4rem;
}
.text-wrap01 em{
  font-weight: bold;
  background: linear-gradient(transparent 60%, #FFD036 60%);
}
/*-----------------------
card-wrap02
------------------------*/
.card-wrap02{
  display: flex;
  flex-wrap: wrap;
  max-width: 704px;
  margin: 0 auto 0;
}
.card-wrap02>.item01{
  position: relative;
  width: 340px;
  padding: 14px 14px 22px;
  margin-top: 44px;
  border-radius: 16px;
  border: 2px solid #C4D700;
  text-align: center;
}
.card-wrap02>.item01:nth-child(2n){
  margin-left: 24px;
}
.card-wrap02>.item01>.icon01{
  position: absolute;
  left: 16px;
  top: -22px;
}
.card-wrap02>.item01>.img01{
  margin-bottom: 16px;
}
/*-----------------------
text-area01
------------------------*/
.text-area01{
  margin: 20px 0 0;
  padding: 8px;
  background: #ECF6C9;
  font-weight: bold;
  font-size: 1.4rem;
}
.text-area01:first-child{
  margin-top: 0;
}
/*-----------------------
img-layout01
------------------------*/
.img-layout01{
  display: flex;
  margin: 20px 0 0;
}
.img-layout01>.img{
  max-width: 340px;
  margin: 0 auto;
}
.img-layout01>.text{
  flex: 1;
  padding-top: 40px;
  margin: 0 0 0 20px;
}
/*-----------------------
text-balloon01
------------------------*/
.text-balloon01{
  position: relative;
  border-radius: 16px;
  padding: 16px;
  margin-bottom: 36px;
  background: #FFEBEB;
}
.text-balloon01>.ttl01{
  font-weight: bold;
  color: #C83030;
}
.text-balloon01>.ttl01>img{
  width: 32px;
  margin-right: 4px;
  vertical-align: -0.6em;
}
.text-balloon01::after{
  display: block;
  content: '';
  position: absolute;
  left: calc(50% - 43px);
  bottom: -28px;
  height:38px;
  width: 86px;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  background: #FFEBEB;
}
/*-----------------------
img-layout02
------------------------*/
.img-layout02{
  display: flex;
  margin: 12px 0 0;
}
.img-layout02>.img{
  max-width: 340px;
}
.img-layout02>.text{
  flex: 1;
  margin: 0 20px 0 0;
}
/*-----------------------
card-normal01
------------------------*/
.card-normal01.-type01>.inner>.header{
  padding: 16px 48px 16px 16px;
  text-align: left;
}
.card-normal01.-type01>.inner>.header>.title{
  font-size: 1.6rem;
  color: #141D1D!important;
}
.card-normal01.-type01>.inner>.header>.title{
  font-size: 1.6rem;
  color: #141D1D!important;
}
.card-normal01.-type01>.inner>.body{
  padding: 16px;
}
.card-normal01.-type01>.inner>.body hr{
  margin: 16px -16px;
}
.card-normal01.-type01>.inner>.body:not(:first-child)::before {
  left: 0;
  right: 0;
  width: auto;
}
.toggle-block01.-type01.card-normal01>.inner>.header[role=tab]::after{
  top: calc(50% - 12px);
  width: 24px;
  height: 24px;
}
/*-----------------------
qa-wrap01
------------------------*/
.qa-wrap01{
  max-width: 900px;
  margin: 32px auto 0;
}
.qa-wrap01>.item01{
  margin: 12px 0 0;
  border-radius: 8px;box-shadow: 0px 4px 6px 0px #141D1D14;
  box-shadow: 0px 0px 4px 0px #141D1D0D;
  background: #fff;
}
.qa-wrap01>.item01>.head01{
  position: relative;
  padding: 24px 28px 16px 68px;
  color: #004831;
  font-weight: bold;
}
.qa-wrap01>.item01>.body01{
  position: relative;
  padding:0 28px 24px 68px;
}
.qa-wrap01>.item01 .icon01{
  position: absolute;
  left: 28px;
  top: 0.6em;
  font-size: 2.9rem;
  color: #004831;
  line-height: 1;
  font-weight: bold;
}
.qa-wrap01>.item01>.body01 .icon01{
  top: -0.1em;
  left: 30px;
  color: #A0C81E;
}
.qa-wrap01>.item01 .line01{
  background: linear-gradient(transparent 60%, #FFD036 60%);
}
/*-----------------------
text-layout01
------------------------*/
.text-layout01{
  text-align: center;
}
.text-layout01>.text01{
  font-size: 3.2rem;
  line-height: 1;
  color: #FF5F04;
  font-family: "noto-sans-black";
}
.text-layout01>.text02{
  margin: 16px 0 0;
  font-size: 2rem;
  font-weight: bold;
  color: #004831;
}
.text-layout01>.text02>em{
  background-image: radial-gradient(3px 3px at center center,#004831,#004831 100%,transparent);
  background-position: top right;
  background-repeat: repeat-x;
  background-size: 1em 6px;
  padding-top: .2em;
  font-size: 2.4rem;
  font-weight: bold;
}
/*-----------------------
table-wrap01
------------------------*/
.table-wrap01{
  overflow: hidden;
  border-radius: 12px;
  margin: 24px 0 0;
  border: 1px solid #D5DEDB;
}
.table-wrap01>table{
  width: 100%;
  background: #fff;
  font-size: 1.4rem;
}
.table-wrap01>table>tbody>tr>th{
  padding: 16px 14px 16px 16px;
  background: #044934;
  color: #fff;
  font-weight: bold;
}
.table-wrap01>table>tbody>tr>td{
  padding: 16px;
}
.table-wrap01>table>tbody>tr:not(:first-child)>th,
.table-wrap01>table>tbody>tr:not(:first-child)>td{
  border-top: 1px solid #D5DEDB;
}
/*-----------------------
modal
------------------------*/
.modal-block01.-teiki01 {
  max-width: 960px;
  width: 100%;
  background-color: #F5F9E6;
  border-radius: 0;
}
.modal-block01.-teiki01>.inner>.header {
  padding: 30px 40px;
}
.modal-block01.-teiki01>.inner>.header>.title>.inner {
  color: #004831;
}
.modal-block01.-teiki01>.inner>.body {
  padding: 50px 4% 50px 4%;
  background-color: #fff;
}
.modal-block01.-teiki01>.inner>.body:not(:first-child) {
  margin: 0 40px 40px;
}
.modal-block01.-teiki01>.inner>.body>.txtWrap01 {
  font-size: 2rem;
  text-align: center;
}
.modal-block01.-teiki01>.inner>.body>.btnWrap01 {
  max-width: 488px;
  margin: 16px auto 0;
}
.modal-block01.-teiki01>.inner>.header>.btn {
  top: 20px;
  right: 24px;
}
.modal-block01.-teiki01>.inner>.header>.btn:focus {
  outline: none;
}
.modal-block01.-teiki01 .icon-circledLink01>.inner::after {
  content: '';
  display: block;
  position: absolute;
  top: calc(50% - 10px);
  right: 12px;
  width: 20px;
  height: 20px;
  background: url(/kojin/olive/special/campaign/sbi/CP04229/imgs/index_ico_11.svg) no-repeat 0 0 / 100%;
}
.modal-block01.-teiki01 [class*=icon-][class*=btn-type]>.inner {
  padding-right: 20px;
  padding-left: 20px;
}
.modal-list01 {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 32px;
}
.modal-list01>.item {
  position: relative;
  text-align: center;
}
.modal-list01>.item:not(:first-child) {
  margin-left: 138px;
}
.modal-list01>.item:not(:last-child)::after {
  position: absolute;
  top: 40%;
  right: -80px;
  display: block;
  width: 42px;
  height: 38px;
  background-color: #2b2b2b;
  content: "";
  clip-path: polygon(100% 0, 0 0, 50% 100%);
  transform: rotate(-90deg);
}
.modal-list01 .img01>img{
  max-width: 220px;
}
@media screen and (min-width: 768px) {
  .tab-block01>.wrap>.panel>.inner {
    padding: 40px 16px 0;
  }
  .btn-type01.-type01:not(:disabled):not([aria-disabled=true]):hover{
    background: #538775;
  }
  .btn-type01.-type03:not(:disabled):not([aria-disabled=true]):hover{
    background: #e9874f;
  }
}
@media screen and (max-width: 767px) {
  /*-----------------------
  fixed-area
  ------------------------*/
  #fixed-area .btn-list01>.item:not(:first-child) {
    margin-left: 16px;
  }
  /*-----------------------
  common
  ------------------------*/
  .tab-block01>.list{
    margin: 0 -16px;
  }
  .tab-block01>.list>.item{
    width: 44.53%;
  }
  .tab-block01>.list>.item:not(:first-child){
    margin-left: 1.3%;
  }
  .tab-block01>.list>.item>.switch>.inner{
    min-height: 90px;
  }
  .tab-block01>.wrap>.panel>.inner{
    padding-top: 40px;
  }
  /*-----------------------
  kv-area01
  ------------------------*/
  .kv-head01{
    padding: 10px 0;
  }
  .kv-head01>img{
    width: 75%;
  }
  .kv-area01{
    padding: 0 0 88px;
    background: #F5F9E6;
  }
  .kv-area01>.inner>.ttl01{
    margin:  0 auto;
    width: 100%;
    max-width: 100%;
  }
  .kv-area01>.kv-cv01{
    margin: 0 auto 0;
    padding: 0 18px;
  }
  .kv-area01>.kv-cv01 .btn-list01>.item{
    margin: 0 auto 0;
  }
  .kv-area01>.kv-cv01 .btn-list01>.item._space{
    padding-top: 0;
    margin-top: 16px;
  }
  /*-----------------------
  bg-area01
  ------------------------*/
  .bg-area01{
    margin-top: -28px;
    padding: 46px 16px 88px;
    border-radius: 28px 28px 0 0;
  }
  .bg-area01._color02{
    padding-bottom: 58px;
  }
  /*bg-img*/
  .bg-img01{
    background-size: 100%;
  }
  /*02*/
  .bg-area02{
    margin-top: -28px;
    padding-bottom: 28px;
    border-radius: 28px 28px 0 0;
  }
  /*-----------------------
  card-wrap01
  ------------------------*/
  .card-wrap01{
    display: block;
  }
  .card-wrap01>.item01{
    width: auto;
    max-width: 100%;
  }
  .card-wrap01>.item01:not(:first-child){
    margin: 98px 0 0;
  }
  .card-wrap01>.item01:not(:first-child)::before{
    left: calc(50% - 59px);
    top: -62px;
    height: 33px;
    width: 118px;
    background: url(/kojin/olive/special/campaign/sbi/CP04229/imgs/index_ico_05_sp.svg) no-repeat 0 0 /100%;
  }
  .card-wrap01>.item01>.body01{
    padding: 16px 16px 24px;
  }
  /*-----------------------
  img-wrap01
  ------------------------*/
  .img-wrap01{
    margin: 0 -16px;
  }
  .img-wrap02 img{
    width: 260px;
  }
  .img-wrap03 img{
    width: 282px;
  }
  /*-----------------------
  content-area01
  ------------------------*/
  .content-area01{
    padding: 46px 16px 60px;
  }
  .content-area01 hr{
    margin: 40px -16px 32px;
  }
  /*-----------------------
  card-wrap02
  ------------------------*/
  .card-wrap02{
    display: block;
    margin: 52px auto 0;
  }
  .card-wrap02>.item01{
    width: 100%;
    margin: 0;
    margin: 44px 0 0;
  }
  .card-wrap02>.item01:nth-child(2n){
    margin: 44px 0 0;
  }
  /*-----------------------
  img-layout01
  ------------------------*/
  .img-layout01{
    display: block;
    margin: 16px 0 0;
  }
  .img-layout01:first-child{
    margin-top: 0;
  }
  .img-layout01>.text{
    padding: 0;
    margin: 16px 0 0;
  }
  /*-----------------------
  img-layout02
  ------------------------*/
  .img-layout02{
    display: block;
  }
  .img-layout02>.img{
    margin: 8px auto 0;
  }
  .img-layout02>.text{
    margin: 0;
  }
  /*-----------------------
  qa-wrap01
  ------------------------*/
  .qa-wrap01>.item01>.head01{
    padding: 20px 20px 20px 52px;
  }
  .qa-wrap01>.item01>.body01{
    position: relative;
    padding: 0 20px 20px 52px;
  }
  .qa-wrap01>.item01 .icon01{
    left: 18px;
    top: 0.7em;
    font-size: 2.4rem;
  }
  .qa-wrap01>.item01>.body01 .icon01{
    left: 19px;
    top: -0.2em;
  }
  /*-----------------------
  table-wrap01
  ------------------------*/
  .table-wrap01{
    margin-top: 32px;
  }
  /*-----------------------
  modal
  ------------------------*/
  .modal-block01.-teiki01>.inner>.header {
    padding: 24px;
  }
  .modal-block01.-teiki01>.inner>.body:not(:first-child) {
    margin: 0 24px 24px;
  }
  .modal-block01.-teiki01>.inner>.body {
    padding: 40px 20px;
  }
  .modal-block01.-teiki01>.inner>.body>.txtWrap01 {
    font-size: 1.4rem;
    text-align: left;
  }
  .modal-block01>.inner>.header>.title>.inner {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 374px) {
  /*-----------------------
  modal
  ------------------------*/
  .modal-block01.-teiki01 .teiki-btn01 {
    font-size: 1.4rem;
  }
}