@charset "UTF-8";

:root {
  --color-01: #0d78aa;
  --color-02: #64afdb;
  --color-03: #8dc045;
}

/* font */
.sans {
  font-family: "Noto Sans", sans-serif;
}

.serif {
  font-family: "Noto Serif", serif;
}

/* ------------------------------ slick */
.slide-arrow {
  z-index: 90;
  position: absolute;
  cursor: pointer;
  transition: 0.3s;
  width: 8.26vw;
  top: calc(50% - 4.13vw);
}

.slide-arrow:hover {
  opacity: 0.7;
}

.prev-arrow {
  left: 2vw;
}

.next-arrow {
  right: 2vw;
}

/*
 00. multi-class
========================================================================== */
.fNavi-wrap {
  z-index: 99
}

.idx,
.idx * {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.idx {
  position: relative;
}

.idx img {
  max-width: 100%;
}

.idx_inr {
  position: relative;
  display: block;
}

.idx_box {
  position: relative;
  display: block;
}

.idx_lm {
  position: absolute;
  width: 100%;
  left: 0;
  text-align: center;
}

.idx_lm span {
  display: inline-block;
  width: 16.93vw;
}

.idx_lm img {
  aspect-ratio: 127 / 88;
}

.idx_lst li {
  position: relative;
  display: block;
  padding-left: 1.2em;
  margin-bottom: 0.5em;
  background-repeat: no-repeat;
  background-position: 0 0.4em;
  background-size: 0.8em auto;
}

.idx_lst.idx_lst_dot li::before {
  content: "";
  display: block;
  position: absolute;
  width: 0.2em;
  aspect-ratio: 1 / 1;
  left: 0;
  top: 0.7em;
  background-color: #2e2e2e;
  border-radius: 50%;
}

.brckts {
  display: inline-block;
  margin: 0 -0.4em;
}

.kerning {
  font-feature-settings: 'palt';
}

/*
  header
========================================================================== */
.header {
  width: 100%;
  box-sizing: border-box;
}

.header * {
  box-sizing: border-box;
}

.header a,
.header img {
  display: block;
}

.site_ttl {
  position: sticky;
  top: 0;
  z-index: 9999;
  font-size: 1.94vw;
  line-height: 1;
  width: 100%;
  height: 5.33vw;
  display: grid;
  align-items: center;
  color: #fff;
  padding: 0 4vw;
  background-color: #007ac7;
  box-sizing: border-box;
}

.header {
  position: sticky;
  top: 5.33vw;
  z-index: 9999;
  width: 100%;
  display: grid;
  grid-template-columns: 1fr;
  align-content: center;
}

.header h1 {
  position: relative;
  z-index: 99999;
  font-size: 1.94vw;
  line-height: 1;
  color: #444444;
  height: 5.33vw;
  display: grid;
  align-items: center;
  color: #fff;
  padding: 0 4vw;
  background-color: #007ac7;
}

.header .logo {
  display: grid;
  align-items: center;
  height: 16.4vw;
  background-color: #fff;
}

.header .logo a {
  display: block;
  width: 45.73vw;
  margin-left: 4.4vw;
}

.header .logo img {
  aspect-ratio: 343 / 60;
}

.header .h_menu {
  position: absolute;
  width: 16.4vw;
  right: 0;
  top: 0;
}

/* -------------------------  gn */
.gn_set {
  display: none;
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 10000;
  box-sizing: border-box;
  border-top: 1px solid #318cb7;
}

.gn_set * {
  box-sizing: border-box;
}

.gn_set .gn {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  min-height: 100vh;
  z-index: 2;
  transition: 0.2s;
  background: rgba(0, 181, 255, 0.9);
  padding: 18.6666666667vw 5.3333333333vw 10.6666666667vw;
  box-sizing: border-box;
}

.gn_set .gn_close {
  width: 16.4vw;
  position: absolute;
  top: 5.33vw;
  right: 0;
}

.gn_set .gn_lst {
  overflow-y: scroll;
  height: calc(100vh - 18vw - 6vh);
  padding-bottom: 20vw;
}

.gn_set .gn_ttl {
  font-weight: 300;
  font-size: 4.44vw;
  color: #fff;
  line-height: 1;
  padding: 1.2vw 4.4vw 1.733vw;
  margin: 0 0 4vw;
  letter-spacing: 0.08em;
  background-color: #009bdb;
}

.gn_set ul + .gn_ttl {
  margin-top: 6vw;
}

.gn_set ul {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4.4vw 0;
  margin: 0 0 0 4.4vw;
}

.gn_set ul li {
  width: 100%;
}

.gn_set a {
  color: #fff;
  font-size: 4.17vw;
  line-height: 1;
  font-weight: 300;
}

/*

========================================================================== */
/*

========================================================================== */
/*

========================================================================== */
/*
  footer
========================================================================== */
footer,
footer * {
  box-sizing: border-box;
}

footer {
  background: #daedf5;
  padding: 12.8vw 5.33333% 6% 5.33333%;
}

footer .f_logo {
  width: 43.33333vw;
  margin: 0 auto 12.13333vw;
}

footer .f_btn {
  display: flex;
  justify-content: center;
  margin-bottom: 10%;
}

footer .f_btn li {
  width: 47.76%;
}

footer .f_btn li + li {
  margin-left: 4.8%;
}

footer .f_link {
  margin-bottom: 10%;
}

footer .f_link ul {
  display: flex;
  justify-content: center;
  align-items: center;
}

footer .f_link ul + ul {
  margin-top: 1em;
}

footer .f_link ul:before,
footer .f_link ul:after {
  content: "";
  display: inline-block;
  width: 1px;
  height: 7px;
  background: #656565;
}

footer .f_link ul li {
  font-size: 2.66667vw;
  line-height: 1em;
  padding: 0 0 0 1em;
  display: flex;
  align-items: center;
}

footer .f_link ul li:last-child {
  padding: 0 1em 0 1em;
}

footer .f_link ul li + li:before {
  content: "";
  display: block;
  width: 1px;
  height: 7px;
  background: #656565;
  margin-right: 1em;
}

footer .f_copy {
  text-align: center;
  font-size: 11.5px;
  line-height: 1em;
  font-family: "Montserrat";
  margin-bottom: 1em;
}

/* -------------------------  fNavi */
.fNavi-wrap {
  z-index: 9010;
  position: fixed;
  bottom: 0;
  width: 100%;
  background-color: #0d78aa;
}

.fNavi {
  display: grid;
  grid-template-columns: 1fr 1fr;
  width: 100%;
}

.fNavi li {
  height: 17.6vw;
}

.fNavi li * {
  font-weight: 500;
}

.fNavi a {
  display: grid;
  position: relative;
  align-items: center;
  height: 100%;
  font-size: 3.85vw;
  color: #fff;
  text-decoration: none;
  background-repeat: no-repeat;
  letter-spacing: 0.08em;
}

.fNavi a::before {
  content: "";
  display: block;
  position: absolute;
  height: 2.8vw;
  aspect-ratio: 14 / 21;
  right: 2vw;
  top: calc((100% - 2.8vw) / 2);
  background-color: #fff;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}

.fNavi a span {
  display: block;
  padding-right: 7.5vw;
  text-align: center;
  line-height: 1.2;
}

.fNavi a i {
  font-size: 4.5vw;
  line-height: 1;
  font-family: "Jost", sans-serif;
}

.fNavi li:nth-of-type(1) a {
  background-color: #06c755;
  padding-left: 15.2vw;
  background-size: calc((64 / 750) * 100vw);
  background-position: 3.6vw 50%;
  background-image: url("../../images/common/sp_ico_line.png");
}

.fNavi li:nth-of-type(2) a {
  background-color: #f38e7d;
  padding-left: 14vw;
  background-size: calc((51 / 750) * 100vw);
  background-position: 4vw 50%;
  background-image: url("../../images/common/sp_ico_web.png");
}

.fNavi li:nth-of-type(3) span {
  display: block;
}

/*
  mainPhoto
========================================================================== */
/*
  breadcrumb
========================================================================== */
.breadcrumb {
  padding: 0 2.5% 7.5%;
}

.breadcrumb {
  list-style: none;
  font-size: 0;
}

.breadcrumb li {
  display: inline;
  font-size: 10px;
}

.breadcrumb li:not(:last-child):after {
  content: ">";
  padding-left: 0.8em;
  padding-right: 0.6em;
}

.breadcrumb li a {
  text-decoration: underline;
}

/*
  search
========================================================================== */
.idx_search {
  margin: 0 4vw 9.2vw;
  padding: 5.6vw 0 0;
  aspect-ratio: 690 / 585;
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: 100% 100%;
  background-image: url("../../images/sp/search_bg.png");
  color: #fff;
  position: relative;
}

.idx_search .ttl {
  margin: 0 0 3.6vw;
  padding: 0 0 0 16.6vw;
  background-repeat: no-repeat;
  background-position: 4.4vw 50%;
  background-size: 11.46vw auto;
  background-image: url("../../images/sp/search_lens.png");
}

.idx_search .ttl * {
  font-weight: 500;
}

.idx_search .ttl span {
  font-size: 5.66vw;
  line-height: 1.3;
}

.idx_search .ttl span i {
  font-size: 4.07vw;
}

.idx_search .logo {
  margin: 0 2.4vw 4.4vw;
  padding: 0 0 2.4vw 2.8vw;
  border-bottom: 1px solid #fff;
}

.idx_search .logo span {
  display: inline-block;
  width: 45.86vw;
}

.idx_search .logo img {
  aspect-ratio: 344 / 63;
}

.idx_search .idx_lst {
  margin: 0 0 2.8vw 3.6vw;
}

.idx_search .idx_lst li {
  padding-left: 6vw;
  background-position: 0 1vw;
  background-size: 5.73vw auto;
  background-image: url("../../images/sp/search_check.png");
  background-repeat: no-repeat;
  line-height: 1.3;
}

.idx_search .idx_lst li i,
.idx_search .idx_lst li span {
  font-weight: 500;
}

.idx_search .idx_lst li em {
  color: #fff88f;
  font-family: "Jost", sans-serif;
}

.idx_search .idx_lst li:nth-of-type(1) {
  background-position: 0 2.4vw;
}

.idx_search .idx_lst li:nth-of-type(1) span {
  font-size: 4.27vw;
  letter-spacing: 0.08em;
}

.idx_search .idx_lst li:nth-of-type(1) span i {
  font-size: 5.07vw;
}

.idx_search .idx_lst li:nth-of-type(1) span i:last-of-type {
  font-size: 6.9vw;
  line-height: 1;
}

.idx_search .idx_lst li:nth-of-type(1) em {
  font-size: 12.35vw;
  line-height: 0.4;
  color: #fff88f;
}

.idx_search .idx_lst li:nth-of-type(1) em i {
  font-size: 4.8vw;
}

.idx_search .idx_lst li:nth-of-type(1) span.note {
  font-size: 2.77vw;
  text-align: right;
  display: block;
  margin-right: 4.2vw;
}

.idx_search .idx_lst li:nth-of-type(2) {
  font-size: 4.8vw;
  background-position: 0 0.5em;
}

.idx_search .idx_lst li:nth-of-type(2) em {
  font-size: 8vw;
  line-height: 1;
}

.idx_search .srch {
  font-size: 4.97vw;
  margin: 0 8vw;
}

.idx_search .srch form {
  display: block;
  overflow: hidden;
  position: relative;
}

.idx_search .srch form::before {
  position: absolute;
  top: 50%;
  right: 1.6em;
  transform: translateY(-50%);
  content: "";
  width: 1em;
  aspect-ratio: 3 / 2;
  background-color: #fff;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  font-size: 70%;
  pointer-events: none;
}

.idx_search .srch form select {
  height: 100%;
  width: 100%;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: none;
  border-radius: 3em !important;
  background: linear-gradient(to right, #fff 0, #fff calc(100% - 2.8em), #525252 calc(100% - 2.8em), #525252 100%);
  border: none;
  padding: 0.4em 2em 0.5em;
  line-height: 1;
  color: #000;
  cursor: pointer;
  font-weight: 300;
}

.idx_search .srch form option {
  background-color: #fff;
}

.idx_search .fig {
  position: absolute;
  width: 26vw;
  top: -4.4vw;
  right: 3.2vw;
}

.idx_search .fig {
  aspect-ratio: 195 / 281;
}

/*
  campaign
========================================================================== */
.low_campaign {
  width: 90%;
  margin: 0 auto 8vw;
}

.idx_campaign {
  margin: 0 2.8vw 5.2vw;
}

.idx_campaign .idx_inr {
  padding: 5.6vw 34.6vw 2.8vw 2.8vw;
  color: #fff;
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: 100% auto;
  background-image: url("../../images/sp/campaign_bg.jpg");
}

.idx_campaign .idx_ttl {
  margin: 1vw 0 3.5vw;
}

.idx_campaign .idx_ttl span:nth-of-type(1) {
  position: absolute;
  display: grid;
  align-items: center;
  text-align: center;
  width: 13.73vw;
  left: 1.5vw;
  top: .75vw;
  aspect-ratio: 1 / 1;
  background-color: #2ec0ad;
  color: #fff;
  border-radius: 50%;
  transform: rotate(-18deg);
}

.idx_campaign .idx_ttl span:nth-of-type(1) i {
  font-size: 3.56vw;
  font-weight: 700;
}

.idx_campaign .idx_ttl span:nth-of-type(2) {
  display: flex;
  align-items: baseline;
  justify-content: flex-end;
  font-size: 4.49vw;
  color: #333333;
  line-height: 1;
  text-align: right;
  padding-right: 6.7vw;
}

.idx_campaign .idx_ttl span:nth-of-type(2) em {
  font-size: 7.6vw;
  font-family: "Jost", sans-serif;
  line-height: 0.7;
}

.idx_campaign .catch {
  font-size: 4vw;
  text-align: center;
  margin: 0 0 1vw;
  border-bottom: 0.5vw solid #fff88f;
  white-space: nowrap;
}

.idx_campaign .small {
  margin-bottom: 1vw;
  text-align: center;
  font-size: 2.27vw;
  line-height: 1.2;
}

.idx_campaign .lead {
  margin: 0 0 1.2vw 7vw;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: end;
}

.idx_campaign .lead > i {
  font-size: 5vw;
}

.idx_campaign .lead span:nth-of-type(1) {
  font-size: 4.1vw;
  line-height: 1.3;
  padding: 0 0 .25vw 1vw;
  white-space: nowrap;
}

.idx_campaign .lead span:nth-of-type(2) {
  font-size: 6vw;
  line-height: 1;
  position: relative;
}

.idx_campaign .lead span:nth-of-type(2) em {
  font-size: 8vw;
  font-family: "Jost", sans-serif;
  letter-spacing: -0.04em;
  margin-right: 0.1em;
  margin-left: -0.1em;
}

.idx_campaign .lead span:nth-of-type(2) i {
  position: absolute;
  font-size: 2.65vw;
  right: 1vw;
  bottom: 1vw;
}

.idx_campaign .kkm {
  background-color: #2ec0ad;
  color: #fff;
  padding: 0.2em 0;
}

.idx_campaign .kkm span {
  display: block;
  text-align: center;
}

.idx_campaign .kkm span:nth-of-type(1) {
  font-size: 2.68vw;
  line-height: 1.3;
}

.idx_campaign .kkm span:nth-of-type(2) {
  font-size: 2.39vw;
  font-weight: 300;
}

.idx_campaign .note {
  font-size: 2.4vw;
  color: #333333;
  margin: 1vw 1vw 0;
}

.idx_campaign .note span {
  display: block;
}

/*
	risk
========================================================================== */
.idx_risk {
  margin: 16vw 0 8vw;
  padding: 4.8vw 2.4vw 4vw;
  color: #2e2e2e;
  background-color: #f6fcff;
}

.idx_risk .idx_lm {
  top: -10.8vw;
}

.idx_risk .idx_lm span {
  width: 9.2vw;
}

.idx_risk .idx_inr {
  background-color: #fff;
  padding: 3.4vw 6vw 3.6vw;
}

.idx_risk .idx_ttl {
  font-size: 3.6vw;
  color: #13baff;
  padding: 0 0 1.8vw;
  margin: 0 0 3.6vw;
  border-bottom: 0.06em dashed #666;
  text-align: center;
  line-height: 1.4;
}

.idx_risk .box + .box {
  margin-top: 6vw;
}

.idx_risk .box .ttl {
  font-size: 3.33vw;
  position: relative;
  margin: 0 0 0.6vw;
}

.idx_risk .box .ttl::before {
  content: "■";
  color: #13baff;
  display: inline-block;
  margin-right: 0.3em;
}

.idx_risk .box p,
.idx_risk .box p *,
.idx_risk .box ul,
.idx_risk .box ul * {
  font-size: 3.056vw;
  font-weight: 300;
}

.idx_risk .box p i {
  display: inline-block;
  margin-left: -0.5em;
}

.idx_risk .box p + ul {
  margin-left: 0.8em;
}

.idx_risk .box li {
  padding-left: 0.6em;
  margin-bottom: 0;
}
