@charset "shift_jis";
/* Updated 2025/10/10.T */
/*-------------------------------
font
-------------------------------*/
@font-face {
  font-family: "noto-sans-black";
  src: url("/kojin/campaign/fonts/NotoSansJP-Black.woff") format("woff");
}
/*-------------------------------
layout
-------------------------------*/
body {
  overflow: hidden;
  min-width: auto;
}
#header-wrap {
  z-index: 4;
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  #main-area {
    background-color: #f5f9e6;
  }
}
.cpEndTxt {
  z-index: 1;
}
#containment-area {
  margin-bottom: 0;
}
#footer-area {
  position: relative;
  z-index: 1;
}
#footer-content {
  margin-top: 0;
}
.layout-container01 {
  position: relative;
  z-index: 1;
  overflow: visible;
  margin: 0 auto;
  max-width: 500px;
}
.layout-bg01 {
  position: fixed;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 0;
  height: 100vh;
  background: url("/kojin/campaign/nippons2025/imgs/index_bg_01.jpg") center 0 no-repeat;
  background-size: cover;
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .layout-bg01 {
    display: none;
  }
}
/*-----------------------
cmn
------------------------*/
.btn-type01.-orange01 {
  background-color: #e95501;
}
.btn-type01.-orange01:hover {
  background-color: #e95501 !important;
}
.btn-type01.-green01 {
  background-color: #017a4f;
}
.btn-type01.-green01:hover {
  background-color: #017a4f !important;
}
.cmn-btn01 {
  position: relative;
  border: 3px solid #004831 !important;
}
.cmn-btn01 .inner {
  padding: 0 0 0 25px;
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .cmn-btn01 .inner {
    padding: 0 0 0 0;
  }
}
.cmn-btn01 .inner:after {
  margin: 0 0 0 14px;
  width: 26px;
  height: 26px;
  background: url("/kojin/cmn/imgs/ico_arrow_right_02.svg") 0 0/cover no-repeat;
  content: "";
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .cmn-btn01 .inner:after {
    position: absolute;
    top: calc(50% - 13px);
    right: 9px;
    display: block;
    margin: 0;
  }
}
/*-----------------------
menu-area
------------------------*/
.menu-area01 {
  position: fixed;
  top: calc(50% - 220px);
  right: 83px;
  z-index: 30;
  width: 340px;
  border-radius: 20px;
  background-color: rgba(255, 255, 255, 0.9);
  box-shadow: 0 0 20px 0 #00000014;
  transition: all .25s ease-out;
}
.menu-area01 .head01 {
  position: relative;
  border-radius: 20px 20px 0 0;
  background: #006444;
  color: #ffffff;
  text-align: center;
}
.menu-area01 .head01:before {
  position: absolute;
  bottom: -24px;
  left: 0;
  z-index: 0;
  display: block;
  width: 100%;
  height: 30px;
  background: url("/kojin/campaign/nippons2025/imgs/index_bg_04.svg") 0 bottom no-repeat;
  background-size: 100% auto;
  content: "";
}
.menu-area01 .ttl01 {
  position: relative;
  padding: 35px 0 6px 0;
  line-height: 1;
}
.menu-area01 .list01 {
  position: relative;
  padding: 62px 0 108px 0;
}
.menu-area01 .list01:after {
  position: absolute;
  bottom: -8px;
  left: 0;
  display: block;
  width: 100%;
  height: 100px;
  background: url("/kojin/campaign/nippons2025/imgs/index_img_02.svg") calc(50% + 25px) 0 no-repeat;
  content: "";
}
.menu-area01 a {
  position: relative;
  display: block;
  padding: 18px 0 18px 98px;
  color: #56635f;
  text-decoration: none;
  letter-spacing: .1em;
  font-weight: bold;
  font-size: 1.8rem;
  line-height: 1;
}
.menu-area01 a:before {
  position: absolute;
  top: calc(50% - 6px);
  left: 66px;
  display: none;
  width: 14px;
  height: 15px;
  background: url("/kojin/campaign/nippons2025/imgs/index_ico_05.svg") 0 0 no-repeat;
  content: "";
}
.menu-area01 a.is-current {
  color: #004831;
}
.menu-area01 a.is-current:before {
  display: block;
}
@media screen and (max-width: 1730px) {
  .menu-area01 {
    right: 28px;
  }
}
@media screen and (max-width: 1660px) {
  .menu-area01 {
    right: 20px;
    width: 260px;
  }
  .menu-area01 .list01:after {
    background-position: calc(50% + 5px) 0;
  }
  .menu-area01 a {
    padding-left: 40px;
  }
  .menu-area01 a.is-current:before {
    left: 20px;
  }
}
@media screen and (max-width: 1470px) {
  .menu-area01 {
    right: 10px;
    width: 242px;
  }
  .menu-area01 .list01:after {
    background-position: calc(50% + 0px) 0;
  }
  .menu-area01 a {
    padding-left: 30px;
    font-size: 1.4rem;
  }
  .menu-area01 a.is-current:before {
    left: 10px;
  }
}
@media screen and (max-width: 1420px) {
  .menu-area01 {
    display: none !important;
  }
}
/*-----------------------
kv-area
------------------------*/
.kv-area {
  position: relative;
  z-index: 1;
  text-align: center;
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .kv-area {
    padding: 0 0 66px 0;
    border-radius: 0 0 5.33333vw 5.33333vw;
    background: url("/kojin/campaign/nippons2025/imgs/index_bg_02.png") 0 0 no-repeat;
    background-size: cover;
  }
}
.kv-area .wrap02 {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 20px 0 20px 0;
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .kv-area .wrap02 {
    display: block;
    padding: 3.73333vw 8vw 0 8vw;
  }
}
.kv-area .block01:nth-child(2) {
  margin: 0 0 0 54px;
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .kv-area .block01:first-child {
    padding-top: 6.4vw;
  }
  .kv-area .block01:nth-child(2) {
    margin: 5.33333vw 0 0 0 !important;
  }
}
@media print, screen and (min-width: 768px) {
  .kv-area .ttl01 {
    padding: 0 137px 0 0;
  }
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .kv-area .ttl01 img {
    width: 100%;
    height: auto;
  }
}
.kv-area .text-hooray01 {
  color: #004831;
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .kv-area .text-hooray01 {
    margin: 0 -7.46667vw;
    font-size: 4.26667vw;
  }
}
/* SMALL STYLES */
@media screen and (max-width: 374px) {
  .kv-area .text-hooray01 > .inner {
    padding: 0 2.66667vw;
  }
}
.kv-area .text-hooray01 > .inner:before {
  bottom: 11px;
  left: 8px;
  width: 18px;
  background-color: #004831;
  transform: rotate(50deg);
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .kv-area .text-hooray01 > .inner:before {
    bottom: 2.93333vw;
    left: -0.53333vw;
    width: 4.8vw;
    height: 0.53333vw;
  }
}
.kv-area .text-hooray01 > .inner:after {
  right: 8px;
  bottom: 11px;
  width: 18px;
  background-color: #004831;
  transform: rotate(-50deg);
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .kv-area .text-hooray01 > .inner:after {
    right: -0.53333vw;
    bottom: 2.93333vw;
    width: 4.8vw;
    height: 0.53333vw;
  }
}
.kv-area .btn-type01 {
  margin: 5px 0 0 0;
  width: 406px;
  height: 66px;
  font-size: 2.0rem;
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .kv-area .btn-type01 {
    margin: 1.33333vw 0 0 0;
    width: 108.26667vw !important;
    height: 17.6vw;
    font-size: 5.33333vw;
  }
}
.kv-area .btn-type01 > .inner {
  min-height: 100%;
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .kv-area .btn-type01 > .inner:after {
    top: calc(50% - 3.4666vw);
    right: 2.4vw;
    width: 6.93333vw;
    height: 6.93333vw;
  }
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .kv-area .btn01 {
    height: 14.93333vw;
  }
}
.kv-area .btn02 {
  font-size: 1.6rem;
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .kv-area .btn02 {
    height: 12.26667vw;
    font-size: 4.26667vw;
  }
}
@media screen and (max-width: 950px) {
  .kv-area .block01:nth-child(2) {
    margin: 0 0 0 1.33333vw;
  }
  .kv-area .btn-type01 {
    width: 350px;
  }
}
/*-----------------------
intro-area
------------------------*/
.cpnloadEnd .intro-area .end01 {
  display: flex;
}
.intro-area {
  padding: 56px 18px 40px 18px;
}
.intro-area .end01 {
  position: absolute;
  top: 0;
  left: 0;
  display: none;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  border-radius: 20px;
  background-color: rgba(0, 0, 0, 0.5);
  color: #ffffff;
  font-weight: bold;
  font-size: 2.7rem;
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .intro-area .end01 {
    font-size: 6.13333vw;
  }
}
.intro-area .frame01 {
  position: relative;
  border-radius: 20px;
  box-shadow: 0 0 20px 0 #00000014;
  text-align: center;
}
.intro-area .frame01 + .frame01 {
  margin: 56px 0 0 0;
}
.intro-area .head01 {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 0 6px 0;
  height: 68px;
  border-radius: 20px 20px 0 0;
  background-color: #004831;
  color: #ffffff;
  letter-spacing: .1em;
  font-weight: 900;
  font-size: 2.6rem;
  font-family: "noto-sans-black";
  line-height: 1;
}
.intro-area .head01:before {
  position: absolute;
  z-index: 1;
  display: block;
  content: "";
}
.intro-area .head01:after {
  position: absolute;
  bottom: -13px;
  left: calc(50% - 18px);
  display: block;
  width: 38px;
  height: 20px;
  background: url("/kojin/campaign/nippons2025/imgs/index_ico_01.svg") 0 0 no-repeat;
  content: "";
}
.intro-area .head01.-icon01:before {
  top: -21px;
  left: -11px;
  width: 58px;
  height: 58px;
  background: url("/kojin/campaign/nippons2025/imgs/index_ico_02.png") 0 0 no-repeat;
  background-size: 100% auto;
}
.intro-area .head01.-icon02:before {
  top: -19px;
  left: -11px;
  width: 60px;
  height: 50px;
  background: url("/kojin/campaign/nippons2025/imgs/index_ico_03.png") 0 0 no-repeat;
  background-size: 100% auto;
}
.intro-area .body01 {
  overflow: hidden;
  border: 6px solid #ffffff;
  border-top: 0;
  border-radius: 0 0 20px 20px;
  background-color: #ffffff;
  color: #004831;
  letter-spacing: .00em;
  font-weight: bold;
}
.intro-area .wrap01 {
  padding: 20px 0 24px 0;
}
.intro-area .wrap02 {
  padding: 20px 0 8px 0;
}
.intro-area .wrap03 {
  padding: 10px 0 14px 0;
  background-color: #c6de78;
}
.intro-area .ttl01 {
  font-weight: bold;
  font-size: 2.0rem;
}
.intro-area .txt01 {
  display: inline-block;
  margin: 0 0 -2px 0;
  padding: 1px 10px 2px 10px;
  border-radius: 4px;
  background: #e5edea;
  color: #ff5f04;
  font-size: 2.0rem;
}
.intro-area .txt02 {
  margin: 0 -4px 0 2px;
  color: #ff5f04;
  letter-spacing: .00em;
  font-size: 4.0rem;
  font-family: "roboto";
}
.intro-area .txt03 {
  color: #ff5f04;
  font-size: 2.8rem;
}
.intro-area .txt04 {
  display: inline-block;
  font-size: 2.0rem;
  transform: translate(-2px, 0);
}
.intro-area .txt05 {
  display: inline-block;
  margin: -8px -2px 0 0;
  color: #ff5f04;
  font-size: 2.4rem;
}
.intro-area .txt06 {
  display: inline-block;
  margin: -8px 0 0 0;
  font-size: 2.0rem;
}
.intro-area .txt11 {
  display: inline-block;
  margin: 0 0 -4px 0;
  color: #ff5f04;
  font-size: 2.8rem;
}
.intro-area .txt12 {
  display: inline-block;
  margin: 0 -4px 0 0;
  color: #ff5f04;
  font-size: 1.6rem;
}
.intro-area .txt13 {
  font-size: 2.0rem;
}
.intro-area .txt14 {
  display: inline-block;
  margin: 0 -4px 0 0;
  font-size: 2.4rem;
}
.intro-area .txt15 {
  font-size: 2.0rem;
}
.intro-area .txt16 {
  font-size: 2.0rem;
}
.intro-area .txt21 {
  display: inline-block;
  margin: -1px 0 0 0;
  text-align: left;
  letter-spacing: .0em;
  font-size: 2.2rem;
}
/* SP STYLES */
@media screen and (max-width: 767.98px) {
  .intro-area .txt21 {
    padding: 0 16px;
  }
}
/* SMALL STYLES */
@media screen and (max-width: 374px) {
  .intro-area .txt21 {
    font-size: 5.86667vw;
  }
}
/*-----------------------
detail-area
------------------------*/
.detail-area {
  position: relative;
  margin: 73px 0 0 0;
  padding: 26px 18px 40px 18px;
  border-radius: 40px;
  background-color: #e2efbc;
}
.detail-area:before {
  position: absolute;
  top: -54px;
  left: calc(50% - 51px);
  display: block;
  width: 102px;
  height: 58px;
  background: url("/kojin/campaign/nippons2025/imgs/index_ico_04.svg") 0 0 no-repeat;
  background-size: 100% auto;
  content: "";
}
.detail-area .ttl01 {
  padding: 0 0 30px 0;
  color: #004831;
  text-align: center;
  font-weight: 900;
  font-size: 2.6rem;
  font-family: "noto-sans-black";
  line-height: 1;
}
.detail-area .ttl02 {
  padding: 10px 5px;
  background-color: #a0c81e;
  color: #003927;
  text-align: center;
  font-weight: bold;
  font-size: 1.4rem;
}
.detail-area .wrap01 {
  overflow: hidden;
  border-radius: 20px;
  background-color: #ffffff;
}
.detail-area .block01 {
  padding: 16px 16px 15px 16px;
  letter-spacing: -.01em;
  font-size: 1.4rem;
}
.detail-area .card-normal01 {
  margin-top: 46px;
  border: 0;
  border-radius: 8px;
}
.detail-area .card-normal01 > .inner > .header {
  padding: 20px 18px;
  text-align: left;
}
.detail-area .card-normal01 > .inner > .header:after {
  top: calc(50% - 12px) !important;
  right: 13px !important;
  width: 27px !important;
  height: 27px !important;
  background-size: 27px auto !important;
}
.detail-area .card-normal01 > .inner > .header > .title {
  font-size: 1.6rem;
}
.detail-area .card-normal01 > .inner > .header > .title > .inner {
  padding-left: 34px !important;
}
.detail-area .card-normal01 > .inner > .header > .title > .inner::before {
  top: -3px !important;
}
.detail-area .card-normal01 > .inner > .body {
  padding: 25px 17px;
}
.detail-area .card-normal01 > .inner > .body:not(:first-child):before {
  left: 0;
  width: 100%;
  background: #d5dedb;
}
.detail-area .glyph-attention01 > .inner:before {
  background-size: 30px auto;
}
.detail-area [class*=card-normal] > .inner > .header > .title[class*=glyph-] > .inner::before {
  top: 0;
  width: 30px;
  height: 30px;
}
.detail-area .toggle-block01 > [role=tablist] > [role=tab]:after {
  background-size: 30px auto;
}
.detail-area .list-circle01 {
  margin-left: 8px;
}
.detail-area .list-circle01 > .item:before {
  top: .6em;
  left: 0;
  width: 5px;
  height: 5px;
  background-color: #56635f;
}
/*-----------------------
olive-area
------------------------*/
.olive-area {
  padding: 56px 18px 100px 18px;
}
.olive-area .frame01 {
  overflow: hidden;
  border-radius: 20px;
  background-color: #ffffff;
  box-shadow: 0 0 20px 0 #00000014;
  text-align: center;
}
.olive-area .head01 {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  background-color: #c6de78;
  color: #004831;
  font-weight: bold;
  font-size: 2.0rem;
}
.olive-area .body01 {
  position: relative;
  padding: 42px 20px 30px 20px;
}
.olive-area .body01:before {
  position: absolute;
  top: -8px;
  left: 0;
  z-index: 0;
  display: block;
  width: 100%;
  height: 30px;
  background: url("/kojin/campaign/nippons2025/imgs/index_bg_03.svg") 0 bottom no-repeat;
  background-size: 100% auto;
  content: "";
}
.olive-area .ttl01 {
  display: inline-block;
  transform: translate(0, 10px);
}
.olive-area .img01 {
  padding: 0 0 24px 0;
}
.olive-area .btn-type02 {
  padding: 2px 15px;
  width: 100%;
  border-color: #b3c8c1;
  border-radius: 50px;
}
/* ----------------------------------
inq-area
---------------------------------- */
.inq-area01 {
  width: 100%;
  z-index: 1;
  position: relative;
}
.inq-area01 .wrap01 {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
  width: 100%;
  height: 93px;
  background: rgba(255, 255, 255, 0.8);
}
/* PC Only */
@media screen and (min-width: 768px) {
  .inq-area01 .btn-type01 {
    width: 406px;
    height: 66px;
  }
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .inq-area01 .wrap01 {
    padding: 0 20px;
  }
  .inq-area01 .btn-type01 {
    width: 424px;
    max-width: 100%;
  }
}
/* SMALL STYLES */
@media screen and (max-width: 374px) {
  .inq-area01 .wrap01 {
    padding: 0 4.26667vw;
  }
  .inq-area01 .btn-type01 > .inner {
    font-size: 4.27vw;
  }
}

/* ----------------------------------
fixed-area
---------------------------------- */
.fixed-area01 {
  position: fixed;
  bottom: 0;
  right: 0;
  z-index: 2;
  width: 100%;
  display: none;
}
.fixed-area01 .wrap01 {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
  width: 100%;
  height: 93px;
  background: rgba(255, 255, 255, 0.8);
}
/* PC Only */
@media screen and (min-width: 768px) {
  .fixed-area01 .btn-type01 {
    width: 406px;
    height: 66px;
  }
}
/* SP STYLES */
@media screen and (max-width: 767px) {
  .fixed-area01 .wrap01 {
    padding: 0 20px;
  }
  .fixed-area01 .btn-type01 {
    width: 424px;
    max-width: 100%;
  }
}
/* SMALL STYLES */
@media screen and (max-width: 374px) {
  .fixed-area01 .wrap01 {
    padding: 0 4.26667vw;
  }
  .fixed-area01 .btn-type01 > .inner {
    font-size: 4.27vw;
  }
}