@charset "UTF-8";
/*! destyle.css v4.0.0 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model and set borders */
/* ============================================ */
*,
::before,
::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border-style: solid;
  border-width: 0;
}

/* Document */
/* ============================================ */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 * 3. Remove gray overlay on links for iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -webkit-tap-highlight-color: transparent; /* 3*/
}

/* Sections */
/* ============================================ */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

/* Vertical rhythm */
/* ============================================ */
p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

/* Headings */
/* ============================================ */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
  margin: 0;
}

/* Lists (enumeration) */
/* ============================================ */
ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Lists (definition) */
/* ============================================ */
dt {
  font-weight: bold;
}

dd {
  margin-left: 0;
}

/* Grouping content */
/* ============================================ */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  -webkit-box-sizing: content-box;
          box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}

address {
  font-style: inherit;
}

/* Text-level semantics */
/* ============================================ */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Replaced content */
/* ============================================ */
/**
 * Prevent vertical alignment issues.
 */
svg,
img,
embed,
object,
iframe {
  vertical-align: bottom;
}

/* Forms */
/* ============================================ */
/**
 * Reset form fields to make them styleable.
 * 1. Make form elements stylable across systems iOS especially.
 * 2. Inherit text-transform from parent.
 */
button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none; /* 1 */
  -moz-appearance: none;
       appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  border-radius: 0;
  text-align: inherit;
  text-transform: inherit; /* 2 */
}

/**
 * Correct cursors for clickable elements.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
}

button:disabled,
[type=button]:disabled,
[type=reset]:disabled,
[type=submit]:disabled {
  cursor: default;
}

/**
 * Improve outlines for Firefox and unify style with input elements & buttons.
 */
:-moz-focusring {
  outline: auto;
}

select:disabled {
  opacity: inherit;
}

/**
 * Remove padding
 */
option {
  padding: 0;
}

/**
 * Reset to invisible
 */
fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
}

legend {
  padding: 0;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * Correct the outline style in Safari.
 */
[type=search] {
  outline-offset: -2px; /* 1 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Fix font inheritance.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/**
 * Fix appearance for Firefox
 */
[type=number] {
  -moz-appearance: textfield;
}

/**
 * Clickable labels
 */
label[for] {
  cursor: pointer;
}

/* Interactive */
/* ============================================ */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/*
 * Remove outline for editable content.
 */
[contenteditable]:focus {
  outline: auto;
}

/* Tables */
/* ============================================ */
/**
1. Correct table border color inheritance in all Chrome and Safari.
*/
table {
  border-color: inherit; /* 1 */
  border-collapse: collapse;
}

caption {
  text-align: left;
}

td,
th {
  vertical-align: top;
  padding: 0;
}

th {
  text-align: left;
  font-weight: bold;
}

/* mixin
--------------------------- */
/*----- メディアクエリ -----*/
/*----- px変換 -----*/
/* 使い方
font-size: rem(16);
font-size: vw(16);
line-height: lh(16,28);
letter-spacing: ls(50);
*/
/* base
--------------------------- */
html {
  overflow: auto;
}
html.is-open {
  overflow: hidden;
  position: fixed;
  z-index: -1;
  width: 100%;
  height: 100dvh;
  top: 0;
  left: 0;
}

ul, ol {
  list-style: none;
}

img,
video,
object {
  max-width: 100%;
  height: auto;
}

a:hover {
  text-decoration: none;
}

/*
 *  Remodal - v1.1.1
 *  Responsive, lightweight, fast, synchronized with CSS animations, fully customizable modal window plugin with declarative configuration and hash tracking.
 *  http://vodkabears.github.io/remodal/
 *
 *  Made by Ilya Makarov
 *  Under MIT License
 */
/* ==========================================================================
   Remodal's default mobile first theme
   ========================================================================== */
/* Default theme styles for the background */
.remodal-bg.remodal-is-opening,
.remodal-bg.remodal-is-opened {
  -webkit-filter: blur(3px);
  filter: blur(3px);
}

/* Default theme styles of the overlay */
.remodal-overlay {
  background: rgba(43, 46, 56, 0.9);
}

.remodal-overlay.remodal-is-opening,
.remodal-overlay.remodal-is-closing {
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
}

.remodal-overlay.remodal-is-opening {
  -webkit-animation-name: remodal-overlay-opening-keyframes;
  animation-name: remodal-overlay-opening-keyframes;
}

.remodal-overlay.remodal-is-closing {
  -webkit-animation-name: remodal-overlay-closing-keyframes;
  animation-name: remodal-overlay-closing-keyframes;
}

/* Default theme styles of the wrapper */
.remodal-wrapper {
  padding: 10px 10px 0;
}

/* Default theme styles of the modal dialog */
.remodal {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  margin-bottom: 10px;
  padding: 35px;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  color: #2b2e38;
  background: #fff;
}

.remodal.remodal-is-opening,
.remodal.remodal-is-closing {
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
}

.remodal.remodal-is-opening {
  -webkit-animation-name: remodal-opening-keyframes;
  animation-name: remodal-opening-keyframes;
}

.remodal.remodal-is-closing {
  -webkit-animation-name: remodal-closing-keyframes;
  animation-name: remodal-closing-keyframes;
}

/* Vertical align of the modal dialog */
.remodal,
.remodal-wrapper:after {
  vertical-align: middle;
}

/* Close button */
.remodal-close {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  overflow: visible;
  width: 35px;
  height: 35px;
  margin: 0;
  padding: 0;
  cursor: pointer;
  -webkit-transition: color 0.2s;
  transition: color 0.2s;
  text-decoration: none;
  color: #95979c;
  border: 0;
  outline: 0;
  background: transparent;
}

.remodal-close:hover,
.remodal-close:focus {
  color: #2b2e38;
}

.remodal-close:before {
  font-family: Arial, "Helvetica CY", "Nimbus Sans L", sans-serif !important;
  font-size: 25px;
  line-height: 35px;
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 35px;
  content: "×";
  text-align: center;
}

/* Dialog buttons */
.remodal-confirm,
.remodal-cancel {
  font: inherit;
  display: inline-block;
  overflow: visible;
  min-width: 110px;
  margin: 0;
  padding: 12px 0;
  cursor: pointer;
  -webkit-transition: background 0.2s;
  transition: background 0.2s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  border: 0;
  outline: 0;
}

.remodal-confirm {
  color: #fff;
  background: #81c784;
}

.remodal-confirm:hover,
.remodal-confirm:focus {
  background: #66bb6a;
}

.remodal-cancel {
  color: #fff;
  background: #e57373;
}

.remodal-cancel:hover,
.remodal-cancel:focus {
  background: #ef5350;
}

/* Remove inner padding and border in Firefox 4+ for the button tag. */
.remodal-confirm::-moz-focus-inner,
.remodal-cancel::-moz-focus-inner,
.remodal-close::-moz-focus-inner {
  padding: 0;
  border: 0;
}

/* Keyframes
   ========================================================================== */
@-webkit-keyframes remodal-opening-keyframes {
  from {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
    opacity: 0;
  }
  to {
    -webkit-transform: none;
    transform: none;
    opacity: 1;
    -webkit-filter: blur(0);
    filter: blur(0);
  }
}
@keyframes remodal-opening-keyframes {
  from {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
    opacity: 0;
  }
  to {
    -webkit-transform: none;
    transform: none;
    opacity: 1;
    -webkit-filter: blur(0);
    filter: blur(0);
  }
}
@-webkit-keyframes remodal-closing-keyframes {
  from {
    -webkit-transform: scale(1);
    transform: scale(1);
    opacity: 1;
  }
  to {
    -webkit-transform: scale(0.95);
    transform: scale(0.95);
    opacity: 0;
    -webkit-filter: blur(0);
    filter: blur(0);
  }
}
@keyframes remodal-closing-keyframes {
  from {
    -webkit-transform: scale(1);
    transform: scale(1);
    opacity: 1;
  }
  to {
    -webkit-transform: scale(0.95);
    transform: scale(0.95);
    opacity: 0;
    -webkit-filter: blur(0);
    filter: blur(0);
  }
}
@-webkit-keyframes remodal-overlay-opening-keyframes {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes remodal-overlay-opening-keyframes {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-webkit-keyframes remodal-overlay-closing-keyframes {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes remodal-overlay-closing-keyframes {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
/* Media queries
   ========================================================================== */
@media only screen and (min-width: 641px) {
  .remodal {
    max-width: 700px;
  }
}
/* IE8
   ========================================================================== */
.lt-ie9 .remodal-overlay {
  background: #2b2e38;
}

.lt-ie9 .remodal {
  width: 700px;
}

/*
 *  Remodal - v1.1.1
 *  Responsive, lightweight, fast, synchronized with CSS animations, fully customizable modal window plugin with declarative configuration and hash tracking.
 *  http://vodkabears.github.io/remodal/
 *
 *  Made by Ilya Makarov
 *  Under MIT License
 */
/* ==========================================================================
   Remodal's necessary styles
   ========================================================================== */
/* Hide scroll bar */
html.remodal-is-locked {
  overflow: hidden;
  -ms-touch-action: none;
  touch-action: none;
}

/* Anti FOUC */
.remodal,
[data-remodal-id] {
  display: none;
}

/* Necessary styles of the overlay */
.remodal-overlay {
  position: fixed;
  z-index: 9999;
  top: -5000px;
  right: -5000px;
  bottom: -5000px;
  left: -5000px;
  display: none;
}

/* Necessary styles of the wrapper */
.remodal-wrapper {
  position: fixed;
  z-index: 10000;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  display: none;
  overflow: auto;
  text-align: center;
  -webkit-overflow-scrolling: touch;
}

.remodal-wrapper:after {
  display: inline-block;
  height: 100%;
  margin-left: -0.05em;
  content: "";
}

/* Fix iPad, iPhone glitches */
.remodal-overlay,
.remodal-wrapper {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

/* Necessary styles of the modal dialog */
.remodal {
  position: relative;
  outline: none;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
       text-size-adjust: 100%;
}

.remodal-is-initialized {
  /* Disable Anti-FOUC */
  display: inline-block;
}

/* Slider */
.slick-slider {
  position: relative;
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0;
}
.slick-list:focus {
  outline: none;
}
.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.slick-track:before, .slick-track:after {
  content: "";
  display: table;
}
.slick-track:after {
  clear: both;
}
.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none;
}
[dir=rtl] .slick-slide {
  float: right;
}
.slick-slide img {
  display: block;
}
.slick-slide.slick-loading img {
  display: none;
}
.slick-slide.dragging img {
  pointer-events: none;
}
.slick-initialized .slick-slide {
  display: block;
}
.slick-loading .slick-slide {
  visibility: hidden;
}
.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
  display: none;
}

/* utility
--------------------------- */
@media all and (min-width: 769px) {
  .u-view-pc {
    display: none;
  }
}

@media all and (min-width: 769px) {
  .u-view-sp {
    display: none;
  }
}

.u-inner {
  max-width: 1036px;
  padding-left: 20px;
  padding-right: 20px;
  margin: auto;
}
@media all and (min-width: 769px) {
  .u-inner {
    max-width: 100%;
    padding-left: 15px;
    padding-right: 15px;
  }
}

@media (hover: hover) {
  .u-alpha {
    -webkit-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
  }
  .u-alpha:hover {
    opacity: 0.7;
  }
}

.u-font-fahkwang {
  font-family: "Fahkwang", serif;
}

.c-btn01 {
  max-width: 81.8666666667vw;
  margin-left: auto;
  margin-right: auto;
}
@media all and (min-width: 769px) {
  .c-btn01 {
    max-width: 307px;
  }
}
.c-btn01__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  height: 13.3333333333vw;
  font-size: 4.2666666667vw;
  font-weight: bold;
  color: #5F92D9;
  border-radius: 6.6666666667vw;
  background: -webkit-radial-gradient(circle, rgb(255, 255, 255) 0%, rgb(248, 249, 250) 35%, rgb(231, 238, 248) 100%);
  background: radial-gradient(circle, rgb(255, 255, 255) 0%, rgb(248, 249, 250) 35%, rgb(231, 238, 248) 100%);
  -webkit-box-shadow: 0px 0.8vw 0px #5f92d9;
          box-shadow: 0px 0.8vw 0px #5f92d9;
  position: relative;
}
@media all and (min-width: 769px) {
  .c-btn01__link {
    height: 50px;
    font-size: 16px;
    border-radius: 25px;
    -webkit-box-shadow: 0px 3px 0px #5f92d9;
            box-shadow: 0px 3px 0px #5f92d9;
  }
}
.c-btn01__link:after {
  content: "";
  background: url(../images/ico_arrow02.png) no-repeat 0 0;
  background-size: contain;
  width: 4vw;
  height: 4vw;
  position: absolute;
  top: 50%;
  right: 4vw;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
@media all and (min-width: 769px) {
  .c-btn01__link:after {
    width: 15px;
    height: 15px;
    right: 15px;
  }
}

.c-btn_anim {
  -webkit-animation: fuwafuwa 2s linear infinite;
          animation: fuwafuwa 2s linear infinite;
}
.c-btn_anim.is-delay {
  -webkit-animation-delay: 0.6s;
          animation-delay: 0.6s;
}

@-webkit-keyframes fuwafuwa {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  50% {
    -webkit-transform: translateY(-5px);
            transform: translateY(-5px);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes fuwafuwa {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  50% {
    -webkit-transform: translateY(-5px);
            transform: translateY(-5px);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
.js-toggle-content {
  display: none;
}

.js-switch-content {
  display: none;
}
.js-switch-content.is-active {
  display: block;
}

@-webkit-keyframes zoom-fade {
  0% {
    opacity: 0;
    -webkit-transform: translate(0, -50%) scale(0.8);
            transform: translate(0, -50%) scale(0.8);
  }
  50% {
    opacity: 0.5;
  }
  100% {
    opacity: 0;
    -webkit-transform: translate(0, -50%) scale(1.6);
            transform: translate(0, -50%) scale(1.6);
  }
}

@keyframes zoom-fade {
  0% {
    opacity: 0;
    -webkit-transform: translate(0, -50%) scale(0.8);
            transform: translate(0, -50%) scale(0.8);
  }
  50% {
    opacity: 0.5;
  }
  100% {
    opacity: 0;
    -webkit-transform: translate(0, -50%) scale(1.6);
            transform: translate(0, -50%) scale(1.6);
  }
}
.anim-kv-smooth {
  -webkit-animation: smooth-kv 0.6s linear forwards;
          animation: smooth-kv 0.6s linear forwards;
  -webkit-animation-delay: 0.3s;
          animation-delay: 0.3s;
  -webkit-clip-path: inset(0 100% 0 0);
          clip-path: inset(0 100% 0 0);
}
.anim-kv-smooth.is-delay01 {
  -webkit-animation-delay: 0.6s;
          animation-delay: 0.6s;
}
.anim-kv-smooth.is-delay02 {
  -webkit-animation-delay: 0.9s;
          animation-delay: 0.9s;
}
.anim-kv-smooth.is-delay03 {
  -webkit-animation-delay: 1.2s;
          animation-delay: 1.2s;
}

.anim-kv-slideL {
  opacity: 0;
  -webkit-transform: translate(-100%, 0);
          transform: translate(-100%, 0);
  -webkit-animation: kv-slide 0.6s ease-in forwards;
          animation: kv-slide 0.6s ease-in forwards;
  -webkit-animation-delay: 0.6s;
          animation-delay: 0.6s;
}

.anim-kv-slideR {
  opacity: 0;
  -webkit-transform: translate(100%, 0);
          transform: translate(100%, 0);
  -webkit-animation: kv-slide 0.6s ease-in forwards;
          animation: kv-slide 0.6s ease-in forwards;
  -webkit-animation-delay: 1.2s;
          animation-delay: 1.2s;
}

@-webkit-keyframes smooth-kv {
  0% {
    -webkit-clip-path: inset(0 100% 0 0);
            clip-path: inset(0 100% 0 0);
  }
  100% {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
}

@keyframes smooth-kv {
  0% {
    -webkit-clip-path: inset(0 100% 0 0);
            clip-path: inset(0 100% 0 0);
  }
  100% {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
}
@-webkit-keyframes kv-slide {
  100% {
    opacity: 1;
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}
@keyframes kv-slide {
  100% {
    opacity: 1;
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}
.anim-slide-L {
  opacity: 0;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
  -webkit-transition: all 0.6s ease 0.3s;
  transition: all 0.6s ease 0.3s;
}
.anim-slide-L.is-active {
  opacity: 1;
  -webkit-transform: translateX(0);
          transform: translateX(0);
}

.anim-slide-R {
  opacity: 0;
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
  -webkit-transition: all 0.6s ease 0.3s;
  transition: all 0.6s ease 0.3s;
}
.anim-slide-R.is-active {
  opacity: 1;
  -webkit-transform: translateX(0);
          transform: translateX(0);
}

.anim-fade-sec {
  opacity: 0;
  -webkit-transform: translateY(20px);
          transform: translateY(20px);
  -webkit-transition: all 1s ease 0.6s;
  transition: all 1s ease 0.6s;
}
.anim-fade-sec.is-active {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

.anim-fluffy {
  -webkit-animation: fluffy 2s linear infinite;
          animation: fluffy 2s linear infinite;
}
.anim-fluffy.is-delay01 {
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
}
.anim-fluffy.is-delay02 {
  -webkit-animation-delay: 0.4s;
          animation-delay: 0.4s;
}
.anim-fluffy.is-delay03 {
  -webkit-animation-delay: 0.6s;
          animation-delay: 0.6s;
}
.anim-fluffy.is-delay04 {
  -webkit-animation-delay: 0.8s;
          animation-delay: 0.8s;
}
.anim-fluffy.is-delay05 {
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
}

@-webkit-keyframes fluffy {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  50% {
    -webkit-transform: translateY(-10px);
            transform: translateY(-10px);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes fluffy {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  50% {
    -webkit-transform: translateY(-10px);
            transform: translateY(-10px);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
.circleY-animated {
  -webkit-animation: animecircleY 2s infinite ease-in-out;
          animation: animecircleY 2s infinite ease-in-out;
  -webkit-animation-delay: 0s;
          animation-delay: 0s;
  -webkit-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
}

.circle-animated {
  -webkit-animation: animecircle 4s infinite ease-in-out;
          animation: animecircle 4s infinite ease-in-out;
  -webkit-animation-delay: 2s;
          animation-delay: 2s;
  -webkit-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
}

@-webkit-keyframes animecircleY {
  50% {
    -webkit-transform: translateY(5px) skew(3deg, -3deg) rotate(-5deg);
            transform: translateY(5px) skew(3deg, -3deg) rotate(-5deg);
  }
}

@keyframes animecircleY {
  50% {
    -webkit-transform: translateY(5px) skew(3deg, -3deg) rotate(-5deg);
            transform: translateY(5px) skew(3deg, -3deg) rotate(-5deg);
  }
}
@-webkit-keyframes animecircle {
  50% {
    -webkit-transform: translateX(-2px) skew(-1deg, 1deg) rotate(2deg);
            transform: translateX(-2px) skew(-1deg, 1deg) rotate(2deg);
  }
}
@keyframes animecircle {
  50% {
    -webkit-transform: translateX(-2px) skew(-1deg, 1deg) rotate(2deg);
            transform: translateX(-2px) skew(-1deg, 1deg) rotate(2deg);
  }
}
/* body
--------------------------- */
body {
  font-family: "Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  font-size: 3.7333333333vw;
  font-weight: 500;
  color: #575253;
  background-color: #FCE5EF;
}
@media all and (min-width: 769px) {
  body {
    font-size: 14px;
  }
}

/* l-wrapper
--------------------------- */
.l-wrapper {
  position: relative;
}

@media all and (min-width: 769px) {
  .cp-contents {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.cp-contents-main-left {
  display: none;
}
@media all and (min-width: 769px) {
  .cp-contents-main-left {
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    width: calc((100% - 375px) / 2);
  }
  .cp-contents-main-left img {
    width: 100%;
  }
}

.cp-contents-main-right {
  display: none;
}
@media all and (min-width: 769px) {
  .cp-contents-main-right {
    display: block;
    position: fixed;
    top: 0;
    right: 0;
    width: calc((100% - 375px) / 2);
  }
  .cp-contents-main-right img {
    width: 100%;
  }
}

.cp-contents-main {
  background-color: #FCE5EF;
  padding-bottom: 10.6666666667vw;
  margin: auto;
}
.cp-contents-main.is-content {
  position: static;
}
@media all and (min-width: 769px) {
  .cp-contents-main {
    max-width: 375px;
    -webkit-box-shadow: 0px 0px 20px #f2b7c8;
            box-shadow: 0px 0px 20px #f2b7c8;
    padding-bottom: 40px;
  }
}

.cp-fv-menu {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: calc(100vh + 30.6666666667vw + 14.9333333333vw);
  z-index: 10;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
.cp-fv-menu.is-fv-anc {
  display: none;
  visibility: hidden;
}
@media all and (min-width: 769px) {
  .cp-fv-menu {
    height: calc(100vh + 115px + 30vh);
    width: 375px;
    right: 0;
    margin: auto;
  }
}
.cp-fv-menu__list {
  padding-bottom: 14.9333333333vw;
}
@media all and (min-width: 769px) {
  .cp-fv-menu__list {
    padding-bottom: 30vh;
  }
}
.cp-fv-menu__item + .cp-fv-menu__item {
  margin-top: 1.3333333333vw;
}
@media all and (min-width: 769px) {
  .cp-fv-menu__item + .cp-fv-menu__item {
    margin-top: 5px;
  }
}
.cp-fv-menu__item__link {
  text-indent: -9999px;
  display: inline-block;
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
  height: 6.6666666667vw;
  -webkit-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
}
@media all and (min-width: 769px) {
  .cp-fv-menu__item__link {
    height: 25px;
  }
}
.cp-fv-menu__item.item01 .cp-fv-menu__item__link {
  background-image: url(../images/btn_menu01.png);
  width: 43.4666666667vw;
}
@media (hover: hover) {
  .cp-fv-menu__item.item01 .cp-fv-menu__item__link:hover {
    background-image: url(../images/btn_menu01_hov.png);
  }
}
@media all and (min-width: 769px) {
  .cp-fv-menu__item.item01 .cp-fv-menu__item__link {
    width: 163px;
  }
}
.cp-fv-menu__item.item02 .cp-fv-menu__item__link {
  background-image: url(../images/btn_menu02.png);
  width: 84vw;
}
@media (hover: hover) {
  .cp-fv-menu__item.item02 .cp-fv-menu__item__link:hover {
    background-image: url(../images/btn_menu02_hov.png);
  }
}
@media all and (min-width: 769px) {
  .cp-fv-menu__item.item02 .cp-fv-menu__item__link {
    width: 315px;
  }
}
.cp-fv-menu__item.item03 .cp-fv-menu__item__link {
  background-image: url(../images/btn_menu03.png);
  width: 36vw;
}
@media (hover: hover) {
  .cp-fv-menu__item.item03 .cp-fv-menu__item__link:hover {
    background-image: url(../images/btn_menu03_hov.png);
  }
}
@media all and (min-width: 769px) {
  .cp-fv-menu__item.item03 .cp-fv-menu__item__link {
    width: 135px;
  }
}
.cp-fv-menu__item.item04 .cp-fv-menu__item__link {
  background-image: url(../images/btn_menu04.png);
  width: 76.8vw;
}
@media (hover: hover) {
  .cp-fv-menu__item.item04 .cp-fv-menu__item__link:hover {
    background-image: url(../images/btn_menu04_hov.png);
  }
}
@media all and (min-width: 769px) {
  .cp-fv-menu__item.item04 .cp-fv-menu__item__link {
    width: 288px;
  }
}

.cp-kv {
  position: relative;
  overflow: hidden;
}
.cp-kv__img {
  text-align: center;
}
.cp-kv__img img {
  width: 100%;
}
.cp-kv__txt {
  position: absolute;
}
.cp-kv__txt img {
  width: 100%;
}
.cp-kv__txt.txt01 {
  width: 17.3333333333vw;
  top: 14.6666666667vw;
  left: 18.6666666667vw;
}
@media all and (min-width: 769px) {
  .cp-kv__txt.txt01 {
    width: 65px;
    top: 55px;
    left: 70px;
  }
}
.cp-kv__txt.txt02 {
  width: 38.1333333333vw;
  top: 24.5333333333vw;
  left: 18.9333333333vw;
}
@media all and (min-width: 769px) {
  .cp-kv__txt.txt02 {
    width: 143px;
    top: 92px;
    left: 71px;
  }
}
.cp-kv__txt.sub-txt01 {
  width: 30.9333333333vw;
  top: 41.8666666667vw;
  left: 36vw;
}
@media all and (min-width: 769px) {
  .cp-kv__txt.sub-txt01 {
    width: 116px;
    top: 157px;
    left: 135px;
  }
}
.cp-kv__txt.sub-txt02 {
  width: 25.3333333333vw;
  top: 49.3333333333vw;
  left: 46.9333333333vw;
}
@media all and (min-width: 769px) {
  .cp-kv__txt.sub-txt02 {
    width: 95px;
    top: 185px;
    left: 176px;
  }
}
.cp-kv__txt.product01 {
  width: 47.2vw;
  top: 56.2666666667vw;
  left: 6.4vw;
}
@media all and (min-width: 769px) {
  .cp-kv__txt.product01 {
    width: 177px;
    top: 211px;
    left: 24px;
  }
}
.cp-kv__txt.product02 {
  width: 51.2vw;
  top: 72vw;
  right: 6.1333333333vw;
}
@media all and (min-width: 769px) {
  .cp-kv__txt.product02 {
    width: 192px;
    top: 270px;
    right: 23px;
  }
}
.cp-kv__txt.ico-10th {
  width: 34.6666666667vw;
  top: 4.2666666667vw;
  right: 7.7333333333vw;
}
@media all and (min-width: 769px) {
  .cp-kv__txt.ico-10th {
    width: 130px;
    top: 16px;
    right: 29px;
  }
}
.cp-kv__btns {
  background-color: #fff;
  padding: 1.6vw 5.3333333333vw;
}
@media all and (min-width: 769px) {
  .cp-kv__btns {
    padding: 6px 20px;
  }
}
.cp-kv__btns__item {
  border-bottom: 0.2666666667vw solid #E5696A;
}
@media all and (min-width: 769px) {
  .cp-kv__btns__item {
    border-bottom: 1px solid #E5696A;
  }
}
.cp-kv__btns__item:last-child {
  border-bottom: none;
}
.cp-kv__btns__item.item01 img {
  width: 32vw;
}
@media all and (min-width: 769px) {
  .cp-kv__btns__item.item01 img {
    width: 120px;
  }
}
.cp-kv__btns__item.item02 img {
  width: 75.4666666667vw;
}
@media all and (min-width: 769px) {
  .cp-kv__btns__item.item02 img {
    width: 283px;
  }
}
.cp-kv__btns__item.item03 img {
  width: 27.7333333333vw;
}
@media all and (min-width: 769px) {
  .cp-kv__btns__item.item03 img {
    width: 104px;
  }
}
.cp-kv__btns__item.item04 img {
  width: 58.1333333333vw;
}
@media all and (min-width: 769px) {
  .cp-kv__btns__item.item04 img {
    width: 218px;
  }
}
.cp-kv__btns__link {
  width: 100%;
  min-height: 10.9333333333vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}
@media all and (min-width: 769px) {
  .cp-kv__btns__link {
    min-height: 41px;
  }
}
.cp-kv__btns__link:after {
  content: "";
  background: url(../images/ico_arrow01.png) no-repeat 0 0;
  background-size: contain;
  width: 4vw;
  height: 4vw;
  position: absolute;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
@media all and (min-width: 769px) {
  .cp-kv__btns__link:after {
    width: 15px;
    height: 15px;
  }
}

.cp-history {
  margin-top: 18.6666666667vw;
}
@media all and (min-width: 769px) {
  .cp-history {
    margin-top: 70px;
  }
}
.cp-history__head {
  background: url(../images/bg_history_head.png) no-repeat 0 0;
  background-size: contain;
  width: 89.3333333333vw;
  height: 78.6666666667vw;
  margin: 0 auto -13.3333333333vw;
  padding-top: 2.6666666667vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
}
@media all and (min-width: 769px) {
  .cp-history__head {
    width: 335px;
    height: 295px;
    margin: 0 auto -50px;
    padding-top: 10px;
  }
}
.cp-history__head:before, .cp-history__head:after {
  content: "";
  background: url(../images/bg_history_head_ico.png) no-repeat 0 0;
  background-size: contain;
  width: 10.9333333333vw;
  height: 9.8666666667vw;
}
@media all and (min-width: 769px) {
  .cp-history__head:before, .cp-history__head:after {
    width: 41px;
    height: 37px;
  }
}
.cp-history__head:before {
  position: absolute;
  top: 3.7333333333vw;
  left: 4.2666666667vw;
}
@media all and (min-width: 769px) {
  .cp-history__head:before {
    top: 14px;
    left: 16px;
  }
}
.cp-history__head:after {
  position: absolute;
  bottom: 16.8vw;
  right: 6.9333333333vw;
}
@media all and (min-width: 769px) {
  .cp-history__head:after {
    bottom: 63px;
    right: 26px;
  }
}
.cp-history__head__lead {
  text-align: center;
}
.cp-history__head__lead img {
  width: 53.6vw;
}
@media all and (min-width: 769px) {
  .cp-history__head__lead img {
    width: 201px;
  }
}
.cp-history__head__txt {
  margin-top: 4vw;
  text-align: center;
  font-size: 4.2666666667vw;
  font-weight: bold;
  color: #fff;
  line-height: 1.625;
  letter-spacing: 0.03em;
}
@media all and (min-width: 769px) {
  .cp-history__head__txt {
    margin-top: 15px;
    font-size: 16px;
  }
}
.cp-history__tit {
  text-align: center;
}
.cp-history__tit img {
  width: 80.5333333333vw;
}
@media all and (min-width: 769px) {
  .cp-history__tit img {
    width: 302px;
  }
}
.cp-history__flow {
  padding: 8vw 0 16vw;
  overflow: hidden;
  position: relative;
}
@media all and (min-width: 769px) {
  .cp-history__flow {
    padding: 30px 0 60px;
  }
}
.cp-history__flow__item {
  position: absolute;
}
.cp-history__flow__item img {
  width: 100%;
}
.cp-history__flow__item.item01 {
  top: 8vw;
  left: 38.9333333333vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item.item01 {
    top: 30px;
    left: 146px;
  }
}
.cp-history__flow__item.item02 {
  top: 95.2vw;
  right: 5.3333333333vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item.item02 {
    top: 357px;
    right: 20px;
  }
}
.cp-history__flow__item.item03 {
  top: 176vw;
  left: 5.3333333333vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item.item03 {
    top: 660px;
    left: 20px;
  }
}
.cp-history__flow__item.item04 {
  top: 204.2666666667vw;
  left: 21.0666666667vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item.item04 {
    top: 766px;
    left: 79px;
  }
}
.cp-history__flow__item.item05 {
  top: 276.5333333333vw;
  left: 5.3333333333vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item.item05 {
    top: 1037px;
    left: 20px;
  }
}
.cp-history__flow__item.item06 {
  bottom: 151.4666666667vw;
  right: 4.5333333333vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item.item06 {
    bottom: 568px;
    right: 17px;
  }
}
.cp-history__flow__item.item07 {
  top: 444vw;
  left: 5.3333333333vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item.item07 {
    top: 1665px;
    left: 20px;
  }
}
.cp-history__flow__item.item08 {
  bottom: 8.5333333333vw;
  left: 5.3333333333vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item.item08 {
    bottom: 32px;
    left: 20px;
  }
}
.cp-history__flow__txt {
  position: relative;
  font-size: 4.2666666667vw;
  color: #E5696A;
  font-weight: bold;
  line-height: 1.375;
  letter-spacing: 0.03em;
}
@media all and (min-width: 769px) {
  .cp-history__flow__txt {
    font-size: 16px;
  }
}
.cp-history__flow__txt + .cp-history__flow__txt {
  margin-top: 1.6vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__txt + .cp-history__flow__txt {
    margin-top: 6px;
  }
}
.cp-history__flow .txt01 {
  display: inline-block;
  background-color: #fff;
  padding: 0.5333333333vw 1.3333333333vw 0;
}
@media all and (min-width: 769px) {
  .cp-history__flow .txt01 {
    padding: 2px 5px 0;
  }
}
.cp-history__flow .is-font-m {
  font-size: 4.8vw;
  line-height: 1.2222222222;
}
@media all and (min-width: 769px) {
  .cp-history__flow .is-font-m {
    font-size: 18px;
  }
}
.cp-history__flow .is-font-l {
  font-size: 5.3333333333vw;
  line-height: 1.1;
}
@media all and (min-width: 769px) {
  .cp-history__flow .is-font-l {
    font-size: 20px;
  }
}
.cp-history__flow .is-black {
  font-size: 3.7333333333vw;
  color: #575253;
  font-weight: 400;
  line-height: 1.6428571429;
}
@media all and (min-width: 769px) {
  .cp-history__flow .is-black {
    font-size: 14px;
  }
}
.cp-history__flow .num {
  display: inline-block;
  width: 7.4666666667vw;
  position: absolute;
  top: -5.3333333333vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow .num {
    width: 28px;
    top: -20px;
  }
}
.cp-history__flow .num img {
  width: 100%;
}
.cp-history__flow .year {
  margin-left: 7.4666666667vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow .year {
    margin-left: 28px;
  }
}
.cp-history__flow .ext {
  font-size: 3.2vw;
  color: #575253;
  font-weight: normal;
  letter-spacing: 0.012em;
  margin-left: 1.8666666667vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow .ext {
    font-size: 12px;
    margin-left: 7px;
  }
}
.cp-history__flow sup {
  font-size: 2.6666666667vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow sup {
    font-size: 10px;
  }
}
.cp-history__flow__item01__box {
  position: relative;
}
.cp-history__flow__item01__box:before {
  content: "";
  background: url(../images/ico_history_flow_item01.png) no-repeat 0 0;
  background-size: contain;
  width: 5.0666666667vw;
  height: 2.4vw;
  position: absolute;
  top: -2.4vw;
  left: 0;
  right: 0;
  margin: auto;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item01__box:before {
    width: 19px;
    height: 9px;
    top: -9px;
  }
}
.cp-history__flow__item01__box:after {
  content: "";
  background: url(../images/img_history_flow_item01.png) no-repeat 0 0;
  background-size: contain;
  width: 15.2vw;
  height: 23.7333333333vw;
  position: absolute;
  top: 21.3333333333vw;
  right: -9.8666666667vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item01__box:after {
    width: 57px;
    height: 89px;
    top: 80px;
    right: -37px;
  }
}
.cp-history__flow__item01__box__txt {
  margin-top: 5.3333333333vw;
  background-color: #fff;
  border-radius: 2.6666666667vw;
  padding: 2.1333333333vw 0;
  line-height: 1.5714285714;
  text-align: center;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item01__box__txt {
    margin-top: 20px;
    border-radius: 10px;
    padding: 8px 0;
  }
}
.cp-history__flow__item01__img01 {
  position: absolute;
  top: 32vw;
  left: -33.3333333333vw;
  width: 25.6vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item01__img01 {
    top: 120px;
    left: -125px;
    width: 96px;
  }
}
.cp-history__flow__item02__img01 {
  position: absolute;
  top: -12.8vw;
  left: -60.5333333333vw;
  width: 56vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item02__img01 {
    top: -48px;
    left: -227px;
    width: 210px;
  }
}
.cp-history__flow__item02__img02 {
  position: absolute;
  top: 6.1333333333vw;
  left: 0.2666666667vw;
  width: 33.6vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item02__img02 {
    top: 23px;
    left: 1px;
    width: 126px;
  }
}
.cp-history__flow__item02__img03 {
  position: absolute;
  top: 40.5333333333vw;
  left: -21.0666666667vw;
  width: 53.8666666667vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item02__img03 {
    top: 152px;
    left: -79px;
    width: 202px;
  }
}
.cp-history__flow__item03__img01 {
  position: absolute;
  top: -22.4vw;
  left: 20vw;
  width: 52.2666666667vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item03__img01 {
    top: -84px;
    left: 75px;
    width: 196px;
  }
}
.cp-history__flow__item04__img01 {
  position: absolute;
  top: 6.9333333333vw;
  left: -9.6vw;
  width: 66.6666666667vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item04__img01 {
    top: 26px;
    left: -36px;
    width: 250px;
  }
}
.cp-history__flow__item05__img01 {
  position: absolute;
  top: -24.5333333333vw;
  left: 44.5333333333vw;
  width: 41.8666666667vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item05__img01 {
    top: -92px;
    left: 167px;
    width: 157px;
  }
}
.cp-history__flow__item05__img02 {
  position: absolute;
  top: 25.0666666667vw;
  left: 0.2666666667vw;
  width: 53.8666666667vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item05__img02 {
    top: 94px;
    left: 1px;
    width: 202px;
  }
}
.cp-history__flow__item06__img01 {
  position: absolute;
  top: -22.6666666667vw;
  left: -3.4666666667vw;
  width: 50.1333333333vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item06__img01 {
    top: -85px;
    left: -13px;
    width: 188px;
  }
}
.cp-history__flow__item06__img02 {
  position: absolute;
  top: -23.2vw;
  left: -37.3333333333vw;
  width: 41.6vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item06__img02 {
    top: -87px;
    left: -140px;
    width: 156px;
  }
}
.cp-history__flow__item07__box {
  background: url(../images/bg_history_flow_item07.png) no-repeat 0 0;
  background-size: contain;
  width: 29.0666666667vw;
  height: 26.9333333333vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 4vw 2.6666666667vw 0 0;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item07__box {
    width: 109px;
    height: 101px;
    padding: 15px 10px 0 0;
  }
}
.cp-history__flow__item07__box__txt {
  color: #E5696A;
  font-weight: 400;
  text-align: center;
}
.cp-history__flow__item07__box__txt sup {
  font-size: 10px;
}
.cp-history__flow__item07__box .item07-txt01 {
  font-weight: bold;
}
.cp-history__flow__item07__box .item07-txt02 {
  font-size: 6.6666666667vw;
  font-weight: bold;
  line-height: 1.36;
  letter-spacing: 0.03em;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item07__box .item07-txt02 {
    font-size: 25px;
  }
}
.cp-history__flow__item07__box .item07-txt03 {
  font-size: 4.8vw;
  font-weight: bold;
  line-height: 1.8888888889;
  letter-spacing: 0.03em;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item07__box .item07-txt03 {
    font-size: 18px;
  }
}
.cp-history__flow__item07__ext {
  margin-top: 12vw;
  font-size: 3.2vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item07__ext {
    margin-top: 45px;
    font-size: 12px;
  }
}
.cp-history__flow__item07__ext .ext01 {
  line-height: 1.25;
}
.cp-history__flow__item07__ext .ext02 {
  line-height: 1.25;
}
.cp-history__flow__item07__img01 {
  position: absolute;
  top: -40vw;
  left: -2.6666666667vw;
  width: 93.8666666667vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item07__img01 {
    top: -150px;
    left: -10px;
    width: 352px;
  }
}
.cp-history__flow__item08__img01 {
  position: absolute;
  top: -16vw;
  left: 47.4666666667vw;
  width: 44.2666666667vw;
}
@media all and (min-width: 769px) {
  .cp-history__flow__item08__img01 {
    top: -60px;
    left: 178px;
    width: 166px;
  }
}
.cp-history__flow__img img {
  width: 100%;
}

.cp-know {
  margin-top: 18.6666666667vw;
  padding-top: 6.6666666667vw;
  padding-bottom: 28.8vw;
  background: url(../images/bg_know.png) no-repeat 50% 100%;
  background-size: 100%;
  overflow: hidden;
  position: relative;
}
@media all and (min-width: 769px) {
  .cp-know {
    margin-top: 70px;
    padding-top: 25px;
    padding-bottom: 108px;
  }
}
.cp-know__head {
  text-align: center;
  margin-bottom: -8vw;
}
@media all and (min-width: 769px) {
  .cp-know__head {
    margin-bottom: -30px;
  }
}
.cp-know__head__lead img {
  width: 83.4666666667vw;
}
@media all and (min-width: 769px) {
  .cp-know__head__lead img {
    width: 313px;
  }
}
.cp-know__head__tit {
  display: inline-block;
  margin-top: -8.5333333333vw;
}
@media all and (min-width: 769px) {
  .cp-know__head__tit {
    margin-top: -32px;
  }
}
.cp-know__head__tit img {
  width: 60.9333333333vw;
}
@media all and (min-width: 769px) {
  .cp-know__head__tit img {
    width: 228.5px;
  }
}
.cp-know__txt {
  margin-top: 13.3333333333vw;
  text-align: center;
  font-size: 4.2666666667vw;
  line-height: 1.375;
  letter-spacing: 0.03em;
}
@media all and (min-width: 769px) {
  .cp-know__txt {
    margin-top: 50px;
    font-size: 16px;
  }
}
.cp-know__txt2 {
  width: 76.2666666667vw;
  margin: 5.8666666667vw auto 0;
  text-align: center;
  font-size: 4.2666666667vw;
  line-height: 1.5625;
  position: relative;
}
@media all and (min-width: 769px) {
  .cp-know__txt2 {
    width: 286px;
    margin: 22px auto 0;
    font-size: 16px;
  }
}
.cp-know__txt2:before, .cp-know__txt2:after {
  content: "";
  width: 0.2666666667vw;
  height: 5.3333333333vw;
  background-color: #E5696A;
  position: absolute;
  top: 0;
}
@media all and (min-width: 769px) {
  .cp-know__txt2:before, .cp-know__txt2:after {
    width: 1px;
    height: 20px;
  }
}
.cp-know__txt2:before {
  left: 0;
  -webkit-transform: rotate(-30deg);
          transform: rotate(-30deg);
}
.cp-know__txt2:after {
  right: 0;
  -webkit-transform: rotate(30deg);
          transform: rotate(30deg);
}
.cp-know__btns {
  margin-top: 2.6666666667vw;
  position: relative;
  z-index: 2;
}
@media all and (min-width: 769px) {
  .cp-know__btns {
    margin-top: 10px;
  }
}
.cp-know__btns__item + .cp-know__btns__item {
  margin-top: 3.2vw;
}
@media all and (min-width: 769px) {
  .cp-know__btns__item + .cp-know__btns__item {
    margin-top: 12px;
  }
}
.cp-know__icon {
  position: absolute;
}
.cp-know__icon.blue01 {
  width: 14.1333333333vw;
}
@media all and (min-width: 769px) {
  .cp-know__icon.blue01 {
    width: 53px;
  }
}
.cp-know__icon.blue02 {
  width: 9.0666666667vw;
}
@media all and (min-width: 769px) {
  .cp-know__icon.blue02 {
    width: 34px;
  }
}
.cp-know__icon.pink01 {
  width: 8vw;
}
@media all and (min-width: 769px) {
  .cp-know__icon.pink01 {
    width: 30px;
  }
}
.cp-know__icon.pink02 {
  width: 13.8666666667vw;
}
@media all and (min-width: 769px) {
  .cp-know__icon.pink02 {
    width: 52px;
  }
}
.cp-know__icon.pink03 {
  width: 11.7333333333vw;
}
@media all and (min-width: 769px) {
  .cp-know__icon.pink03 {
    width: 44px;
  }
}
.cp-know__circle {
  position: absolute;
}
.cp-know__circle img {
  width: 100%;
}
.cp-know__circle.blue01 {
  width: 14.1333333333vw;
  top: 45.3333333333vw;
  right: 2.6666666667vw;
}
@media all and (min-width: 769px) {
  .cp-know__circle.blue01 {
    width: 53px;
    top: 170px;
    right: 10px;
  }
}
.cp-know__circle.blue02 {
  width: 9.0666666667vw;
  top: 106.6666666667vw;
  left: 21.6vw;
}
@media all and (min-width: 769px) {
  .cp-know__circle.blue02 {
    width: 34px;
    top: 400px;
    left: 81px;
  }
}
.cp-know__circle.pink01 {
  width: 8vw;
  top: 2.6666666667vw;
  right: 14.4vw;
}
@media all and (min-width: 769px) {
  .cp-know__circle.pink01 {
    width: 30px;
    top: 10px;
    right: 54px;
  }
}
.cp-know__circle.pink02 {
  width: 13.8666666667vw;
  top: 88vw;
  left: 0.5333333333vw;
}
@media all and (min-width: 769px) {
  .cp-know__circle.pink02 {
    width: 52px;
    top: 330px;
    left: 2px;
  }
}
.cp-know__circle.pink03 {
  width: 11.7333333333vw;
  top: 99.7333333333vw;
  right: -1.8666666667vw;
}
@media all and (min-width: 769px) {
  .cp-know__circle.pink03 {
    width: 44px;
    top: 374px;
    right: -7px;
  }
}
.cp-know__modal {
  position: fixed;
  top: 100%;
  left: 0;
  right: 0;
  margin: auto;
  width: calc(100% - 8vw);
  height: calc(100% - 11.2vw);
  z-index: 0;
  visibility: hidden;
  opacity: 0;
  -webkit-transition: all 0.7s ease-in-out;
  transition: all 0.7s ease-in-out;
  background-color: #fff;
  border-radius: 2.6666666667vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal {
    border-radius: 10px;
    width: 345px;
    height: calc(100% - 42px);
  }
}
.cp-know__modal.is-active {
  top: 11.2vw;
  visibility: visible;
  opacity: 1;
  z-index: 100;
}
@media all and (min-width: 769px) {
  .cp-know__modal.is-active {
    top: 42px;
  }
}
.cp-know__modal__inner {
  overflow-y: scroll;
  overscroll-behavior-y: contain;
  width: 100%;
  height: 100%;
  padding: 8vw 4vw 5.3333333333vw;
  position: relative;
}
@media all and (min-width: 769px) {
  .cp-know__modal__inner {
    padding: 30px 15px 20px;
  }
}
.cp-know__modal__close {
  position: absolute;
  top: 3.2vw;
  right: 4.2666666667vw;
  width: 4.5333333333vw;
  height: 4.5333333333vw;
  z-index: 1;
}
@media all and (min-width: 769px) {
  .cp-know__modal__close {
    top: 12px;
    right: 16px;
    width: 17px;
    height: 17px;
  }
}
.cp-know__modal__tit {
  text-align: center;
}
.cp-know__modal__tit.tit01 img {
  width: 65.3333333333vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__tit.tit01 img {
    width: 245px;
  }
}
.cp-know__modal__tit.tit02 img {
  width: 62.9333333333vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__tit.tit02 img {
    width: 236px;
  }
}
.cp-know__modal__list {
  margin-top: 6.1333333333vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__list {
    margin-top: 23px;
  }
}
.cp-know__modal__item + .cp-know__modal__item {
  margin-top: -8vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item + .cp-know__modal__item {
    margin-top: -30px;
  }
}
.cp-know__modal__item:nth-child(odd) .cp-know__modal__item__tit {
  background: url(../images/bg_topics_tit_red.png) no-repeat 0 0;
  background-size: contain;
}
.cp-know__modal__item:nth-child(odd) .cp-know__modal__item__in {
  background: -webkit-gradient(linear, left top, left bottom, from(#fce5ef), to(#fec5db));
  background: -webkit-linear-gradient(#fce5ef 0%, #fec5db 100%);
  background: linear-gradient(#fce5ef 0%, #fec5db 100%);
}
.cp-know__modal__item:nth-child(even) .cp-know__modal__item__tit {
  background: url(../images/bg_topics_tit_blue.png) no-repeat 0 0;
  background-size: contain;
}
.cp-know__modal__item:nth-child(even) .cp-know__modal__item__in {
  background: -webkit-gradient(linear, left top, left bottom, from(#dbe9fd), color-stop(70.44%, #b6d2f7), to(#a6c9f4));
  background: -webkit-linear-gradient(#dbe9fd 0%, #b6d2f7 70.44%, #a6c9f4 100%);
  background: linear-gradient(#dbe9fd 0%, #b6d2f7 70.44%, #a6c9f4 100%);
}
.cp-know__modal__item:last-child .cp-know__modal__item__in {
  padding-bottom: 5.3333333333vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item:last-child .cp-know__modal__item__in {
    padding-bottom: 20px;
  }
}
.cp-know__modal__item__tit {
  width: 40vw;
  height: 8.8vw;
  font-size: 4.2666666667vw;
  font-weight: bold;
  letter-spacing: 0.08em;
  color: #E5696A;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 1.3333333333vw 0 0 5.3333333333vw;
  position: relative;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__tit {
    width: 150px;
    height: 33px;
    font-size: 16px;
    padding: 5px 0 0 20px;
  }
}
.cp-know__modal__item__tit .num {
  display: inline-block;
  background: url(../images/bg_topics_num.png) no-repeat 0 0;
  background-size: contain;
  width: 10.9333333333vw;
  height: 9.0666666667vw;
  color: #fff;
  font-size: 4.8vw;
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 1.3333333333vw 1.3333333333vw 0 0;
  margin: 0 0 0.8vw 0.8vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__tit .num {
    width: 41px;
    height: 34px;
    font-size: 18px;
    padding: 5px 5px 0 0;
    margin: 0 0 3px 3px;
  }
}
.cp-know__modal__item__in {
  margin-top: -2.1333333333vw;
  padding: 3.7333333333vw 5.3333333333vw 13.3333333333vw;
  border-radius: 1.3333333333vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__in {
    margin-top: -8px;
    padding: 14px 20px 50px;
    border-radius: 5px;
  }
}
.cp-know__modal__item__head {
  border-top: 1px solid #E5696A;
  border-bottom: 1px solid #E5696A;
  text-align: center;
  padding: 3.2vw 0;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__head {
    padding: 12px 0;
  }
}
.cp-know__modal__item__head__txt {
  font-size: 4.8vw;
  font-weight: bold;
  color: #E5696A;
  letter-spacing: 0.03em;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__head__txt {
    font-size: 18px;
  }
}
.cp-know__modal__item__head__txt .bg {
  background-color: #fff;
  border-radius: 1.3333333333vw;
  padding: 0 1.3333333333vw;
}
.cp-know__modal__item__head__txt .bg.is-dib {
  display: inline-block;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__head__txt .bg {
    border-radius: 5px;
    padding: 0 5px;
  }
}
.cp-know__modal__item__head__txt .is-font-s {
  font-size: 3.7333333333vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__head__txt .is-font-s {
    font-size: 14px;
  }
}
.cp-know__modal__item__head__txt .is-font-m {
  font-size: 4.2666666667vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__head__txt .is-font-m {
    font-size: 16px;
  }
}
.cp-know__modal__item__head__txt sup {
  font-size: 2.6666666667vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__head__txt sup {
    font-size: 10px;
  }
}
.cp-know__modal__item__block {
  background-color: #fff;
  margin-top: 4vw;
  border-radius: 2.6666666667vw;
  padding: 5.3333333333vw 2.6666666667vw 4vw;
  text-align: center;
  position: relative;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__block {
    margin-top: 15px;
    border-radius: 10px;
    padding: 20px 10px 15px;
  }
}
.cp-know__modal__item__block:before {
  content: "";
  background: url(../images/ico_history_flow_item01.png) no-repeat 0 0;
  background-size: contain;
  width: 5.0666666667vw;
  height: 2.4vw;
  position: absolute;
  top: -2.1333333333vw;
  left: 0;
  right: 0;
  margin: auto;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__block:before {
    width: 19px;
    height: 9px;
    top: -8px;
  }
}
.cp-know__modal__item__block__tit {
  font-size: 4.2666666667vw;
  margin-bottom: 2.1333333333vw;
  font-weight: bold;
  color: #E5696A;
  letter-spacing: 0.03em;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__block__tit {
    font-size: 16px;
    margin-bottom: 8px;
  }
}
.cp-know__modal__item__block__txt {
  font-size: 4.2666666667vw;
  line-height: 1.4375;
  letter-spacing: 0.03em;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__block__txt {
    font-size: 16px;
  }
}
.cp-know__modal__item__block__txt .color-pink {
  color: #E5696A;
}
.cp-know__modal__item__block__txt .bold {
  font-weight: bold;
}
.cp-know__modal__item__block__txt sup {
  font-size: 2.6666666667vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__block__txt sup {
    font-size: 10px;
  }
}
.cp-know__modal__item__block__txt .font {
  font-size: 5.3333333333vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__block__txt .font {
    font-size: 20px;
  }
}
.cp-know__modal__item__block__img {
  margin-top: 2.6666666667vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__block__img {
    margin-top: 10px;
  }
}
.cp-know__modal__item__block__img img {
  width: 61.8666666667vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__block__img img {
    width: 232px;
  }
}
.cp-know__modal__item__ext01 {
  margin-top: 1.0666666667vw;
  font-size: 3.2vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__ext01 {
    margin-top: 4px;
    font-size: 12px;
  }
}
.cp-know__modal__item__ext01.mt10 {
  margin-top: 2.6666666667vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__ext01.mt10 {
    margin-top: 10px;
  }
}
.cp-know__modal__item__ext02 {
  margin-top: 2.1333333333vw;
  font-size: 3.2vw;
  line-height: 1.25;
  letter-spacing: -0.05em;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__ext02 {
    margin-top: 8px;
    font-size: 12px;
  }
}
.cp-know__modal__item__img9 {
  text-align: right;
  margin: 1.8666666667vw 0 2.6666666667vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__img9 {
    margin: 7px 0 10px;
  }
}
.cp-know__modal__item__img9 img {
  width: 67.2vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__img9 img {
    width: 252px;
  }
}
.cp-know__modal__item__img10 {
  position: absolute;
  top: -4vw;
  right: -4vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__img10 {
    top: -15px;
    right: -15px;
  }
}
.cp-know__modal__item__img10 img {
  width: 14.4vw;
}
@media all and (min-width: 769px) {
  .cp-know__modal__item__img10 img {
    width: 54px;
  }
}

.cp-howto {
  margin-top: 18.6666666667vw;
  background: url(../images/bg_howto.png) no-repeat 50% 100%;
  background-size: 100%;
  overflow: hidden;
  position: relative;
}
@media all and (min-width: 769px) {
  .cp-howto {
    margin-top: 70px;
  }
}
.cp-howto__tit {
  text-align: center;
}
.cp-howto__tit img {
  width: 49.3333333333vw;
}
@media all and (min-width: 769px) {
  .cp-howto__tit img {
    width: 185px;
  }
}
.cp-howto__head {
  padding-bottom: 8.5333333333vw;
}
@media all and (min-width: 769px) {
  .cp-howto__head {
    padding-bottom: 32px;
  }
}
.cp-howto__head__lead {
  padding-top: 3.2vw;
  text-align: center;
}
@media all and (min-width: 769px) {
  .cp-howto__head__lead {
    padding-top: 12px;
  }
}
.cp-howto__head__lead img {
  width: 36.8vw;
}
@media all and (min-width: 769px) {
  .cp-howto__head__lead img {
    width: 138px;
  }
}
.cp-howto__head__list {
  max-width: 53.3333333333vw;
  margin: 6.6666666667vw auto 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
}
@media all and (min-width: 769px) {
  .cp-howto__head__list {
    max-width: 200px;
    margin: 25px auto 0;
  }
}
.cp-howto__head__list:before {
  content: "";
  background: url(../images/img_howto_head.png) no-repeat 0 0;
  background-size: contain;
  width: 17.6vw;
  height: 26.6666666667vw;
  position: absolute;
  top: 40vw;
  left: 4.2666666667vw;
}
@media all and (min-width: 769px) {
  .cp-howto__head__list:before {
    width: 66px;
    height: 100px;
    top: 150px;
    left: 16px;
  }
}
.cp-howto__head__item {
  width: 10.6666666667vw;
  position: relative;
}
@media all and (min-width: 769px) {
  .cp-howto__head__item {
    width: 40px;
  }
}
.cp-howto__head__item + .cp-howto__head__item:before {
  content: "";
  background: url(../images/ico_howto_head_arw.png) no-repeat 0 0;
  background-size: contain;
  width: 7.7333333333vw;
  height: 2.6666666667vw;
  position: absolute;
  top: 45%;
  left: -50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media all and (min-width: 769px) {
  .cp-howto__head__item + .cp-howto__head__item:before {
    width: 29px;
    height: 10px;
  }
}
.cp-howto__head__item:nth-child(2) .cp-howto__head__txt {
  position: relative;
}
.cp-howto__head__item:nth-child(2) .cp-howto__head__txt:before {
  content: "";
  background: url(../images/ico_howto_head.png) no-repeat 0 0;
  background-size: contain;
  width: 4.8vw;
  height: 5.8666666667vw;
  position: absolute;
  top: -1.3333333333vw;
  right: -4.2666666667vw;
}
@media all and (min-width: 769px) {
  .cp-howto__head__item:nth-child(2) .cp-howto__head__txt:before {
    width: 18px;
    height: 22px;
    position: absolute;
    top: -5px;
    right: -16px;
  }
}
.cp-howto__head__num {
  font-family: "Fahkwang", serif;
  width: 9.3333333333vw;
  height: 9.3333333333vw;
  border-radius: 50%;
  background: -webkit-gradient(linear, left top, left bottom, from(#f1bbd4), to(#a6c9f4));
  background: -webkit-linear-gradient(#f1bbd4 0%, #a6c9f4 100%);
  background: linear-gradient(#f1bbd4 0%, #a6c9f4 100%);
  -webkit-filter: drop-shadow(0.5333333333vw 0.5333333333vw 0px #5f92d9);
          filter: drop-shadow(0.5333333333vw 0.5333333333vw 0px #5f92d9);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 6.6666666667vw;
  color: #fff;
  font-weight: 600;
  margin: auto;
}
@media all and (min-width: 769px) {
  .cp-howto__head__num {
    width: 35px;
    height: 35px;
    -webkit-filter: drop-shadow(2px 2px 0px #5f92d9);
            filter: drop-shadow(2px 2px 0px #5f92d9);
    font-size: 25px;
  }
}
.cp-howto__head__txt {
  margin: 3.7333333333vw auto 0;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  font-size: 4.2666666667vw;
  font-weight: bold;
  color: #5F92D9;
  line-height: 1.4;
  letter-spacing: 0.1em;
}
@media all and (min-width: 769px) {
  .cp-howto__head__txt {
    margin: 14px auto 0;
    font-size: 16px;
  }
}
.cp-howto__head__txt span {
  text-combine-upright: all;
}
.cp-howto__head__txt.color-red {
  font-size: 4.8vw;
  color: #E5696A;
}
@media all and (min-width: 769px) {
  .cp-howto__head__txt.color-red {
    font-size: 18px;
  }
}
.cp-howto__point__item__tit {
  width: 77.6vw;
  margin: auto;
  text-align: center;
  font-family: "Fahkwang", serif;
  font-size: 5.3333333333vw;
  font-weight: bold;
  padding-bottom: 1.0666666667vw;
  letter-spacing: 0.01em;
  color: #5F92D9;
  position: relative;
}
@media all and (min-width: 769px) {
  .cp-howto__point__item__tit {
    width: 291px;
    font-size: 20px;
    padding-bottom: 4px;
  }
}
.cp-howto__point__item__tit:before, .cp-howto__point__item__tit:after {
  content: "";
  width: 21.0666666667vw;
  height: 0.2666666667vw;
  background-color: #5F92D9;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
@media all and (min-width: 769px) {
  .cp-howto__point__item__tit:before, .cp-howto__point__item__tit:after {
    width: 79px;
    height: 1px;
  }
}
.cp-howto__point__item__tit:before {
  left: 0;
}
.cp-howto__point__item__tit:after {
  right: 0;
}
.cp-howto__point__item__tit .num {
  font-size: 7.2vw;
  margin-left: 1.0666666667vw;
}
@media all and (min-width: 769px) {
  .cp-howto__point__item__tit .num {
    font-size: 27px;
    margin-left: 4px;
  }
}
.cp-howto__point__point1 {
  position: relative;
  margin: -0.5333333333vw 0px 0px 14.6666666667vw;
  padding-bottom: 10.6666666667vw;
}
@media all and (min-width: 769px) {
  .cp-howto__point__point1 {
    margin: -2px 0px 0px 55px;
    padding-bottom: 40px;
  }
}
.cp-howto__point__point1__img img {
  width: 36.2666666667vw;
}
@media all and (min-width: 769px) {
  .cp-howto__point__point1__img img {
    width: 136px;
  }
}
.cp-howto__point__point1__in {
  position: absolute;
  top: 8vw;
  right: 8.5333333333vw;
}
@media all and (min-width: 769px) {
  .cp-howto__point__point1__in {
    top: 30px;
    right: 32px;
  }
}
.cp-howto__point__point1__txt {
  font-size: 4.8vw;
  font-weight: bold;
  letter-spacing: 0.03em;
  color: #5F92D9;
  line-height: 1.5555555556;
}
@media all and (min-width: 769px) {
  .cp-howto__point__point1__txt {
    font-size: 18px;
  }
}
.cp-howto__point__point1__lead {
  width: 25.8666666667vw;
  height: 26.1333333333vw;
  border-radius: 50%;
  background: -webkit-gradient(linear, left top, left bottom, from(#5f92d9), to(#bac7e7));
  background: -webkit-linear-gradient(#5f92d9 0%, #bac7e7 100%);
  background: linear-gradient(#5f92d9 0%, #bac7e7 100%);
  -webkit-filter: drop-shadow(0.5333333333vw 0.5333333333vw 0px #5f92d9);
          filter: drop-shadow(0.5333333333vw 0.5333333333vw 0px #5f92d9);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
  font-size: 4.2666666667vw;
  font-weight: bold;
  color: #fff;
  margin: 5.3333333333vw 0 0 5.3333333333vw;
  letter-spacing: 0.01em;
  line-height: 1.375;
}
@media all and (min-width: 769px) {
  .cp-howto__point__point1__lead {
    width: 97px;
    height: 98px;
    font-size: 16px;
    -webkit-filter: drop-shadow(2px 2px 0px #5f92d9);
            filter: drop-shadow(2px 2px 0px #5f92d9);
    margin: 20px 0 0 20px;
  }
}
.cp-howto__point__point2 {
  padding-bottom: 25.3333333333vw;
}
@media all and (min-width: 769px) {
  .cp-howto__point__point2 {
    padding-bottom: 95px;
  }
}
.cp-howto__point__point2__in {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-right: 2.6666666667vw;
}
@media all and (min-width: 769px) {
  .cp-howto__point__point2__in {
    margin-right: 10px;
  }
}
.cp-howto__point__point2__img img {
  width: 33.0666666667vw;
}
@media all and (min-width: 769px) {
  .cp-howto__point__point2__img img {
    width: 124px;
  }
}
.cp-howto__point__point2__list {
  margin-left: 1.8666666667vw;
}
@media all and (min-width: 769px) {
  .cp-howto__point__point2__list {
    margin-left: 7px;
  }
}
.cp-howto__point__point2__item {
  font-size: 4.2666666667vw;
  font-weight: 500;
  line-height: 1.25;
  letter-spacing: 0.03em;
  padding-left: 4vw;
  text-indent: -4vw;
  position: relative;
}
@media all and (min-width: 769px) {
  .cp-howto__point__point2__item {
    font-size: 16px;
    padding-left: 15px;
    text-indent: -15px;
  }
}
.cp-howto__point__point2__item + .cp-howto__point__point2__item {
  margin-top: 3.2vw;
}
@media all and (min-width: 769px) {
  .cp-howto__point__point2__item + .cp-howto__point__point2__item {
    margin-top: 12px;
  }
}
.cp-howto__point__point2__item:before {
  content: "";
  width: 2.1333333333vw;
  height: 2.1333333333vw;
  border-radius: 50%;
  background-color: #5F92D9;
  display: inline-block;
  margin: 0 1.8666666667vw 0.5333333333vw 0;
}
@media all and (min-width: 769px) {
  .cp-howto__point__point2__item:before {
    width: 8px;
    height: 8px;
    margin: 0 7px 2px 0;
  }
}
.cp-howto__point__point2__box {
  margin: 2.6666666667vw auto 0;
  width: 65.0666666667vw;
  background-color: #fff;
  border-radius: 2.6666666667vw;
  padding: 3.4666666667vw 4.8vw 2.1333333333vw;
  font-size: 4.2666666667vw;
  font-weight: bold;
  letter-spacing: 0.03em;
  line-height: 1.5625;
  color: #5F92D9;
  text-align: center;
  position: relative;
}
@media all and (min-width: 769px) {
  .cp-howto__point__point2__box {
    margin: 10px auto 0;
    width: 244px;
    border-radius: 10px;
    padding: 13px 18px 8px;
    font-size: 16px;
  }
}
.cp-howto__point__point2__box:before {
  content: "";
  background: url(../images/ico_history_flow_item01.png) no-repeat 0 0;
  width: 5.0666666667vw;
  height: 2.1333333333vw;
  position: absolute;
  top: -2.1333333333vw;
  left: 0;
  right: 0;
  margin: auto;
}
@media all and (min-width: 769px) {
  .cp-howto__point__point2__box:before {
    width: 19px;
    height: 8px;
    top: -8px;
  }
}
.cp-howto__circle {
  position: absolute;
}
.cp-howto__circle img {
  width: 100%;
}
.cp-howto__circle.blue01 {
  width: 12.8vw;
  top: 38.6666666667vw;
  left: -2.6666666667vw;
}
@media all and (min-width: 769px) {
  .cp-howto__circle.blue01 {
    width: 48px;
    top: 145px;
    left: -10px;
  }
}
.cp-howto__circle.blue02 {
  width: 18.1333333333vw;
  top: 143.4666666667vw;
  left: 0;
}
@media all and (min-width: 769px) {
  .cp-howto__circle.blue02 {
    width: 68px;
    top: 538px;
    left: 0;
  }
}
.cp-howto__circle.blue03 {
  width: 10.6666666667vw;
  top: 217.6vw;
  right: 1.6vw;
}
@media all and (min-width: 769px) {
  .cp-howto__circle.blue03 {
    width: 40px;
    top: 816px;
    right: 6px;
  }
}
.cp-howto__circle.pink01 {
  width: 7.2vw;
  top: 64vw;
  left: 11.2vw;
}
@media all and (min-width: 769px) {
  .cp-howto__circle.pink01 {
    width: 27px;
    top: 240px;
    left: 42px;
  }
}
.cp-howto__circle.pink02 {
  width: 16vw;
  top: 75.4666666667vw;
  right: 0;
}
@media all and (min-width: 769px) {
  .cp-howto__circle.pink02 {
    width: 60px;
    top: 283px;
    right: 0;
  }
}
.cp-howto__circle.pink03 {
  width: 7.2vw;
  top: 155.2vw;
  left: 24vw;
}
@media all and (min-width: 769px) {
  .cp-howto__circle.pink03 {
    width: 27px;
    top: 582px;
    left: 90px;
  }
}

.cp-perfect {
  margin-top: 21.3333333333vw;
  position: relative;
}
@media all and (min-width: 769px) {
  .cp-perfect {
    margin-top: 80px;
  }
}
.cp-perfect__inner {
  position: relative;
}
.cp-perfect__img img {
  width: 100%;
}
.cp-perfect__head {
  position: absolute;
  top: 5.3333333333vw;
  left: 0;
  width: 100%;
}
@media all and (min-width: 769px) {
  .cp-perfect__head {
    top: 20px;
  }
}
.cp-perfect__head__tit {
  text-align: center;
}
.cp-perfect__head__tit img {
  width: 63.7333333333vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__head__tit img {
    width: 239px;
  }
}
.cp-perfect__head__lead {
  margin-top: 4.2666666667vw;
  text-align: center;
  font-size: 4.2666666667vw;
  font-weight: bold;
  color: #E5696A;
  letter-spacing: 0.02em;
  line-height: 1.375;
}
@media all and (min-width: 769px) {
  .cp-perfect__head__lead {
    margin-top: 16px;
    font-size: 16px;
  }
}
.cp-perfect__flow__box {
  width: 33.3333333333vw;
  height: 21.3333333333vw;
  border-radius: 1.8666666667vw;
  background: #fff;
  -webkit-box-shadow: 0.8vw 0.8vw 0px #5f92d9;
          box-shadow: 0.8vw 0.8vw 0px #5f92d9;
  font-size: 4.2666666667vw;
  font-weight: bold;
  color: #5F92D9;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
  line-height: 1.25;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__box {
    width: 125px;
    height: 80px;
    border-radius: 7px;
    -webkit-box-shadow: 3px 3px 0px #5f92d9;
            box-shadow: 3px 3px 0px #5f92d9;
    font-size: 16px;
  }
}
.cp-perfect__flow__box.is-ptt1 {
  margin-left: 3.4666666667vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__box.is-ptt1 {
    margin-left: 13px;
  }
}
.cp-perfect__flow__box.is-ptt2 {
  width: 30.6666666667vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__box.is-ptt2 {
    width: 115px;
  }
}
.cp-perfect__flow__box.is-ptt3 {
  width: 30.6666666667vw;
  height: 17.3333333333vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__box.is-ptt3 {
    width: 115px;
    height: 65px;
  }
}
.cp-perfect__flow__product__txt {
  font-weight: bold;
  color: #E5696A;
  letter-spacing: 0.03em;
  line-height: 1.2857142857;
}
.cp-perfect__flow__product__txt.is-ptt1 {
  margin: 2.1333333333vw 0 0 4.5333333333vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__product__txt.is-ptt1 {
    margin: 8px 0 0 17px;
  }
}
.cp-perfect__flow__product__txt.is-ptt2 {
  margin: 2.1333333333vw 0 0 -1.6vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__product__txt.is-ptt2 {
    margin: 8px 0 0 -6px;
  }
}
.cp-perfect__flow__first {
  font-size: 5.0666666667vw;
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.02em;
  line-height: 1.2631578947;
  background: url(../images/bg_perfect_flow_first.png) no-repeat 0 0;
  background-size: contain;
  width: 38.6666666667vw;
  height: 33.0666666667vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-bottom: 1.6vw;
  position: absolute;
  top: 44.2666666667vw;
  left: 2.1333333333vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__first {
    font-size: 19px;
    width: 145px;
    height: 124px;
    padding-bottom: 6px;
    top: 166px;
    left: 8px;
  }
}
.cp-perfect__flow__second {
  position: absolute;
  top: 103.4666666667vw;
  left: 10.9333333333vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__second {
    top: 388px;
    left: 41px;
  }
}
.cp-perfect__flow__product1 {
  position: absolute;
  top: 46.9333333333vw;
  right: 9.6vw;
  z-index: 1;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__product1 {
    top: 176px;
    right: 36px;
  }
}
.cp-perfect__flow__product1__img {
  margin: 2.1333333333vw 0 0 -5.3333333333vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__product1__img {
    margin: 8px 0 0 -20px;
  }
}
.cp-perfect__flow__product1__img img {
  width: 44.1333333333vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__product1__img img {
    width: 165.5px;
  }
}
.cp-perfect__flow__product2 {
  position: absolute;
  top: 151.4666666667vw;
  left: 10.9333333333vw;
  z-index: 1;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__product2 {
    top: 568px;
    left: 41px;
  }
}
.cp-perfect__flow__product2__img {
  margin: 4vw 0 0 -1.6vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__product2__img {
    margin: 15px 0 0 -6px;
  }
}
.cp-perfect__flow__product2__img img {
  width: 33.8666666667vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__product2__img img {
    width: 127px;
  }
}
.cp-perfect__flow__product3 {
  position: absolute;
  top: 151.4666666667vw;
  right: 9.6vw;
  z-index: 1;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__product3 {
    top: 568px;
    right: 36px;
  }
}
.cp-perfect__flow__product3__img {
  margin: 4vw 0 0 -1.6vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__product3__img {
    margin: 15px 0 0 -6px;
  }
}
.cp-perfect__flow__product3__img img {
  width: 33.8666666667vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__product3__img img {
    width: 127px;
  }
}
.cp-perfect__flow__want {
  position: absolute;
  top: 144.5333333333vw;
  width: 100%;
  text-align: center;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__want {
    top: 542px;
    margin-left: 2px;
  }
}
.cp-perfect__flow__want .txt {
  font-size: 4.2666666667vw;
  font-weight: bold;
  color: #5F92D9;
  letter-spacing: 0.08em;
  position: relative;
  z-index: 1;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__want .txt {
    font-size: 16px;
  }
}
.cp-perfect__flow__want .txt:before {
  content: "";
  background: -webkit-gradient(linear, left top, right top, from(#c4d6f2), to(#f3c9dc));
  background: -webkit-linear-gradient(left, #c4d6f2 0%, #f3c9dc 100%);
  background: linear-gradient(90deg, #c4d6f2 0%, #f3c9dc 100%);
  width: calc(100% + 1.0666666667vw);
  height: 1.3333333333vw;
  position: absolute;
  bottom: 0.5333333333vw;
  left: -1.0666666667vw;
  margin: auto;
  z-index: -1;
}
@media all and (min-width: 769px) {
  .cp-perfect__flow__want .txt:before {
    width: calc(100% + 4px);
    height: 5px;
    bottom: 2px;
    left: -4px;
  }
}
.cp-perfect__circle {
  position: absolute;
}
.cp-perfect__circle img {
  width: 100%;
}
.cp-perfect__circle.blue01 {
  width: 9.0666666667vw;
  top: 33.3333333333vw;
  right: 16vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__circle.blue01 {
    width: 34px;
    top: 125px;
    right: 60px;
  }
}
.cp-perfect__circle.blue02 {
  width: 9.0666666667vw;
  top: 135.2vw;
  left: 2.1333333333vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__circle.blue02 {
    width: 34px;
    top: 507px;
    left: 8px;
  }
}
.cp-perfect__circle.blue03 {
  width: 14.9333333333vw;
  top: 131.7333333333vw;
  right: 2.1333333333vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__circle.blue03 {
    width: 56px;
    top: 494px;
    right: 8px;
  }
}
.cp-perfect__circle.blue04 {
  width: 6.9333333333vw;
  top: 179.2vw;
  right: 40.8vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__circle.blue04 {
    width: 26px;
    top: 672px;
    right: 153px;
  }
}
.cp-perfect__circle.pink01 {
  width: 13.8666666667vw;
  top: 80.8vw;
  left: 22.9333333333vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__circle.pink01 {
    width: 52px;
    top: 303px;
    left: 86px;
  }
}
.cp-perfect__circle.pink02 {
  width: 12.8vw;
  top: 197.6vw;
  left: 37.8666666667vw;
}
@media all and (min-width: 769px) {
  .cp-perfect__circle.pink02 {
    width: 48px;
    top: 741px;
    left: 142px;
  }
}

.cp-menu {
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 10;
  width: 100%;
}
@media all and (min-width: 769px) {
  .cp-menu {
    width: 375px;
    left: calc((100% - 375px) / 2);
  }
}
.cp-menu__list {
  margin: 0 0 1.6vw 0.5333333333vw;
}
@media all and (min-width: 769px) {
  .cp-menu__list {
    margin: 0 0 6px 2px;
  }
}
.cp-menu__item + .cp-menu__item {
  margin-top: 1.3333333333vw;
}
@media all and (min-width: 769px) {
  .cp-menu__item + .cp-menu__item {
    margin-top: 5px;
  }
}
.cp-menu__item__link {
  text-indent: -9999px;
  display: inline-block;
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
  height: 6.6666666667vw;
  -webkit-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
}
@media all and (min-width: 769px) {
  .cp-menu__item__link {
    height: 25px;
  }
}
.cp-menu__item.item01 .cp-menu__item__link {
  background-image: url(../images/btn_menu01.png);
  width: 43.4666666667vw;
}
@media (hover: hover) {
  .cp-menu__item.item01 .cp-menu__item__link:hover {
    background-image: url(../images/btn_menu01_hov.png);
  }
}
@media all and (min-width: 769px) {
  .cp-menu__item.item01 .cp-menu__item__link {
    width: 163px;
  }
}
.cp-menu__item.item02 .cp-menu__item__link {
  background-image: url(../images/btn_menu02.png);
  width: 78.9333333333vw;
}
@media (hover: hover) {
  .cp-menu__item.item02 .cp-menu__item__link:hover {
    background-image: url(../images/btn_menu02_hov.png);
  }
}
@media all and (min-width: 769px) {
  .cp-menu__item.item02 .cp-menu__item__link {
    width: 296px;
  }
}
.cp-menu__item.item03 .cp-menu__item__link {
  background-image: url(../images/btn_menu03.png);
  width: 36vw;
}
@media (hover: hover) {
  .cp-menu__item.item03 .cp-menu__item__link:hover {
    background-image: url(../images/btn_menu03_hov.png);
  }
}
@media all and (min-width: 769px) {
  .cp-menu__item.item03 .cp-menu__item__link {
    width: 135px;
  }
}
.cp-menu__item.item04 .cp-menu__item__link {
  background-image: url(../images/btn_menu04.png);
  width: 68vw;
}
@media (hover: hover) {
  .cp-menu__item.item04 .cp-menu__item__link:hover {
    background-image: url(../images/btn_menu04_hov.png);
  }
}
@media all and (min-width: 769px) {
  .cp-menu__item.item04 .cp-menu__item__link {
    width: 255px;
  }
}
.cp-menu__txt {
  font-size: 4.2666666667vw;
  font-weight: bold;
  color: #E5696A;
  letter-spacing: 0.08em;
  padding-left: 4.2666666667vw;
  display: block;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 10.4vw;
  background-color: #fff;
  line-height: 1;
}
@media all and (min-width: 769px) {
  .cp-menu__txt {
    width: 375px;
    font-size: 16px;
    padding-left: 16px;
    height: 39px;
  }
}
.cp-menu__txt:after {
  content: "";
  background: url(../images/ico_menu.png) no-repeat 0 0;
  background-size: contain;
  width: 2.9333333333vw;
  height: 2.4vw;
  display: inline-block;
  margin: 0 0 0.2666666667vw 2.6666666667vw;
}
@media all and (min-width: 769px) {
  .cp-menu__txt:after {
    width: 11px;
    height: 9px;
    margin: 0 0 1px 10px;
  }
}
.cp-menu__txt.is-active {
  color: #5F92D9;
}
.cp-menu__txt.is-active:after {
  background: url(../images/ico_menu_open.png) no-repeat 0 50%;
  background-size: contain;
}
@media (hover: hover) {
  .cp-menu__txt:not(.is-active):hover {
    color: #5F92D9;
  }
  .cp-menu__txt:not(.is-active):hover:after {
    background: url(../images/ico_menu_hov.png) no-repeat 0 0;
    background-size: contain;
  }
}