@charset "shift_jis";
/* Updated 2026/02/16.T */
/*---------------------------------------------
base
---------------------------------------------*/
body {
  overflow: hidden;
  min-width: auto;
}
#header-wrap {
  z-index: 3;
}
.cpEndTxt {
  z-index: 3;
}
.section-main {
  position: relative;
  overflow: visible;
  margin: 0 auto;
  max-width: 500px;
  background-color: #ffffff;
  box-shadow: 0 14px 40px 0 rgba(20, 29, 29, 0.16);
}
.section-mainInr {
  overflow: hidden;
}
.layout-bg01 {
  position: fixed;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: -5;
  display: flex;
  height: 100vh;
  background: url(/kojin/olive/special/campaign/collab/lawson202602/imgs/index_bg_01.jpg) center top / cover no-repeat;
}
@media screen and (max-width: 500px) {
  .section-main {
    box-shadow: none;
  }
}
/*---------------------------------------------
kv
---------------------------------------------*/
.kv-area01 {
  position: relative;
  background-color: #ffffff;
  text-align: center;
}
.kv-area01 .text {
  width: 92%;
  position: absolute;
  top: 42.7%;
  left: calc(50% - (92% / 2));
}
.kv-area01 .btn-list01 {
  margin-top: 0;
  padding: 0 24px;
  width: 100%;
  position: absolute;
  top: 81%;
  left: 0;
}
@media screen and (max-width: 499px) {
  .kv-area01 .btn-list01 {
    padding: 0 4.8vw;
  }
}
/*---------------------------------------------
footer
---------------------------------------------*/
#footer-area {
  position: relative;
  z-index: 1;
}
#footer-content {
  margin-top: 0;
}
.footer-logo {
  padding-bottom: 70px;
}
body.cpnloadEnd .footer-logo {
  padding-bottom: 0;
}
#footer-fixed .panel {
  background: rgba(255, 255, 255, 0.5);
}
#footer-fixed .btn-list01>.item {
  max-width: 360px;
}
#footer-fixed .btn-type01.-color01>.inner {
  min-height: 28px;
}
#footer-fixed .btn-type01.-color02>.inner {
  min-height: 34px;
}
@media screen and (max-width: 499px) {
  #footer-fixed .btn-type01 {
    width: 100%;
  }
  #footer-fixed .btn-type01.-color01>.inner {
    min-height: 8.533vw;
  }
  #footer-fixed .btn-type01.-color02>.inner {
    min-height: 10.133vw;
  }
}
/*---------------------------------------------
menu
---------------------------------------------*/
.menu-area01 {
  position: fixed;
  top: 0;
  right: 0;
  width: calc((100% - 500px) / 2);
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.menu-area01>.inner {
  max-width: 352px;
  background: #fff;
  border-radius: 43px;
  width: calc(100% - 40px);
}
.menu-area01 .list01 {
  padding: 9px 10px 40px 10px;
}
.menu-area01 .list01 a {
  font-weight: bold;
  font-size: 1.8rem;
  border-radius: 3em;
  display: block;
  padding: 2.6% 17.6%;
  text-decoration: none;
  color: #56635f;
}
.menu-area01 li:first-child>a {
  margin-top: 2.6%;
}
.menu-area01 .list01 li:not(:first-child)>a {
  margin-top: 2.1%;
}
.menu-area01 .list01 a.is-current,
.menu-area01 .list01 a:hover {
  position: relative;
  color: #f4476c;
}
.menu-area01 .list01 a.is-current::before,
.menu-area01 .list01 a:hover::before {
  content: '';
  display: block;
  width: 6%;
  height: 16px;
  background: url(/kojin/olive/special/campaign/collab/lawson202602/imgs/index_ico_02.png) center center / 100% auto no-repeat;
  position: absolute;
  top: 35%;
  left: 10%;
}
.menu-area01 .list01 a.is-current img,
.menu-area01 .list01 a:hover img {
  filter: invert(100%) sepia(0%) saturate(0%) hue-rotate(293deg) brightness(106%) contrast(103%);
  -webkit-filter: invert(100%) sepia(0%) saturate(0%) hue-rotate(293deg) brightness(106%) contrast(103%);
  opacity: 1;
}
.menu-area01 .btn-list01 {
  margin-top: 6%;
  padding: 5%;
  background: linear-gradient(270deg, rgba(120, 230, 240, 0.3) 0%, rgba(212, 236, 255, 0.3) 100%);
}
.menu-area01 .btn-list01>.item:not(:first-child) {
  margin-left: 4%;
}
@media screen and (max-width: 930px) {
  .menu-area01 {
    display: none !important;
  }
}
@media screen and (max-height: 642px) {
  .menu-area01 {
    display: none !important;
  }
}
/*---------------------------------------------
img
---------------------------------------------*/
.img-area01 {
  position: fixed;
  top: 0;
  left: 0;
  width: calc((100% - 500px) / 2);
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 930px) {
  .img-area01 {
    display: none !important;
  }
}
@media screen and (max-height: 642px) {
  .img-area01 {
    display: none !important;
  }
}
/*---------------------------------------------
content
---------------------------------------------*/
.content-block02 {
  background: transparent;
}
.content-block02:not(.-contentsFull01)>.inner {
  padding: 0 18px;
}
.content-block02.-bg01 {
  background: url(/kojin/olive/special/campaign/collab/lawson202602/imgs/index_bg_02.png) 0 0 / 100% auto repeat-y;
}
.content-block02.-bg02 {
  background: #eefaff;
}
.content-block02.-bg03 {
  background: #f2fbfb;
}
.content-block02.-bg04 {
  background: #fff;
}
@media screen and (max-width: 499px) {
  .content-block02:not(.-contentsFull01)>.inner {
    width: 100%;
    padding: 0 4.8vw;
  }
}
/*---------------------------------------------
table
---------------------------------------------*/
.table-radius01 {
  font-size: 1.8rem;
}
.table-radius01 tr:first-child th {
  border-radius: 18px 18px 0 0;
}
.table-radius01 tr:first-child td {
  border-radius: 0 0 0 0;
}
.table-radius01 tr:last-child th {
  border-bottom: 0;
  border-radius: 0 0 0 0;
}
.table-radius01 tr:last-child td {
  border-bottom: 0;
  border-radius: 0 0 18px 18px;
}
.table-radius01 th {
  padding: 15px 10px 15px 16px;
  width: 100%;
  text-align: center;
  border-bottom: 1px solid #d5dedb;
  background-color: #006444;
  color: #fff;
  font-weight: bold;
  display: block;
}
.table-radius01 td {
  padding: 15px 16px;
  width: 100%;
  border-bottom: 1px solid #d5dedb;
  background-color: #fff;
  display: block;
}
/*---------------------------------------------
card
---------------------------------------------*/
.card-box01.-green01 {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px 10px;
  background: #f4f8e5;
  border: 3px solid #147a4f;
  color: #017a4f;
}
.card-normal03 {
  border-radius: 20px;
}
.card-normal03.-deco01 {
  position: relative;
}
.card-normal03.-deco01::before,
.card-normal03.-deco01::after {
  content: '';
  display: block;
  width: 89px;
  height: 93px;
  background: url(/kojin/olive/special/campaign/collab/lawson202602/imgs/index_bg_deco_01.png) center top / 100% auto no-repeat;
  position: absolute;
  top: -37px;
  left: -9px;
}
.card-normal03.-deco01::after {
  width: 52px;
  height: 48px;
  background: url(/kojin/olive/special/campaign/collab/lawson202602/imgs/index_bg_deco_02.png) center top / 100% auto no-repeat;
  position: absolute;
  top: initial;
  left: initial;
  bottom: 38px;
  right: -8px;
}
.card-normal03.-deco01>.inner {
  position: relative;
}
.card-normal03 {
  border-radius: 20px;
}
.card-normal03>.inner>.header {
  border-radius: 20px 20px 0 0;
}
.card-normal03>.inner>.body {
  border-radius: 0 0 20px 20px;
}
.card-normal03.-pink01>.inner>.header {
  text-align: center;
  background: #f4476c;
  color: #fff;
}
.card-normal03.-blue01>.inner>.header {
  text-align: center;
  background: #0076bf;
  color: #fff;
}
.card-normal03.-pink01>.inner>.header>.title>.inner,
.card-normal03.-blue01>.inner>.header>.title>.inner {
  color: #fff;
}
.card-normal03.-pink01>.inner>.body,
.card-normal03.-blue01>.inner>.body {
  padding: 20px;
}
/*---------------------------------------------
list
---------------------------------------------*/
.list-step01.-blue01>.item:not(:first-child)::before {
  border-color: #0076bf transparent transparent transparent;
}
.list-step01.-blue02>.item:not(.-full) {
  padding: 16px 18px;
}
.list-step01.-blue02>.item:not(:first-child) {
  padding-top: 149px;
}
.list-step01.-blue02>.item:not(:first-child)::before {
  content: "";
  display: block;
  position: absolute;
  top: 40px;
  left: calc(50% - 69px);
  width: 138px;
  height: 69px;
  border: none;
  background: url(/kojin/olive/special/campaign/collab/lawson202602/imgs/index_ico_01.svg) center center / 100% auto no-repeat;
}
.list-step01.-blue02>.item.-bg01 {
  padding: 40px 0;
  background: #fff;
}
.list-circle01>.item::before {
  top: .65em;
  width: .3em;
  height: .3em;
  background: #56635f;
}
.list-border>.item:not(:first-child) {
  margin-top: 24px;
  padding-top: 24px;
  border-top: 2px solid;
}
.-pink01 .list-border>.item:not(:first-child) {
  border-color: #f4476c;
}
.-blue01 .list-border>.item:not(:first-child) {
  border-color: #0076bf;
}
/*---------------------------------------------
button
---------------------------------------------*/
.btn-list01>.item {
  max-width: initial;
}
.btn-type01.-orange01 {
  background: #ff5f04;
}
@media screen and (max-width: 1460px) {
  .btn-type01.-small01>.inner {
    font-size: 1.027vw;
  }
}
@media screen and (max-width: 499px) {
  .btn-list01.-spColumn>.item {
    width: calc((100% - 4%) / 2);
  }
  .btn-list01>.item:not(:first-child) {
    margin-left: 4%;
  }
}
.mark-plus {
  display: inline-block;
  width: 1.5em;
  height: 1.5em;
  position: relative;
  background: #000;
  border-radius: 50%;
  vertical-align: bottom;
}
.mark-plus::before,
.mark-plus::after {
  content: '';
  display: block;
  width: 60%;
  height: 3px;
  background: #fff;
  position: absolute;
  top: 44%;
  left: 20%;
}
.mark-plus::after {
  transform: rotate(90deg);
}
.mark-plus.-pink01 {
  background: #f4476c;
}
.mark-plus.-blue01 {
  background: #0076bf;
}
.position-wrap01 {
  position: relative;
}
[class*="position-wrap"]>.item {
  position: absolute;
}
.position-wrap01>.item:nth-child(2) {
  width: 71%;
  top: 43.5%;
  left: 18%;
}
.position-wrap01>.item:nth-child(3) {
  width: 71%;
  top: 93.5%;
  left: 18%;
}
@media screen and (max-width: 375px) {
  .position-wrap01 ._fsXs {
    font-size: 3.2vw !important;
  }
}
.detail-text01 {
  display: flex;
  margin-right: 0;
}
.detail-text01>.title {
  flex: 0 0 auto;
}
.detail-text01:not(:first-child) {
    margin-top: 8px;
}
/*---------------------------------------------
slick
---------------------------------------------*/
.tab-block01>.list>.item>.switch>.inner {
  min-height: 93px;
}
.slick-slide {
  margin: 0 8px;
  width: 352px;
}
.carousel-block03>.list>.slick-arrow.slick-prev {
  left: 5px;
}
.carousel-block03>.list>.slick-arrow.slick-next {
  right: 5px;
}
.slick-track {
  display: flex;
}
.slick-slide {
  height: auto !important;
}
.slick-slide>[class*="card"] {
  height: 100%;
}
/*---------------------------------------------
modal
---------------------------------------------*/
.modal-block01 .btn-type01 {
  font-size: initial;
}
html.is-modalShow {
  overflow: hidden;
  height: 125%;
}
html.is-modalShow body {
  position: fixed;
  width: 100%;
}
.modal-area.-show .modal-bg {
  display: flex;
}
.modal-area.-show .modal-content {
  display: block;
}
.modal-area .modal-bg {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 94;
  display: none;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
}
.modal-area .modal-content {
  display: none;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  width: 100%;
  height: 100%;
}
.modal-area .modal-frame {
  position: relative;
  z-index: 7;
  overflow-y: auto;
  box-sizing: border-box;
  margin: 0 auto;
  max-height: calc(100% - 120px);
  width: 960px;
  border-radius: 6px;
  background: #ffffff;
  box-shadow: 0 14px 40px rgba(20, 29, 29, 0.16);
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .modal-area .modal-frame {
    width: calc(100% - 9.6vw);
  }
}
.modal-area .modal-wrap01 {
  position: relative;
  overflow-y: auto;
  box-sizing: border-box;
  padding: 24px 30px 24px 30px;
  width: 100%;
  height: 50%;
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .modal-area .modal-wrap01 {
    padding: 24px 16px 24px 16px;
  }
}
.modal-area .ttl01 {
  padding: 0 1px 0 0;
  color: #004831;
  text-align: center;
  font-weight: bold;
  font-size: 2.8rem;
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .modal-area .ttl01 {
    font-size: 2.4rem;
  }
}
/* SMALL STYLES */
@media screen and (max-width: 374px) {
  .modal-area .ttl01 {
    font-size: 6.4vw;
  }
}
.modal-area .formWrap01 {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  margin-top: 24px;
  height: 60vh;
  background: url(/kojin/olive/special/campaign/collab/lawson202602/imgs/index_txt_01.svg) center center no-repeat;
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .modal-area .formWrap01 {
    margin-top: 6.13333vw;
  }
}
.modal-area .formWrap01 iframe {
  display: block;
  width: 100%;
  height: 100%;
}
.modal-area .btnClose01 {
  appearance: none;
  position: absolute;
  top: 22px;
  right: 21px;
  width: 34px;
  height: 34px;
  border: 1px solid #d5dedb;
  border-radius: 50%;
  background: url("/kojin/cmn/imgs/btn_close_01.svg") center center no-repeat #ffffff;
}
.btn-type01[data-modal] {
  display: none;
}
.btn-type01[data-modal].-active {
  display: inline-flex;
}
.modal-content.is-modalShow,
.is-modalShow[data-modal].-active {
  display: flex;
}
/*---------------------------------------------
general
---------------------------------------------*/
._t-gray04 {
  color: #56635f !important;
}
._t-pink01 {
  color: #f6c7d8 !important;
}
._t-yellow01 {
  color: #ffdb66 !important;
}