@charset "UTF-8";

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  border: 0;
  font-size: 100%;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}
blockquote,
q {
  quotes: none;
}
blockquote::before,
blockquote::after,
q::before,
q::after {
  content: "";
}
input,
textarea {
  margin: 0;
  padding: 0;
}
ol,
ul {
  list-style: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
h1,
h2,
h3,
h4 {
  font-weight: 700;
}
i,
em {
  font-style: normal;
}
html {
  font-size: 62.5%;
}
body {
  background: #FFF;
  color: #333333;
  font-family: "Noto Sans", "Noto Sans CJK JP", "Noto Sans CJK JP Subset", sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1;
  -webkit-text-size-adjust: none;
}
*:focus {
  outline: none;
}
* {
  box-sizing: border-box;
}
img {
  border: 0;
  height: auto;
  max-width: 100%;
  vertical-align: bottom;
}
a {
  color: #000;
  text-decoration: none;
  transition: all 0.3s ease-in-out;
}
a:visited {
  color: #000;
}
a:active,
a:focus {
  outline: none;
}
.wrapper {
  background: #fff;
  overflow: hidden;
  position: relative;
}

.sec_title span {
  display: block;
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 1.6;
}
.sec_title em {
  color: #67be8d;
}
.bg_blue {
  background: #f5f9f7;
}
.sec.arr_top_blue {
  position: relative;
}
.sec.arr_top_blue::before {
  border-color: #eff6ff transparent transparent;
  border-style: solid;
  border-width: 50px 75px 0;
  content: "";
  height: 0;
  left: calc(50% - 75px);
  position: absolute;
  top: 0;
  width: 0;
}
.sec .txt_wrap p {
  hanging-punctuation: allow-end;
  letter-spacing: 0.035em;
  line-break: strict;
  overflow-wrap: break-word;
  word-wrap: break-word;
}
.sec .txt_wrap p b {
  font-weight: 700;
}
.sec .txt_wrap p + p {
  margin-top: 35px;
}
.txt_blue {
  color: #376fe1;
}
.txt_blue_d {
  color: #29479c;
}
.txt_red {
  color: #f00;
}
mark,
.txt_marker {
  background: linear-gradient(transparent 80%, #f5ff9e 20%);
  padding: 0 5px;
}
.txt_size_b_01 {
  font-size: 115%;
}
.txt_size_b_02 {
  font-size: 140%;
}
.txt_size_b_03 {
  font-size: 180%;
}
.taC {
  text-align: center;
}
.taR {
  text-align: right;
}
.anim_scale {
  -webkit-animation-direction: alternate;
  animation-direction: alternate;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  -webkit-animation-name: anim_scale;
  animation-name: anim_scale;
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-transform: scale(0.9, 0.9);
  transform: scale(0.9, 0.9);
}
.footer {
  align-items: center;
  background: #67be8d;
  color: #fff;
  display: flex;
  flex-direction: column;
  height: 110px;
  justify-content: center;
  padding: 0 46px;
}
.footer_nav {
  align-items: center;
  display: flex;
  justify-content: center;
  margin-bottom: 20px;
}
.footer_nav li {
  color: #fff;
  font-size: 100%;
  letter-spacing: 0.035em;
}
.footer_nav li a {
  color: #fff;
  margin: 0 15px;
}
.footer_nav li + li::before {
  content: "|";
}
.footer_copy {
  font-size: 1.1rem;
}
.cta_wrap {
  text-align: center;
}
.cta_title {
  align-items: center;
  display: inline-flex;
  margin-bottom: 10px;
  position: relative;
  text-align: center;
}
.cta_title::after,
.cta_title::before {
  background: url(../img/txt_deco_01.svg) center center/cover no-repeat;
  content: "";
  height: 37px;
  width: 15px;
}
.cta_title::after {
  margin-left: 9px;
  -webkit-transform: scale(-1, 1);
  transform: scale(-1, 1);
}
.cta_title::before {
  margin-right: 9px;
}
.cta_title span {
  font-size: 2.0rem;
  font-weight: 700;
  line-height: 1;
}
.cta_title em {
	color: #67be8d;
	font-size: 2.6rem;
}
.cta_attention {
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.6;
  margin-top: 10px;
  text-align: center;
}



/* ------------------------------------
media query
------------------------------------ */
@media (hover: none) {
  a {
    -webkit-tap-highlight-color: rgb(0 0 0 / 0);
  }
  a:active {
    color: #000;
    opacity: 0.65;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  a:hover {
    color: #000;
    opacity: 0.65;
  }
}
@media only screen {
  [data-scroll] {
    opacity: 0;
    transition: all 0.6s ease-in-out 0s;
  }
  [data-scroll].show {
    opacity: 1;
  }
  [data-scroll].up_in {
    opacity: 0;
    -webkit-transform: translateY(50px);
    transform: translateY(50px);
    transition: all 0.6s ease-in-out 0s;
  }
  [data-scroll].up_in.show {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
  [data-scroll].left_in {
    opacity: 0;
    -webkit-transform: translateX(-50px);
    transform: translateX(-50px);
    transition: all 0.6s ease-in-out 0s;
  }
  [data-scroll].left_in.show {
    opacity: 1;
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
  [data-scroll].right_in {
    opacity: 0;
    -webkit-transform: translateX(50px);
    transform: translateX(50px);
    transition: all 0.6s ease-in-out 0s;
  }
  [data-scroll].right_in.show {
    opacity: 1;
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}
@media not screen, screen and (min-width: 601px) {
  .vsp600 {
    display: none;
  }
}
@media screen and (min-width: 601px), print {
  a.sp_link {
    pointer-events: none;
  }
  .sec_title {
    letter-spacing: 0.04em;
    margin-bottom: 40px;
    text-align: center;
  }
  .sec .txt_wrap p {
   /* font-size: 16px;*/
    line-height: 1.9;
  }
}

@media screen and (max-width: 600px) {
  body {
   /* font-size: 3.8667vw;*/
	  font-size: 3.8667vw;
  }
  .sec_title {
    margin-bottom: 3.3333vw;
    margin-right: -3%;
  }
  .sec_title span {
    font-size: 6.6vw;
    line-height: 1.18;
  }
  .sec_title small {
    /*font-size: 57.14%;*/
    margin-bottom: 2.6667vw;
  }
  .sec_title_sb {
   /* font-size: 5.0667vw;*/
    line-height: 1.47;
    margin-bottom: 4vw;
  }
  .sec.arr_top_blue::before {
    border-width: 6.6667vw 10vw 0;
    left: calc(50% - 10vw);
  }
  .sec .txt_wrap p {
   /* font-size: 3.5vw;*/
    line-height: 1.6;
  }
  .sec .txt_wrap p + p {
    margin-top: 4.6667vw;
  }
  .vpc600 {
    display: none;
  }
  .txt_marker {
    background: linear-gradient(transparent 55%, #ff0 55%);
    padding: 0;
  }
  .txt_size_b_02 {
   /* font-size: 130%;*/
  }
  .txt_size_b_03 {
   /* font-size: 150%;*/
  }
  .sp_center {
    text-align: center;
  }
  .footer {
    height: 24vw;
    padding: 0 6vw;
  }
  .footer_nav {
    margin-bottom: 4vw;
	font-size: 3vw;
  }
  .cta_wrap {
  }
  .cta_title {
    /*font-size: 3.8667vw;*/
  }
  .cta_title::after,
  .cta_title::before {
    height: 6.6667vw;
    width: 4.9333vw;
  }
  .cta_title::after {
    margin: 0 -1.0667vw 0 1.0667vw;
  }
  .cta_title::before {
    margin: 0 1.0667vw 0 -1.0667vw;
  }
  .cta_title {
    margin-bottom: 2vw;
  }
  .cta_title span {
    font-size: 3.8667vw;
    letter-spacing: -0.02em;
  }
.cta_title em {
	color: #67be8d;
	font-size: 120%;
}
}
@media only screen and (max-width: 600px) {
  [data-scroll].up_in {
    -webkit-transform: translateY(20px);
    transform: translateY(20px);
  }
  [data-scroll].left_in {
    -webkit-transform: translateX(-20px);
    transform: translateX(-20px);
  }
  [data-scroll].right_in {
    -webkit-transform: translateX(20px);
    transform: translateX(20px);
  }
}
@media print {
  body {
    min-width: 1040px !important;
    position: relative !important;
    -webkit-print-color-adjust: exact;
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
    width: 100%;
  }
  *,
  [data-scroll] {
    opacity: 1 !important;
  }
  .header {
    background: #000;
  }
  .sec_concept ul li figure img {
    -webkit-transform: translateY(0) !important;
    transform: translateY(0) !important;
  }
}
@-webkit-keyframes anim_scale {
  100% {
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
  }
}
@keyframes anim_scale {
  100% {
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
  }
}
