@charset "UTF-8";
/*! destyle.css v3.0.0 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model and set borders */
/* ============================================ */
*,
::before,
::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
}

/* Document */
/* ============================================ */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 * 3. Remove gray overlay on links for iOS.
 */
html {
  line-height: 1.15;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
  -webkit-tap-highlight-color: transparent;
  /* 3*/
}

/* Sections */
/* ============================================ */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

/* Vertical rhythm */
/* ============================================ */
p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

/* Headings */
/* ============================================ */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
  margin: 0;
}

/* Lists (enumeration) */
/* ============================================ */
ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Lists (definition) */
/* ============================================ */
dt {
  font-weight: bold;
}

dd {
  margin-left: 0;
}

/* Grouping content */
/* ============================================ */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: inherit;
  /* 2 */
}

address {
  font-style: inherit;
}

/* Text-level semantics */
/* ============================================ */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted;
  /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: inherit;
  /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Replaced content */
/* ============================================ */
/**
 * Prevent vertical alignment issues.
 */
svg,
img,
embed,
object,
iframe {
  vertical-align: bottom;
}

/* Forms */
/* ============================================ */
/**
 * Reset form fields to make them styleable.
 * 1. Make form elements stylable across systems iOS especially.
 * 2. Inherit text-transform from parent.
 */
button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  /* 1 */
  -moz-appearance: none;
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  border-radius: 0;
  text-align: inherit;
  text-transform: inherit;
  /* 2 */
}

/**
 * Reset radio and checkbox appearance to preserve their look in iOS.
 */
[type=checkbox] {
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
  appearance: checkbox;
}

[type=radio] {
  -webkit-appearance: radio;
  -moz-appearance: radio;
  appearance: radio;
}

/**
 * Correct cursors for clickable elements.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
}

button:disabled,
[type=button]:disabled,
[type=reset]:disabled,
[type=submit]:disabled {
  cursor: default;
}

/**
 * Improve outlines for Firefox and unify style with input elements & buttons.
 */
:-moz-focusring {
  outline: auto;
}

select:disabled {
  opacity: inherit;
}

/**
 * Remove padding
 */
option {
  padding: 0;
}

/**
 * Reset to invisible
 */
fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
}

legend {
  padding: 0;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the outline style in Safari.
 */
[type=search] {
  outline-offset: -2px;
  /* 1 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Fix font inheritance.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */
}

/**
 * Clickable labels
 */
label[for] {
  cursor: pointer;
}

/* Interactive */
/* ============================================ */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/*
 * Remove outline for editable content.
 */
[contenteditable]:focus {
  outline: auto;
}

/* Tables */
/* ============================================ */
/**
1. Correct table border color inheritance in all Chrome and Safari.
*/
table {
  border-color: inherit;
  /* 1 */
}

caption {
  text-align: left;
}

td,
th {
  vertical-align: top;
  padding: 0;
}

th {
  text-align: left;
  font-weight: bold;
}

body {
  font-family: 中ゴシックBBB, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-size: 13px;
  font-style: normal;
  line-height: 2;
}
.is-modal-open body, .is-menu-open body {
  overflow: hidden;
}

img {
  max-width: 100%;
  height: auto;
}

hr {
  height: 1px;
  background-color: #E6E6E6;
  border: none;
  color: #E6E6E6;
}

@-webkit-keyframes borderToLong {
  0% {
    width: 0;
  }
  100% {
    width: 32px;
  }
}

@keyframes borderToLong {
  0% {
    width: 0;
  }
  100% {
    width: 32px;
  }
}
@-webkit-keyframes headerDisplay {
  0% {
    -webkit-transform: translateY(-100%);
    transform: translateY(-100%);
  }
  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}
@keyframes headerDisplay {
  0% {
    -webkit-transform: translateY(-100%);
    transform: translateY(-100%);
  }
  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}
[data-inscreen] {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

[data-inscreen-type=fadein-up] {
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
  -webkit-transform: translateY(30px);
  transform: translateY(30px);
  opacity: 0;
}

[data-inscreen-type=fadein-up].is-inscreen {
  -webkit-transform: translateY(0);
  transform: translateY(0);
  opacity: 1;
}

[data-inscreen-type=left-to-right-rectangle] {
  display: inline-block;
  position: relative;
  -webkit-transition: -webkit-transform 0.4s cubic-bezier(0.8, 0, 0.5, 1);
  transition: -webkit-transform 0.4s cubic-bezier(0.8, 0, 0.5, 1);
  transition: transform 0.4s cubic-bezier(0.8, 0, 0.5, 1);
  transition: transform 0.4s cubic-bezier(0.8, 0, 0.5, 1), -webkit-transform 0.4s cubic-bezier(0.8, 0, 0.5, 1);
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
  -webkit-transform: scale(0, 1);
  transform: scale(0, 1);
  -webkit-transform-origin: 100% 50%;
  transform-origin: 100% 50%;
}
[data-inscreen-type=left-to-right-rectangle]::before {
  display: block;
  width: 100%;
  height: calc(100% - 20px);
  content: "";
  position: absolute;
  top: 10px;
  left: 0;
  background-color: #e7152d;
  -webkit-transform-origin: 0 50%;
  transform-origin: 0 50%;
  -webkit-transition: -webkit-transform 0.4s cubic-bezier(0.3, 0, 0.1, 1);
  transition: -webkit-transform 0.4s cubic-bezier(0.3, 0, 0.1, 1);
  transition: transform 0.4s cubic-bezier(0.3, 0, 0.1, 1);
  transition: transform 0.4s cubic-bezier(0.3, 0, 0.1, 1), -webkit-transform 0.4s cubic-bezier(0.3, 0, 0.1, 1);
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  z-index: 3;
}
[data-inscreen-type=left-to-right-rectangle].c-sub-heading__span::before, [data-inscreen-type=left-to-right-rectangle].c-under-cta-heading__span::before, [data-inscreen-type=left-to-right-rectangle].c-under-heading__span::before {
  top: 0;
  height: 100%;
}

[data-inscreen-type=left-to-right-rectangle].is-inscreen {
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  -webkit-transform: scale(1, 1);
  transform: scale(1, 1);
  -webkit-transform-origin: 0 50%;
  transform-origin: 0 50%;
}
[data-inscreen-type=left-to-right-rectangle].is-inscreen::before {
  -webkit-transform: scale(0, 1);
  transform: scale(0, 1);
  -webkit-transition-delay: 0.6s;
  transition-delay: 0.6s;
  -webkit-transform-origin: 100% 50%;
  transform-origin: 100% 50%;
}

[data-inscreen-type=header] {
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
  -webkit-transform: translateY(-100px);
  transform: translateY(-100px);
}
@media screen and (max-width: 991px) {
  [data-inscreen-type=header] {
    -webkit-transform: translateY(-80px);
    transform: translateY(-80px);
  }
}
@media screen and (max-width: 767px) {
  [data-inscreen-type=header] {
    -webkit-transform: translateY(-60px);
    transform: translateY(-60px);
  }
}

[data-inscreen-type=header].is-inscreen {
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

/* Footer
   ----------------------------------------------------------------- */
.l-footer__inner {
  width: 994px;
  margin: auto;
  padding-top: 60px;
}
@media screen and (max-width: 991px) {
  .l-footer__inner {
    width: auto;
    padding: 60px 40px 0;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__inner {
    padding: 60px 0 0;
  }
}
@media screen and (max-width: 991px) {
  .l-footer__logo {
    margin-top: 10px;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__logo {
    padding: 0 30px;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__logo > img {
    width: 210px;
    height: auto;
  }
}
@media screen and (max-width: 575px) {
  .l-footer__logo > img {
    width: 167px;
    height: auto;
  }
}
.l-footer__data {
  margin-top: 60px;
  padding-bottom: 90px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
@media screen and (max-width: 991px) {
  .l-footer__data {
    display: block;
    margin-top: 30px;
  }
}
@media screen and (max-width: 991px) {
  .l-footer__data {
    padding-bottom: 30px;
  }
}
.l-footer__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 787px;
}
@media screen and (max-width: 991px) {
  .l-footer__list {
    width: auto;
    display: block;
  }
}
.l-footer__item {
  -webkit-box-flex: 1;
  -ms-flex: 1 0 auto;
  flex: 1 0 auto;
}
@media screen and (max-width: 991px) {
  .l-footer__item {
    margin-top: 40px;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__item {
    margin-top: 0;
  }
}
.l-footer__item + .l-footer__item {
  margin-left: 35px;
}
@media screen and (max-width: 991px) {
  .l-footer__item + .l-footer__item {
    margin-left: 0;
  }
}
.l-footer__category {
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .l-footer__category {
    background-image: url(../images/common/icon-plus.svg);
    background-repeat: no-repeat;
    background-position: right 30px center;
    padding: 10px 30px;
  }
  .l-footer__category.is-open {
    background-image: url(../images/common/icon-minus.svg);
  }
}
@media screen and (max-width: 767px) {
  .l-footer__toggle {
    margin-top: 0;
    height: 0;
    overflow: hidden;
    -webkit-transition: height 0.3s;
    transition: height 0.3s;
  }
}
.l-footer__sublist {
  margin-top: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 991px) {
  .l-footer__sublist {
    margin-top: 10px;
    display: block;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__sublist {
    margin-top: 0;
    background-color: #F9F9F9;
    padding: 10px 30px 30px;
  }
}
.l-footer__subitem {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
  padding-right: 25px;
}
@media screen and (max-width: 991px) {
  .l-footer__subitem {
    display: inline;
    padding-right: 0;
  }
}
@media screen and (max-width: 991px) {
  .l-footer__linklist {
    display: inline;
    font-size: 0;
  }
}
@media screen and (max-width: 991px) {
  .l-footer__linkitem {
    display: inline-block;
    width: 25%;
    padding-top: 8px;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__linkitem {
    width: 50%;
    padding-top: 20px;
  }
}
@media screen and (max-width: 575px) {
  .l-footer__linkitem {
    display: block;
    width: auto;
  }
}
.l-footer__linkitem__external:after {
  content: url(../images/common/icon-external.svg);
  padding-left: 4px;
}
.l-footer__linkitem > a {
  font-size: 12px;
  line-height: 1.4;
  -webkit-transition: color 0.3s;
  transition: color 0.3s;
}
@media screen and (min-width: 992px) {
  .l-footer__linkitem > a:hover {
    color: #EF3340;
  }
}
.l-footer__linkitem > a::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 1px;
  background-color: #222;
  vertical-align: middle;
  margin-right: 6px;
}
.l-footer__linkitem + .l-footer__linkitem {
  margin-top: 5px;
}
@media screen and (max-width: 991px) {
  .l-footer__linkitem + .l-footer__linkitem {
    margin-top: 0;
  }
}
@media screen and (max-width: 991px) {
  .l-footer__sidelist {
    margin-top: 40px;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__sidelist {
    padding: 0 30px;
  }
}
.l-footer__sideitem {
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-size: 14px;
}
.l-footer__sideitem > a {
  -webkit-transition: color 0.3s;
  transition: color 0.3s;
}
@media screen and (min-width: 992px) {
  .l-footer__sideitem > a:hover {
    color: #EF3340;
  }
}
.l-footer__sideitem + .l-footer__sideitem {
  margin-top: 20px;
}
@media screen and (max-width: 991px) {
  .l-footer__sideitem + .l-footer__sideitem {
    margin-top: 14px;
  }
}
.l-footer__sns ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.l-footer__sns ul li {
  margin-right: 15px;
}
.l-footer__sns ul li:last-child {
  margin-right: 0;
}

.l-header {
  background-color: #fff;
  position: relative;
  z-index: 50;
}
.l-header-form {
  background-color: #fff;
  padding: 30px;
}
@media screen and (min-width: 992px) {
  .l-header.is-fixed {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    -webkit-animation: headerDisplay 0.7s forwards;
    animation: headerDisplay 0.7s forwards;
    -webkit-box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.1);
    box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.1);
  }
  .l-header.is-fixed .l-header__inner {
    height: auto;
  }
  .l-header.is-fixed .l-header__logo {
    padding-left: 0;
  }
  .l-header.is-fixed .l-header-side {
    height: auto;
  }
  .l-header.is-fixed .l-header__logo--sm {
    display: block;
  }
  .l-header.is-fixed .l-header__logo--lg {
    display: none;
  }
  .l-header.is-fixed .l-header-side__top {
    display: none;
  }
  .l-header.is-fixed .l-header-nav__children {
    top: 56px;
  }
  .l-header.is-fixed + .l-header-nav__dropdown-bg {
    top: 84px;
  }
}
@media screen and (min-width: 992px) {
  .is-scrolled-96 .l-header {
    -webkit-animation: headerDisplay 0.7s forwards;
    animation: headerDisplay 0.7s forwards;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
  }
}
@media screen and (max-width: 991px) {
  .l-header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
  }
}
.l-header__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 96px;
}
.l-header__inner--cta {
  height: 80px;
}
.l-header__inner--cta .l-header__logo {
  margin-right: auto;
}
.l-header__inner--cta .c-linkpanel {
  width: auto;
  height: 80px;
}
@media screen and (max-width: 991px) {
  .l-header__inner--cta .c-linkpanel {
    height: 80px;
  }
}
@media screen and (max-width: 767px) {
  .l-header__inner--cta .c-linkpanel {
    height: 60px;
  }
}
@media screen and (min-width: 992px) {
  .is-scrolled-96 .l-header__inner {
    height: 76px;
  }
}
@media screen and (max-width: 991px) {
  .l-header__inner {
    height: 80px;
  }
}
@media screen and (max-width: 767px) {
  .l-header__inner {
    height: 60px;
  }
}
.l-header__logo {
  padding-left: 20px;
}
.l-header__logo--sm {
  display: none;
}
.l-header__logo > a {
  display: block;
}
.l-header__logo > a > img {
  vertical-align: middle;
}
@media screen and (max-width: 991px) {
  .l-header__logo > a > img {
    width: 198px;
    height: auto;
  }
}
@media screen and (max-width: 767px) {
  .l-header__logo > a > img {
    width: 145px;
    height: auto;
  }
}
@media screen and (max-width: 575px) {
  .l-header__logo > a > img {
    width: 110px;
    height: auto;
  }
}
.l-header-nav__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.l-header-nav__item {
  font-size: 14px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  padding: 0 30px;
}
@media screen and (max-width: 1200px) {
  .l-header-nav__item {
    padding: 0 18px;
    font-size: 13px;
  }
}
.l-header-nav__item + .l-header-nav__item {
  border-left: 1px solid #E6E6E6;
}
.l-header-nav__item > a {
  display: block;
  background-image: -webkit-gradient(linear, left top, left bottom, from(#EF3340), to(#EF3340));
  background-image: linear-gradient(#EF3340, #EF3340);
  background-position: 100% 100%;
  background-repeat: no-repeat;
  background-size: 0% 1px;
  -webkit-transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  padding-bottom: 3px;
}
@media screen and (min-width: 992px) {
  .l-header-nav__item > a:hover {
    color: #EF3340;
    background-position: 0 100%;
    background-size: 100% 1px;
  }
}
.l-header-nav__button {
  position: relative;
  display: block;
  cursor: pointer;
  background-image: -webkit-gradient(linear, left top, left bottom, from(#EF3340), to(#EF3340));
  background-image: linear-gradient(#EF3340, #EF3340);
  background-position: 100% 100%;
  background-repeat: no-repeat;
  background-size: 0% 1px;
  -webkit-transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  padding-bottom: 3px;
}
@media screen and (min-width: 992px) {
  .l-header-nav__button:hover {
    color: #EF3340;
    background-position: 0 100%;
    background-size: 100% 1px;
  }
}
.l-header-nav__dropdown-bg {
  background: #fff;
  -webkit-transition: height 300ms;
  transition: height 300ms;
  height: 0;
  position: fixed;
  top: 96px;
  left: 0;
  right: 0;
  z-index: 21;
}
.is-scrolled-96 .l-header-nav__dropdown-bg {
  top: 76px;
}
.l-header-nav__dropdown-overlay {
  background: rgba(0, 0, 0, 0.4);
  -webkit-transition: opacity 300ms;
  transition: opacity 300ms;
  position: fixed;
  top: 96px;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 20;
  opacity: 0;
}
.is-scrolled-96 .l-header-nav__dropdown-overlay {
  top: 76px;
}
.is-nav-open .l-header-nav__dropdown-overlay {
  opacity: 1;
}
.l-header-nav__children {
  height: 0;
  opacity: 0;
  overflow: hidden;
  -webkit-transition: opacity 200ms ease-out 300ms;
  transition: opacity 200ms ease-out 300ms;
  position: absolute;
  top: 72px;
  left: 0;
  right: 0;
  width: 100%;
  z-index: 25;
}
.l-header-nav__children .p-dropdown {
  margin-top: 20px;
}
.is-scrolled-96 .l-header-nav__children {
  top: 68px;
}
.is-nav-open .l-header-nav__children {
  opacity: 1;
}
.l-header-side {
  -webkit-box-flex: 1;
  -ms-flex: 1 0 auto;
  flex: 1 0 auto;
  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: end;
  -ms-flex-align: end;
  align-items: flex-end;
  height: 96px;
}
@media screen and (min-width: 992px) {
  .is-scrolled-96 .l-header-side {
    height: 76px;
  }
}
.l-header-side__top {
  height: 46px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.is-scrolled-96 .l-header-side__top {
  height: 36px;
}
.l-header-side__bottom {
  height: 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.is-scrolled-96 .l-header-side__bottom {
  height: 40px;
}
.l-header-side__tel {
  margin-left: 20px;
  padding-left: 20px;
  border-left: 1px solid #E6E6E6;
}
.l-header-side__number {
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  font-weight: bold;
  letter-spacing: 0.1rem;
  font-size: 17px;
}
.l-header-side__time {
  font-size: 13px;
}
.is-scrolled-96 .l-header-side__simple-button {
  padding: 7px 14px 7px 16px;
}
.l-header-panels {
  margin-left: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.l-header-panels__dropdown {
  text-align: center;
  padding-bottom: 20px;
}
.l-header-panels__dropdown__heading {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding-bottom: 10px;
  border-bottom: 1px solid #222;
  font-weight: 700;
  font-family: 太ゴB101, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-size: 18px;
  margin-bottom: 10px;
}
.l-header-panels__dropdown__heading img {
  margin-right: 10px;
}
.l-header-subnav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.l-header-subnav__item {
  font-size: 13px;
}
.l-header-subnav__item--external > a::after {
  content: "";
  display: inline-block;
  background-image: url(../images/common/icon-external.svg);
  width: 10px;
  height: 9px;
  background-size: contain;
  margin-left: 1px;
  vertical-align: middle;
}
.l-header-subnav__item--external > a:hover::after {
  background-image: url(../images/common/icon-external-hover.svg);
}
.l-header-subnav__item > a {
  display: block;
  background-image: -webkit-gradient(linear, left top, left bottom, from(#EF3340), to(#EF3340));
  background-image: linear-gradient(#EF3340, #EF3340);
  background-position: 100% 100%;
  background-repeat: no-repeat;
  background-size: 0% 1px;
  -webkit-transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  padding-bottom: 1px;
}
@media screen and (min-width: 992px) {
  .l-header-subnav__item > a:hover {
    color: #EF3340;
    background-position: 0 100%;
    background-size: 100% 1px;
  }
}
.l-header-subnav__item:not(:first-child) {
  margin-left: 18px;
}
.l-header-spsub {
  display: none;
}
@media screen and (max-width: 991px) {
  .l-header-spsub {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.l-header-spsub__list {
  border: 1px solid #222;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-right: 12px;
}
.l-header-spsub__item + .l-header-spsub__item {
  border-left: 1px solid #222;
}
.l-header-spsub__item > a {
  font-size: 10px;
  line-height: 1.4;
  padding: 3px 12px;
}
@media screen and (max-width: 767px) {
  .l-header-spsub__item > a {
    padding: 3px 7px;
  }
}

/**
 * p-header-nav
 */
.p-header-nav__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.p-header-nav__item {
  font-size: 14px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  padding: 0 30px;
}
@media screen and (min-width: ) {
  .p-header-nav__item {
    padding: 0 20px;
    font-size: 13px;
  }
}
.p-header-nav__item + .p-header-nav__item {
  border-left: 1px solid #E6E6E6;
}
.p-header-nav__item > a {
  display: block;
  background-image: -webkit-gradient(linear, left top, left bottom, from(#EF3340), to(#EF3340));
  background-image: linear-gradient(#EF3340, #EF3340);
  background-position: 100% 100%;
  background-repeat: no-repeat;
  background-size: 0% 1px;
  -webkit-transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  padding-bottom: 3px;
}
@media screen and (min-width: 992px) {
  .p-header-nav__item > a:hover {
    color: #EF3340;
    background-position: 0 100%;
    background-size: 100% 1px;
  }
}
.p-header-nav__button {
  position: relative;
  display: block;
  cursor: pointer;
  background-image: -webkit-gradient(linear, left top, left bottom, from(#EF3340), to(#EF3340));
  background-image: linear-gradient(#EF3340, #EF3340);
  background-position: 100% 100%;
  background-repeat: no-repeat;
  background-size: 0% 1px;
  -webkit-transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  padding-bottom: 3px;
}
@media screen and (min-width: 992px) {
  .p-header-nav__button:hover {
    color: #EF3340;
    background-position: 0 100%;
    background-size: 100% 1px;
  }
}
.p-header-nav__dropdown-bg {
  background: #fff;
  -webkit-transition: height 300ms;
  transition: height 300ms;
  height: 0;
  position: fixed;
  top: 96px;
  left: 0;
  right: 0;
  z-index: 21;
}
.is-scrolled-96 .p-header-nav__dropdown-bg {
  top: 76px;
}
.p-header-nav__dropdown-overlay {
  background: rgba(0, 0, 0, 0.4);
  -webkit-transition: opacity 300ms;
  transition: opacity 300ms;
  position: fixed;
  top: 96px;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 20;
  opacity: 0;
}
.is-scrolled-96 .p-header-nav__dropdown-overlay {
  top: 76px;
}
.is-nav-open .p-header-nav__dropdown-overlay {
  opacity: 1;
}
.p-header-nav__children {
  height: 0;
  opacity: 0;
  overflow: hidden;
  -webkit-transition: opacity 200ms ease-out 300ms;
  transition: opacity 200ms ease-out 300ms;
  position: absolute;
  top: 86px;
  left: 0;
  right: 0;
  width: 100%;
  z-index: 25;
}
.is-scrolled-96 .p-header-nav__children {
  top: 68px;
}
.is-nav-open .p-header-nav__children {
  opacity: 1;
}

.l-header-banner {
  background-attachment: fixed;
  background-image: linear-gradient(105deg, #e73ede 10%, #f6d448 30%, #e73324 45%, #bc36f6 55%, #3f69f6 65%, #9ee74a 75%, #e73ede 90%);
  width: 100%;
  background-size: 700vw 100%;
  -webkit-animation-name: gradation;
  animation-name: gradation;
  -webkit-animation-duration: 150s;
  animation-duration: 150s;
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  -webkit-animation-direction: normal;
  animation-direction: normal;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  padding: 10px 0;
}
@media screen and (max-width: 991px) {
  .l-header-banner {
    display: none;
  }
}

@-webkit-keyframes gradation {
  0% {
    background-position: 0% 0%;
  }
  100% {
    background-position: -700vw 100%;
  }
}
@keyframes gradation {
  0% {
    background-position: 0% 0%;
  }
  100% {
    background-position: -700vw 100%;
  }
}
/* Menu
   ----------------------------------------------------------------- */
.l-menu-contents {
  position: fixed;
  top: 80px;
  left: 0;
  background-color: #fff;
  width: 100%;
  height: 0;
  overflow: scroll;
  z-index: 80;
  -webkit-transition: height 0.3s;
  transition: height 0.3s;
}
@media screen and (min-width: 992px) {
  .l-menu-contents {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .l-menu-contents {
    top: 60px;
  }
}
.l-menu-contents.is-open {
  height: calc(100% - 80px);
}
@media screen and (max-width: 767px) {
  .l-menu-contents.is-open {
    height: calc(100% - 60px);
  }
}
.l-menu-contents__inner {
  -webkit-transition: opacity 200ms ease-out 300ms;
  transition: opacity 200ms ease-out 300ms;
  opacity: 0;
  padding-top: 10px;
}
.l-menu-contents.is-open .l-menu-contents__inner {
  opacity: 1;
}
.l-menu-contents__link {
  font-size: 15px;
  display: block;
  padding: 16px 40px;
  position: relative;
}
.l-menu-contents__link--external::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 30px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background-image: url(../images/common/icon-external.svg);
  width: 15px;
  height: 14px;
  background-size: contain;
  vertical-align: middle;
}
.l-menu-contents__button {
  font-size: 15px;
  display: block;
  width: 100%;
  padding: 16px 40px;
  background-image: url(../images/common/icon-plus.svg);
  background-repeat: no-repeat;
  background-position: right 30px center;
}
.l-menu-contents__button.is-open {
  background-image: url(../images/common/icon-minus.svg);
}
.l-menu-contents__toggle {
  height: 0;
  overflow: hidden;
  -webkit-transition: height 0.3s;
  transition: height 0.3s;
}
.l-menu-contents__sublist {
  background-color: #F9F9F9;
  padding: 22px 40px;
}
.l-menu-contents__subitem {
  padding: 4px 0;
}
.l-menu-contents__subitem + .l-menu-contents__subitem {
  margin-top: 16px;
}
.l-menu-contents__subitem > a {
  display: block;
  font-size: 13px;
  position: relative;
  padding-left: 16px;
  line-height: 1.4;
}
.l-menu-contents__subitem > a > span {
  font-size: 11px;
  display: block;
  margin-top: 7px;
}
.l-menu-contents__subitem > a::before {
  content: "";
  position: absolute;
  top: 10px;
  left: 0px;
  width: 6px;
  height: 1px;
  background-color: #222;
  margin-right: 6px;
}

/* Wrapper
   ----------------------------------------------------------------- */
.l-wrapper {
  width: 100%;
  overflow-x: hidden;
}
@media screen and (max-width: 991px) {
  .l-wrapper {
    padding-top: 80px;
  }
}
@media screen and (max-width: 767px) {
  .l-wrapper {
    padding-top: 60px;
  }
}
.l-wrapper--form {
  padding-top: 0 !important;
}
.l-wrapper--header-sticky {
  overflow: visible;
  padding-top: 0 !important;
}
.l-wrapper--header-sticky .l-header {
  position: sticky;
  top: 0;
  width: 100%;
  background-color: #fff;
}

.l-main {
  margin-bottom: 60px;
}
.l-main--top {
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .l-main--top {
    margin-top: 40px;
  }
}
.l-main--top .l-article-header {
  margin-bottom: 90px;
}
@media screen and (max-width: 767px) {
  .l-main--top .l-article-header {
    margin-bottom: 40px;
  }
}
.l-main--offset {
  margin-bottom: -60px;
}
.l-main--industry .c-heading-4 {
  margin-top: 30px;
}
.l-main__more-information {
  margin-top: 160px;
}
@media screen and (max-width: 767px) {
  .l-main__more-information {
    margin-top: 60px;
  }
}

.c-more-infomation {
  background-color: #F9F9F9;
}
.c-more-infomation__inner {
  padding: 55px 0 65px;
  width: 994px;
  margin: auto;
}
@media screen and (max-width: 991px) {
  .c-more-infomation__inner {
    width: auto;
    padding: 55px 40px;
  }
}
@media screen and (max-width: 767px) {
  .c-more-infomation__inner {
    padding: 55px 30px;
  }
}
.c-more-infomation__heading {
  text-align: center;
}
.c-more-infomation__en {
  font-size: 12px;
  color: #EF3340;
  line-height: 1.4;
  display: block;
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  font-weight: bold;
  letter-spacing: 0.1rem;
}
.c-more-infomation__jp {
  font-size: 32px;
  line-height: 1.4;
  margin-top: 22px;
  display: block;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .c-more-infomation__jp {
    font-size: 24px;
  }
}
.c-more-infomation__image {
  overflow: hidden;
}
.c-more-infomation__image > img {
  -webkit-transition: -webkit-transform 0.75s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: -webkit-transform 0.75s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 0.75s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 0.75s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.75s cubic-bezier(0.215, 0.61, 0.355, 1);
  width: 100%;
  height: auto;
}
.c-more-infomation__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 60px;
}
@media screen and (max-width: 991px) {
  .c-more-infomation__list {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-top: 0;
    padding: 0 20px;
  }
}
@media screen and (max-width: 767px) {
  .c-more-infomation__list {
    display: block;
    padding: 0;
  }
}
.c-more-infomation__item {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 300px;
  flex: 0 0 300px;
}
@media screen and (min-width: 992px) {
  .c-more-infomation__item > a:hover .u-underline {
    color: #EF3340;
    background-position: 0 100%;
    background-size: 100% 1px;
  }
  .c-more-infomation__item > a:hover .c-more-infomation__image > img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
}
@media screen and (max-width: 991px) {
  .c-more-infomation__item {
    margin-top: 60px;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 47%;
    flex: 0 0 47%;
  }
}
.c-more-infomation__item + .c-more-infomation__item {
  margin-left: 46px;
}
@media screen and (max-width: 991px) {
  .c-more-infomation__item + .c-more-infomation__item {
    margin-left: 0;
  }
}
@media screen and (max-width: 991px) {
  .c-more-infomation__item:nth-child(2n) {
    margin-left: 6%;
  }
}
@media screen and (max-width: 767px) {
  .c-more-infomation__item:nth-child(2n) {
    margin-left: 0;
  }
}
.c-more-infomation__text {
  margin-top: 26px;
  line-height: 1.4;
  font-size: 20px;
  text-align: center;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}

.l-appeal {
  margin-top: 60px;
}
.l-appeal__contents {
  padding: 60px 0 126px;
  background-image: url(../images/common/bg-contact.jpg);
  background-size: cover;
  background-position: center;
}
@media screen and (max-width: 767px) {
  .l-appeal__contents {
    background-image: url(../images/common/bg-contact-sm.jpg);
    padding-bottom: 50px;
  }
}
@media screen and (max-width: 575px) {
  .l-appeal__contents {
    padding: 55px 30px;
  }
}
.l-appeal__catch {
  text-align: center;
  color: #fff;
  font-size: 24px;
  line-height: 1.8;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .l-appeal__catch {
    font-size: 20px;
  }
}
@media screen and (max-width: 575px) {
  .l-appeal__catch {
    text-align: left;
  }
}
.l-appeal__text {
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .l-appeal__text {
    margin-top: 20px;
    font-size: 14px;
  }
}
@media screen and (max-width: 575px) {
  .l-appeal__text {
    text-align: left;
  }
}
.l-appeal__tel {
  margin-top: 17px;
  color: #fff;
  text-align: center;
}
.l-appeal__note {
  margin-top: 15px;
  font-size: 12px;
  color: #fff;
  text-align: center;
}
.l-appeal-tel {
  border-top: 1px solid #222;
  border-bottom: 1px solid #222;
  padding: 20px;
  text-align: center;
}
.l-appeal-tel h4 {
  margin-bottom: 5px;
}
.l-appeal-sm {
  border-top: 1px solid #222;
  border-bottom: 1px solid #222;
  padding: 71px 0;
}
@media screen and (max-width: 767px) {
  .l-appeal-sm {
    padding: 45px 0;
  }
}
.l-appeal-sm__heading {
  font-size: 32px;
  text-align: center;
  line-height: 1.4;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .l-appeal-sm__heading {
    font-size: 20px;
    text-align: left;
    line-height: 1.6;
  }
}
.l-appeal-sm__heading--sm {
  font-size: 24px;
}
@media screen and (max-width: 767px) {
  .l-appeal-sm__heading--sm {
    font-size: 20px;
  }
}
.l-appeal-sm__text {
  font-size: 16px;
  line-height: 1.4;
  text-align: center;
  margin-top: 8px;
}
@media screen and (max-width: 767px) {
  .l-appeal-sm__text {
    font-size: 14px;
    text-align: left;
    margin-top: 10px;
    line-height: 1.6;
  }
}
.l-appeal-sm__tel {
  text-align: center;
  margin-top: 24px;
}
@media screen and (max-width: 767px) {
  .l-appeal-sm__tel {
    text-align: left;
  }
}
.l-appeal-sm__note {
  text-align: center;
  font-size: 12px;
  margin-top: 9px;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .l-appeal-sm__note {
    text-align: left;
    margin-top: 10px;
  }
}
.l-appeal-sm__cta {
  margin: 27px auto 0;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 991px) {
  .l-appeal-sm__cta {
    width: auto;
  }
}
@media screen and (max-width: 767px) {
  .l-appeal-sm__cta {
    margin-top: 33px;
    padding: 0;
  }
}
.l-appeal-sm__item {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 50%;
  flex: 0 0 50%;
  background-color: #fff;
}
.l-appeal-sm__item > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-align: center;
  position: relative;
  height: 110px;
  font-size: 24px;
  color: #fff;
  line-height: 1.4;
  -webkit-transition: background-color 0.5s;
  transition: background-color 0.5s;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
.l-appeal-sm__item > a.is-sm {
  font-size: 18px;
}
@media screen and (max-width: 991px) {
  .l-appeal-sm__item > a {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    font-size: 14px;
    height: 130px;
  }
}
@media screen and (max-width: 767px) {
  .l-appeal-sm__item > a {
    height: 130px;
  }
}
.l-appeal-sm__item > a::before {
  content: "";
  display: inline-block;
  background-repeat: no-repeat;
  background-position: center;
  margin-right: 24px;
}
@media screen and (max-width: 991px) {
  .l-appeal-sm__item > a::before {
    display: block;
    margin-right: 0;
    margin-bottom: 12px;
  }
}
.l-appeal-sm__item > a::after {
  content: "";
  position: absolute;
  right: 10px;
  bottom: 10px;
  width: 0;
  height: 0;
  border-style: solid;
  border-right-width: 26px;
  border-top-width: 26px;
  -webkit-transition: border-color 0.5s;
  transition: border-color 0.5s;
}
.l-appeal-sm__item--form > a {
  background-color: #EF3340;
}
.l-appeal-sm__item--form > a::before {
  width: 30px;
  height: 21px;
  background-image: url(../images/common/icon-contact.svg);
  background-size: 30px 21px;
}
@media screen and (max-width: 991px) {
  .l-appeal-sm__item--form > a::before {
    width: 100%;
    height: 30px;
  }
}
.l-appeal-sm__item--form > a::after {
  border-color: transparent #C8102E;
}
@media screen and (min-width: 992px) {
  .l-appeal-sm__item--form > a:hover {
    background-color: #B02D36;
  }
}
.l-appeal-sm__item--download > a {
  background-color: #C8102E;
}
.l-appeal-sm__item--download > a::before {
  width: 24px;
  height: 30px;
  background-image: url(../images/common/icon-document.svg);
  background-size: 24px 30px;
}
@media screen and (max-width: 991px) {
  .l-appeal-sm__item--download > a::before {
    width: 100%;
    height: 30px;
  }
}
.l-appeal-sm__item--download > a::after {
  border-color: transparent #EF3340;
}
@media screen and (min-width: 992px) {
  .l-appeal-sm__item--download > a:hover {
    background-color: #95102A;
  }
}
.l-appeal-sm__item--demo > a {
  background-color: #C8102E;
}
.l-appeal-sm__item--demo > a::before {
  width: 50px;
  height: 30px;
  background-image: url(../images/common/icon-demo.svg);
  background-size: 50px 30px;
}
@media screen and (max-width: 991px) {
  .l-appeal-sm__item--demo > a::before {
    width: 100%;
    height: 30px;
  }
}
.l-appeal-sm__item--demo > a::after {
  border-color: transparent #EF3340;
}
@media screen and (min-width: 992px) {
  .l-appeal-sm__item--demo > a:hover {
    background-color: #95102A;
  }
}
.l-appeal-sm__item--light > a {
  background-color: #EF3340;
}
.l-appeal-sm__item--dark > a {
  background-color: #C8102E;
}

.l-article-eyecatch {
  margin-bottom: 30px;
}
.l-article-eyecatch__caption {
  margin-top: 20px;
  color: #666;
  font-size: 12px;
}

.l-article-header {
  position: relative;
  margin-bottom: 60px;
}
.l-article-header__date {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 20px;
  font-size: 14px;
}
.l-article-header__date dl {
  margin-right: 20px;
}
.l-article-header__date dt {
  margin-right: 10px;
}
.l-article-header__date time {
  margin-right: 20px;
  color: #AAAAAA;
  font-weight: 700;
}
.l-article-header__company {
  margin-top: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767px) {
  .l-article-header__company {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
@media screen and (min-width: 768px) {
  .l-article-header__company {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.l-article-header__logo {
  margin-top: 20px;
}
@media screen and (min-width: 768px) {
  .l-article-header__logo {
    margin-left: auto;
    margin-top: 0;
  }
}
.l-article-header--center {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .l-article-header--center {
    text-align: left;
  }
}
.l-article-header__heading {
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-size: 36px;
  line-height: 54px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .l-article-header__heading {
    font-size: 28px;
    line-height: 42px;
  }
}
.l-article-header__attribute {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-top: 20px;
}
.l-article-header__attribute time {
  margin-right: 20px;
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  color: #AAAAAA;
  font-weight: 700;
  font-size: 14px;
}
@media screen and (max-width: 991px) {
  .l-article-header__attribute {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }
}
.l-article-header__lists {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.l-article-header__tags {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.l-article-header__tags > * {
  margin-right: 10px;
  margin-bottom: 5px;
  margin-top: 5px;
}
.l-article-header__share {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-left: auto;
}
.l-article-header__share > * {
  margin-right: 10px;
  margin-bottom: 5px;
  margin-top: 5px;
}
.l-article-header__share a:hover {
  opacity: 0.8;
}
@media screen and (max-width: 991px) {
  .l-article-header__share {
    margin-left: 0;
    margin-top: 10px;
  }
}
.l-article-header__description {
  margin-top: 20px;
  font-size: 14px;
}
.l-article-header__name {
  font-size: 14px;
  font-weight: 700;
}
.l-article-header__card {
  margin-top: -40px;
  padding: 30px;
  background-color: #F9F9F9;
}
@media screen and (max-width: 767px) {
  .l-article-header__card {
    margin-top: 0;
  }
}
.l-article-header__eyecatch {
  margin-top: 30px;
}
.l-article-header__user-story {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0;
  margin: 0;
  position: absolute;
  letter-spacing: 0.1rem;
  line-height: 1;
  -webkit-transform-origin: top right;
  transform-origin: top right;
  -webkit-transform: rotate(90deg) translateX(100%);
  transform: rotate(90deg) translateX(100%);
  top: 60px;
  right: -30px;
  z-index: 1;
  font-weight: 700;
}
@media screen and (max-width: 991px) {
  .l-article-header__user-story {
    display: none;
  }
}
.l-article-header__user-story:before {
  content: "";
  height: 1px;
  width: 90px;
  margin-right: 7.5px;
  background-color: #222;
}
@media screen and (max-width: 991px) {
  .l-article-header__user-story:before {
    width: 30px;
  }
}

.l-article-header-seminars__status {
  margin-top: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-size: 20px;
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  font-weight: 700;
  min-height: 60px;
}
@media screen and (max-width: 767px) {
  .l-article-header-seminars__status {
    font-size: 14px;
  }
  .l-article-header-seminars__status strong {
    font-size: 16px;
  }
}
.l-article-header-seminars__status strong {
  font-size: 28px;
  margin-right: 0.5rem;
}
.l-article-header-seminars__status .c-label {
  margin-right: 0.5rem;
}
.l-article-header-seminars__attributes {
  margin-top: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.l-article-header-seminars__attributes li {
  margin-right: 20px;
}
.l-article-header-seminars__attributes img {
  margin-right: 0.5rem;
  vertical-align: sub;
}

.l-article {
  margin-bottom: 40px;
}
.l-article * {
  font-size: 14px;
}
.l-article > * {
  margin-top: 20px;
}
.l-article h2, .l-article h3, .l-article h4, .l-article h5 {
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-weight: 700;
}
.l-article h2 {
  font-size: 28px;
  line-height: 42px;
  margin-top: 60px;
  border-bottom: 1px solid #E6E6E6;
  position: relative;
  padding-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .l-article h2 {
    font-size: 20px;
    line-height: 30px;
  }
}
.l-article h2:before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 80px;
  height: inherit;
  border-bottom: 1px solid #222;
}
.l-article h2 + h3 {
  margin-top: 20px;
}
.l-article h3 {
  font-size: 20px;
  line-height: 30px;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .l-article h3 {
    font-size: 16px;
    line-height: 24px;
  }
}
.l-article h4 {
  font-size: 16px;
  line-height: 24px;
}
@media screen and (max-width: 767px) {
  .l-article h4 {
    font-size: 14px;
    line-height: 21px;
  }
}
.l-article ul, .l-article ol {
  padding-left: 30px;
}
.l-article ul li + li, .l-article ol li + li {
  margin-top: 5px;
}
.l-article ul {
  list-style-type: disc;
}
.l-article ol {
  list-style-type: decimal;
}
.l-article a {
  text-decoration: underline;
}

.l-it-hojo__mv {
  background: -webkit-gradient(linear, left top, left bottom, from(#f4f3f8), color-stop(95%, #f4f3f8), color-stop(95%, white));
  background: linear-gradient(180deg, #f4f3f8 0%, #f4f3f8 95%, white 95%);
  margin-bottom: 30px;
}
.l-it-hojo__mv span {
  font-weight: bold;
  display: block;
  margin-bottom: 10px;
  font-size: 14px;
}
.l-it-hojo__mv h1 {
  font-size: 36px;
  font-weight: bold;
  line-height: 54px;
  margin-bottom: 30px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
}
@media screen and (max-width: 991px) {
  .l-it-hojo__mv {
    text-align: center;
    background: #F4F3F8;
    padding-top: 30px;
    padding-bottom: 30px;
  }
  .l-it-hojo__mv h1 {
    font-size: 24px;
    margin-bottom: 20px;
    line-height: 1.5;
  }
}
.l-it-hojo__border-box {
  border: 1px dashed #939FA8;
  padding: 20px;
}
.l-it-hojo__border-box h3 {
  font-weight: bold;
  font-size: 14px;
  margin-bottom: 10px;
}
.l-it-hojo__case {
  margin-top: 4rem;
  background-color: #fff;
  padding: 20px;
  position: relative;
  text-align: center;
  -webkit-box-shadow: 0px 10px 24px rgba(0, 0, 0, 0.1);
  box-shadow: 0px 10px 24px rgba(0, 0, 0, 0.1);
  border-radius: 6px;
}
.l-it-hojo__case__eyecatch {
  margin-top: -4rem;
  margin-bottom: 20px;
}
.l-it-hojo__case h3 {
  font-weight: bold;
  font-size: 16px;
  margin-bottom: 20px;
}
.l-it-hojo__feature {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.l-it-hojo__feature__no {
  color: #EF3340;
  font-size: 46px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  line-height: 1;
  padding-right: 20px;
  margin-right: 20px;
  border-right: 2px solid #EF3340;
}
.l-it-hojo__feature h3 {
  font-weight: bold;
  font-size: 20px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  margin-bottom: 20px;
}
.l-it-hojo__table th, .l-it-hojo__table td {
  text-align: center;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  vertical-align: middle;
}
.l-it-hojo__table thead th {
  background-color: #999;
  color: #fff;
  font-weight: bold;
}
.l-it-hojo__table tbody tr th {
  background-color: #222;
  color: #fff;
  font-weight: bold;
  font-size: 16px;
  min-width: 6rem;
}
@media screen and (max-width: 767px) {
  .l-it-hojo__table tbody tr th {
    font-size: 13px;
    min-width: 5rem;
  }
}
.l-it-hojo__table tbody tr td {
  font-weight: bold;
  background-color: #F4F3F8;
}
@media screen and (max-width: 767px) {
  .l-it-hojo__table tbody tr td {
    line-height: 1.5;
    font-weight: normal;
  }
}
.l-it-hojo__table tbody tr td strong {
  font-size: 20px;
  padding-left: 4px;
  padding-right: 2px;
}
@media screen and (max-width: 767px) {
  .l-it-hojo__table tbody tr td strong {
    font-size: 14px;
    font-weight: bold;
    padding: 0;
  }
}
.l-it-hojo__seminar {
  -webkit-box-shadow: 0px 10px 24px rgba(0, 0, 0, 0.1);
  box-shadow: 0px 10px 24px rgba(0, 0, 0, 0.1);
  border-radius: 6px;
  background-color: #fff;
  margin-bottom: 30px;
}
.l-it-hojo__seminar__content {
  padding: 20px;
}
.l-it-hojo__seminar__heading {
  font-size: 16px;
  font-weight: bold;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
}

.l-terms {
  margin-bottom: 40px;
}
.l-terms-wrapper {
  border-top: 3px solid #EF3340;
  background: #f9f9f9;
}
.l-terms-header, .l-terms h1 {
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-weight: 700;
  margin-top: 60px;
  font-size: 20px;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 4px;
  padding: 5px 10px;
}
.l-terms * {
  font-size: 14px;
}
.l-terms > * {
  margin-top: 20px;
}
.l-terms h2, .l-terms h3, .l-terms h4, .l-terms h5 {
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-weight: 700;
}
.l-terms h2 {
  font-size: 16px;
  line-height: 24px;
  margin-top: 40px;
}
.l-terms ul, .l-terms ol {
  padding-left: 30px;
}
.l-terms ul li + li, .l-terms ol li + li {
  margin-top: 5px;
}
.l-terms ul {
  list-style-type: disc;
}
.l-terms ol {
  list-style-type: decimal;
}
.l-terms a {
  text-decoration: underline;
}

.l-case-attributes {
  margin-top: 30px;
  width: 100%;
}
.l-case-attributes th, .l-case-attributes td {
  padding: 5px 0;
}
.l-case-attributes th {
  width: 7rem;
  padding-right: 10px;
}
@media screen and (max-width: 767px) {
  .l-case-attributes tr {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-bottom: 10px;
  }
  .l-case-attributes th, .l-case-attributes td {
    padding: 0;
  }
}
.l-case-problems, .l-case-effects {
  margin-top: 20px;
}
.l-case-problems th, .l-case-effects th {
  background-color: #999;
  color: #fff;
  vertical-align: middle;
  font-size: 20px;
  width: 6rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .l-case-problems th, .l-case-effects th {
    width: 2rem;
    padding: 10px;
  }
}
.l-case-problems td, .l-case-effects td {
  padding: 10px 10px 10px 20px;
}
.l-case-problems td ul, .l-case-effects td ul {
  padding-left: 15px;
}
.l-case-problems td ul li:before, .l-case-effects td ul li:before {
  content: "-";
  color: #999;
  margin-left: -15px;
  margin-right: 10px;
}
.l-case-effects th {
  background-color: #EF3340;
}
.l-case-effects td ul li {
  font-weight: 700;
  font-family: 太ゴB101, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
}
.l-case-effects td ul li:before {
  content: "-";
  color: #EF3340;
}
.l-case-products {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.l-case-products li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-right: 10px;
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .l-case-products li {
    margin-top: 10px;
    margin-bottom: 0;
  }
}
.l-case-products li img {
  width: 1.5rem;
  height: auto;
  margin-right: 5px;
}
.l-case-products li a:hover {
  opacity: 0.8;
}

/**
 * c-arrow-button
 */
.c-arrow-button {
  display: block;
  background-repeat: no-repeat;
  background-position: center;
  width: 72px;
  height: 72px;
  background-color: rgba(255, 255, 255, 0.8);
  -webkit-box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.2);
  box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.2);
  border-radius: 50%;
  overflow: visible;
  position: relative;
}
.c-arrow-button--right {
  background-image: url(../images/common/icon-arrow-right.svg);
}
.c-arrow-button--left {
  background-image: url(../images/common/icon-arrow-left.svg);
}
.c-arrow-button--simple {
  width: 15px;
  height: 15px;
  border-radius: 0;
  background-color: transparent;
  -webkit-box-shadow: none;
  box-shadow: none;
}

.c-balloon {
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-bottom: 20px;
}
.c-balloon__item {
  position: relative;
  text-align: center;
  background-color: #939FA8;
  color: #fff;
  padding: 10px 40px;
  border-radius: 120px;
  line-height: 1.6;
}
.c-balloon__item:after {
  border: solid transparent;
  content: "";
  height: 0;
  width: 0;
  pointer-events: none;
  position: absolute;
  border-color: rgba(147, 159, 168, 0);
  border-top-width: 12px;
  border-bottom-width: 12px;
  border-left-width: 11px;
  border-right-width: 11px;
  margin-left: -11px;
  border-top-color: #939FA8;
  top: 100%;
  left: 50%;
}
.c-balloon--lg {
  font-size: 18px;
}
.c-balloon--primary-light .c-balloon__item {
  position: relative;
  background: #FFEEEE;
  text-align: center;
  border: 1px solid #EF3340;
  color: #EF3340;
  padding: 10px 40px;
  border-radius: 120px;
  line-height: 1.6;
}
.c-balloon--primary-light .c-balloon__item:after, .c-balloon--primary-light .c-balloon__item:before {
  border: solid transparent;
  content: "";
  height: 0;
  width: 0;
  pointer-events: none;
  position: absolute;
  top: 100%;
  left: 50%;
}
.c-balloon--primary-light .c-balloon__item:after {
  border-color: rgba(255, 238, 238, 0);
  border-top-width: 10px;
  border-bottom-width: 10px;
  border-left-width: 10px;
  border-right-width: 10px;
  margin-left: -10px;
  border-top-color: #FFEEEE;
}
.c-balloon--primary-light .c-balloon__item:before {
  border-color: rgba(239, 51, 64, 0);
  border-top-width: 11px;
  border-bottom-width: 11px;
  border-left-width: 11px;
  border-right-width: 11px;
  margin-left: -11px;
  margin-top: 1px;
  border-top-color: #EF3340;
}

/**
 * c-heading
 */
.c-heading {
  padding-left: 37px;
  position: relative;
  margin-bottom: 60px;
}
@media screen and (max-width: 767px) {
  .c-heading {
    margin-bottom: 40px;
  }
}
.c-heading::before {
  content: "";
  position: absolute;
  top: 16px;
  left: 0;
  width: 4px;
  height: calc(100% - 16px);
  background-color: #222;
}
.c-heading__lead {
  font-size: 14px;
  margin-bottom: 40px;
}
.c-heading__primary {
  display: block;
  font-size: 54px;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .c-heading__primary {
    font-size: 46px;
  }
}
.c-heading__secondary {
  display: block;
  font-size: 24px;
  margin-top: 13px;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .c-heading__secondary {
    font-size: 18px;
    margin-top: 26px;
  }
}
.c-heading-horizonal {
  margin-bottom: 60px;
}
.c-heading-horizonal__primary {
  font-size: 44px;
  line-height: 1;
  vertical-align: middle;
}
.c-heading-horizonal__secondary {
  font-size: 24px;
  line-height: 1;
  margin-left: 20px;
  vertical-align: middle;
}
@media screen and (max-width: 767px) {
  .c-heading-horizonal__secondary {
    display: block;
    margin-top: 14px;
    margin-left: 0;
    font-size: 18px;
  }
}

.c-heading-md {
  padding-left: 30px;
  position: relative;
  margin-bottom: 40px;
  line-height: 28px;
  border-left: 2px solid #222;
  font-size: 28px;
  font-weight: 700;
  line-height: 1.5;
  display: block;
}
@media screen and (max-width: 767px) {
  .c-heading-md {
    font-size: 19.6px;
    padding-left: 22px;
  }
}

.c-heading-sm {
  padding-left: 30px;
  position: relative;
  margin-bottom: 40px;
  line-height: 36px;
  border-left: 2px solid #222;
}
@media screen and (max-width: 767px) {
  .c-heading-sm {
    padding-left: 22px;
  }
}
.c-heading-sm__primary {
  font-size: 36px;
  line-height: 1.5;
  display: block;
}
.c-heading-sm__primary--under {
  margin-top: 17px;
}
@media screen and (max-width: 767px) {
  .c-heading-sm__primary {
    font-size: 22px;
  }
}
.c-heading-sm__secondary {
  font-size: 15.4px;
  line-height: 1.4;
  display: block;
}
@media screen and (max-width: 767px) {
  .c-heading-sm__secondary {
    font-size: 14px;
  }
}

.c-heading-center {
  text-align: center;
  margin-bottom: 40px;
}
.c-heading-center__en {
  font-size: 12px;
  color: #EF3340;
  line-height: 1.4;
  display: block;
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  font-weight: bold;
  letter-spacing: 0.1rem;
  text-transform: uppercase;
}
.c-heading-center__jp {
  font-size: 32px;
  line-height: 1.7;
  margin-top: 22px;
  display: block;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .c-heading-center__jp {
    font-size: 24px;
  }
}
@media screen and (min-width: 992px) {
  .c-heading-center__with-icon {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    text-align: left;
  }
  .c-heading-center__with-icon small {
    padding-right: 20px;
  }
}
@media screen and (max-width: 991px) {
  .c-heading-center__with-icon small {
    display: none;
  }
}

.c-heading-3 {
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-weight: 700;
  font-size: 28px;
  margin-bottom: 30px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .c-heading-3 {
    font-size: 23.8px;
  }
}

.c-heading-4 {
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-weight: 700;
  font-size: 20px;
  margin-bottom: 30px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .c-heading-4 {
    font-size: 17px;
  }
}

.c-heading-5 {
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-weight: 700;
  font-size: 16px;
  margin-bottom: 20px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .c-heading-5 {
    font-size: 13.6px;
  }
}

/**
 * c-link
 */
.c-link {
  display: inline-block;
  background-color: #EF3340;
  padding: 15px 31px;
  font-size: 22px;
  color: #fff;
  text-decoration: none !important;
  text-align: center;
  -webkit-transition: background-color 0.5s;
  transition: background-color 0.5s;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  -webkit-box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
  box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
}
.c-link--form {
  padding: 15px 110px;
}
@media screen and (min-width: 992px) {
  .c-link:hover {
    background-color: #B02D36;
  }
}
@media screen and (max-width: 991px) {
  .c-link {
    padding: 14px 21px;
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .c-link {
    font-size: 16px;
  }
}

/**
 * c-linkpanel
 */
.c-linkpanel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-align: center;
  width: 150px;
  height: 50px;
  color: #fff;
  font-size: 12px;
  -webkit-transition: background-color 0.5s;
  transition: background-color 0.5s;
  -webkit-box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
  box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
}
@media screen and (min-width: 992px) {
  .is-scrolled-96 .c-linkpanel {
    height: 40px;
  }
}
.c-linkpanel--form {
  background-color: #C8102E;
}
.c-linkpanel--form::before {
  content: "";
  display: inline-block;
  width: 19px;
  height: 23px;
  background-image: url(../images/common/icon-document.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  margin-right: 8px;
}
@media screen and (max-width: 1200px) {
  .c-linkpanel--form::before {
    width: 13.3px;
    height: 16.1px;
  }
}
@media screen and (max-width: 1200px) {
  .c-linkpanel--form {
    width: 90px;
  }
}
@media screen and (min-width: 992px) {
  .c-linkpanel--form:hover {
    background-color: #95102A;
  }
}
.c-linkpanel--contact {
  background-color: #EF3340;
}
.c-linkpanel--contact::before {
  content: "";
  display: inline-block;
  width: 25px;
  height: 17px;
  background-image: url(../images/common/icon-contact.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  margin-right: 8px;
}
@media screen and (max-width: 1200px) {
  .c-linkpanel--contact::before {
    width: 17.5px;
    height: 11.9px;
  }
}
@media screen and (max-width: 1200px) {
  .c-linkpanel--contact {
    width: 110px;
  }
}
@media screen and (min-width: 992px) {
  .c-linkpanel--contact:hover {
    background-color: #B02D36;
  }
}

.c-more {
  display: inline-block;
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  font-size: 18px;
  -webkit-transition: color 0.3s;
  transition: color 0.3s;
}
.c-more__external {
  background-image: url(../images/common/icon-external.svg);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  width: 12px;
  height: 12px;
  position: relative;
  display: inline-block;
}
.c-more__border {
  position: relative;
  display: inline-block;
  margin-left: 5px;
  width: 21px;
  height: 1px;
  vertical-align: middle;
  top: -2px;
}
.c-more__border::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #EF3340;
}
.c-more--white-block {
  display: block;
  text-align: center;
  padding: 18px 0;
  position: relative;
  z-index: 5;
}
.c-more--white-block::before {
  background-color: #fff !important;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #F9F9F9;
  z-index: -10;
}
.c-more--white-block::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 100%;
  background-color: #E2E2E2;
  z-index: -5;
  -webkit-transition: width 0.3s;
  transition: width 0.3s;
}
@media screen and (min-width: 992px) {
  .c-more--white-block:hover {
    color: #EF3340;
  }
  .c-more--white-block:hover::after {
    width: 100%;
  }
  .c-more--white-block:hover .c-more__border::after {
    -webkit-animation: borderToLong 0.3s forwards;
    animation: borderToLong 0.3s forwards;
  }
}
.c-more--block {
  display: block;
  text-align: center;
  padding: 18px 0;
  position: relative;
  z-index: 5;
}
.c-more--block::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #F9F9F9;
  z-index: -10;
  -webkit-box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
  box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
}
.c-more--block::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 100%;
  background-color: #E2E2E2;
  z-index: -5;
  -webkit-transition: width 0.3s;
  transition: width 0.3s;
  -webkit-box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
  box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
}
@media screen and (min-width: 992px) {
  .c-more--block:hover {
    color: #EF3340;
  }
  .c-more--block:hover::after {
    width: 100%;
  }
  .c-more--block:hover .c-more__border::after {
    -webkit-animation: borderToLong 0.3s forwards;
    animation: borderToLong 0.3s forwards;
  }
}

.c-simple-button {
  padding: 11px 14px 11px 16px;
  line-height: 1;
  font-size: 14px;
  border: 1px solid #CCCCCC;
  -webkit-transition: color 0.3s, border 0.3s;
  transition: color 0.3s, border 0.3s;
}
@media screen and (max-width: 1200px) {
  .c-simple-button {
    font-size: 12px;
  }
}
.c-simple-button:hover {
  border: 1px solid #EF3340;
  color: #EF3340;
  cursor: pointer;
}

.c-tel {
  line-height: 1;
  font-size: 18px;
  font-weight: bold;
}
.c-tel > span {
  font-size: 34px;
}
.c-tel--appeal {
  font-size: 28px !important;
}
.c-tel--appeal a {
  text-decoration: none;
  font-size: 28px;
}
@media screen and (max-width: 575px) {
  .c-tel--appeal {
    font-size: 18px;
  }
  .c-tel--appeal a {
    font-size: 18px;
  }
}
.c-tel--appeal > span {
  font-size: 42px;
}
@media screen and (max-width: 575px) {
  .c-tel--appeal > span {
    font-size: 30px;
  }
}

.c-breadcrumb {
  display: inline-block;
}
.c-breadcrumb__list {
  background: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  padding: 5px 30px;
}
.c-breadcrumb__item {
  display: inline;
  font-size: 12px;
}
.c-breadcrumb__item::after {
  content: "＞";
  margin: 0 15px;
}
.c-breadcrumb__item:last-child::after {
  content: "";
  margin: 0;
}
@media screen and (min-width: 992px) {
  .c-breadcrumb__item > a {
    background-image: -webkit-gradient(linear, left top, left bottom, from(#EF3340), to(#EF3340));
    background-image: linear-gradient(#EF3340, #EF3340);
    background-position: 100% 100%;
    background-repeat: no-repeat;
    background-size: 0% 1px;
    -webkit-transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
    transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
    padding-bottom: 4px;
  }
}
@media screen and (min-width: 992px) and (min-width: 992px) {
  .c-breadcrumb__item > a:hover {
    color: #EF3340;
    background-position: 0 100%;
    background-size: 100% 1px;
  }
}

.c-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-right: -20px;
  margin-left: -20px;
}
@media screen and (min-width: 0) {
  .c-row.c-row--gap-xs-0 {
    margin-right: 0px;
    margin-left: 0px;
  }
  .c-row.c-row--gap-xs-0 .c-col {
    padding-right: 0px;
    padding-left: 0px;
  }
}
@media screen and (min-width: 0) {
  .c-row.c-row--gap-xs-1 {
    margin-right: -20px;
    margin-left: -20px;
  }
  .c-row.c-row--gap-xs-1 .c-col {
    padding-right: 20px;
    padding-left: 20px;
  }
}
@media screen and (min-width: 0) {
  .c-row.c-row--gap-xs-2 {
    margin-right: -40px;
    margin-left: -40px;
  }
  .c-row.c-row--gap-xs-2 .c-col {
    padding-right: 40px;
    padding-left: 40px;
  }
}
@media screen and (min-width: 0) {
  .c-row.c-row--gap-xs-3 {
    margin-right: -60px;
    margin-left: -60px;
  }
  .c-row.c-row--gap-xs-3 .c-col {
    padding-right: 60px;
    padding-left: 60px;
  }
}
@media screen and (min-width: 0) {
  .c-row.c-row--gap-xs-4 {
    margin-right: -80px;
    margin-left: -80px;
  }
  .c-row.c-row--gap-xs-4 .c-col {
    padding-right: 80px;
    padding-left: 80px;
  }
}
@media screen and (min-width: 0) {
  .c-row.c-row--gap-xs-5 {
    margin-right: -100px;
    margin-left: -100px;
  }
  .c-row.c-row--gap-xs-5 .c-col {
    padding-right: 100px;
    padding-left: 100px;
  }
}
@media screen and (min-width: 576px) {
  .c-row.c-row--gap-sm-0 {
    margin-right: 0px;
    margin-left: 0px;
  }
  .c-row.c-row--gap-sm-0 .c-col {
    padding-right: 0px;
    padding-left: 0px;
  }
}
@media screen and (min-width: 576px) {
  .c-row.c-row--gap-sm-1 {
    margin-right: -20px;
    margin-left: -20px;
  }
  .c-row.c-row--gap-sm-1 .c-col {
    padding-right: 20px;
    padding-left: 20px;
  }
}
@media screen and (min-width: 576px) {
  .c-row.c-row--gap-sm-2 {
    margin-right: -40px;
    margin-left: -40px;
  }
  .c-row.c-row--gap-sm-2 .c-col {
    padding-right: 40px;
    padding-left: 40px;
  }
}
@media screen and (min-width: 576px) {
  .c-row.c-row--gap-sm-3 {
    margin-right: -60px;
    margin-left: -60px;
  }
  .c-row.c-row--gap-sm-3 .c-col {
    padding-right: 60px;
    padding-left: 60px;
  }
}
@media screen and (min-width: 576px) {
  .c-row.c-row--gap-sm-4 {
    margin-right: -80px;
    margin-left: -80px;
  }
  .c-row.c-row--gap-sm-4 .c-col {
    padding-right: 80px;
    padding-left: 80px;
  }
}
@media screen and (min-width: 576px) {
  .c-row.c-row--gap-sm-5 {
    margin-right: -100px;
    margin-left: -100px;
  }
  .c-row.c-row--gap-sm-5 .c-col {
    padding-right: 100px;
    padding-left: 100px;
  }
}
@media screen and (min-width: 768px) {
  .c-row.c-row--gap-md-0 {
    margin-right: 0px;
    margin-left: 0px;
  }
  .c-row.c-row--gap-md-0 .c-col {
    padding-right: 0px;
    padding-left: 0px;
  }
}
@media screen and (min-width: 768px) {
  .c-row.c-row--gap-md-1 {
    margin-right: -20px;
    margin-left: -20px;
  }
  .c-row.c-row--gap-md-1 .c-col {
    padding-right: 20px;
    padding-left: 20px;
  }
}
@media screen and (min-width: 768px) {
  .c-row.c-row--gap-md-2 {
    margin-right: -40px;
    margin-left: -40px;
  }
  .c-row.c-row--gap-md-2 .c-col {
    padding-right: 40px;
    padding-left: 40px;
  }
}
@media screen and (min-width: 768px) {
  .c-row.c-row--gap-md-3 {
    margin-right: -60px;
    margin-left: -60px;
  }
  .c-row.c-row--gap-md-3 .c-col {
    padding-right: 60px;
    padding-left: 60px;
  }
}
@media screen and (min-width: 768px) {
  .c-row.c-row--gap-md-4 {
    margin-right: -80px;
    margin-left: -80px;
  }
  .c-row.c-row--gap-md-4 .c-col {
    padding-right: 80px;
    padding-left: 80px;
  }
}
@media screen and (min-width: 768px) {
  .c-row.c-row--gap-md-5 {
    margin-right: -100px;
    margin-left: -100px;
  }
  .c-row.c-row--gap-md-5 .c-col {
    padding-right: 100px;
    padding-left: 100px;
  }
}
@media screen and (min-width: 992px) {
  .c-row.c-row--gap-lg-0 {
    margin-right: 0px;
    margin-left: 0px;
  }
  .c-row.c-row--gap-lg-0 .c-col {
    padding-right: 0px;
    padding-left: 0px;
  }
}
@media screen and (min-width: 992px) {
  .c-row.c-row--gap-lg-1 {
    margin-right: -20px;
    margin-left: -20px;
  }
  .c-row.c-row--gap-lg-1 .c-col {
    padding-right: 20px;
    padding-left: 20px;
  }
}
@media screen and (min-width: 992px) {
  .c-row.c-row--gap-lg-2 {
    margin-right: -40px;
    margin-left: -40px;
  }
  .c-row.c-row--gap-lg-2 .c-col {
    padding-right: 40px;
    padding-left: 40px;
  }
}
@media screen and (min-width: 992px) {
  .c-row.c-row--gap-lg-3 {
    margin-right: -60px;
    margin-left: -60px;
  }
  .c-row.c-row--gap-lg-3 .c-col {
    padding-right: 60px;
    padding-left: 60px;
  }
}
@media screen and (min-width: 992px) {
  .c-row.c-row--gap-lg-4 {
    margin-right: -80px;
    margin-left: -80px;
  }
  .c-row.c-row--gap-lg-4 .c-col {
    padding-right: 80px;
    padding-left: 80px;
  }
}
@media screen and (min-width: 992px) {
  .c-row.c-row--gap-lg-5 {
    margin-right: -100px;
    margin-left: -100px;
  }
  .c-row.c-row--gap-lg-5 .c-col {
    padding-right: 100px;
    padding-left: 100px;
  }
}
@media screen and (min-width: 0) {
  .c-row.c-row--xs-row {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }
}
@media screen and (min-width: 0) {
  .c-row.c-row--xs-column {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
@media screen and (min-width: 0) {
  .c-row.c-row--xs-row-reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
}
@media screen and (min-width: 0) {
  .c-row.c-row--xs-column-reverse {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
}
@media screen and (min-width: 576px) {
  .c-row.c-row--sm-row {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }
}
@media screen and (min-width: 576px) {
  .c-row.c-row--sm-column {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
@media screen and (min-width: 576px) {
  .c-row.c-row--sm-row-reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
}
@media screen and (min-width: 576px) {
  .c-row.c-row--sm-column-reverse {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
}
@media screen and (min-width: 768px) {
  .c-row.c-row--md-row {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }
}
@media screen and (min-width: 768px) {
  .c-row.c-row--md-column {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
@media screen and (min-width: 768px) {
  .c-row.c-row--md-row-reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
}
@media screen and (min-width: 768px) {
  .c-row.c-row--md-column-reverse {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
}
@media screen and (min-width: 992px) {
  .c-row.c-row--lg-row {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }
}
@media screen and (min-width: 992px) {
  .c-row.c-row--lg-column {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
@media screen and (min-width: 992px) {
  .c-row.c-row--lg-row-reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
}
@media screen and (min-width: 992px) {
  .c-row.c-row--lg-column-reverse {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
}
.c-row.c-row--center {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
@media screen and (min-width: 0) {
  .c-row.c-row--xs-center {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}
@media screen and (min-width: 576px) {
  .c-row.c-row--sm-center {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}
@media screen and (min-width: 768px) {
  .c-row.c-row--md-center {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}
@media screen and (min-width: 992px) {
  .c-row.c-row--lg-center {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}
.c-row.c-row--flex-start {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}
@media screen and (min-width: 0) {
  .c-row.c-row--xs-flex-start {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}
@media screen and (min-width: 576px) {
  .c-row.c-row--sm-flex-start {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}
@media screen and (min-width: 768px) {
  .c-row.c-row--md-flex-start {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}
@media screen and (min-width: 992px) {
  .c-row.c-row--lg-flex-start {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}
.c-row.c-row--flex-end {
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}
@media screen and (min-width: 0) {
  .c-row.c-row--xs-flex-end {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }
}
@media screen and (min-width: 576px) {
  .c-row.c-row--sm-flex-end {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }
}
@media screen and (min-width: 768px) {
  .c-row.c-row--md-flex-end {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }
}
@media screen and (min-width: 992px) {
  .c-row.c-row--lg-flex-end {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }
}

.c-col {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
  -ms-flex-preferred-size: 100%;
  flex-basis: 100%;
  width: 100%;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
  flex-basis: 100%;
  width: 100%;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
  flex-basis: 100%;
  width: 100%;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
  flex-basis: 100%;
  width: 100%;
}
.c-col--xs-1 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 0) {
  .c-col--xs-1 {
    -ms-flex-preferred-size: 8.3333333333%;
    flex-basis: 8.3333333333%;
    width: 8.3333333333%;
  }
}
.c-col--xs-2 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 0) {
  .c-col--xs-2 {
    -ms-flex-preferred-size: 16.6666666667%;
    flex-basis: 16.6666666667%;
    width: 16.6666666667%;
  }
}
.c-col--xs-3 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 0) {
  .c-col--xs-3 {
    -ms-flex-preferred-size: 25%;
    flex-basis: 25%;
    width: 25%;
  }
}
.c-col--xs-4 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 0) {
  .c-col--xs-4 {
    -ms-flex-preferred-size: 33.3333333333%;
    flex-basis: 33.3333333333%;
    width: 33.3333333333%;
  }
}
.c-col--xs-5 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 0) {
  .c-col--xs-5 {
    -ms-flex-preferred-size: 41.6666666667%;
    flex-basis: 41.6666666667%;
    width: 41.6666666667%;
  }
}
.c-col--xs-6 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 0) {
  .c-col--xs-6 {
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    width: 50%;
  }
}
.c-col--xs-7 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 0) {
  .c-col--xs-7 {
    -ms-flex-preferred-size: 58.3333333333%;
    flex-basis: 58.3333333333%;
    width: 58.3333333333%;
  }
}
.c-col--xs-8 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 0) {
  .c-col--xs-8 {
    -ms-flex-preferred-size: 66.6666666667%;
    flex-basis: 66.6666666667%;
    width: 66.6666666667%;
  }
}
.c-col--xs-9 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 0) {
  .c-col--xs-9 {
    -ms-flex-preferred-size: 75%;
    flex-basis: 75%;
    width: 75%;
  }
}
.c-col--xs-10 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 0) {
  .c-col--xs-10 {
    -ms-flex-preferred-size: 83.3333333333%;
    flex-basis: 83.3333333333%;
    width: 83.3333333333%;
  }
}
.c-col--xs-11 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 0) {
  .c-col--xs-11 {
    -ms-flex-preferred-size: 91.6666666667%;
    flex-basis: 91.6666666667%;
    width: 91.6666666667%;
  }
}
.c-col--xs-12 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 0) {
  .c-col--xs-12 {
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    width: 100%;
  }
}
.c-col--sm-1 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 576px) {
  .c-col--sm-1 {
    -ms-flex-preferred-size: 8.3333333333%;
    flex-basis: 8.3333333333%;
    width: 8.3333333333%;
  }
}
.c-col--sm-2 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 576px) {
  .c-col--sm-2 {
    -ms-flex-preferred-size: 16.6666666667%;
    flex-basis: 16.6666666667%;
    width: 16.6666666667%;
  }
}
.c-col--sm-3 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 576px) {
  .c-col--sm-3 {
    -ms-flex-preferred-size: 25%;
    flex-basis: 25%;
    width: 25%;
  }
}
.c-col--sm-4 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 576px) {
  .c-col--sm-4 {
    -ms-flex-preferred-size: 33.3333333333%;
    flex-basis: 33.3333333333%;
    width: 33.3333333333%;
  }
}
.c-col--sm-5 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 576px) {
  .c-col--sm-5 {
    -ms-flex-preferred-size: 41.6666666667%;
    flex-basis: 41.6666666667%;
    width: 41.6666666667%;
  }
}
.c-col--sm-6 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 576px) {
  .c-col--sm-6 {
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    width: 50%;
  }
}
.c-col--sm-7 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 576px) {
  .c-col--sm-7 {
    -ms-flex-preferred-size: 58.3333333333%;
    flex-basis: 58.3333333333%;
    width: 58.3333333333%;
  }
}
.c-col--sm-8 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 576px) {
  .c-col--sm-8 {
    -ms-flex-preferred-size: 66.6666666667%;
    flex-basis: 66.6666666667%;
    width: 66.6666666667%;
  }
}
.c-col--sm-9 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 576px) {
  .c-col--sm-9 {
    -ms-flex-preferred-size: 75%;
    flex-basis: 75%;
    width: 75%;
  }
}
.c-col--sm-10 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 576px) {
  .c-col--sm-10 {
    -ms-flex-preferred-size: 83.3333333333%;
    flex-basis: 83.3333333333%;
    width: 83.3333333333%;
  }
}
.c-col--sm-11 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 576px) {
  .c-col--sm-11 {
    -ms-flex-preferred-size: 91.6666666667%;
    flex-basis: 91.6666666667%;
    width: 91.6666666667%;
  }
}
.c-col--sm-12 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 576px) {
  .c-col--sm-12 {
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    width: 100%;
  }
}
.c-col--md-1 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 768px) {
  .c-col--md-1 {
    -ms-flex-preferred-size: 8.3333333333%;
    flex-basis: 8.3333333333%;
    width: 8.3333333333%;
  }
}
.c-col--md-2 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 768px) {
  .c-col--md-2 {
    -ms-flex-preferred-size: 16.6666666667%;
    flex-basis: 16.6666666667%;
    width: 16.6666666667%;
  }
}
.c-col--md-3 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 768px) {
  .c-col--md-3 {
    -ms-flex-preferred-size: 25%;
    flex-basis: 25%;
    width: 25%;
  }
}
.c-col--md-4 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 768px) {
  .c-col--md-4 {
    -ms-flex-preferred-size: 33.3333333333%;
    flex-basis: 33.3333333333%;
    width: 33.3333333333%;
  }
}
.c-col--md-5 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 768px) {
  .c-col--md-5 {
    -ms-flex-preferred-size: 41.6666666667%;
    flex-basis: 41.6666666667%;
    width: 41.6666666667%;
  }
}
.c-col--md-6 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 768px) {
  .c-col--md-6 {
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    width: 50%;
  }
}
.c-col--md-7 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 768px) {
  .c-col--md-7 {
    -ms-flex-preferred-size: 58.3333333333%;
    flex-basis: 58.3333333333%;
    width: 58.3333333333%;
  }
}
.c-col--md-8 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 768px) {
  .c-col--md-8 {
    -ms-flex-preferred-size: 66.6666666667%;
    flex-basis: 66.6666666667%;
    width: 66.6666666667%;
  }
}
.c-col--md-9 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 768px) {
  .c-col--md-9 {
    -ms-flex-preferred-size: 75%;
    flex-basis: 75%;
    width: 75%;
  }
}
.c-col--md-10 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 768px) {
  .c-col--md-10 {
    -ms-flex-preferred-size: 83.3333333333%;
    flex-basis: 83.3333333333%;
    width: 83.3333333333%;
  }
}
.c-col--md-11 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 768px) {
  .c-col--md-11 {
    -ms-flex-preferred-size: 91.6666666667%;
    flex-basis: 91.6666666667%;
    width: 91.6666666667%;
  }
}
.c-col--md-12 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 768px) {
  .c-col--md-12 {
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    width: 100%;
  }
}
.c-col--lg-1 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 992px) {
  .c-col--lg-1 {
    -ms-flex-preferred-size: 8.3333333333%;
    flex-basis: 8.3333333333%;
    width: 8.3333333333%;
  }
}
.c-col--lg-2 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 992px) {
  .c-col--lg-2 {
    -ms-flex-preferred-size: 16.6666666667%;
    flex-basis: 16.6666666667%;
    width: 16.6666666667%;
  }
}
.c-col--lg-3 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 992px) {
  .c-col--lg-3 {
    -ms-flex-preferred-size: 25%;
    flex-basis: 25%;
    width: 25%;
  }
}
.c-col--lg-4 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 992px) {
  .c-col--lg-4 {
    -ms-flex-preferred-size: 33.3333333333%;
    flex-basis: 33.3333333333%;
    width: 33.3333333333%;
  }
}
.c-col--lg-5 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 992px) {
  .c-col--lg-5 {
    -ms-flex-preferred-size: 41.6666666667%;
    flex-basis: 41.6666666667%;
    width: 41.6666666667%;
  }
}
.c-col--lg-6 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 992px) {
  .c-col--lg-6 {
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    width: 50%;
  }
}
.c-col--lg-7 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 992px) {
  .c-col--lg-7 {
    -ms-flex-preferred-size: 58.3333333333%;
    flex-basis: 58.3333333333%;
    width: 58.3333333333%;
  }
}
.c-col--lg-8 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 992px) {
  .c-col--lg-8 {
    -ms-flex-preferred-size: 66.6666666667%;
    flex-basis: 66.6666666667%;
    width: 66.6666666667%;
  }
}
.c-col--lg-9 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 992px) {
  .c-col--lg-9 {
    -ms-flex-preferred-size: 75%;
    flex-basis: 75%;
    width: 75%;
  }
}
.c-col--lg-10 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 992px) {
  .c-col--lg-10 {
    -ms-flex-preferred-size: 83.3333333333%;
    flex-basis: 83.3333333333%;
    width: 83.3333333333%;
  }
}
.c-col--lg-11 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 992px) {
  .c-col--lg-11 {
    -ms-flex-preferred-size: 91.6666666667%;
    flex-basis: 91.6666666667%;
    width: 91.6666666667%;
  }
}
.c-col--lg-12 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 20px;
  padding-left: 20px;
}
@media screen and (min-width: 992px) {
  .c-col--lg-12 {
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    width: 100%;
  }
}

.p-slider, .c-container {
  margin: 0 auto;
  max-width: 994px;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 991px) {
  .p-slider, .c-container {
    padding: 0 40px;
  }
}
@media screen and (max-width: 767px) {
  .p-slider, .c-container {
    padding: 0 30px;
  }
}

.c-container--lg {
  max-width: 1067px;
}
.c-container--md {
  max-width: 780px;
}
.c-container--sm {
  max-width: 400px;
}
.c-container.is-visible {
  overflow: visible;
}

.c-section {
  margin-bottom: 60px;
}
.c-section--sm {
  margin-bottom: 40px;
}
.c-section--lg {
  margin-bottom: 90px;
}
.c-section--gray {
  background-color: #F9F9F9;
}
.c-section__header {
  position: relative;
  top: -20px;
  margin-bottom: -20px;
}
.c-section--cta {
  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;
  margin-top: 30px;
}
@media screen and (min-width: 768px) {
  .c-section--cta {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }
  .c-section--cta .c-button + .c-button {
    margin-left: 20px;
  }
}
@media screen and (max-width: 767px) {
  .c-section--cta .c-button + .c-button {
    margin-top: 20px;
  }
}
.c-section--cta h2 {
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-size: 16px;
  margin-bottom: 10px;
}
@media screen and (max-width: 991px) {
  .c-section--cta h2 {
    font-size: 13px;
  }
}

.c-form {
  padding: 2px;
  margin-bottom: 20px;
}
.c-form--required .c-form__label:after {
  content: "必須";
  margin-left: 10px;
  background-color: #999;
  font-weight: 400;
  display: inline-block;
  color: #fff;
  padding: 2px 5px;
  line-height: 1.4;
  font-size: 11px;
}
.c-form__label {
  display: block;
  font-size: 14px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  margin-bottom: 5px;
}
.c-form__group-2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
.c-form__group-2 > * {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 calc((100% - 20px) / 2);
  flex: 0 0 calc((100% - 20px) / 2);
}
.c-form__group-3 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
.c-form__group-3 > * {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 calc((100% - 20px) / 3);
  flex: 0 0 calc((100% - 20px) / 3);
}
.c-form__group-4 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
.c-form__group-4 > * {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 calc((100% - 20px) / 4);
  flex: 0 0 calc((100% - 20px) / 4);
}
.c-form__group-5 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
.c-form__group-5 > * {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 calc((100% - 20px) / 5);
  flex: 0 0 calc((100% - 20px) / 5);
}
.c-form__input {
  background-color: #fff;
  border: 1px solid #CCCCCC;
  width: 100%;
  padding: 9px 20px;
}
.c-form__input:focus {
  outline: 2px solid #EF3340;
}
.c-form__input::-webkit-input-placeholder {
  color: #999;
}
.c-form__input::-moz-placeholder {
  color: #999;
}
.c-form__input:-ms-input-placeholder {
  color: #999;
}
.c-form__input::-ms-input-placeholder {
  color: #999;
}
.c-form__input::placeholder {
  color: #999;
}
.c-form__check {
  display: inline-block;
}
@media screen and (max-width: 575px) {
  .c-form__check {
    display: block;
  }
}
.c-form__check + .c-form__check {
  margin-left: 30px;
}
@media screen and (max-width: 575px) {
  .c-form__check + .c-form__check {
    margin-left: 0;
    margin-top: 10px;
  }
}
.c-form__check input {
  display: none;
}
.c-form__check input:checked + span::after {
  content: "";
}
.c-form__check span {
  padding-left: 30px;
  position: relative;
}
.c-form__check span::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  border: 1px solid #CCCCCC;
  background-color: #fff;
}
.c-form__check span::after {
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  border: 1px solid #EF3340;
  background-color: #EF3340;
  background-image: url(../images/common/icon-check.svg);
  background-position: center;
  background-repeat: no-repeat;
}
.c-form__policy {
  font-size: 14px;
  margin-top: 40px;
  margin-bottom: 40px;
  text-align: center;
  line-height: 1.5714285714;
}
.c-form__policy > a {
  color: #0070C9;
}
.c-form__button {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .c-form__button {
    width: auto;
  }
}
.c-form--search {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  margin-bottom: 0;
}
.c-form--search .c-form__input {
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
}
.c-form--search .c-form__button {
  position: absolute;
  top: 0;
  right: 0;
  cursor: pointer;
  padding: 8px 20px;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.c-form--search .c-form__button:hover {
  -webkit-transform: scale(1.2);
  transform: scale(1.2);
}

.c-select {
  width: 100%;
  padding: 10px 19px;
  border: 2px solid #CCCCCC;
  font-size: 14px;
  line-height: 1.4;
  background-image: url(../images/common/arrow-header.svg);
  background-position: right 20px center;
  background-repeat: no-repeat;
  -webkit-transition: color 0.3s;
  transition: color 0.3s;
  background-color: #fff;
}
.c-select::-ms-expand {
  display: none;
}
.c-select--form {
  border: 1px solid #CCCCCC;
  padding: 11px 20px;
}
.c-select:focus {
  outline: 2px solid #EF3340;
}
@media screen and (min-width: 992px) {
  .c-select:hover {
    color: #EF3340;
  }
}

.c-form-container {
  background-color: #F9F9F9;
  padding: 40px;
}
@media screen and (max-width: 767px) {
  .c-form-container {
    padding: 20px;
  }
}

.c-pagination {
  margin-bottom: 40px;
}
@media screen and (max-width: 575px) {
  .c-pagination {
    margin: auto;
    width: 278px;
    height: 104px;
    position: relative;
  }
}
.c-pagination__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
@media screen and (max-width: 991px) {
  .c-pagination__list {
    margin: 0 -6px;
  }
}
.c-pagination__item {
  margin: 0 6px;
}
.c-pagination__item > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 46px;
  height: 46px;
  -webkit-transition: background-color 0.3s, color 0.3s;
  transition: background-color 0.3s, color 0.3s;
}
@media screen and (min-width: 992px) {
  .c-pagination__item > a:hover {
    background-color: #222;
    color: #fff;
  }
}
.c-pagination__item--number.is-active > a {
  background-color: #222;
  color: #fff;
}
.c-pagination__item--rest {
  width: 46px;
  height: 46px;
  background-repeat: no-repeat;
  background-position: center;
  background-image: url(../images/common/icon-pager-dot.svg);
}
.c-pagination__item--prev > a, .c-pagination__item--next > a, .c-pagination__item--number > a {
  border: 1px solid #222;
}
.c-pagination__item--prev > a, .c-pagination__item--next > a {
  background-repeat: no-repeat;
  background-position: center;
  background-size: 12px 9px;
}
@media screen and (max-width: 575px) {
  .c-pagination__item--prev > a, .c-pagination__item--next > a {
    width: 100%;
  }
}
@media screen and (max-width: 575px) {
  .c-pagination__item--prev, .c-pagination__item--next {
    position: absolute;
    bottom: 0;
    width: 134px;
  }
}
.c-pagination__item--prev {
  margin-right: 34px;
}
.c-pagination__item--prev > a {
  background-image: url(../images/common/icon-arrow-back.svg);
}
@media screen and (min-width: 992px) {
  .c-pagination__item--prev > a:hover {
    background-image: url(../images/common/icon-arrow-back-off.svg);
  }
}
@media screen and (max-width: 575px) {
  .c-pagination__item--prev {
    left: 0;
    margin: 0;
  }
}
.c-pagination__item--next {
  margin-left: 34px;
}
.c-pagination__item--next > a {
  background-image: url(../images/common/icon-arrow-next.svg);
}
@media screen and (min-width: 992px) {
  .c-pagination__item--next > a:hover {
    background-image: url(../images/common/icon-arrow-next-off.svg);
  }
}
@media screen and (max-width: 575px) {
  .c-pagination__item--next {
    right: 0;
    margin: 0;
  }
}

.c-tab {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  text-align: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .c-tab {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
@media screen and (max-width: 767px) {
  .c-tab--row {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }
}
@media screen and (max-width: 767px) {
  .c-tab--row .c-tab__link {
    font-size: 15.4px;
  }
}
.c-tab__item {
  width: 100%;
  position: relative;
}
.c-tab__item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 1px;
  height: 35px;
  background-color: #E6E6E6;
}
@media screen and (max-width: 767px) {
  .c-tab__item::before {
    width: 0;
  }
}
.c-tab__item:first-child:before {
  width: 0;
}
.c-tab__link {
  display: block;
  position: relative;
  padding-top: 2px;
  padding-bottom: 20px;
  text-align: center;
  font-size: 20px;
  line-height: 1.4;
  color: #999;
  -webkit-transition: color 0.3s;
  transition: color 0.3s;
}
@media screen and (max-width: 767px) {
  .c-tab__link {
    padding-top: 10px;
    padding-bottom: 10px;
  }
}
.c-tab__link::before, .c-tab__link::after {
  content: "";
  position: absolute;
  height: 1px;
  width: 90%;
  left: 5%;
  bottom: 0;
}
@media screen and (max-width: 767px) {
  .c-tab__link::before, .c-tab__link::after {
    width: 100%;
    left: 0;
  }
}
.c-tab__link::before {
  background-color: #CCCCCC;
  width: 90%;
  left: 5%;
}
@media screen and (max-width: 767px) {
  .c-tab__link::before {
    width: 100%;
    left: 0;
  }
}
.c-tab__link::after {
  width: 0;
  background-color: #222;
  -webkit-transition: width 0.3s;
  transition: width 0.3s;
}
.c-tab__link.is-active {
  font-weight: bold;
  color: #222;
}
.c-tab__link.is-active::after {
  width: 90%;
  left: 5%;
}
@media screen and (max-width: 767px) {
  .c-tab__link.is-active::after {
    width: 100%;
    left: 0;
  }
}
@media screen and (min-width: 992px) {
  .c-tab__link:hover {
    font-weight: bold;
    color: #222;
  }
  .c-tab__link:hover::after {
    width: 90%;
    left: 5%;
  }
}

.c-tab-content {
  display: none;
}
.c-tab-content.is-active {
  display: block;
}

.c-tab-secondary {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: -12px;
}
.c-tab-secondary__item {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 186px;
  flex: 0 0 186px;
  margin-top: 12px;
}
@media screen and (max-width: 991px) {
  .c-tab-secondary__item {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 23.26%;
    flex: 0 0 23.26%;
  }
}
.c-tab-secondary__item:not(:nth-child(5n)) {
  margin-right: 16px;
}
@media screen and (max-width: 991px) {
  .c-tab-secondary__item:not(:nth-child(5n)) {
    margin-right: 0;
  }
}
@media screen and (max-width: 991px) {
  .c-tab-secondary__item:not(:nth-child(4n)) {
    margin-right: 2.32%;
  }
}
@media screen and (max-width: 767px) {
  .c-tab-secondary__item:not(:nth-child(4n)) {
    margin-right: 0;
  }
}
@media screen and (max-width: 767px) {
  .c-tab-secondary__item {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 32%;
    flex: 0 0 32%;
  }
}
@media screen and (max-width: 767px) {
  .c-tab-secondary__item:not(:nth-child(3n)) {
    margin-right: 2%;
  }
}
.c-tab-secondary__link {
  display: block;
  padding: 4px;
  text-align: center;
  font-size: 16px;
  line-height: 1.4;
  border: 2px solid #CCCCCC;
  border-radius: 500px;
  -webkit-transition: background-color 0.3s, color 0.3s, border 0.3s;
  transition: background-color 0.3s, color 0.3s, border 0.3s;
}
.c-tab-secondary__link.is-active {
  background-color: #222;
  color: #fff;
  border: 2px solid #222;
}
@media screen and (min-width: 992px) {
  .c-tab-secondary__link:hover {
    background-color: #222;
    color: #fff;
    border: 2px solid #222;
  }
}

.c-tag {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  background-color: #AAAAAA;
  color: #fff;
  padding: 0 10px;
  line-height: 2;
  border-radius: 2px;
}
.c-tag--category {
  background-color: #222;
  border-radius: 10rem;
  color: #fff;
  padding: 0 10px;
  line-height: 2;
}

@media screen and (min-width: 992px) {
  a.c-tag:hover {
    background-color: #CCCCCC;
    -webkit-transition: background-color 0.3s;
    transition: background-color 0.3s;
  }
}
.c-tag-list .c-tag {
  margin-top: 5px;
  margin-right: 5px;
}

.c-app-icon {
  text-align: center;
}
.c-app-icon__thumbnail {
  display: block;
}
.c-app-icon__caption {
  display: block;
  margin-top: 0.3rem;
  font-size: 12px;
  line-height: 1.5;
}

.c-app-icons {
  max-width: 570px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}
.c-app-icons .c-app-icon {
  padding: 0 7.5px;
  margin-bottom: 7.5px;
  max-width: 4.5rem;
}
.c-app-icons--lg .c-app-icon {
  padding: 0 15px;
  margin-bottom: 15px;
  -ms-flex-preferred-size: 20%;
  flex-basis: 20%;
}
@media screen and (max-width: 991px) {
  .c-app-icons--lg .c-app-icon {
    -ms-flex-preferred-size: 25%;
    flex-basis: 25%;
  }
}
@media screen and (max-width: 767px) {
  .c-app-icons--lg .c-app-icon {
    -ms-flex-preferred-size: 33.3%;
    flex-basis: 33.3%;
  }
}

.c-button {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-align: center;
  font-weight: 700;
  font-size: 14px;
  background-color: #fff;
  border: 1px solid #222;
  text-decoration: none !important;
  padding: 10px 20px;
  -webkit-transition: background-color 0.5s;
  transition: background-color 0.5s;
}
@media screen and (min-width: 992px) {
  .c-button:hover {
    border: 1px solid #EF3340;
    color: #EF3340;
    cursor: pointer;
  }
}
.c-button--block {
  width: 100%;
}
.c-button--secondary {
  border: 1px solid #EF3340;
  -webkit-transition: background-color 0.5s;
  transition: background-color 0.5s;
}
@media screen and (min-width: 992px) {
  .c-button--secondary:hover {
    color: #fff;
    border: none;
    border: 1px solid #EF3340;
    background-color: #EF3340;
  }
}
.c-button--primary {
  color: #fff;
  background-color: #EF3340;
  padding: 11px 20px;
  border: none;
  -webkit-box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
  box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
}
@media screen and (min-width: 992px) {
  .c-button--primary:hover {
    color: #fff;
    border: none;
    background-color: #B02D36;
  }
}
.c-button--dark {
  color: #fff;
  background-color: #C8102E;
  padding: 11px 20px;
  border: none;
  -webkit-box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
  box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
}
@media screen and (min-width: 992px) {
  .c-button--dark:hover {
    color: #fff;
    border: none;
    background-color: #95102A;
  }
}
.c-button--inverse {
  color: #EF3340;
  background-color: #fff;
  border: 1px solid #EF3340;
}
.c-button--inverse .c-button__chevron-right:after {
  content: url(../images/common/icon-chevron-right-red.svg);
  vertical-align: middle;
  margin-left: 20px;
  -webkit-transition: background-color 0.5s;
  transition: background-color 0.5s;
}
@media screen and (min-width: 992px) {
  .c-button--inverse:hover {
    color: #fff;
    border: 1px solid #EF3340;
    background-color: #EF3340;
  }
  .c-button--inverse:hover .c-button__chevron-right:after {
    content: url(../images/common/icon-chevron-right-white.svg);
  }
}
.c-button--contact::before {
  content: "";
  display: inline-block;
  width: 18px;
  height: 18px;
  background-image: url(../images/common/icon-contact.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  margin-right: 8px;
}

.c-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 30px;
}
.c-table caption {
  text-align: center;
  padding: 10px;
  font-weight: bold;
  font-size: 14px;
}
.c-table th, .c-table td {
  padding: 10px;
}
.c-table--center th, .c-table--center td {
  text-align: center;
}
.c-table--color caption {
  background-color: #222;
  margin-bottom: 2px;
  color: #fff;
}
.c-table--color thead tr th, .c-table--color thead tr td {
  background-color: #999;
  color: #fff;
  font-weight: bold;
}
.c-table--color thead tr th {
  border-right: 1px solid #fff;
}
.c-table--color tbody tr th, .c-table--color tbody tr td {
  background-color: #F7F6FE;
}
.c-table--color tbody tr th {
  border-right: 1px solid #fff;
  font-weight: normal;
}
.c-table--color tbody tr:nth-child(even) th, .c-table--color tbody tr:nth-child(even) td {
  background-color: #E7E7EF;
}

.c-lmenu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  text-align: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
@media screen and (min-width: 576px) {
  .c-lmenu-container.is-fixed {
    position: fixed;
    top: 10px;
    left: 0;
    right: 0;
    z-index: 2;
  }
  .c-lmenu-container.is-fixed .c-container {
    position: relative;
    overflow: visible;
  }
  .c-lmenu-container.is-fixed .c-lmenu {
    background-color: #fff;
    -webkit-box-shadow: 0px 0px 24px rgba(0, 0, 0, 0.2);
    box-shadow: 0px 0px 24px rgba(0, 0, 0, 0.2);
    position: relative;
  }
  .c-lmenu-container.is-fixed .c-lmenu__arrow-down {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .c-lmenu {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.c-lmenu__item {
  width: 100%;
  position: relative;
}
.c-lmenu__item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 1px;
  height: 100%;
  background-color: #E6E6E6;
}
@media screen and (max-width: 767px) {
  .c-lmenu__item::before {
    width: 0;
  }
}
.c-lmenu__item:first-child:before {
  width: 0;
}
.c-lmenu__link {
  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;
  position: relative;
  text-align: center;
  font-size: 20px;
  line-height: 1.4;
  padding: 15px;
  -webkit-transition: color 0.3s;
  transition: color 0.3s;
}
@media screen and (min-width: 992px) {
  .c-lmenu__link:hover {
    font-weight: bold;
    color: #EF3340;
  }
  .c-lmenu__link:hover::after {
    width: 90%;
    left: 5%;
  }
}
@media screen and (max-width: 767px) {
  .c-lmenu__link {
    font-size: 18px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 6px;
  }
}
.c-lmenu__arrow-down {
  margin-top: 12px;
}
@media screen and (max-width: 767px) {
  .c-lmenu__arrow-down {
    margin-top: 0;
    margin-left: 10px;
  }
  .c-lmenu__arrow-down img {
    vertical-align: middle;
  }
}

.p-ad {
  border: 1px solid #DDDDDD;
  padding: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin: 40px 0;
}
@media screen and (max-width: 767px) {
  .p-ad {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.p-ad__eyecatch {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  display: block;
  overflow: hidden;
  margin-right: 20px;
}
@media screen and (max-width: 767px) {
  .p-ad__eyecatch {
    margin-right: 0;
    margin-bottom: 20px;
  }
}
.p-ad__eyecatch > img {
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  width: 100%;
  height: auto;
}
.p-ad__eyecatch > img:hover {
  -webkit-transform: scale(1.05);
  transform: scale(1.05);
}
.p-ad__content {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
.p-ad__content p {
  margin-top: 12px;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  .p-ad__content .c-button {
    display: block;
  }
}
.p-ad__heading {
  font-size: 16px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  line-height: 1.2;
}

.p-author {
  border-top: 1px solid #E6E6E6;
  border-bottom: 1px solid #E6E6E6;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 30px 0;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-author {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.p-author__thumbnail {
  width: 120px;
  margin-right: 20px;
}
@media screen and (max-width: 767px) {
  .p-author__thumbnail {
    margin-right: 0;
    margin-bottom: 10px;
  }
}
.p-author__content {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
.p-author__name {
  font-size: 20px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  margin-bottom: 10px;
}
.p-author__profile {
  font-size: 12px;
}
.p-author__sns {
  list-style-type: none !important;
  padding-left: 0 !important;
}
.p-author__sns li, .p-author__sns a {
  font-size: 12px !important;
}
.p-author__sns li {
  margin-top: 0 !important;
}

/**
 * p-cta
 */
.p-cta {
  margin: -96px auto 0;
  width: 994px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 991px) {
  .p-cta {
    width: auto;
    padding: 0 40px;
  }
}
@media screen and (max-width: 767px) {
  .p-cta {
    margin-top: 0;
    padding: 0;
    display: block;
  }
}
.p-cta__item {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 50%;
  flex: 0 0 50%;
  background-color: #fff;
}
.p-cta__item > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-align: center;
  position: relative;
  height: 180px;
  font-size: 24px;
  color: #fff;
  line-height: 1.4;
  -webkit-transition: background-color 0.5s;
  transition: background-color 0.5s;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
@media screen and (max-width: 991px) {
  .p-cta__item > a {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    font-size: 20px;
  }
}
@media screen and (max-width: 767px) {
  .p-cta__item > a {
    height: 130px;
  }
}
.p-cta__item > a::before {
  content: "";
  display: inline-block;
  background-repeat: no-repeat;
  background-position: center;
  margin-right: 24px;
}
@media screen and (max-width: 991px) {
  .p-cta__item > a::before {
    display: block;
    margin-right: 0;
    margin-bottom: 12px;
  }
}
.p-cta__item > a::after {
  content: "";
  position: absolute;
  right: 10px;
  bottom: 10px;
  width: 0;
  height: 0;
  border-style: solid;
  border-right-width: 26px;
  border-top-width: 26px;
  -webkit-transition: border-color 0.5s;
  transition: border-color 0.5s;
}
.p-cta__item--form > a {
  background-color: #EF3340;
}
.p-cta__item--form > a::before {
  width: 30px;
  height: 21px;
  background-image: url(../images/common/icon-contact.svg);
  background-size: 30px 21px;
}
@media screen and (max-width: 991px) {
  .p-cta__item--form > a::before {
    width: 100%;
    height: 30px;
  }
}
.p-cta__item--form > a::after {
  border-color: transparent #C8102E;
}
@media screen and (min-width: 992px) {
  .p-cta__item--form > a:hover {
    background-color: #B02D36;
  }
}
.p-cta__item--download > a {
  background-color: #C8102E;
}
.p-cta__item--download > a::before {
  width: 24px;
  height: 30px;
  background-image: url(../images/common/icon-document.svg);
  background-size: 24px 30px;
}
@media screen and (max-width: 991px) {
  .p-cta__item--download > a::before {
    width: 100%;
    height: 30px;
  }
}
.p-cta__item--download > a::after {
  border-color: transparent #EF3340;
}
@media screen and (min-width: 992px) {
  .p-cta__item--download > a:hover {
    background-color: #95102A;
  }
}

.p-dropdown__inner {
  padding-top: 30px;
  padding-bottom: 30px;
  width: 992px;
  margin: 0 auto;
}
.p-dropdown__heading {
  font-weight: 700;
  color: #999;
  padding-bottom: 10px;
  border-bottom: 1px solid #999;
  font-size: 20px;
}
.p-dropdown__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: 30px;
}
.p-dropdown__list::before {
  content: "";
  display: block;
  width: 220px;
  height: 0;
  -webkit-box-ordinal-group: 2;
  -ms-flex-order: 1;
  order: 1;
}
.p-dropdown__list:after {
  content: "";
  display: block;
  width: 220px;
  height: 0;
}
.p-dropdown__item {
  width: 220px;
  border-bottom: 1px solid #CCCCCC;
  font-size: 16px;
}
.p-dropdown__item--full {
  width: 100%;
}
.p-dropdown__item--sm {
  font-size: 15px;
}
.p-dropdown__item > a {
  height: 70px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: relative;
  z-index: 5;
  line-height: 1.4;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  padding: 0 22px 0 10px;
}
.p-dropdown__item > a > span {
  display: block;
  font-size: 12px;
  color: #999;
  margin-top: 7px;
}
.p-dropdown__item > a.is-external::after {
  background-image: url(../images/common/icon-external.svg);
}
.p-dropdown__item > a::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 100%;
  background-color: #F9F9F9;
  z-index: -1;
  -webkit-transition: width 0.3s;
  transition: width 0.3s;
}
.p-dropdown__item > a::after {
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  right: 10px;
  width: 10px;
  height: 9px;
  background-image: url(../images/common/icon-arrow-next.svg);
  background-size: 10px 9px;
  background-repeat: no-repeat;
  background-position: center;
}
@media screen and (min-width: 992px) {
  .p-dropdown__item > a.is-external:hover {
    cursor: pointer;
  }
  .p-dropdown__item > a.is-external:hover::after {
    background-image: url(../images/common/icon-external-hover.svg);
  }
  .p-dropdown__item > a:hover::before {
    width: 100%;
  }
  .p-dropdown__item > a:hover::after {
    background-image: url(../images/common/icon-arrow-menu-hover.svg);
  }
}
.p-dropdown__item--products {
  position: relative;
}
.p-dropdown__item--products .p-dropdown__icon {
  content: "";
  position: absolute;
  z-index: 10;
  top: 50%;
  left: 6px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 30px;
  height: 30px;
  background-image: url(../images/common/icon-product-01.svg);
  background-size: contain;
}
.p-dropdown__item--products > a {
  padding-left: 50px;
}
.p-dropdown__item:not(:nth-child(4n)) {
  margin-right: 0;
}
.p-dropdown__item--case {
  width: 306px;
  margin-right: 30px;
}
.p-dropdown__item--case:not(:nth-child(3n)) {
  margin-right: 0;
}
.p-dropdown__link {
  text-align: right;
  margin-top: 30px;
  margin-bottom: 30px;
}
.p-dropdown__link > a {
  display: inline-block;
  position: relative;
  right: 18px;
  font-size: 14px;
  background-image: -webkit-gradient(linear, left top, left bottom, from(#222), to(#222));
  background-image: linear-gradient(#222, #222);
  background-position: 100% 100%;
  background-repeat: no-repeat;
  background-size: 0% 1px;
  -webkit-transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  padding-bottom: 1px;
  line-height: 1.4;
}
@media screen and (min-width: 992px) {
  .p-dropdown__link > a:hover {
    color: #222;
    background-position: 0 100%;
    background-size: 100% 1px;
  }
}
.p-dropdown__link > a::after {
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  right: -18px;
  width: 10px;
  height: 9px;
  background-image: url(../images/common/icon-arrow-next.svg);
  background-size: 10px 9px;
  background-repeat: no-repeat;
  background-position: center;
}

/**
 * footer-bottom
 */
.p-footer-bottom {
  background-color: #1F1F1F;
}
.p-footer-bottom__inner {
  width: 994px;
  margin: auto;
  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;
  justify-content: space-between;
  min-height: 101px;
}
@media screen and (max-width: 991px) {
  .p-footer-bottom__inner {
    width: auto;
    padding: 20px 40px;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
  }
}
@media screen and (max-width: 767px) {
  .p-footer-bottom__inner {
    padding: 25px 0;
    display: block;
    height: auto;
  }
}
.p-footer-bottom__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 991px) {
  .p-footer-bottom__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.p-footer-bottom__item > a {
  background-image: -webkit-gradient(linear, left top, left bottom, from(#AAAAAA), to(#AAAAAA));
  background-image: linear-gradient(#AAAAAA, #AAAAAA);
  background-position: 100% 100%;
  background-repeat: no-repeat;
  background-size: 0% 1px;
  -webkit-transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  padding-bottom: 4px;
  color: #AAAAAA;
  font-size: 12px;
}
@media screen and (min-width: 992px) {
  .p-footer-bottom__item > a:hover {
    color: #AAAAAA;
    background-position: 0 100%;
    background-size: 100% 1px;
  }
}
@media screen and (max-width: 767px) {
  .p-footer-bottom__item {
    margin-left: 26px;
  }
}
@media screen and (min-width: 992px) {
  .p-footer-bottom__item + .p-footer-bottom__item {
    margin-left: 26px;
  }
}
.p-footer-bottom__copy {
  color: #AAAAAA;
  font-size: 12px;
}
@media screen and (max-width: 767px) {
  .p-footer-bottom__copy {
    text-align: center;
    margin-top: 15px;
  }
}

/**
 * p-menu-links
 */
.p-menu-links {
  margin: 30px;
  padding-top: 40px;
  border-top: 1px solid #C0C0C0;
}
.p-menu-links__item + .p-menu-links__item {
  margin-top: 12px;
}
.p-menu-links__button {
  display: block;
  padding: 12px 0;
  text-align: center;
  font-size: 16px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
.p-menu-links__button--login {
  border: 1px solid #222;
}
.p-menu-links__button--form {
  background-color: #EF3340;
  color: #fff;
  -webkit-box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
  box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
}
.p-menu-links__button--form::before {
  content: "";
  display: inline-block;
  width: 25px;
  height: 17px;
  background-image: url(../images/common/icon-contact.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  margin-right: 8px;
  position: relative;
  top: 5px;
}
.p-menu-links__button--download {
  background-color: #C8102E;
  color: #fff;
  -webkit-box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
  box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
}
.p-menu-links__button--download::before {
  content: "";
  display: inline-block;
  width: 19px;
  height: 23px;
  background-image: url(../images/common/icon-document.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  margin-right: 8px;
  position: relative;
  top: 2px;
}

.p-menu-links-downloads {
  margin: 30px;
  padding-bottom: 40px;
  border-bottom: 1px solid #C0C0C0;
}
.p-menu-links-downloads dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 10px;
  font-family: 太ゴB101, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
}
.p-menu-links-downloads dt img {
  margin-right: 10px;
}
.p-menu-links-downloads__item + .p-menu-links-downloads__item {
  margin-top: 20px;
}

/**
 * p-menu
 */
.p-menu {
  position: relative;
  width: 80px;
  height: 80px;
  background-color: #fff;
  -webkit-box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
  box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
}
@media screen and (max-width: 767px) {
  .p-menu {
    width: 60px;
    height: 60px;
  }
}
.p-menu-primary {
  background-color: #EF3340;
}
.p-menu-primary__top, .p-menu-primary__middle, .p-menu-primary__bottom {
  background-color: #fff;
}
.p-menu-link {
  position: relative;
  width: 80px;
  height: 80px;
  background-color: #EF3340;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
  box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
}
.p-menu-link--dark {
  background-color: #C8102E;
}
@media screen and (max-width: 767px) {
  .p-menu-link {
    width: 60px;
    height: 60px;
    padding-left: 5px;
    padding-right: 5px;
  }
}
.p-menu__top, .p-menu__middle, .p-menu__bottom {
  position: absolute;
  display: block;
  left: 24px;
  background-color: #EF3340;
  width: 32px;
  height: 1px;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}
@media screen and (max-width: 767px) {
  .p-menu__top, .p-menu__middle, .p-menu__bottom {
    width: 24px;
    left: 18px;
  }
}
.p-menu__top {
  top: 24px;
  -webkit-transform-origin: left top;
  transform-origin: left top;
}
@media screen and (max-width: 767px) {
  .p-menu__top {
    top: 18px;
  }
}
.p-menu__middle {
  top: 35px;
}
@media screen and (max-width: 767px) {
  .p-menu__middle {
    top: 27px;
  }
}
.p-menu__bottom {
  top: 46px;
  -webkit-transform-origin: left bottom;
  transform-origin: left bottom;
}
@media screen and (max-width: 767px) {
  .p-menu__bottom {
    top: 36px;
  }
}
.p-menu.is-open .p-menu__top,
.p-menu.is-open .p-menu__bottom {
  width: 32px;
  left: 30px;
}
@media screen and (max-width: 767px) {
  .p-menu.is-open .p-menu__top,
.p-menu.is-open .p-menu__bottom {
    width: 25px;
    left: 22px;
  }
}
.p-menu.is-open .p-menu__top {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.p-menu.is-open .p-menu__middle {
  display: none;
}
.p-menu.is-open .p-menu__bottom {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

/**
 * p-parallax
 */
.p-parallax {
  width: 994px;
  margin: auto;
  position: relative;
  z-index: 15;
}
.p-parallax__object {
  position: absolute;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.p-parallax__object--01 {
  top: 576px;
  left: -320px;
  width: 65px;
  height: 134px;
  background-color: #EF3340;
}
.p-parallax__object--02 {
  top: 1408px;
  right: -320px;
  width: 112px;
  height: 47px;
  background-color: #C8102E;
}
.p-parallax__object--03 {
  top: 2125px;
  left: -259px;
  width: 89px;
  height: 37px;
  background-color: #C8102E;
}
.p-parallax__object--04 {
  top: 2153px;
  left: -324px;
  width: 65px;
  height: 134px;
  background-color: #EF3340;
}
.p-parallax__object--05 {
  top: 2698px;
  right: -310px;
  width: 65px;
  height: 134px;
  background-color: #EF3340;
}
.p-parallax__object--06 {
  top: 3242px;
  left: -150px;
  width: 89px;
  height: 37px;
  background-color: #C8102E;
}
.p-parallax__object--07 {
  top: 4618px;
  right: -325px;
  width: 65px;
  height: 134px;
  background-color: #EF3340;
}
.p-parallax__object--08 {
  top: 4832px;
  right: -260px;
  width: 89px;
  height: 37px;
  background-color: #C8102E;
}
.p-parallax__object--09 {
  top: 5741px;
  left: -331px;
  width: 63px;
  height: 37px;
  background-color: #C8102E;
}
.p-parallax__object--10 {
  top: 5775px;
  left: -268px;
  width: 65px;
  height: 134px;
  background-color: #EF3340;
}

/**
 * p-modal
 */
.p-modal {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 100;
  overflow: hidden;
  outline: 0;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
  opacity: 0;
}
.is-modal-open .p-modal {
  overflow-x: hidden;
  overflow-y: auto;
  opacity: 1;
}
.p-modal__bg {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.5);
}
.p-modal__inner {
  max-width: 800px;
  min-height: calc(100% - 3.5rem);
  margin: 1.75rem auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media screen and (max-width: 991px) {
  .p-modal__inner {
    max-width: 500px;
  }
}
@media screen and (max-width: 767px) {
  .p-modal__inner {
    margin: 0.5rem;
    min-height: calc(100% - 1rem);
  }
}
.p-modal__dialog {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  width: 100%;
  background-color: #fff;
  border-radius: 0.3rem;
}
.p-modal__youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.p-modal__youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}

.p-kv {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.p-kv__container {
  width: 1280px;
  height: 680px;
  padding: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
}
@media screen and (max-width: 991px) {
  .p-kv__container {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    padding: 20px;
    text-align: center;
    height: auto;
  }
}
.p-kv__main {
  -ms-flex-preferred-size: 50%;
  flex-basis: 50%;
}
@media screen and (max-width: 991px) {
  .p-kv__main {
    text-align: center;
  }
  .p-kv__main .u-is-sp {
    display: inline-block;
  }
}
.p-kv__eyecatch {
  position: absolute;
  width: 1180px;
  top: -30px;
  right: -212px;
  z-index: -1;
}
@media screen and (max-width: 1200px) {
  .p-kv__eyecatch {
    width: 1050px;
    top: 0;
    right: -320px;
  }
}
@media screen and (max-width: 991px) {
  .p-kv__eyecatch {
    width: auto;
    position: static;
    margin-left: -45px;
  }
}
.p-kv__eyecatch video {
  width: 100%;
  -webkit-filter: contrast(110%);
}
@media screen and (max-width: 991px) {
  .p-kv__eyecatch video {
    width: 128%;
  }
}
.p-kv__catch-primary {
  font-size: 55.2px;
  line-height: 1.3;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
@media screen and (max-width: 991px) {
  .p-kv__catch-primary {
    font-size: 46px;
    margin-top: 20px;
  }
}
@media screen and (max-width: 767px) {
  .p-kv__catch-primary {
    font-size: 41.4px;
  }
}
@media screen and (max-width: 575px) {
  .p-kv__catch-primary {
    font-size: 36px;
  }
}
.p-kv__catch-secondary {
  font-size: 28px;
  margin-top: 30px;
  line-height: 1.3;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
@media screen and (max-width: 991px) {
  .p-kv__catch-secondary {
    margin-top: 10px;
    font-size: 28px;
  }
}
@media screen and (max-width: 767px) {
  .p-kv__catch-secondary {
    font-size: 20px;
  }
}
@media screen and (max-width: 575px) {
  .p-kv__catch-secondary {
    font-size: 15.4px;
  }
}
.p-kv__catch-fact {
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-kv__catch-fact {
    margin-top: 20px;
  }
}
.p-kv__link {
  margin-top: 40px;
}
@media screen and (max-width: 991px) {
  .p-kv__link {
    display: none;
  }
}

.p-kv .c-link, .p-kv-cta .c-link {
  padding-bottom: 20px;
}

.p-kv-notice {
  width: 1280px;
  max-width: 100%;
  padding: 30px;
  margin: 0 auto;
  color: #666;
  font-size: 12px;
}

.p-kv-cta {
  padding: 0 20px;
}
@media screen and (min-width: 992px) {
  .p-kv-cta {
    display: none;
  }
}

/**
 * p-ticker
 */
.p-ticker {
  background-color: #F9F9F9;
  position: relative;
}
.p-ticker__inner {
  width: 994px;
  height: 104px;
  margin: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media screen and (max-width: 991px) {
  .p-ticker__inner {
    width: auto;
    height: auto;
    padding: 30px 40px;
    display: block;
  }
}
@media screen and (max-width: 767px) {
  .p-ticker__inner {
    padding: 30px 30px 0;
  }
}
.p-ticker__heading {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
  font-size: 24px;
  margin-right: 40px;
  line-height: 1.4;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .p-ticker__heading {
    font-size: 22px;
  }
}
.p-ticker__main {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 calc(100% - 139px - 60px);
  flex: 0 0 calc(100% - 139px - 60px);
}
@media screen and (max-width: 991px) {
  .p-ticker__main {
    margin-top: 30px;
  }
}
.p-ticker__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .p-ticker__item {
    padding-bottom: 25px;
  }
}
.p-ticker__date {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  font-size: 16px;
  color: #C0C0C0;
  margin-right: 12px;
}
@media screen and (max-width: 767px) {
  .p-ticker__date {
    font-size: 13px;
  }
}
.p-ticker__new {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 40px;
  flex: 0 0 40px;
  text-align: center;
  background-color: #EF3340;
  color: #fff;
  font-size: 10px;
  padding: 3px 0;
  margin-right: 8px;
  line-height: 1.4;
}
.p-ticker__text {
  -webkit-box-flex: 1;
  -ms-flex: auto;
  flex: auto;
  font-size: 16px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding-bottom: 4px;
}
@media screen and (min-width: 992px) {
  .p-ticker__text {
    padding-right: 15px;
    max-width: 795px;
    position: relative;
    top: 4px;
  }
}
.p-ticker__text > a {
  background-image: -webkit-gradient(linear, left top, left bottom, from(#EF3340), to(#EF3340));
  background-image: linear-gradient(#EF3340, #EF3340);
  background-position: 100% 100%;
  background-repeat: no-repeat;
  background-size: 0% 1px;
  -webkit-transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  padding-bottom: 4px;
}
@media screen and (min-width: 992px) {
  .p-ticker__text > a:hover {
    color: #EF3340;
    background-position: 0 100%;
    background-size: 100% 1px;
  }
}
@media screen and (max-width: 767px) {
  .p-ticker__text {
    font-size: 13px;
    margin-top: 6px;
  }
}
@media screen and (max-width: 575px) {
  .p-ticker__text {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
  }
}
.p-ticker__button + .p-ticker__button {
  margin-left: 30px;
}
.p-ticker__control {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 991px) {
  .p-ticker__control {
    position: absolute;
    top: 40px;
    right: 40px;
  }
}

.p-slider {
  overflow: visible;
  position: relative;
}
.p-slider__container {
  overflow: visible !important;
}
.p-slider__button {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  overflow: visible;
}
@media screen and (max-width: 767px) {
  .p-slider__button {
    display: none;
  }
}
.p-slider__button--right {
  right: -36px;
}
@media screen and (max-width: 991px) {
  .p-slider__button--right {
    right: 30px;
  }
}
.p-slider__button--left {
  left: -36px;
}
@media screen and (max-width: 991px) {
  .p-slider__button--left {
    left: 30px;
  }
}

.p-slider-filled {
  width: 994px;
  margin: auto;
  position: relative;
}
@media screen and (max-width: 991px) {
  .p-slider-filled {
    width: auto;
    padding: 0 40px;
  }
}
@media screen and (max-width: 767px) {
  .p-slider-filled {
    padding: 0 30px;
  }
}
.p-slider-filled__container {
  width: 2976px !important;
  margin-left: -994px;
  overflow: visible !important;
}
@media screen and (max-width: 991px) {
  .p-slider-filled__container {
    width: auto !important;
    margin-left: 0;
  }
}

.p-industry {
  overflow: visible !important;
}
@media screen and (min-width: 992px) {
  .p-industry > a:hover .c-more {
    color: #EF3340;
  }
  .p-industry > a:hover .c-more__border::after {
    -webkit-animation: borderToLong 0.3s forwards;
    animation: borderToLong 0.3s forwards;
  }
  .p-industry > a:hover .p-use-case__image > img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
}
.p-industry__number {
  font-family: 太ゴB101, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-size: 10px;
  line-height: 1.4;
}
.p-industry__subheading {
  margin-top: 10px;
  font-size: 24px;
  line-height: 1.4;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .p-industry__subheading {
    font-size: 20px;
  }
}
.p-industry__image {
  margin-top: 14px;
  overflow: hidden;
}
.p-industry__image > img {
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  width: 100%;
  height: auto;
}
.p-industry__text {
  margin-top: 14px;
  font-size: 13px;
}
@media screen and (max-width: 767px) {
  .p-industry__text {
    min-height: 5rem;
  }
}
.p-industry__link {
  text-align: right;
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .p-industry__link {
    margin-top: 10px;
  }
}

.p-product {
  margin-bottom: 30px;
}
@media screen and (min-width: 992px) {
  .p-product > a:hover .c-more {
    color: #EF3340;
  }
  .p-product > a:hover .c-more .c-more__external {
    background-image: url(../images/common/icon-external-hover.svg);
  }
  .p-product > a:hover .c-more__border::after {
    -webkit-animation: borderToLong 0.3s forwards;
    animation: borderToLong 0.3s forwards;
  }
}
.p-product__image > img {
  width: 100%;
  height: auto;
}
@media screen and (max-width: 991px) {
  .p-product__image {
    padding: 0 26px;
  }
}
@media screen and (max-width: 767px) {
  .p-product__image {
    padding: 0;
  }
}
@media screen and (max-width: 575px) {
  .p-product__image {
    padding: 0 44px;
  }
}
.p-product__heading {
  margin-top: 10px;
  font-size: 20px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
@media screen and (max-width: 575px) {
  .p-product__heading {
    text-align: center;
  }
}
.p-product__text {
  margin-top: 5px;
  font-size: 13px;
}
.p-product__link {
  margin-top: 26px;
  text-align: right;
}

@media screen and (max-width: 991px) {
  .p-project {
    height: 100%;
  }
}
.p-project > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background-color: #F9F9F9;
  position: relative;
  z-index: 5;
}
@media screen and (max-width: 991px) {
  .p-project > a {
    display: block;
    height: 100%;
  }
}
@media screen and (min-width: 992px) {
  .p-project > a:hover .p-project__image > img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
  .p-project > a:hover .c-more {
    color: #EF3340;
  }
  .p-project > a:hover .c-more__border::after {
    -webkit-animation: borderToLong 0.3s forwards;
    animation: borderToLong 0.3s forwards;
  }
}
.p-project__image {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 50%;
  flex: 0 0 50%;
  overflow: hidden;
}
.p-project__image > img {
  width: 100%;
  height: auto;
  -webkit-transition: -webkit-transform 0.75s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: -webkit-transform 0.75s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 0.75s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 0.75s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.75s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.p-project__main {
  -webkit-box-flex: 0;
  -ms-flex: 0 1 auto;
  flex: 0 1 auto;
  padding: 40px 51px;
  position: relative;
}
@media screen and (max-width: 991px) {
  .p-project__main {
    padding: 40px;
  }
}
@media screen and (max-width: 767px) {
  .p-project__main {
    padding: 20px 30px;
  }
}
.p-project__number {
  position: absolute;
  line-height: 1;
  top: 15px;
  right: 13px;
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  font-weight: bold;
  font-size: 100px;
  letter-spacing: 0.08em;
  color: #F9F9F9;
  text-shadow: 1px 1px 0 #C0C0C0, -1px -1px 0 #C0C0C0, -1px 1px 0 #C0C0C0, 1px -1px 0 #C0C0C0, 0px 1px 0 #C0C0C0, -1px 0 #C0C0C0, -1px 0 0 #C0C0C0, 1px 0 0 #C0C0C0;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-project__number {
    display: none;
  }
}
.p-project__caption {
  font-family: 太ゴB101, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-size: 12px;
}
.p-project__heading {
  font-size: 28px;
  line-height: 1.4;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .p-project__heading {
    font-size: 24px;
  }
}
.p-project__text {
  margin-top: 20px;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .p-project__text {
    margin-top: 14px;
    font-size: 13px;
  }
}
.p-project__link {
  text-align: right;
  margin-top: 20px;
}

.p-movie + .p-movie {
  margin-top: 40px;
}
.p-movie__button {
  position: relative;
  overflow: hidden;
  position: relative;
}
@media screen and (min-width: 992px) {
  .p-movie__button:hover > img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
}
.p-movie__button > img {
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}
.p-movie__button::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
  width: 72px;
  height: 72px;
  background-image: url(../images/common/icon-movie-arrow.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 72px;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .p-movie__button::after {
    width: 54px;
    height: 54px;
    background-size: 54px;
  }
}
@media screen and (max-width: 575px) {
  .p-movie__button::after {
    width: 40px;
    height: 40px;
    background-size: 40px;
  }
}
.p-movie__button > img {
  width: 100%;
  height: auto;
}
@media screen and (max-width: 991px) {
  .p-movie__button > img {
    height: 240px;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover";
  }
}
@media screen and (max-width: 767px) {
  .p-movie__button > img {
    height: 180px;
  }
}
@media screen and (max-width: 575px) {
  .p-movie__button > img {
    height: 140px;
  }
}
.p-movie__title {
  position: absolute;
  left: 0;
  bottom: 0;
  background-color: #fff;
  min-width: 250px;
  padding: 17px 20px 9px;
  text-align: center;
  font-size: 20px;
  line-height: 1.4;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .p-movie__title {
    min-width: 186px;
    font-size: 15px;
    padding: 16px 19px;
  }
}
@media screen and (max-width: 575px) {
  .p-movie__title {
    min-width: 140px;
    font-size: 13px;
    padding: 13px 10px;
  }
}

@media screen and (min-width: 992px) {
  .p-case > a:hover .u-underline {
    color: #EF3340;
    background-position: 0 100%;
    background-size: 100% 1px;
  }
  .p-case > a:hover .p-case__image > img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
}
.p-case__image {
  overflow: hidden;
  margin-bottom: 20px;
}
.p-case__image > img {
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  width: 100%;
  height: auto;
}
.p-case__client {
  font-size: 16px;
  line-height: 1.625;
  margin-bottom: 10px;
}
.p-case__case {
  font-size: 20px;
  line-height: 1.65;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
.p-case__text {
  margin-top: 10px;
}
.p-case__link {
  margin-top: 55px;
}
.p-case-industry__result {
  border-top: 1px solid #222;
  border-bottom: 1px solid #222;
  padding: 20px 0;
}
@media screen and (min-width: 768px) {
  .p-case-industry__result {
    height: 100%;
  }
}
.p-case-industry__result__heading {
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-size: 20px;
  line-height: 1.4;
}
.p-case-industry__result__list {
  margin-top: 18px;
}
.p-case-industry__result__item {
  display: table;
  width: 100%;
  font-size: 14px;
  line-height: 1.6;
}
.p-case-industry__result__item::before {
  content: "・";
  display: table-cell;
  vertical-align: top;
  width: 1.5em;
}
.p-case-industry__result__item > span {
  display: table-cell;
  vertical-align: top;
}
.p-case-industry__result__item + .p-case-industry__result__item {
  margin-top: 13px;
}
.p-case-industry__result__link {
  text-align: right;
  margin-top: 30px;
}
.p-case-lg__image {
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .p-case-lg__image {
    margin-bottom: 30px;
  }
}
.p-case-lg__image > img {
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  width: 100%;
  height: auto;
}
@media screen and (min-width: 768px) {
  .p-case-lg > a:hover .c-more {
    color: #EF3340;
  }
  .p-case-lg > a:hover .c-more__border::after {
    -webkit-animation: borderToLong 0.3s forwards;
    animation: borderToLong 0.3s forwards;
  }
  .p-case-lg > a:hover .p-case-lg__image > img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
}

.p-column {
  position: relative;
}
.p-column__category {
  z-index: 2;
  background-color: #222;
  display: inline-block;
  border-radius: 10rem;
  color: #fff;
  padding: 0 10px;
  line-height: 2;
  position: absolute;
  top: -12px;
  left: 10px;
}
.p-column__eyecatch {
  display: block;
  margin-bottom: 20px;
  overflow: hidden;
}
.p-column__eyecatch > img {
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  width: 100%;
  height: auto;
}
.p-column__heading {
  font-size: 16px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  line-height: 1.8;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}
.p-column hr {
  margin: 20px 0 10px;
}
.p-column__tags {
  margin-bottom: 20px;
}
.p-column__attributes {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.p-column__attributes time {
  color: #999;
  font-weight: bold;
}
.p-column__attributes .c-more {
  font-size: 14px;
  font-weight: bold;
}
@media screen and (min-width: 992px) {
  .p-column .p-column__eyecatch > img:hover {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
  .p-column .c-more:hover {
    color: #EF3340;
  }
  .p-column .c-more:hover .c-more__border::after {
    -webkit-animation: borderToLong 0.3s forwards;
    animation: borderToLong 0.3s forwards;
  }
}
.p-column--lg {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  background-color: #F9F9F9;
  position: relative;
  z-index: 5;
}
@media screen and (max-width: 991px) {
  .p-column--lg {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
}
.p-column--lg .p-column__category {
  position: relative;
  top: 0;
  left: 0;
  margin-bottom: 20px;
}
.p-column--lg .p-column__heading {
  margin-bottom: 20px;
  font-size: 20px;
  line-height: 1.7;
}
.p-column--lg .p-column__eyecatch {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  margin-bottom: 0;
}
.p-column--lg .p-column__eyecatch img {
  -o-object-fit: cover;
  object-fit: cover;
}
@media screen and (min-width: 992px) {
  .p-column--lg .p-column__eyecatch img {
    height: 100%;
  }
}
.p-column--lg .p-column__main {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding: 30px;
  position: relative;
}
@media screen and (max-width: 991px) {
  .p-column--lg .p-column__main {
    padding: 20px;
  }
}
@media screen and (max-width: 767px) {
  .p-column--lg .p-column__main {
    padding: 10px;
  }
}

.p-column-categories {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.p-column-categories > * {
  margin: 0.5rem;
}
.p-column-categories--left {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}

.p-companies {
  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;
}
.p-companies__item {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 17.8%;
  flex: 0 0 17.8%;
  margin-bottom: 30px;
}
.p-companies__item:not(:nth-child(5n)) {
  margin-right: 2.75%;
}
@media screen and (max-width: 767px) {
  .p-companies__item:not(:nth-child(5n)) {
    margin-right: 0;
  }
}
@media screen and (max-width: 767px) {
  .p-companies__item:not(:nth-child(3n)) {
    margin-right: 1.5%;
  }
}
@media screen and (max-width: 767px) {
  .p-companies__item {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 32%;
    flex: 0 0 32%;
  }
}
.p-companies__item > img {
  width: 100%;
  height: auto;
}

.p-post + .p-post {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .p-post + .p-post {
    margin-top: 0;
  }
}
@media screen and (max-width: 767px) {
  .p-post {
    padding-bottom: 30px;
    border-bottom: 1px solid #E6E6E6;
  }
}
@media screen and (max-width: 767px) {
  .p-post:not(:first-child) {
    padding-top: 30px;
  }
}
@media screen and (min-width: 992px) {
  .p-post > a:hover .u-underline {
    color: #EF3340;
    background-position: 0 100%;
    background-size: 100% 1px;
  }
}
.p-post__date {
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  font-size: 16px;
  font-weight: bold;
  color: #C0C0C0;
  line-height: 1.1875;
}
@media screen and (max-width: 767px) {
  .p-post__date {
    font-size: 13px;
  }
}
.p-post__text {
  font-size: 18px;
  margin-top: 14px;
  line-height: 1.4;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding-bottom: 1px;
}
@media screen and (max-width: 767px) {
  .p-post__text {
    font-size: 13px;
  }
}
.p-post__link {
  margin-top: 75px;
}

.p-news-lg > a {
  display: block;
  padding: 28px 11px;
  border-top: 1px solid #E6E6E6;
  position: relative;
  z-index: 10;
}
.p-news-lg > a::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  background-color: #F9F9F9;
  width: 0;
  height: 100%;
  -webkit-transition: width 0.3s;
  transition: width 0.3s;
  z-index: -1;
}
@media screen and (min-width: 992px) {
  .p-news-lg > a:hover::before {
    width: 100%;
  }
  .p-news-lg > a:hover .c-more {
    color: #EF3340;
  }
  .p-news-lg > a:hover .c-more__border::after {
    -webkit-animation: borderToLong 0.3s forwards;
    animation: borderToLong 0.3s forwards;
  }
}
.p-news-lg__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.p-news-lg__date {
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  font-weight: bold;
  letter-spacing: 0.1rem;
  font-size: 16px;
  color: #999;
}
.p-news-lg__categorylist {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-left: 16px;
}
.p-news-lg__categoryitem {
  padding: 3px 12px;
  background-color: #999;
  color: #fff;
  font-size: 11px;
  line-height: 1.4;
}
.p-news-lg__categoryitem + .p-news-lg__categoryitem {
  margin-left: 8px;
}
.p-news-lg__text {
  margin-top: 20px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-size: 20px;
  line-height: 1.7;
}
.p-news-lg__link {
  margin-top: 17px;
  text-align: right;
}

.p-download > a,
.p-download-lg > a {
  display: block;
}
@media screen and (min-width: 992px) {
  .p-download > a:hover .p-download__heading,
.p-download > a:hover .p-download-lg__heading,
.p-download-lg > a:hover .p-download__heading,
.p-download-lg > a:hover .p-download-lg__heading {
    color: #EF3340;
    background-position: 0 100%;
    background-size: 100% 1px;
  }
  .p-download > a:hover .p-download__image > img,
.p-download > a:hover .p-download-lg__image > img,
.p-download-lg > a:hover .p-download__image > img,
.p-download-lg > a:hover .p-download-lg__image > img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
  .p-download > a:hover .c-more,
.p-download-lg > a:hover .c-more {
    color: #EF3340;
  }
  .p-download > a:hover .c-more__border::after,
.p-download-lg > a:hover .c-more__border::after {
    -webkit-animation: borderToLong 0.3s forwards;
    animation: borderToLong 0.3s forwards;
  }
}
.p-download__image,
.p-download-lg__image {
  overflow: hidden;
}
.p-download__image > img,
.p-download-lg__image > img {
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  width: 100%;
  height: auto;
}
.p-download__heading,
.p-download-lg__heading {
  margin-top: 18px;
  font-size: 20px;
  line-height: 1.45;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
@media screen and (min-width: 768px) {
  .p-download__heading,
.p-download-lg__heading {
    min-height: 3.6rem;
  }
}
.p-download__text,
.p-download-lg__text {
  margin-top: 10px;
  font-size: 13px;
  line-height: 2;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
.p-download__link,
.p-download-lg__link {
  text-align: right;
  margin-top: 20px;
}

.p-seminar > a {
  display: block;
}
@media screen and (min-width: 992px) {
  .p-seminar > a:hover .u-underline {
    color: #EF3340;
    background-position: 0 100%;
    background-size: 100% 1px;
  }
  .p-seminar > a:hover .p-seminar__thumbnail > img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
}
@media screen and (min-width: 768px) {
  .p-seminar {
    max-width: none !important;
    min-width: auto !important;
  }
}
.p-seminar__thumbnail {
  overflow: hidden;
}
.p-seminar__thumbnail > img {
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  width: 100%;
  height: auto;
}
.p-seminar__status {
  margin-top: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-size: 20px;
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  font-weight: 700;
  min-height: 60px;
}
@media screen and (max-width: 767px) {
  .p-seminar__status {
    font-size: 14px;
  }
  .p-seminar__status strong {
    font-size: 16px;
  }
}
.p-seminar__status strong {
  font-size: 28px;
  margin-right: 0.5rem;
}
.p-seminar__status .c-label {
  margin-right: 0.5rem;
}
.p-seminar__heading {
  font-size: 20px;
  line-height: 1.45;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
.p-seminar__text {
  margin-top: 10px;
}
.p-seminar__attributes {
  margin-top: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.p-seminar__attributes li {
  margin-right: 20px;
}
.p-seminar__attributes img {
  margin-right: 0.5rem;
  vertical-align: sub;
}

.c-label {
  display: inline-block;
  background: #CCCCCC;
  color: #fff;
  padding: 0 15px;
  font-weight: 700;
  font-size: 12px;
}
.c-label--gray {
  background-color: #CCCCCC;
}
.c-label--red {
  background-color: #EF3340;
}
.c-label--white {
  background-color: #fff;
  border: 1px solid #222;
  color: #222;
}
.c-label--black {
  background-color: #222;
}
.c-label--gray {
  background-color: #CCCCCC;
}

@media screen and (min-width: 768px) {
  .p-seminer {
    max-width: none !important;
    min-width: auto !important;
  }
}
.p-seminer > a {
  display: block;
}
@media screen and (min-width: 992px) {
  .p-seminer > a:hover .u-underline {
    color: #EF3340;
    background-position: 0 100%;
    background-size: 100% 1px;
  }
  .p-seminer > a:hover .p-webinar__image > img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
}
.p-seminer__image {
  overflow: hidden;
}
.p-seminer__image > img {
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  width: 100%;
  height: auto;
}
.p-seminer__subheading {
  margin-top: 18px;
  font-size: 20px;
  line-height: 1.45;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
.p-seminer__label {
  display: inline-block;
  margin-top: 18px;
  padding: 3px 12px;
  font-size: 12px;
  border: 1px solid #222;
  line-height: 2;
}

/**
 * p-security
 */
.p-security {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.p-security__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
}
.p-security__item + .p-security__item {
  margin-left: 20px;
}
.p-security__text {
  -webkit-box-flex: 0;
  -ms-flex: 0 1 auto;
  flex: 0 1 auto;
  margin-left: 30px;
  font-size: 12px;
  line-height: 1.6666666667;
}

.p-share__heading {
  text-align: center;
  font-weight: bold;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-size: 16px;
  margin-bottom: 10px;
}
.p-share__content > * {
  margin: 10px 5px;
}
.p-share__content a:hover {
  opacity: 0.8;
}

.p-jumbotron {
  padding-top: 40px;
  padding-bottom: 40px;
}
.p-jumbotron .c-container {
  overflow: visible;
  margin-bottom: 40px;
}
.p-jumbotron__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media screen and (max-width: 991px) {
  .p-jumbotron__container {
    display: block;
  }
}
@media screen and (min-width: 992px) {
  .p-jumbotron__main {
    width: 40%;
  }
}
@media screen and (min-width: 992px) {
  .p-jumbotron__main--lg {
    width: 50%;
  }
}
.p-jumbotron__eyecatch {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 50%;
  flex: 0 0 50%;
  position: relative;
}
@media screen and (max-width: 991px) {
  .p-jumbotron__eyecatch {
    margin-top: 30px;
    text-align: center;
  }
}
.p-jumbotron__heading {
  font-size: 46px;
  line-height: 1.4;
  margin-bottom: 30px;
  letter-spacing: 0.15rem;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}
.p-jumbotron__heading small {
  font-size: 20px;
  display: block;
  margin-bottom: 7.5px;
}
@media screen and (max-width: 575px) {
  .p-jumbotron__heading {
    font-size: 30px;
  }
}
.p-jumbotron__icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.p-jumbotron__icon * {
  margin-right: 15px;
}
.p-jumbotron__text {
  font-size: 14px;
}
@media screen and (max-width: 991px) {
  .p-jumbotron__text {
    font-size: 13px;
  }
}
.p-jumbotron__cta {
  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;
  margin-top: 30px;
}
@media screen and (min-width: 768px) {
  .p-jumbotron__cta {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }
  .p-jumbotron__cta .c-button + .c-button {
    margin-left: 20px;
  }
}
@media screen and (max-width: 767px) {
  .p-jumbotron__cta .c-button + .c-button {
    margin-top: 20px;
  }
}
.p-jumbotron__cta h2 {
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-size: 16px;
  margin-bottom: 10px;
}
@media screen and (max-width: 991px) {
  .p-jumbotron__cta h2 {
    font-size: 13px;
  }
}
.p-jumbotron__link {
  margin-top: 30px;
  position: relative;
  z-index: 2;
}
.p-jumbotron__parallax {
  position: absolute;
  top: 65px;
  left: 0;
  width: 100%;
  height: calc(100% - 65px);
}
.p-jumbotron__object {
  position: absolute;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.p-jumbotron__object--01 {
  top: -21px;
  left: -60px;
  width: 100px;
  height: 42px;
  background-color: #C8102E;
  z-index: 5;
}
@media screen and (max-width: 767px) {
  .p-jumbotron__object--01 {
    top: -16px;
    left: -50px;
    width: 80px;
    height: 33px;
  }
}
@media screen and (max-width: 575px) {
  .p-jumbotron__object--01 {
    top: -26px;
    left: -30px;
    width: 53px;
    height: 22px;
  }
}
.p-jumbotron__object--02 {
  top: -60px;
  left: 30px;
  width: 226px;
  height: 99px;
  background-color: #F9F9F9;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-jumbotron__object--02 {
    top: -47px;
    left: 30px;
    width: 180px;
    height: 79px;
  }
}
@media screen and (max-width: 575px) {
  .p-jumbotron__object--02 {
    width: 121px;
    height: 63px;
  }
}
.p-jumbotron__object--03 {
  top: -24px;
  right: -34px;
  width: 74px;
  height: 74px;
  background-color: #F9F9F9;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-jumbotron__object--03 {
    width: 59px;
    height: 59px;
  }
}
@media screen and (max-width: 575px) {
  .p-jumbotron__object--03 {
    top: -30px;
    right: -20px;
    width: 39px;
    height: 39px;
  }
}
.p-jumbotron__object--04 {
  bottom: -40px;
  left: -40px;
  width: 74px;
  height: 164px;
  background-color: #F9F9F9;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-jumbotron__object--04 {
    width: 59px;
    height: 131px;
  }
}
@media screen and (max-width: 575px) {
  .p-jumbotron__object--04 {
    bottom: -20px;
    left: -20px;
    width: 39px;
    height: 87px;
  }
}
.p-jumbotron__object--05 {
  bottom: 106px;
  right: -61px;
  width: 33px;
  height: 33px;
  background-color: #C8102E;
}
@media screen and (max-width: 767px) {
  .p-jumbotron__object--05 {
    right: -53px;
    bottom: 78px;
    width: 26px;
    height: 26px;
  }
}
@media screen and (max-width: 575px) {
  .p-jumbotron__object--05 {
    bottom: 58px;
    right: -30px;
    width: 17px;
    height: 17px;
  }
}
.p-jumbotron__object--06 {
  bottom: -26px;
  right: -28px;
  width: 65px;
  height: 134px;
  background-color: #EF3340;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-jumbotron__object--06 {
    width: 52px;
    height: 107px;
  }
}
@media screen and (max-width: 575px) {
  .p-jumbotron__object--06 {
    bottom: -15px;
    right: -13px;
    width: 34px;
    height: 71px;
  }
}

.p-lnav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  text-align: center;
  counter-reset: item;
  list-style-type: none;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-left: 1px;
}
@media screen and (max-width: 767px) {
  .p-lnav {
    border-top: 1px solid #E6E6E6;
    margin-left: 0;
  }
}
.p-lnav__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  padding: 7.5px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-weight: 700;
  font-size: 16px;
  -ms-flex-preferred-size: 100%;
  flex-basis: 100%;
  padding: 15px;
  border-right: 1px solid #E6E6E6;
  border-left: 1px solid #E6E6E6;
  margin-bottom: 15px;
}
@media screen and (min-width: 992px) {
  .p-lnav__item {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 16.6666666667%;
    flex: 0 0 16.6666666667%;
    margin-left: -1px;
  }
}
@media screen and (max-width: 767px) {
  .p-lnav__item {
    border-right: none;
    border-left: none;
    margin-bottom: 0;
    padding: 14px 7px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    border-bottom: 1px solid #E6E6E6;
  }
  .p-lnav__item:before {
    margin-right: 20px;
  }
  .p-lnav__item:after {
    margin-left: auto;
    height: 36px !important;
  }
}
.p-lnav__item:hover {
  color: #EF3340;
}
.p-lnav__item:before {
  counter-increment: item;
  content: "0" counter(item);
  font-size: 20px;
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  color: #EF3340;
  line-height: 1;
}
.p-lnav__item:after {
  content: url(../images/common/icon-arrow-down.svg);
  -webkit-transform: scale(0.3);
  transform: scale(0.3);
  height: 20px;
  line-height: 1;
  vertical-align: top;
}
.p-lnav-heading {
  position: relative;
  padding-top: 54px;
  margin-bottom: 30px;
}
.p-lnav-heading__number {
  position: absolute;
  line-height: 1;
  top: 0;
  left: 0;
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  font-weight: bold;
  font-size: 120px;
  color: #fff;
  text-shadow: 1px 1px 0 #E2E2E2, -1px -1px 0 #E2E2E2, -1px 1px 0 #E2E2E2, 1px -1px 0 #E2E2E2, 0px 1px 0 #E2E2E2, -1px 0 #E2E2E2, -1px 0 0 #E2E2E2, 1px 0 0 #E2E2E2;
  z-index: -1;
}
.p-lnav-heading__en {
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  font-size: 12px;
  letter-spacing: 0.1rem;
}
.p-lnav-heading__title {
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-size: 20px;
  font-weight: 700;
}
.p-lnav--fix {
  counter-reset: none;
}
@media screen and (min-width: 768px) {
  .p-lnav--fix {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: auto;
    border-left: none;
  }
  .p-lnav--fix .p-lnav__item {
    -ms-flex-preferred-size: auto;
    flex-basis: auto;
    width: 13rem;
  }
  .p-lnav--fix .p-lnav__item:first-child {
    border-left: 1px solid #E6E6E6;
  }
}

.p-hero {
  padding: 40px 0;
  margin-bottom: 40px;
}
@media screen and (max-width: 991px) {
  .p-hero {
    padding: 30px 0;
    margin-bottom: 30px;
  }
}
.p-hero__text {
  font-size: 14px;
  margin-top: 30px;
  width: 615px;
  line-height: 2.1428571429;
}
@media screen and (max-width: 991px) {
  .p-hero__text {
    width: auto;
  }
}
.p-hero__parallax {
  position: relative;
  z-index: -1;
  width: 994px;
  margin: auto;
}
@media screen and (max-width: 991px) {
  .p-hero__parallax {
    width: auto;
  }
}
.p-hero__cta {
  margin-top: 30px;
}
.p-hero__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-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-top: 30px;
}
@media screen and (min-width: 768px) {
  .p-hero__links {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    width: 50%;
  }
  .p-hero__links .c-button + .c-button {
    margin-left: 20px;
  }
}
@media screen and (max-width: 767px) {
  .p-hero__links .c-button + .c-button {
    margin-top: 20px;
  }
}
.p-hero__object {
  position: absolute;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.p-hero__object--01 {
  top: 108px;
  right: 140px;
  width: 149px;
  height: 74px;
  background-color: #E6E6E6;
  z-index: 50;
}
@media screen and (max-width: 991px) {
  .p-hero__object--01 {
    top: 18px;
    right: 174px;
    width: 59px;
    height: 30px;
  }
}
@media screen and (max-width: 767px) {
  .p-hero__object--01 {
    top: 24px;
    right: 96px;
    width: 32px;
    height: 16px;
  }
}
.p-hero__object--02 {
  top: 46px;
  right: 50px;
  width: 149px;
  height: 244px;
  background-color: #F9F9F9;
}
@media screen and (max-width: 991px) {
  .p-hero__object--02 {
    top: 0;
    right: 138px;
    width: 59px;
    height: 99px;
  }
}
@media screen and (max-width: 767px) {
  .p-hero__object--02 {
    top: 13px;
    right: 76px;
    width: 32px;
    height: 54px;
  }
}
.p-hero__object--03 {
  top: 94px;
  right: -235px;
  width: 149px;
  height: 74px;
  background-color: #E6E6E6;
}
@media screen and (max-width: 991px) {
  .p-hero__object--03 {
    top: 11px;
    right: 23px;
    width: 59px;
    height: 30px;
  }
}
@media screen and (max-width: 767px) {
  .p-hero__object--03 {
    top: 14px;
    right: 12px;
    width: 32px;
    height: 16px;
  }
}
.p-hero__object--04 {
  top: 318px;
  left: -176px;
  width: 88px;
  height: 181px;
  background-color: #F9F9F9;
}
@media screen and (max-width: 991px) {
  .p-hero__object--04 {
    display: none;
  }
}
.p-hero__object--05 {
  top: 319px;
  right: 214px;
  width: 74px;
  height: 74px;
  background-color: #F9F9F9;
}
@media screen and (max-width: 991px) {
  .p-hero__object--05 {
    top: 101px;
    right: 208px;
    width: 30px;
    height: 30px;
  }
}
@media screen and (max-width: 767px) {
  .p-hero__object--05 {
    top: 63px;
    right: 115px;
    width: 16px;
    height: 16px;
  }
}
.p-hero__object--06 {
  top: 290px;
  right: -290px;
  width: 342px;
  height: 182px;
  background-color: #E6E6E6;
}
@media screen and (max-width: 991px) {
  .p-hero__object--06 {
    top: 92px;
    right: 0;
    width: 138px;
    height: 73px;
  }
}
@media screen and (max-width: 767px) {
  .p-hero__object--06 {
    top: 63px;
    right: 0;
    width: 76px;
    height: 40px;
  }
}
.p-hero__object--07 {
  top: 611px;
  left: -297px;
  width: 186px;
  height: 74px;
  background-color: #E6E6E6;
}
@media screen and (max-width: 575px) {
  .p-hero__object--07 {
    display: none;
  }
}
.p-hero-heading__primary {
  font-size: 70px;
  display: block;
  line-height: 1.3;
}
@media screen and (max-width: 991px) {
  .p-hero-heading__primary {
    font-size: 70px;
  }
}
@media screen and (max-width: 767px) {
  .p-hero-heading__primary {
    font-size: 46px;
  }
}
.p-hero-heading__secondary {
  font-size: 30px;
  color: #EF3340;
  display: block;
  line-height: 1.3;
}
@media screen and (max-width: 991px) {
  .p-hero-heading__secondary {
    margin-top: 8px;
    font-size: 30px;
  }
}
@media screen and (max-width: 767px) {
  .p-hero-heading__secondary {
    font-size: 20px;
  }
}
.p-hero-heading__simple {
  font-size: 46px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-hero-heading__simple {
    font-size: 28px;
  }
}

.p-user-story {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  margin-bottom: 30px;
}
@media screen and (max-width: 991px) {
  .p-user-story {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
}
.p-user-story__text {
  flex-basis: 40%;
  -ms-flex-preferred-size: 40%;
  padding: 30px;
  z-index: 2;
}
@media screen and (max-width: 991px) {
  .p-user-story__text {
    padding: 0;
  }
}
.p-user-story__eyecatch {
  flex-basis: 60%;
  -ms-flex-preferred-size: 60%;
  z-index: 2;
}
@media screen and (max-width: 991px) {
  .p-user-story__eyecatch {
    margin-bottom: 20px;
  }
}
.p-user-story__image {
  padding-right: 30px;
}
@media screen and (max-width: 991px) {
  .p-user-story__image {
    padding: 0;
  }
}
@media screen and (max-width: 991px) {
  .p-user-story__heading {
    font-size: 20px;
    margin-bottom: 10px;
  }
}
.p-user-story__number {
  line-height: 1;
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  font-weight: bold;
  font-size: 120px;
  color: rgba(255, 255, 255, 0.1);
  -webkit-text-stroke: 1px #e9e9e9;
  text-stroke: 1px #e9e9e9;
  z-index: -1;
}
@media screen and (max-width: 991px) {
  .p-user-story__number {
    display: none;
  }
}
.p-user-story__caption {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0;
  margin: 0;
  position: absolute;
  letter-spacing: 0.1rem;
  line-height: 1;
  -webkit-transform-origin: top right;
  transform-origin: top right;
  -webkit-transform: rotate(90deg) translateX(100%);
  transform: rotate(90deg) translateX(100%);
  top: 45px;
  right: 0;
  z-index: 1;
  font-weight: 700;
}
@media screen and (max-width: 991px) {
  .p-user-story__caption {
    display: none;
  }
}
.p-user-story__caption:before {
  content: "";
  height: 1px;
  width: 90px;
  margin-right: 7.5px;
  background-color: #222;
}
@media screen and (max-width: 991px) {
  .p-user-story__caption:before {
    width: 30px;
  }
}
.p-user-story__background {
  position: absolute;
  top: 90px;
  bottom: -30px;
  left: 0;
  right: 60px;
  z-index: 1;
  background-color: #F9F9F9;
}
@media screen and (max-width: 991px) {
  .p-user-story__background {
    display: none;
  }
}
.p-user-story.is-reverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}
@media screen and (max-width: 991px) {
  .p-user-story.is-reverse {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
}
.p-user-story.is-reverse .p-user-story__background {
  right: 0;
  left: 60px;
}
.p-user-story.is-reverse .p-user-story__image {
  padding-left: 30px;
  padding-right: 0;
}
@media screen and (max-width: 991px) {
  .p-user-story.is-reverse .p-user-story__image {
    padding: 0;
  }
}
.p-user-story.is-reverse .p-user-story__number {
  text-align: right;
}
.p-user-story.is-reverse .p-user-story__caption {
  -webkit-transform-origin: top left;
  transform-origin: top left;
  right: initial;
  left: 15px;
  top: -60px;
}
.p-user-story.is-reverse .p-user-story__eyecatch {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}

.p-eyecatch {
  height: 40vh;
  margin-bottom: 40px;
  background-size: cover;
  background-position: center;
}

.p-points {
  border-top: 1px solid #222;
  border-bottom: 1px solid #222;
  padding: 20px;
}
.p-points__heading {
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-weight: 700;
  font-size: 20px;
  margin-bottom: 10px;
}

.p-problem {
  border: 1px solid #222;
  border-top-width: 4px;
  padding: 30px;
  text-align: center;
}
.p-problem__eyecatch {
  margin-bottom: 10px;
}
.p-problem__heading {
  margin-top: 10px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-weight: 700;
  font-size: 20px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-problem__heading {
    font-size: 17px;
  }
}
.p-problem__description {
  margin-top: 10px;
}
.p-problem__link {
  margin-top: 20px;
}
.p-problem-case {
  background-color: #F9F9F9;
  padding: 30px;
}
.p-problem-case__heading {
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-weight: 700;
  font-size: 20px;
  line-height: 1.5;
  border-bottom: 1px solid #DDDDDD;
  padding-bottom: 20px;
  margin-bottom: 30px;
}
.p-problem-case__before dt, .p-problem-case__after dt {
  background-size: 1rem auto;
  padding-left: 1.5rem;
  font-size: 14px;
}
.p-problem-case__before ul, .p-problem-case__after ul {
  padding-left: 1rem;
  list-style-type: disc;
}
.p-problem-case__before dt {
  background: url(../images/problems/icon-case-before.svg) left 0px top 5px no-repeat;
}
.p-problem-case__after dt {
  background: url(../images/problems/icon-case-after.svg) left 0px top 5px no-repeat;
  color: #EF3340;
}
.p-problem__list-eyecatch {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.p-problem__list-eyecatch figure {
  min-width: 100px;
  margin-left: auto;
  position: relative;
}
.p-problem__list-eyecatch figure img {
  position: absolute;
  top: 50%;
  right: 0%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
}

.p-problem-flow__header {
  background: #222;
  color: #fff;
  text-align: center;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-size: 20px;
  padding: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .p-problem-flow__header {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.p-problem-flow__header span {
  background-color: #fff;
  color: #222;
  padding: 0 10px 0 5px;
  margin-right: 10px;
  font-size: 13px;
  -webkit-clip-path: polygon(90% 0%, 100% 50%, 90% 100%, 0% 100%, 0 51%, 0% 0%);
  clip-path: polygon(90% 0%, 100% 50%, 90% 100%, 0% 100%, 0 51%, 0% 0%);
}
.p-problem-flow__content {
  background: #F9F9F9;
  padding: 30px;
}
.p-problem-flow__heading {
  text-align: center;
  background-image: url(../images/problems/bg-dotted.svg);
  background-position: center;
  background-repeat: repeat-x;
  margin-bottom: 20px;
}
.p-problem-flow__heading span {
  background: #F9F9F9;
  color: #F9F9F9;
  padding: 0 20px;
  line-height: 60px;
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  font-weight: bold;
  font-size: 50px;
  letter-spacing: 0.04em;
  text-shadow: 1px 1px 0 #222, -1px -1px 0 #222, -1px 1px 0 #222, 1px -1px 0 #222, 0px 1px 0 #222, -1px 0 #222, -1px 0 0 #222, 1px 0 0 #222;
}
.p-problem-flow__lists {
  background: #fff;
  border-radius: 4px;
  padding: 10px;
}
.p-problem-flow__lists li {
  background: url(../images/problems/icon-problem-check.svg) left 0px top 5px no-repeat;
  background-size: 1rem auto;
  padding-left: 1.5rem;
  text-align: left !important;
}
.p-problem-flow__lists li strong {
  font-weight: bold;
  color: #EF3340;
}
.p-problem-flow__point {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  background: #fff;
  border-radius: 50rem;
  border: 1px solid #EF3340;
  padding: 10px;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  .p-problem-flow__point {
    border-radius: 1rem;
  }
}
.p-problem-flow__point span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-weight: bold;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-size: 16.8px;
  color: #EF3340;
}
.p-problem-flow__point span:before {
  content: url(../images/problems/icon-point.svg);
  line-height: 1;
  padding-right: 0.5rem;
}
.p-problem-flow__point.is-inverse {
  background-color: #EF3340;
  color: #fff;
}
.p-problem-flow__point.is-inverse span {
  color: #fff;
}
.p-problem-flow__point.is-inverse span:before {
  content: url(../images/problems/icon-point-white.svg);
}
.p-problem-flow__point-lg {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background-color: #EF3340;
  border: 1px solid #EF3340;
  border-radius: 0.5rem;
  color: #fff;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-weight: bold;
  padding: 5px 10px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-size: 20px;
}
.p-problem-flow__point-lg img {
  width: 108px;
}
.p-problem-flow__point-lg span {
  -webkit-box-flex: 2;
  -ms-flex-positive: 2;
  flex-grow: 2;
  text-align: center;
  display: block;
}
.p-problem-flow__point-lg-inverse {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background-color: #fff;
  border: 1px solid #EF3340;
  border-radius: 0.5rem;
  color: #EF3340;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-weight: bold;
  padding: 5px 10px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-size: 20px;
}
.p-problem-flow__point-lg-inverse img {
  width: 108px;
}
.p-problem-flow__point-lg-inverse span {
  -webkit-box-flex: 2;
  -ms-flex-positive: 2;
  flex-grow: 2;
  text-align: center;
  display: block;
}
.p-problem-flow__point-eyecatch {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background-color: #EF3340;
  border: 1px solid #EF3340;
  border-radius: 0.5rem;
  color: #fff;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-weight: bold;
  padding: 5px 10px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-size: 16.8px;
  line-height: 1.8;
}
.p-problem-flow__point-eyecatch img {
  margin-right: 20px;
}
.p-problem-flow__point-eyecatch span {
  -webkit-box-flex: 2;
  -ms-flex-positive: 2;
  flex-grow: 2;
  text-align: left;
  display: block;
}
@media screen and (max-width: 767px) {
  .p-problem-flow__point-eyecatch {
    -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;
  }
  .p-problem-flow__point-eyecatch img {
    margin-right: 0;
    margin-bottom: 10px;
  }
}
@media screen and (min-width: 992px) {
  .p-problem-flow__point-eyecatch {
    border-radius: 50rem;
  }
}
.p-problem-flow__point-sm {
  font-weight: bold;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  font-size: 16.8px;
  color: #EF3340;
}
.p-problem-flow__point-sm:before {
  content: url(../images/problems/icon-problem-check.svg);
  line-height: 1;
  padding-right: 0.5rem;
}
.p-problem-flow__next {
  width: 100%;
  background-image: url(../images/problems/icon-arrow-down.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  height: 46px;
  margin-top: 30px;
  margin-bottom: 30px;
}
.p-problem-flow__down {
  background-image: url(../images/common/icon-triangle-down.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  width: 100%;
  height: 18px;
}

.p-step {
  background-color: #F9F9F9;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 30px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  margin-bottom: 36px;
}
@media screen and (max-width: 767px) {
  .p-step {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.p-step__number {
  font-weight: bold;
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  font-size: 14px;
  text-align: center;
  letter-spacing: 0.2rem;
  line-height: 1;
}
.p-step__number strong {
  display: block;
  line-height: 1;
  margin-top: 5px;
  font-size: 69px;
  color: #F9F9F9;
  text-shadow: 1px 1px 0 #222, -1px -1px 0 #222, -1px 1px 0 #222, 1px -1px 0 #222, 0px 1px 0 #222, -1px 0 #222, -1px 0 0 #222, 1px 0 0 #222;
  z-index: -1;
}
.p-step__heading {
  font-weight: 700;
  font-size: 20px;
  white-space: nowrap;
  padding: 0 30px;
}
@media screen and (max-width: 767px) {
  .p-step__heading {
    margin: 10px 0;
  }
}
.p-step__arrow {
  position: absolute;
  bottom: -53px;
  left: 66px;
  height: 80px;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .p-step__arrow {
    left: 49%;
  }
}

.p-price {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  border: 1px solid #222;
  padding: 30px;
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  .p-price {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.p-price__item {
  text-align: center;
  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;
  width: 100%;
}
.p-price__divider {
  background-image: url(../images/pages/pricing/bg-dotted-plus.svg);
  width: 100%;
  background-position: center;
  background-repeat: no-repeat;
  max-width: 28px;
}
@media screen and (max-width: 767px) {
  .p-price__divider {
    max-width: 100%;
    height: 28px;
    margin: 30px 0;
    background-image: url(../images/pages/pricing/bg-dotted-plus-horizontal.svg);
    background-position: center;
    background-repeat: no-repeat;
  }
}
.p-price__eyecatch {
  margin-bottom: 20px;
}
.p-price__heading {
  margin-bottom: 10px;
  font-weight: 700;
  font-size: 20px;
}
.p-price__heading strong {
  font-size: 36px;
  line-height: 1;
}

.p-toc {
  background-color: #F9F9F9;
  padding: 20px;
}
.p-toc__heading {
  font-size: 16px;
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
  cursor: pointer;
}
.p-toc__heading:before {
  content: "▼";
  -webkit-transform: rotate(-90deg);
  transform: rotate(-90deg);
  display: inline-block;
  margin-right: 10px;
}
.p-toc__heading.is-active:before {
  -webkit-transform: rotate(0);
  transform: rotate(0);
  -webkit-transition: -webkit-transform 0.2s;
  transition: -webkit-transform 0.2s;
  transition: transform 0.2s;
  transition: transform 0.2s, -webkit-transform 0.2s;
}
.p-toc ol {
  position: relative;
  margin: 0;
  padding: 0 0 0 33px;
  counter-reset: li;
}
.p-toc ol li {
  position: relative;
  list-style: none;
  margin-top: 5px;
}
.p-toc ol > li:before {
  position: absolute;
  font-weight: bold;
  counter-increment: li;
  content: counter(li) ".";
  left: -2rem;
  top: 0.25rem;
  color: #222;
  width: 1.3rem;
  height: 1.3rem;
  font-size: 0.85rem;
  text-align: center;
  border-radius: 100%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  font-weight: bold;
  line-height: 1.3rem;
  background: none;
  padding: 0;
}
.p-toc__content {
  display: none;
}
.p-toc__content.is-active {
  display: block;
}
.p-toc__content > ol > li:before {
  color: #fff;
  background: #EF3340;
  content: counter(li) "";
}
.p-toc__content > ol > li > ol > li:before {
  color: #fff;
  background: #999;
  content: counter(li) "";
}

.qa {
  margin: 40px;
}

.qa__block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  min-width: 200px;
}

.qa__item {
  display: inline-block;
}

.qa__head {
  position: relative;
  text-align: left;
  padding: 20px 30px 20px 20px;
  border-radius: 8px 8px 0 0;
  background: lightblue;
  color: black;
  cursor: pointer;
  width: 100%;
}

.qa__head:after {
  content: "";
  border-top: 1px solid black;
  border-left: 1px solid black;
  display: inline-block;
  width: 10px;
  height: 10px;
  -webkit-transform: rotate(-135deg) translateY(9px);
  transform: rotate(-135deg) translateY(9px);
  position: absolute;
  right: 20px;
  top: 50%;
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
}

.qa__body {
  position: relative;
  border-radius: 0 0 8px 8px;
  background: #fff;
  color: black;
  border: transparent;
  padding: 0 20px;
  line-height: 0;
  opacity: 0;
  -webkit-transition: line-height 0.4s, padding 0.4s, opacity 0.4s;
  transition: line-height 0.4s, padding 0.4s, opacity 0.4s;
}

.qa__body.is-open {
  padding: 20px;
  line-height: 1.5;
  opacity: 1;
  border: 1px solid lightblue;
}

.qa__head.is-open::after {
  -webkit-transform: rotate(45deg) translateY(-10px);
  transform: rotate(45deg) translateY(-10px);
}

.qa__item:not(:first-child) {
  margin-top: 16px;
}

.p-faq__question {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  cursor: pointer;
  padding: 30px 20px;
  font-size: 16px;
  font-weight: 700;
  border-bottom: 1px solid #E6E6E6;
}
@media screen and (max-width: 767px) {
  .p-faq__question {
    padding: 20px 0;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }
}
.p-faq__question.is-active {
  border-bottom: none;
}
.p-faq__question.is-active .p-faq__trigger {
  background-image: url(../images/common/icon-close.svg);
}
.p-faq__icon {
  color: #CCCCCC;
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  font-size: 36px;
  margin-right: 30px;
}
@media screen and (max-width: 767px) {
  .p-faq__icon {
    font-size: 28px;
    margin-right: 20px;
  }
}
.p-faq__trigger {
  background-image: url(../images/common/icon-open.svg);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  margin-left: 30px;
  width: 16px;
  height: 16px;
  min-width: 16px;
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  .p-faq__trigger {
    margin-top: 16px;
    margin-left: 20px;
  }
}
.p-faq__answer {
  background-color: #F9F9F9;
  padding: 30px;
  -webkit-transition: opacity 0.4s, visibility 0s ease 1s;
  transition: opacity 0.4s, visibility 0s ease 1s;
  opacity: 0;
  display: none;
  border-bottom: 1px solid #E6E6E6;
}
.p-faq__answer.is-active {
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  opacity: 1;
  display: block;
  -webkit-animation-duration: 0.5s;
  animation-duration: 0.5s;
  -webkit-animation-name: accodion;
  animation-name: accodion;
}
@-webkit-keyframes accodion {
  0% {
    display: none;
    opacity: 0;
    -webkit-transform: translateY(-1rem);
    transform: translateY(-1rem);
  }
  1% {
    display: block;
    opacity: 0.2;
    -webkit-transform: translateY(-0.5rem);
    transform: translateY(-0.5rem);
  }
  100% {
    display: block;
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}
@keyframes accodion {
  0% {
    display: none;
    opacity: 0;
    -webkit-transform: translateY(-1rem);
    transform: translateY(-1rem);
  }
  1% {
    display: block;
    opacity: 0.2;
    -webkit-transform: translateY(-0.5rem);
    transform: translateY(-0.5rem);
  }
  100% {
    display: block;
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

.p-card {
  border: 1px solid #222;
  padding: 30px;
}
.p-card > * + * {
  margin-top: 10px;
}
.p-card > * + h2, .p-card > * + h3, .p-card > * + h4 {
  margin-top: 20px;
}
.p-card--background {
  border: none;
  background-color: #F9F9F9;
}

.p-link-card {
  border: 1px solid #DDDDDD;
  padding: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-decoration: none !important;
}
@media screen and (max-width: 991px) {
  .p-link-card {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
  .p-link-card__thumbnail {
    max-width: 100%;
    margin-right: 0;
    margin-bottom: 20px;
  }
}
.p-link-card:hover {
  background-color: #F9F9F9;
}
.p-link-card__thumbnail {
  max-width: 10rem;
  margin-right: 30px;
}
.p-link-card__title {
  font-size: 16.8px;
  font-weight: 700;
  line-height: 1.6;
}
.p-link-card__excerpt {
  margin-top: 10px;
  font-size: 12px;
  color: #666;
}

.u-chevron-right {
  background-image: url(../images/common/icon-chevron-down.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 42px;
  height: 18px;
}
.u-chevron-left {
  background-image: url(../images/common/icon-chevron-down.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 42px;
  height: 18px;
}
.u-chevron-top {
  background-image: url(../images/common/icon-chevron-down.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 42px;
  height: 18px;
}
.u-chevron-bottom {
  background-image: url(../images/common/icon-chevron-down.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 42px;
  height: 18px;
}

/**
 * clearfix
 */
.u-clearfix::after {
  content: "";
  display: block;
  clear: both;
}

.u-color-primary {
  color: #EF3340;
}

.u-underline {
  background-image: -webkit-gradient(linear, left top, left bottom, from(#EF3340), to(#EF3340));
  background-image: linear-gradient(#EF3340, #EF3340);
  background-position: 100% 100%;
  background-repeat: no-repeat;
  background-size: 0% 1px;
  -webkit-transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: background-size 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.u-hover-alpha {
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
@media screen and (min-width: 992px) {
  .u-hover-alpha:hover {
    opacity: 0.6;
  }
}

.u-font-midashi {
  font-family: 見出ゴMB31, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: bold;
}

.u-font-bbb {
  font-family: 中ゴシックBBB, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
}

.u-font-futo {
  font-family: 太ゴB101, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
}

.u-font-en {
  font-family: "Helvetica Neue", "Open Sans", sans-serif;
  font-weight: bold;
  letter-spacing: 0.1rem;
}

.u-font-weight-bold {
  font-weight: 700;
  font-family: 太ゴB101, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
}

.u-font-size-body {
  font-size: 13px;
}
.u-font-size-sm {
  font-size: 14px;
}
.u-font-size-md {
  font-size: 20px;
}
.u-font-size-lg {
  font-size: 24px;
}
.u-font-size-xl {
  font-size: 32px;
}
.u-font-size-h2 {
  font-size: 36px;
}
.u-font-size-h3 {
  font-size: 28px;
}
.u-font-size-h4 {
  font-size: 20px;
}
.u-font-size-h5 {
  font-size: 16px;
}
@media screen and (min-width: 0) {
  .u-font-size-xs-body {
    font-size: 13px;
  }
  .u-font-size-xs-sm {
    font-size: 14px;
  }
  .u-font-size-xs-md {
    font-size: 20px;
  }
  .u-font-size-xs-lg {
    font-size: 24px;
  }
  .u-font-size-xs-xl {
    font-size: 32px;
  }
  .u-font-size-xs-h2 {
    font-size: 36px;
  }
  .u-font-size-xs-h3 {
    font-size: 28px;
  }
  .u-font-size-xs-h4 {
    font-size: 20px;
  }
  .u-font-size-xs-h5 {
    font-size: 16px;
  }
}
@media screen and (min-width: 576px) {
  .u-font-size-sm-body {
    font-size: 13px;
  }
  .u-font-size-sm-sm {
    font-size: 14px;
  }
  .u-font-size-sm-md {
    font-size: 20px;
  }
  .u-font-size-sm-lg {
    font-size: 24px;
  }
  .u-font-size-sm-xl {
    font-size: 32px;
  }
  .u-font-size-sm-h2 {
    font-size: 36px;
  }
  .u-font-size-sm-h3 {
    font-size: 28px;
  }
  .u-font-size-sm-h4 {
    font-size: 20px;
  }
  .u-font-size-sm-h5 {
    font-size: 16px;
  }
}
@media screen and (min-width: 768px) {
  .u-font-size-md-body {
    font-size: 13px;
  }
  .u-font-size-md-sm {
    font-size: 14px;
  }
  .u-font-size-md-md {
    font-size: 20px;
  }
  .u-font-size-md-lg {
    font-size: 24px;
  }
  .u-font-size-md-xl {
    font-size: 32px;
  }
  .u-font-size-md-h2 {
    font-size: 36px;
  }
  .u-font-size-md-h3 {
    font-size: 28px;
  }
  .u-font-size-md-h4 {
    font-size: 20px;
  }
  .u-font-size-md-h5 {
    font-size: 16px;
  }
}
@media screen and (min-width: 992px) {
  .u-font-size-lg-body {
    font-size: 13px;
  }
  .u-font-size-lg-sm {
    font-size: 14px;
  }
  .u-font-size-lg-md {
    font-size: 20px;
  }
  .u-font-size-lg-lg {
    font-size: 24px;
  }
  .u-font-size-lg-xl {
    font-size: 32px;
  }
  .u-font-size-lg-h2 {
    font-size: 36px;
  }
  .u-font-size-lg-h3 {
    font-size: 28px;
  }
  .u-font-size-lg-h4 {
    font-size: 20px;
  }
  .u-font-size-lg-h5 {
    font-size: 16px;
  }
}

.u-mr-0 {
  margin-right: 0px !important;
}

.u-mr-minus-0 {
  margin-right: 0px !important;
}

.u-pr-0 {
  padding-right: 0px !important;
}

.u-mr-1 {
  margin-right: 20px !important;
}

.u-mr-minus-1 {
  margin-right: -20px !important;
}

.u-pr-1 {
  padding-right: 20px !important;
}

.u-mr-2 {
  margin-right: 40px !important;
}

.u-mr-minus-2 {
  margin-right: -40px !important;
}

.u-pr-2 {
  padding-right: 40px !important;
}

.u-mr-3 {
  margin-right: 60px !important;
}

.u-mr-minus-3 {
  margin-right: -60px !important;
}

.u-pr-3 {
  padding-right: 60px !important;
}

.u-mr-4 {
  margin-right: 80px !important;
}

.u-mr-minus-4 {
  margin-right: -80px !important;
}

.u-pr-4 {
  padding-right: 80px !important;
}

.u-mr-5 {
  margin-right: 100px !important;
}

.u-mr-minus-5 {
  margin-right: -100px !important;
}

.u-pr-5 {
  padding-right: 100px !important;
}

.u-mr-auto {
  margin-right: auto !important;
}

.u-ml-0 {
  margin-left: 0px !important;
}

.u-ml-minus-0 {
  margin-left: 0px !important;
}

.u-pl-0 {
  padding-left: 0px !important;
}

.u-ml-1 {
  margin-left: 20px !important;
}

.u-ml-minus-1 {
  margin-left: -20px !important;
}

.u-pl-1 {
  padding-left: 20px !important;
}

.u-ml-2 {
  margin-left: 40px !important;
}

.u-ml-minus-2 {
  margin-left: -40px !important;
}

.u-pl-2 {
  padding-left: 40px !important;
}

.u-ml-3 {
  margin-left: 60px !important;
}

.u-ml-minus-3 {
  margin-left: -60px !important;
}

.u-pl-3 {
  padding-left: 60px !important;
}

.u-ml-4 {
  margin-left: 80px !important;
}

.u-ml-minus-4 {
  margin-left: -80px !important;
}

.u-pl-4 {
  padding-left: 80px !important;
}

.u-ml-5 {
  margin-left: 100px !important;
}

.u-ml-minus-5 {
  margin-left: -100px !important;
}

.u-pl-5 {
  padding-left: 100px !important;
}

.u-ml-auto {
  margin-left: auto !important;
}

.u-mt-0 {
  margin-top: 0px !important;
}

.u-mt-minus-0 {
  margin-top: 0px !important;
}

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

.u-mt-1 {
  margin-top: 20px !important;
}

.u-mt-minus-1 {
  margin-top: -20px !important;
}

.u-pt-1 {
  padding-top: 20px !important;
}

.u-mt-2 {
  margin-top: 40px !important;
}

.u-mt-minus-2 {
  margin-top: -40px !important;
}

.u-pt-2 {
  padding-top: 40px !important;
}

.u-mt-3 {
  margin-top: 60px !important;
}

.u-mt-minus-3 {
  margin-top: -60px !important;
}

.u-pt-3 {
  padding-top: 60px !important;
}

.u-mt-4 {
  margin-top: 80px !important;
}

.u-mt-minus-4 {
  margin-top: -80px !important;
}

.u-pt-4 {
  padding-top: 80px !important;
}

.u-mt-5 {
  margin-top: 100px !important;
}

.u-mt-minus-5 {
  margin-top: -100px !important;
}

.u-pt-5 {
  padding-top: 100px !important;
}

.u-mt-auto {
  margin-top: auto !important;
}

.u-mb-0 {
  margin-bottom: 0px !important;
}

.u-mb-minus-0 {
  margin-bottom: 0px !important;
}

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

.u-mb-1 {
  margin-bottom: 20px !important;
}

.u-mb-minus-1 {
  margin-bottom: -20px !important;
}

.u-pb-1 {
  padding-bottom: 20px !important;
}

.u-mb-2 {
  margin-bottom: 40px !important;
}

.u-mb-minus-2 {
  margin-bottom: -40px !important;
}

.u-pb-2 {
  padding-bottom: 40px !important;
}

.u-mb-3 {
  margin-bottom: 60px !important;
}

.u-mb-minus-3 {
  margin-bottom: -60px !important;
}

.u-pb-3 {
  padding-bottom: 60px !important;
}

.u-mb-4 {
  margin-bottom: 80px !important;
}

.u-mb-minus-4 {
  margin-bottom: -80px !important;
}

.u-pb-4 {
  padding-bottom: 80px !important;
}

.u-mb-5 {
  margin-bottom: 100px !important;
}

.u-mb-minus-5 {
  margin-bottom: -100px !important;
}

.u-pb-5 {
  padding-bottom: 100px !important;
}

.u-mb-auto {
  margin-bottom: auto !important;
}

.u-my-0 {
  margin-top: 0px !important;
  margin-bottom: 0px !important;
}

.u-my-minus-0 {
  margin-top: 0px !important;
  margin-bottom: 0px !important;
}

.u-py-0 {
  padding-top: 0px !important;
  padding-bottom: 0px !important;
}

.u-my-1 {
  margin-top: 20px !important;
  margin-bottom: 20px !important;
}

.u-my-minus-1 {
  margin-top: -20px !important;
  margin-bottom: -20px !important;
}

.u-py-1 {
  padding-top: 20px !important;
  padding-bottom: 20px !important;
}

.u-my-2 {
  margin-top: 40px !important;
  margin-bottom: 40px !important;
}

.u-my-minus-2 {
  margin-top: -40px !important;
  margin-bottom: -40px !important;
}

.u-py-2 {
  padding-top: 40px !important;
  padding-bottom: 40px !important;
}

.u-my-3 {
  margin-top: 60px !important;
  margin-bottom: 60px !important;
}

.u-my-minus-3 {
  margin-top: -60px !important;
  margin-bottom: -60px !important;
}

.u-py-3 {
  padding-top: 60px !important;
  padding-bottom: 60px !important;
}

.u-my-4 {
  margin-top: 80px !important;
  margin-bottom: 80px !important;
}

.u-my-minus-4 {
  margin-top: -80px !important;
  margin-bottom: -80px !important;
}

.u-py-4 {
  padding-top: 80px !important;
  padding-bottom: 80px !important;
}

.u-my-5 {
  margin-top: 100px !important;
  margin-bottom: 100px !important;
}

.u-my-minus-5 {
  margin-top: -100px !important;
  margin-bottom: -100px !important;
}

.u-py-5 {
  padding-top: 100px !important;
  padding-bottom: 100px !important;
}

.u-mx-0 {
  margin-left: 0px !important;
  margin-right: 0px !important;
}

.u-mx-minus-0 {
  margin-left: 0px !important;
  margin-right: 0px !important;
}

.u-px-0 {
  padding-left: 0px !important;
  padding-right: 0px !important;
}

.u-mx-1 {
  margin-left: 20px !important;
  margin-right: 20px !important;
}

.u-mx-minus-1 {
  margin-left: -20px !important;
  margin-right: -20px !important;
}

.u-px-1 {
  padding-left: 20px !important;
  padding-right: 20px !important;
}

.u-mx-2 {
  margin-left: 40px !important;
  margin-right: 40px !important;
}

.u-mx-minus-2 {
  margin-left: -40px !important;
  margin-right: -40px !important;
}

.u-px-2 {
  padding-left: 40px !important;
  padding-right: 40px !important;
}

.u-mx-3 {
  margin-left: 60px !important;
  margin-right: 60px !important;
}

.u-mx-minus-3 {
  margin-left: -60px !important;
  margin-right: -60px !important;
}

.u-px-3 {
  padding-left: 60px !important;
  padding-right: 60px !important;
}

.u-mx-4 {
  margin-left: 80px !important;
  margin-right: 80px !important;
}

.u-mx-minus-4 {
  margin-left: -80px !important;
  margin-right: -80px !important;
}

.u-px-4 {
  padding-left: 80px !important;
  padding-right: 80px !important;
}

.u-mx-5 {
  margin-left: 100px !important;
  margin-right: 100px !important;
}

.u-mx-minus-5 {
  margin-left: -100px !important;
  margin-right: -100px !important;
}

.u-px-5 {
  padding-left: 100px !important;
  padding-right: 100px !important;
}

@media screen and (min-width: 0) {
  .u-mr-xs-0 {
    margin-right: 0px !important;
  }

  .u-mr-xs-minus-0 {
    margin-right: 0px !important;
  }

  .u-pr-xs-0 {
    padding-right: 0px !important;
  }

  .u-ml-xs-0 {
    margin-left: 0px !important;
  }

  .u-ml-xs-minus-0 {
    margin-left: 0px !important;
  }

  .u-pl-xs-0 {
    padding-left: 0px !important;
  }

  .u-mt-xs-0 {
    margin-top: 0px !important;
  }

  .u-mt-xs-minus-0 {
    margin-top: 0px !important;
  }

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

  .u-mb-xs-0 {
    margin-bottom: 0px !important;
  }

  .u-mb-xs-minus-0 {
    margin-bottom: 0px !important;
  }

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

  .u-my-xs-0 {
    margin-top: 0px !important;
    margin-bottom: 0px !important;
  }

  .u-my-xs-minus-0 {
    margin-top: 0px !important;
    margin-bottom: 0px !important;
  }

  .u-py-xs-0 {
    padding-top: 0px !important;
    padding-bottom: 0px !important;
  }

  .u-mx-xs-0 {
    margin-right: 0px !important;
    margin-left: 0px !important;
  }

  .u-mx-xs-minus-0 {
    margin-right: 0px !important;
    margin-left: 0px !important;
  }

  .u-px-xs-0 {
    padding-right: 0px !important;
    padding-left: 0px !important;
  }

  .u-mr-xs-1 {
    margin-right: 20px !important;
  }

  .u-mr-xs-minus-1 {
    margin-right: -20px !important;
  }

  .u-pr-xs-1 {
    padding-right: 20px !important;
  }

  .u-ml-xs-1 {
    margin-left: 20px !important;
  }

  .u-ml-xs-minus-1 {
    margin-left: -20px !important;
  }

  .u-pl-xs-1 {
    padding-left: 20px !important;
  }

  .u-mt-xs-1 {
    margin-top: 20px !important;
  }

  .u-mt-xs-minus-1 {
    margin-top: -20px !important;
  }

  .u-pt-xs-1 {
    padding-top: 20px !important;
  }

  .u-mb-xs-1 {
    margin-bottom: 20px !important;
  }

  .u-mb-xs-minus-1 {
    margin-bottom: -20px !important;
  }

  .u-pb-xs-1 {
    padding-bottom: 20px !important;
  }

  .u-my-xs-1 {
    margin-top: 20px !important;
    margin-bottom: 20px !important;
  }

  .u-my-xs-minus-1 {
    margin-top: -20px !important;
    margin-bottom: -20px !important;
  }

  .u-py-xs-1 {
    padding-top: 20px !important;
    padding-bottom: 20px !important;
  }

  .u-mx-xs-1 {
    margin-right: 20px !important;
    margin-left: 20px !important;
  }

  .u-mx-xs-minus-1 {
    margin-right: 20px !important;
    margin-left: 20px !important;
  }

  .u-px-xs-1 {
    padding-right: 20px !important;
    padding-left: 20px !important;
  }

  .u-mr-xs-2 {
    margin-right: 40px !important;
  }

  .u-mr-xs-minus-2 {
    margin-right: -40px !important;
  }

  .u-pr-xs-2 {
    padding-right: 40px !important;
  }

  .u-ml-xs-2 {
    margin-left: 40px !important;
  }

  .u-ml-xs-minus-2 {
    margin-left: -40px !important;
  }

  .u-pl-xs-2 {
    padding-left: 40px !important;
  }

  .u-mt-xs-2 {
    margin-top: 40px !important;
  }

  .u-mt-xs-minus-2 {
    margin-top: -40px !important;
  }

  .u-pt-xs-2 {
    padding-top: 40px !important;
  }

  .u-mb-xs-2 {
    margin-bottom: 40px !important;
  }

  .u-mb-xs-minus-2 {
    margin-bottom: -40px !important;
  }

  .u-pb-xs-2 {
    padding-bottom: 40px !important;
  }

  .u-my-xs-2 {
    margin-top: 40px !important;
    margin-bottom: 40px !important;
  }

  .u-my-xs-minus-2 {
    margin-top: -40px !important;
    margin-bottom: -40px !important;
  }

  .u-py-xs-2 {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }

  .u-mx-xs-2 {
    margin-right: 40px !important;
    margin-left: 40px !important;
  }

  .u-mx-xs-minus-2 {
    margin-right: 40px !important;
    margin-left: 40px !important;
  }

  .u-px-xs-2 {
    padding-right: 40px !important;
    padding-left: 40px !important;
  }

  .u-mr-xs-3 {
    margin-right: 60px !important;
  }

  .u-mr-xs-minus-3 {
    margin-right: -60px !important;
  }

  .u-pr-xs-3 {
    padding-right: 60px !important;
  }

  .u-ml-xs-3 {
    margin-left: 60px !important;
  }

  .u-ml-xs-minus-3 {
    margin-left: -60px !important;
  }

  .u-pl-xs-3 {
    padding-left: 60px !important;
  }

  .u-mt-xs-3 {
    margin-top: 60px !important;
  }

  .u-mt-xs-minus-3 {
    margin-top: -60px !important;
  }

  .u-pt-xs-3 {
    padding-top: 60px !important;
  }

  .u-mb-xs-3 {
    margin-bottom: 60px !important;
  }

  .u-mb-xs-minus-3 {
    margin-bottom: -60px !important;
  }

  .u-pb-xs-3 {
    padding-bottom: 60px !important;
  }

  .u-my-xs-3 {
    margin-top: 60px !important;
    margin-bottom: 60px !important;
  }

  .u-my-xs-minus-3 {
    margin-top: -60px !important;
    margin-bottom: -60px !important;
  }

  .u-py-xs-3 {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
  }

  .u-mx-xs-3 {
    margin-right: 60px !important;
    margin-left: 60px !important;
  }

  .u-mx-xs-minus-3 {
    margin-right: 60px !important;
    margin-left: 60px !important;
  }

  .u-px-xs-3 {
    padding-right: 60px !important;
    padding-left: 60px !important;
  }

  .u-mr-xs-4 {
    margin-right: 80px !important;
  }

  .u-mr-xs-minus-4 {
    margin-right: -80px !important;
  }

  .u-pr-xs-4 {
    padding-right: 80px !important;
  }

  .u-ml-xs-4 {
    margin-left: 80px !important;
  }

  .u-ml-xs-minus-4 {
    margin-left: -80px !important;
  }

  .u-pl-xs-4 {
    padding-left: 80px !important;
  }

  .u-mt-xs-4 {
    margin-top: 80px !important;
  }

  .u-mt-xs-minus-4 {
    margin-top: -80px !important;
  }

  .u-pt-xs-4 {
    padding-top: 80px !important;
  }

  .u-mb-xs-4 {
    margin-bottom: 80px !important;
  }

  .u-mb-xs-minus-4 {
    margin-bottom: -80px !important;
  }

  .u-pb-xs-4 {
    padding-bottom: 80px !important;
  }

  .u-my-xs-4 {
    margin-top: 80px !important;
    margin-bottom: 80px !important;
  }

  .u-my-xs-minus-4 {
    margin-top: -80px !important;
    margin-bottom: -80px !important;
  }

  .u-py-xs-4 {
    padding-top: 80px !important;
    padding-bottom: 80px !important;
  }

  .u-mx-xs-4 {
    margin-right: 80px !important;
    margin-left: 80px !important;
  }

  .u-mx-xs-minus-4 {
    margin-right: 80px !important;
    margin-left: 80px !important;
  }

  .u-px-xs-4 {
    padding-right: 80px !important;
    padding-left: 80px !important;
  }

  .u-mr-xs-5 {
    margin-right: 100px !important;
  }

  .u-mr-xs-minus-5 {
    margin-right: -100px !important;
  }

  .u-pr-xs-5 {
    padding-right: 100px !important;
  }

  .u-ml-xs-5 {
    margin-left: 100px !important;
  }

  .u-ml-xs-minus-5 {
    margin-left: -100px !important;
  }

  .u-pl-xs-5 {
    padding-left: 100px !important;
  }

  .u-mt-xs-5 {
    margin-top: 100px !important;
  }

  .u-mt-xs-minus-5 {
    margin-top: -100px !important;
  }

  .u-pt-xs-5 {
    padding-top: 100px !important;
  }

  .u-mb-xs-5 {
    margin-bottom: 100px !important;
  }

  .u-mb-xs-minus-5 {
    margin-bottom: -100px !important;
  }

  .u-pb-xs-5 {
    padding-bottom: 100px !important;
  }

  .u-my-xs-5 {
    margin-top: 100px !important;
    margin-bottom: 100px !important;
  }

  .u-my-xs-minus-5 {
    margin-top: -100px !important;
    margin-bottom: -100px !important;
  }

  .u-py-xs-5 {
    padding-top: 100px !important;
    padding-bottom: 100px !important;
  }

  .u-mx-xs-5 {
    margin-right: 100px !important;
    margin-left: 100px !important;
  }

  .u-mx-xs-minus-5 {
    margin-right: 100px !important;
    margin-left: 100px !important;
  }

  .u-px-xs-5 {
    padding-right: 100px !important;
    padding-left: 100px !important;
  }
}
@media screen and (min-width: 0) {
  .u-mr-xs-auto {
    margin-right: auto !important;
  }

  .u-ml-xs-auto {
    margin-left: auto !important;
  }

  .u-mt-xs-auto {
    margin-top: auto !important;
  }

  .u-mb-xs-auto {
    margin-bottom: auto !important;
  }
}
@media screen and (min-width: 576px) {
  .u-mr-sm-0 {
    margin-right: 0px !important;
  }

  .u-mr-sm-minus-0 {
    margin-right: 0px !important;
  }

  .u-pr-sm-0 {
    padding-right: 0px !important;
  }

  .u-ml-sm-0 {
    margin-left: 0px !important;
  }

  .u-ml-sm-minus-0 {
    margin-left: 0px !important;
  }

  .u-pl-sm-0 {
    padding-left: 0px !important;
  }

  .u-mt-sm-0 {
    margin-top: 0px !important;
  }

  .u-mt-sm-minus-0 {
    margin-top: 0px !important;
  }

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

  .u-mb-sm-0 {
    margin-bottom: 0px !important;
  }

  .u-mb-sm-minus-0 {
    margin-bottom: 0px !important;
  }

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

  .u-my-sm-0 {
    margin-top: 0px !important;
    margin-bottom: 0px !important;
  }

  .u-my-sm-minus-0 {
    margin-top: 0px !important;
    margin-bottom: 0px !important;
  }

  .u-py-sm-0 {
    padding-top: 0px !important;
    padding-bottom: 0px !important;
  }

  .u-mx-sm-0 {
    margin-right: 0px !important;
    margin-left: 0px !important;
  }

  .u-mx-sm-minus-0 {
    margin-right: 0px !important;
    margin-left: 0px !important;
  }

  .u-px-sm-0 {
    padding-right: 0px !important;
    padding-left: 0px !important;
  }

  .u-mr-sm-1 {
    margin-right: 20px !important;
  }

  .u-mr-sm-minus-1 {
    margin-right: -20px !important;
  }

  .u-pr-sm-1 {
    padding-right: 20px !important;
  }

  .u-ml-sm-1 {
    margin-left: 20px !important;
  }

  .u-ml-sm-minus-1 {
    margin-left: -20px !important;
  }

  .u-pl-sm-1 {
    padding-left: 20px !important;
  }

  .u-mt-sm-1 {
    margin-top: 20px !important;
  }

  .u-mt-sm-minus-1 {
    margin-top: -20px !important;
  }

  .u-pt-sm-1 {
    padding-top: 20px !important;
  }

  .u-mb-sm-1 {
    margin-bottom: 20px !important;
  }

  .u-mb-sm-minus-1 {
    margin-bottom: -20px !important;
  }

  .u-pb-sm-1 {
    padding-bottom: 20px !important;
  }

  .u-my-sm-1 {
    margin-top: 20px !important;
    margin-bottom: 20px !important;
  }

  .u-my-sm-minus-1 {
    margin-top: -20px !important;
    margin-bottom: -20px !important;
  }

  .u-py-sm-1 {
    padding-top: 20px !important;
    padding-bottom: 20px !important;
  }

  .u-mx-sm-1 {
    margin-right: 20px !important;
    margin-left: 20px !important;
  }

  .u-mx-sm-minus-1 {
    margin-right: 20px !important;
    margin-left: 20px !important;
  }

  .u-px-sm-1 {
    padding-right: 20px !important;
    padding-left: 20px !important;
  }

  .u-mr-sm-2 {
    margin-right: 40px !important;
  }

  .u-mr-sm-minus-2 {
    margin-right: -40px !important;
  }

  .u-pr-sm-2 {
    padding-right: 40px !important;
  }

  .u-ml-sm-2 {
    margin-left: 40px !important;
  }

  .u-ml-sm-minus-2 {
    margin-left: -40px !important;
  }

  .u-pl-sm-2 {
    padding-left: 40px !important;
  }

  .u-mt-sm-2 {
    margin-top: 40px !important;
  }

  .u-mt-sm-minus-2 {
    margin-top: -40px !important;
  }

  .u-pt-sm-2 {
    padding-top: 40px !important;
  }

  .u-mb-sm-2 {
    margin-bottom: 40px !important;
  }

  .u-mb-sm-minus-2 {
    margin-bottom: -40px !important;
  }

  .u-pb-sm-2 {
    padding-bottom: 40px !important;
  }

  .u-my-sm-2 {
    margin-top: 40px !important;
    margin-bottom: 40px !important;
  }

  .u-my-sm-minus-2 {
    margin-top: -40px !important;
    margin-bottom: -40px !important;
  }

  .u-py-sm-2 {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }

  .u-mx-sm-2 {
    margin-right: 40px !important;
    margin-left: 40px !important;
  }

  .u-mx-sm-minus-2 {
    margin-right: 40px !important;
    margin-left: 40px !important;
  }

  .u-px-sm-2 {
    padding-right: 40px !important;
    padding-left: 40px !important;
  }

  .u-mr-sm-3 {
    margin-right: 60px !important;
  }

  .u-mr-sm-minus-3 {
    margin-right: -60px !important;
  }

  .u-pr-sm-3 {
    padding-right: 60px !important;
  }

  .u-ml-sm-3 {
    margin-left: 60px !important;
  }

  .u-ml-sm-minus-3 {
    margin-left: -60px !important;
  }

  .u-pl-sm-3 {
    padding-left: 60px !important;
  }

  .u-mt-sm-3 {
    margin-top: 60px !important;
  }

  .u-mt-sm-minus-3 {
    margin-top: -60px !important;
  }

  .u-pt-sm-3 {
    padding-top: 60px !important;
  }

  .u-mb-sm-3 {
    margin-bottom: 60px !important;
  }

  .u-mb-sm-minus-3 {
    margin-bottom: -60px !important;
  }

  .u-pb-sm-3 {
    padding-bottom: 60px !important;
  }

  .u-my-sm-3 {
    margin-top: 60px !important;
    margin-bottom: 60px !important;
  }

  .u-my-sm-minus-3 {
    margin-top: -60px !important;
    margin-bottom: -60px !important;
  }

  .u-py-sm-3 {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
  }

  .u-mx-sm-3 {
    margin-right: 60px !important;
    margin-left: 60px !important;
  }

  .u-mx-sm-minus-3 {
    margin-right: 60px !important;
    margin-left: 60px !important;
  }

  .u-px-sm-3 {
    padding-right: 60px !important;
    padding-left: 60px !important;
  }

  .u-mr-sm-4 {
    margin-right: 80px !important;
  }

  .u-mr-sm-minus-4 {
    margin-right: -80px !important;
  }

  .u-pr-sm-4 {
    padding-right: 80px !important;
  }

  .u-ml-sm-4 {
    margin-left: 80px !important;
  }

  .u-ml-sm-minus-4 {
    margin-left: -80px !important;
  }

  .u-pl-sm-4 {
    padding-left: 80px !important;
  }

  .u-mt-sm-4 {
    margin-top: 80px !important;
  }

  .u-mt-sm-minus-4 {
    margin-top: -80px !important;
  }

  .u-pt-sm-4 {
    padding-top: 80px !important;
  }

  .u-mb-sm-4 {
    margin-bottom: 80px !important;
  }

  .u-mb-sm-minus-4 {
    margin-bottom: -80px !important;
  }

  .u-pb-sm-4 {
    padding-bottom: 80px !important;
  }

  .u-my-sm-4 {
    margin-top: 80px !important;
    margin-bottom: 80px !important;
  }

  .u-my-sm-minus-4 {
    margin-top: -80px !important;
    margin-bottom: -80px !important;
  }

  .u-py-sm-4 {
    padding-top: 80px !important;
    padding-bottom: 80px !important;
  }

  .u-mx-sm-4 {
    margin-right: 80px !important;
    margin-left: 80px !important;
  }

  .u-mx-sm-minus-4 {
    margin-right: 80px !important;
    margin-left: 80px !important;
  }

  .u-px-sm-4 {
    padding-right: 80px !important;
    padding-left: 80px !important;
  }

  .u-mr-sm-5 {
    margin-right: 100px !important;
  }

  .u-mr-sm-minus-5 {
    margin-right: -100px !important;
  }

  .u-pr-sm-5 {
    padding-right: 100px !important;
  }

  .u-ml-sm-5 {
    margin-left: 100px !important;
  }

  .u-ml-sm-minus-5 {
    margin-left: -100px !important;
  }

  .u-pl-sm-5 {
    padding-left: 100px !important;
  }

  .u-mt-sm-5 {
    margin-top: 100px !important;
  }

  .u-mt-sm-minus-5 {
    margin-top: -100px !important;
  }

  .u-pt-sm-5 {
    padding-top: 100px !important;
  }

  .u-mb-sm-5 {
    margin-bottom: 100px !important;
  }

  .u-mb-sm-minus-5 {
    margin-bottom: -100px !important;
  }

  .u-pb-sm-5 {
    padding-bottom: 100px !important;
  }

  .u-my-sm-5 {
    margin-top: 100px !important;
    margin-bottom: 100px !important;
  }

  .u-my-sm-minus-5 {
    margin-top: -100px !important;
    margin-bottom: -100px !important;
  }

  .u-py-sm-5 {
    padding-top: 100px !important;
    padding-bottom: 100px !important;
  }

  .u-mx-sm-5 {
    margin-right: 100px !important;
    margin-left: 100px !important;
  }

  .u-mx-sm-minus-5 {
    margin-right: 100px !important;
    margin-left: 100px !important;
  }

  .u-px-sm-5 {
    padding-right: 100px !important;
    padding-left: 100px !important;
  }
}
@media screen and (min-width: 576px) {
  .u-mr-sm-auto {
    margin-right: auto !important;
  }

  .u-ml-sm-auto {
    margin-left: auto !important;
  }

  .u-mt-sm-auto {
    margin-top: auto !important;
  }

  .u-mb-sm-auto {
    margin-bottom: auto !important;
  }
}
@media screen and (min-width: 768px) {
  .u-mr-md-0 {
    margin-right: 0px !important;
  }

  .u-mr-md-minus-0 {
    margin-right: 0px !important;
  }

  .u-pr-md-0 {
    padding-right: 0px !important;
  }

  .u-ml-md-0 {
    margin-left: 0px !important;
  }

  .u-ml-md-minus-0 {
    margin-left: 0px !important;
  }

  .u-pl-md-0 {
    padding-left: 0px !important;
  }

  .u-mt-md-0 {
    margin-top: 0px !important;
  }

  .u-mt-md-minus-0 {
    margin-top: 0px !important;
  }

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

  .u-mb-md-0 {
    margin-bottom: 0px !important;
  }

  .u-mb-md-minus-0 {
    margin-bottom: 0px !important;
  }

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

  .u-my-md-0 {
    margin-top: 0px !important;
    margin-bottom: 0px !important;
  }

  .u-my-md-minus-0 {
    margin-top: 0px !important;
    margin-bottom: 0px !important;
  }

  .u-py-md-0 {
    padding-top: 0px !important;
    padding-bottom: 0px !important;
  }

  .u-mx-md-0 {
    margin-right: 0px !important;
    margin-left: 0px !important;
  }

  .u-mx-md-minus-0 {
    margin-right: 0px !important;
    margin-left: 0px !important;
  }

  .u-px-md-0 {
    padding-right: 0px !important;
    padding-left: 0px !important;
  }

  .u-mr-md-1 {
    margin-right: 20px !important;
  }

  .u-mr-md-minus-1 {
    margin-right: -20px !important;
  }

  .u-pr-md-1 {
    padding-right: 20px !important;
  }

  .u-ml-md-1 {
    margin-left: 20px !important;
  }

  .u-ml-md-minus-1 {
    margin-left: -20px !important;
  }

  .u-pl-md-1 {
    padding-left: 20px !important;
  }

  .u-mt-md-1 {
    margin-top: 20px !important;
  }

  .u-mt-md-minus-1 {
    margin-top: -20px !important;
  }

  .u-pt-md-1 {
    padding-top: 20px !important;
  }

  .u-mb-md-1 {
    margin-bottom: 20px !important;
  }

  .u-mb-md-minus-1 {
    margin-bottom: -20px !important;
  }

  .u-pb-md-1 {
    padding-bottom: 20px !important;
  }

  .u-my-md-1 {
    margin-top: 20px !important;
    margin-bottom: 20px !important;
  }

  .u-my-md-minus-1 {
    margin-top: -20px !important;
    margin-bottom: -20px !important;
  }

  .u-py-md-1 {
    padding-top: 20px !important;
    padding-bottom: 20px !important;
  }

  .u-mx-md-1 {
    margin-right: 20px !important;
    margin-left: 20px !important;
  }

  .u-mx-md-minus-1 {
    margin-right: 20px !important;
    margin-left: 20px !important;
  }

  .u-px-md-1 {
    padding-right: 20px !important;
    padding-left: 20px !important;
  }

  .u-mr-md-2 {
    margin-right: 40px !important;
  }

  .u-mr-md-minus-2 {
    margin-right: -40px !important;
  }

  .u-pr-md-2 {
    padding-right: 40px !important;
  }

  .u-ml-md-2 {
    margin-left: 40px !important;
  }

  .u-ml-md-minus-2 {
    margin-left: -40px !important;
  }

  .u-pl-md-2 {
    padding-left: 40px !important;
  }

  .u-mt-md-2 {
    margin-top: 40px !important;
  }

  .u-mt-md-minus-2 {
    margin-top: -40px !important;
  }

  .u-pt-md-2 {
    padding-top: 40px !important;
  }

  .u-mb-md-2 {
    margin-bottom: 40px !important;
  }

  .u-mb-md-minus-2 {
    margin-bottom: -40px !important;
  }

  .u-pb-md-2 {
    padding-bottom: 40px !important;
  }

  .u-my-md-2 {
    margin-top: 40px !important;
    margin-bottom: 40px !important;
  }

  .u-my-md-minus-2 {
    margin-top: -40px !important;
    margin-bottom: -40px !important;
  }

  .u-py-md-2 {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }

  .u-mx-md-2 {
    margin-right: 40px !important;
    margin-left: 40px !important;
  }

  .u-mx-md-minus-2 {
    margin-right: 40px !important;
    margin-left: 40px !important;
  }

  .u-px-md-2 {
    padding-right: 40px !important;
    padding-left: 40px !important;
  }

  .u-mr-md-3 {
    margin-right: 60px !important;
  }

  .u-mr-md-minus-3 {
    margin-right: -60px !important;
  }

  .u-pr-md-3 {
    padding-right: 60px !important;
  }

  .u-ml-md-3 {
    margin-left: 60px !important;
  }

  .u-ml-md-minus-3 {
    margin-left: -60px !important;
  }

  .u-pl-md-3 {
    padding-left: 60px !important;
  }

  .u-mt-md-3 {
    margin-top: 60px !important;
  }

  .u-mt-md-minus-3 {
    margin-top: -60px !important;
  }

  .u-pt-md-3 {
    padding-top: 60px !important;
  }

  .u-mb-md-3 {
    margin-bottom: 60px !important;
  }

  .u-mb-md-minus-3 {
    margin-bottom: -60px !important;
  }

  .u-pb-md-3 {
    padding-bottom: 60px !important;
  }

  .u-my-md-3 {
    margin-top: 60px !important;
    margin-bottom: 60px !important;
  }

  .u-my-md-minus-3 {
    margin-top: -60px !important;
    margin-bottom: -60px !important;
  }

  .u-py-md-3 {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
  }

  .u-mx-md-3 {
    margin-right: 60px !important;
    margin-left: 60px !important;
  }

  .u-mx-md-minus-3 {
    margin-right: 60px !important;
    margin-left: 60px !important;
  }

  .u-px-md-3 {
    padding-right: 60px !important;
    padding-left: 60px !important;
  }

  .u-mr-md-4 {
    margin-right: 80px !important;
  }

  .u-mr-md-minus-4 {
    margin-right: -80px !important;
  }

  .u-pr-md-4 {
    padding-right: 80px !important;
  }

  .u-ml-md-4 {
    margin-left: 80px !important;
  }

  .u-ml-md-minus-4 {
    margin-left: -80px !important;
  }

  .u-pl-md-4 {
    padding-left: 80px !important;
  }

  .u-mt-md-4 {
    margin-top: 80px !important;
  }

  .u-mt-md-minus-4 {
    margin-top: -80px !important;
  }

  .u-pt-md-4 {
    padding-top: 80px !important;
  }

  .u-mb-md-4 {
    margin-bottom: 80px !important;
  }

  .u-mb-md-minus-4 {
    margin-bottom: -80px !important;
  }

  .u-pb-md-4 {
    padding-bottom: 80px !important;
  }

  .u-my-md-4 {
    margin-top: 80px !important;
    margin-bottom: 80px !important;
  }

  .u-my-md-minus-4 {
    margin-top: -80px !important;
    margin-bottom: -80px !important;
  }

  .u-py-md-4 {
    padding-top: 80px !important;
    padding-bottom: 80px !important;
  }

  .u-mx-md-4 {
    margin-right: 80px !important;
    margin-left: 80px !important;
  }

  .u-mx-md-minus-4 {
    margin-right: 80px !important;
    margin-left: 80px !important;
  }

  .u-px-md-4 {
    padding-right: 80px !important;
    padding-left: 80px !important;
  }

  .u-mr-md-5 {
    margin-right: 100px !important;
  }

  .u-mr-md-minus-5 {
    margin-right: -100px !important;
  }

  .u-pr-md-5 {
    padding-right: 100px !important;
  }

  .u-ml-md-5 {
    margin-left: 100px !important;
  }

  .u-ml-md-minus-5 {
    margin-left: -100px !important;
  }

  .u-pl-md-5 {
    padding-left: 100px !important;
  }

  .u-mt-md-5 {
    margin-top: 100px !important;
  }

  .u-mt-md-minus-5 {
    margin-top: -100px !important;
  }

  .u-pt-md-5 {
    padding-top: 100px !important;
  }

  .u-mb-md-5 {
    margin-bottom: 100px !important;
  }

  .u-mb-md-minus-5 {
    margin-bottom: -100px !important;
  }

  .u-pb-md-5 {
    padding-bottom: 100px !important;
  }

  .u-my-md-5 {
    margin-top: 100px !important;
    margin-bottom: 100px !important;
  }

  .u-my-md-minus-5 {
    margin-top: -100px !important;
    margin-bottom: -100px !important;
  }

  .u-py-md-5 {
    padding-top: 100px !important;
    padding-bottom: 100px !important;
  }

  .u-mx-md-5 {
    margin-right: 100px !important;
    margin-left: 100px !important;
  }

  .u-mx-md-minus-5 {
    margin-right: 100px !important;
    margin-left: 100px !important;
  }

  .u-px-md-5 {
    padding-right: 100px !important;
    padding-left: 100px !important;
  }
}
@media screen and (min-width: 768px) {
  .u-mr-md-auto {
    margin-right: auto !important;
  }

  .u-ml-md-auto {
    margin-left: auto !important;
  }

  .u-mt-md-auto {
    margin-top: auto !important;
  }

  .u-mb-md-auto {
    margin-bottom: auto !important;
  }
}
@media screen and (min-width: 992px) {
  .u-mr-lg-0 {
    margin-right: 0px !important;
  }

  .u-mr-lg-minus-0 {
    margin-right: 0px !important;
  }

  .u-pr-lg-0 {
    padding-right: 0px !important;
  }

  .u-ml-lg-0 {
    margin-left: 0px !important;
  }

  .u-ml-lg-minus-0 {
    margin-left: 0px !important;
  }

  .u-pl-lg-0 {
    padding-left: 0px !important;
  }

  .u-mt-lg-0 {
    margin-top: 0px !important;
  }

  .u-mt-lg-minus-0 {
    margin-top: 0px !important;
  }

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

  .u-mb-lg-0 {
    margin-bottom: 0px !important;
  }

  .u-mb-lg-minus-0 {
    margin-bottom: 0px !important;
  }

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

  .u-my-lg-0 {
    margin-top: 0px !important;
    margin-bottom: 0px !important;
  }

  .u-my-lg-minus-0 {
    margin-top: 0px !important;
    margin-bottom: 0px !important;
  }

  .u-py-lg-0 {
    padding-top: 0px !important;
    padding-bottom: 0px !important;
  }

  .u-mx-lg-0 {
    margin-right: 0px !important;
    margin-left: 0px !important;
  }

  .u-mx-lg-minus-0 {
    margin-right: 0px !important;
    margin-left: 0px !important;
  }

  .u-px-lg-0 {
    padding-right: 0px !important;
    padding-left: 0px !important;
  }

  .u-mr-lg-1 {
    margin-right: 20px !important;
  }

  .u-mr-lg-minus-1 {
    margin-right: -20px !important;
  }

  .u-pr-lg-1 {
    padding-right: 20px !important;
  }

  .u-ml-lg-1 {
    margin-left: 20px !important;
  }

  .u-ml-lg-minus-1 {
    margin-left: -20px !important;
  }

  .u-pl-lg-1 {
    padding-left: 20px !important;
  }

  .u-mt-lg-1 {
    margin-top: 20px !important;
  }

  .u-mt-lg-minus-1 {
    margin-top: -20px !important;
  }

  .u-pt-lg-1 {
    padding-top: 20px !important;
  }

  .u-mb-lg-1 {
    margin-bottom: 20px !important;
  }

  .u-mb-lg-minus-1 {
    margin-bottom: -20px !important;
  }

  .u-pb-lg-1 {
    padding-bottom: 20px !important;
  }

  .u-my-lg-1 {
    margin-top: 20px !important;
    margin-bottom: 20px !important;
  }

  .u-my-lg-minus-1 {
    margin-top: -20px !important;
    margin-bottom: -20px !important;
  }

  .u-py-lg-1 {
    padding-top: 20px !important;
    padding-bottom: 20px !important;
  }

  .u-mx-lg-1 {
    margin-right: 20px !important;
    margin-left: 20px !important;
  }

  .u-mx-lg-minus-1 {
    margin-right: 20px !important;
    margin-left: 20px !important;
  }

  .u-px-lg-1 {
    padding-right: 20px !important;
    padding-left: 20px !important;
  }

  .u-mr-lg-2 {
    margin-right: 40px !important;
  }

  .u-mr-lg-minus-2 {
    margin-right: -40px !important;
  }

  .u-pr-lg-2 {
    padding-right: 40px !important;
  }

  .u-ml-lg-2 {
    margin-left: 40px !important;
  }

  .u-ml-lg-minus-2 {
    margin-left: -40px !important;
  }

  .u-pl-lg-2 {
    padding-left: 40px !important;
  }

  .u-mt-lg-2 {
    margin-top: 40px !important;
  }

  .u-mt-lg-minus-2 {
    margin-top: -40px !important;
  }

  .u-pt-lg-2 {
    padding-top: 40px !important;
  }

  .u-mb-lg-2 {
    margin-bottom: 40px !important;
  }

  .u-mb-lg-minus-2 {
    margin-bottom: -40px !important;
  }

  .u-pb-lg-2 {
    padding-bottom: 40px !important;
  }

  .u-my-lg-2 {
    margin-top: 40px !important;
    margin-bottom: 40px !important;
  }

  .u-my-lg-minus-2 {
    margin-top: -40px !important;
    margin-bottom: -40px !important;
  }

  .u-py-lg-2 {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }

  .u-mx-lg-2 {
    margin-right: 40px !important;
    margin-left: 40px !important;
  }

  .u-mx-lg-minus-2 {
    margin-right: 40px !important;
    margin-left: 40px !important;
  }

  .u-px-lg-2 {
    padding-right: 40px !important;
    padding-left: 40px !important;
  }

  .u-mr-lg-3 {
    margin-right: 60px !important;
  }

  .u-mr-lg-minus-3 {
    margin-right: -60px !important;
  }

  .u-pr-lg-3 {
    padding-right: 60px !important;
  }

  .u-ml-lg-3 {
    margin-left: 60px !important;
  }

  .u-ml-lg-minus-3 {
    margin-left: -60px !important;
  }

  .u-pl-lg-3 {
    padding-left: 60px !important;
  }

  .u-mt-lg-3 {
    margin-top: 60px !important;
  }

  .u-mt-lg-minus-3 {
    margin-top: -60px !important;
  }

  .u-pt-lg-3 {
    padding-top: 60px !important;
  }

  .u-mb-lg-3 {
    margin-bottom: 60px !important;
  }

  .u-mb-lg-minus-3 {
    margin-bottom: -60px !important;
  }

  .u-pb-lg-3 {
    padding-bottom: 60px !important;
  }

  .u-my-lg-3 {
    margin-top: 60px !important;
    margin-bottom: 60px !important;
  }

  .u-my-lg-minus-3 {
    margin-top: -60px !important;
    margin-bottom: -60px !important;
  }

  .u-py-lg-3 {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
  }

  .u-mx-lg-3 {
    margin-right: 60px !important;
    margin-left: 60px !important;
  }

  .u-mx-lg-minus-3 {
    margin-right: 60px !important;
    margin-left: 60px !important;
  }

  .u-px-lg-3 {
    padding-right: 60px !important;
    padding-left: 60px !important;
  }

  .u-mr-lg-4 {
    margin-right: 80px !important;
  }

  .u-mr-lg-minus-4 {
    margin-right: -80px !important;
  }

  .u-pr-lg-4 {
    padding-right: 80px !important;
  }

  .u-ml-lg-4 {
    margin-left: 80px !important;
  }

  .u-ml-lg-minus-4 {
    margin-left: -80px !important;
  }

  .u-pl-lg-4 {
    padding-left: 80px !important;
  }

  .u-mt-lg-4 {
    margin-top: 80px !important;
  }

  .u-mt-lg-minus-4 {
    margin-top: -80px !important;
  }

  .u-pt-lg-4 {
    padding-top: 80px !important;
  }

  .u-mb-lg-4 {
    margin-bottom: 80px !important;
  }

  .u-mb-lg-minus-4 {
    margin-bottom: -80px !important;
  }

  .u-pb-lg-4 {
    padding-bottom: 80px !important;
  }

  .u-my-lg-4 {
    margin-top: 80px !important;
    margin-bottom: 80px !important;
  }

  .u-my-lg-minus-4 {
    margin-top: -80px !important;
    margin-bottom: -80px !important;
  }

  .u-py-lg-4 {
    padding-top: 80px !important;
    padding-bottom: 80px !important;
  }

  .u-mx-lg-4 {
    margin-right: 80px !important;
    margin-left: 80px !important;
  }

  .u-mx-lg-minus-4 {
    margin-right: 80px !important;
    margin-left: 80px !important;
  }

  .u-px-lg-4 {
    padding-right: 80px !important;
    padding-left: 80px !important;
  }

  .u-mr-lg-5 {
    margin-right: 100px !important;
  }

  .u-mr-lg-minus-5 {
    margin-right: -100px !important;
  }

  .u-pr-lg-5 {
    padding-right: 100px !important;
  }

  .u-ml-lg-5 {
    margin-left: 100px !important;
  }

  .u-ml-lg-minus-5 {
    margin-left: -100px !important;
  }

  .u-pl-lg-5 {
    padding-left: 100px !important;
  }

  .u-mt-lg-5 {
    margin-top: 100px !important;
  }

  .u-mt-lg-minus-5 {
    margin-top: -100px !important;
  }

  .u-pt-lg-5 {
    padding-top: 100px !important;
  }

  .u-mb-lg-5 {
    margin-bottom: 100px !important;
  }

  .u-mb-lg-minus-5 {
    margin-bottom: -100px !important;
  }

  .u-pb-lg-5 {
    padding-bottom: 100px !important;
  }

  .u-my-lg-5 {
    margin-top: 100px !important;
    margin-bottom: 100px !important;
  }

  .u-my-lg-minus-5 {
    margin-top: -100px !important;
    margin-bottom: -100px !important;
  }

  .u-py-lg-5 {
    padding-top: 100px !important;
    padding-bottom: 100px !important;
  }

  .u-mx-lg-5 {
    margin-right: 100px !important;
    margin-left: 100px !important;
  }

  .u-mx-lg-minus-5 {
    margin-right: 100px !important;
    margin-left: 100px !important;
  }

  .u-px-lg-5 {
    padding-right: 100px !important;
    padding-left: 100px !important;
  }
}
@media screen and (min-width: 992px) {
  .u-mr-lg-auto {
    margin-right: auto !important;
  }

  .u-ml-lg-auto {
    margin-left: auto !important;
  }

  .u-mt-lg-auto {
    margin-top: auto !important;
  }

  .u-mb-lg-auto {
    margin-bottom: auto !important;
  }
}
.u-text-underline {
  text-decoration: underline !important;
}
.u-text-center {
  text-align: center !important;
}
.u-text-left {
  text-align: left !important;
}
.u-text-right {
  text-align: right !important;
}
@media screen and (min-width: 0) {
  .u-text-xs-center {
    text-align: center !important;
  }
  .u-text-xs-left {
    text-align: left !important;
  }
  .u-text-xs-right {
    text-align: right !important;
  }
}
@media screen and (min-width: 576px) {
  .u-text-sm-center {
    text-align: center !important;
  }
  .u-text-sm-left {
    text-align: left !important;
  }
  .u-text-sm-right {
    text-align: right !important;
  }
}
@media screen and (min-width: 768px) {
  .u-text-md-center {
    text-align: center !important;
  }
  .u-text-md-left {
    text-align: left !important;
  }
  .u-text-md-right {
    text-align: right !important;
  }
}
@media screen and (min-width: 992px) {
  .u-text-lg-center {
    text-align: center !important;
  }
  .u-text-lg-left {
    text-align: left !important;
  }
  .u-text-lg-right {
    text-align: right !important;
  }
}
.u-text-muted {
  color: #666;
}

.u-d-inline {
  display: inline !important;
}
.u-d-inline-block {
  display: inline-block !important;
}
.u-d-block {
  display: block !important;
}
.u-d-inline-flex {
  display: -webkit-inline-box !important;
  display: -ms-inline-flexbox !important;
  display: inline-flex !important;
}
.u-d-flex {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
}
.u-d-none {
  display: none !important;
}
@media screen and (min-width: 0) {
  .u-d-xs-inline {
    display: inline !important;
  }
  .u-d-xs-inline-block {
    display: inline-block !important;
  }
  .u-d-xs-block {
    display: block !important;
  }
  .u-d-xs-inline-flex {
    display: -webkit-inline-box !important;
    display: -ms-inline-flexbox !important;
    display: inline-flex !important;
  }
  .u-d-xs-flex {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }
  .u-d-xs-none {
    display: none !important;
  }
}
@media screen and (min-width: 576px) {
  .u-d-sm-inline {
    display: inline !important;
  }
  .u-d-sm-inline-block {
    display: inline-block !important;
  }
  .u-d-sm-block {
    display: block !important;
  }
  .u-d-sm-inline-flex {
    display: -webkit-inline-box !important;
    display: -ms-inline-flexbox !important;
    display: inline-flex !important;
  }
  .u-d-sm-flex {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }
  .u-d-sm-none {
    display: none !important;
  }
}
@media screen and (min-width: 768px) {
  .u-d-md-inline {
    display: inline !important;
  }
  .u-d-md-inline-block {
    display: inline-block !important;
  }
  .u-d-md-block {
    display: block !important;
  }
  .u-d-md-inline-flex {
    display: -webkit-inline-box !important;
    display: -ms-inline-flexbox !important;
    display: inline-flex !important;
  }
  .u-d-md-flex {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }
  .u-d-md-none {
    display: none !important;
  }
}
@media screen and (min-width: 992px) {
  .u-d-lg-inline {
    display: inline !important;
  }
  .u-d-lg-inline-block {
    display: inline-block !important;
  }
  .u-d-lg-block {
    display: block !important;
  }
  .u-d-lg-inline-flex {
    display: -webkit-inline-box !important;
    display: -ms-inline-flexbox !important;
    display: inline-flex !important;
  }
  .u-d-lg-flex {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }
  .u-d-lg-none {
    display: none !important;
  }
}

@media screen and (max-width: 991px) {
  .u-is-pc {
    display: none;
  }
}
.u-is-sp {
  display: none;
}
@media screen and (max-width: 991px) {
  .u-is-sp {
    display: block;
  }
}
.u-is-sm {
  display: none;
}
@media screen and (max-width: 767px) {
  .u-is-sm {
    display: block;
  }
}
.u-is-xs {
  display: none;
}
@media screen and (max-width: 575px) {
  .u-is-xs {
    display: block;
  }
}
@media screen and (max-width: 767px) {
  .u-is-ov-sm {
    display: none;
  }
}

.u-flex-grow-0 {
  -webkit-box-flex: 0;
  -ms-flex-positive: 0;
  flex-grow: 0;
}
.u-flex-grow-1 {
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
}
.u-flex-grow-2 {
  -webkit-box-flex: 2;
  -ms-flex-positive: 2;
  flex-grow: 2;
}

.u-align-items-center {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media screen and (min-width: 0) {
  .u-align-items-xs-center {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
@media screen and (min-width: 576px) {
  .u-align-items-sm-center {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
@media screen and (min-width: 768px) {
  .u-align-items-md-center {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
@media screen and (min-width: 992px) {
  .u-align-items-lg-center {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.u-align-items-flex-start {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}
@media screen and (min-width: 0) {
  .u-align-items-xs-flex-start {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }
}
@media screen and (min-width: 576px) {
  .u-align-items-sm-flex-start {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }
}
@media screen and (min-width: 768px) {
  .u-align-items-md-flex-start {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }
}
@media screen and (min-width: 992px) {
  .u-align-items-lg-flex-start {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }
}
.u-align-items-flex-end {
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}
@media screen and (min-width: 0) {
  .u-align-items-xs-flex-end {
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
  }
}
@media screen and (min-width: 576px) {
  .u-align-items-sm-flex-end {
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
  }
}
@media screen and (min-width: 768px) {
  .u-align-items-md-flex-end {
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
  }
}
@media screen and (min-width: 992px) {
  .u-align-items-lg-flex-end {
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
  }
}

.u-justify-content-start {
  -webkit-box-pack: start !important;
  -ms-flex-pack: start !important;
  justify-content: start !important;
}
.u-justify-content-center {
  -webkit-box-pack: center !important;
  -ms-flex-pack: center !important;
  justify-content: center !important;
}
.u-justify-content-end {
  -webkit-box-pack: end !important;
  -ms-flex-pack: end !important;
  justify-content: end !important;
}
@media screen and (min-width: 0) {
  .u-justify-content-xs-start {
    -webkit-box-pack: start !important;
    -ms-flex-pack: start !important;
    justify-content: start !important;
  }
  .u-justify-content-xs-center {
    -webkit-box-pack: center !important;
    -ms-flex-pack: center !important;
    justify-content: center !important;
  }
  .u-justify-content-xs-end {
    -webkit-box-pack: end !important;
    -ms-flex-pack: end !important;
    justify-content: end !important;
  }
}
@media screen and (min-width: 576px) {
  .u-justify-content-sm-start {
    -webkit-box-pack: start !important;
    -ms-flex-pack: start !important;
    justify-content: start !important;
  }
  .u-justify-content-sm-center {
    -webkit-box-pack: center !important;
    -ms-flex-pack: center !important;
    justify-content: center !important;
  }
  .u-justify-content-sm-end {
    -webkit-box-pack: end !important;
    -ms-flex-pack: end !important;
    justify-content: end !important;
  }
}
@media screen and (min-width: 768px) {
  .u-justify-content-md-start {
    -webkit-box-pack: start !important;
    -ms-flex-pack: start !important;
    justify-content: start !important;
  }
  .u-justify-content-md-center {
    -webkit-box-pack: center !important;
    -ms-flex-pack: center !important;
    justify-content: center !important;
  }
  .u-justify-content-md-end {
    -webkit-box-pack: end !important;
    -ms-flex-pack: end !important;
    justify-content: end !important;
  }
}
@media screen and (min-width: 992px) {
  .u-justify-content-lg-start {
    -webkit-box-pack: start !important;
    -ms-flex-pack: start !important;
    justify-content: start !important;
  }
  .u-justify-content-lg-center {
    -webkit-box-pack: center !important;
    -ms-flex-pack: center !important;
    justify-content: center !important;
  }
  .u-justify-content-lg-end {
    -webkit-box-pack: end !important;
    -ms-flex-pack: end !important;
    justify-content: end !important;
  }
}

.u-d-flex--row {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
}
.u-d-flex--column {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}
.u-d-flex--row-reverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}
.u-d-flex--column-reverse {
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
}
@media screen and (min-width: 0) {
  .u-d-flex--xs-row {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }
}
@media screen and (min-width: 0) {
  .u-d-flex--xs-column {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
@media screen and (min-width: 0) {
  .u-d-flex--xs-row-reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
}
@media screen and (min-width: 0) {
  .u-d-flex--xs-column-reverse {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
}
@media screen and (min-width: 576px) {
  .u-d-flex--sm-row {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }
}
@media screen and (min-width: 576px) {
  .u-d-flex--sm-column {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
@media screen and (min-width: 576px) {
  .u-d-flex--sm-row-reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
}
@media screen and (min-width: 576px) {
  .u-d-flex--sm-column-reverse {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
}
@media screen and (min-width: 768px) {
  .u-d-flex--md-row {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }
}
@media screen and (min-width: 768px) {
  .u-d-flex--md-column {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
@media screen and (min-width: 768px) {
  .u-d-flex--md-row-reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
}
@media screen and (min-width: 768px) {
  .u-d-flex--md-column-reverse {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
}
@media screen and (min-width: 992px) {
  .u-d-flex--lg-row {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }
}
@media screen and (min-width: 992px) {
  .u-d-flex--lg-column {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
@media screen and (min-width: 992px) {
  .u-d-flex--lg-row-reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
}
@media screen and (min-width: 992px) {
  .u-d-flex--lg-column-reverse {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
}
.u-d-flex--center {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
@media screen and (min-width: 0) {
  .u-d-flex--xs-center {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}
@media screen and (min-width: 576px) {
  .u-d-flex--sm-center {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}
@media screen and (min-width: 768px) {
  .u-d-flex--md-center {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}
@media screen and (min-width: 992px) {
  .u-d-flex--lg-center {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}
.u-d-flex--flex-start {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}
@media screen and (min-width: 0) {
  .u-d-flex--xs-flex-start {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}
@media screen and (min-width: 576px) {
  .u-d-flex--sm-flex-start {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}
@media screen and (min-width: 768px) {
  .u-d-flex--md-flex-start {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}
@media screen and (min-width: 992px) {
  .u-d-flex--lg-flex-start {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}
.u-d-flex--flex-end {
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}
@media screen and (min-width: 0) {
  .u-d-flex--xs-flex-end {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }
}
@media screen and (min-width: 576px) {
  .u-d-flex--sm-flex-end {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }
}
@media screen and (min-width: 768px) {
  .u-d-flex--md-flex-end {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }
}
@media screen and (min-width: 992px) {
  .u-d-flex--lg-flex-end {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }
}

.u-lineheight-10 {
  line-height: 1;
}
.u-lineheight-11 {
  line-height: 1.1;
}
.u-lineheight-12 {
  line-height: 1.2;
}
.u-lineheight-13 {
  line-height: 1.3;
}
.u-lineheight-14 {
  line-height: 1.4;
}
.u-lineheight-15 {
  line-height: 1.5;
}
.u-lineheight-16 {
  line-height: 1.6;
}
.u-lineheight-17 {
  line-height: 1.7;
}
.u-lineheight-18 {
  line-height: 1.8;
}
.u-lineheight-19 {
  line-height: 1.9;
}
.u-lineheight-20 {
  line-height: 2;
}
.u-lineheight-21 {
  line-height: 2.1;
}
.u-lineheight-22 {
  line-height: 2.2;
}
.u-lineheight-23 {
  line-height: 2.3;
}
.u-lineheight-24 {
  line-height: 2.4;
}
.u-lineheight-25 {
  line-height: 2.5;
}
.u-lineheight-26 {
  line-height: 2.6;
}
.u-lineheight-27 {
  line-height: 2.7;
}
.u-lineheight-28 {
  line-height: 2.8;
}
.u-lineheight-29 {
  line-height: 2.9;
}
.u-lineheight-30 {
  line-height: 3;
}

.u-list-asterisk > li {
  list-style-type: none;
  position: relative;
}
.u-list-asterisk > li::before {
  margin-left: -30px;
  content: "※";
  padding-right: 16px;
}
.u-list-none {
  padding-left: 0 !important;
  list-style-type: none !important;
}

.u-opacity-100 {
  opacity: 1;
}
.u-opacity-90 {
  opacity: 0.9;
}
.u-opacity-80 {
  opacity: 0.8;
}
.u-opacity-70 {
  opacity: 0.7;
}
.u-opacity-60 {
  opacity: 0.6;
}
.u-opacity-50 {
  opacity: 0.5;
}
.u-opacity-40 {
  opacity: 0.4;
}
.u-opacity-30 {
  opacity: 0.3;
}
.u-opacity-20 {
  opacity: 0.2;
}
.u-opacity-10 {
  opacity: 0.1;
}
.u-opacity-0 {
  opacity: 0;
}

.u-border {
  border: 1px solid #222;
}
.u-border--right {
  border: none;
  border-right-style: solid;
  border-width: 1px;
  border-color: #CCCCCC;
}
.u-border--left {
  border: none;
  border-left-style: solid;
  border-width: 1px;
  border-color: #CCCCCC;
}
.u-border--top {
  border: none;
  border-top-style: solid;
  border-width: 1px;
  border-color: #CCCCCC;
}
.u-border--bottom {
  border: none;
  border-bottom-style: solid;
  border-width: 1px;
  border-color: #CCCCCC;
}
.u-border--1px {
  border-width: 1px !important;
}
.u-border--2px {
  border-width: 2px !important;
}
.u-border--3px {
  border-width: 3px !important;
}
.u-border--primary {
  border-color: #EF3340;
}
.u-border-radius {
  border-radius: 4px;
}

.wp-caption-text {
  margin-top: 10px;
  color: #666;
  font-size: 12px;
}

.aligncenter {
  display: block;
  margin: 0 auto;
}
.aligncenter.wp-caption {
  text-align: center;
}

.alignright {
  float: right;
}

.alignleft {
  float: left;
}

.mktoForm {
  width: 100% !important;
}
.mktoForm .mktoOffset {
  display: none;
}
.mktoForm .mktoFormRow {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .mktoForm .mktoFormRow {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.mktoForm .mktoFormCol {
  width: 100%;
  margin-bottom: 20px !important;
}
.mktoForm .mktoFormCol + .mktoFormCol {
  margin-left: 30px;
}
@media screen and (max-width: 767px) {
  .mktoForm .mktoFormCol + .mktoFormCol {
    margin-left: 0;
  }
}
.mktoForm .mktoFieldWrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -ms-flex-preferred-size: 1;
  flex-basis: 1;
  width: 100%;
}
.mktoForm .mktoGutter {
  display: none;
}
.mktoForm .mktoLabel {
  display: block;
  font-size: 14px;
  font-weight: bold;
  font-family: 太ゴB101, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  margin-bottom: 5px;
  width: 100% !important;
}
.mktoForm .mktoRequiredField .mktoLabel:after {
  content: "必須";
  margin-left: 10px;
  background-color: #999;
  font-weight: 400;
  display: inline-block;
  color: #fff;
  padding: 2px 5px;
  line-height: 1.4;
  font-size: 11px;
}
.mktoForm .mktoAsterix {
  display: none !important;
}

.mktoField {
  background-color: #fff;
  border: 1px solid #CCCCCC;
  font-size: 14px !important;
  width: 100% !important;
  height: auto !important;
  padding: 9px 12px !important;
}
.mktoField:focus {
  outline: 2px solid #EF3340;
}
.mktoField::-webkit-input-placeholder {
  color: #999;
}
.mktoField::-moz-placeholder {
  color: #999;
}
.mktoField:-ms-input-placeholder {
  color: #999;
}
.mktoField::-ms-input-placeholder {
  color: #999;
}
.mktoField::placeholder {
  color: #999;
}

.mktoHtmlText {
  width: 100% !important;
}
.mktoHtmlText div {
  text-align: center !important;
}
.mktoHtmlText a {
  text-decoration: underline;
  color: #222 !important;
}
.mktoHtmlText span {
  font-size: 12px !important;
  text-align: center;
}

.mktoButtonWrap {
  margin-left: 0 !important;
}

.mktoButtonRow {
  text-align: center !important;
  width: 100%;
}

.mktoButton {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-align: center;
  font-weight: 700;
  font-size: 14px;
  text-decoration: none !important;
  padding: 10px 20px;
  -webkit-transition: background-color 0.5s;
  transition: background-color 0.5s;
  color: #fff;
  background-color: #EF3340;
  border: none;
  -webkit-box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
  box-shadow: 0 -5px 0 -2px rgba(0, 0, 0, 0.2) inset;
}
@media screen and (min-width: 992px) {
  .mktoButton:hover {
    color: #fff;
    border: none;
    background-color: #B02D36;
  }
}
@media screen and (max-width: 767px) {
  .mktoButton {
    width: 100%;
  }
}

.mktoForm .mktoError .mktoErrorMsg {
  background-image: none !important;
  background-color: #EF3340 !important;
  text-shadow: none !important;
  -webkit-box-shadow: none !important;
  box-shadow: none !important;
  border-color: #EF3340 !important;
}

.mktoForm .mktoError .mktoErrorArrow {
  background-color: #EF3340 !important;
  border-color: #EF3340 !important;
}

.mktoForm .mktoCheckboxList,
.mktoForm .mktoRadioList {
  width: 100% !important;
}
.mktoForm .mktoCheckboxList .mktoField,
.mktoForm .mktoRadioList .mktoField {
  width: auto !important;
  margin-top: 2px;
}
.mktoForm .mktoCheckboxList > label,
.mktoForm .mktoRadioList > label {
  margin: 0 0 10px 20px !important;
}