@charset "UTF-8";
/* =====================================================================
  Reset styles
===================================================================== */
/* 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 {
  border: 0;
  font: inherit;
  font-size: 100%;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

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;
}

select, input, button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  margin: 0;
  padding: 0;
}

/* =====================================================================
  Base styles
===================================================================== */
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", "SF Pro JP", "SF Pro Display", "SF Pro Icons", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ ProN W3", "Noto Sans JP", "Yu Gothic", "メイリオ", Meiryo, "MS P ゴシック", "Helveica Neue", Helvetica, Arial, sans-serif;
  font-size: 62.5%;
  overflow-x: hidden;
}

body {
  color: #000;
  font-size: 10px;
  -webkit-text-size-adjust: 100%;
  background: #F5F5F5;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

a,
a:hover {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  color: inherit;
  text-decoration: none;
}

img {
  height: auto;
  vertical-align: bottom;
  width: 100%;
}

button {
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
  border: none;
  display: block;
  width: 100%;
}

/* =====================================================================
  Layouts
===================================================================== */
.l-header {
  background: #FFF;
  height: 13.3333333333vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .l-header {
    height: 96px;
  }
}

.l-header-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
  height: 100%;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 auto;
  padding: 0 4.4444444444vw;
}
@media only screen and (min-width: 768px) {
  .l-header-inner {
    max-width: 1184px;
    padding: 0 32px;
  }
}

.l-header-logo {
  display: block;
  max-width: 33.3333333333vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .l-header-logo {
    max-width: 200px;
  }
}

.l-footer {
  position: relative;
}

.l-footer-section + .l-footer-section {
  margin-top: 40px;
}

.l-footer-heading {
  border-bottom: solid 1px #DCDCDC;
  padding-bottom: 4px;
}

.l-footer-heading-text {
  color: #2B2B2B;
  font-size: 4.4444444444vw;
  font-weight: bold;
  line-height: 6.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .l-footer-heading-text {
    font-size: 16px;
    line-height: 24px;
  }
}

.l-footer-list {
  margin-top: 2.2222222222vw;
}
@media only screen and (min-width: 768px) {
  .l-footer-list {
    margin-top: 8px;
  }
}

.l-footer-list-item {
  color: #585858;
  display: block;
  font-size: 3.3333333333vw;
  line-height: 5.5555555556vw;
  padding-left: 4.4444444444vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .l-footer-list-item {
    font-size: 12px;
    line-height: 20px;
    padding-left: 16px;
  }
}
.l-footer-list-item::before {
  background: #585858;
  border-radius: 50%;
  content: "";
  display: block;
  height: 8px;
  left: 0;
  position: absolute;
  top: 6px;
  width: 8px;
}
.l-footer-list-item + .l-footer-list-item {
  margin-top: 1.1111111111vw;
}
@media only screen and (min-width: 768px) {
  .l-footer-list-item + .l-footer-list-item {
    margin-top: 4px;
  }
}

.l-footer-items {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 2.2222222222vw -4.4444444444vw 0;
}
@media only screen and (min-width: 768px) {
  .l-footer-items {
    margin: 8px -16px 0;
  }
}

.l-footer-item {
  padding: 0 4.4444444444vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .l-footer-item {
    padding: 0 16px;
    width: 25%;
  }
}
.l-footer-item + .l-footer-item {
  margin-top: 6.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .l-footer-item + .l-footer-item {
    margin-top: 0;
  }
}

.l-footer-description {
  color: #2B2B2B;
  font-size: 2.7777777778vw;
  line-height: 4.4444444444vw;
  margin-top: 2.2222222222vw;
}
@media only screen and (min-width: 768px) {
  .l-footer-description {
    font-size: 12px;
    line-height: 18px;
    margin-top: 8px;
  }
}

.l-footer-logo {
  display: block;
  margin: 0 auto;
  max-width: 160px;
  width: 100%;
}

.l-footer-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 8px;
}
.l-footer-link > a {
  font-size: 12px;
  line-height: 18px;
  text-decoration: underline;
}

/* =====================================================================
  Components
===================================================================== */
.c-container {
  margin: 0 auto;
  padding: 0 4.4444444444vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .c-container {
    max-width: 1184px;
    padding: 0 32px;
  }
}
@media only screen and (min-width: 768px) {
  .c-container.-full {
    max-width: 100%;
  }
}
.c-container.-compressed {
  padding: 0 8.8888888889vw;
}
@media only screen and (min-width: 768px) {
  .c-container.-compressed {
    max-width: 960px;
    padding: 0 32px;
  }
}

.c-wrapper {
  padding: 15.5555555556vw 0;
}
@media only screen and (min-width: 768px) {
  .c-wrapper {
    padding: 104px 0;
  }
}
.c-wrapper.-bg-bright {
  background: #FFFFFF;
}
.c-wrapper.-bg-palewhite {
  background: #F7F8F9;
}
.c-wrapper.-bg-smbc {
  background: #074E46;
}
.c-wrapper.-bg-acom {
  background: #B90218;
}
.c-wrapper.-bg-promise {
  background: #FFE200;
}
.c-wrapper.-bg-aiful {
  background: #F7E6DE;
}
.c-wrapper.-size-thin {
  padding: 40px 0;
}
.c-wrapper.-search {
  background: #ECF6ED;
}
.c-wrapper.-footerguide {
  background: #F7F8F9;
}
.c-wrapper.-footerend {
  background: #FFFFFF;
  border-top: solid 8px #074E46;
  padding: 48px 0 40px;
}
.lp2-1 .c-wrapper {
  padding: 8.8888888889vw 0;
}
@media only screen and (min-width: 768px) {
  .lp2-1 .c-wrapper {
    padding: 40px 0;
  }
}

.c-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
  background: #F5B52B;
  border-radius: 1.1111111111vw;
  color: #074E46;
  height: 13.3333333333vw;
          justify-content: center;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .c-button {
    border-radius: 4px;
    height: 48px;
  }
}
.c-button.-size-small {
  -webkit-column-gap: 2.2222222222vw;
     -moz-column-gap: 2.2222222222vw;
          column-gap: 2.2222222222vw;
}
@media only screen and (min-width: 768px) {
  .c-button.-size-small {
    -webkit-column-gap: 8px;
       -moz-column-gap: 8px;
            column-gap: 8px;
  }
}
.c-button.-size-medium {
  -webkit-column-gap: 3.3333333333vw;
     -moz-column-gap: 3.3333333333vw;
          column-gap: 3.3333333333vw;
}
@media only screen and (min-width: 768px) {
  .c-button.-size-medium {
    -webkit-column-gap: 12px;
       -moz-column-gap: 12px;
            column-gap: 12px;
  }
}
.c-button.-size-large {
  -webkit-column-gap: 4.4444444444vw;
     -moz-column-gap: 4.4444444444vw;
          column-gap: 4.4444444444vw;
}
@media only screen and (min-width: 768px) {
  .c-button.-size-large {
    -webkit-column-gap: 16px;
       -moz-column-gap: 16px;
            column-gap: 16px;
  }
}
.-bg-promise .c-button {
  background: #024795;
  color: #FFE200;
}
.-bg-aiful .c-button {
  background: #149077;
  color: #FFFFFF;
}
.-bg-acom .c-button {
  background: #000000;
  color: #FFFFFF;
}
.p-compare-button .c-button {
  -webkit-column-gap: 1.1111111111vw;
     -moz-column-gap: 1.1111111111vw;
          column-gap: 1.1111111111vw;
}
@media only screen and (min-width: 768px) {
  .p-compare-button .c-button {
    -webkit-column-gap: 4px;
       -moz-column-gap: 4px;
            column-gap: 4px;
  }
}

.c-button-text {
  font-size: 3.8888888889vw;
  font-weight: bold;
  line-height: 6.6666666667vw;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .c-button-text {
    font-size: 14px;
    line-height: 24px;
  }
}
@media only screen and (min-width: 768px) {
  .-size-large .c-button-text {
    font-size: 16px;
  }
}
.p-compare-button .c-button-text {
  color: #2B2B2B !important;
  font-size: 2.7777777778vw;
}
@media only screen and (min-width: 768px) {
  .p-compare-button .c-button-text {
    font-size: 14px;
  }
}
.c-button-text.-color-black {
  color: #000000 !important;
}

.c-button-icon {
  display: block;
  height: 3.3333333333vw;
  width: 3.3333333333vw;
}
@media only screen and (min-width: 768px) {
  .c-button-icon {
    height: 12px;
    width: 12px;
  }
}
.-size-large .c-button-icon {
  height: 4.4444444444vw;
  width: 4.4444444444vw;
}
@media only screen and (min-width: 768px) {
  .-size-large .c-button-icon {
    height: 16px;
    width: 16px;
  }
}

.c-label {
  background: #DAEFDB;
  border-radius: 1.1111111111vw;
  color: #585858;
  display: inline-block;
  font-size: 2.7777777778vw;
  font-weight: bold;
  padding: 2.2222222222vw 1.1111111111vw;
}
@media only screen and (min-width: 768px) {
  .c-label {
    border-radius: 4px;
    font-size: 12px;
    padding: 8px 4px;
  }
}

.c-card {
  border-radius: 24px;
  max-width: 88.8888888889vw;
  overflow: hidden;
  width: 100%;
  -webkit-box-shadow: 0 0 10px 0px rgba(0, 0, 0, 0.1);
  background: #FFFFFF;
          box-shadow: 0 0 10px 0px rgba(0, 0, 0, 0.1);
}
@media only screen and (min-width: 768px) {
  .c-card {
    border-radius: 24px;
    max-width: 800px;
  }
}

.c-card-detail {
  padding: 4.4444444444vw;
}
@media only screen and (min-width: 768px) {
  .c-card-detail {
    padding: 40px;
  }
}

.c-card-summary {
  color: #074E46;
  font-size: 3.3333333333vw;
  font-weight: bold;
  line-height: 5vw;
}
@media only screen and (min-width: 768px) {
  .c-card-summary {
    font-size: 20px;
    line-height: 30px;
  }
}

.c-card-heading {
  color: #000000;
  display: block;
  font-size: 6.6666666667vw;
  font-weight: bold;
  line-height: 8.8888888889vw;
}
@media only screen and (min-width: 768px) {
  .c-card-heading {
    font-size: 40px;
    line-height: 56px;
    margin-top: 12px;
  }
}

.c-card-description {
  display: block;
  font-size: 3.3333333333vw;
  line-height: 5vw;
}
@media only screen and (min-width: 768px) {
  .c-card-description {
    font-size: 16px;
    line-height: 24px;
    margin-top: 32px;
  }
}

.c-card-labels {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 1.1111111111vw -1.6666666667vw 0;
  row-gap: 3.3333333333vw;
}
@media only screen and (min-width: 768px) {
  .c-card-labels {
    margin: 4px -6px 0;
    row-gap: 12px;
  }
}

.c-card-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 8.8888888889vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .c-card-button {
    margin-top: 32px;
  }
}

.c-card-button-link {
  display: inline-block;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .c-card-button-link {
    max-width: 400px;
  }
}

.c-card-label {
  padding: 1.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .c-card-label {
    padding: 0 6px;
  }
}

.c-comment {
  background: #FFFFFF;
  padding: 4.4444444444vw;
  -webkit-box-shadow: 0.2777777778vw 0.5555555556vw 5.5555555556vw 0.8333333333vw rgba(0, 0, 0, 0.1);
  border-radius: 2.2222222222vw;
          box-shadow: 0.2777777778vw 0.5555555556vw 5.5555555556vw 0.8333333333vw rgba(0, 0, 0, 0.1);
  height: 100%;
}
@media only screen and (min-width: 768px) {
  .c-comment {
    padding: 24px;
    -webkit-box-shadow: 1px 2px 20px 3px rgba(0, 0, 0, 0.1);
    border-radius: 8px;
            box-shadow: 1px 2px 20px 3px rgba(0, 0, 0, 0.1);
  }
}

.c-comment-items {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  height: 100%;
}

.c-comment-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media only screen and (min-width: 768px) {
  .c-comment-item.-avatar {
    max-width: 120px;
  }
}
.c-comment-item.-detail {
  height: 100%;
  padding: 4.4444444444vw 0 0;
}
@media only screen and (min-width: 768px) {
  .c-comment-item.-detail {
    max-width: calc(100% - 120px);
    padding: 0 0 0 24px;
  }
}

.c-comment-detail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  width: 100%;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.c-comment-avatar {
  max-width: 33.3333333333vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .c-comment-avatar {
    max-width: 120px;
  }
}

.c-comment-heading {
  color: #2B2B2B;
  font-size: 4.4444444444vw;
  font-weight: bold;
  line-height: 6.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .c-comment-heading {
    font-size: 20px;
    line-height: 30px;
  }
}

.c-comment-profile {
  color: #585858;
  font-size: 2.7777777778vw;
  line-height: 4.4444444444vw;
  margin-top: 1.1111111111vw;
}
@media only screen and (min-width: 768px) {
  .c-comment-profile {
    font-size: 12px;
    line-height: 18px;
    margin-top: 4px;
  }
}

.c-comment-summary {
  color: #2B2B2B;
  font-size: 3.3333333333vw;
  line-height: 5vw;
  margin: 4.4444444444vw 0;
}
@media only screen and (min-width: 768px) {
  .c-comment-summary {
    font-size: 16px;
    line-height: 24px;
    margin: 16px 0;
  }
}

.c-comment-overview {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: 4.4444444444vw;
  row-gap: 1.1111111111vw;
}
@media only screen and (min-width: 768px) {
  .c-comment-overview {
    -webkit-column-gap: 32px;
       -moz-column-gap: 32px;
            column-gap: 32px;
    margin-top: auto;
  }
}

.c-comment-overview-item {
  width: 50%;
}
@media only screen and (min-width: 768px) {
  .c-comment-overview-item {
    width: auto;
  }
}

.c-comment-overview-heading {
  color: #585858;
  font-size: 2.7777777778vw;
  line-height: 4.4444444444vw;
}
@media only screen and (min-width: 768px) {
  .c-comment-overview-heading {
    font-size: 10px;
    line-height: 16px;
  }
}

.c-comment-overview-description {
  color: #585858;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 1.1111111111vw;
     -moz-column-gap: 1.1111111111vw;
          column-gap: 1.1111111111vw;
  font-size: 3.8888888889vw;
  font-weight: bold;
  line-height: 5.5555555556vw;
}
@media only screen and (min-width: 768px) {
  .c-comment-overview-description {
    font-size: 16px;
    line-height: 24px;
    -webkit-column-gap: 4px;
       -moz-column-gap: 4px;
            column-gap: 4px;
  }
}
@media only screen and (min-width: 768px) {
  .c-comment-overview-description > small {
    font-size: 12px;
    line-height: 18px;
  }
}

.c-sectiontitle {
  color: #2B2B2B;
  display: block;
  font-size: 6.6666666667vw;
  font-weight: bold;
  line-height: 7.7777777778vw;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .c-sectiontitle {
    font-size: 64px;
    line-height: 1.5;
  }
}
.c-sectiontitle > small {
  display: block;
  font-size: 4.4444444444vw;
  line-height: 6.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .c-sectiontitle > small {
    font-size: 40px;
    margin-bottom: 12px;
  }
}
.p-ranking-heading .c-sectiontitle {
  font-size: 5.5555555556vw;
  line-height: 6.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .p-ranking-heading .c-sectiontitle {
    font-size: 56px;
    line-height: 1.5;
  }
}
.p-ranking-heading .c-sectiontitle > small {
  font-size: 3.3333333333vw;
  line-height: 5.5555555556vw;
}
@media only screen and (min-width: 768px) {
  .p-ranking-heading .c-sectiontitle > small {
    font-size: 32px;
  }
}

.c-searchbutton {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
  background: #F5B52B;
  border-radius: 10000px;
  height: 56px;
          justify-content: center;
  position: relative;
  width: 100%;
}
.c-searchbutton:hover {
  cursor: pointer;
}

.c-searchbutton-text {
  font-size: 5.5555555556vw;
  font-weight: bold;
  line-height: 8.8888888889vw;
}
@media only screen and (min-width: 768px) {
  .c-searchbutton-text {
    font-size: 20px;
    line-height: 32px;
  }
}

.c-searchbutton-icon {
  display: block;
  height: 6.6666666667vw;
  position: absolute;
  right: 16px;
  width: 6.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .c-searchbutton-icon {
    height: 24px;
    width: 24px;
  }
}

.c-feature {
  padding: 15.5555555556vw 0;
}
@media only screen and (min-width: 768px) {
  .c-feature {
    padding: 104px 0;
  }
}

.c-feature-heading {
  font-size: 8.8888888889vw;
  font-weight: bold;
  line-height: 11.1111111111vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .c-feature-heading {
    font-size: 40px;
    line-height: 56px;
  }
}
.c-feature-heading[data-number="1"], .c-feature-heading[data-number="2"], .c-feature-heading[data-number="3"] {
  padding-left: 15.5555555556vw;
}
@media only screen and (min-width: 768px) {
  .c-feature-heading[data-number="1"], .c-feature-heading[data-number="2"], .c-feature-heading[data-number="3"] {
    padding-left: 96px;
  }
}

.c-feature-heading-badge {
  background-position: center center;
  background-size: cover;
  display: block;
  left: 0;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  height: 13.3333333333vw;
          transform: translateY(-50%);
  width: 13.3333333333vw;
}
@media only screen and (min-width: 768px) {
  .c-feature-heading-badge {
    height: 80px;
    width: 80px;
  }
}
.c-feature-heading-badge[data-number="1"] {
  background-image: url("../images/badge_number_1_sm.png");
}
@media only screen and (min-width: 768px) {
  .c-feature-heading-badge[data-number="1"] {
    background-image: url("../images/badge_number_1_sm.png");
  }
}
.c-feature-heading-badge[data-number="2"] {
  background-image: url("../images/badge_number_2_sm.png");
}
@media only screen and (min-width: 768px) {
  .c-feature-heading-badge[data-number="2"] {
    background-image: url("../images/badge_number_2_sm.png");
  }
}
.c-feature-heading-badge[data-number="3"] {
  background-image: url("../images/badge_number_3_sm.png");
}
@media only screen and (min-width: 768px) {
  .c-feature-heading-badge[data-number="3"] {
    background-image: url("../images/badge_number_3_sm.png");
  }
}

.c-feature-summary {
  font-size: 5.5555555556vw;
  font-weight: bold;
  line-height: 7.7777777778vw;
  margin-bottom: 2.2222222222vw;
  margin-top: 1.1111111111vw;
}
@media only screen and (min-width: 768px) {
  .c-feature-summary {
    font-size: 24px;
    line-height: 36px;
    margin-bottom: 12px;
    margin-top: 12px;
  }
}

.c-feature-items {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.c-feature-item {
  width: 100%;
}
.c-feature-item.-eyecatch {
  width: 28.8888888889vw;
}
@media only screen and (min-width: 768px) {
  .c-feature-item.-eyecatch {
    margin: 0;
    max-width: 400px;
    width: 100%;
  }
}
.c-feature-item.-detail {
  max-width: calc(100% - 28.8888888889vw);
  padding-left: 4.4444444444vw;
}
@media only screen and (min-width: 768px) {
  .c-feature-item.-detail {
    max-width: calc(100% - 400px);
    padding-left: 32px;
    padding-top: 0;
  }
}

.c-feature-specs {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 0 -4.4444444444vw;
  row-gap: 6.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .c-feature-specs {
    margin: 0 -16px;
    row-gap: 32px;
  }
}

.c-feature-spec {
  padding: 0 4.4444444444vw;
  width: 50%;
}
@media only screen and (min-width: 768px) {
  .c-feature-spec {
    padding: 0 16px;
    width: 180px;
  }
}
.c-feature-spec:last-child {
  width: 100%;
}

.c-feature-spec-heading {
  color: #585858;
  display: block;
  font-size: 3.8888888889vw;
  line-height: 5.5555555556vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .c-feature-spec-heading {
    font-size: 12px;
    line-height: 18px;
  }
}

.c-feature-spec-data {
  color: #2B2B2B;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-weight: bold;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  font-size: 16px;
  line-height: 24px;
}
.c-feature-spec-data > small {
  color: #585858;
  font-size: 10px;
  line-height: 16px;
}

.c-feature-spec-data-text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
}
.c-feature-spec-data-text > small {
  color: #585858;
  font-size: 10px;
  line-height: 16px;
}

.c-feature-logos {
  max-width: 60vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .c-feature-logos {
    max-width: 216px;
  }
}

.c-feature-recommends {
  margin-top: 6.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .c-feature-recommends {
    margin-top: 32px;
  }
}

.c-feature-recommend-heading {
  border: solid 0.5555555556vw #074E46;
  color: #074E46;
  display: inline-block;
  font-size: 2.7777777778vw;
  font-weight: bold;
  line-height: 3.8888888889vw;
  padding: 1.1111111111vw 2.2222222222vw;
}
@media only screen and (min-width: 768px) {
  .c-feature-recommend-heading {
    border: solid 2px #074E46;
    font-size: 12px;
    line-height: 16px;
    padding: 8px;
  }
}

.c-feature-recommend-items {
  margin-top: 2.2222222222vw;
}
@media only screen and (min-width: 768px) {
  .c-feature-recommend-items {
    margin-top: 16px;
  }
}

.c-feature-recommend-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  color: #074E46;
  font-size: 3.8888888889vw;
  font-weight: bold;
  line-height: 5.5555555556vw;
  padding-left: 5.5555555556vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .c-feature-recommend-item {
    font-size: 20px;
    line-height: 30px;
    -webkit-column-gap: 8px;
       -moz-column-gap: 8px;
            column-gap: 8px;
    padding-left: 40px;
  }
}

.c-feature-recommend-icon {
  display: block;
  height: 5.5555555556vw;
  left: 0;
  position: absolute;
  width: 5.5555555556vw;
}
@media only screen and (min-width: 768px) {
  .c-feature-recommend-icon {
    height: 32px;
    width: 32px;
  }
}

.c-feature-secondary {
  margin-top: 6.6666666667vw;
  padding: 4.4444444444vw;
}
@media only screen and (min-width: 768px) {
  .c-feature-secondary {
    border-radius: 8px;
    margin-top: 32px;
    padding: 24px;
  }
}

.c-feature-secondary-heading {
  color: #585858;
  font-size: 5.5555555556vw;
  font-weight: bold;
  line-height: 7.7777777778vw;
}
@media only screen and (min-width: 768px) {
  .c-feature-secondary-heading {
    font-size: 24px;
    line-height: 36px;
  }
}

.c-feature-labels {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 8px -8px 0;
}

.c-feature-label {
  padding: 8px;
}

.c-feature-secondary-description {
  font-size: 16px;
  line-height: 24px;
}

.c-feature-sponcer {
  color: #848484;
  font-size: 3.3333333333vw;
  line-height: 1.5;
  margin-top: 6.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .c-feature-sponcer {
    font-size: 12px;
    margin-top: 32px;
  }
}

.c-feature-pickup {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #272622;
  font-size: 4.4444444444vw;
  font-weight: bold;
  line-height: 6.6666666667vw;
  margin-bottom: 4.4444444444vw;
  padding: 0 1.2em;
}
@media only screen and (min-width: 768px) {
  .c-feature-pickup {
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 8px;
  }
}
.c-feature-pickup::before {
  background: #000000;
  content: "";
  display: block;
  height: 1.4em;
  left: 0;
  position: absolute;
  top: 50%;
  width: 2px;
  -webkit-transform: translate(0, -45%) rotate(-25deg);
          transform: translate(0, -45%) rotate(-25deg);
  -webkit-transform-origin: top;
          transform-origin: top;
}
.c-feature-pickup::after {
  background: #000000;
  content: "";
  display: block;
  height: 1.4em;
  left: auto;
  position: absolute;
  right: 0;
  top: 50%;
  width: 2px;
  -webkit-transform: translate(0, -45%) rotate(25deg);
          transform: translate(0, -45%) rotate(25deg);
  -webkit-transform-origin: top;
          transform-origin: top;
}

.c-feature-notes {
  margin-top: 2.2222222222vw;
}
@media only screen and (min-width: 768px) {
  .c-feature-notes {
    margin-top: 4px;
  }
}

.c-feature-note {
  color: #848484;
  display: block;
  font-size: 3.3333333333vw;
  line-height: 1.5;
  padding-left: 4.4444444444vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .c-feature-note {
    font-size: 12px;
    padding-left: 16px;
  }
}
.c-feature-note::before {
  content: "※";
  left: 0;
  position: absolute;
}
.c-feature-note + .c-feature-note {
  margin-top: 0.5555555556vw;
}
@media only screen and (min-width: 768px) {
  .c-feature-note + .c-feature-note {
    margin-top: 2px;
  }
}

.c-feature-button-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 16px;
}

.c-feature-button {
  display: block;
  max-width: 400px;
  width: 100%;
}

.c-feature-catchcopy {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  border: solid 2px #074E46;
  color: #074E46;
  font-size: 3.8888888889vw;
  font-weight: bold;
  margin-bottom: 4.4444444444vw;
  padding: 3.3333333333vw 2.2222222222vw 4.4444444444vw;
}
@media only screen and (min-width: 768px) {
  .c-feature-catchcopy {
    font-size: 24px;
    padding: 16px 8px 20px;
  }
}
.c-feature-catchcopy > strong {
  font-size: 1.5em;
}

.c-qa-heading {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
  background: #ECF6ED;
          justify-content: space-between;
  padding: 2.2222222222vw;
}
@media only screen and (min-width: 768px) {
  .c-qa-heading {
    padding: 12px 16px;
  }
}
.c-qa-heading:hover {
  cursor: pointer;
}

.c-qa-question-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  color: #074E46;
  font-size: 3.8888888889vw;
  font-weight: bold;
  line-height: 5.5555555556vw;
  -webkit-column-gap: 1.1111111111vw;
     -moz-column-gap: 1.1111111111vw;
          column-gap: 1.1111111111vw;
}
@media only screen and (min-width: 768px) {
  .c-qa-question-inner {
    font-size: 20px;
    line-height: 24px;
    -webkit-column-gap: 8px;
       -moz-column-gap: 8px;
            column-gap: 8px;
  }
}

.c-qa-answer {
  display: block;
  height: 0;
  overflow: hidden;
  -webkit-transition: all 0.2s ease-out;
  padding: 0 2.2222222222vw 0 2.2222222222vw;
  transition: all 0.2s ease-out;
}
@media only screen and (min-width: 768px) {
  .c-qa-answer {
    padding: 0 16px 0 16px;
  }
}
.is-show .c-qa-answer {
  height: auto;
  padding: 2.2222222222vw 2.2222222222vw 11.1111111111vw 2.2222222222vw;
}
@media only screen and (min-width: 768px) {
  .is-show .c-qa-answer {
    padding: 16px 16px 40px 16px;
  }
}
.is-show:last-of-type .c-qa-answer {
  padding-bottom: 0;
}

.c-qa-answer-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  color: #074E46;
  font-size: 3.8888888889vw;
  line-height: 5.5555555556vw;
  -webkit-column-gap: 2.2222222222vw;
     -moz-column-gap: 2.2222222222vw;
          column-gap: 2.2222222222vw;
}
@media only screen and (min-width: 768px) {
  .c-qa-answer-inner {
    font-size: 20px;
    line-height: 24px;
    -webkit-column-gap: 8px;
       -moz-column-gap: 8px;
            column-gap: 8px;
  }
}
.c-qa-answer-inner small {
  font-size: 3.3333333333vw;
  line-height: 5.5555555556vw;
}
@media only screen and (min-width: 768px) {
  .c-qa-answer-inner small {
    font-size: 12px;
    line-height: 16px;
  }
}

.c-qa-q,
.c-qa-a {
  color: #074E46;
  font-size: 4.4444444444vw;
  font-weight: bold;
  line-height: 5.5555555556vw;
}
@media only screen and (min-width: 768px) {
  .c-qa-q,
  .c-qa-a {
    font-size: 20px;
    line-height: 24px;
  }
}

.c-qa-arrow {
  display: block;
  height: 5.5555555556vw;
  margin-left: auto;
  width: 5.5555555556vw;
  -webkit-transform: rotate(0);
          transform: rotate(0);
  -webkit-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}
@media only screen and (min-width: 768px) {
  .c-qa-arrow {
    height: 32px;
    width: 32px;
  }
}
.is-show .c-qa-arrow {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.c-radio {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  height: 6.6666666667vw;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media only screen and (min-width: 768px) {
  .c-radio {
    height: 24px;
  }
}
.c-radio:hover {
  cursor: pointer;
}

.c-radio-text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #ACACAC;
  color: #2B2B2B;
  font-size: 3.8888888889vw;
  font-weight: bold;
  line-height: 6.6666666667vw;
  padding-left: 8.8888888889vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .c-radio-text {
    font-size: 16px;
    line-height: 24px;
    padding-left: 32px;
  }
}
.c-radio-text::before {
  background: #FFFFFF;
  border: solid 0.5555555556vw #CDCDCD;
  border-radius: 50%;
  content: "";
  display: block;
  height: 6.6666666667vw;
  left: 0;
  position: absolute;
  width: 6.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .c-radio-text::before {
    border: solid 2px #CDCDCD;
    height: 24px;
    width: 24px;
  }
}
.c-radio-text::after {
  background: #074E46;
  border-radius: 50%;
  content: "";
  display: block;
  height: 2.2222222222vw;
  left: 2.2222222222vw;
  opacity: 0;
  position: absolute;
  width: 2.2222222222vw;
}
@media only screen and (min-width: 768px) {
  .c-radio-text::after {
    height: 8px;
    left: 8px;
    width: 8px;
  }
}
.c-radio-input:checked + .c-radio-text {
  color: #2B2B2B;
}
.c-radio-input:checked + .c-radio-text::before {
  border-color: #074E46;
}
.c-radio-input:checked + .c-radio-text::after {
  opacity: 1;
}

.c-checkbox {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  height: 6.6666666667vw;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media only screen and (min-width: 768px) {
  .c-checkbox {
    height: 24px;
  }
}
.c-checkbox:hover {
  cursor: pointer;
}

.c-checkbox-text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #ACACAC;
  color: #2b2b2b;
  font-size: 3.8888888889vw;
  font-weight: bold;
  line-height: 6.6666666667vw;
  padding-left: 8.8888888889vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .c-checkbox-text {
    font-size: 16px;
    line-height: 24px;
    padding-left: 32px;
  }
}
.c-checkbox-text::before {
  background: #FFFFFF;
  border: solid 0.5555555556vw #CDCDCD;
  border-radius: 1.1111111111vw;
  content: "";
  display: block;
  height: 6.6666666667vw;
  left: 0;
  position: absolute;
  width: 6.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .c-checkbox-text::before {
    border: solid 2px #CDCDCD;
    border-radius: 4px;
    height: 24px;
    width: 24px;
  }
}
.c-checkbox-text::after {
  background: #074E46;
  border-bottom: solid 1.1111111111vw #FFFFFF;
  border-left: solid 1.1111111111vw #FFFFFF;
  border-radius: 1px;
  content: "";
  display: block;
  height: 2.5vw;
  left: 1.3888888889vw;
  opacity: 0;
  position: absolute;
  top: 1.6666666667vw;
  width: 3.6111111111vw;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
@media only screen and (min-width: 768px) {
  .c-checkbox-text::after {
    border-bottom: solid 4px #FFFFFF;
    border-left: solid 4px #FFFFFF;
    height: 9px;
    left: 6px;
    top: 6px;
    width: 13px;
  }
}
.c-checkbox-input:checked + .c-checkbox-text {
  color: #2b2b2b;
}
.c-checkbox-input:checked + .c-checkbox-text::before {
  background: #074E46;
  border-color: #074E46;
}
.c-checkbox-input:checked + .c-checkbox-text::after {
  opacity: 1;
}

.c-selectbox {
  background: #FFFFFF;
  border: solid 0.5555555556vw #CDCDCD;
  border-radius: 1.1111111111vw;
  max-width: 240px;
  position: relative;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .c-selectbox {
    border: solid 2px #CDCDCD;
    border-radius: 4px;
  }
}
.c-selectbox::after {
  border-bottom: solid 2px #2B2B2B;
  border-right: solid 2px #2B2B2B;
  content: "";
  display: block;
  height: 2.2222222222vw;
  position: absolute;
  right: 3.3333333333vw;
  top: 50%;
  width: 2.2222222222vw;
  -webkit-transform: translateY(-75%) rotate(45deg);
          transform: translateY(-75%) rotate(45deg);
}
@media only screen and (min-width: 768px) {
  .c-selectbox::after {
    height: 8px;
    right: 12px;
    width: 8px;
  }
}

.c-selectbox-select {
  color: #2B2B2B;
  display: block;
  font-size: 3.8888888889vw;
  font-weight: bold;
  line-height: 5.5555555556vw;
  padding: 3.3333333333vw 8.8888888889vw 3.3333333333vw 3.3333333333vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .c-selectbox-select {
    font-size: 16px;
    line-height: 20px;
    padding: 16px 40px 16px 16px;
  }
}

.c-initialmodal {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
  border-radius: 4.4444444444vw;
          flex-direction: column;
  overflow: hidden;
}
@media only screen and (min-width: 768px) {
  .c-initialmodal {
    border-radius: 16px;
  }
}

.c-initialmodal-image {
  background: gray;
  height: 82.2222222222vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .c-initialmodal-image {
    height: 450px;
  }
}

.c-initialmodal-detail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 4.4444444444vw;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
  background: #FFFFFF;
          flex-direction: column;
}

.c-initialmodal-text {
  color: #2F946B;
  font-size: 3.8888888889vw;
  font-weight: bold;
  line-height: 5.5555555556vw;
  margin-bottom: 3.3333333333vw;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .c-initialmodal-text {
    font-size: 24px;
    line-height: 32px;
    margin-bottom: 20px;
  }
}
.c-initialmodal-text > span {
  display: block;
}
@media only screen and (min-width: 768px) {
  .c-initialmodal-text > span {
    display: inline;
  }
}

.c-initialmodal-buttons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: 2.2222222222vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .c-initialmodal-buttons {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-column-gap: 24px;
       -moz-column-gap: 24px;
            column-gap: 24px;
    row-gap: 0;
  }
}

.c-initialmodal-button-wrapper {
  display: block;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .c-initialmodal-button-wrapper {
    max-width: 300px;
  }
}

.c-initialmodal-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
  border-radius: 2.2222222222vw;
  height: 21.1111111111vw;
          justify-content: center;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .c-initialmodal-button {
    border-radius: 8px;
    height: 96px;
  }
}
.c-initialmodal-button.-yes {
  background: #2F946B;
  border: solid 4px #2F946B;
}
.c-initialmodal-button.-no {
  background: #FFFFFF;
  border: solid 4px #2F946B;
}

.c-initialmodal-button-text {
  font-size: 4.4444444444vw;
  font-weight: bold;
  line-height: 6.6666666667vw;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .c-initialmodal-button-text {
    font-size: 24px;
    line-height: 32px;
  }
}
.-yes .c-initialmodal-button-text {
  color: #FFFFFF;
}
.-no .c-initialmodal-button-text {
  color: #2F946B;
}

.c-initialmodal-button-summary {
  display: block;
  font-size: 2.7777777778vw;
  font-weight: bold;
  line-height: 4.4444444444vw;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .c-initialmodal-button-summary {
    font-size: 12px;
    line-height: 16px;
  }
}
.-yes .c-initialmodal-button-summary {
  color: #FFFFFF;
}
.-no .c-initialmodal-button-summary {
  color: #2F946B;
}

.c-initialmodal-notes {
  color: #848484;
  font-size: 2.7777777778vw;
  line-height: 4.4444444444vw;
  text-align: left;
}
@media only screen and (min-width: 768px) {
  .c-initialmodal-notes {
    font-size: 12px;
    line-height: 20px;
    margin-top: 32px;
    text-align: center;
  }
}

.c-eliminate-protection-modal {
  height: 100svh;
  left: 0;
  opacity: 0;
  pointer-events: none;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 100;
}
.c-eliminate-protection-modal.is-active {
  opacity: 1;
  pointer-events: all;
}

.c-eliminate-protection-modal-inner {
  height: 500px;
  left: 50%;
  max-width: 300px;
  position: absolute;
  top: 50%;
  width: 80%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.c-eliminate-protection-modal-overlay {
  background: rgba(0, 0, 0, 0.7);
  height: 100svh;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.c-eliminate-protection-modal-close {
  background: red;
  display: block;
  height: 24px;
  position: absolute;
  right: 0;
  top: 0;
  width: 24px;
  -webkit-transform: translate(50%, -50%);
  border-radius: 50%;
          transform: translate(50%, -50%);
}
.c-eliminate-protection-modal-close::before {
  background: white;
  bottom: 0;
  content: "";
  display: block;
  height: 2px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 50%;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
.c-eliminate-protection-modal-close::after {
  background: white;
  bottom: 0;
  content: "";
  display: block;
  height: 2px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 50%;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

.c-eliminate-protection-modal-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 90%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
  background: #F5B52B;
  border-radius: 8px;
  height: 64px;
          justify-content: center;
  margin: 16px auto 0;
  -webkit-transition: all 0.1s ease-out;
  transition: all 0.1s ease-out;
}
.c-eliminate-protection-modal-button:hover {
  cursor: pointer;
  -webkit-transform: scale(1.02);
          transform: scale(1.02);
  -webkit-filter: brightness(1.1);
          filter: brightness(1.1);
}

.c-eliminate-protection-modal-button-text {
  font-size: 16px;
  font-weight: bold;
}

/* =====================================================================
  Projects
===================================================================== */
.p-hero {
  background: #f1f1f1;
  display: block;
  height: 111.1111111111vw;
  position: relative;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .p-hero {
    height: 720px;
  }
}
.lp2-1 .p-hero {
  height: 66.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .lp2-1 .p-hero {
    height: 720px;
  }
}

.p-hero-image {
  background-image: url("../images/hero_sp.jpg");
  background-position: center center;
  background-size: cover;
  height: 111.1111111111vw;
}
@media only screen and (min-width: 768px) {
  .p-hero-image {
    background-image: url("../images/hero.jpg");
    height: 720px;
  }
}
@media only screen and (min-width: 1921px) {
  .p-hero-image {
    margin: 0 auto;
    max-width: 1920px;
  }
}
.p-hero-image.-beginner {
  background-image: url("../images/hero_beginner_sp.jpg");
}
@media only screen and (min-width: 768px) {
  .p-hero-image.-beginner {
    background-image: url("../images/hero_beginner.jpg");
  }
}
.lp2-1 .p-hero-image {
  background-image: url("../images/hero_2-1_sp.jpg");
  height: 66.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .lp2-1 .p-hero-image {
    background-image: url("../images/hero_2-1.jpg");
  }
}
.lp2-1 .p-hero-image.-beginner {
  background-image: url("../images/hero_beginner_2-1_sp.jpg");
}
@media only screen and (min-width: 768px) {
  .lp2-1 .p-hero-image.-beginner {
    background-image: url("../images/hero_beginner_2-1.jpg");
  }
}

.p-ranking-heading {
  margin-bottom: 8.8888888889vw;
}
@media only screen and (min-width: 768px) {
  .p-ranking-heading {
    margin-bottom: 56px;
  }
}

.p-ranking-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 8.8888888889vw 5.5555555556vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .p-ranking-item {
    max-width: 1008px;
    padding: 104px 24px 64px;
  }
}

.p-ranking-badge {
  left: 1.1111111111vw;
  max-width: 22.2222222222vw;
  position: absolute;
  top: 0;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .p-ranking-badge {
    left: 24px;
    max-width: 22.916%;
  }
}

.p-ranking-bullets {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-column-gap: 16px;
     -moz-column-gap: 16px;
          column-gap: 16px;
}

.p-ranking-bullet {
  background: gray;
  border-radius: 50%;
  display: block;
  height: 16px;
  width: 16px;
}
.p-ranking-bullet.is-current {
  background: black;
}
.p-ranking-bullet:hover {
  cursor: pointer;
}

.p-refresh-heading {
  font-size: 5.5555555556vw;
  font-weight: bold;
  line-height: 1.5;
  margin-bottom: 3.3333333333vw;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .p-refresh-heading {
    font-size: 24px;
    margin-bottom: 12px;
  }
}

.p-refresh-banner {
  margin: 0 auto;
  max-width: 400px;
  width: 100%;
}

.p-refresh-text {
  font-size: 4.4444444444vw;
  line-height: 1.5;
  margin-top: 2.2222222222vw;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .p-refresh-text {
    font-size: 16px;
    margin-top: 8px;
  }
}
.p-refresh-text > a {
  font-weight: bold;
  text-decoration: underline;
}

.p-search-heading {
  margin: 0 auto 11.1111111111vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .p-search-heading {
    margin: 0 auto 80px;
    max-width: 520px;
  }
}

.p-search-items {
  counter-reset: item;
  list-style-type: none;
}

.p-search-item + .p-search-item {
  margin-top: 8.8888888889vw;
}
@media only screen and (min-width: 768px) {
  .p-search-item + .p-search-item {
    margin-top: 32px;
  }
}

.p-search-item-title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-weight: bold;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  color: #074E46;
  font-size: 3.8888888889vw;
  line-height: 5.5555555556vw;
  -webkit-column-gap: 1.1111111111vw;
     -moz-column-gap: 1.1111111111vw;
          column-gap: 1.1111111111vw;
  margin-bottom: 3.3333333333vw;
}
@media only screen and (min-width: 768px) {
  .p-search-item-title {
    -webkit-column-gap: 4px;
       -moz-column-gap: 4px;
            column-gap: 4px;
    font-size: 20px;
    line-height: 32px;
    margin-bottom: 8px;
  }
}
.p-search-item-title::before {
  content: "Q" counter(item) ".";
  counter-increment: item;
  display: inline-block;
  width: 8.8888888889vw;
}
@media only screen and (min-width: 768px) {
  .p-search-item-title::before {
    width: auto;
  }
}

.p-search-item-description {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-column-gap: 8.8888888889vw;
     -moz-column-gap: 8.8888888889vw;
          column-gap: 8.8888888889vw;
  row-gap: 4.4444444444vw;
}
@media only screen and (min-width: 768px) {
  .p-search-item-description {
    -webkit-column-gap: 32px;
       -moz-column-gap: 32px;
            column-gap: 32px;
    row-gap: 8px;
  }
}

.p-search-button {
  margin: 40px auto 0;
  max-width: 400px;
  width: 100%;
}

.p-cta-heading {
  color: #FFFFFF;
  font-size: 6.6666666667vw;
  font-weight: bold;
  line-height: 10vw;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .p-cta-heading {
    font-size: 24px;
    line-height: 36px;
  }
}
.p-cta-heading > small {
  font-size: 4.4444444444vw;
  line-height: 6.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .p-cta-heading > small {
    font-size: 16px;
    line-height: 24px;
  }
}
.-bg-aiful .p-cta-heading {
  color: #DA2E20;
}
.-bg-aiful .p-cta-heading > small {
  color: #D4565A;
}
.-bg-promise .p-cta-heading {
  color: #000000;
}

.p-cta-timer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  font-size: 4.4444444444vw;
  font-weight: bold;
  line-height: 8.8888888889vw;
  -webkit-column-gap: 1.1111111111vw;
     -moz-column-gap: 1.1111111111vw;
          column-gap: 1.1111111111vw;
}
@media only screen and (min-width: 768px) {
  .p-cta-timer {
    font-size: 16px;
    line-height: 32px;
    -webkit-column-gap: 4px;
       -moz-column-gap: 4px;
            column-gap: 4px;
  }
}
.-bg-aiful .p-cta-timer {
  color: #D4565A;
}
.-bg-acom .p-cta-timer {
  color: #FFFFFF;
}
.-bg-smbc .p-cta-timer {
  color: #FFFFFF;
}
.-bg-promise .p-cta-timer {
  color: #000000;
}

.p-cta-timer-number {
  font-size: 13.3333333333vw;
  line-height: 20vw;
}
@media only screen and (min-width: 768px) {
  .p-cta-timer-number {
    font-size: 48px;
    line-height: 72px;
  }
}
.-bg-smbc .p-cta-timer-number {
  color: #F5B52B;
}
.-bg-promise .p-cta-timer-number {
  color: #024795;
}
.-bg-aiful .p-cta-timer-number {
  color: #DA2E20;
}
.-bg-acom .p-cta-timer-number {
  color: #FFFFFF;
}

.p-cta-summary {
  font-size: 4.4444444444vw;
  font-weight: bold;
  line-height: 7.7777777778vw;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .p-cta-summary {
    font-size: 16px;
    line-height: 28px;
  }
}
.-bg-smbc .p-cta-summary {
  color: #FFFFFF;
}
.-bg-smbc .p-cta-summary > strong {
  color: #F5B52B;
}
.-bg-acom .p-cta-summary {
  color: #FFFFFF;
}
.-bg-acom .p-cta-summary > strong {
  color: #FFFFFF;
}
.-bg-promise .p-cta-summary {
  color: #000000;
}
.-bg-promise .p-cta-summary > strong {
  color: #024795;
}
.-bg-aiful .p-cta-summary {
  color: #D4565A;
}
.-bg-aiful .p-cta-summary > strong {
  color: #149077;
}

.p-cta-button {
  margin: 6.6666666667vw auto 0;
  max-width: 400px;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .p-cta-button {
    margin: 24px auto 0;
  }
}
.-bg-acom .p-cta-button, .-bg-aiful .p-cta-button, .-bg-promise .p-cta-button, .-bg-smbc .p-cta-button {
  max-width: 320px;
}

.p-cta-links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: 4.4444444444vw;
  row-gap: 2.2222222222vw;
}
@media only screen and (min-width: 768px) {
  .p-cta-links {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    margin-top: 16px;
  }
}

@media only screen and (min-width: 768px) {
  .p-cta-links-item {
    margin-top: 32px;
    width: auto;
  }
}

.p-cta-link {
  display: inline-block;
  padding: 0 16px;
}

.p-cta-link-texts {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 8px;
     -moz-column-gap: 8px;
          column-gap: 8px;
}

.p-cta-link-text {
  font-size: 3.3333333333vw;
  font-weight: bold;
  line-height: 5vw;
}
@media only screen and (min-width: 768px) {
  .p-cta-link-text {
    font-size: 14px;
    line-height: 16px;
  }
}
.-bg-smbc .p-cta-link-text {
  color: #F5B52B;
}
.-bg-acom .p-cta-link-text {
  color: #FFFFFF;
}
.-bg-promise .p-cta-link-text {
  color: #024795;
}
.-bg-aiful .p-cta-link-text {
  color: #149077;
}

.p-cta-link-icon {
  display: block;
  height: 12px;
  width: 12px;
}

.p-compare-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.p-compare-aside {
  margin-top: 120px;
  width: 33.3333333333vw;
}
@media only screen and (min-width: 768px) {
  .p-compare-aside {
    margin-top: 120px;
    width: 240px;
  }
}

.p-compare-aside-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
  background: #F7F7F7;
  border-bottom: solid 2px #F1F1F1;
  border-left: solid 2px #F1F1F1;
  height: 17.7777777778vw;
          justify-content: center;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .p-compare-aside-item {
    height: 100px;
  }
}
.p-compare-aside-item.-transparent {
  background: #FFFFFF;
  border: none;
  height: 26.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .p-compare-aside-item.-transparent {
    height: 160px;
  }
}
.p-compare-aside-item.-heading {
  border-top: solid 2px #F1F1F1;
  height: 17.7777777778vw;
}
@media only screen and (min-width: 768px) {
  .p-compare-aside-item.-heading {
    height: 64px;
  }
}
.p-compare-aside-item:last-child {
  background: #FFFFFF;
  border-bottom: none;
  border-left: none;
}

.p-compare-aside-text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  color: #2B2B2B;
  font-size: 2.7777777778vw;
  font-weight: bold;
  line-height: 4.4444444444vw;
}
@media only screen and (min-width: 768px) {
  .p-compare-aside-text {
    font-size: 16px;
    line-height: 32px;
  }
}
.p-compare-aside-text > small {
  color: #585858;
  font-size: 2.2222222222vw;
  line-height: 2.7777777778vw;
}
@media only screen and (min-width: 768px) {
  .p-compare-aside-text > small {
    font-size: 10px;
    line-height: 12px;
  }
}

.p-compare-contents-wrapper {
  overflow-x: scroll;
  width: calc(100% - 33.3333333333vw);
}
@media only screen and (min-width: 768px) {
  .p-compare-contents-wrapper {
    width: calc(100% - 240px);
  }
}

.p-compare-contents {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 120px;
}

.p-compare-contents-list {
  min-width: 37.7777777778vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .p-compare-contents-list {
    min-width: 219px;
  }
}
.p-compare-contents-list.-pickup::before {
  content: "";
  display: block;
  left: 50%;
  position: absolute;
  top: 0;
  -webkit-transform: translate(-50%, -105%);
  background-image: url("../images/babble_sm.png");
  background-size: cover;
  height: 13.3333333333vw;
          transform: translate(-50%, -105%);
  width: 22.2222222222vw;
}
@media only screen and (min-width: 768px) {
  .p-compare-contents-list.-pickup::before {
    background-image: url("../images/babble_lg.png");
    background-size: cover;
    height: 64px;
    width: 152px;
  }
}

.p-compare-contents-list-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background: #FFFFFF;
  border-bottom: solid 2px #F1F1F1;
  height: 17.7777777778vw;
}
@media only screen and (min-width: 768px) {
  .p-compare-contents-list-item {
    height: 100px;
  }
}
.p-compare-contents-list-item.-eyecatch {
  border-bottom: none;
  height: 26.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .p-compare-contents-list-item.-eyecatch {
    height: 160px;
  }
}
.p-compare-contents-list-item.-heading {
  background: #F7F7F7;
  border-top: solid 2px #F1F1F1;
  height: 17.7777777778vw;
}
@media only screen and (min-width: 768px) {
  .p-compare-contents-list-item.-heading {
    height: 64px;
  }
}
.p-compare-contents-list-item:last-child {
  border-bottom: none;
}
.p-compare-contents-list-item.-column {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 0;
}
.p-compare-contents-list:last-child .p-compare-contents-list-item {
  border-right: solid 2px #F1F1F1;
}
.p-compare-contents-list:last-child .p-compare-contents-list-item:last-child {
  border-right: none;
}
.p-compare-contents-list-item.-marked::after {
  background-image: url("../images/bg_compare_circle.svg");
  background-position: center center;
  background-size: cover;
  content: "";
  display: block;
  left: 50%;
  position: absolute;
  -webkit-transform: translate(-50%, 0);
  height: 6.6666666667vw;
          transform: translate(-50%, 0);
  width: 6.6666666667vw;
  z-index: 0;
}
@media only screen and (min-width: 768px) {
  .p-compare-contents-list-item.-marked::after {
    height: 40px;
    width: 40px;
  }
}
.p-compare-contents-list-item.-colored::after {
  background-image: url("../images/bg_compare_doublecircle.svg");
  background-position: center center;
  background-size: cover;
  content: "";
  display: block;
  left: 50%;
  position: absolute;
  -webkit-transform: translate(-50%, 0);
  height: 6.6666666667vw;
          transform: translate(-50%, 0);
  width: 6.6666666667vw;
  z-index: 0;
}
@media only screen and (min-width: 768px) {
  .p-compare-contents-list-item.-colored::after {
    height: 40px;
    width: 40px;
  }
}
.p-compare-contents-list-item.-none::after {
  content: none;
}

.p-compare-contents-text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-column-gap: 0.5555555556vw;
     -moz-column-gap: 0.5555555556vw;
  color: #2B2B2B;
          column-gap: 0.5555555556vw;
  font-size: 3.8888888889vw;
  line-height: 5.5555555556vw;
  position: relative;
  z-index: 1;
}
@media only screen and (min-width: 768px) {
  .p-compare-contents-text {
    font-size: 16px;
    line-height: 32px;
    -webkit-column-gap: 2px;
       -moz-column-gap: 2px;
            column-gap: 2px;
  }
}
.p-compare-contents-text > small {
  font-size: 2.7777777778vw;
}
@media only screen and (min-width: 768px) {
  .p-compare-contents-text > small {
    font-size: 12px;
    line-height: 20px;
  }
}
.p-compare-contents-text.-bold {
  font-weight: bold;
}

.p-compare-contents-logo {
  display: block;
  max-width: 22.2222222222vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .p-compare-contents-logo {
    max-width: 96px;
  }
}

.p-compare-contents-eyecatch {
  display: block;
  max-width: 22.2222222222vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .p-compare-contents-eyecatch {
    max-width: 132px;
  }
}

.p-compare-button {
  display: inline-block;
  max-width: 33.3333333333vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .p-compare-button {
    max-width: 176px;
  }
}

.p-compare-notes {
  margin-top: 32px;
}
@media only screen and (min-width: 768px) {
  .p-compare-notes {
    margin-top: 32px;
  }
}

.p-compare-note + .p-compare-note {
  margin-top: 1.1111111111vw;
}
@media only screen and (min-width: 768px) {
  .p-compare-note + .p-compare-note {
    margin-top: 4px;
  }
}

.p-compare-note-text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  color: #585858;
  font-size: 2.7777777778vw;
  line-height: 4.4444444444vw;
  position: relative;
  -webkit-column-gap: 1.1111111111vw;
     -moz-column-gap: 1.1111111111vw;
          column-gap: 1.1111111111vw;
}
@media only screen and (min-width: 768px) {
  .p-compare-note-text {
    font-size: 12px;
    line-height: 16px;
    -webkit-column-gap: 8px;
       -moz-column-gap: 8px;
            column-gap: 8px;
  }
}
.p-compare-note-text::before {
  content: "※";
}

.p-comments {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 0 -4.4444444444vw;
}
@media only screen and (min-width: 768px) {
  .p-comments {
    margin: 0 -16px;
    row-gap: 32px;
  }
}

.p-comments-heading {
  margin-bottom: 11.1111111111vw;
}
@media only screen and (min-width: 768px) {
  .p-comments-heading {
    margin-bottom: 80px;
  }
}
.lp2-1 .p-comments-heading {
  margin-bottom: 2.2222222222vw;
}
@media only screen and (min-width: 768px) {
  .lp2-1 .p-comments-heading {
    margin-bottom: 32px;
  }
}

.p-comments-item {
  padding: 4.4444444444vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .p-comments-item {
    padding: 0 16px;
    width: 50%;
  }
}

.p-comments-item-inner {
  height: 100%;
}

.p-comments-item-inner-child {
  height: 100%;
}

.p-comments-bullets {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-column-gap: 16px;
     -moz-column-gap: 16px;
          column-gap: 16px;
}
@media only screen and (min-width: 768px) {
  .p-comments-bullets {
    display: none;
  }
}

.p-comments-bullet {
  background: gray;
  border-radius: 50%;
  display: block;
  height: 16px;
  width: 16px;
}
.p-comments-bullet.is-current {
  background: black;
}
.p-comments-bullet:hover {
  cursor: pointer;
}

.p-flow-heading-wrapper {
  margin-bottom: 11.1111111111vw;
}
@media only screen and (min-width: 768px) {
  .p-flow-heading-wrapper {
    margin-bottom: 64px;
  }
}

.p-flow-heading {
  display: block;
  margin: 0 auto;
  max-width: 72.2222222222vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .p-flow-heading {
    max-width: 448px;
  }
}

.p-feature-contents {
  background: #FFFFFF;
}
.p-feature-contents.is-result {
  background: #FFF8E0;
}

.p-feature-cta-wrapper {
  margin-left: calc(50% - 50vw);
  width: 100vw;
}

.p-qa-title {
  margin-bottom: 8.8888888889vw;
}
@media only screen and (min-width: 768px) {
  .p-qa-title {
    margin-bottom: 64px;
  }
}

.p-qa-notes {
  counter-reset: item;
  list-style-type: none;
  margin-top: 8.8888888889vw;
  padding-left: 0;
}
@media only screen and (min-width: 768px) {
  .p-qa-notes {
    margin-top: 32px;
  }
}

.p-qa-note {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  color: #585858;
  font-size: 2.7777777778vw;
  line-height: 4.4444444444vw;
  -webkit-column-gap: 2.2222222222vw;
     -moz-column-gap: 2.2222222222vw;
          column-gap: 2.2222222222vw;
}
@media only screen and (min-width: 768px) {
  .p-qa-note {
    font-size: 16px;
    line-height: 1.5;
    -webkit-column-gap: 8px;
       -moz-column-gap: 8px;
            column-gap: 8px;
  }
}
.p-qa-note::before {
  content: "※" counter(item);
  counter-increment: item;
  display: block;
}
.p-qa-note + .p-qa-note {
  margin-top: 1.1111111111vw;
}
@media only screen and (min-width: 768px) {
  .p-qa-note + .p-qa-note {
    margin-top: 4px;
  }
}

.p-initialmodal {
  height: 100svh;
  left: 50%;
  position: fixed;
  top: 50%;
  width: 100vw;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 100;
}
.p-initialmodal.is-close {
  display: none;
  pointer-events: none;
}

.p-initialmodal-inner {
  display: block;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  max-width: 91.1111111111vw;
  position: absolute;
          transform: translate(-50%, -50%);
  width: 100%;
  z-index: 10;
}
@media only screen and (min-width: 768px) {
  .p-initialmodal-inner {
    height: 720px;
    max-width: 800px;
  }
}

.p-initialmodal-overlay {
  background: rgba(0, 0, 0, 0.7);
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 0;
}

.p-footerguide-heading {
  color: #2B2B2B;
  font-size: 3.8888888889vw;
  font-weight: bold;
  line-height: 5.5555555556vw;
  margin-bottom: 1.1111111111vw;
}
@media only screen and (min-width: 768px) {
  .p-footerguide-heading {
    font-size: 14px;
    line-height: 20px;
    margin-bottom: 4px;
  }
}

.p-footerguide + .p-footerguide {
  margin-top: 2.2222222222vw;
}
@media only screen and (min-width: 768px) {
  .p-footerguide + .p-footerguide {
    margin-top: 8px;
  }
}

.p-footerguide-label {
  background: #D9D9D9;
  color: #2B2B2B;
  display: inline-block;
  font-size: 2.7777777778vw;
  line-height: 4.4444444444vw;
  margin-bottom: 1.1111111111vw;
  padding: 1.1111111111vw;
}
@media only screen and (min-width: 768px) {
  .p-footerguide-label {
    font-size: 10px;
    line-height: 16px;
    margin-bottom: 4px;
    padding: 4px;
  }
}

.p-footerguide-description {
  color: #2B2B2B;
  font-size: 3.3333333333vw;
  line-height: 5vw;
  margin-bottom: 1.1111111111vw;
}
@media only screen and (min-width: 768px) {
  .p-footerguide-description {
    font-size: 12px;
    line-height: 18px;
    margin-top: 4px;
  }
}

.p-footerguide-notes {
  color: #2B2B2B;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 0.5555555556vw;
     -moz-column-gap: 0.5555555556vw;
          column-gap: 0.5555555556vw;
  font-size: 2.7777777778vw;
  line-height: 4.4444444444vw;
}
@media only screen and (min-width: 768px) {
  .p-footerguide-notes {
    -webkit-column-gap: 2px;
       -moz-column-gap: 2px;
            column-gap: 2px;
    font-size: 10px;
    line-height: 16px;
  }
}
.p-footerguide-notes::before {
  content: "*";
}

.p-floatingbanner {
  bottom: 4.4444444444vw;
  height: 35.5555555556vw;
  position: fixed;
  right: 4.4444444444vw;
  width: 35.5555555556vw;
  z-index: 10;
}
@media only screen and (min-width: 768px) {
  .p-floatingbanner {
    bottom: 40px;
    height: 240px;
    right: 40px;
    width: 240px;
  }
}
.p-floatingbanner:hover {
  cursor: pointer;
}

.p-searchlabels {
  background: #E9FDF1;
  padding: 4.4444444444vw 0;
}
@media only screen and (min-width: 768px) {
  .p-searchlabels {
    padding: 16px 0;
  }
}

.p-searchlabels-heading {
  color: #074E46;
  font-size: 3.3333333333vw;
  font-weight: bold;
  line-height: 5vw;
}
@media only screen and (min-width: 768px) {
  .p-searchlabels-heading {
    font-size: 12px;
    line-height: 18px;
  }
}

.p-searchlabels-inwrapper {
  overflow-x: scroll;
  scrollbar-width: none;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .p-searchlabels-inwrapper {
    margin: 0 auto;
    max-width: 1184px;
  }
}

.p-searchlabels-items {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 0 4.4444444444vw;
  -webkit-column-gap: 24px;
     -moz-column-gap: 24px;
          column-gap: 24px;
}
@media only screen and (min-width: 768px) {
  .p-searchlabels-items {
    padding: 0 32px;
  }
}

.p-searchlabels-index {
  color: #585858;
  font-size: 10px;
  font-weight: bold;
  line-height: 20px;
}

.p-searchlabels-item:last-of-type {
  padding-right: 4.4444444444vw;
}

.p-searchlabels-labels {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 8px;
     -moz-column-gap: 8px;
          column-gap: 8px;
}

.p-searchlabels-label {
  background: #2F946B;
  border: solid 3px #139D66;
  border-radius: 10000px;
  border-width: 3px;
  color: #FFFFFF;
  display: inline-block;
  font-size: 10px;
  font-weight: bold;
  padding: 8px 24px;
  white-space: nowrap;
}

/* =====================================================================
  Common styles
===================================================================== */
.p-example {
  position: relative;
}

/* =====================================================================
  utilities
===================================================================== */
.u-text-hidden {
  height: 1px;
  opacity: 0;
  overflow: hidden;
  position: absolute;
  width: 1px;
}

.u-pt-zero {
  padding-top: 0 !important;
}

.u-pb-zero {
  padding-bottom: 0 !important;
}

.slick-initialized .p-ranking-item.slick-slide {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
  height: auto !important;
          justify-content: center;
}

.u-br.-only-sp {
  display: block;
}
@media only screen and (min-width: 768px) {
  .u-br.-only-sp {
    display: none;
  }
}

/* =====================================================================
  Pages
===================================================================== */
.info-title {
  background: #074E46;
  color: #FFFFFF;
  font-size: 5.5555555556vw;
  font-weight: bold;
  line-height: 1.5;
  margin-bottom: 6.6666666667vw;
  padding: 3.3333333333vw 0;
  text-align: center;
  -webkit-font-smoothing: antialiased;
}
@media only screen and (min-width: 768px) {
  .info-title {
    font-size: 24px;
    margin-bottom: 24px;
    padding: 16px 0;
  }
}

.info-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.info-item + .info-item {
  margin-top: 4.4444444444vw;
}
@media only screen and (min-width: 768px) {
  .info-item + .info-item {
    margin-top: 24px;
  }
}

.info-heading {
  font-size: 4.4444444444vw;
  font-weight: bold;
  line-height: 6.6666666667vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .info-heading {
    font-size: 16px;
    line-height: 24px;
    width: 200px;
  }
}

.info-description {
  font-size: 4.4444444444vw;
  line-height: 6.6666666667vw;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .info-description {
    font-size: 16px;
    line-height: 24px;
    width: calc(100% - 200px);
  }
}