@charset "UTF-8";
/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
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 {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
  box-sizing: border-box; }

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, picture {
  display: block;
  box-sizing: border-box; }

body {
  line-height: 1; }

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

/* reset for form */
input {
  padding: 0;
  border: none;
  border-radius: 0;
  outline: none;
  background: none;
  box-sizing: border-box;
  font-family: 'Noto Sans JP', sans-serif; }

textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  resize: none;
  padding: 0;
  border: 0;
  outline: none;
  background: transparent;
  box-sizing: border-box;
  font-family: 'Noto Sans JP', sans-serif; }

button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 0;
  border: none;
  outline: none;
  background: transparent;
  box-sizing: border-box;
  font-family: 'Noto Sans JP', sans-serif; }

select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 0;
  border: none;
  outline: none;
  background: transparent;
  box-sizing: border-box;
  font-family: 'Noto Sans JP', sans-serif; }
  select::-ms-expand {
    display: none; }

/* ▼IE10・IE11用 */
:-ms-input-placeholder {
  color: #919191; }

/* ▼Chrome・Safari・Opera用(※1：Edgeでも有効) */
::-webkit-input-placeholder {
  color: #919191; }

/* ▼Firefox18以前用(※2) */
:-moz-placeholder {
  color: #919191; }

/* ▼Firefox19以上用(※3) */
::-moz-placeholder {
  color: #919191;
  opacity: 1; }

/* ▼CSS4標準(予定)の記述 */
::placeholder {
  color: #919191; }

/*========== set.scss ==========*/
html {
  font-size: 62.5%;
  background-color: #fff; }

body {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  color: #000;
  text-align: left;
  word-wrap: break-word;
  font-size: 1.6rem; }
  @media screen and (max-width: 767px) {
    body {
      font-size: calc(100vw / ( 375 / 15 )); } }

.clearfix:after {
  content: "";
  clear: both;
  display: block; }

img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  pointer-events: none; }

a {
  text-decoration: none;
  color: #000; }
  @media screen and (min-width: 768px) {
    a[href^="tel:"] {
      pointer-events: none; } }
  a:hover {
    filter: alpha(opacity=75);
    -moz-opacity: 0.75;
    opacity: 0.75;
    -webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease; }
  a.txtLink {
    text-decoration: underline; }
    a.txtLink.forBlank:after {
      content: "";
      display: inline-block;
      vertical-align: middle;
      width: 1.3em;
      height: 1.3em;
      margin-left: 0.5em;
      background: url("../images/icon_blank.svg") center no-repeat;
      background-size: contain; }
    a.txtLink.forPDF:after {
      content: "";
      display: inline-block;
      vertical-align: middle;
      width: 1.5em;
      height: 1.2em;
      margin-left: 0.5em;
      background: url("../images/icon_pdf_bk.svg") center no-repeat;
      background-size: contain; }

sup {
  vertical-align: super;
  font-size: 75%; }

@media screen and (max-width: 767px) {
  .noSP {
    display: none !important; } }

@media screen and (min-width: 768px) {
  .noPC {
    display: none !important; } }

.noShow {
  display: none !important; }

.toggle {
  cursor: pointer; }
  .toggle.open + .toggled {
    visibility: visible;
    opacity: 1;
    height: auto; }

.toggled {
  visibility: hidden;
  opacity: 0;
  height: 0;
  transition: all 0.3s ease; }

.inView {
  opacity: 0;
  visibility: hidden;
  transition: all 1s;
  transform: translateY(40px); }
  .inView.is-active {
    opacity: 1;
    visibility: visible;
    transform: translateY(0); }

/*========== l-header.scss ==========*/
.l-header {
  position: sticky;
  left: 0;
  top: 0;
  width: 100%;
  z-index: 9999;
  transition: all  0.3s ease;
  background: #fff; }
  .l-header.bg {
    box-shadow: 0 5px 5px 0 rgba(0, 0, 0, 0.15); }

/*========== l-footer.scss ==========*/
.l-footer {
  background: #208C30;
  padding: calc(100vw / ( 375 / 30 )) 0 calc(100vw / ( 375 / 20 )); }
  @media screen and (max-width: 767px) {
    .l-footer {
      padding-bottom: calc(100vw / ( 375 / 106 )); } }
  @media screen and (min-width: 768px) {
    .l-footer {
      padding: calc(100vw / ( 1440 / 24 )) 0; } }
  @media screen and (min-width: 1441px) {
    .l-footer {
      padding: 24px 0; } }

/*========== c-inner.scss ==========*/
.c-inner {
  margin: 0 auto;
  position: relative;
  z-index: 1;
  width: calc(100vw / ( 375 / 345 )); }
  @media screen and (min-width: 768px) {
    .c-inner {
      width: 96%;
      max-width: 1120px; } }
  @media screen and (min-width: 1441px) {
    .c-inner {
      width: 100%;
     } }

/*========== c-title.scss ==========*/
.c-title-top {
  text-align: center;
  font-weight: 700;
  text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.35);
  font-size: calc(100vw / ( 375 / 30 )); }
  @media screen and (min-width: 768px) {
    .c-title-top {
      font-size: 3.8rem; } }
  .c-title-top .eng {
    display: block;
    font-family: "Outfit", sans-serif;
    line-height: 180%;
    letter-spacing: 0.21em;
    font-size: calc(100vw / ( 375 / 18 ));
    padding-top: calc(100vw / ( 375 / 7 )); }
    @media screen and (min-width: 768px) {
      .c-title-top .eng {
        font-size: 2.0rem;
        padding-top: 7px; } }
.c-title-head {
  position: absolute;
  z-index: 1;
  left: 0;
  top: 50%;
  white-space: nowrap;
  transform: translateY(-50%);
  font-weight: 700;
  font-size: calc(100vw / ( 375 / 30 )); }
  @media screen and (min-width: 768px) {
    .c-title-head {
      font-size: 3.6rem; } }
  .c-title-head .eng {
    display: block;
    letter-spacing: 0.15em;
    font-family: "Outfit", sans-serif;
    font-size: calc(100vw / ( 375 / 17 ));
    padding: 0.5em 0 0 0.25em; }
    @media screen and (min-width: 768px) {
      .c-title-head .eng {
        font-size: 2.0rem; } }
  .c-title-headArea {
    background: url("../images/headarea_bg.png") center no-repeat;
    background-size: cover;
    border-bottom: 6px solid #B0DBAF; }
    .c-title-headArea__inner {
      position: relative;
      height: calc(100vw / ( 375 / 130 )); }
      @media screen and (min-width: 768px) {
        .c-title-headArea__inner {
          height: 194px; } }
.c-title-primary {
  position: relative;
  font-size: calc(100vw / ( 375 / 24 ));
  padding-left: calc(100vw / ( 375 / 16 ));
  margin-bottom: calc(100vw / ( 375 / 32 )); }
  @media screen and (min-width: 768px) {
    .c-title-primary {
      font-size: calc(100vw / ( 1440 / 32 ));
      margin-bottom: 1.5em;
      padding-left: 1em; } }
  @media screen and (min-width: 1441px) {
    .c-title-primary {
      font-size: 3.2rem; } }
  .c-title-primary:before, .c-title-primary:after {
    content: "";
    display: block;
    position: absolute;
    left: 0; }
  .c-title-primary:before {
    top: 0;
    height: 100%;
    width: 2px;
    background: #405174; }
  .c-title-primary:after {
    height: 1px;
    width: 100%;
    background: #E6E6E6;
    bottom: calc(-100vw / ( 375 / 8 )); }
    @media screen and (min-width: 768px) {
      .c-title-primary:after {
        bottom: -0.5em; } }
.c-title-secondary {
  position: relative;
  font-weight: 500;
  font-size: calc(100vw / ( 375 / 22 ));
  padding-left: 2.5em;
  margin-top: calc(100vw / ( 375 / 40 )); }
  @media screen and (min-width: 768px) {
    .c-title-secondary {
      font-size: calc(100vw / ( 1440 / 28 ));
      padding-left: calc(100vw / ( 1440 / 90 ));
      margin-top: calc(100vw / ( 1440 / 64 )); } }
  @media screen and (min-width: 1441px) {
    .c-title-secondary {
      font-size: 2.8rem;
      padding-left: 90px;
      margin-top: 64px; } }
  .c-title-secondary:before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0.5em;
    height: 2px;
    width: 2em;
    background: #8C8C8C; }
    @media screen and (min-width: 768px) {
      .c-title-secondary:before {
        width: calc(100vw / ( 1440 / 80 )); } }
    @media screen and (min-width: 1441px) {
      .c-title-secondary:before {
        width: 80px; } }
  .c-title-secondary + * {
    padding-top: calc(100vw / ( 375 / 28 )); }
    @media screen and (min-width: 768px) {
      .c-title-secondary + * {
        padding-top: calc(100vw / ( 1440 / 32 )); } }
    @media screen and (min-width: 1441px) {
      .c-title-secondary + * {
        padding-top: 32px; } }
.c-title-tertiary {
  font-weight: 500;
  position: relative;
  padding-top: 2em;
  font-size: calc(100vw / ( 375 / 20 )); }
  @media screen and (min-width: 768px) {
    .c-title-tertiary {
      font-size: calc(100vw / ( 1440 / 24 )); } }
  @media screen and (min-width: 1441px) {
    .c-title-tertiary {
      font-size: 2.4rem; } }
  .c-title-tertiary:before {
    content: "";
    display: block;
    height: 1px;
    width: 2em;
    background: #F56600;
    margin-bottom: 0.666em; }
  .c-title-tertiary + * {
    padding-top: calc(100vw / ( 375 / 28 )); }
    @media screen and (min-width: 768px) {
      .c-title-tertiary + * {
        padding-top: calc(100vw / ( 1440 / 32 )); } }
    @media screen and (min-width: 1441px) {
      .c-title-tertiary + * {
        padding-top: 32px; } }
.c-title-quaternary {
  font-weight: 500;
  background: #E0E3E9;
  padding: 0.8em 1.4em;
  margin-top: 1.6em;
  font-size: calc(100vw / ( 375 / 18 )); }
  @media screen and (min-width: 768px) {
    .c-title-quaternary {
      font-size: calc(100vw / ( 1440 / 20 )); } }
  @media screen and (min-width: 1441px) {
    .c-title-quaternary {
      font-size: 2.0rem; } }
  .c-title-quaternary + * {
    padding-top: calc(100vw / ( 375 / 28 )); }
    @media screen and (min-width: 768px) {
      .c-title-quaternary + * {
        padding-top: calc(100vw / ( 1440 / 32 )); } }
    @media screen and (min-width: 1441px) {
      .c-title-quaternary + * {
        padding-top: 32px; } }
.c-title-quinary {
  font-weight: 500;
  padding-top: 2em;
  font-size: calc(100vw / ( 375 / 18 )); }
  @media screen and (min-width: 768px) {
    .c-title-quinary {
      font-size: calc(100vw / ( 1440 / 20 )); } }
  @media screen and (min-width: 1441px) {
    .c-title-quinary {
      font-size: 2.0rem; } }
  .c-title-quinary + * {
    padding-top: calc(100vw / ( 375 / 28 )); }
    @media screen and (min-width: 768px) {
      .c-title-quinary + * {
        padding-top: calc(100vw / ( 1440 / 32 )); } }
    @media screen and (min-width: 1441px) {
      .c-title-quinary + * {
        padding-top: 32px; } }
.c-title-lead {
  color: #F56600;
  font-weight: 700;
  font-size: calc(100vw / ( 375 / 16 )); }
  @media screen and (min-width: 768px) {
    .c-title-lead {
      font-size: calc(100vw / ( 1440 / 24 )); } }
  @media screen and (min-width: 1441px) {
    .c-title-lead {
      font-size: 2.4rem; } }

#contents .c-title-primary:not(:first-child) {
  margin-top: calc(100vw / ( 375 / 40 )); }
  @media screen and (min-width: 768px) {
    #contents .c-title-primary:not(:first-child) {
      margin-top: calc(100vw / ( 1440 / 80 )); } }
  @media screen and (min-width: 1441px) {
    #contents .c-title-primary:not(:first-child) {
      margin-top: 80px; } }

/*========== c-list.scss ==========*/
.c-list-std__item {
  position: relative;
  padding-left: 1.25em;
  margin-bottom: 1em;
  line-height: 1.6; }
  .c-list-std__item:before {
    content: "■";
    display: block;
    position: absolute;
    left: 0;
    top: 0; }
.c-list-idt__item {
  position: relative;
  text-indent: -1em;
  margin-left: 1em;
  line-height: 1.4;
  margin-bottom: 1em; }
  .c-list-idt__item.forNote {
    color: #8C8C8C;
    font-size: 1.4rem; }
    @media screen and (max-width: 767px) {
      .c-list-idt__item.forNote {
        font-size: calc(100vw / ( 375 / 12 )); } }
.c-list-num__item {
  position: relative;
  padding-left: 1.75em;
  line-height: 1.6;
  margin-bottom: 1em; }
  .c-list-num__item .num {
    position: absolute;
    left: 0;
    top: 0; }

/*========== c-btn.scss ==========*/
.c-btn-std {
  cursor: pointer;
  display: inline-block;
  color: #fff;
  background: #F56600;
  border: 2px solid #F56600;
  font-weight: 700;
  padding: calc(100vw / ( 375 / 15 )) calc(100vw / ( 375 / 20 )) calc(100vw / ( 375 / 15 )) calc(100vw / ( 375 / 28 ));
  border-radius: calc(100vw / ( 375 / 50 )); }
  @media screen and (max-width: 767px) {
    .c-btn-std {
      display: flex;
      margin: auto;
      justify-content: center;
      width: calc(100vw / ( 375 / 260 )); } }
  @media screen and (min-width: 768px) {
    .c-btn-std {
      border-radius: calc(100vw / ( 1440 / 50 ));
      padding: calc(100vw / ( 1440 / 18 )) calc(100vw / ( 1440 / 35 )) calc(100vw / ( 1440 / 18 )) calc(100vw / ( 1440 / 30 )); } }
  @media screen and (min-width: 1441px) {
    .c-btn-std {
      border-radius: 50px;
      padding: 18px 35px 18px 30px; } }
  .c-btn-std .in {
    display: flex;
    align-items: center; }
    .c-btn-std .in:after {
      content: "";
      display: inline-block;
      width: 0.6em;
      height: 1em;
      background: url("../images/icon_arrow.svg") center no-repeat;
      background-size: contain;
      margin-left: 0.5em; }
    .c-btn-std .in.down:after {
      width: 1em;
      height: 0.6em;
      background-image: url("../images/icon_down.svg"); }
    .c-btn-std .in.blank:after {
      width: 1em;
      height: 1em;
      background-image: url("../images/icon_blank_white.svg"); }
  .c-btn-std.gr {
    background: #23A232;
    border-color: #23A232; }
  .c-btn-std.grBD {
    background: #fff;
    border-color: #23A232;
    color: #23A232; }
    .c-btn-std.grBD .in:after {
      background-image: url("../images/icon_down_gr.svg"); }
  .c-btn-std.noBG {
    background: #fff;
    color: #F56600; }
    .c-btn-std.noBG .in.down:after {
      background-image: url("../images/icon_down_or.svg"); }
  .c-btn-stdWrap {
    display: flex; }
    .c-btn-stdWrap.center {
      justify-content: center;
      margin-top: 1.5em;
     }

/*========== c-table.scss ==========*/
.c-table-std {
  border-collapse: collapse;
  width: 100%;
  border-top: 1px solid #8D8D8D;
  border-left: 1px solid #8D8D8D; }
  .c-table-std th, .c-table-std td {
    border-collapse: collapse;
    border-bottom: 1px solid #8D8D8D;
    border-right: 1px solid #8D8D8D;
    line-height: 1.4;
    padding: 10px 15px; }
    @media screen and (max-width: 767px) {
      .c-table-std th, .c-table-std td {
        display: block;
        padding: calc(100vw / ( 375 / 6 )) calc(100vw / ( 375 / 15 ));
        line-height: 180%; } }
  .c-table-std tbody th {
    background: #ECF6ED;
    color: #208C30;
    font-weight: 700;
    vertical-align: middle; }
  .c-table-std tbody td .note {
    font-size: calc(100vw / ( 375 / 14 )); }
    @media screen and (min-width: 768px) {
      .c-table-std tbody td .note {
        font-size: 1.4rem; } }

/*========== p-kv.scss ==========*/
.p-kv {
  background: url("../images/kv_bg_sp.webp") center no-repeat;
  background-size: cover;
  opacity: 0;
  transform: scale(1.05); }
  @media screen and (min-width: 768px) {
    .p-kv {
      background-image: url("../images/kv_bg.webp"); } }
  .p-kv:after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.32); }
  .p-kv__inner {
    position: relative;
    height: 100vh; }
    @media screen and (max-width: 767px) {
      .p-kv__inner {
        padding-left: 0;
        padding-right: 0; } }
  .p-kv-lead {
    opacity: 0;
    position: absolute;
    color: #fff;
    line-height: 180%;
    text-shadow: 2px 2px 2px rgba(0, 0, 0, 0.16);
    white-space: nowrap;
    z-index: 1;
    text-align: left;
    font-size: calc(100vw / ( 375 / 24 )); }
    @media screen and (max-width: 767px) {
      .p-kv-lead {
        left: 50%;
        top: 50%;
        transform: translateX(-50%); } }
    @media screen and (min-width: 768px) {
      .p-kv-lead {
        left: calc(100vw / ( 1440 / 128 ));
        bottom: calc(100vh / ( 810 / 128 ));
        font-size: calc(100vw / ( 1440 / 40 )); } }
    @media screen and (min-width: 1441px) {
      .p-kv-lead {
        left: 128px;
        font-size: 4.0rem; } }
  .p-kv-scroll {
    opacity: 0;
    z-index: 1;
    position: absolute;
    left: 50%;
    bottom: 30px; }
    .p-kv-scroll:before {
      animation: scroll 2s infinite;
      background-color: #000;
      bottom: -30px;
      content: "";
      height: 80px;
      right: -8px;
      margin: auto;
      position: absolute;
      width: 1px;
      z-index: 2; }
    .p-kv-scroll:after {
      background-color: #ccc;
      bottom: -30px;
      content: "";
      height: 80px;
      right: -8px;
      margin: auto;
      position: absolute;
      width: 1px; }
    .p-kv-scroll .forTxt {
      display: block;
      height: 49px; }
      .p-kv-scroll .forTxt img {
        width: auto;
        height: 100%; }
  .p-kv.loadEnd {
    animation: loading 2.5s linear forwards; }
    .p-kv.loadEnd .p-kv-lead, .p-kv.loadEnd .p-kv-scroll {
      animation: showItem 1.5s 2.5s linear forwards; }

@keyframes loading {
  0% {
    opacity: 0;
    transform: scale(1.05); }
  100% {
    opacity: 1;
    transform: scale(1); } }
@keyframes showItem {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
@keyframes scroll {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0; }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0; }
  51% {
    transform: scale(1, 1);
    transform-origin: 0 100%; }
  100% {
    transform: scale(1, 1);
    transform-origin: 0 100%; } }
/*========== p-nav.scss ==========*/
.p-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-left: 25px; }
  @media screen and (min-width: 768px) {
    .p-nav {
      height: 98px; } }
  @media screen and (max-width: 767px) {
    .p-nav {
      padding-left: 12px; } }
  @media screen and (max-width: 767px) {
    .p-nav_L {
      height: calc(100vw / ( 375 / 60 ));
      display: flex;
      align-items: center; } }
  @media screen and (min-width: 768px) {
    .p-nav_L {
      width: 24em; } }
  @media screen and (min-width: 768px) and (max-width: 1210px) {
    .p-nav_L {
      width: 15em; } }
  .p-nav_R {
    display: flex;
    align-items: center; }
    @media screen and (min-width: 768px) {
      .p-nav_R {
        justify-content: flex-end;
        width: calc(100% - 24em - 25px); } }
    @media screen and (min-width: 768px) and (max-width: 1210px) {
      .p-nav_R {
        width: calc(100% - 15em - 25px); } }
    @media screen and (max-width: 767px) {
      .p-nav_R {
        margin-right: calc(100vw / ( 375 / 60 )); } }
  .p-nav-logo {
    font-weight: 700; }
    @media screen and (min-width: 768px) {
      .p-nav-logo {
        margin-right: 1em; } }
    .p-nav-logo a {
      display: flex;
      flex-direction: column; }
    .p-nav-logo .kenwood {
      color: #fff;
      background: #208C30;
      border-radius: 2px;
      width: 12em;
      text-align: center;
      font-size: calc(100vw / ( 375 / 7 ));
      height: calc(100vw / ( 375 / 14 ));
      line-height: calc(100vw / ( 375 / 14 )); }
      @media screen and (min-width: 768px) {
        .p-nav-logo .kenwood {
          font-size: 1.4rem;
          height: 25px;
          line-height: 25px; } }
    .p-nav-logo .title {
      font-size: calc(100vw / ( 375 / 12.5 ));
      padding-top: 0.2em; }
      @media screen and (max-width: 767px) {
        .p-nav-logo .title {
          line-height: 132%; } }
      @media screen and (min-width: 768px) {
        .p-nav-logo .title {
          font-size: 1.8rem;
          letter-spacing: 0.01em;
          padding-top: 13px; } }
      @media screen and (min-width: 768px) and (max-width: 1210px) {
        .p-nav-logo .title br.noPC {
          display: block !important; } }
  @media screen and (min-width: 768px) {
    .p-nav-items {
      display: flex;
      align-items: center;
      justify-content: flex-end; }
      .p-nav-items:not(:last-child) {
        margin-bottom: 18px; } }
  .p-nav-items .item {
    font-size: 1.4rem; }
    @media screen and (max-width: 767px) {
      .p-nav-items .item {
        font-size: calc(100vw / ( 375 / 18 )); } }
    @media screen and (max-width: 767px) {
      .p-nav-items .item:first-child a {
        border-top: 1px solid #fff; } }
    @media screen and (min-width: 768px) {
      .p-nav-items .item:not(:last-child) {
        margin-right: 1.0em; } }
    .p-nav-items .item a {
      font-weight: 700; }
      @media screen and (max-width: 767px) {
        .p-nav-items .item a {
          display: block;
          color: #fff;
          position: relative;
          border-bottom: 1px solid #fff;
          padding: calc(100vw / ( 375 / 20 )) 0;
          font-size: calc(100vw / ( 375 / 18 )); }
          .p-nav-items .item a:after {
            content: "";
            display: block;
            position: absolute;
            right: 0;
            top: 50%;
            transform: translateY(-50%);
            width: calc(100vw / ( 375 / 8 ));
            height: calc(100vw / ( 375 / 13 ));
            background: url("../images/icon_arrow.svg") right center no-repeat;
            background-size: contain; } }
      @media screen and (min-width: 768px) {
        .p-nav-items .item a {
          display: inline-block;
          font-size: 1.5rem;
          padding-right: 1.0em;
          position: relative; }
          .p-nav-items .item a:after {
            content: "";
            display: block;
            position: absolute;
            right: 0;
            top: 50%;
            transform: translateY(-50%);
            width: 11px;
            height: 11px;
            background: url("../images/icon_down_or.svg") center no-repeat;
            background-size: contain; } }
      @media screen and (max-width: 767px) {
        .p-nav-items .item a.toHome {
          border: none;
          background: #fff;
          color: #208C30;
          border-radius: 10px;
          text-align: center; } }
      @media screen and (min-width: 768px) {
        .p-nav-items .item a.toHome {
          font-size: 1.2rem; } }
      @media screen and (min-width: 768px) {
        .p-nav-items .item a.toHome:after {
          background-image: url("../images/icon_down_gr.svg"); } }
      @media screen and (max-width: 767px) {
        .p-nav-items .item a.toHome .in {
          display: inline-block;
          position: relative;
          padding-right: 1em; }
          .p-nav-items .item a.toHome .in:after {
            content: "";
            display: block;
            position: absolute;
            right: 0;
            top: 50%;
            transform: translateY(-50%);
            width: calc(100vw / ( 375 / 8 ));
            height: calc(100vw / ( 375 / 14 ));
            background: url("../images/icon_down_gr.svg") right center no-repeat;
            background-size: contain; } }
      @media screen and (min-width: 768px) {
        .p-nav-items .item a.toPage:after {
          transform: rotate(-90deg) translateX(50%); } }
      @media screen and (min-width: 768px) {
        .p-nav-items .item a.current {
          padding-right: 0;
          color: #F56600; }
          .p-nav-items .item a.current:after {
            display: none; }
          .p-nav-items .item a.current:before {
            content: "";
            display: block;
            position: absolute;
            left: 50%;
            bottom: -11px;
            transform: translateX(-50%);
            width: 11px;
            height: 11px;
            background: url("../images/icon_down_or.svg") center no-repeat;
            background-size: contain; } }
  @media screen and (min-width: 768px) {
    .p-nav-type {
      display: flex;
      flex-direction: column;
      width: 114px; } }
  .p-nav-type__item a {
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    font-weight: 700;
    height: calc(100vw / ( 375 / 60 ));
    font-size: 12px;
    padding: 0 8px; }
    @media screen and (min-width: 768px) {
      .p-nav-type__item a {
        height: 98px;
        font-size: 1.2rem; } }
  .p-nav-type__item.forDL {
    background: #F56600; }
    @media screen and (max-width: 767px) {
      .p-nav-type__item.forDL {
        display: none; } }
  .p-nav-type__item.forMedia {
    background: #23A232; }
    .p-nav-type__item.forMedia .in {
      position: relative;
      display: inline-block; }
      @media screen and (min-width: 768px) {
        .p-nav-type__item.forMedia .in {
          padding-right: 22px; } }
      .p-nav-type__item.forMedia .in:before {
        content: "";
        display: block;
        background: url("../images/icon_blank_white.svg") center no-repeat;
        background-size: contain; }
        @media screen and (max-width: 767px) {
          .p-nav-type__item.forMedia .in:before {
            width: 1em;
            height: 1em;
            margin: 0 auto 3px; } }
        @media screen and (min-width: 768px) {
          .p-nav-type__item.forMedia .in:before {
            position: absolute;
            right: 0;
            top: 50%;
            transform: translateY(-50%);
            width: 16px;
            height: 16px; } }
  .p-nav-anc {
    padding: calc(100vw / ( 375 / 50 )) 0; }
    @media screen and (min-width: 768px) {
      .p-nav-anc {
        padding: calc(100vw / ( 1440 / 50 )) 0; } }
    @media screen and (min-width: 1441px) {
      .p-nav-anc {
        padding: 50px 0; } }
    @media screen and (max-width: 767px) {
      .p-nav-anc__inner {
        padding: 0 calc(100vw / ( 375 / 5 )); } }
    .p-nav-anc_items {
      display: flex;
      flex-wrap: wrap; }
      @media screen and (max-width: 767px) {
        .p-nav-anc_items {
          flex-direction: column;
          margin-bottom: calc(100vw / ( 375 / 20 )); } }
      .p-nav-anc_items__item {
        display: flex; }
        @media screen and (min-width: 768px) {
          .p-nav-anc_items__item {
            width: 31.25%;
            margin-bottom: 15px; }
            .p-nav-anc_items__item:not(:nth-child(3n)) {
              margin-right: 3.125%; } }
        @media screen and (max-width: 767px) {
          .p-nav-anc_items__item:not(:last-child) {
            margin-bottom: calc(100vw / ( 375 / 15 )); } }
        .p-nav-anc_items__item a {
          display: flex;
          align-items: center;
          width: 100%;
          color: #F56600;
          border: 2px solid #F56600;
          border-radius: 5px;
          padding: 1em;
          position: relative;
          font-weight: 700;
          padding-right: 3em; }
          .p-nav-anc_items__item a:after {
            content: "";
            display: block;
            position: absolute;
            top: 50%;
            transform: translateY(-50%);
            background: url("../images/icon_down_or.svg") center no-repeat;
            background-size: contain;
            right: 1em;
            width: 1.15em;
            height: 0.6em; }
          .p-nav-anc_items__item a:hover {
            color: #fff;
            background: #F56600;
            opacity: 1; }
            .p-nav-anc_items__item a:hover:after {
              background-image: url("../images/icon_down.svg"); }
  .p-nav .burger {
    width: calc(100vw / ( 375 / 20 ));
    height: 100%;
    display: flex;
    align-items: center;
    z-index: 9999;
    cursor: pointer;
    margin: auto; }
    .p-nav .burger--wrap {
      background: #F56600;
      height: 100%;
      z-index: 9999;
      position: absolute;
      right: 0;
      top: 0;
      display: block;
      width: calc(100vw / ( 375 / 60 ));
      height: calc(100vw / ( 375 / 60 )); }
      @media screen and (min-width: 768px) {
        .p-nav .burger--wrap {
          display: none; } }
    .p-nav .burger:before, .p-nav .burger:after {
      content: "";
      position: absolute;
      width: calc(100vw / ( 375 / 20 ));
      height: calc(100vw / ( 375 / 4 ));
      right: calc(100vw / ( 375 / 20 ));
      background: #fff; }
    .p-nav .burger:before {
      top: calc(100vw / ( 375 / 19 )); }
    .p-nav .burger:after {
      bottom: calc(100vw / ( 375 / 19 )); }
    .p-nav .burger-active:before {
      transform: rotate(45deg);
      top: 0;
      bottom: 0;
      margin: auto; }
    .p-nav .burger-active:after {
      transform: rotate(-45deg);
      top: 0;
      bottom: 0;
      margin: auto; }
    .p-nav .burger-active > .line {
      transform: scale(0); }
    .p-nav .burger .line {
      width: 100%;
      height: calc(100vw / ( 375 / 4 ));
      background: #fff; }
  @media screen and (max-width: 767px) {
    .p-nav .navigation {
      opacity: 0.0;
      top: 0;
      z-index: -1;
      width: 0;
      position: fixed;
      transition: 0.3s;
      -webkit-overflow-scrolling: touch;
      background-color: #208C30;
      right: 0;
      height: 0;
      width: 100vw; } }
  @media screen and (min-width: 768px) {
    .p-nav .navigation {
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      margin-right: 15px; } }
  @media screen and (max-width: 767px) {
    .p-nav .navigation--content {
      position: relative;
      right: -100vw;
      top: calc(100vw / ( 375 / 60 ));
      height: calc(100svh - calc(100vw / ( 375 / 60 )));
      background: rgba(32, 140, 48, 0.96);
      padding: calc(100vw / ( 375 / 30 )) calc(100vw / ( 375 / 26 ));
      display: flex;
      flex-direction: column-reverse;
      justify-content: space-between;
      overflow-y: scroll; } }
  @media screen and (max-width: 767px) {
    .p-nav .navigation.nav-active {
      opacity: 1.0;
      z-index: 9998;
      width: 100vw; }
      .p-nav .navigation.nav-active .navigation--content {
        right: 0; } }

/*========== p-contact.scss ==========*/
.p-contact {
  background: url("../images/top/contact_bg_sp.jpg") center no-repeat;
  background-size: cover;
  position: relative;
  padding: calc(100vw / ( 375 / 60 )) 0; }
  @media screen and (min-width: 768px) {
    .p-contact {
      background-image: url("../images/top/contact_bg.jpg");
      padding: calc(100vw / ( 1440 / 80 )) 0; } }
  @media screen and (min-width: 1441px) {
    .p-contact {
      padding: 80px 0; } }
  .p-contact:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(35, 162, 50, 0.7); }
  @media screen and (min-width: 768px) {
    .p-contact__inner {
      display: flex;
      justify-content: space-between; } }
  @media screen and (max-width: 767px) {
    .p-contact-L {
      margin-bottom: calc(100vw / ( 375 / 40 )); } }
  @media screen and (min-width: 768px) {
    .p-contact-L {
      width: 34.465%; } }
  .p-contact-L .forTtl {
    color: #fff;
    margin-bottom: calc(100vw / ( 375 / 25 )); }
    @media screen and (min-width: 768px) {
      .p-contact-L .forTtl {
        text-align: left;
        margin-bottom: calc(100vw / ( 1440 / 44 )); } }
    @media screen and (min-width: 1441px) {
      .p-contact-L .forTtl {
        margin-bottom: 44px; } }
    @media screen and (max-width: 767px) {
      .p-contact-L .forTtl .eng {
        font-size: calc(100vw / ( 375 / 16 ));
        padding-top: 0.5em; } }
  .p-contact-L .forTxt {
    color: #fff;
    font-weight: 700;
    letter-spacing: 0.02em;
    text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.35);
    line-height: 160%; }
    @media screen and (max-width: 767px) {
      .p-contact-L .forTxt {
        text-align: center;
        font-size: calc(100vw / ( 375 / 16 ));
        margin-bottom: calc(100vw / ( 375 / 14 )); } }
    @media screen and (min-width: 768px) {
      .p-contact-L .forTxt {
        font-size: 1.8rem;
        margin-bottom: calc(100vw / ( 1440 / 20 )); } }
    @media screen and (min-width: 1441px) {
      .p-contact-L .forTxt {
        margin-bottom: 33px; } }
  @media screen and (min-width: 768px) {
    .p-contact-R {
      width: 65.535%; } }
  .p-contact-R__sec {
    background: #fff;
    border-radius: calc(100vw / ( 375 / 10 ));
    padding: calc(100vw / ( 375 / 25 )) calc(100vw / ( 375 / 20 )) calc(100vw / ( 375 / 30 )); }
    @media screen and (min-width: 768px) {
      .p-contact-R__sec {
        border-radius: 10px;
        padding: calc(100vw / ( 1440 / 27 )) calc(100vw / ( 1440 / 30 )) calc(100vw / ( 1440 / 36 )); } }
    @media screen and (min-width: 1441px) {
      .p-contact-R__sec {
        padding: 27px 40px 36px; } }
    .p-contact-R__sec:not(:last-child) {
      margin-bottom: calc(100vw / ( 375 / 20 )); }
      @media screen and (min-width: 768px) {
        .p-contact-R__sec:not(:last-child) {
          margin-bottom: calc(100vw / ( 1440 / 30 )); } }
      @media screen and (min-width: 1441px) {
        .p-contact-R__sec:not(:last-child) {
          margin-bottom: 30px; } }
  .p-contact-R .forTtl {
    color: #208C30;
    font-weight: 700;
    line-height: 150%;
    font-size: calc(100vw / ( 375 / 20 ));
    margin-bottom: calc(100vw / ( 375 / 14 )); }
    @media screen and (min-width: 768px) {
      .p-contact-R .forTtl {
        text-align: center;
        font-size: 1.8rem;
        margin-bottom: 18px; } }
  .p-contact-R .forSubttl {
    background: #F56600;
    color: #fff;
    font-weight: 700;
    border-radius: 3px;
    line-height: 140%;
    padding: calc(100vw / ( 375 / 5 )) calc(100vw / ( 375 / 10 ));
    margin-bottom: calc(100vw / ( 375 / 23 )); }
    @media screen and (max-width: 767px) {
      .p-contact-R .forSubttl {
        font-size: calc(100vw / ( 375 / 16 )); } }
    @media screen and (min-width: 768px) {
      .p-contact-R .forSubttl {
        text-align: center;
        padding: 5px 10px;
        margin-bottom: 16px; } }
  @media screen and (min-width: 768px) {
    .p-contact-R .forBy {
      display: flex;
      flex-wrap: wrap; } }
  .p-contact-R .forBy + .forBy_hour {
    padding-top: 1em; }
  @media screen and (min-width: 768px) {
    .p-contact-R .forBy-in {
      width: 50%; } }
  @media screen and (max-width: 767px) {
    .p-contact-R .forBy-in:first-child {
      margin-bottom: calc(100vw / ( 375 / 15 )); } }
  @media screen and (min-width: 768px) {
    .p-contact-R .forBy-in:first-child {
      border-right: 1px solid #D1D1D1;
      padding-right: calc(100vw / ( 1440 / 25 )); } }
  @media screen and (min-width: 1441px) {
    .p-contact-R .forBy-in:first-child {
      padding-right: 25px; } }
  @media screen and (min-width: 768px) {
    .p-contact-R .forBy-in:last-child {
      padding-left: calc(100vw / ( 1440 / 25 )); } }
  @media screen and (min-width: 1441px) {
    .p-contact-R .forBy-in:last-child {
      padding-left: 25px; } }
  @media screen and (max-width: 767px) {
    .p-contact-R .forBy-in.phone {
      margin-bottom: calc(100vw / ( 375 / 25 )); } }
  @media screen and (min-width: 768px) {
    .p-contact-R .forBy-in.phone {
      width: 54%;
      padding-right: calc(100vw / ( 1440 / 40 )); } }
  @media screen and (min-width: 1441px) {
    .p-contact-R .forBy-in.phone {
      padding-right: 40px; } }
  @media screen and (min-width: 768px) {
    .p-contact-R .forBy-in.mail {
      width: 46%; } }
  @media screen and (min-width: 1441px) {
    .p-contact-R .forBy-in.mail {
      padding-left: 35px; } }
  @media screen and (max-width: 767px) {
    .p-contact-R .forBy-in.mail .forBy_ttl {
      display: none; } }
  .p-contact-R .forBy_ttl {
    font-weight: 700;
    line-height: 150%; }
    @media screen and (max-width: 767px) {
      .p-contact-R .forBy_ttl {
        font-size: calc(100vw / ( 375 / 16 )); } }
  .p-contact-R .forBy_tel {
    font-family: "Outfit", sans-serif;
    font-weight: 600;
    letter-spacing: 0.03em;
    line-height: 1.25;
    font-size: calc(100vw / ( 375 / 44 )); }
    @media screen and (min-width: 768px) {
      .p-contact-R .forBy_tel {
        font-size: 4.4rem; } }
  .p-contact-R .forBy_hour {
    line-height: 180%;
    margin-bottom: 0.5em; }
    @media screen and (min-width: 768px) {
      .p-contact-R .forBy_hour {
        font-size: 1.5rem; } }
  .p-contact-R .forBy_notes__item {
    color: #6D6D6D;
    line-height: 180%;
    font-size: calc(100vw / ( 375 / 14 )); }
    @media screen and (min-width: 768px) {
      .p-contact-R .forBy_notes__item {
        font-size: 1.4rem; } }
  @media screen and (min-width: 768px) {
    .p-contact-R .forBy_btn {
      margin-top: calc(100vw / ( 1440 / 26 )); } }
  @media screen and (min-width: 1441px) {
    .p-contact-R .forBy_btn {
      margin-top: 26px; } }
  .p-contact-R .forBy_btn .c-btn-std {
    display: block;
    width: 100%; }
    .p-contact-R .forBy_btn .c-btn-std .in {
      justify-content: center; }

/*========== p-footer.scss ==========*/
.p-footer-nav {
  margin-bottom: calc(100vw / ( 375 / 10 )); }
  @media screen and (min-width: 768px) {
    .p-footer-nav {
      margin-bottom: calc(100vw / ( 1440 / 24 )); } }
  @media screen and (min-width: 1441px) {
    .p-footer-nav {
      margin-bottom: 24px; } }
  .p-footer-nav .items {
    display: flex;
    justify-content: center; }
    @media screen and (max-width: 767px) {
      .p-footer-nav .items {
        flex-wrap: wrap; } }
    @media screen and (max-width: 767px) {
      .p-footer-nav .items .item {
        width: 50%;
        margin-bottom: 1.5em; } }
    @media screen and (min-width: 768px) {
      .p-footer-nav .items .item {
        margin: 0 .75em; } }
    .p-footer-nav .items .item a {
      color: #fff;
      text-decoration: underline;
      font-size: 1.4rem; }
      @media screen and (max-width: 767px) {
        .p-footer-nav .items .item a {
          font-size: calc(100vw / ( 375 / 13 )); } }
.p-footer-copy {
  display: block;
  text-align: center;
  color: #fff;
  font-size: 1.4rem; }
  @media screen and (max-width: 767px) {
    .p-footer-copy {
      font-size: calc(100vw / ( 375 / 12 )); } }
.p-footer-buyBtn {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  background: #F56600;
  font-weight: 700; }
  @media screen and (min-width: 768px) {
    .p-footer-buyBtn {
      writing-mode: vertical-rl;
      font-size: 2.0rem;
      letter-spacing: 0.1em;
      padding: 17px 0; } }
  @media screen and (max-width: 767px) {
    .p-footer-buyBtn {
      border-radius: 10px;
      font-size: calc(100vw / ( 375 / 18 ));
      height: calc(100vw / ( 375 / 56 )); } }
  .p-footer-buyBtnWrap {
    position: fixed;
    z-index: 50;
    left: 0; }
    @media screen and (min-width: 768px) {
      .p-footer-buyBtnWrap {
        top: 50%;
        transform: translateY(-50%);
        border-radius: 0px 10px 10px 0px;
        overflow: hidden; } }
    @media screen and (max-width: 767px) {
      .p-footer-buyBtnWrap {
        width: 100%;
        bottom: 0;
        background: rgba(31, 31, 31, 0.87);
        padding: calc(100vw / ( 375 / 15 ));
        height: calc(100vw / ( 375 / 86 )); } }
  .p-footer-buyBtn .in {
    display: inline-block;
    position: relative; }
    @media screen and (min-width: 768px) {
      .p-footer-buyBtn .in {
        display: flex;
        align-items: center;
        padding-top: 32px;
        width: 58px; } }
    @media screen and (max-width: 767px) {
      .p-footer-buyBtn .in {
        padding-left: calc(100vw / ( 375 / 31 )); } }
    .p-footer-buyBtn .in:before {
      content: "";
      display: block;
      position: absolute;
      background: url("../images/icon_cart.svg") center no-repeat;
      background-size: contain; }
      @media screen and (min-width: 768px) {
        .p-footer-buyBtn .in:before {
          top: 0;
          left: 50%;
          transform: translateX(-50%);
          width: 29px;
          height: 29px; } }
      @media screen and (max-width: 767px) {
        .p-footer-buyBtn .in:before {
          left: 0;
          top: 50%;
          transform: translateY(-50%);
          width: calc(100vw / ( 375 / 25 ));
          height: calc(100vw / ( 375 / 25 )); } }

.tooltip {
  /* 各方向ごとの矢印 */ }
  .tooltip-trigger {
    color: #F56600;
    text-decoration: underline;
    position: relative;
    padding-right: 1.8em;
    cursor: pointer;
    display: inline-block; }
    .tooltip-trigger:after {
      content: "";
      display: block;
      position: absolute;
      right: 0;
      top: 50%;
      transform: translateY(-50%);
      width: 1.6em;
      height: 1.6em;
      background: url("../images/icon_question.svg") center no-repeat;
      background-size: contain; }
  .tooltip-box {
    display: none;
    z-index: 1000; }
    @media screen and (min-width: 768px) {
      .tooltip-box {
        position: absolute;
        width: 402px;
        max-width: 95vw;
        background: #fff;
        border: 2px solid #23A232;
        padding: 20px;
        border-radius: 10px; } }
    @media screen and (max-width: 767px) {
      .tooltip-box {
        position: fixed !important;
        top: 60px !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        width: calc(100vw / ( 375 / 335 ));
        height: auto;
        max-height: calc(100svh - 60px);
        overflow-y: auto;
        padding: calc(100vw / ( 375 / 50 )) 0; } }
    .tooltip-box:after {
      content: "";
      position: absolute;
      width: 12px;
      height: 19px;
      background: url("../images/tooltip_before.png") center no-repeat;
      background-size: contain; }
      @media screen and (max-width: 767px) {
        .tooltip-box:after {
          display: none; } }
  .tooltip-top:after {
    bottom: 55px; }
  .tooltip-bottom:after {
    top: 55px; }
  .tooltip-left:after {
    right: -12px;
    transform: rotate(180deg); }
  .tooltip-right:after {
    left: -12px; }
  @media screen and (max-width: 767px) {
    .tooltip-overlay {
      position: fixed;
      inset: 0;
      background: rgba(32, 140, 48, 0.9);
      z-index: 999;
      display: none;
      top: 60px;
      height: calc(100svh - 60px); } }
  @media screen and (max-width: 767px) {
    .tooltip-content {
      background: #fff;
      border: 1px solid #208C30;
      border-radius: calc(100vw / ( 375 / 10 ));
      padding: calc(100vw / ( 375 / 25 )) calc(100vw / ( 375 / 20 ));
      margin: calc(100vw / ( 375 / 15 )) 0; } }

.js-tooltip-close {
  color: #fff;
  border: 1px solid #fff;
  font-weight: 700;
  font-size: calc(100vw / ( 375 / 13 ));
  border-radius: calc(100vw / ( 375 / 50 ));
  width: calc(100vw / ( 375 / 90 ));
  height: calc(100vw / ( 375 / 28 ));
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center; }
  .js-tooltip-close .in {
    display: inline-block;
    position: relative;
    padding-right: calc(100vw / ( 375 / 15 )); }
    .js-tooltip-close .in:after {
      content: "";
      display: block;
      position: absolute;
      right: 0;
      top: 50%;
      transform: translateY(-50%);
      width: calc(100vw / ( 375 / 12 ));
      height: calc(100vw / ( 375 / 12 ));
      background: url("../images/icon_close.svg") center no-repeat;
      background-size: contain; }

/*========== p-top.scss ==========*/
.p-top-main {
  position: relative; }
  @media screen and (max-width: 767px) {
    .p-top-main {
      background: url("../images/top/main_bg_sp.png") center no-repeat;
      background-size: cover;
      padding: calc(100vw / ( 375 / 35 )) 0 calc(100vw / ( 375 / 40 )); } }
  @media screen and (min-width: 768px) {
    .p-top-main:before, .p-top-main:after {
      content: "";
      display: block;
      position: absolute;
      height: 100%;
      top: 0; } }
  @media screen and (min-width: 768px) {
    .p-top-main:before {
      width: calc(100vw / ( 1440 / 666 ));
      background: url("../images/top/main_bg_l.png") center no-repeat;
      background-size: cover;
      left: 0; } }
  @media screen and (min-width: 1441px) {
    .p-top-main:before {
      width: calc(((100% - 1120px) / 2) + 506px); } }
  @media screen and (min-width: 768px) {
    .p-top-main:after {
      width: calc(100vw / ( 1440 / 774 ));
      background: url("../images/top/main_bg_r.jpg") center no-repeat;
      background-size: cover;
      right: 0; } }
  @media screen and (min-width: 1441px) {
    .p-top-main:after {
      width: calc(((100% - 1120px) / 2) + 614px); } }
  @media screen and (min-width: 768px) {
    .p-top-main__inner {
      width: 45%;
      padding: calc(100vw / ( 1440 / 50 )) 0; } }
  @media screen and (min-width: 1441px) {
    .p-top-main__inner {
      width: 506px;
      padding: 50px 0; } }
  .p-top-main__inner .forTtl .kenwood {
    display: inline-block;
    line-height: 1;
    color: #fff;
    background: #208C30;
    border-radius: 3px;
    font-size: calc(100vw / ( 375 / 18 ));
    padding: calc(100vw / ( 375 / 7 )) calc(100vw / ( 375 / 10 ));
    margin-bottom: calc(100vw / ( 375 / 10 )); }
    @media screen and (min-width: 768px) {
      .p-top-main__inner .forTtl .kenwood {
        padding: 8px 12px;
        margin-bottom: 15px;
        font-size: 2.1rem; } }
  .p-top-main__inner .forTtl .title {
    letter-spacing: 0.01em;
    display: block;
    font-weight: 700;
    line-height: 130%;
    font-size: calc(100vw / ( 375 / 30 )); }
    @media screen and (min-width: 768px) {
      .p-top-main__inner .forTtl .title {
        font-size: 4.0rem; } }
  .p-top-main__inner .forImg {
    margin: calc(100vw / ( 375 / 25 )) calc(-100vw / ( 375 / 15 ));
    padding-left: calc(100vw / ( 375 / 20 )); }
    @media screen and (min-width: 768px) {
      .p-top-main__inner .forImg {
        display: none; } }
  .p-top-main__inner .forTxt {
    line-height: 180%;
    letter-spacing: 0.01em; }
    @media screen and (max-width: 767px) {
      .p-top-main__inner .forTxt {
        margin-right: -1em;
        margin-bottom: calc(100vw / ( 375 / 20 )); } }
    @media screen and (min-width: 768px) {
      .p-top-main__inner .forTxt {
        font-size: 1.7rem;
        margin: 22px 0; } }
    .p-top-main__inner .forTxt .att {
      color: #F56600;
      font-weight: 700; }
.p-top-news {
  padding: calc(100vw / ( 375 / 50 )) 0 0; }
  @media screen and (min-width: 768px) {
    .p-top-news {
      padding: calc(100vw / ( 1440 / 81 )) 0 calc(100vw / ( 1440 / 68 )); } }
  @media screen and (min-width: 1441px) {
    .p-top-news {
      padding: 81px 0 68px; } }
  @media screen and (max-width: 767px) {
    .p-top-news__inner {
      padding-bottom: calc(100vw / ( 375 / 50 )); } }
  @media screen and (min-width: 768px) {
    .p-top-news__inner {
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between; } }
  .p-top-news_ttl {
    font-weight: 700; }
    @media screen and (max-width: 767px) {
      .p-top-news_ttl {
        margin-bottom: calc(100vw / ( 375 / 40 )); } }
    @media screen and (min-width: 768px) {
      .p-top-news_ttl {
        text-align: left;
        width: 26.16072%; } }
    .p-top-news_ttl .eng {
      font-family: "Outfit", sans-serif;
      color: #208C30;
      letter-spacing: 0.08em;
      font-size: calc(100vw / ( 375 / 45 )); }
      @media screen and (min-width: 768px) {
        .p-top-news_ttl .eng {
          font-size: 4.5rem; } }
    .p-top-news_ttl .wa {
      display: block;
      padding-top: 0.5em; }
      @media screen and (max-width: 767px) {
        .p-top-news_ttl .wa {
          font-size: calc(100vw / ( 375 / 16 )); } }
  @media screen and (min-width: 768px) {
    .p-top-news_posts {
      width: 73.83928%; } }
  .p-top-news_posts .items {
    position: relative;
    padding-bottom: 3em; }
    .p-top-news_posts .items:after {
      content: "";
      display: block;
      position: absolute;
      left: 0;
      bottom: 0;
      width: 100%;
      height: 40%;
      background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, white 80%); }
    .p-top-news_posts .items.no-hide:after {
      display: none; }
    .p-top-news_posts .items .item:not(:first-child) {
      margin-top: calc(100vw / ( 375 / 20 )); }
      @media screen and (min-width: 768px) {
        .p-top-news_posts .items .item:not(:first-child) {
          margin-top: 20px; } }
    .p-top-news_posts .items .item .forDate {
      display: inline-block;
      border: 1px solid #F56600;
      color: #F56600;
      font-family: "Outfit", sans-serif;
      font-weight: 600;
      letter-spacing: 0.09em;
      border-radius: 2px;
      margin-bottom: calc(100vw / ( 375 / 12 ));
      font-size: calc(100vw / ( 375 / 14 ));
      padding: calc(100vw / ( 375 / 5 )) calc(100vw / ( 375 / 12 )); }
      @media screen and (min-width: 768px) {
        .p-top-news_posts .items .item .forDate {
          font-size: 1.5rem;
          padding: 6px 15px;
          margin-bottom: 0.8em; } }
    .p-top-news_posts .items .item .forTxt {
      line-height: 180%; }
.p-top-products {
  position: relative; }
  @media screen and (max-width: 767px) {
    .p-top-products {
      background: url("../images/top/products_bg_sp.jpg") center no-repeat;
      background-size: cover;
      padding: calc(100vw / ( 375 / 50 )) calc(100vw / ( 375 / 2 )) calc(100vw / ( 375 / 50 )) calc(100vw / ( 375 / 3 )); } }
  @media screen and (min-width: 768px) {
    .p-top-products:before, .p-top-products:after {
      content: "";
      display: block;
      position: absolute;
      height: 100%;
      top: 0; } }
  @media screen and (max-width: 767px) {
    .p-top-products:before {
      content: "";
      display: block;
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%;
      background: rgba(35, 162, 50, 0.8); } }
  @media screen and (min-width: 768px) {
    .p-top-products:before {
      width: calc(100vw / ( 1440 / 565 ));
      background: url("../images/top/products_bg_l.jpg") center no-repeat;
      background-size: cover;
      left: 0; } }
  @media screen and (min-width: 1441px) {
    .p-top-products:before {
      width: calc(((100% - 1120px) / 2) + 415px); } }
  @media screen and (min-width: 768px) {
    .p-top-products:after {
      width: calc(100vw / ( 1440 / 875 ));
      background: url("../images/top/products_bg_r.jpg") center no-repeat;
      background-size: cover;
      right: 0; } }
  @media screen and (min-width: 1441px) {
    .p-top-products:after {
      width: calc(((100% - 1120px) / 2) + 705px); } }
  @media screen and (min-width: 768px) {
    .p-top-products__bg {
      position: relative;
      z-index: 1;
      padding: calc(100vw / ( 1440 / 80 )) 0; } }
  @media screen and (min-width: 1441px) {
    .p-top-products__bg {
      padding: 80px 0; } }
  @media screen and (min-width: 768px) {
    .p-top-products__bg:after {
      content: "";
      display: block;
      position: absolute;
      height: 100%;
      top: 0;
      width: calc(100vw / ( 1440 / 875 ));
      right: 0;
      background: rgba(35, 162, 50, 0.8); } }
  @media screen and (min-width: 1441px) {
    .p-top-products__bg:after {
      width: calc(((100% - 1120px) / 2) + 705px); } }
  @media screen and (min-width: 768px) {
    .p-top-products .c-inner {
      display: flex;
      justify-content: flex-end; } }
  .p-top-products__inner {
    background: #fff;
    border-radius: 10px;
    padding: calc(100vw / ( 375 / 20 )); }
    @media screen and (min-width: 768px) {
      .p-top-products__inner {
        position: relative;
        width: 58%;
        padding: calc(100vw / ( 1440 / 35 )) calc(100vw / ( 1440 / 40 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-products__inner {
        width: 625px;
        padding: 35px 40px; } }
    .p-top-products__inner .pdBox_ttl {
      padding: calc(100vw / ( 375 / 3 )) calc(100vw / ( 375 / 13 ));
      background: #208C30;
      color: #fff;
      font-weight: 700;
      border-radius: 2px;
      line-height: 140%;
      font-size: calc(100vw / ( 375 / 18 )); }
      @media screen and (max-width: 767px) {
        .p-top-products__inner .pdBox_ttl {
          text-align: center; } }
      @media screen and (min-width: 768px) {
        .p-top-products__inner .pdBox_ttl {
          display: block;
          padding: 5px 15px;
          font-size: 2.4rem; } }
      .p-top-products__inner .pdBox_ttl .sizeS {
        font-size: calc(100vw / ( 375 / 14 )); }
        @media screen and (max-width: 767px) {
          .p-top-products__inner .pdBox_ttl .sizeS {
            display: block; } }
        @media screen and (min-width: 768px) {
          .p-top-products__inner .pdBox_ttl .sizeS {
            /* padding-left: 1em; */
            font-size: 1.7rem; } }
    .p-top-products__inner .pdBox_detail {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      padding: calc(100vw / ( 375 / 25 )) 0; }
      @media screen and (min-width: 768px) {
        .p-top-products__inner .pdBox_detail {
          padding: 22px 0; } }
      .p-top-products__inner .pdBox_detail .forImg {
        width: calc(100vw / ( 375 / 100 ));
        margin-right: calc(100vw / ( 375 / 20 )); }
        @media screen and (min-width: 768px) {
          .p-top-products__inner .pdBox_detail .forImg {
            width: 145px;
            margin-right: 30px; } }
      .p-top-products__inner .pdBox_detail .forInfo {
        width: calc(100% - calc(100vw / ( 375 / 120 ))); }
        @media screen and (min-width: 768px) {
          .p-top-products__inner .pdBox_detail .forInfo {
            width: calc(100% - 175px); } }
        .p-top-products__inner .pdBox_detail .forInfo_txt {
          line-height: 160%;
          margin-bottom: 0.5em; }
          @media screen and (min-width: 768px) {
            .p-top-products__inner .pdBox_detail .forInfo_txt {
              font-size: 1.6rem; } }
        .p-top-products__inner .pdBox_detail .forInfo_price {
          font-weight: 700; }
          .p-top-products__inner .pdBox_detail .forInfo_price .num {
            font-family: "Albert Sans", sans-serif;
            letter-spacing: -0.01em;
            font-size: calc(100vw / ( 375 / 35 )); }
            @media screen and (min-width: 768px) {
              .p-top-products__inner .pdBox_detail .forInfo_price .num {
                font-size: 3.7rem; } }
    .p-top-products__inner .pdBox_btns {
      margin-bottom: calc(100vw / ( 375 / 8 )); }
      @media screen and (min-width: 768px) {
        .p-top-products__inner .pdBox_btns {
          display: flex;
          justify-content: space-between;
          flex-wrap: wrap;
          margin-bottom: 15px; } }
      @media screen and (min-width: 768px) {
        .p-top-products__inner .pdBox_btns__item {
          width: 48.62385%; } }
      @media screen and (max-width: 767px) {
        .p-top-products__inner .pdBox_btns__item:not(:last-child) {
          margin-bottom: calc(100vw / ( 375 / 13 )); } }
      @media screen and (min-width: 768px) {
        .p-top-products__inner .pdBox_btns__item .c-btn-std {
          display: flex;
          width: 100%;
          justify-content: center; } }
      .p-top-products__inner .pdBox_btns__item .c-btn-std.forCoupon {
        background: #FBE32B;
        border-color: #FBE32B;
        color: #000; }
        @media screen and (max-width: 767px) {
          .p-top-products__inner .pdBox_btns__item .c-btn-std.forCoupon {
            font-size: 0.9em; } }
        .p-top-products__inner .pdBox_btns__item .c-btn-std.forCoupon .in {
          line-height: 130%; }
          .p-top-products__inner .pdBox_btns__item .c-btn-std.forCoupon .in:before {
            content: "";
            display: inline-block;
            vertical-align: middle;
            width: calc(100vw / ( 375 / 29 ));
            height: calc(100vw / ( 375 / 20 ));
            margin-right: calc(100vw / ( 375 / 10 ));
            background: url("../images/icon_coupon.svg") center no-repeat;
            background-size: contain; }
          .p-top-products__inner .pdBox_btns__item .c-btn-std.forCoupon .in:after {
            background-image: url("../images/icon_arrow_bk.svg");
            margin-left: calc(100vw / ( 375 / 9 ));
            rotate: 90deg;
           }
    .p-top-products__inner .pdBox_note {
      line-height: 170%;
      font-size: calc(100vw / ( 375 / 14 )); }
      @media screen and (min-width: 768px) {
        .p-top-products__inner .pdBox_note {
          text-align: left;
          font-size: 1.4rem; } }
    .p-top-products__inner .pdBox.aboutMedia {
      border-top: 1px dashed #6D6D6D;
      padding-top: calc(100vw / ( 375 / 30 )); }
      @media screen and (min-width: 768px) {
        .p-top-products__inner .pdBox.aboutMedia {
          padding-top: calc(100vw / ( 1440 / 30 )); } }
      @media screen and (min-width: 1441px) {
        .p-top-products__inner .pdBox.aboutMedia {
          padding-top: 30px; } }
      .p-top-products__inner .pdBox.aboutMedia .pdBox_ttl {
        font-size: calc(100vw / ( 375 / 17 )); }
        @media screen and (min-width: 768px) {
          .p-top-products__inner .pdBox.aboutMedia .pdBox_ttl {
            font-size: 1.7rem; } }
        .p-top-products__inner .pdBox.aboutMedia .pdBox_ttl .sizeS {
          font-size: calc(100vw / ( 375 / 13 )); }
          @media screen and (min-width: 768px) {
            .p-top-products__inner .pdBox.aboutMedia .pdBox_ttl .sizeS {
              font-size: 1.4rem; } }
      @media screen and (min-width: 768px) {
        .p-top-products__inner .pdBox.aboutMedia .pdBox_detail {
          padding: 20px 0; } }
      .p-top-products__inner .pdBox.aboutMedia .pdBox_detail .forImg {
        width: calc(100vw / ( 375 / 68 )); }
        @media screen and (min-width: 768px) {
          .p-top-products__inner .pdBox.aboutMedia .pdBox_detail .forImg {
            width: 87px; } }
      .p-top-products__inner .pdBox.aboutMedia .pdBox_detail .forInfo {
        width: calc(100% - calc(100vw / ( 375 / 88 ))); }
        @media screen and (min-width: 768px) {
          .p-top-products__inner .pdBox.aboutMedia .pdBox_detail .forInfo {
            width: calc(100% - 117px); } }
        .p-top-products__inner .pdBox.aboutMedia .pdBox_detail .forInfo_txt {
          font-size: calc(100vw / ( 375 / 13 )); }
          @media screen and (min-width: 768px) {
            .p-top-products__inner .pdBox.aboutMedia .pdBox_detail .forInfo_txt {
              font-size: 1.5rem; } }
        .p-top-products__inner .pdBox.aboutMedia .pdBox_detail .forInfo_price .num {
          letter-spacing: -0.04em;
          font-size: calc(100vw / ( 375 / 28 )); }
          @media screen and (min-width: 768px) {
            .p-top-products__inner .pdBox.aboutMedia .pdBox_detail .forInfo_price .num {
              font-size: 3.0rem; } }
      @media screen and (max-width: 767px) {
        .p-top-products__inner .pdBox.aboutMedia .pdBox_btns {
          text-align: center;
          margin-bottom: calc(100vw / ( 375 / 8 )); } }
      @media screen and (min-width: 768px) {
        .p-top-products__inner .pdBox.aboutMedia .pdBox_btns {
          align-items: center;
          flex-direction: column; } }
      .p-top-products__inner .pdBox.aboutMedia .pdBox_btns .forTtl {
        font-weight: 700;
        color: #F56600;
        position: relative;
        padding: 0 1em; }
        @media screen and (max-width: 767px) {
          .p-top-products__inner .pdBox.aboutMedia .pdBox_btns .forTtl {
            display: inline-block;
            margin-bottom: calc(100vw / ( 375 / 8 ));
            font-size: calc(100vw / ( 375 / 12 )); } }
        @media screen and (min-width: 768px) {
          .p-top-products__inner .pdBox.aboutMedia .pdBox_btns .forTtl {
            font-size: 1.3rem;
            margin-bottom: 9px; } }
        .p-top-products__inner .pdBox.aboutMedia .pdBox_btns .forTtl:before, .p-top-products__inner .pdBox.aboutMedia .pdBox_btns .forTtl:after {
          content: "";
          display: block;
          position: absolute;
          height: 1.2em;
          width: 2px;
          background: #F56600;
          top: 50%; }
        .p-top-products__inner .pdBox.aboutMedia .pdBox_btns .forTtl:before {
          left: 0;
          transform: rotate(-30deg) translateY(-50%); }
        .p-top-products__inner .pdBox.aboutMedia .pdBox_btns .forTtl:after {
          right: 0;
          transform: rotate(30deg) translateY(-50%); }
      @media screen and (min-width: 768px) {
        .p-top-products__inner .pdBox.aboutMedia .pdBox_btns .forBtn {
          width: 260px; } }
      @media screen and (min-width: 768px) {
        .p-top-products__inner .pdBox.aboutMedia .pdBox_btns .forBtn .c-btn-std {
          font-size: 1.4rem;
          padding: 12px 0;
          display: flex;
          justify-content: center; } }
      .p-top-products__inner .pdBox.aboutMedia .pdBox_note {
        text-align: left; }
  @media screen and (min-width: 768px) {
    .p-top-products_coupon {
      position: absolute;
      right: 0;
      top: 0;
      transform: translateY(-20%);
      width: calc(100vw / ( 1440 / 140 ));
      right: calc(100vw / ( 1440 / 25 )); } }
  @media screen and (min-width: 1441px) {
    .p-top-products_coupon {
      right: 25px;
      width: 140px; } }
.p-top-feature {
  background: #FFF5EA;
  position: relative;
  padding: calc(100vw / ( 375 / 70 )) 0; }
  @media screen and (min-width: 768px) {
    .p-top-feature {
      padding: calc(100vw / ( 1440 / 90 )) 0; } }
  @media screen and (min-width: 1441px) {
    .p-top-feature {
      padding: 90px 0; } }
  .p-top-feature:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: calc(50% - 290px);
    background: rgba(245, 102, 0, 0.1); }
    @media screen and (max-width: 767px) {
      .p-top-feature:after {
        width: calc(100vw / ( 375 / 140 )); } }
  .p-top-feature_ttl {
    text-align: center;
    color: #F56600;
    font-weight: 900;
    margin-bottom: calc(100vw / ( 375 / 60 )); }
    @media screen and (min-width: 768px) {
      .p-top-feature_ttl {
        margin-bottom: 80px; } }
    .p-top-feature_ttl .balloon {
      display: inline-block;
      background: #F56600;
      color: #fff;
      border-radius: 3px;
      position: relative;
      margin-bottom: 0.5em;
      font-size: calc(100vw / ( 375 / 18 ));
      padding: calc(100vw / ( 375 / 8 )) calc(100vw / ( 375 / 10 )); }
      .p-top-feature_ttl .balloon:after {
        content: "";
        display: block;
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
        background: url("../images/icon_balloon_btm.svg") center no-repeat;
        background-size: contain;
        width: calc(100vw / ( 375 / 24 ));
        height: calc(100vw / ( 375 / 20 ));
        bottom: calc(-100vw / ( 375 / 15 )); }
        @media screen and (min-width: 768px) {
          .p-top-feature_ttl .balloon:after {
            width: 24px;
            height: 20px;
            bottom: -15px; } }
      @media screen and (min-width: 768px) {
        .p-top-feature_ttl .balloon {
          font-size: 2.4rem;
          padding: 10px 10px; } }
    .p-top-feature_ttl .title {
      display: block;
      letter-spacing: 0.03em;
      font-size: calc(100vw / ( 375 / 42 )); }
      @media screen and (min-width: 768px) {
        .p-top-feature_ttl .title {
          font-size: 4.2rem; } }
      .p-top-feature_ttl .title .num {
        font-size: calc(100vw / ( 375 / 49 )); }
        @media screen and (min-width: 768px) {
          .p-top-feature_ttl .title .num {
            font-size: 4.9rem; } }
      .p-top-feature_ttl .title .unit {
        font-size: calc(100vw / ( 375 / 34 )); }
        @media screen and (min-width: 768px) {
          .p-top-feature_ttl .title .unit {
            font-size: 3.4rem; } }
  .p-top-feature_item {
    background: #fff;
    border-radius: 10px;
    display: flex; }
    @media screen and (max-width: 767px) {
      .p-top-feature_item {
        position: relative;
        flex-direction: column;
        padding: calc(100vw / ( 375 / 45 )) calc(100vw / ( 375 / 20 )) calc(100vw / ( 375 / 25 )); } }
    @media screen and (min-width: 768px) {
      .p-top-feature_item.even {
        flex-direction: row-reverse; } }
    @media screen and (min-width: 768px) {
      .p-top-feature_item.even .forImg {
        border-radius: 0 10px 10px 0; } }
    .p-top-feature_item:not(:last-child) {
      margin-bottom: calc(100vw / ( 375 / 65 )); }
      @media screen and (min-width: 768px) {
        .p-top-feature_item:not(:last-child) {
          margin-bottom: calc(100vw / ( 1440 / 80 )); } }
      @media screen and (min-width: 1441px) {
        .p-top-feature_item:not(:last-child) {
          margin-bottom: 80px; } }
    .p-top-feature_item .forImg {
      overflow: hidden;
      flex: 1; }
      @media screen and (min-width: 768px) {
        .p-top-feature_item .forImg {
          width: 46.4285%;
          border-radius: 10px 0 0 10px; } }
      @media screen and (max-width: 767px) {
        .p-top-feature_item .forImg {
          border-radius: 10px;
          order: 2;
          margin: calc(100vw / ( 375 / 20 )) 0; } }
      .p-top-feature_item .forImg img {
        width: 100%;
        height: 100%;
        object-fit: cover; }
    .p-top-feature_item .forTxt {
      position: relative; }
      @media screen and (min-width: 768px) {
        .p-top-feature_item .forTxt {
          width: 53.5715%; } }
      @media screen and (max-width: 767px) {
        .p-top-feature_item .forTxt {
          display: contents; } }
      @media screen and (min-width: 768px) {
        .p-top-feature_item .forTxt.on01 {
          padding: calc(100vw / ( 1440 / 91 )) 0 0 calc(100vw / ( 1440 / 39 )); } }
      @media screen and (min-width: 1441px) {
        .p-top-feature_item .forTxt.on01 {
          padding: 91px 0 0 39px; } }
      @media screen and (min-width: 768px) {
        .p-top-feature_item .forTxt.on02 {
          padding: calc(100vw / ( 1440 / 58 )) 0 0 calc(100vw / ( 1440 / 62 )); } }
      @media screen and (min-width: 1441px) {
        .p-top-feature_item .forTxt.on02 {
          padding: 58px 0 0 62px; } }
      @media screen and (min-width: 768px) and (max-width: 820px) {
        .p-top-feature_item .forTxt.on02 .on02_br {
          display: none !important; } }
      @media screen and (min-width: 768px) {
        .p-top-feature_item .forTxt.on03 {
          padding: calc(100vw / ( 1440 / 80 )) 0 0 calc(100vw / ( 1440 / 62 )); } }
      @media screen and (min-width: 1441px) {
        .p-top-feature_item .forTxt.on03 {
          padding: 91px 0 0 62px; } }
      .p-top-feature_item .forTxt_ttl {
        font-weight: 700;
        font-size: 2.6rem; }
        @media screen and (max-width: 767px) {
          .p-top-feature_item .forTxt_ttl {
            order: 1;
            font-size: calc(100vw / ( 375 / 25 ));
            line-height: 142%;
            position: relative; } }
        .p-top-feature_item .forTxt_ttl .num {
          position: absolute;
          color: #F56600;
          top: 0;
          transform: translateY(calc(-100vw / ( 375 / 64 )));
          font-family: "Outfit", sans-serif;
          font-weight: 600;
          letter-spacing: 0.03em;
          font-size: calc(100vw / ( 375 / 52 )); }
          @media screen and (min-width: 768px) {
            .p-top-feature_item .forTxt_ttl .num {
              font-size: 6.4rem;
              transform: translateY(-50%); } }
          @media screen and (min-width: 768px) {
            .p-top-feature_item .forTxt_ttl .num01 {
              left: calc(100vw / ( 1440 / 40 )); } }
          @media screen and (min-width: 1441px) {
            .p-top-feature_item .forTxt_ttl .num01 {
              left: 40px; } }
          @media screen and (min-width: 768px) {
            .p-top-feature_item .forTxt_ttl .num02 {
              left: calc(100vw / ( 1440 / 62 )); } }
          @media screen and (min-width: 1441px) {
            .p-top-feature_item .forTxt_ttl .num02 {
              left: 62px; } }
          @media screen and (min-width: 768px) {
            .p-top-feature_item .forTxt_ttl .num03 {
              left: calc(100vw / ( 1440 / 40 )); } }
          @media screen and (min-width: 1441px) {
            .p-top-feature_item .forTxt_ttl .num03 {
              left: 40px; } }
          .p-top-feature_item .forTxt_ttl .num:after {
            content: "";
            display: inline-block;
            vertical-align: top;
            margin-left: 0.5em;
            width: 1px;
            height: 1em;
            background: #F56600;
            transform: rotate(40deg); }
            @media screen and (max-width: 767px) {
              .p-top-feature_item .forTxt_ttl .num:after {
                margin-top: -0.1em; } }
      @media screen and (min-width: 768px) {
        .p-top-feature_item .forTxt_txt {
          padding: 22px 0; } }
      @media screen and (max-width: 767px) {
        .p-top-feature_item .forTxt_txt {
          order: 3; } }
      .p-top-feature_item .forTxt_txt p {
        line-height: 180%; }
        @media screen and (min-width: 768px) {
          .p-top-feature_item .forTxt_txt p:not(:last-child) {
            margin-bottom: 0.5em; } }
      .p-top-feature_item .forTxt_obj {
        position: absolute; }
        .p-top-feature_item .forTxt_obj.obj01 {
          width: calc(100vw / ( 375 / 120 ));
          right: calc(100vw / ( 375 / 19 ));
          top: calc(100vw / ( 375 / 12.5 )); }
          @media screen and (min-width: 768px) {
            .p-top-feature_item .forTxt_obj.obj01 {
              width: calc(100vw / ( 1440 / 186 ));
              right: calc(100vw / ( 1440 / 23 ));
              top: calc(100vw / ( 1440 / 88 )); } }
          @media screen and (min-width: 767px) and (max-width: 890px) {
            .p-top-feature_item .forTxt_obj.obj01 {
              top: calc(100vw / ( 1440 / 195 )); } }
          @media screen and (min-width: 1441px) {
            .p-top-feature_item .forTxt_obj.obj01 {
              width: 186px;
              right: 23px;
              top: 88px; } }
        @media screen and (max-width: 767px) {
          .p-top-feature_item .forTxt_obj.obj02 {
            width: calc(100vw / ( 375 / 87 ));
            right: calc(100vw / ( 375 / 26 ));
            top: calc(100vw / ( 375 / 19.5 )); } }
        @media screen and (min-width: 768px) {
          .p-top-feature_item .forTxt_obj.obj02 {
            width: calc(100vw / ( 1440 / 136 ));
            right: calc(100vw / ( 1440 / 50 ));
            bottom: calc(100vw / ( 1440 / 22 )); } }
        @media screen and (min-width: 767px) and (max-width: 890px) {
          .p-top-feature_item .forTxt_obj.obj02 {
            bottom: calc(-100vw / ( 1440 / 5 )); } }
        @media screen and (min-width: 1441px) {
          .p-top-feature_item .forTxt_obj.obj02 {
            width: 136px;
            right: 50px;
            bottom: 22px; } }
        @media screen and (max-width: 767px) {
          .p-top-feature_item .forTxt_obj.obj03 {
            width: calc(100vw / ( 375 / 124 ));
            right: calc(100vw / ( 375 / 19 ));
            top: calc(100vw / ( 375 / 25 )); } }
        @media screen and (min-width: 768px) {
          .p-top-feature_item .forTxt_obj.obj03 {
            width: calc(100vw / ( 1440 / 212 ));
            right: calc(100vw / ( 1440 / 23 ));
            bottom: calc(100vw / ( 1440 / 24 )); } }
        @media screen and (min-width: 1441px) {
          .p-top-feature_item .forTxt_obj.obj03 {
            width: 212px;
            right: 23px;
            bottom: 24px; } }
      @media screen and (max-width: 767px) {
        .p-top-feature_item .forTxt_btn {
          order: 4;
          margin: calc(100vw / ( 375 / 20 )) auto calc(100vw / ( 375 / 10 )); } }
.p-top-devices {
  background: #E7F2E4;
  padding: calc(100vw / ( 375 / 70 )) 0; }
  @media screen and (min-width: 768px) {
    .p-top-devices {
      padding: calc(100vw / ( 1440 / 80 )) 0; } }
  @media screen and (min-width: 1441px) {
    .p-top-devices {
      padding: 80px 0; } }
  @media screen and (min-width: 768px) {
    .p-top-devices__inner {
      margin: auto;
      width: calc(100vw / ( 1440 / 940 )); } }
  @media screen and (min-width: 1441px) {
    .p-top-devices__inner {
      width: 940px; } }
  .p-top-devices_btn {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    background: #fff;
    border: 2px solid #208C30;
    position: relative;
    border-radius: 10px;
    padding: calc(100vw / ( 375 / 15 )) calc(100vw / ( 375 / 16 )) calc(100vw / ( 375 / 15 )) calc(100vw / ( 375 / 20 ));
    margin-bottom: calc(100vw / ( 375 / 20 )); }
    @media screen and (min-width: 768px) {
      .p-top-devices_btn {
        padding: calc(100vw / ( 1440 / 30 )) calc(100vw / ( 1440 / 30 )) calc(100vw / ( 1440 / 30 )) calc(100vw / ( 1440 / 174 ));
        margin-bottom: calc(100vw / ( 1440 / 25 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-devices_btn {
        padding: 30px 30px 30px 174px;
        margin-bottom: 25px; } }
    .p-top-devices_btn:before, .p-top-devices_btn:after {
      content: "";
      display: block;
      position: absolute;
      top: 50%;
      transform: translateY(-50%); }
    .p-top-devices_btn:before {
      background: url("../images/icon_dl.svg") center no-repeat;
      background-size: contain; }
      @media screen and (max-width: 767px) {
        .p-top-devices_btn:before {
          display: none; } }
      @media screen and (min-width: 768px) {
        .p-top-devices_btn:before {
          width: calc(100vw / ( 1440 / 86 ));
          height: calc(100vw / ( 1440 / 54 ));
          left: calc(100vw / ( 1440 / 50 )); } }
      @media screen and (min-width: 1441px) {
        .p-top-devices_btn:before {
          width: 86px;
          height: 54px;
          left: 50px; } }
    .p-top-devices_btn:after {
      background: url("../images/icon_arrow_gr.svg") center no-repeat;
      background-size: contain;
      width: calc(100vw / ( 375 / 22 ));
      height: calc(100vw / ( 375 / 10 ));
      right: calc(100vw / ( 375 / 16 )); }
      @media screen and (min-width: 768px) {
        .p-top-devices_btn:after {
          width: 26px;
          height: 12px;
          right: calc(100vw / ( 1440 / 30 )); } }
      @media screen and (min-width: 1441px) {
        .p-top-devices_btn:after {
          right: 30px; } }
    .p-top-devices_btn .forNote {
      position: relative;
      font-weight: 700;
      color: #D21403;
      margin-bottom: 1em;
      padding-left: 2em;
      background: linear-gradient(transparent 40%, #FFF600 60%);
      font-size: calc(100vw / ( 375 / 16 )); }
      @media screen and (min-width: 768px) {
        .p-top-devices_btn .forNote {
          font-size: calc(100vw / ( 1440 / 20 )); } }
      @media screen and (min-width: 1441px) {
        .p-top-devices_btn .forNote {
          font-size: 2.0rem; } }
      .p-top-devices_btn .forNote:before {
        content: "";
        display: block;
        position: absolute;
        left: 0;
        top: 50%;
        transform: translateY(-50%);
        width: 1.7em;
        height: 1.7em;
        background: url("../images/icon_caution.png") center no-repeat;
        background-size: contain; }
        @media screen and (max-width: 767px) {
          .p-top-devices_btn .forNote:before {
            width: 1.875em;
            height: 1.875em; } }
    .p-top-devices_btn .forTtl {
      color: #208C30;
      font-weight: 700;
      font-size: calc(100vw / ( 375 / 23 )); }
      @media screen and (max-width: 767px) {
        .p-top-devices_btn .forTtl {
          line-height: 140%; } }
      @media screen and (min-width: 768px) {
        .p-top-devices_btn .forTtl {
          font-size: calc(100vw / ( 1440 / 34 )); } }
      @media screen and (min-width: 1441px) {
        .p-top-devices_btn .forTtl {
          font-size: 3.4rem; } }
      .p-top-devices_btn .forTtl-file {
        font-size: calc(100vw / ( 375 / 18 )); }
        @media screen and (min-width: 768px) {
          .p-top-devices_btn .forTtl-file {
            font-size: calc(100vw / ( 1440 / 24 )); } }
        @media screen and (min-width: 1441px) {
          .p-top-devices_btn .forTtl-file {
            font-size: 2.4rem; } }
  .p-top-devices_note {
    font-size: calc(100vw / ( 375 / 14 )); }
    @media screen and (min-width: 768px) {
      .p-top-devices_note {
        font-size: 1.4rem; } }
    .p-top-devices_note .c-list-idt__item:not(:last-child) {
      margin-bottom: calc(100vw / ( 375 / 10 )); }
      @media screen and (min-width: 768px) {
        .p-top-devices_note .c-list-idt__item:not(:last-child) {
          margin-bottom: 10px; } }
.p-top-prepare {
  background: url("../images/top/prepare_bg_sp.jpg") center no-repeat;
  background-size: cover;
  position: relative;
  padding: calc(100vw / ( 375 / 70 )) 0; }
  @media screen and (min-width: 768px) {
    .p-top-prepare {
      background-image: url("../images/top/prepare_bg.jpg");
      padding: calc(100vw / ( 1440 / 60 )) 0; } }
  @media screen and (min-width: 1441px) {
    .p-top-prepare {
      padding: 60px 0; } }
  .p-top-prepare:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(35, 162, 50, 0.8); }
  .p-top-prepare_ttl {
    color: #fff;
    margin-bottom: calc(100vw / ( 375 / 30 )); }
    @media screen and (max-width: 767px) {
      .p-top-prepare_ttl {
        line-height: 1.3; } }
    @media screen and (min-width: 768px) {
      .p-top-prepare_ttl {
        margin-bottom: calc(100vw / ( 1440 / 50 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-prepare_ttl {
        margin-bottom: 50px; } }
  @media screen and (min-width: 768px) {
    .p-top-prepare_items {
      display: flex;
      flex-wrap: wrap;
      column-gap: calc(100vw / ( 1440 / 36 ));
      margin-bottom: calc(100vw / ( 1440 / 15 )); } }
  @media screen and (min-width: 1441px) {
    .p-top-prepare_items {
      column-gap: 36px;
      margin-bottom: 15px; } }
  .p-top-prepare_items__item {
    background: #fff;
    border-radius: 10px; }
    @media screen and (max-width: 767px) {
      .p-top-prepare_items__item {
        margin-bottom: calc(100vw / ( 375 / 20 ));
        padding: calc(100vw / ( 375 / 20 )); } }
    @media screen and (min-width: 768px) {
      .p-top-prepare_items__item {
        width: calc((100% - calc(100vw / ( 1440 / 108 ))) / 4);
        padding: calc(100vw / ( 1440 / 20 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-prepare_items__item {
        width: calc((100% - 108px) / 4);
        padding: 20px; } }
    .p-top-prepare_items__item .forIcon {
      margin: 0 auto; }
      @media screen and (max-width: 767px) {
        .p-top-prepare_items__item .forIcon {
          width: calc(100vw / ( 375 / 158 ));
          margin-bottom: calc(100vw / ( 375 / 13 )); } }
      @media screen and (min-width: 768px) {
        .p-top-prepare_items__item .forIcon {
          width: calc(100vw / ( 1440 / 158 )); } }
      @media screen and (min-width: 1441px) {
        .p-top-prepare_items__item .forIcon {
          width: 158px; } }
    .p-top-prepare_items__item .forDetail_ttl {
      color: #F56600;
      font-weight: 700;
      line-height: 160%;
      margin-bottom: 0.5em;
      text-align: center;
      font-size: calc(100vw / ( 375 / 20 )); }
      @media screen and (min-width: 768px) {
        .p-top-prepare_items__item .forDetail_ttl {
          line-height: 140%;
          font-size: 2.2rem; } }
      .p-top-prepare_items__item .forDetail_ttl .sizeS {
        font-size: 0.8em;
        line-height: 1.5; }
        @media screen and (min-width: 768px) {
          .p-top-prepare_items__item .forDetail_ttl .sizeS {
            display: block; } }
    .p-top-prepare_items__item .forDetail_txt {
      line-height: 160%; }
      @media screen and (min-width: 768px) {
        .p-top-prepare_items__item .forDetail_txt {
          font-size: 1.5rem; } }
      @media screen and (min-width: 768px) {
        .p-top-prepare_items__item .forDetail_txt .tooltip-trigger {
          font-size: 1.5rem; } }
      .p-top-prepare_items__item .forDetail_txt .tooltip-trigger:focus-visible {
        outline: auto; }
      .p-top-prepare_items__item .forDetail_txt p:not(:last-child) {
        margin-bottom: 0.5em; }
      .p-top-prepare_items__item .forDetail_txt .c-list-idt {
        font-size: calc(100vw / ( 375 / 14 )); }
        @media screen and (min-width: 768px) {
          .p-top-prepare_items__item .forDetail_txt .c-list-idt {
            font-size: 1.4rem; } }
  .p-top-prepare_notes {
    margin-bottom: calc(100vw / ( 375 / 28 )); }
    @media screen and (min-width: 768px) {
      .p-top-prepare_notes {
        margin-bottom: calc(100vw / ( 1440 / 40 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-prepare_notes {
        margin-bottom: 40px; } }
    .p-top-prepare_notes__item {
      color: #fff;
      line-height: 160%;
      text-shadow: 0px 0px 6px #0C3C13;
      font-size: calc(100vw / ( 375 / 14 )); }
      @media screen and (min-width: 768px) {
        .p-top-prepare_notes__item {
          line-height: 180%;
          font-size: 1.4rem; } }
      @media screen and (max-width: 767px) {
        .p-top-prepare_notes__item:not(:last-child) {
          margin-bottom: 0.5em; } }
  .p-top-prepare_DL {
    background: #fff;
    border-radius: 10px;
    text-align: center;
    padding: calc(100vw / ( 375 / 30 )) calc(100vw / ( 375 / 20 )); }
    @media screen and (min-width: 768px) {
      .p-top-prepare_DL {
        padding: calc(100vw / ( 1440 / 27 )) calc(100vw / ( 1440 / 33 )) calc(100vw / ( 1440 / 30 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-prepare_DL {
        padding: 27px 33px 30px; } }
    .p-top-prepare_DL .forTtl {
      display: inline-block;
      color: #208C30;
      font-weight: 700;
      margin-bottom: 1.1em;
      position: relative;
      padding-left: 1.5em;
      font-size: calc(100vw / ( 375 / 20 )); }
      @media screen and (min-width: 768px) {
        .p-top-prepare_DL .forTtl {
          font-size: 2.0rem; } }
      .p-top-prepare_DL .forTtl:before {
        content: "";
        display: block;
        position: absolute;
        left: 0;
        top: 50%;
        transform: translateY(-50%);
        background: url("../images/icon_timer.svg") center no-repeat;
        background-size: contain;
        width: calc(100vw / ( 375 / 19 ));
        height: calc(100vw / ( 375 / 24 )); }
        @media screen and (min-width: 768px) {
          .p-top-prepare_DL .forTtl:before {
            width: 19px;
            height: 24px; } }
    @media screen and (min-width: 768px) {
      .p-top-prepare_DL .forItems {
        display: flex;
        justify-content: center;
        column-gap: calc(100vw / ( 1440 / 32 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-prepare_DL .forItems {
        column-gap: 32px; } }
    .p-top-prepare_DL .forItems-item {
      text-align: left;
      font-weight: 700; }
      @media screen and (min-width: 768px) {
        .p-top-prepare_DL .forItems-item {
          width: calc((100% - calc(100vw / ( 1440 / 64 ))) / 3); } }
      @media screen and (min-width: 1441px) {
        .p-top-prepare_DL .forItems-item {
          width: calc((100% - 64px) / 3); } }
      @media screen and (max-width: 767px) {
        .p-top-prepare_DL .forItems-item:not(:last-child) {
          margin-bottom: calc(100vw / ( 375 / 17 )); } }
      .p-top-prepare_DL .forItems-item__inner {
        display: flex;
        justify-content: space-between;
        align-items: center;
        border: 2px solid #23A232;
        border-radius: 5px;
        padding: calc(100vw / ( 375 / 15 )) calc(100vw / ( 375 / 18 )); }
        @media screen and (min-width: 768px) {
          .p-top-prepare_DL .forItems-item__inner {
            padding: calc(100vw / ( 1440 / 15 )) calc(100vw / ( 1440 / 30 )); } }
        @media screen and (min-width: 1441px) {
          .p-top-prepare_DL .forItems-item__inner {
            padding: 15px 30px; } }
    .p-top-prepare_DL .forItems_ttl {
      line-height: 160%;
      padding-right: 1em;
      font-size: calc(100vw / ( 375 / 16 )); }
      @media screen and (min-width: 768px) {
        .p-top-prepare_DL .forItems_ttl {
          font-size: 1.7rem; } }
    .p-top-prepare_DL .forItems_min {
      color: #208C30;
      font-size: calc(100vw / ( 375 / 21 )); }
      @media screen and (min-width: 768px) {
        .p-top-prepare_DL .forItems_min {
          font-size: 2.1rem; } }
      .p-top-prepare_DL .forItems_min .num {
        font-family: "Outfit", sans-serif;
        font-size: calc(100vw / ( 375 / 40 )); }
        @media screen and (min-width: 768px) {
          .p-top-prepare_DL .forItems_min .num {
            font-size: 4.0rem; } }
  .p-top-prepare_spec .forTtl {
    color: #208C30;
    border-bottom: 2px solid #208C30;
    font-weight: 700;
    padding-bottom: 0.5em;
    margin-bottom: 1em; }
    @media screen and (min-width: 768px) {
      .p-top-prepare_spec .forTtl {
        font-size: 1.5rem; } }
  .p-top-prepare_spec .forTbl {
    border-collapse: collapse;
    line-height: 1.2; }
    @media screen and (min-width: 768px) {
      .p-top-prepare_spec .forTbl {
        font-size: 1.2rem; } }
    .p-top-prepare_spec .forTblWrap:not(:last-child) {
      margin-bottom: calc(100vw / ( 375 / 30 )); }
      @media screen and (min-width: 768px) {
        .p-top-prepare_spec .forTblWrap:not(:last-child) {
          margin-bottom: 20px; } }
    .p-top-prepare_spec .forTbl th {
      color: #208C30;
      font-weight: 700;
      padding: 0.25em 0;
      vertical-align: top;
      width: 8em; }
      @media screen and (max-width: 767px) {
        .p-top-prepare_spec .forTbl th {
          width: 100%;
          font-size: calc(100vw / ( 375 / 13 ));
          margin-bottom: calc(100vw / ( 375 / 6 )); } }
    .p-top-prepare_spec .forTbl td {
      padding: 0.25em 0 0.25em 1em; }
      @media screen and (max-width: 767px) {
        .p-top-prepare_spec .forTbl td {
          font-size: calc(100vw / ( 375 / 14 ));
          margin-bottom: calc(100vw / ( 375 / 12 )); } }
    @media screen and (max-width: 767px) {
      .p-top-prepare_spec .forTbl th, .p-top-prepare_spec .forTbl td {
        display: block;
        padding: 0; } }
.p-top-mediaBtn {
  margin: 0 auto;
  display: block; }
  @media screen and (min-width: 768px) {
    .p-top-mediaBtn {
      width: 680px; } }
  .p-top-mediaBtnWrap {
    padding: calc(100vw / ( 375 / 30 )) calc(100vw / ( 375 / 20 )); }
    @media screen and (min-width: 768px) {
      .p-top-mediaBtnWrap {
        padding: calc(100vw / ( 1440 / 50 )) 0; } }
    @media screen and (min-width: 1441px) {
      .p-top-mediaBtnWrap {
        padding: 50px 0; } }
.p-top-steps-note {
  font-weight: 400;
  line-height: 160%;
  font-size: calc(100vw / ( 375 / 14 ));
  margin-bottom: calc(100vw / ( 375 / 36 )); }
  @media screen and (min-width: 768px) {
    .p-top-steps-note {
      text-align: center;
      font-size: 1.4rem;
      line-height: 180%;
      margin-bottom: 3em; } }
.p-top-steps_flow {
  border-top: calc(100vw / ( 375 / 10 )) solid #B0DBAF;
  border-bottom: calc(100vw / ( 375 / 10 )) solid #B0DBAF;
  background: url("../images/top/steps_bg.jpg") center no-repeat;
  background-size: cover;
  position: relative;
  padding: calc(100vw / ( 375 / 50 )) 0; }
  @media screen and (min-width: 768px) {
    .p-top-steps_flow {
      border-top-width: calc(100vw / ( 1440 / 15 ));
      border-bottom-width: calc(100vw / ( 1440 / 15 ));
      padding: calc(100vw / ( 1440 / 70 )) 0 calc(100vw / ( 1440 / 85 )); } }
  @media screen and (min-width: 1441px) {
    .p-top-steps_flow {
      border-top-width: 15px;
      border-bottom-width: 15px;
      padding: 70px 0 85px; } }
  .p-top-steps_flow:after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: #C0E0C5;
    mix-blend-mode: hard-light; }
  .p-top-steps_flow .forTtl {
    text-shadow: none;
    margin-bottom: calc(100vw / ( 375 / 36 )); }
    @media screen and (min-width: 768px) {
      .p-top-steps_flow .forTtl {
        margin-bottom: 25px; } }
    .p-top-steps_flow .forTtl .eng {
      color: #208C30; }
  .p-top-steps_flow .forTxt {
    text-align: center;
    line-height: 180%;
    margin-bottom: 1.5em; }
    .p-top-steps_flow .forTxt a {
      color: #208C30;
      text-decoration: underline;
      font-weight: bold; }
  .p-top-steps_flow .forSteps__item {
    position: relative;
    background: #fff;
    box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1);
    border-radius: 10px;
    padding: calc(100vw / ( 375 / 20 )) calc(100vw / ( 375 / 20 )) calc(100vw / ( 375 / 20 )) calc(100vw / ( 375 / 67 )); }
    .p-top-steps_flow .forSteps__item:not(:last-child) {
      margin-bottom: calc(100vw / ( 375 / 25 )); }
      @media screen and (min-width: 768px) {
        .p-top-steps_flow .forSteps__item:not(:last-child) {
          margin-bottom: 30px; } }
    @media screen and (min-width: 768px) {
      .p-top-steps_flow .forSteps__item {
        display: flex;
        align-items: center;
        padding: calc(100vw / ( 1440 / 35 )) calc(100vw / ( 1440 / 30 )) calc(100vw / ( 1440 / 35 )) calc(100vw / ( 1440 / 136 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-steps_flow .forSteps__item {
        padding: 35px 30px 35px 136px; } }
    .p-top-steps_flow .forSteps__item:before {
      content: "";
      display: block;
      position: absolute;
      z-index: 1;
      left: calc(100vw / ( 375 / 10 ));
      top: calc(-100vw / ( 375 / 25 ));
      width: calc(100vw / ( 375 / 40 ));
      height: calc(100% + calc(100vw / ( 375 / 50 ))); }
      @media screen and (min-width: 768px) {
        .p-top-steps_flow .forSteps__item:before {
          left: calc(100vw / ( 1440 / 24 ));
          top: -30px;
          width: calc(100vw / ( 1440 / 74 ));
          height: calc(100% + 64px); } }
      @media screen and (min-width: 1441px) {
        .p-top-steps_flow .forSteps__item:before {
          left: 24px;
          width: 74px; } }
    @media screen and (min-width: 768px) {
      .p-top-steps_flow .forSteps__item .c-btn-std {
        font-size: 2.4rem;
        padding-top: calc(100vw / ( 1440 / 21 ));
        padding-bottom: calc(100vw / ( 1440 / 21 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-steps_flow .forSteps__item .c-btn-std {
        padding-top: 21px;
        padding-bottom: 21px; } }
    .p-top-steps_flow .forSteps__item.step01:before {
      z-index: 3;
      top: calc(-100vw / ( 375 / 12 ));
      height: calc(100% + calc(100vw / ( 375 / 40 )));
      background: url("../images/top/steps_btm01.svg") center bottom no-repeat;
      background-size: 100% auto; }
      @media screen and (min-width: 768px) {
        .p-top-steps_flow .forSteps__item.step01:before {
          top: -11px;
          height: calc(100% + 37px); } }
    .p-top-steps_flow .forSteps__item.step02:before {
      background: #FF7A1C; }
    .p-top-steps_flow .forSteps__item.step02 .c-btn-std .in {
      position: relative; }
      @media screen and (min-width: 768px) {
        .p-top-steps_flow .forSteps__item.step02 .c-btn-std .in.dl {
          padding-left: 96px; } }
      .p-top-steps_flow .forSteps__item.step02 .c-btn-std .in.dl:before {
        content: "";
        display: block;
        position: absolute;
        left: 0;
        top: 50%;
        transform: translateY(-50%);
        background: url("../images/top/steps_icon_dl.svg") center no-repeat;
        background-size: contain; }
        @media screen and (min-width: 768px) {
          .p-top-steps_flow .forSteps__item.step02 .c-btn-std .in.dl:before {
            width: 80px;
            height: 52px; } }
    .p-top-steps_flow .forSteps__item.step03:before {
      z-index: 2;
      background: url("../images/top/steps_btm02.svg") center bottom no-repeat;
      background-size: 100% auto; }
    @media screen and (max-width: 767px) {
      .p-top-steps_flow .forSteps__item.step04 {
        padding-bottom: calc(100vw / ( 375 / 137 )); } }
    .p-top-steps_flow .forSteps__item.step04:before {
      background: #FFA668;
      height: calc(100% + calc(100vw / ( 375 / 37 ))); }
      @media screen and (min-width: 768px) {
        .p-top-steps_flow .forSteps__item.step04:before {
          height: calc(100% + 43px); } }
    @media screen and (max-width: 767px) {
      .p-top-steps_flow .forSteps__item.step04:after {
        content: "";
        display: block;
        position: absolute;
        width: calc(100vw / ( 375 / 181 ));
        height: calc(100vw / ( 375 / 117 ));
        background: url("../images/top/steps_flow_item04.svg") center bottom no-repeat;
        background-size: contain;
        bottom: 0;
        right: calc(100vw / ( 375 / 33 )); } }
  .p-top-steps_flow .forSteps_device {
    writing-mode: vertical-rl;
    position: absolute;
    top: 50%;
    transform: translateY(-55%);
    color: #fff;
    font-weight: 700;
    z-index: 4;
    font-size: calc(100vw / ( 375 / 16 ));
    left: calc(100vw / ( 375 / 22 )); }
    @media screen and (min-width: 768px) {
      .p-top-steps_flow .forSteps_device {
        font-size: 2.0rem;
        left: calc(100vw / ( 1440 / 48 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-steps_flow .forSteps_device {
        left: 50px; } }
  .p-top-steps_flow .forSteps_img {
    width: calc(100vw / ( 375 / 129 ));
    margin: 0 auto calc(100vw / ( 375 / 20 )); }
    @media screen and (min-width: 768px) {
      .p-top-steps_flow .forSteps_img {
        width: 141px;
        margin: 0 48px 0 0; } }
  .p-top-steps_flow .forSteps_ttl {
    font-weight: 700;
    margin-bottom: calc(100vw / ( 375 / 10 )); }
    @media screen and (min-width: 768px) {
      .p-top-steps_flow .forSteps_ttl {
        margin-bottom: 11px; } }
    .p-top-steps_flow .forSteps_ttl .num {
      background: #23A232;
      color: #fff;
      display: inline-block;
      letter-spacing: 0.15em;
      font-family: "Outfit", sans-serif;
      border-radius: 2px;
      font-size: calc(100vw / ( 375 / 13 ));
      margin-bottom: calc(100vw / ( 375 / 6 ));
      padding: calc(100vw / ( 375 / 5 )) calc(100vw / ( 375 / 10 )); }
      @media screen and (min-width: 768px) {
        .p-top-steps_flow .forSteps_ttl .num {
          padding: 5px 20px;
          margin-bottom: 6px;
          font-size: 1.5rem; } }
    .p-top-steps_flow .forSteps_ttl .title {
      display: block;
      line-height: 145%;
      font-size: calc(100vw / ( 375 / 21 )); }
      @media screen and (min-width: 768px) {
        .p-top-steps_flow .forSteps_ttl .title {
          line-height: 180%;
          font-size: 2.4rem; } }
  .p-top-steps_flow .forSteps_txt {
    line-height: 180%; }
    @media screen and (max-width: 767px) {
      .p-top-steps_flow .forSteps_txt {
        line-height: 160%; } }
    .p-top-steps_flow .forSteps_txt .case {
      font-weight: 700;
      font-size: calc(100vw / ( 375 / 18 ));
      margin-bottom: calc(100vw / ( 375 / 10 )); }
      @media screen and (min-width: 768px) {
        .p-top-steps_flow .forSteps_txt .case {
          font-size: 1.8rem;
          margin-bottom: 10px; } }
      @media screen and (min-width: 768px) {
        .p-top-steps_flow .forSteps_txt .caseBox {
          width: calc((100% - calc(100vw / ( 1440 / 40 ))) / 2); } }
      @media screen and (min-width: 1441px) {
        .p-top-steps_flow .forSteps_txt .caseBox {
          width: calc((100% - 40px) / 2); } }
      @media screen and (max-width: 767px) {
        .p-top-steps_flow .forSteps_txt .caseBox:not(:last-child) {
          margin-bottom: calc(100vw / ( 375 / 15 )); } }
      @media screen and (min-width: 768px) {
        .p-top-steps_flow .forSteps_txt .caseBoxWrap {
          display: flex;
          flex-wrap: wrap;
          column-gap: calc(100vw / ( 1440 / 40 )); } }
      @media screen and (min-width: 1441px) {
        .p-top-steps_flow .forSteps_txt .caseBoxWrap {
          column-gap: 40px; } }
    @media screen and (min-width: 768px) {
      .p-top-steps_flow .forSteps_txt .numList {
        margin-bottom: 28px; } }
    .p-top-steps_flow .forSteps_txt .numList__item {
      position: relative;
      padding-left: 2em; }
      .p-top-steps_flow .forSteps_txt .numList__item:not(:last-child) {
        margin-bottom: 0.5em; }
      .p-top-steps_flow .forSteps_txt .numList__item .num {
        position: absolute;
        left: 0;
        top: 0.2em;
        background: #F56600;
        border-radius: 50%;
        display: flex;
        justify-content: center;
        align-items: center;
        color: #fff;
        font-family: "Outfit", sans-serif;
        font-weight: 700;
        width: 1.5625em;
        height: 1.5625em; }
        @media screen and (max-width: 767px) {
          .p-top-steps_flow .forSteps_txt .numList__item .num {
            top: 0.1em;
            font-size: calc(100vw / ( 375 / 14 )); } }
.p-top-steps_links {
  background: #E7F2E4;
  padding: calc(100vw / ( 375 / 40 )) 0 calc(100vw / ( 375 / 50 )); }
  @media screen and (min-width: 768px) {
    .p-top-steps_links {
      padding: calc(100vw / ( 1440 / 65 )) 0 calc(100vw / ( 1440 / 80 )); } }
  @media screen and (min-width: 1441px) {
    .p-top-steps_links {
      padding: 65px 0 80px; } }
  @media screen and (min-width: 768px) {
    .p-top-steps_links .items {
      display: flex;
      justify-content: center;
      flex-wrap: wrap;
      column-gap: calc(100vw / ( 1440 / 43 ));
      margin-right: -1px; } }
  @media screen and (min-width: 1441px) {
    .p-top-steps_links .items {
      column-gap: 43px; } }
  .p-top-steps_links .items .item {
    border: 1px solid #23A232;
    background: #fff;
    border-radius: 10px;
    padding: calc(100vw / ( 375 / 20 )); }
    @media screen and (min-width: 768px) {
      .p-top-steps_links .items .item {
        width: calc((100% - calc(100vw / ( 1440 / 86 ))) / 3);
        padding: calc(100vw / ( 1440 / 30 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-steps_links .items .item {
        width: calc((100% - 86px) / 3);
        padding: 30px; } }
    @media screen and (min-width: 768px) {
      .p-top-steps_links .items .item.only {
        width: calc(100vw / ( 1440 / 800 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-steps_links .items .item.only {
        width: 800px; } }
    @media screen and (min-width: 768px) {
      .p-top-steps_links .items .item.only a {
        display: flex;
        align-items: center; } }
    @media screen and (min-width: 768px) {
      .p-top-steps_links .items .item.only a .forIcon {
        margin-bottom: 0;
        margin-right: calc(100vw / ( 1440 / 16 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-steps_links .items .item.only a .forIcon {
        margin-right: 16px; } }
    @media screen and (min-width: 768px) {
      .p-top-steps_links .items .item.only a .forDetail_ttl {
        margin-bottom: calc(100vw / ( 1440 / 8 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-steps_links .items .item.only a .forDetail_ttl {
        margin-bottom: 8px; } }
    @media screen and (max-width: 767px) {
      .p-top-steps_links .items .item:not(:last-child) {
        margin-bottom: calc(100vw / ( 375 / 20 )); } }
    .p-top-steps_links .items .item .forIcon {
      display: flex;
      justify-content: center;
      margin-bottom: 18px; }
      @media screen and (max-width: 767px) {
        .p-top-steps_links .items .item .forIcon {
          display: none; } }
      .p-top-steps_links .items .item .forIcon img {
        width: auto;
        height: 66px; }
    .p-top-steps_links .items .item .forDetail_ttl {
      color: #208C30;
      font-weight: 700;
      line-height: 180%;
      display: inline-block;
      position: relative;
      padding-right: 1.5em;
      margin-bottom: 0.6em;
      font-size: calc(100vw / ( 375 / 18 )); }
      @media screen and (min-width: 768px) {
        .p-top-steps_links .items .item .forDetail_ttl {
          font-size: 2.0rem; } }
      @media screen and (max-width: 767px) {
        .p-top-steps_links .items .item .forDetail_ttl {
          padding-left: calc(100vw / ( 375 / 44 )); } }
      .p-top-steps_links .items .item .forDetail_ttl:after {
        content: "";
        display: block;
        position: absolute;
        right: 0;
        top: 50%;
        transform: translateY(-50%);
        width: 1em;
        height: 1em;
        background: url("../images/icon_arrow-circle.png") center no-repeat;
        background-size: contain; }
      @media screen and (max-width: 767px) {
        .p-top-steps_links .items .item .forDetail_ttl:before {
          content: "";
          display: block;
          position: absolute;
          left: 0;
          top: 50%;
          transform: translateY(-50%);
          width: calc(100vw / ( 375 / 34 ));
          height: calc(100vw / ( 375 / 43 ));
          background-position: center;
          background-repeat: no-repeat;
          background-size: contain; } }
      .p-top-steps_links .items .item .forDetail_ttl.ttl01:before {
        background-image: url("../images/top/steps_link_icon01.png"); }
      .p-top-steps_links .items .item .forDetail_ttl.ttl02:before {
        background-image: url("../images/top/steps_link_icon02.png"); }
      .p-top-steps_links .items .item .forDetail_ttl.ttl03:before {
        background-image: url("../images/top/steps_link_icon03.png"); }
    .p-top-steps_links .items .item .forDetail_txt {
      line-height: 180%; }
      @media screen and (min-width: 768px) {
        .p-top-steps_links .items .item .forDetail_txt {
          font-size: 1.5rem; } }
.p-top-info {
  background: #F3F3F3;
  padding: calc(100vw / ( 375 / 70 )) 0; }
  @media screen and (min-width: 768px) {
    .p-top-info {
      padding: calc(100vw / ( 1440 / 80 )) 0; } }
  @media screen and (min-width: 1441px) {
    .p-top-info {
      padding: 80px 0; } }
  .p-top-info_ttl {
    text-align: center;
    color: #208C30;
    font-weight: 700;
    font-size: calc(100vw / ( 375 / 28 ));
    margin-bottom: calc(100vw / ( 375 / 33 )); }
    @media screen and (min-width: 768px) {
      .p-top-info_ttl {
        font-size: 3.4rem;
        margin-bottom: calc(100vw / ( 1440 / 50 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-info_ttl {
        margin-bottom: 50px; } }
  .p-top-info_data {
    border: 2px solid #23A232;
    border-radius: 10px;
    background: #fff;
    padding: calc(100vw / ( 375 / 20 )); }
    @media screen and (min-width: 768px) {
      .p-top-info_data {
        padding: calc(100vw / ( 1440 / 35 )) calc(100vw / ( 1440 / 50 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-info_data {
        padding: 35px 50px; } }
    @media screen and (min-width: 768px) {
      .p-top-info_data__inner {
        display: flex;
        flex-wrap: wrap;
        column-gap: calc(100vw / ( 1440 / 30 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-info_data__inner {
        column-gap: 30px; } }
    @media screen and (min-width: 768px) {
      .p-top-info_data__inner .c-table-std {
        width: calc((100% - calc(100vw / ( 1440 / 30 ))) / 2); } }
    @media screen and (min-width: 1441px) {
      .p-top-info_data__inner .c-table-std {
        width: calc((100% - 30px) / 2); } }
    .p-top-info_data + .p-top-info_data {
      margin-top: calc(100vw / ( 375 / 33 )); }
      @media screen and (min-width: 768px) {
        .p-top-info_data + .p-top-info_data {
          margin-top: calc(100vw / ( 1440 / 30 )); } }
      @media screen and (min-width: 1441px) {
        .p-top-info_data + .p-top-info_data {
          margin-top: 30px; } }
    .p-top-info_data .forTtl {
      color: #208C30;
      font-weight: 700;
      font-size: calc(100vw / ( 375 / 20 ));
      margin-bottom: calc(100vw / ( 375 / 15 )); }
      @media screen and (min-width: 768px) {
        .p-top-info_data .forTtl {
          font-size: 2.2rem;
          margin-bottom: 1.2em; } }
    @media screen and (max-width: 767px) {
      .p-top-info_data .c-table-std + .c-table-std {
        border-top: none; } }
  .p-top-info_notes {
    margin-top: calc(100vw / ( 375 / 33 )); }
    @media screen and (min-width: 768px) {
      .p-top-info_notes {
        margin-top: calc(100vw / ( 1440 / 50 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-info_notes {
        margin-top: 50px; } }
    .p-top-info_notes__item {
      line-height: 160%;
      font-size: 1.4rem; }
      @media screen and (max-width: 767px) {
        .p-top-info_notes__item {
          font-size: calc(100vw / ( 375 / 14 )); } }
      .p-top-info_notes__item:not(:last-child) {
        margin-bottom: 0.5em; }
.p-top-online {
  background: url("../images/top/online_bg_sp.jpg") center no-repeat;
  background-size: cover;
  position: relative;
  text-align: center;
  padding: calc(100vw / ( 375 / 70 )) 0; }
  @media screen and (min-width: 768px) {
    .p-top-online {
      background-image: url("../images/top/online_bg.jpg");
      padding: calc(100vw / ( 1440 / 70 )) 0; } }
  @media screen and (min-width: 1441px) {
    .p-top-online {
      padding: 70px 0; } }
  .p-top-online:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(35, 162, 50, 0.8); }
    @media screen and (max-width: 767px) {
      .p-top-online:after {
        background: rgba(35, 162, 50, 0.7); } }
  .p-top-online_ttl {
    color: #fff;
    margin-bottom: calc(100vw / ( 375 / 20 )); }
    @media screen and (min-width: 768px) {
      .p-top-online_ttl {
        margin-bottom: calc(100vw / ( 1440 / 35 )); } }
    @media screen and (min-width: 1441px) {
      .p-top-online_ttl {
        margin-bottom: 35px; } }
  .p-top-online_txt {
    color: #fff;
    margin-bottom: 3em; }
    @media screen and (max-width: 767px) {
      .p-top-online_txt {
        line-height: 1.5; } }
  .p-top-online_items {
    display: flex;
    flex-wrap: wrap; }
    @media screen and (min-width: 768px) {
      .p-top-online_items {
        column-gap: 10px;
        margin-bottom: 10px; } }
    .p-top-online_items__item {
      position: relative;
      background: #fff;
      border-radius: 10px;
      text-align: left;
      padding: calc(100vw / ( 375 / 10 ));
      margin-bottom: 4%; }
      @media screen and (max-width: 767px) {
        .p-top-online_items__item {
          width: 48%; }
          .p-top-online_items__item:nth-child(odd) {
            margin-right: 4%; } }
      @media screen and (min-width: 768px) {
        .p-top-online_items__item {
          width: calc((100% - 30px) / 4);
          margin-bottom: 40px;
          display: flex;
          flex-wrap: wrap;
          align-items: center;
          justify-content: space-between;
          padding: calc(100vw / ( 1440 / 20 )) calc(100vw / ( 1440 / 12 )); } }
      @media screen and (min-width: 1441px) {
        .p-top-online_items__item {
          padding: 20px 12px; } }
      .p-top-online_items__item .cost {
        position: absolute;
        top: 0;
        color: #fff;
        display: flex;
        justify-content: center;
        align-items: center;
        background: #F56600;
        border-radius: 50%;
        transform: translateY(-40%);
        font-weight: 900;
        letter-spacing: 0.06em;
        width: calc(100vw / ( 375 / 45 ));
        height: calc(100vw / ( 375 / 45 ));
        font-size: calc(100vw / ( 375 / 14 ));
        right: calc(100vw / ( 375 / 5 )); }
        @media screen and (min-width: 768px) {
          .p-top-online_items__item .cost {
            width: calc(100vw / ( 1440 / 63 ));
            height: calc(100vw / ( 1440 / 63 ));
            right: calc(100vw / ( 1440 / 10 ));
            font-size: calc(100vw / ( 1440 / 16 ));
            transform: translateY(-60%); } }
        @media screen and (min-width: 1441px) {
          .p-top-online_items__item .cost {
            width: 63px;
            height: 63px;
            right: 10px;
            font-size: 1.6rem; } }
      @media screen and (max-width: 767px) {
        .p-top-online_items__item .forIcon {
          width: calc(100vw / ( 375 / 60 ));
          margin: 0 auto calc(100vw / ( 375 / 10 )); } }
      @media screen and (min-width: 768px) {
        .p-top-online_items__item .forIcon {
          width: calc(100vw / ( 1440 / 53 )); } }
      @media screen and (min-width: 1441px) {
        .p-top-online_items__item .forIcon {
          width: 53px; } }
      @media screen and (min-width: 768px) {
        .p-top-online_items__item .forDetail {
          width: calc(100% - calc(100vw / ( 1440 / 65 ))); } }
      @media screen and (min-width: 1441px) {
        .p-top-online_items__item .forDetail {
          width: calc(100% - 65px); } }
      .p-top-online_items__item .forDetail_ttl {
        color: #F56600;
        font-weight: 700;
        font-size: calc(100vw / ( 375 / 16 )); }
        @media screen and (min-width: 768px) {
          .p-top-online_items__item .forDetail_ttl {
            line-height: 1.4;
            font-size: calc(100vw / ( 1440 / 22 )); } }
        @media screen and (min-width: 1441px) {
          .p-top-online_items__item .forDetail_ttl {
            font-size: 2.0rem; } }
        @media screen and (max-width: 767px) {
          .p-top-online_items__item .forDetail_ttl {
            text-align: center; } }
      .p-top-online_items__item .forDetail_txt {
        line-height: 160%; }
        @media screen and (min-width: 768px) {
          .p-top-online_items__item .forDetail_txt {
            font-size: 1.5rem; } }
  @media screen and (max-width: 767px) {
    .p-top-online_link {
      padding-top: calc(100vw / ( 375 / 20 )); } }
  .p-top-online_link .forTtl {
    color: #fff;
    display: inline-block;
    font-weight: 700;
    margin-bottom: 1em;
    text-shadow: 0px 0px 6px rgba(0, 0, 0, 0.45);
    letter-spacing: 0.02em;
    position: relative;
    padding: 0 1em; }
    @media screen and (min-width: 768px) {
      .p-top-online_link .forTtl {
        font-size: 1.5rem; } }
    .p-top-online_link .forTtl:before, .p-top-online_link .forTtl:after {
      content: "";
      display: block;
      position: absolute;
      height: 1.2em;
      width: 2px;
      background: #fff;
      top: 50%; }
    .p-top-online_link .forTtl:before {
      left: 0;
      transform: rotate(-30deg) translateY(-50%); }
    .p-top-online_link .forTtl:after {
      right: 0;
      transform: rotate(30deg) translateY(-50%); }
.p-top-coupon {
  position: relative; }
  .p-top-coupon:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: calc(50% - 290px);
    background: #FFF5EA; }
    @media screen and (max-width: 767px) {
      .p-top-coupon:after {
        width: calc(100vw / ( 375 / 112 )); } }
  @media screen and (max-width: 767px) {
    .p-top-coupon__inner {
      width: calc(100vw / ( 375 / 305 )); } }
  @media screen and (min-width: 768px) {
    .p-top-coupon__inner {
      display: flex;
      justify-content: flex-end;
      position: relative;
      padding: calc(100vw / ( 1440 / 115 )) 0 calc(100vw / ( 1440 / 165 )); } }
  @media screen and (min-width: 1441px) {
    .p-top-coupon__inner {
      padding: 115px 0 165px; } }
  @media screen and (max-width: 767px) {
    .p-top-coupon .area-img {
      margin: 0 calc(-100vw / ( 375 / 35 )); } }
  @media screen and (min-width: 768px) {
    .p-top-coupon .area-img {
      position: absolute;
      width: 47.76785%;
      left: calc(-100vw / ( 1440 / 104 ));
      top: 50%;
      transform: translateY(-50%); } }
  @media screen and (min-width: 1441px) {
    .p-top-coupon .area-img {
      left: -104px; } }
  @media screen and (max-width: 767px) {
    .p-top-coupon .area-txt {
      padding: calc(100vw / ( 375 / 40 )) 0 calc(100vw / ( 375 / 60 )); } }
  @media screen and (min-width: 768px) {
    .p-top-coupon .area-txt {
      width: 55.8%; } }
  .p-top-coupon .area-txt .forTtl {
    color: #F56600;
    font-weight: 700;
    font-size: calc(100vw / ( 375 / 24 ));
    margin-bottom: calc(100vw / ( 375 / 20 )); }
    @media screen and (min-width: 768px) {
      .p-top-coupon .area-txt .forTtl {
        font-size: 2.6rem;
        margin-bottom: 23px; } }
  .p-top-coupon .area-txt .forTxt {
    margin-bottom: calc(100vw / ( 375 / 20 )); }
    @media screen and (min-width: 768px) {
      .p-top-coupon .area-txt .forTxt {
        margin-bottom: 23px; } }
    .p-top-coupon .area-txt .forTxt p {
      line-height: 180%; }
      .p-top-coupon .area-txt .forTxt p:not(:last-child) {
        margin-bottom: 1em; }

/*========== p-merit.scss ==========*/
.p-merit-main {
  position: relative; }
  @media screen and (max-width: 767px) {
    .p-merit-main {
      background: url("../images/merit/main_bg_sp.png") center no-repeat;
      background-size: cover;
      padding: calc(100vw / ( 375 / 40 )) 0; } }
  @media screen and (min-width: 768px) {
    .p-merit-main:before, .p-merit-main:after {
      content: "";
      display: block;
      position: absolute;
      height: 100%;
      width: 50%;
      top: 0; } }
  @media screen and (min-width: 768px) {
    .p-merit-main:before {
      background: url("../images/merit/main_bg_l.png") center no-repeat;
      background-size: cover;
      left: 0; } }
  @media screen and (min-width: 768px) {
    .p-merit-main:after {
      background: url("../images/merit/main_bg_r.jpg") center no-repeat;
      background-size: cover;
      background-position: center -80px;
      right: 0; } }
  @media screen and (min-width: 768px) {
    .p-merit-main__inner {
      width: 50%;
      padding: calc(100vw / ( 1440 / 60 )) calc(100vw / ( 1440 / 44 )) calc(100vw / ( 1440 / 60 )) calc(100vw / ( 1440 / 44 )); } }
  @media screen and (min-width: 1441px) {
    .p-merit-main__inner {
      padding: 60px 44px 100px 44px; } }
  .p-merit-main__inner .forLead {
    position: relative;
    display: block;
    border: 3px solid #23A232;
    background: #fff;
    font-weight: 700;
    color: #208C30;
    line-height: 140%;
    border-radius: 6px;
    font-size: calc(100vw / ( 375 / 15 ));
    padding: calc(100vw / ( 375 / 10 )) calc(100vw / ( 375 / 12 )) calc(100vw / ( 375 / 13 )); }
    @media screen and (min-width: 768px) {
      .p-merit-main__inner .forLead {
        display: inline-block;
        font-size: 1.6rem;
        padding: 16px;
        margin-bottom: 13px; } }
    .p-merit-main__inner .forLead:after {
      content: "";
      display: block;
      position: absolute;
      left: 40%;
      background: url("../images/merit/main_coupon_after.png") center bottom no-repeat;
      background-size: contain;
      width: calc(100vw / ( 375 / 32 ));
      height: calc(100vw / ( 375 / 18 ));
      bottom: calc(-100vw / ( 375 / 17 )); }
      @media screen and (min-width: 768px) {
        .p-merit-main__inner .forLead:after {
          width: 33px;
          height: 18px;
          bottom: -18px; } }
    .p-merit-main__inner .forLead .in {
      display: inline-block;
      position: relative;
      padding-left: calc(100vw / ( 375 / 60 )); }
      @media screen and (min-width: 768px) {
        .p-merit-main__inner .forLead .in {
          padding-left: 72px; } }
      .p-merit-main__inner .forLead .in:before {
        content: "";
        display: block;
        position: absolute;
        left: 0;
        top: 50%;
        transform: translateY(-50%);
        background: url("../images/merit/merit_coupon_icon.png") center no-repeat;
        background-size: contain;
        width: calc(100vw / ( 375 / 48 ));
        height: calc(100vw / ( 375 / 48 )); }
        @media screen and (min-width: 768px) {
          .p-merit-main__inner .forLead .in:before {
            width: 58px;
            height: 46px; } }
  .p-merit-main__inner .forTtl {
    font-weight: 700;
    padding: calc(100vw / ( 375 / 25 )) 0 calc(100vw / ( 375 / 10 )); }
    @media screen and (min-width: 768px) {
      .p-merit-main__inner .forTtl {
        padding: 16px 0; } }
    .p-merit-main__inner .forTtl .coupon {
      display: inline-block;
      background: #FBE32B;
      border-radius: 3px;
      padding: calc(100vw / ( 375 / 7 )) calc(100vw / ( 375 / 12 ));
      margin-bottom: calc(100vw / ( 375 / 15 )); }
      @media screen and (min-width: 768px) {
        .p-merit-main__inner .forTtl .coupon {
          padding: 9px 12px;
          font-size: 1.7rem;
          margin-bottom: 13px; } }
    .p-merit-main__inner .forTtl .title {
      display: block;
      line-height: 140%;
      letter-spacing: -0.01em;
      font-size: calc(100vw / ( 375 / 28 )); }
      @media screen and (min-width: 768px) {
        .p-merit-main__inner .forTtl .title {
          font-size: 3.2rem; } }
      .p-merit-main__inner .forTtl .title .in {
        margin-right: 0.5em; }
      .p-merit-main__inner .forTtl .title .price {
        display: block;
        letter-spacing: 0; }
        @media screen and (max-width: 767px) {
          .p-merit-main__inner .forTtl .title .price {
            text-align: right;
            font-size: calc(100vw / ( 375 / 16 )); } }
        @media screen and (min-width: 768px) {
          .p-merit-main__inner .forTtl .title .price {
            display: inline-block;
            font-size: 1.6rem; } }
        .p-merit-main__inner .forTtl .title .price .num {
          font-family: "Albert Sans", sans-serif;
          font-size: calc(100vw / ( 375 / 32 )); }
          @media screen and (min-width: 768px) {
            .p-merit-main__inner .forTtl .title .price .num {
              letter-spacing: -0.01em;
              font-size: 3.5rem; } }
  .p-merit-main__inner .forImg {
    border-radius: 10px;
    overflow: hidden; }
    @media screen and (min-width: 768px) {
      .p-merit-main__inner .forImg {
        display: none; } }
.p-merit-happen {
  background: #EFF8E7;
  padding: calc(100vw / ( 375 / 40 )) 0 calc(100vw / ( 375 / 50 )); }
  @media screen and (min-width: 768px) {
    .p-merit-happen {
      padding: calc(100vw / ( 1440 / 90 )) 0; } }
  @media screen and (min-width: 1441px) {
    .p-merit-happen {
      padding: 90px 0; } }
  .p-merit-happen_ttl {
    color: #208C30;
    font-weight: 900;
    text-align: center;
    line-height: 145%;
    font-size: calc(100vw / ( 375 / 30 ));
    margin-bottom: calc(100vw / ( 375 / 35 )); }
    @media screen and (min-width: 768px) {
      .p-merit-happen_ttl {
        font-size: 3.6rem;
        margin-bottom: 46px; } }
  .p-merit-happen_item {
    background: #fff;
    border-radius: 10px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: calc(100vw / ( 375 / 25 )) calc(100vw / ( 375 / 20 )) 0; }
    @media screen and (min-width: 768px) {
      .p-merit-happen_item {
        position: relative;
        justify-content: flex-start;
        width: calc((100% - calc(100vw / ( 1440 / 74 ))) / 3);
        padding: calc(100vw / ( 1440 / 30 )) calc(100vw / ( 1440 / 30 )) calc(100vw / ( 1440 / 90 )); } }
    @media screen and (min-width: 1441px) {
      .p-merit-happen_item {
        width: calc((100% - 74px) / 3);
        padding: 30px 30px 70px; } }
    @media screen and (min-width: 768px) and (max-width: 930px) {
      .p-merit-happen_item {
        padding-bottom: calc(100vw / ( 1440 / 100 )); } }
    @media screen and (max-width: 767px) {
      .p-merit-happen_item:not(:last-child) {
        margin-bottom: calc(100vw / ( 375 / 25 )); } }
    @media screen and (min-width: 768px) {
      .p-merit-happen_itemWrap {
        display: flex;
        flex-wrap: wrap;
        column-gap: calc(100vw / ( 1440 / 37 )); } }
    @media screen and (min-width: 1441px) {
      .p-merit-happen_itemWrap {
        column-gap: 37px; } }
    .p-merit-happen_item .forTtl {
      order: 3;
      background: #23A232;
      line-height: 180%;
      display: flex;
      justify-content: center;
      align-items: center;
      position: relative;
      padding: 1em;
      margin: 0 calc(-100vw / ( 375 / 20 )); }
      @media screen and (max-width: 767px) {
        .p-merit-happen_item .forTtl {
          font-size: calc(100vw / ( 375 / 20 )); } }
      @media screen and (min-width: 768px) {
        .p-merit-happen_item .forTtl {
          position: absolute;
          left: 0;
          bottom: 0;
          width: calc(100% + calc(100vw / ( 1440 / 60 )));
          margin: 0 calc(-100vw / ( 1440 / 30 )); } }
      @media screen and (min-width: 1441px) {
        .p-merit-happen_item .forTtl {
          margin: 0 -30px;
          width: calc(100% + 60px); } }
      .p-merit-happen_item .forTtl:after {
        content: "";
        display: block;
        position: absolute;
        top: 0;
        left: 50%;
        transform: translateX(-50%);
        border-style: solid;
        border-color: #fff transparent transparent transparent;
        border-width: calc(100vw / ( 375 / 13 )) calc(100vw / ( 375 / 9 )) 0 calc(100vw / ( 375 / 9 )); }
        @media screen and (min-width: 768px) {
          .p-merit-happen_item .forTtl:after {
            border-width: 13px 9px 0 9px; } }
      .p-merit-happen_item .forTtl .in {
        display: inline-block;
        position: relative;
        font-weight: 700;
        color: #fff;
        padding-left: 2em; }
        @media screen and (min-width: 768px) {
          .p-merit-happen_item .forTtl .in {
            font-size: 2.0rem; } }
        @media screen and (min-width: 768px) and (max-width: 800px) {
          .p-merit-happen_item .forTtl .in {
            font-size: 1.65rem;
            letter-spacing: -0.01em;
            padding-left: 1.8em; } }
        @media screen and (min-width: 801px) and (max-width: 930px) {
          .p-merit-happen_item .forTtl .in {
            font-size: 1.8rem; } }
        .p-merit-happen_item .forTtl .in:before {
          content: "";
          display: block;
          position: absolute;
          left: 0;
          top: 50%;
          transform: translateY(-50%);
          width: 1.4em;
          height: 1.4em;
          background: url("../images/merit/mert_happen_icon.svg") center no-repeat;
          background-size: contain; }
    .p-merit-happen_item .forTxt {
      order: 2;
      line-height: 170%;
      font-weight: 700;
      margin-bottom: 1em; }
    .p-merit-happen_item .forImg {
      order: 1;
      margin: 0 auto calc(100vw / ( 375 / 20 ));
      width: calc(100vw / ( 375 / 220 )); }
      @media screen and (min-width: 768px) {
        .p-merit-happen_item .forImg {
          width: 68.7679%;
          margin-bottom: calc(100vw / ( 1440 / 20 )); } }
      @media screen and (min-width: 1441px) {
        .p-merit-happen_item .forImg {
          margin-bottom: 20px; } }
.p-merit-comfy {
  background: #FFF5EA;
  position: relative;
  padding: calc(100vw / ( 375 / 70 )) 0; }
  @media screen and (min-width: 768px) {
    .p-merit-comfy {
      padding: calc(100vw / ( 1440 / 90 )) 0 calc(100vw / ( 1440 / 100 )); } }
  @media screen and (min-width: 1441px) {
    .p-merit-comfy {
      padding: 90px 0 100px; } }
  .p-merit-comfy:after {
    content: "";
    display: block;
    position: absolute;
    right: 0;
    top: 0;
    height: 100%;
    background: rgba(245, 102, 0, 0.1);
    width: calc(100vw / ( 375 / 120 )); }
    @media screen and (min-width: 768px) {
      .p-merit-comfy:after {
        width: calc(50% - 290px); } }
  .p-merit-comfy_ttl {
    color: #F56600;
    font-weight: 900;
    text-align: center;
    line-height: 145%;
    font-size: calc(100vw / ( 375 / 30 ));
    margin-bottom: 1em; }
    @media screen and (min-width: 768px) {
      .p-merit-comfy_ttl {
        font-size: 3.6rem;
        margin-bottom: 50px; } }
  .p-merit-comfy_item {
    background: #fff;
    border-radius: 10px;
    display: flex;
    overflow: hidden;
    position: relative; }
    @media screen and (max-width: 767px) {
      .p-merit-comfy_item {
        flex-direction: column;
        padding: calc(100vw / ( 375 / 30 )) calc(100vw / ( 375 / 20 )) calc(100vw / ( 375 / 20 )); } }
    .p-merit-comfy_item:not(:last-child) {
      margin-bottom: calc(100vw / ( 375 / 25 )); }
      @media screen and (min-width: 768px) {
        .p-merit-comfy_item:not(:last-child) {
          margin-bottom: calc(100vw / ( 1440 / 40 )); } }
      @media screen and (min-width: 1441px) {
        .p-merit-comfy_item:not(:last-child) {
          margin-bottom: 40px; } }
    .p-merit-comfy_item:after {
      content: "";
      top: 0;
      right: 0;
      border-bottom: 100px solid transparent;
      border-right: 104px solid #F56600;
      position: absolute; }
      @media screen and (max-width: 767px) {
        .p-merit-comfy_item:after {
          border-bottom-width: calc(100vw / ( 375 / 100 ));
          border-right-width: calc(100vw / ( 375 / 104 )); } }
    @media screen and (min-width: 768px) {
      .p-merit-comfy_item .forImg {
        width: 50%;
        display: flex; } }
    @media screen and (max-width: 767px) {
      .p-merit-comfy_item .forImg {
        padding: calc(100vw / ( 375 / 20 )) 0;
        order: 2; } }
    .p-merit-comfy_item .forImg img {
      object-fit: cover; }
    .p-merit-comfy_item .forTxt {
      position: relative; }
      @media screen and (max-width: 767px) {
        .p-merit-comfy_item .forTxt {
          display: contents; } }
      @media screen and (min-width: 768px) {
        .p-merit-comfy_item .forTxt {
          width: 50%;
          padding: calc(100vw / ( 1440 / 60 )) calc(100vw / ( 1440 / 120 )) calc(100vw / ( 1440 / 60 )) calc(100vw / ( 1440 / 90 )); } }
      @media screen and (min-width: 1441px) {
        .p-merit-comfy_item .forTxt {
          padding: 60px 40px 60px 90px; } }
      .p-merit-comfy_item .forTxt:before {
        content: "";
        display: block;
        position: absolute;
        right: 0;
        bottom: 0;
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain; }
      .p-merit-comfy_item .forTxt.item01:before {
        background-image: url("../images/merit/comfy_icon01.png"); }
        @media screen and (min-width: 768px) {
          .p-merit-comfy_item .forTxt.item01:before {
            width: 86px;
            height: 86px;
            right: 25px;
            bottom: 10px; } }
      .p-merit-comfy_item .forTxt.item02:before {
        background-image: url("../images/merit/comfy_icon02.png"); }
        @media screen and (min-width: 768px) {
          .p-merit-comfy_item .forTxt.item02:before {
            width: 73px;
            height: 73px;
            right: 38px;
            bottom: 24px; } }
      .p-merit-comfy_item .forTxt_ttl {
        line-height: 160%;
        font-weight: 700;
        font-size: 2.6rem; }
        @media screen and (max-width: 767px) {
          .p-merit-comfy_item .forTxt_ttl {
            font-size: calc(100vw / ( 375 / 23 ));
            line-height: 148%;
            order: 1;
            padding-right: calc(100vw / ( 375 / 60 )); } }
        .p-merit-comfy_item .forTxt_ttl .num {
          line-height: 1;
          color: #fff;
          position: absolute;
          z-index: 2;
          right: calc(100vw / ( 375 / 10 ));
          top: calc(100vw / ( 375 / 10 ));
          display: flex;
          justify-content: flex-end;
          align-items: center;
          font-family: "Outfit", sans-serif;
          letter-spacing: 0.05em;
          font-weight: 600;
          width: 2em;
          font-size: calc(100vw / ( 375 / 33 )); }
          @media screen and (min-width: 768px) {
            .p-merit-comfy_item .forTxt_ttl .num {
              right: 12px;
              top: 12px;
              font-size: 3.3rem; } }
          .p-merit-comfy_item .forTxt_ttl .num:after {
            content: "";
            display: block;
            height: 3px;
            width: 21px;
            position: absolute;
            right: 0;
            bottom: -10px;
            background: #fff; }
            @media screen and (max-width: 767px) {
              .p-merit-comfy_item .forTxt_ttl .num:after {
                width: calc(100vw / ( 375 / 21 ));
                height: calc(100vw / ( 375 / 3 )); } }
      @media screen and (max-width: 767px) {
        .p-merit-comfy_item .forTxt_txt {
          order: 3; } }
      @media screen and (min-width: 768px) {
        .p-merit-comfy_item .forTxt_txt {
          padding: 22px 0; } }
      .p-merit-comfy_item .forTxt_txt p {
        line-height: 180%; }
        @media screen and (min-width: 768px) {
          .p-merit-comfy_item .forTxt_txt p:not(:last-child) {
            margin-bottom: 0.5em; } }
    @media screen and (min-width: 768px) {
      .p-merit-comfy_item:nth-child(even) {
        flex-direction: row-reverse; }
        .p-merit-comfy_item:nth-child(even):after {
          right: auto;
          left: 0;
          border-right: none;
          border-bottom: 100px solid transparent;
          border-left: 104px solid #F56600; }
        .p-merit-comfy_item:nth-child(even) .num {
          right: auto;
          left: 10px;
          justify-content: flex-start; }
          .p-merit-comfy_item:nth-child(even) .num:after {
            right: auto;
            left: 0; } }
    @media screen and (min-width: 768px) {
      .p-merit-comfy_item:nth-child(even) .forTxt {
        padding-left: calc(100vw / ( 1440 / 120 )); } }
    @media screen and (min-width: 1441px) {
      .p-merit-comfy_item:nth-child(even) .forTxt {
        padding-left: 90px; } }
.p-merit-voice {
  background: url("../images/merit/voice_bg_sp.jpg") center no-repeat;
  background-size: cover;
  padding: calc(100vw / ( 375 / 70 )) 0; }
  @media screen and (min-width: 768px) {
    .p-merit-voice {
      background-image: url("../images/merit/voice_bg.jpg");
      padding: calc(100vw / ( 1440 / 60 )) 0 calc(100vw / ( 1440 / 70 )); } }
  @media screen and (min-width: 1441px) {
    .p-merit-voice {
      padding: 60px 0 70px; } }
  .p-merit-voice_ttl {
    text-align: center;
    font-weight: 700;
    color: #208C30;
    line-height: 145%;
    font-size: calc(100vw / ( 375 / 36 ));
    margin-bottom: calc(100vw / ( 375 / 35 )); }
    @media screen and (min-width: 768px) {
      .p-merit-voice_ttl {
        font-size: 3.6rem;
        margin-bottom: 55px; } }
  @media screen and (max-width: 767px) {
    .p-merit-voice_items {
      padding: 0 calc(100vw / ( 375 / 20 )); } }
  @media screen and (min-width: 768px) {
    .p-merit-voice_items {
      display: flex;
      flex-wrap: wrap;
      column-gap: calc(100vw / ( 1440 / 37 )); } }
  @media screen and (min-width: 1441px) {
    .p-merit-voice_items {
      column-gap: 37px; } }
  .p-merit-voice_items__item {
    background: #fff;
    border-radius: 10px;
    padding: calc(100vw / ( 375 / 20 )); }
    @media screen and (min-width: 768px) {
      .p-merit-voice_items__item {
        width: calc((100% - calc(100vw / ( 1440 / 74 ))) / 3);
        padding: calc(100vw / ( 1440 / 30 )); } }
    @media screen and (min-width: 1441px) {
      .p-merit-voice_items__item {
        width: calc((100% - 74px) / 3);
        padding: 30px; } }
    @media screen and (max-width: 767px) {
      .p-merit-voice_items__item:not(:last-child) {
        margin-bottom: calc(100vw / ( 375 / 25 )); } }
    .p-merit-voice_items__item .forImg {
      margin: 0 auto calc(100vw / ( 375 / 10 ));
      width: calc(100vw / ( 375 / 176 )); }
      @media screen and (min-width: 768px) {
        .p-merit-voice_items__item .forImg {
          width: 48%;
          margin-bottom: 20px; } }
    .p-merit-voice_items__item .forTxt {
      line-height: 170%; }
.p-merit-dl {
  background: url("../images/merit/dl_bg_sp.jpg") center no-repeat;
  background-size: cover;
  position: relative;
  padding: calc(100vw / ( 375 / 70 )) 0; }
  @media screen and (min-width: 768px) {
    .p-merit-dl {
      background-image: url("../images/merit/dl_bg.jpg");
      padding: calc(100vw / ( 1440 / 54 )) 0 calc(100vw / ( 1440 / 80 )); } }
  @media screen and (min-width: 1441px) {
    .p-merit-dl {
      padding: 54px 0 80px; } }
  .p-merit-dl:after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(35, 162, 50, 0.8); }
  .p-merit-dl_ttl {
    text-align: center;
    color: #fff;
    font-weight: 900;
    filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.35));
    font-size: calc(100vw / ( 375 / 30 ));
    margin-bottom: calc(100vw / ( 375 / 35 )); }
    @media screen and (min-width: 768px) {
      .p-merit-dl_ttl {
        font-size: 3.6rem;
        margin-bottom: 50px; } }
    .p-merit-dl_ttl:before {
      content: "";
      display: block;
      margin: 0 auto;
      background: url("../images/icon_dl_white.svg") center no-repeat;
      background-size: contain;
      width: calc(100vw / ( 375 / 60 ));
      height: calc(100vw / ( 375 / 38 ));
      margin-bottom: calc(100vw / ( 375 / 24 )); }
      @media screen and (min-width: 768px) {
        .p-merit-dl_ttl:before {
          width: 60px;
          height: 38px;
          margin-bottom: 24px; } }
  .p-merit-dl_txt {
    color: #fff;
    text-align: center;
    line-height: 180%;
    margin-bottom: calc(100vw / ( 375 / 36 )); }
    @media screen and (min-width: 768px) {
      .p-merit-dl_txt {
        margin-bottom: 3em; } }
    .p-merit-dl_txt a {
      color: #fff;
      text-decoration: underline;
      font-weight: bold; }
  .p-merit-dl .forSteps__item {
    position: relative;
    background: #fff;
    box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1);
    border-radius: 10px;
    padding: calc(100vw / ( 375 / 20 )) calc(100vw / ( 375 / 20 )) calc(100vw / ( 375 / 20 )) calc(100vw / ( 375 / 67 )); }
    .p-merit-dl .forSteps__item:not(:last-child) {
      margin-bottom: calc(100vw / ( 375 / 25 )); }
      @media screen and (min-width: 768px) {
        .p-merit-dl .forSteps__item:not(:last-child) {
          margin-bottom: 30px; } }
    @media screen and (min-width: 768px) {
      .p-merit-dl .forSteps__item {
        display: flex;
        align-items: center;
        padding: calc(100vw / ( 1440 / 35 )) calc(100vw / ( 1440 / 30 )) calc(100vw / ( 1440 / 35 )) calc(100vw / ( 1440 / 136 )); } }
    @media screen and (min-width: 1441px) {
      .p-merit-dl .forSteps__item {
        padding: 35px 30px 35px 136px; } }
    .p-merit-dl .forSteps__item:before {
      content: "";
      display: block;
      position: absolute;
      z-index: 1;
      left: calc(100vw / ( 375 / 10 ));
      top: calc(-100vw / ( 375 / 25 ));
      width: calc(100vw / ( 375 / 40 ));
      height: calc(100% + calc(100vw / ( 375 / 50 ))); }
      @media screen and (min-width: 768px) {
        .p-merit-dl .forSteps__item:before {
          left: calc(100vw / ( 1440 / 24 ));
          top: -30px;
          width: calc(100vw / ( 1440 / 74 ));
          height: calc(100% + 64px); } }
      @media screen and (min-width: 1441px) {
        .p-merit-dl .forSteps__item:before {
          left: 24px;
          width: 74px; } }
    @media screen and (min-width: 768px) {
      .p-merit-dl .forSteps__item .c-btn-std {
        font-size: 2.4rem;
        padding-top: calc(100vw / ( 1440 / 21 ));
        padding-bottom: calc(100vw / ( 1440 / 21 )); } }
    @media screen and (min-width: 1441px) {
      .p-merit-dl .forSteps__item .c-btn-std {
        padding-top: 21px;
        padding-bottom: 21px; } }
    .p-merit-dl .forSteps__item.step01:before {
      z-index: 3;
      top: calc(-100vw / ( 375 / 12 ));
      height: calc(100% + calc(100vw / ( 375 / 40 )));
      background: url("../images/top/steps_btm01.svg") center bottom no-repeat;
      background-size: 100% auto; }
      @media screen and (min-width: 768px) {
        .p-merit-dl .forSteps__item.step01:before {
          top: -11px;
          height: calc(100% + 37px); } }
    .p-merit-dl .forSteps__item.step02:before {
      background: #FF7A1C; }
    .p-merit-dl .forSteps__item.step02 .c-btn-std .in {
      position: relative; }
      @media screen and (min-width: 768px) {
        .p-merit-dl .forSteps__item.step02 .c-btn-std .in.dl {
          padding-left: 96px; } }
      .p-merit-dl .forSteps__item.step02 .c-btn-std .in.dl:before {
        content: "";
        display: block;
        position: absolute;
        left: 0;
        top: 50%;
        transform: translateY(-50%);
        background: url("../images/top/steps_icon_dl.svg") center no-repeat;
        background-size: contain; }
        @media screen and (min-width: 768px) {
          .p-merit-dl .forSteps__item.step02 .c-btn-std .in.dl:before {
            width: 80px;
            height: 52px; } }
    .p-merit-dl .forSteps__item.step03:before {
      z-index: 2;
      background: url("../images/top/steps_btm02.svg") center bottom no-repeat;
      background-size: 100% auto; }
    @media screen and (max-width: 767px) {
      .p-merit-dl .forSteps__item.step04 {
        padding-bottom: calc(100vw / ( 375 / 137 )); } }
    .p-merit-dl .forSteps__item.step04:before {
      background: #FFA668;
      height: calc(100% + calc(100vw / ( 375 / 37 ))); }
      @media screen and (min-width: 768px) {
        .p-merit-dl .forSteps__item.step04:before {
          height: calc(100% + 43px); } }
    @media screen and (max-width: 767px) {
      .p-merit-dl .forSteps__item.step04:after {
        content: "";
        display: block;
        position: absolute;
        width: calc(100vw / ( 375 / 181 ));
        height: calc(100vw / ( 375 / 117 ));
        background: url("../images/top/steps_flow_item04.svg") center bottom no-repeat;
        background-size: contain;
        bottom: 0;
        right: calc(100vw / ( 375 / 33 )); } }
  .p-merit-dl .forSteps_device {
    writing-mode: vertical-rl;
    position: absolute;
    top: 50%;
    transform: translateY(-55%);
    color: #fff;
    font-weight: 700;
    z-index: 4;
    font-size: calc(100vw / ( 375 / 16 ));
    left: calc(100vw / ( 375 / 22 )); }
    @media screen and (min-width: 768px) {
      .p-merit-dl .forSteps_device {
        font-size: 2.0rem;
        left: calc(100vw / ( 1440 / 48 )); } }
    @media screen and (min-width: 1441px) {
      .p-merit-dl .forSteps_device {
        left: 50px; } }
  .p-merit-dl .forSteps_img {
    width: calc(100vw / ( 375 / 129 ));
    margin: 0 auto calc(100vw / ( 375 / 20 )); }
    @media screen and (min-width: 768px) {
      .p-merit-dl .forSteps_img {
        width: 141px;
        margin: 0 48px 0 0; } }
  .p-merit-dl .forSteps_ttl {
    font-weight: 700;
    margin-bottom: calc(100vw / ( 375 / 10 )); }
    @media screen and (min-width: 768px) {
      .p-merit-dl .forSteps_ttl {
        margin-bottom: 11px; } }
    .p-merit-dl .forSteps_ttl .num {
      background: #23A232;
      color: #fff;
      display: inline-block;
      letter-spacing: 0.15em;
      font-family: "Outfit", sans-serif;
      border-radius: 2px;
      font-size: calc(100vw / ( 375 / 13 ));
      margin-bottom: calc(100vw / ( 375 / 6 ));
      padding: calc(100vw / ( 375 / 5 )) calc(100vw / ( 375 / 10 )); }
      @media screen and (min-width: 768px) {
        .p-merit-dl .forSteps_ttl .num {
          padding: 5px 20px;
          margin-bottom: 6px;
          font-size: 1.5rem; } }
    .p-merit-dl .forSteps_ttl .title {
      display: block;
      line-height: 145%;
      font-size: calc(100vw / ( 375 / 21 )); }
      @media screen and (min-width: 768px) {
        .p-merit-dl .forSteps_ttl .title {
          line-height: 180%;
          font-size: 2.4rem; } }
  .p-merit-dl .forSteps_txt {
    line-height: 180%; }
    @media screen and (max-width: 767px) {
      .p-merit-dl .forSteps_txt {
        line-height: 160%; } }
    .p-merit-dl .forSteps_txt .case {
      font-weight: 700;
      font-size: calc(100vw / ( 375 / 18 ));
      margin-bottom: calc(100vw / ( 375 / 10 )); }
      @media screen and (min-width: 768px) {
        .p-merit-dl .forSteps_txt .case {
          font-size: 1.8rem;
          margin-bottom: 10px; } }
      @media screen and (min-width: 768px) {
        .p-merit-dl .forSteps_txt .caseBox {
          width: calc((100% - calc(100vw / ( 1440 / 40 ))) / 2); } }
      @media screen and (min-width: 1441px) {
        .p-merit-dl .forSteps_txt .caseBox {
          width: calc((100% - 40px) / 2); } }
      @media screen and (max-width: 767px) {
        .p-merit-dl .forSteps_txt .caseBox:not(:last-child) {
          margin-bottom: calc(100vw / ( 375 / 15 )); } }
      @media screen and (min-width: 768px) {
        .p-merit-dl .forSteps_txt .caseBoxWrap {
          display: flex;
          flex-wrap: wrap;
          column-gap: calc(100vw / ( 1440 / 40 )); } }
      @media screen and (min-width: 1441px) {
        .p-merit-dl .forSteps_txt .caseBoxWrap {
          column-gap: 40px; } }
    @media screen and (min-width: 768px) {
      .p-merit-dl .forSteps_txt .numList {
        margin-bottom: 28px; } }
    .p-merit-dl .forSteps_txt .numList__item {
      position: relative;
      padding-left: 2em; }
      .p-merit-dl .forSteps_txt .numList__item:not(:last-child) {
        margin-bottom: 0.5em; }
      .p-merit-dl .forSteps_txt .numList__item .num {
        position: absolute;
        left: 0;
        top: 0.2em;
        background: #F56600;
        border-radius: 50%;
        display: flex;
        justify-content: center;
        align-items: center;
        color: #fff;
        font-family: "Outfit", sans-serif;
        font-weight: 700;
        width: 1.5625em;
        height: 1.5625em; }
        @media screen and (max-width: 767px) {
          .p-merit-dl .forSteps_txt .numList__item .num {
            top: 0.1em;
            font-size: calc(100vw / ( 375 / 14 )); } }
.p-merit-faq {
  padding: calc(100vw / ( 375 / 30 )) 0; }
  @media screen and (min-width: 768px) {
    .p-merit-faq {
      padding: calc(100vw / ( 1440 / 50 )) 0; } }
  @media screen and (min-width: 1441px) {
    .p-merit-faq {
      padding: 50px 0; } }
  @media screen and (min-width: 768px) {
    .p-merit-faq__inner {
      max-width: 928px; } }
  .p-merit-faq__inner a {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #F56600;
    color: #fff;
    font-weight: 700;
    border-radius: 10px; }
    @media screen and (max-width: 767px) {
      .p-merit-faq__inner a {
        flex-direction: column;
        padding: calc(100vw / ( 375 / 20 )); } }
    @media screen and (min-width: 768px) {
      .p-merit-faq__inner a {
        padding: calc(100vw / ( 1440 / 32 )) 0; } }
    @media screen and (min-width: 1441px) {
      .p-merit-faq__inner a {
        padding: 32px 0; } }
  .p-merit-faq__inner .forTtl {
    position: relative;
    text-align: left; }
    @media screen and (max-width: 767px) {
      .p-merit-faq__inner .forTtl {
        width: 100%;
        font-size: calc(100vw / ( 375 / 25 ));
        border-bottom: 1px solid #fff;
        padding-bottom: calc(100vw / ( 375 / 10 ));
        padding-left: calc(100vw / ( 375 / 70 ));
        margin-bottom: calc(100vw / ( 375 / 20 )); } }
    @media screen and (min-width: 768px) {
      .p-merit-faq__inner .forTtl {
        border-right: 2px solid #fff;
        font-size: 2.8rem;
        padding: calc(100vw / ( 1440 / 14 )) calc(100vw / ( 1440 / 25 )) calc(100vw / ( 1440 / 14 )) 116px; } }
    @media screen and (min-width: 1441px) {
      .p-merit-faq__inner .forTtl {
        padding: 14px 25px 14px 116px; } }
    .p-merit-faq__inner .forTtl .eng {
      display: block;
      font-family: "Outfit", sans-serif;
      letter-spacing: 0.15em;
      padding-top: 0.75em;
      font-size: calc(100vw / ( 375 / 14 )); }
      @media screen and (min-width: 768px) {
        .p-merit-faq__inner .forTtl .eng {
          padding-top: 1em;
          font-size: 1.6rem; } }
    .p-merit-faq__inner .forTtl:before {
      content: "";
      display: block;
      position: absolute;
      left: 0;
      background: url("../images/merit/faq_icon.svg") center no-repeat;
      background-size: contain;
      width: calc(100vw / ( 375 / 66 ));
      height: calc(100vw / ( 375 / 62 )); }
      @media screen and (max-width: 767px) {
        .p-merit-faq__inner .forTtl:before {
          bottom: calc(100vw / ( 375 / 5 )); } }
      @media screen and (min-width: 768px) {
        .p-merit-faq__inner .forTtl:before {
          width: 106px;
          height: 106px;
          top: 50%;
          transform: translateY(-50%); } }
    @media screen and (max-width: 767px) {
      .p-merit-faq__inner .forTtl:after {
        content: "";
        display: block;
        position: absolute;
        right: 0;
        top: 40%;
        transform: translateY(-50%);
        background: url("../images/icon_arrow.svg") center no-repeat;
        background-size: contain;
        width: calc(100vw / ( 375 / 26 ));
        height: calc(100vw / ( 375 / 14 )); } }
  .p-merit-faq__inner .forTxt {
    line-height: 180%; }
    @media screen and (min-width: 768px) {
      .p-merit-faq__inner .forTxt {
        position: relative;
        padding: 0 calc(100vw / ( 1440 / 50 )) 0 calc(100vw / ( 1440 / 25 )); } }
    @media screen and (min-width: 1441px) {
      .p-merit-faq__inner .forTxt {
        padding: 0 50px 0 25px; } }
    @media screen and (min-width: 768px) and (max-width: 900px) {
      .p-merit-faq__inner .forTxt {
        padding-right: calc(100vw / ( 1440 / 70 )); } }
    @media screen and (min-width: 768px) {
      .p-merit-faq__inner .forTxt:after {
        content: "";
        display: block;
        position: absolute;
        right: 0;
        top: 50%;
        transform: translateY(-50%);
        width: 1em;
        height: 1.5em;
        background: url("../images/icon_arrow.svg") center no-repeat;
        background-size: contain; } }
    @media screen and (min-width: 768px) and (max-width: 900px) {
      .p-merit-faq__inner .forTxt:after {
        right: 1em; } }
.p-merit-products {
  position: relative; }
  @media screen and (min-width: 768px) {
    .p-merit-products:before, .p-merit-products:after {
      content: "";
      display: block;
      position: absolute;
      height: 100%;
      top: 0;
      background-position: center;
      background-repeat: no-repeat;
      background-size: cover; } }
  @media screen and (min-width: 768px) {
    .p-merit-products:before {
      width: calc(100vw / ( 1440 / 565 )); } }
  @media screen and (min-width: 1441px) {
    .p-merit-products:before {
      width: calc(((100% - 1120px) / 2) + 415px); } }
  @media screen and (min-width: 768px) {
    .p-merit-products:after {
      width: calc(100vw / ( 1440 / 875 )); } }
  @media screen and (min-width: 1441px) {
    .p-merit-products:after {
      width: calc(((100% - 1120px) / 2) + 705px); } }
  @media screen and (min-width: 768px) {
    .p-merit-products .c-inner {
      display: flex; } }
  .p-merit-products__bg {
    position: relative;
    padding: calc(100vw / ( 375 / 60 )) 0; }
    @media screen and (max-width: 767px) {
      .p-merit-products__bg {
        background-position: center;
        background-repeat: no-repeat;
        background-size: cover; } }
    @media screen and (min-width: 768px) {
      .p-merit-products__bg {
        z-index: 1;
        padding: calc(100vw / ( 1440 / 60 )) 0; } }
    @media screen and (min-width: 1441px) {
      .p-merit-products__bg {
        padding: 60px 0; } }
    .p-merit-products__bg:after {
      content: "";
      display: block;
      position: absolute;
      width: 100%;
      height: 100%;
      top: 0;
      background: rgba(35, 162, 50, 0.8); }
      @media screen and (min-width: 768px) {
        .p-merit-products__bg:after {
          width: calc(100vw / ( 1440 / 875 )); } }
      @media screen and (min-width: 1441px) {
        .p-merit-products__bg:after {
          width: calc(((100% - 1120px) / 2) + 705px); } }
  @media screen and (min-width: 768px) {
    .p-merit-products.for1st:before {
      right: 0;
      background-image: url("../images/merit/products_1st_bg.jpg"); } }
  @media screen and (min-width: 768px) {
    .p-merit-products.for1st:after {
      left: 0;
      background-image: url("../images/merit/products_1st_bg_before.jpg"); } }
  @media screen and (min-width: 768px) {
    .p-merit-products.for1st .c-inner {
      justify-content: flex-start; } }
  @media screen and (max-width: 767px) {
    .p-merit-products.for1st .p-merit-products__bg {
      background-image: url("../images/merit/product_1st_bg_sp.jpg"); } }
  @media screen and (min-width: 768px) {
    .p-merit-products.for1st .p-merit-products__bg:after {
      left: 0; } }
  @media screen and (min-width: 768px) {
    .p-merit-products.for2nd:before {
      left: 0;
      background-image: url("../images/merit/products_2nd_bg.jpg"); } }
  @media screen and (min-width: 768px) {
    .p-merit-products.for2nd:after {
      right: 0;
      background-image: url("../images/merit/products_2nd_bg_before.jpg"); } }
  @media screen and (min-width: 768px) {
    .p-merit-products.for2nd .c-inner {
      justify-content: flex-end; } }
  @media screen and (max-width: 767px) {
    .p-merit-products.for2nd .p-merit-products__bg {
      background-image: url("../images/merit/product_1st_bg_sp.jpg"); } }
  @media screen and (min-width: 768px) {
    .p-merit-products.for2nd .p-merit-products__bg:after {
      right: 0; } }
  .p-merit-products__inner {
    background: #fff;
    border-radius: 10px;
    padding: calc(100vw / ( 375 / 15 )); }
    @media screen and (min-width: 768px) {
      .p-merit-products__inner {
        position: relative;
        width: 58%;
        padding: calc(100vw / ( 1440 / 30 )) calc(100vw / ( 1440 / 40 )); } }
    @media screen and (min-width: 1441px) {
      .p-merit-products__inner {
        width: 625px;
        padding: 35px 40px; } }
    @media screen and (max-width: 767px) {
      .p-merit-products__inner .pdBox {
        position: relative;
        padding: calc(100vw / ( 375 / 57 )) 0 calc(100vw / ( 375 / 35 )); } }
    .p-merit-products__inner .pdBox_detail {
      display: flex;
      flex-wrap: wrap;
      align-items: center; }
      .p-merit-products__inner .pdBox_detail .forImg {
        width: calc(100vw / ( 375 / 100 ));
        margin-right: calc(100vw / ( 375 / 20 )); }
        @media screen and (min-width: 768px) {
          .p-merit-products__inner .pdBox_detail .forImg {
            width: 145px;
            margin-right: 35px; } }
      .p-merit-products__inner .pdBox_detail .forInfo {
        width: calc(100% - calc(100vw / ( 375 / 120 ))); }
        @media screen and (min-width: 768px) {
          .p-merit-products__inner .pdBox_detail .forInfo {
            width: calc(100% - 180px); } }
        .p-merit-products__inner .pdBox_detail .forInfo_ttl {
          font-weight: 700; }
          .p-merit-products__inner .pdBox_detail .forInfo_ttl .coupon {
            display: inline-block;
            border-radius: 3px;
            background: #FBE32B; }
            @media screen and (min-width: 768px) {
              .p-merit-products__inner .pdBox_detail .forInfo_ttl .coupon {
                font-size: 1.6rem;
                padding: 8px 12px; } }
            @media screen and (max-width: 767px) {
              .p-merit-products__inner .pdBox_detail .forInfo_ttl .coupon {
                display: block;
                text-align: center;
                position: absolute;
                left: 0;
                top: 0;
                width: 100%;
                height: calc(100vw / ( 375 / 34 ));
                line-height: calc(100vw / ( 375 / 34 ));
                font-size: calc(100vw / ( 375 / 14 )); } }
          .p-merit-products__inner .pdBox_detail .forInfo_ttl .title {
            display: block;
            line-height: 140%;
            font-size: calc(100vw / ( 375 / 20 )); }
            @media screen and (max-width: 767px) {
              .p-merit-products__inner .pdBox_detail .forInfo_ttl .title {
                margin-bottom: 0.5em; } }
            @media screen and (min-width: 768px) {
              .p-merit-products__inner .pdBox_detail .forInfo_ttl .title {
                padding-top: 10px;
                font-size: 2.8rem; } }
        .p-merit-products__inner .pdBox_detail .forInfo_price {
          font-weight: 700; }
          @media screen and (min-width: 768px) {
            .p-merit-products__inner .pdBox_detail .forInfo_price {
              padding: 15px 0; } }
          .p-merit-products__inner .pdBox_detail .forInfo_price .num {
            font-family: "Albert Sans", sans-serif;
            letter-spacing: -0.01em;
            font-size: calc(100vw / ( 375 / 32 )); }
            @media screen and (min-width: 768px) {
              .p-merit-products__inner .pdBox_detail .forInfo_price .num {
                font-size: 3.7rem; } }
        .p-merit-products__inner .pdBox_detail .forInfo_btns {
          margin-bottom: calc(100vw / ( 375 / 8 )); }
          @media screen and (min-width: 768px) {
            .p-merit-products__inner .pdBox_detail .forInfo_btns {
              margin-bottom: 10px; } }
        .p-merit-products__inner .pdBox_detail .forInfo_note {
          line-height: 170%;
          font-size: calc(100vw / ( 375 / 13 ));
          text-align: center; }
          @media screen and (min-width: 768px) {
            .p-merit-products__inner .pdBox_detail .forInfo_note {
              text-align: left;
              font-size: 1.4rem; } }
          @media screen and (max-width: 767px) {
            .p-merit-products__inner .pdBox_detail .forInfo_note {
              position: absolute;
              left: 0;
              bottom: 0; } }
  @media screen and (min-width: 768px) {
    .p-merit-products_img {
      display: none; } }

/*========== p-faq.scss ==========*/
.p-faq {
  background: #EFF8E7;
  padding: calc(100vw / ( 375 / 70 )) 0; }
  @media screen and (min-width: 768px) {
    .p-faq {
      padding: calc(100vw / ( 1440 / 80 )) 0; } }
  @media screen and (min-width: 1441px) {
    .p-faq {
      padding: 80px 0; } }
  @media screen and (min-width: 1441px) {
    .p-faq__inner {
      max-width: 1041px; } }
  .p-faq__sec {
    counter-reset: section; }
    .p-faq__sec:not(:last-child) {
      margin-bottom: calc(100vw / ( 375 / 65 )); }
      @media screen and (min-width: 768px) {
        .p-faq__sec:not(:last-child) {
          margin-bottom: calc(100vw / ( 1440 / 100 )); } }
      @media screen and (min-width: 1441px) {
        .p-faq__sec:not(:last-child) {
          margin-bottom: 100px; } }
  .p-faq-ttl {
    text-align: center;
    color: #208C30;
    font-weight: 900;
    line-height: 140%;
    font-size: calc(100vw / ( 375 / 30 ));
    margin-bottom: 1em; }
    @media screen and (min-width: 768px) {
      .p-faq-ttl {
        font-size: 3.6rem;
        margin-bottom: 49px;
        line-height: 170%; } }
  .p-faq-qa .chara {
    font-family: "Yantramanav", sans-serif;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    width: calc(100vw / ( 375 / 50 ));
    font-size: calc(100vw / ( 375 / 25 )); }
    @media screen and (min-width: 768px) {
      .p-faq-qa .chara {
        width: 90px;
        font-size: 4.0rem; } }
  .p-faq-qa .txt {
    line-height: 160%;
    width: calc(100% - calc(100vw / ( 375 / 50 )));
    padding: calc(100vw / ( 375 / 10 )) calc(100vw / ( 375 / 15 )); }
    @media screen and (min-width: 768px) {
      .p-faq-qa .txt {
        width: calc(100% - 90px);
        padding: 25px 17px; } }
  .p-faq-qa .forQ {
    position: relative;
    background: #fff;
    border-radius: 5px;
    overflow: hidden; }
    .p-faq-qa .forQ button {
      width: 100%;
      display: flex;
      flex-wrap: wrap;
      text-align: left;
      font-weight: 500;
      font-size: calc(100vw / ( 375 / 15 ));
      cursor: pointer;
      height: 100%; }
      @media screen and (min-width: 768px) {
        .p-faq-qa .forQ button {
          font-size: 1.6rem; } }
      .p-faq-qa .forQ button:focus-visible {
        outline: auto; }
    .p-faq-qa .forQ .chara {
      color: #fff;
      background: #23A232; }
      .p-faq-qa .forQ .chara:after {
        counter-increment: section;
        content: counter(section); }
    .p-faq-qa .forQ .txt {
      color: #000;
      padding-right: calc(100vw / ( 375 / 32 )); }
      @media screen and (min-width: 768px) {
        .p-faq-qa .forQ .txt {
          padding-right: 60px; } }
    .p-faq-qa .forQ:after {
      content: "";
      display: block;
      position: absolute;
      top: 50%;
      transform: translateY(-50%) rotate(90deg);
      background: url("../images/icon_down_gr.svg") center no-repeat;
      background-size: contain;
      right: calc(100vw / ( 375 / 8 ));
      width: calc(100vw / ( 375 / 18 ));
      height: calc(100vw / ( 375 / 12 )); }
      @media screen and (min-width: 768px) {
        .p-faq-qa .forQ:after {
          right: 17px;
          width: 26px;
          height: 16px; } }
    .p-faq-qa .forQ.open {
      border-radius: 5px 5px 0 0;
      border-bottom: 1px solid #CCCCCC; }
      .p-faq-qa .forQ.open:after {
        transform: translateY(-50%) rotate(-90deg); }
  .p-faq-qa .forA {
    display: flex;
    flex-wrap: wrap;
    background: #fff;
    border-radius: 0 0 5px 5px; }
    .p-faq-qa .forA:not(:last-child) {
      margin-bottom: calc(100vw / ( 375 / 10 )); }
      @media screen and (min-width: 768px) {
        .p-faq-qa .forA:not(:last-child) {
          margin-bottom: calc(100vw / ( 1440 / 20 )); } }
      @media screen and (min-width: 1441px) {
        .p-faq-qa .forA:not(:last-child) {
          margin-bottom: 20px; } }
    .p-faq-qa .forA .chara {
      color: #208C30; }
    .p-faq-qa .forA .txtLink {
      color: #F56600; }
    .p-faq-qa .forA .c-list-idt {
      padding-top: 0.5em; }
      .p-faq-qa .forA .c-list-idt__item {
        margin-bottom: 0.5em; }
        .p-faq-qa .forA .c-list-idt__item:last-child {
          margin-bottom: 0; }
    .p-faq-qa .forA .c-list-num__item {
      margin-bottom: 0.5em; }
      .p-faq-qa .forA .c-list-num__item:last-child {
        margin-bottom: 0; }
  .p-faq-note {
    text-align: right; }
    @media screen and (max-width: 767px) {
      .p-faq-note {
        line-height: 1.4; } }
    @media screen and (min-width: 768px) {
      .p-faq-note {
        font-size: 1.5rem; } }
    .p-faq-note a {
      display: inline-block;
      position: relative;
      padding-right: 1.3em; }
      .p-faq-note a:after {
        content: "";
        display: block;
        position: absolute;
        right: 0;
        top: 50%;
        transform: translateY(-50%) rotate(270deg);
        background: url("../images/icon_down_or.svg") right center no-repeat;
        background-size: contain;
        width: 1em;
        height: 0.7em; }

/*========== u-utility.scss ==========*/
.u-uLine {
  background: linear-gradient(transparent 60%, #FFED62 60%); }
.u-bold {
  font-weight: 700; }
.u-mt1em {
  margin-top: 1em !important; }
.u-mb0 {
  margin-bottom: 0 !important; }
.u-mb05em {
  margin-bottom: 0.5em !important; }
