@charset "UTF-8";
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
* {
  outline: none;
}

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

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

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

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

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

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

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none;
}

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

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

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type=checkbox],
[type=radio] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * 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 odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * 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. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

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

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none;
}

* {
  box-sizing: border-box;
}

h1,
h2,
h3,
h4,
h5,
p {
  margin: 0;
}

ul,
ol,
li {
  margin: 0;
  padding: 0;
  list-style: none;
}

img {
  vertical-align: bottom;
}

dl,
dt,
dd {
  margin: 0;
  padding: 0;
}

input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0px 1000px #fff inset;
}

select::-ms-expand {
  display: none;
}

@media (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}
/* Base
   ========================================================================== */
* {
  box-sizing: border-box;
}

*::before {
  box-sizing: border-box;
}

*::after {
  box-sizing: border-box;
}

@media screen and (max-width: 767px) {
  .br-pc {
    display: none;
  }
}

.br-sp {
  display: none;
}
@media screen and (max-width: 767px) {
  .br-sp {
    display: block;
  }
}

.show_pc {
  display: flex !important;
}
@media screen and (max-width: 767px) {
  .show_pc {
    display: none !important;
  }
}

.show_sp {
  display: none !important;
}
@media screen and (max-width: 767px) {
  .show_sp {
    display: flex !important;
  }
}

a {
  color: #2f2f2f;
  text-decoration: none;
}
a:hover {
  opacity: 0.5;
}
@media screen and (max-width: 767px) {
  a:hover {
    opacity: 1;
  }
}

html {
  overflow-x: hidden;
  height: 100%;
}

img {
  height: auto;
}

body {
  scroll-behavior: smooth;
  font-family: "Noto Sans JP", sans-serif;
  background: #fff;
  color: #2f2f2f;
  line-height: 1.6;
  height: 100%;
  font-size: 16px;
  font-style: normal;
  font-weight: normal;
  min-width: 1200px;
}
@media screen and (max-width: 767px) {
  body {
    font-size: 16px;
    font-size: 4.2666666667vw;
    width: 100%;
    min-width: inherit;
  }
}
body.fixed {
  position: fixed;
  overflow: hidden;
}

/* Common
   ========================================================================== */
.logo a {
  display: inline;
  width: 94px;
  height: 80px;
}
@media screen and (max-width: 767px) {
  .logo a {
    width: 74px;
    height: 62px;
  }
}

.logo-medium a {
  display: block;
  width: 138px;
  height: 118px;
}
@media screen and (max-width: 767px) {
  .logo-medium a {
    width: 108px;
    height: 92px;
    margin-bottom: 48px;
  }
}

.breadcrumbs {
  font-size: 12px;
  color: #9f9f9f;
  width: 1200px;
  margin: 0 auto;
  padding-top: 140px;
}
.breadcrumbs a {
  color: #9f9f9f;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .breadcrumbs {
    font-size: 12px;
    font-size: 3.2vw;
    width: 89.33%;
    padding-top: 40px;
  }
}

.header--contents {
  background-color: rgba(255, 255, 255, 0.9);
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  min-width: 1240px;
  height: 120px;
  padding-left: 25px;
  padding-right: 36px;
  position: fixed;
  top: 0;
  z-index: 5;
}
@media screen and (max-width: 767px) {
  .header--contents {
    width: 100%;
    min-width: 100%;
    height: 85px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 14px;
    padding-right: 20px;
    position: static;
  }
  .contents {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}

.nav--contents {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .nav--contents_text {
    display: none;
  }
}

.nav--contents_text-list {
  display: flex;
  justify-content: space-between;
  font-size: 14px;
}
.nav--contents_text-list li + li {
  margin-left: 25px;
}

.nav--contents_btn {
  margin-left: 35px;
}
@media screen and (max-width: 767px) {
  .nav--contents_btn {
    display: none;
  }
}

.nav--contents_btn-list {
  display: flex;
  justify-content: space-between;
}
.nav--contents_btn-list li + li {
  margin-left: 11px;
}

.btn--sml {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  width: 160px;
  height: 38px;
  border-radius: 25px;
  letter-spacing: 3px;
  position: relative;
  z-index: 1;
  transition: 0.3s;
}
.btn--sml:before, .btn--sml:after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  border-radius: 25px;
}
.btn--sml.request_info {
  font-weight: 500;
}
.btn--sml.request_info:before {
  background: #0075a2;
  z-index: -1;
  transition: transform ease 0.3s, opacity 0.3s;
}
.btn--sml.request_info:after {
  border: 2px solid #0075a2;
  box-sizing: border-box;
}
.btn--sml.request_info:hover {
  background: #2ba2d0;
  color: #fff;
  opacity: 1;
}
.btn--sml.request_info:hover:before {
  transform: scale(0);
  opacity: 0;
}
.btn--sml.contact {
  font-weight: 500;
}
.btn--sml.contact:before {
  background: #cc0011;
  z-index: -1;
  transition: transform ease 0.3s, opacity 0.3s;
}
.btn--sml.contact:after {
  border: 2px solid #cc0011;
  box-sizing: border-box;
}
.btn--sml.contact:hover {
  background: #e84956;
  color: #fff;
  opacity: 1;
}
.btn--sml.contact:hover:before {
  transform: scale(0);
  opacity: 0;
}
.btn--sml.login {
  font-weight: 500;
}
.btn--sml.login:before {
  background: #9f9f9f;
  z-index: -1;
  transition: transform ease 0.3s, opacity 0.3s;
}
.btn--sml.login:after {
  border: 2px solid #9f9f9f;
  box-sizing: border-box;
}
.btn--sml.login:hover {
  background: #ccc;
  color: #fff;
  opacity: 1;
}
.btn--sml.login:hover:before {
  transform: scale(0);
  opacity: 0;
}

.btn--large {
  display: flex;
  font-size: 22px;
  font-weight: bold;
  align-items: center;
  justify-content: center;
  color: #fff;
  width: 444px;
  height: 69px;
  border-radius: 40px;
  position: relative;
  z-index: 1;
  transition: 0.3s;
}
@media screen and (max-width: 767px) {
  .btn--large {
    font-size: 18px;
    font-size: 4.8vw;
    width: 89.33%;
    margin-left: auto;
    margin-right: auto;
  }
}
.btn--large:before, .btn--large:after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  border-radius: 40px;
}
.btn--large.request_info:before {
  background: #0075a2;
  z-index: -1;
  transition: transform ease 0.3s, opacity 0.3s;
}
.btn--large.request_info:after {
  border: 2px solid #0075a2;
  box-sizing: border-box;
}
.btn--large.request_info:hover {
  background: #2ba2d0;
  color: #fff;
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .btn--large.request_info:hover {
    background: #0075a2;
  }
}
.btn--large.request_info:hover:before {
  transform: scale(0);
  opacity: 0;
}
@media screen and (max-width: 767px) {
  .btn--large.request_info:hover:before {
    transform: scale(1);
    opacity: 1;
  }
}
.btn--large.contact {
  background: #cc0011;
}
.btn--large.login {
  background: #9f9f9f;
}
.btn--large.effect {
  margin: 80px auto 0 auto;
}
.btn--large.case-study {
  margin: 80px auto 0 auto;
}

.btn--modal {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  color: #fff;
  width: 212px;
  height: 48px;
  border-radius: 60px;
  letter-spacing: 3px;
  position: relative;
  z-index: 1;
  transition: 0.3s;
}
@media screen and (max-width: 767px) {
  .btn--modal {
    font-size: 16px;
    font-size: 4.2666666667vw;
    width: 100%;
    height: 56px;
  }
}
.btn--modal:before, .btn--modal:after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  border-radius: 60px;
}
.btn--modal.request_info {
  margin-bottom: 16px;
}
.btn--modal.request_info:before {
  background: #0075a2;
  z-index: -1;
  transition: transform ease 0.3s, opacity 0.3s;
}
.btn--modal.request_info:after {
  border: 2px solid #0075a2;
  box-sizing: border-box;
}
.btn--modal.request_info:hover {
  background: #2ba2d0;
  color: #fff;
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .btn--modal.request_info:hover {
    background: #0075a2;
  }
}
.btn--modal.request_info:hover:before {
  transform: scale(0);
  opacity: 0;
}
@media screen and (max-width: 767px) {
  .btn--modal.request_info:hover:before {
    transform: scale(1);
    opacity: 1;
  }
}
.btn--modal.contact {
  margin-bottom: 16px;
}
.btn--modal.contact:before {
  background: #cc0011;
  z-index: -1;
  transition: transform ease 0.3s, opacity 0.3s;
}
.btn--modal.contact:after {
  border: 2px solid #cc0011;
  box-sizing: border-box;
}
.btn--modal.contact:hover {
  background: #e84956;
  color: #fff;
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .btn--modal.contact:hover {
    background: #cc0011;
  }
}
.btn--modal.contact:hover:before {
  transform: scale(0);
  opacity: 0;
}
@media screen and (max-width: 767px) {
  .btn--modal.contact:hover:before {
    transform: scale(1);
    opacity: 1;
  }
}
.btn--modal.login:before {
  background: #9f9f9f;
  z-index: -1;
  transition: transform ease 0.3s, opacity 0.3s;
}
.btn--modal.login:after {
  border: 2px solid #9f9f9f;
  box-sizing: border-box;
}
.btn--modal.login:hover {
  background: #ccc;
  color: #fff;
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .btn--modal.login:hover {
    background: #9f9f9f;
  }
}
.btn--modal.login:hover:before {
  transform: scale(0);
  opacity: 0;
}
@media screen and (max-width: 767px) {
  .btn--modal.login:hover:before {
    transform: scale(1);
    opacity: 1;
  }
}

.btn-menu {
  cursor: pointer;
  width: 40px;
  height: 26px;
  position: relative;
  margin-left: 35px;
}
@media screen and (max-width: 767px) {
  .btn-menu {
    width: 33px;
    height: 22px;
  }
}
.btn-menu span {
  background: #2f2f2f;
  width: 40px;
  height: 2px;
  display: inline-block;
  position: absolute;
}
@media screen and (max-width: 767px) {
  .btn-menu span {
    width: 33px;
    height: 2px;
  }
}
.btn-menu span:nth-of-type(1) {
  top: 0px;
}
.btn-menu span:nth-of-type(2) {
  top: 13px;
}
.btn-menu span:nth-of-type(3) {
  top: 26px;
}
.btn-menu:hover {
  opacity: 0.5;
}

.btn--hero--appeal-request_info,
.btn--whitepaper--appeal-request_info {
  display: none;
}
@media screen and (max-width: 767px) {
  .btn--hero--appeal-request_info,
  .btn--whitepaper--appeal-request_info {
    font-size: 18px;
    font-size: 4.8vw;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    width: 100%;
    height: 56px;
    border-radius: 60px;
    letter-spacing: 3px;
    position: relative;
    z-index: 1;
    transition: 0.3s;
  }
  .btn--hero--appeal-request_info:before, .btn--hero--appeal-request_info:after,
  .btn--whitepaper--appeal-request_info:before,
  .btn--whitepaper--appeal-request_info:after {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 60px;
  }
  .btn--hero--appeal-request_info:before,
  .btn--whitepaper--appeal-request_info:before {
    background: #0075a2;
    z-index: -1;
    transition: transform ease 0.3s, opacity 0.3s;
  }
  .btn--hero--appeal-request_info:after,
  .btn--whitepaper--appeal-request_info:after {
    border: 2px solid #0075a2;
    box-sizing: border-box;
  }
  .btn--whitepaper--appeal-request_info {
    text-align: center;
    line-height: 1.1;
    margin-top: 45px;
  }
}

.hero--appeal-check {
  background-color: #cc0011;
  position: relative;
  width: 30px;
  height: 30px;
  margin-right: 6px;
  border-radius: 100%;
}
@media screen and (max-width: 767px) {
  .hero--appeal-check {
    width: 22px;
    height: 22px;
    margin-right: 10px;
  }
}
.hero--appeal-check:after {
  content: "";
  display: block;
  position: absolute;
  top: 9px;
  left: 8px;
  width: 15px;
  height: 8px;
  border-left: 3px solid #fff;
  border-bottom: 3px solid #fff;
  border-radius: 2px 1px 2px 0px;
  transform: rotate(-45deg);
}
@media screen and (max-width: 767px) {
  .hero--appeal-check:after {
    width: 12px;
    height: 7px;
    top: 6px;
    left: 5px;
    border-left: 2px solid #fff;
    border-bottom: 2px solid #fff;
    border-radius: 1px 1px 2px 0px;
    margin-bottom: 18px;
  }
}

.section--title {
  text-align: center;
  font-size: 26px;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .section--title {
    font-size: 22px;
    font-size: 5.8666666667vw;
  }
  .section--title.about {
    display: flex;
    justify-content: center;
    align-items: center;
    background: url(../img/about_sp_title.png) no-repeat center center;
    background-size: 100%;
    height: 90px;
  }
}
.section--title.blog {
  text-align: left;
}
.section--title.media {
  text-align: left;
}
.section--title.what_we_do {
  text-align: left;
}
.section--title.information {
  text-align: left;
}
.section--title.service {
  position: relative;
  z-index: 2;
  text-align: center;
  margin-bottom: 130px;
}
@media screen and (max-width: 767px) {
  .section--title.service {
    display: flex;
    justify-content: center;
    align-items: center;
    background: url(../img/reason_title.png) no-repeat center center;
    background-size: cover;
    position: static;
    width: 89.33%;
    margin: 0 auto 70px auto;
    height: 115px;
  }
}
.section--title.strength {
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .section--title.strength {
    display: flex;
    justify-content: center;
    align-items: center;
    background: url(../img/strength_sp_title.png) no-repeat center center;
    background-size: 150%;
    height: 94px;
  }
}
.section--title.cost {
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .section--title.cost {
    display: flex;
    justify-content: center;
    align-items: center;
    background: url(../img/cost_sp_title.png) no-repeat center center;
    background-size: 100%;
    height: 96px;
  }
}
.section--title.seminar {
  text-align: left;
}
.section--title.faq {
  text-align: left;
}

.link--details-wrapper {
  display: inline-block;
}

.link--details {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 14px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .link--details {
    font-size: 14px;
    font-size: 3.7333333333vw;
  }
}
.link--details.about {
  width: 230px;
  margin: 0 0 0 auto;
}
@media screen and (max-width: 767px) {
  .link--details.about {
    width: 100%;
    text-align: center;
  }
}
.link--details:hover {
  color: #0075a2;
  opacity: 1;
}
.link--details:hover .link--details-border:before, .link--details:hover .link--details-border:after {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
}
.link--details:hover .link--details-border:before {
  left: 4px;
  width: 0px;
  height: 1px;
  background: #7a0;
}
.link--details:hover .link--details-border:after {
  left: 4px;
  width: 12px;
  height: 12px;
  border-top: 1px solid #0075a2;
  border-right: 1px solid #0075a2;
  transform: rotate(45deg);
  animation: border_anim 0.1s linear forwards;
}

@keyframes border_anim {
  0% {
    left: 0;
  }
  100% {
    left: 36px;
  }
}
.link--details-border {
  background: #0075a2;
  display: inline-block;
  width: 45px;
  height: 1px;
  margin-right: 11px;
  position: relative;
}

.link--details-mail {
  display: block;
  background-repeat: no-repeat;
  background-image: url("data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2015%2015%22%20style%3D%22enable-background%3Anew%200%200%2015%2015%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%232F2F2F%3B%7D%3C%2Fstyle%3E%3Cg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_129%22%20transform%3D%22translate(6397.614%2017016.814)%22%3E%20%3Cg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_10%22%20transform%3D%22translate(-6397.614%20-17016.814)%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_6%22%20class%3D%22st0%22%20d%3D%22M12%2C14.1c-0.1%2C0-0.2%2C0-0.3-0.1l-6-4.3C5.6%2C9.6%2C5.5%2C9.5%2C5.5%2C9.3s0-0.3%2C0.1-0.3l5.5-5%20c0.2-0.2%2C0.5-0.1%2C0.6%2C0c0.2%2C0.2%2C0.2%2C0.5%2C0%2C0.6c0%2C0%2C0%2C0%2C0%2C0L6.6%2C9.3l5%2C3.6l2.1-10.8L1.9%2C7l1.2%2C0.4C3.3%2C7.5%2C3.4%2C7.7%2C3.3%2C8%20c0%2C0%2C0%2C0%2C0%2C0C3.3%2C8.2%2C3%2C8.3%2C2.8%2C8.2l0%2C0L0.5%2C7.4C0.3%2C7.4%2C0.2%2C7.2%2C0.2%2C7s0.1-0.3%2C0.3-0.4L14.2%2C1c0.1-0.1%2C0.3%2C0%2C0.4%2C0.1%20c0.1%2C0.1%2C0.2%2C0.3%2C0.2%2C0.4l-2.4%2C12.3c0%2C0.1-0.1%2C0.3-0.3%2C0.3C12.1%2C14.1%2C12%2C14.1%2C12%2C14.1z%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_7%22%20class%3D%22st0%22%20d%3D%22M5.2%2C13.7c-0.1%2C0-0.1%2C0-0.1%2C0c-0.2%2C0-0.3-0.2-0.3-0.3L3.3%2C8.8c-0.1-0.3%2C0-0.5%2C0.3-0.6%20c0%2C0%2C0%2C0%2C0%2C0c0.1%2C0%2C0.1%2C0%2C0.2%2C0c0.2%2C0%2C0.4%2C0.1%2C0.5%2C0.3l1.3%2C3.8l1.1-0.8c0.2-0.2%2C0.5-0.1%2C0.7%2C0.1c0.2%2C0.2%2C0.1%2C0.5-0.1%2C0.7l-1.6%2C1.3%20C5.5%2C13.6%2C5.4%2C13.7%2C5.2%2C13.7z%22%2F%3E%20%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E");
  background-size: 15px auto;
  width: 15px;
  height: 14px;
  margin-left: 10px;
}

.icon_mail-large {
  display: block;
  background-repeat: no-repeat;
  background-image: url("data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2031%2028%22%20style%3D%22enable-background%3Anew%200%200%2031%2028%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23FFFFFF%3B%7D%3C%2Fstyle%3E%3Cg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_10%22%20transform%3D%22translate(0%200)%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_6%22%20class%3D%22st0%22%20d%3D%22M24.7%2C27.6c-0.2%2C0-0.4-0.1-0.5-0.2l-12.4-8.9c-0.2-0.2-0.4-0.4-0.4-0.7c0-0.3%2C0.1-0.5%2C0.3-0.7%20L23%2C6.8c0.4-0.3%2C0.9-0.3%2C1.3%2C0.1c0.3%2C0.4%2C0.3%2C0.9-0.1%2C1.3l-10.4%2C9.5l10.4%2C7.5l4.4-22.3L3.9%2C12.9l2.5%2C0.9C6.8%2C14%2C7.1%2C14.5%2C6.9%2C15%20c0%2C0%2C0%2C0%2C0%2C0c-0.2%2C0.5-0.7%2C0.7-1.1%2C0.6h0L1%2C13.9c-0.4-0.1-0.6-0.5-0.6-0.8c0-0.4%2C0.2-0.7%2C0.6-0.9L29.3%2C0.5c0.3-0.1%2C0.7-0.1%2C0.9%2C0.1%20c0.3%2C0.2%2C0.4%2C0.5%2C0.3%2C0.9l-5%2C25.3c-0.1%2C0.3-0.3%2C0.6-0.6%2C0.7C24.9%2C27.5%2C24.8%2C27.6%2C24.7%2C27.6z%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_7%22%20class%3D%22st0%22%20d%3D%22M10.6%2C25.7c-0.1%2C0-0.2%2C0-0.3%2C0c-0.3-0.1-0.5-0.3-0.6-0.6L7%2C16.8c-0.2-0.5%2C0.1-1%2C0.6-1.2%20c0%2C0%2C0%2C0%2C0%2C0c0.1%2C0%2C0.2%2C0%2C0.3%2C0c0.4%2C0%2C0.8%2C0.3%2C0.9%2C0.6l2.3%2C7l2-1.5c0.4-0.3%2C1-0.2%2C1.3%2C0.2c0.3%2C0.4%2C0.2%2C1-0.2%2C1.3l-3%2C2.3%20C11%2C25.7%2C10.8%2C25.7%2C10.6%2C25.7z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E");
  background-size: 31px auto;
  width: 31px;
  height: 28px;
  margin-left: 10px;
}
@media screen and (max-width: 767px) {
  .icon_mail-large {
    background-size: 24px auto;
    width: 24px;
    height: 21px;
  }
}

.icon--faq {
  display: block;
  background-repeat: no-repeat;
  background-image: url("data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2024%2026%22%20style%3D%22enable-background%3Anew%200%200%2024%2026%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Benable-background%3Anew%20%3B%7D%20.st1%7Bfill%3A%239F9F9F%3B%7D%3C%2Fstyle%3E%3Cg%20class%3D%22st0%22%3E%20%3Cpath%20class%3D%22st1%22%20d%3D%22M23.7%2C23.3c-1.4%2C1.6-3.2%2C2.5-5.3%2C2.5c-2.6%2C0-4.7-1.1-7.6-4.2c-6-0.3-10.4-4.8-10.4-10.7%20c0-6.1%2C4.7-10.7%2C11.2-10.7c6.4%2C0%2C11.1%2C4.6%2C11.1%2C10.7c0%2C5.2-3.4%2C9.3-8.2%2C10.4c1.4%2C1.5%2C2.7%2C2.1%2C4%2C2.1c1.5%2C0%2C2.8-0.6%2C3.8-1.8%20L23.7%2C23.3z%20M11.5%2C19c4.6%2C0%2C8.1-3.5%2C8.1-8.1c0-4.6-3.5-8.1-8.1-8.1c-4.7%2C0-8.2%2C3.5-8.2%2C8.1C3.3%2C15.5%2C6.8%2C19%2C11.5%2C19z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E");
  background-size: 24px auto;
  width: 24px;
  height: 26px;
  margin-left: 6px;
  margin-right: 40px;
}
@media screen and (max-width: 767px) {
  .icon--faq {
    background-size: 22px auto;
    width: 32px;
    height: 26px;
    margin-left: 0px;
    margin-right: 13px;
    margin-top: 5px;
  }
}

.icon--arrow-up {
  text-align: right;
  display: inline-block;
  width: 12px;
  height: 12px;
  margin-top: 10px;
  margin-left: 60px;
  border-top: 1px solid #2f2f2f;
  border-left: 1px solid #2f2f2f;
  transform: rotate(45deg);
}
@media screen and (max-width: 767px) {
  .icon--arrow-up {
    width: 14px;
    margin-left: 20px;
  }
}

.icon--arrow-bottom {
  text-align: right;
  display: inline-block;
  width: 12px;
  height: 12px;
  margin-top: 3px;
  margin-left: 60px;
  border-bottom: 1px solid #2f2f2f;
  border-right: 1px solid #2f2f2f;
  transform: rotate(45deg);
}
@media screen and (max-width: 767px) {
  .icon--arrow-bottom {
    width: 14px;
    margin-left: 20px;
  }
}

.icon--arrow-right {
  text-align: right;
  display: inline-block;
  width: 12px;
  height: 12px;
  margin-top: 3px;
  margin-left: 35px;
  border-top: 1px solid #2f2f2f;
  border-right: 1px solid #2f2f2f;
  transform: rotate(45deg);
}
@media screen and (max-width: 767px) {
  .icon--arrow-right {
    width: 12px;
    margin-left: 30px;
    position: absolute;
    top: 50%;
    right: 0px;
  }
}

.icon-user {
  display: block;
  background-repeat: no-repeat;
  background-image: url("data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%20512%20480%22%20style%3D%22enable-background%3Anew%200%200%20512%20480%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23FFFFFF%3B%7D%3C%2Fstyle%3E%3Cg%20id%3D%22icomoon-ignore%22%3E%3C%2Fg%3E%3Cg%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M392.4%2C182.3h-21.1v-42.1C371.2%2C76.7%2C319.5%2C25%2C255.9%2C25c0%2C0%2C0%2C0%2C0%2C0c-46.4%2C0-88.1%2C27.7-106.2%2C70.5%20c-4.5%2C10.7%2C0.5%2C23%2C11.2%2C27.5c10.7%2C4.5%2C23-0.5%2C27.5-11.2c11.5-27.2%2C38-44.8%2C67.6-44.8c0%2C0%2C0%2C0%2C0%2C0c40.5%2C0%2C73.4%2C32.9%2C73.4%2C73.4v42.1%20H119.6c-11.6%2C0-21%2C9.4-21%2C21v230.7c0%2C11.6%2C9.4%2C21%2C21%2C21h272.7c11.6%2C0%2C21-9.4%2C21-21V203.3C413.3%2C191.7%2C403.9%2C182.3%2C392.4%2C182.3z%20M371.4%2C413.1H140.6V224.3h230.7V413.1z%22%2F%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M256%2C360.7c11.6%2C0%2C21-9.4%2C21-21v-42c0-11.6-9.4-21-21-21s-21%2C9.4-21%2C21v42C235%2C351.3%2C244.4%2C360.7%2C256%2C360.7z%22%20%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E");
  background-size: 24px auto;
  width: 24px;
  height: 27px;
  margin-right: 8px;
}

.icon-close,
.modal--request_info-close {
  display: block;
  background-repeat: no-repeat;
  background-image: url("data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2043%2029%22%20style%3D%22enable-background%3Anew%200%200%2043%2029%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%239F9F9F%3B%7D%3C%2Fstyle%3E%3Cpath%20class%3D%22st0%22%20d%3D%22M42.3%2C26.7L23.3%2C14.5L42.3%2C2.3c0.5-0.3%2C0.6-0.9%2C0.3-1.4c-0.3-0.5-0.9-0.6-1.4-0.3L21.5%2C13.3L1.8%2C0.6%20C1.3%2C0.3%2C0.7%2C0.4%2C0.4%2C0.9C0.1%2C1.4%2C0.3%2C2%2C0.7%2C2.3l18.9%2C12.2L0.7%2C26.7c-0.5%2C0.3-0.6%2C0.9-0.3%2C1.4c0.2%2C0.3%2C0.5%2C0.5%2C0.8%2C0.5%20c0.2%2C0%2C0.4-0.1%2C0.5-0.2l19.7-12.7l19.7%2C12.7c0.2%2C0.1%2C0.4%2C0.2%2C0.5%2C0.2c0.3%2C0%2C0.7-0.2%2C0.8-0.5C42.9%2C27.6%2C42.7%2C27%2C42.3%2C26.7z%22%2F%3E%3C%2Fsvg%3E");
  background-size: 43px auto;
  width: 43px;
  height: 29px;
  position: absolute;
  top: 45px;
  right: 55px;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .icon-close,
  .modal--request_info-close {
    background-size: 33px auto;
    width: 33px;
    height: 21px;
    top: 31px;
    right: 20px;
  }
}
.icon-close:hover,
.modal--request_info-close:hover {
  opacity: 0.5;
}

@media screen and (max-width: 767px) {
  .modal--request_info-close {
    top: 15px;
    right: 15px;
  }
}

.footer--contents-inner {
  display: flex;
  justify-content: space-between;
  width: 1048px;
  margin: 0 auto;
  padding-bottom: 160px;
}
@media screen and (max-width: 767px) {
  .footer--contents-inner {
    width: 100%;
    display: block;
    padding-bottom: 25px;
  }
  .footer--contents-inner .logo-medium {
    width: 89.33%;
    margin-left: auto;
    margin-right: auto;
  }
}

.footer--contents-unity {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .footer--contents-unity {
    display: block;
    width: 81.66%;
    margin-left: auto;
    margin-right: auto;
  }
}

.footer--contents-links {
  display: flex;
  justify-content: space-between;
  margin-right: 48px;
  padding-right: 32px;
  border-right: 1px solid #9f9f9f;
}
@media screen and (max-width: 767px) {
  .footer--contents-links {
    border-bottom: 1px solid #9f9f9f;
    border-right: none;
    margin-right: 0;
    margin-bottom: 40px;
    padding-right: 0;
    padding-bottom: 40px;
  }
}

.footer--contents-links-list {
  padding-top: 8px;
}
.footer--contents-links-list li {
  font-size: 14px;
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .footer--contents-links-list li {
    font-size: 14px;
    font-size: 3.7333333333vw;
  }
}
.footer--contents-links-list li.footer--contents-links-rules a {
  font-size: 12px;
  color: #9f9f9f;
}
@media screen and (max-width: 767px) {
  .footer--contents-links-list li.footer--contents-links-rules a {
    font-size: 12px;
    font-size: 3.2vw;
  }
}
.footer--contents-links-list + .footer--contents-links-list {
  margin-left: 46px;
}
@media screen and (max-width: 767px) {
  .footer--contents-links-list + .footer--contents-links-list {
    margin-left: 0;
  }
}

.footer--contents-detail {
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .footer--contents-detail {
    font-size: 14px;
    font-size: 3.7333333333vw;
  }
}

.footer--contents-detail-list {
  padding-top: 8px;
}
@media screen and (max-width: 767px) {
  .footer--contents-detail-list {
    font-size: 16px;
    font-size: 4.2666666667vw;
  }
}

.footer--contents-detail-name {
  font-weight: normal;
  margin-bottom: 24px;
}
@media screen and (max-width: 767px) {
  .footer--contents-detail-name {
    font-size: 14px;
    font-size: 3.7333333333vw;
  }
}

.footer--contents-detail-address {
  line-height: 2;
  margin-bottom: 16px;
}

.footer--contents-detail-tel {
  font-size: 16px;
  font-weight: normal;
  margin-bottom: 32px;
}
@media screen and (max-width: 767px) {
  .footer--contents-detail-tel {
    font-size: 16px;
    font-size: 4.2666666667vw;
    margin-bottom: 48px;
  }
}

.copyright {
  font-size: 12px;
  color: #9f9f9f;
}
@media screen and (max-width: 767px) {
  .copyright {
    text-align: center;
    font-size: 12px;
    font-size: 3.2vw;
  }
}

.display_fixed {
  overflow-y: hidden;
}
@media screen and (max-width: 767px) {
  .display_fixed {
    position: fixed;
  }
}

.prev-arrow {
  cursor: pointer;
  position: absolute;
  left: 50%;
  bottom: 0;
  z-index: 4;
}
@media screen and (max-width: 767px) {
  .prev-arrow {
    left: 0;
    top: auto;
    bottom: 0;
  }
  .prev-arrow.topic {
    top: 50%;
    left: -15px;
    bottom: auto;
    margin-top: 30%;
  }
  .prev-arrow.topic:before {
    width: 15px;
    height: 15px;
    left: 0;
    top: 0;
    bottom: auto;
  }
}
.prev-arrow:before, .prev-arrow:after {
  position: absolute;
  margin: auto;
  content: "";
  vertical-align: middle;
}
.prev-arrow:before {
  left: -389px;
  bottom: 110px;
  width: 44px;
  height: 44px;
  border-top: 1px solid #2f2f2f;
  border-right: 1px solid #2f2f2f;
  transform: rotate(-135deg);
}
@media screen and (max-width: 767px) {
  .prev-arrow:before {
    width: 20px;
    height: 20px;
    left: 15px;
    bottom: 70px;
  }
}
.prev-arrow:hover {
  opacity: 0.5;
}

.next-arrow {
  cursor: pointer;
  position: absolute;
  right: 50%;
  bottom: 0px;
  z-index: 4;
}
@media screen and (max-width: 767px) {
  .next-arrow {
    right: 0;
    top: auto;
    bottom: 0;
  }
  .next-arrow.topic {
    top: 50%;
    bottom: 0;
    margin-top: 30%;
  }
  .next-arrow.topic:before {
    width: 15px;
    height: 15px;
    left: 0;
    top: 0;
    bottom: auto;
  }
}
.next-arrow:before, .next-arrow:after {
  position: absolute;
  margin: auto;
  content: "";
  vertical-align: middle;
}
.next-arrow:before {
  left: 345px;
  bottom: 120px;
  width: 44px;
  height: 44px;
  border-top: 1px solid #2f2f2f;
  border-right: 1px solid #2f2f2f;
  transform: rotate(45deg);
}
@media screen and (max-width: 767px) {
  .next-arrow:before {
    width: 20px;
    height: 20px;
    left: -35px;
    bottom: 70px;
  }
}
.next-arrow:hover {
  opacity: 0.5;
}

.modal--container,
.modal--request_info-container {
  background-color: rgba(159, 159, 159, 0.6);
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  transition: 0.3s;
}
.modal--container.active,
.modal--request_info-container.active {
  opacity: 1;
  visibility: visible;
  z-index: 999;
  overflow-y: hidden;
}

.modal--request_info-container {
  padding: 40px 20px;
}

.modal--request_info-container-inner {
  overflow: auto;
  max-height: 100%;
}
@media screen and (max-width: 767px) {
  .modal--request_info-container-inner {
    width: 90%;
    margin: 0 auto;
  }
}

.modal--request_info-iframe {
  border: none;
  width: 90%;
  height: 100%;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
@media screen and (max-width: 767px) {
  .modal--request_info-iframe {
    height: 490px !important;
  }
}

.menu--container {
  background: #fff;
  position: absolute;
  vertical-align: middle;
  top: 0;
  left: 0;
  width: 100%;
  min-width: 1200px;
  height: 418px;
  padding: 23px 25px;
}
@media screen and (max-width: 767px) {
  .menu--container {
    overflow-y: auto;
    min-width: 100%;
    height: 100%;
    padding: 11px 20px 35px 14px;
  }
}

.menu--container--inner {
  display: flex;
  justify-content: flex-start;
}

.menu--container--links {
  display: flex;
  justify-content: space-between;
  margin: 63px auto 0 auto;
  width: 776px;
}
@media screen and (max-width: 767px) {
  .menu--container--links {
    display: block;
    width: 100%;
    margin: 59px auto 0 auto;
  }
}

.menu--container--links_wrapper {
  display: flex;
  justify-content: space-between;
  width: 404px;
}
@media screen and (max-width: 767px) {
  .menu--container--links_wrapper {
    width: 91%;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 46px;
  }
}

.menu--container--inner-logo {
  display: block;
  position: absolute;
  top: 23px;
  left: 24px;
}
@media screen and (max-width: 767px) {
  .menu--container--inner-logo {
    width: 74px;
    height: 62px;
    position: static;
    top: 0;
    left: 0;
  }
  .menu--container--inner-logo a {
    width: 100%;
    height: auto;
  }
}

.menu--container--links-list li {
  margin-bottom: 29px;
}
@media screen and (max-width: 767px) {
  .menu--container--links-list li {
    font-size: 16px;
    font-size: 4.2666666667vw;
  }
}

.post--coverage-case *,
.archive-card *,
.blog--frequentlyread-bottom-card * {
  box-sizing: border-box;
  transition: all 0.25s ease;
}

.archive-wrapper {
  margin-left: 436px;
}
@media screen and (max-width: 767px) {
  .archive-wrapper {
    margin: 0;
  }
}

.archive--contents-inner {
  display: flex;
  justify-content: flex-start;
  margin: 160px auto 0 auto;
}
@media screen and (max-width: 767px) {
  .archive--contents-inner {
    display: block;
    width: 100%;
    margin: 24px auto 0 auto;
  }
}

.archive--title-wrapper {
  background: #cce3ec url(../img/blog_title_bg.png) no-repeat center top;
  background-size: contain;
  width: 360px;
  height: calc(100% - 234px);
  margin-right: 75px;
  position: fixed;
  top: 164px;
}
@media screen and (max-width: 767px) {
  .archive--title-wrapper {
    background-size: cover;
    background-position: center;
    width: 100%;
    height: 250px;
    position: static;
    margin: 0 0 24px 0;
    padding-top: 40px;
  }
}

.archive-title {
  font-size: 22px;
  font-weight: normal;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 230px auto 0 auto;
}
@media screen and (max-width: 767px) {
  .archive-title {
    font-size: 18px;
    font-size: 4.8vw;
  }
}
.archive-title.white-paper {
  background: url(../img/white_paper_title_bg.png) no-repeat center center;
  background-size: contain;
  width: 100%;
  height: 159px;
}
@media screen and (max-width: 767px) {
  .archive-title.white-paper {
    width: 100%;
    margin: 0;
    background-size: 90%;
    background-position: right center;
  }
}
.archive-title.blog {
  background: url(../img/blog_title.png) no-repeat center center;
  background-size: contain;
  width: 284px;
  height: 159px;
}
@media screen and (max-width: 767px) {
  .archive-title.blog {
    width: 100%;
    margin: 0;
    background-size: 63.1%;
  }
}

.archive-subtitle {
  width: 148px;
  height: 15px;
  position: absolute;
  left: 50%;
  bottom: 60px;
  margin-left: -78px;
}
@media screen and (max-width: 767px) {
  .archive-subtitle {
    width: 33.15%;
    height: auto;
    margin: 0;
    bottom: auto;
    left: 33%;
  }
}

.archive-card-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  display: none;
}
@media screen and (max-width: 767px) {
  .archive-card-list {
    flex-direction: column;
    margin-left: auto;
    margin-right: auto;
    padding: 0 20px;
  }
}
.archive-card-list.active {
  display: flex;
  animation: appear 0.5s ease;
}

@keyframes appear {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.archive-card {
  width: 328px;
  height: auto;
  margin-bottom: 56px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .archive-card {
    width: 100%;
  }
}
.archive-card a {
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  position: absolute;
  z-index: 1;
}
.archive-card:hover img {
  transform: scale(1.1);
}
@media screen and (max-width: 767px) {
  .archive-card:hover img {
    transform: none;
  }
}

.archive-card--thumbnail {
  width: 328px;
  aspect-ratio: 328/180;
  height: auto;
  border-bottom-right-radius: 30px;
  overflow: hidden;
  margin-bottom: 24px;
}
@media screen and (max-width: 767px) {
  .archive-card--thumbnail {
    width: 100%;
    height: auto;
    aspect-ratio: 335/184;
    margin-bottom: 16px;
  }
}

.archive-caption-wrapper {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 8px;
}

.archive-date,
.single-date,
.blog-date,
.blog--frequentlyread-bottom-date {
  font-family: "Montserrat", sans-serif;
  font-size: 16px;
  color: #9f9f9f;
}
@media screen and (max-width: 767px) {
  .archive-date,
  .single-date,
  .blog-date,
  .blog--frequentlyread-bottom-date {
    font-size: 16px;
    font-size: 4.2666666667vw;
  }
}

.blog-date {
  color: #9f9f9f;
}

.archive-category,
.single-category,
.blog-category,
.blog--frequentlyread-bottom-category {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-size: 16px;
  color: #9f9f9f;
  border: 1px solid #9f9f9f;
  border-radius: 20px;
  margin-left: 14px;
  padding-left: 13px;
  padding-right: 13px;
}
@media screen and (max-width: 767px) {
  .archive-category,
  .single-category,
  .blog-category,
  .blog--frequentlyread-bottom-category {
    font-size: 16px;
    font-size: 4.2666666667vw;
  }
}

.single-category {
  margin: 0 12px 0 0;
}

.blog--frequentlyread-bottom-caption .blog--frequentlyread-bottom-category a {
  color: #9f9f9f;
  left: auto;
  right: auto;
  top: auto;
  bottom: auto;
  position: static;
  z-index: 0;
}

.archive-caption-title {
  font-size: 16px;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .archive-caption-title {
    font-size: 16px;
    font-size: 4.2666666667vw;
  }
}

.archive-card-tab {
  background-color: rgba(255, 255, 255, 0.9);
  font-family: "Montserrat", sans-serif;
  display: flex;
  justify-content: flex-start;
  margin-bottom: 56px;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .archive-card-tab {
    width: 89.33%;
    justify-content: space-between;
    margin-left: auto;
    margin-right: auto;
  }
}
.archive-card-tab li {
  font-size: 16px;
}
@media screen and (max-width: 767px) {
  .archive-card-tab li {
    font-size: 16px;
    font-size: 4.2666666667vw;
  }
}
.archive-card-tab li.active {
  border-bottom: 1px solid #9f9f9f;
  padding-bottom: 2px;
}
.archive-card-tab li + li {
  margin-left: 30px;
}
@media screen and (max-width: 767px) {
  .archive-card-tab li + li {
    margin-left: 0;
  }
}
.archive-card-tab li:hover {
  opacity: 0.5;
}

.icon_mail-xlarge {
  display: block;
  background-repeat: no-repeat;
  background-image: url("data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%20135%20117%22%20style%3D%22enable-background%3Anew%200%200%20135%20117%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23FFFFFF%3B%7D%20.st1%7Bfill%3A%23B1B1B1%3B%7D%3C%2Fstyle%3E%3Cg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_176%22%20transform%3D%22matrix(-0.309%2C%20-0.951%2C%200.951%2C%20-0.309%2C%2019.356%2C%20176.584)%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_18%22%20class%3D%22st0%22%20d%3D%22M85.2%2C116.6l4.9%2C29.3l77.6-106.1l-111.6-7l17.6%2C44L47.1%2C95.3L85.2%2C116.6z%22%2F%3E%20%3Cg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_13%22%20transform%3D%22translate(0%20127.349)%20rotate(-76)%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_6%22%20class%3D%22st1%22%20d%3D%22M105.3%2C28c-0.7%2C0-1.5%2C0.2-2.1%2C0.7L48.8%2C67.9c-1.6%2C1.2-2%2C3.4-0.8%2C5c0.1%2C0.2%2C0.3%2C0.4%2C0.5%2C0.6%20l49.4%2C44.8c1.5%2C1.3%2C3.7%2C1.2%2C5-0.3c1.3-1.4%2C1.2-3.6-0.2-5L56.6%2C71.1l46.3-33.3l19.3%2C98.9L13%2C91.7l11.9-4.1c1.9-0.6%2C2.8-2.7%2C2.2-4.5%20s-2.7-2.8-4.5-2.2L1.7%2C88c-1.9%2C0.6-2.8%2C2.7-2.2%2C4.5c0.3%2C1%2C1.1%2C1.7%2C2%2C2.1l124.1%2C51.1c1.8%2C0.8%2C3.9-0.1%2C4.7-1.9%20c0.3-0.6%2C0.3-1.4%2C0.2-2L108.8%2C30.9C108.5%2C29.2%2C107%2C28%2C105.3%2C28z%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_7%22%20class%3D%22st1%22%20d%3D%22M43.4%2C35.8c-0.4%2C0-0.7%2C0.1-1%2C0.2c-1.1%2C0.3-2%2C1.2-2.3%2C2.3l-11.7%2C35c-0.6%2C1.9%2C0.4%2C3.9%2C2.3%2C4.5%20c1.9%2C0.6%2C3.9-0.4%2C4.5-2.3l10.1-30.3L54%2C52c1.6%2C1.2%2C3.8%2C0.9%2C5-0.7c1.2-1.6%2C0.9-3.8-0.7-5l-12.8-9.8C45%2C36.1%2C44.2%2C35.8%2C43.4%2C35.8z%22%20%2F%3E%20%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E");
  background-size: 147px auto;
  width: 147px;
  height: 156px;
  position: absolute;
  bottom: -65px;
  right: -50px;
}
@media screen and (max-width: 767px) {
  .icon_mail-xlarge {
    display: none;
  }
}

.section--form-title {
  text-align: left;
  font-size: 26px;
  font-weight: normal;
}
@media screen and (max-width: 767px) {
  .section--form-title {
    font-size: 22px;
    font-size: 5.8666666667vw;
    text-align: center;
  }
}

.section--form-sub_title {
  font-family: "Montserrat", sans-serif;
  text-align: left;
  font-size: 16px;
  color: #0075a2;
}
@media screen and (max-width: 767px) {
  .section--form-sub_title {
    font-size: 16px;
    font-size: 4.2666666667vw;
    text-align: center;
  }
}

.single-entry-title {
  font-size: 26px;
  font-weight: bold;
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .single-entry-title {
    font-size: 22px;
    font-size: 5.8666666667vw;
    margin-bottom: 20px;
  }
}

.blog--wrapper .blog-entry--title {
  font-size: 26px;
  font-weight: bold;
  margin-bottom: 7px;
}
@media screen and (max-width: 767px) {
  .blog--wrapper .blog-entry--title {
    font-size: 22px;
    font-size: 5.8666666667vw;
  }
}

.single-entry-thumbnail {
  width: 681px;
  height: 362px;
  overflow: hidden;
  border-bottom-right-radius: 50px;
  margin-bottom: 52px;
}
@media screen and (max-width: 767px) {
  .single-entry-thumbnail {
    width: 100%;
    height: auto;
    margin-bottom: 43px;
  }
}

#toc_container {
  border: 1px dotted #9f9f9f;
  margin: 56px 0;
  padding: 56px 52px;
}
@media screen and (max-width: 767px) {
  #toc_container {
    padding: 33px 28px;
  }
}
#toc_container p.toc_title {
  text-align: left;
  font-size: 16px;
  color: #000;
  margin-bottom: 18px;
}
@media screen and (max-width: 767px) {
  #toc_container p.toc_title {
    font-size: 16px;
    font-size: 4.2666666667vw;
  }
}
#toc_container .toc_list a {
  color: #9f9f9f;
  line-height: 32px;
}
@media screen and (max-width: 767px) {
  #toc_container .toc_list a {
    font-size: 16px;
    font-size: 4.2666666667vw;
  }
}
#toc_container .toc_list a:hover {
  text-decoration: underline;
}

.request_info--form-iframe {
  width: 95%;
  height: 500px;
  border: none;
}
@media screen and (max-width: 767px) {
  .request_info--form-iframe {
    height: 600px;
  }
}

.request_info--form-title {
  text-align: center;
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .request_info--form-title {
    margin-bottom: 0;
  }
}

.request_info--form {
  background: #fff;
  width: 360px;
  height: 680px;
  box-shadow: 0px 3px 30px rgba(47, 47, 47, 0.2);
}
.request_info--form.home {
  text-align: center;
  margin-top: 149px;
  padding-top: 20px;
  overflow-y: hidden;
  padding-bottom: 20px;
}
.request_info--form.service {
  text-align: center;
  padding-top: 20px;
  overflow-y: hidden;
  padding-bottom: 20px;
}
.request_info--form.white-pepar {
  text-align: center;
  padding-top: 38px;
  padding-bottom: 80px;
  overflow-y: hidden;
}
@media screen and (max-width: 767px) {
  .request_info--form {
    display: none;
  }
}
.request_info--form a {
  color: #2f2f2f;
  font-weight: 500;
}

.request_info--form-read {
  font-size: 12px;
  color: #9f9f9f;
}
@media screen and (max-width: 767px) {
  .request_info--form-read {
    font-size: 14px;
    font-size: 3.7333333333vw;
  }
}

.complete-wrpper {
  width: 680px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .complete-wrpper {
    width: 89.33%;
  }
}

.complete-message-read {
  font-size: 36px;
  font-weight: bold;
  text-align: center;
  margin-bottom: 24px;
  padding-top: 100px;
}
@media screen and (max-width: 767px) {
  .complete-message-read {
    font-size: 24px;
    font-size: 6.4vw;
  }
}

.complete-message-read-2 {
  font-size: 14px;
  color: #9f9f9f;
  text-align: center;
  margin-bottom: 32px;
}
@media screen and (max-width: 767px) {
  .complete-message-read-2 {
    font-size: 12px;
    font-size: 3.2vw;
  }
}

.complete-img {
  width: 400px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .complete-img {
    width: 100%;
  }
}

.page-template-page-complete .header--contents {
  display: none;
}
.page-template-page-complete .footer--contents {
  display: none;
}

/* Slider */
.slick-loading .slick-list {
  background: #fff url("./ajax-loader.gif") center center no-repeat;
}

/* Icons */
@font-face {
  font-family: "slick";
  src: url("./fonts/slick.eot");
  src: url("./fonts/slick.eot?#iefix") format("embedded-opentype"), url("./fonts/slick.woff") format("woff"), url("./fonts/slick.ttf") format("truetype"), url("./fonts/slick.svg#slick") format("svg");
  font-weight: normal;
  font-style: normal;
}
/* Arrows */
.slick-prev,
.slick-next {
  position: absolute;
  display: block;
  height: 20px;
  width: 20px;
  line-height: 0px;
  font-size: 0px;
  cursor: pointer;
  background: transparent;
  color: transparent;
  top: 50%;
  transform: translate(0, -50%);
  padding: 0;
  border: none;
  outline: none;
}
.slick-prev:hover, .slick-prev:focus,
.slick-next:hover,
.slick-next:focus {
  outline: none;
  background: transparent;
  color: transparent;
}
.slick-prev:hover:before, .slick-prev:focus:before,
.slick-next:hover:before,
.slick-next:focus:before {
  opacity: 1;
}
.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before {
  opacity: 0.25;
}
.slick-prev:before,
.slick-next:before {
  font-family: "slick";
  font-size: 20px;
  line-height: 1;
  color: white;
  opacity: 0.75;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-prev {
  left: -25px;
}
[dir=rtl] .slick-prev {
  left: auto;
  right: -25px;
}
.slick-prev:before {
  content: "";
}
[dir=rtl] .slick-prev:before {
  content: "";
}

.slick-next {
  right: -25px;
}
[dir=rtl] .slick-next {
  left: -25px;
  right: auto;
}
.slick-next:before {
  content: "";
}
[dir=rtl] .slick-next:before {
  content: "";
}

/* Dots */
.slick-dotted.slick-slider {
  margin-bottom: 30px;
}

.slick-dots {
  position: absolute;
  bottom: -25px;
  list-style: none;
  display: block;
  text-align: center;
  padding: 0;
  margin: 0;
  width: 100%;
}
.slick-dots li {
  position: relative;
  display: inline-block;
  height: 20px;
  width: 20px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}
.slick-dots li button {
  border: 0;
  background: transparent;
  display: block;
  height: 20px;
  width: 20px;
  outline: none;
  line-height: 0px;
  font-size: 0px;
  color: transparent;
  padding: 5px;
  cursor: pointer;
}
.slick-dots li button:hover, .slick-dots li button:focus {
  outline: none;
}
.slick-dots li button:hover:before, .slick-dots li button:focus:before {
  opacity: 1;
}
.slick-dots li button:before {
  position: absolute;
  top: 0;
  left: 0;
  content: "•";
  width: 20px;
  height: 20px;
  font-family: "slick";
  font-size: 6px;
  line-height: 20px;
  text-align: center;
  color: black;
  opacity: 0.25;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.slick-dots li.slick-active button:before {
  color: black;
  opacity: 0.75;
}

/* Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0;
}
.slick-list:focus {
  outline: none;
}
.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.slick-track:before, .slick-track:after {
  content: "";
  display: table;
}
.slick-track:after {
  clear: both;
}
.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none;
}
[dir=rtl] .slick-slide {
  float: right;
}
.slick-slide img {
  display: block;
}
.slick-slide.slick-loading img {
  display: none;
}
.slick-slide.dragging img {
  pointer-events: none;
}
.slick-initialized .slick-slide {
  display: block;
}
.slick-loading .slick-slide {
  visibility: hidden;
}
.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
  display: none;
}

/*banner*/
.banner-pc {
  position: fixed;
  right: 50%;
  bottom: 10px;
  width: 320px;
  z-index: 999;
  margin-right: -160px;
}

.banner-pc a {
  display: block;
}

.banner-pc a:hover {
  opacity: 0.8;
}

.banner-pc .close-btn {
  background-color: #999;
  color: #fff;
  cursor: pointer;
  width: 20px;
  font-size: 14px;
  line-height: 20px;
  text-align: center;
  float: right;
}

.banner-sp {
  position: fixed;
  right: 50%;
  top: 100px;
  width: 290px;
  z-index: 99;
  margin-right: -145px;
}

.banner-sp a {
  display: block;
}

.banner-sp a:hover {
  opacity: 0.8;
}

.banner-sp .close-btn {
  background-color: #999;
  color: #fff;
  cursor: pointer;
  width: 20px;
  font-size: 14px;
  line-height: 20px;
  text-align: center;
  float: right;
}

@media screen and (min-width: 821px) {
  .banner-pc {
    display: block;
  }
  .banner-sp {
    display: none;
  }
}
@media screen and (max-width: 820px) {
  .banner-pc {
    display: none;
  }
  .banner-sp {
    display: block;
  }
}
/* Home
   ========================================================================== */
.header--hero_img {
  background-image: url(../img/top_img.png);
  background-repeat: no-repeat;
  background-position: center top;
  min-width: 1200px;
}
@media screen and (max-width: 767px) {
  .header--hero_img {
    background-image: url(../img/top_sp_img.png);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: contain;
    width: 100%;
    min-width: 100%;
  }
}

.service--hero_img {
  background-image: url(../img/service_img.png);
  background-repeat: no-repeat;
  background-position: center top;
  background-size: 110%;
  min-width: 1200px;
}
@media screen and (max-width: 767px) {
  .service--hero_img {
    background: none;
    width: 100%;
    min-width: 100%;
  }
}

.hero--contents,
.service-hero--contents {
  display: flex;
  justify-content: space-between;
  width: 1200px;
  margin: 0 auto 80px auto;
}
@media screen and (max-width: 767px) {
  .hero--contents,
  .service-hero--contents {
    width: 100%;
    margin-bottom: 0px;
  }
  .service-hero--contents {
    margin-bottom: 64px;
  }
  .hero--appeal {
    width: 89.33%;
    margin-left: auto;
    margin-right: auto;
  }
  .service-hero--appeal {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}

.hero--appeal-title {
  color: #0075a2;
  font-size: 56px;
  font-weight: bold;
  margin-top: 336px;
  line-height: 1.3;
  margin-bottom: 24px;
}
@media screen and (max-width: 767px) {
  .hero--appeal-title {
    font-size: 40px;
    font-size: 10.6666666667vw;
    width: 100%;
    margin: 240px auto 8px auto;
  }
}
.hero--appeal-title.smlStyle {
  font-size: 48px;
}
@media screen and (max-width: 767px) {
  .hero--appeal-title.smlStyle {
    font-size: 36px;
    font-size: 9.6vw;
  }
}

.service-hero--appeal-title {
  color: #0075a2;
  font-size: 54px;
  font-weight: 500;
  margin: 0 auto 20px auto;
  line-height: 1.3;
}
.service-hero--appeal-title .smlStyle {
  font-size: 54px;
}
@media screen and (max-width: 767px) {
  .service-hero--appeal-title .smlStyle {
    font-size: 36px;
    font-size: 9.6vw;
  }
  .service-hero--appeal-title {
    font-size: 42px;
    font-size: 11.2vw;
    width: 89.33%;
    margin-bottom: 40px;
  }
}

.hero--appeal-sub_title,
.service-hero--appeal-sub_title {
  font-size: 24px;
  font-weight: normal;
  margin-bottom: 32px;
}
@media screen and (max-width: 767px) {
  .hero--appeal-sub_title,
  .service-hero--appeal-sub_title {
    font-size: 18px;
    font-size: 4.8vw;
    margin-bottom: 16px;
  }
  .hero--appeal-list {
    margin-bottom: 32px;
  }
}
.hero--appeal-list li {
  display: flex;
  align-items: center;
  font-size: 20px;
  font-style: italic;
  height: auto;
  margin-bottom: 16px;
}
@media screen and (max-width: 767px) {
  .hero--appeal-list li {
    font-size: 16px;
    font-size: 4.2666666667vw;
    flex-wrap: wrap;
    height: auto;
    margin-bottom: 8px;
  }
}
.hero--appeal-list.boldStyle {
  font-weight: bold;
}

.about--contents {
  position: relative;
  width: 1200px;
  margin: 252px auto 0 auto;
  padding-left: 57px;
}
@media screen and (max-width: 767px) {
  .about--contents {
    width: 89.33%;
    padding: 0;
    margin-top: 128px;
  }
}

.section--abouttitle-bg {
  position: absolute;
  top: -120px;
  left: -70px;
  width: 806px;
  height: auto;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .section--abouttitle-bg {
    display: none;
  }
}

.about--contents-inner {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .about--contents-inner {
    display: block;
  }
}

.about--contents-inner-read {
  font-size: 18px;
  width: 413px;
  margin-top: 226px;
  margin-bottom: 56px;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .about--contents-inner-read {
    text-align: center;
    width: 82.38%;
    font-size: 16px;
    font-size: 4.2666666667vw;
    margin: 80px auto 0 auto;
  }
}
.about--contents-inner-read.boldStyle {
  font-weight: bold;
}

.about--contents-flow {
  width: 526px;
  height: 549px;
  margin-top: 59px;
  margin-bottom: 146px;
}
@media screen and (max-width: 767px) {
  .about--contents-flow {
    width: 100%;
    height: auto;
    margin: 80px 0;
  }
}

.section--sub_title {
  font-family: "Montserrat", sans-serif;
  text-align: left;
  font-size: 16px;
  color: #0075a2;
  margin-bottom: 8px;
}
@media screen and (max-width: 767px) {
  .section--sub_title {
    font-size: 16px;
    font-size: 4.2666666667vw;
  }
}

.media--contents {
  background: #f7f7f7;
  width: 100%;
  padding: 160px 0;
}
.media--contents .post--coverage-list {
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  .media--contents {
    margin: 128px 0 0 0;
    padding-top: 128px;
  }
}

.media--contents-inner {
  text-align: center;
  width: 1048px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .media--contents-inner {
    width: 89.33%;
    margin-left: auto;
    margin-right: auto;
  }
}

.post--coverage-list {
  display: flex;
  justify-content: space-between;
  margin: 64px 0;
}
@media screen and (max-width: 767px) {
  .post--coverage-list {
    margin: 88px 0;
  }
}

.post--coverage-case {
  text-align: left;
  width: 328px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .post--coverage-case {
    width: 100%;
  }
}
.post--coverage-case a {
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  position: absolute;
  z-index: 1;
}
.post--coverage-case:hover img {
  transform: scale(1.1);
}
@media screen and (max-width: 767px) {
  .post--coverage-case:hover img {
    transform: none;
  }
}

.post--coverage-case--thumbnail {
  display: flex;
  align-items: center;
  width: 328px;
  height: auto;
  aspect-ratio: 328/172;
  overflow: hidden;
  border-bottom-right-radius: 25px;
  margin-bottom: 24px;
}
@media screen and (max-width: 767px) {
  .post--coverage-case--thumbnail {
    width: 100%;
    height: auto;
    aspect-ratio: 335/175;
  }
  .post--coverage-caption {
    width: 82.38%;
    margin-left: auto;
    margin-right: auto;
  }
}

.post--coverage-caption-wrapper {
  display: flex;
  justify-content: flex-start;
  margin-bottom: 8px;
}

.post--coverage-date {
  font-family: "Montserrat", sans-serif;
  display: inline-block;
  font-size: 16px;
}
@media screen and (max-width: 767px) {
  .post--coverage-date {
    font-size: 16px;
    font-size: 4.2666666667vw;
  }
  .case--carousel-detail .post--coverage-category {
    margin-left: 0;
  }
}

.post--coverage-category {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #9f9f9f;
  border: 1px solid #9f9f9f;
  border-radius: 25px;
  margin-left: 14px;
  padding: 0 13px;
  height: 26px;
}
@media screen and (max-width: 767px) {
  .post--coverage-category {
    font-size: 14px;
    font-size: 3.7333333333vw;
    display: inline-block;
    margin-left: 17px;
    padding: 1px 13px;
    height: auto;
  }
}

.post--coverage-caption-title {
  font-size: 16px;
  font-weight: 500;
}

.what_we_do--illust-read {
  display: block;
  width: 363px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .what_we_do--illust-read {
    font-size: 16px;
    font-size: 4.2666666667vw;
    width: 100%;
  }
}

.what_we_do--contents {
  width: 1200px;
  margin: 0 auto;
  padding: 240px 0;
}
@media screen and (max-width: 767px) {
  .what_we_do--contents {
    width: 89.33%;
    padding: 128px 0;
  }
}

.what_we_do--illust-list {
  width: 100%;
  display: flex;
  justify-content: space-between;
  margin-top: 160px;
}
@media screen and (max-width: 767px) {
  .what_we_do--illust-list {
    display: block;
    margin-top: 88px;
  }
}
.what_we_do--illust-list li {
  width: 370px;
  height: auto;
}
@media screen and (max-width: 767px) {
  .what_we_do--illust-list li {
    width: 100%;
    margin-bottom: 80px;
  }
  .what_we_do--illust-list li:last-child {
    margin-bottom: 0;
  }
}

.what_we_do--illust-thumbnail {
  display: block;
  width: 370px;
  height: 478px;
  overflow: hidden;
  margin: 0 auto 56px auto;
  border-bottom-right-radius: 25px;
  box-shadow: 0px 3px 30px rgba(47, 47, 47, 0.2);
}
@media screen and (max-width: 767px) {
  .what_we_do--illust-thumbnail {
    width: 100%;
    height: auto;
    margin-bottom: 32px;
  }
}

.what_we_do--illust-title {
  display: block;
  font-size: 18px;
  font-weight: 500;
  text-align: center;
  margin-bottom: 32px;
}
@media screen and (max-width: 767px) {
  .what_we_do--illust-title {
    font-size: 20px;
    font-size: 5.3333333333vw;
  }
}

.strength--contents {
  background: #f7f7f7;
  width: 100%;
  padding: 240px 0;
}
@media screen and (max-width: 767px) {
  .strength--contents {
    padding: 128px 0;
  }
}

.strength--contents-inner {
  width: 1200px;
  margin: 0 auto;
  position: relative;
}
@media screen and (max-width: 767px) {
  .strength--contents-inner {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}

.section--strengthtitle-bg {
  position: absolute;
  top: -115px;
  left: 160px;
  width: 1220px;
  height: auto;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .section--strengthtitle-bg {
    display: none;
  }
}

.section--service-bg {
  position: absolute;
  top: 125px;
  left: -50px;
  height: auto;
  z-index: 1;
  width: 770px;
}
@media screen and (max-width: 767px) {
  .section--service-bg {
    display: none;
  }
}

.strength--illust {
  width: 265px;
  height: 265px;
  overflow: hidden;
  position: absolute;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .strength--illust {
    width: 100%;
    height: auto;
    position: static;
  }
}

.strength--illust-list {
  width: 100%;
  display: flex;
  justify-content: space-between;
  margin-top: 160px;
}
@media screen and (max-width: 767px) {
  .strength--illust-list {
    flex-wrap: wrap;
    margin-top: 101px;
    width: 92%;
    margin-left: auto;
    margin-right: auto;
  }
}
.strength--illust-list li {
  width: 265px;
  height: 265px;
}
@media screen and (max-width: 767px) {
  .strength--illust-list li {
    width: 48%;
    height: auto;
    margin-bottom: 26px;
    position: relative;
  }
}

.strength--illust-caption {
  text-align: center;
  font-size: 18px;
  margin-top: 161px;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .strength--illust-caption {
    font-size: 14px;
    font-size: 3.7333333333vw;
    margin-top: 0;
    line-height: 1.3;
    position: absolute;
    top: calc(100% - 21vw);
    width: 100%;
  }
}

.strength--illust-caption--emphasis {
  color: #0075a2;
}

.cost--contents {
  text-align: center;
  width: 732px;
  position: relative;
  padding-top: 232px;
  padding-bottom: 164px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .cost--contents {
    width: 89.33%;
    padding-top: 120px;
    padding-bottom: 212px;
  }
}

.section--costtitle-bg {
  position: absolute;
  top: 120px;
  left: -240px;
  width: 599px;
  height: auto;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .section--costtitle-bg {
    display: none;
  }
}

.cost--contents-read {
  text-align: center;
  font-size: 18px;
  line-height: 2;
  margin-top: 104px;
  margin-bottom: 90px;
}
@media screen and (max-width: 767px) {
  .cost--contents-read {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    font-size: 16px;
    font-size: 4.2666666667vw;
    margin-top: 60px;
    margin-bottom: 83px;
  }
}

.section--graph_illust {
  width: 596px;
  height: 552px;
  overflow: hidden;
  margin: 0 auto 25px auto;
}
@media screen and (max-width: 767px) {
  .section--graph_illust {
    width: 100%;
    height: auto;
  }
}

.section--graph_illust-caption {
  font-size: 16px;
  margin-bottom: 56px;
}
@media screen and (max-width: 767px) {
  .section--graph_illust-caption {
    font-size: 16px;
    font-size: 4.2666666667vw;
    text-align: left;
    margin-bottom: 82px;
  }
}

.information--contents {
  text-align: center;
  width: 1048px;
  margin: 0 auto;
  padding: 136px 0;
}
@media screen and (max-width: 767px) {
  .information--contents {
    width: 89.33%;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 128px;
  }
}

.seminar--contents {
  text-align: center;
  width: 1048px;
  margin: 0 auto;
  padding-bottom: 164px;
}
@media screen and (max-width: 767px) {
  .seminar--contents {
    width: 89.33%;
    padding-bottom: 207px;
  }
}

.case--contents {
  text-align: center;
  width: 100%;
  padding-bottom: 240px;
}
@media screen and (max-width: 767px) {
  .case--contents {
    padding-bottom: 80px;
  }
}

.case--carousel-wrapper {
  margin-top: 160px;
}
@media screen and (max-width: 767px) {
  .case--carousel-wrapper {
    width: 100%;
    margin-top: 72px;
  }
}

.case--carousel-wrapper--inner {
  width: 1048px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .case--carousel-wrapper--inner {
    width: 89.33%;
  }
}

.case--carousel-wrapper--list {
  display: flex;
  justify-content: space-between;
  height: 750px;
  margin-bottom: 55px;
}
@media screen and (max-width: 767px) {
  .case--carousel-wrapper--list {
    height: auto;
    margin-bottom: 80px;
  }
}

.case--carousel-card {
  width: 732px !important;
  height: 750px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .case--carousel-card {
    width: 100% !important;
    height: auto;
    margin-left: 0;
  }
}
.case--carousel-card img {
  background: #000;
}
.case--carousel-card a {
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  position: absolute;
  z-index: 1;
}
.case--carousel-card:hover img {
  transform: scale(1.1);
}

.slick-current .case--carousel-thumbnail-mask {
  display: none;
}

.case--carousel-card * {
  box-sizing: border-box;
  transition: all 0.25s ease;
}

.case--carousel-thumbnail {
  display: block;
  width: 732px;
  height: 482px;
  border-bottom-right-radius: 25px;
  overflow: hidden;
  margin-bottom: 88px;
  box-shadow: 0px 3px 20px rgba(47, 47, 47, 0.2);
}
@media screen and (max-width: 767px) {
  .case--carousel-thumbnail {
    width: 100%;
    height: auto;
    aspect-ratio: 375/247;
    margin-bottom: 30px;
  }
}

.case--carousel-thumbnail-mask {
  display: block;
  background-color: rgba(0, 0, 0, 0.6);
  width: 732px;
  height: 482px;
  border-bottom-right-radius: 25px;
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (max-width: 767px) {
  .case--carousel-thumbnail-mask {
    width: 100%;
    height: auto;
  }
}

.case--carousel-body {
  width: 585px;
  margin: 0 auto;
  position: relative;
}
@media screen and (max-width: 767px) {
  .case--carousel-body {
    width: 100%;
    margin: 0;
  }
}

.slider {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .slider {
    margin: 0 auto 80px auto;
  }
}

.slick-slide {
  margin-left: 78px;
  margin-right: 78px;
}
@media screen and (max-width: 767px) {
  .slick-slide {
    margin-left: auto;
    margin-right: auto;
  }
}

.case--carousel-number {
  font-family: "Montserrat", sans-serif;
  font-size: 220px;
  font-weight: normal;
  position: absolute;
  top: -130px;
  left: 0;
  color: #f7f7f7;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .case--carousel-number {
    top: -100px;
    right: 20px;
    left: auto;
    font-size: 194px;
    font-size: 51.7333333333vw;
  }
}

.case--carousel-title {
  width: 495px;
  font-size: 18px;
  margin-bottom: 16px;
  margin-left: 90px;
  text-align: left;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .case--carousel-title {
    width: 73.33%;
    font-size: 16px;
    font-size: 4.2666666667vw;
    margin-left: auto;
    margin-right: auto;
  }
}

.faq--title-line {
  width: 586px;
}
@media screen and (max-width: 767px) {
  .faq--title-line {
    width: 100%;
  }
}

.case--carousel-detail {
  display: flex;
  justify-content: flex-start;
  margin-left: 90px;
}
@media screen and (max-width: 767px) {
  .case--carousel-detail {
    width: 73.33%;
    text-align: left;
    display: block;
    margin-left: auto;
    margin-right: auto;
  }
  .case--carousel-detail--name {
    font-size: 14px;
    font-size: 3.7333333333vw;
    margin-bottom: 10px;
  }
}

.faq--contents {
  text-align: center;
  width: 732px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .faq--contents {
    width: 89.33%;
    padding-bottom: 80px;
  }
}

.faq--list {
  text-align: left;
  margin-top: 64px;
  margin-bottom: 136px;
}
@media screen and (max-width: 767px) {
  .faq--list {
    margin-top: 80px;
    margin-bottom: 80px;
  }
}

.faq--title {
  display: flex;
  justify-content: flex-start;
}
@media screen and (max-width: 767px) {
  .faq--title {
    font-size: 16px;
    font-size: 4.2666666667vw;
  }
}

.faq--body {
  cursor: pointer;
  padding: 40px 20px 38px 8px;
  border-top: 1px solid #9f9f9f;
  font-size: 16px;
}
@media screen and (max-width: 767px) {
  .faq--body {
    font-size: 16px;
    font-size: 4.2666666667vw;
    padding: 32px 16px 32px 0px;
  }
}
.faq--body:hover {
  background: #f9f9f9;
}
.faq--body > .faq--answer {
  display: none;
}
.faq--body:last-child {
  border-bottom: 1px solid #9f9f9f;
  padding-bottom: 38px;
}

.faq--answer {
  margin-top: 16px;
  margin-left: 71px;
  width: 586px;
}
@media screen and (max-width: 767px) {
  .faq--answer {
    font-size: 16px;
    font-size: 4.2666666667vw;
    width: 100%;
    margin-left: 34px;
    padding-right: 60px;
  }
}
.faq--answer .emphasis {
  color: #0075a2;
}

.news--contents {
  text-align: center;
  width: 100%;
  background-color: #f7f7f7;
  overflow: hidden;
  border-bottom-right-radius: 150px;
  padding: 136px 0;
}
@media screen and (max-width: 767px) {
  .news--contents {
    border-bottom-right-radius: 70px;
    padding: 80px 0;
  }
}

.news--contents-inner {
  display: flex;
  justify-content: space-between;
  width: 1048px;
  margin: 0 auto;
  padding: 0 0 64px 0;
}
@media screen and (max-width: 767px) {
  .news--contents-inner {
    width: 89.33%;
    display: block;
    padding: 0 0 80px 0;
  }
}

.news--contents-titlearea {
  width: 160px;
}
@media screen and (max-width: 767px) {
  .news--contents-titlearea {
    width: 100%;
  }
}

.section-news--sub_title {
  font-family: "Montserrat", sans-serif;
  text-align: left;
  font-size: 16px;
  color: #0075a2;
}
@media screen and (max-width: 767px) {
  .section-news--sub_title {
    font-size: 16px;
    font-size: 4.2666666667vw;
  }
}

.section-news--title {
  text-align: left;
  font-size: 26px;
  font-weight: 500;
}

.section-news--list {
  font-family: "Montserrat", sans-serif;
  width: 732px;
  border-top: 1px solid #9f9f9f;
}
@media screen and (max-width: 767px) {
  .section-news--list {
    width: 100%;
    margin-top: 80px;
  }
}
.section-news--list li {
  border-bottom: 1px solid #9f9f9f;
}
.section-news--list li a {
  display: flex;
  justify-content: space-between;
  padding: 32px 24px 32px 8px;
}
@media screen and (max-width: 767px) {
  .section-news--list li a {
    display: block;
    position: relative;
    padding: 40px 16px;
    text-align: left;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}

.section-news--date {
  display: inline-block;
  font-size: 16px;
}
@media screen and (max-width: 767px) {
  .section-news--date {
    font-size: 16px;
    font-size: 4.2666666667vw;
    margin-bottom: 18px;
  }
}

.section-news--readarea {
  display: flex;
  align-items: normal;
}
@media screen and (max-width: 767px) {
  .section-news--readarea {
    display: block;
  }
}

.section-news--new {
  display: inline-block;
  font-size: 14px;
  color: #cc0011;
  font-style: italic;
  margin-left: 15px;
  width: 37px;
}
@media screen and (max-width: 767px) {
  .section-news--new {
    font-size: 14px;
    font-size: 3.7333333333vw;
  }
}

.section-news--body {
  text-align: left;
  display: inline-block;
  margin-left: 38px;
  width: 465px;
}
@media screen and (max-width: 767px) {
  .section-news--body {
    font-size: 16px;
    font-size: 4.2666666667vw;
    margin-left: 0;
    width: 100%;
  }
}

.request_info--contents {
  text-align: center;
  padding-top: 236px;
  padding-bottom: 176px;
  width: 445px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .request_info--contents {
    width: 100%;
    padding-top: 125px;
    padding-bottom: 0;
  }
}
.request_info--contents.notfound {
  padding-top: 203px;
}
@media screen and (max-width: 767px) {
  .request_info--contents.notfound {
    padding-top: 100px;
  }
}

.request_info--contents-read {
  text-align: center;
  font-size: 18px;
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  .request_info--contents-read {
    font-size: 18px;
    font-size: 4.8vw;
    margin-bottom: 40px;
  }
}

.footer--hero_img {
  background-image: url(../img/footer_img.png);
  background-repeat: no-repeat;
  background-position: center top;
  padding-top: 320px;
}
@media screen and (max-width: 767px) {
  .footer--hero_img {
    background-image: url(../img/footer_sp_img.png);
    background-repeat: no-repeat;
    background-position: center 108px;
    background-size: contain;
    padding-top: 272px;
  }
}

.slide_img {
  width: 100%;
  height: 250px;
  overflow: hidden;
}
.slide_img img {
  width: 100%;
  height: auto;
}

.slide--logo {
  display: flex;
  justify-content: flex-start;
}
.slide--logo li {
  width: 237px;
  height: 82px;
}

.loopSlider {
  height: 82px;
  overflow: hidden;
  position: relative;
  margin-bottom: 233px;
}

.loopSlider .loopslider_wrap {
  height: 82px;
  display: flex;
  position: absolute;
  top: 0;
  left: 0;
}

.loopSlider .loopslider_wrap ul {
  display: flex;
}

.loopSlider .loopslider_wrap ul li {
  width: 237px;
}

.section--movie {
  background: #9f9f9f;
  width: 1080px;
  height: 608px;
  margin: 0 auto 236px auto;
}

.home .breadcrumbs {
  display: none;
}

.service-hero--wrapper {
  position: relative;
}
@media screen and (max-width: 767px) {
  .service-hero--wrapper {
    width: 100%;
    position: static;
    margin-left: auto;
    margin-right: auto;
  }
}

.service-hero--appeal-read {
  font-size: 20px;
  margin-top: 40px;
  margin-bottom: 16px;
}
@media screen and (max-width: 767px) {
  .service-hero--appeal-read {
    font-size: 18px;
    font-size: 4.8vw;
    margin-top: 16px;
    width: 89.33%;
    margin-left: auto;
    margin-right: auto;
  }
}

.service-hero--img {
  width: 787px;
  height: auto;
  position: absolute;
  top: 170px;
  left: -90px;
}
@media screen and (max-width: 767px) {
  .service-hero--img {
    width: 100%;
    position: static;
  }
}

.service-what_we_do--contents {
  background: #f7f7f7;
  width: 100%;
  padding: 164px 0;
}
@media screen and (max-width: 767px) {
  .service-what_we_do--contents {
    padding-top: 64px;
    padding-bottom: 160px;
  }
}

.service-what_we_do--contents-inner {
  width: 1048px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .service-what_we_do--contents-inner {
    width: 100%;
  }
}

.service-what_we_do--line {
  display: flex;
  justify-content: space-between;
  width: 981px;
}
.service-what_we_do--line + .service-what_we_do--line {
  margin-top: 130px;
}
@media screen and (max-width: 767px) {
  .service-what_we_do--line + .service-what_we_do--line {
    margin-top: 68px;
  }
}
.service-what_we_do--line:nth-of-type(2) {
  flex-direction: row-reverse;
  margin-left: 67px;
}
@media screen and (max-width: 767px) {
  .service-what_we_do--line:nth-of-type(2) {
    flex-direction: column;
    margin-left: 0;
  }
  .service-what_we_do--line {
    width: 100%;
    flex-direction: column;
  }
}

.service-what_we_do--line-img {
  width: 495px;
  height: 339px;
  overflow: hidden;
  box-shadow: 0px 3px 20px rgba(47, 47, 47, 0.2);
}
@media screen and (max-width: 767px) {
  .service-what_we_do--line-img {
    width: 89.33%;
    height: auto;
    margin-left: auto;
    margin-right: auto;
  }
}

.service-what_we_do--line-caption {
  padding-top: 64px;
  width: 417px;
}
@media screen and (max-width: 767px) {
  .service-what_we_do--line-caption {
    padding-top: 38px;
    width: 100%;
  }
}

.service-what_we_do--line-point {
  font-family: "Montserrat", sans-serif;
  font-size: 16px;
  color: #0075a2;
  margin-bottom: 34px;
}
@media screen and (max-width: 767px) {
  .service-what_we_do--line-point {
    font-size: 16px;
    font-size: 4.2666666667vw;
    text-align: center;
    margin-bottom: 17px;
  }
}

.service-what_we_do--line-title {
  font-size: 20px;
  font-weight: 500;
  margin-bottom: 34px;
}
@media screen and (max-width: 767px) {
  .service-what_we_do--line-title {
    font-size: 18px;
    font-size: 4.8vw;
    text-align: center;
    margin-bottom: 18px;
  }
}

.service-what_we_do--line-read {
  font-size: 16px;
}
@media screen and (max-width: 767px) {
  .service-what_we_do--line-read {
    font-size: 16px;
    font-size: 4.2666666667vw;
    width: 89.33%;
    margin-left: auto;
    margin-right: auto;
  }
}

.service-what_we_do--contents-inner .btn--large {
  margin: 169px auto 0 auto;
}
@media screen and (max-width: 767px) {
  .service-what_we_do--contents-inner .btn--large {
    margin-top: 145px;
  }
}

.service-reason--wrapper {
  width: 1200px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 233px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .service-reason--wrapper {
    width: 100%;
    padding-top: 100px;
  }
}
.service-reason--wrapper .strength--illust-list {
  margin-top: 0;
}

/* Blog
   ========================================================================== */
figure {
  width: 100%;
  margin: 0;
  padding: 0;
}

.blog--wrapper {
  width: 1200px;
  margin: 60px auto 0 auto;
}
@media screen and (max-width: 767px) {
  .blog--wrapper {
    width: 100%;
    margin: 0 0 82px 0;
  }
}

.blog--wrapper-inner {
  display: flex;
  justify-content: space-between;
  position: relative;
}
@media screen and (max-width: 767px) {
  .blog--wrapper-inner {
    flex-direction: column;
  }
}

.blog--contents {
  width: 740px;
  margin-left: 76px;
}
@media screen and (max-width: 767px) {
  .blog--contents {
    width: 89.33%;
    margin: 50px auto 0 auto;
  }
}
.blog--contents p {
  font-size: 16px;
  line-height: 1.88;
  margin-bottom: 16px;
}
@media screen and (max-width: 767px) {
  .blog--contents p {
    font-size: 16px;
    font-size: 4.2666666667vw;
  }
}
.blog--contents p + h3 {
  margin-top: 40px;
}
.blog--contents p a {
  color: #0075a2;
  text-decoration: underline;
}
.blog--contents h2 {
  color: #5c5c5c;
  font-size: 24px;
  font-weight: bold;
  margin: 48px 0 24px 0;
}
@media screen and (max-width: 767px) {
  .blog--contents h2 {
    font-size: 20px;
    font-size: 5.3333333333vw;
  }
}
.blog--contents h3 {
  color: #5c5c5c;
  font-size: 20px;
  font-weight: normal;
  margin-bottom: 28px;
}
@media screen and (max-width: 767px) {
  .blog--contents h3 {
    font-size: 18px;
    font-size: 4.8vw;
  }
}
.blog--contents ul li {
  list-style-type: disc;
  margin-left: 1em;
  margin-bottom: 8px;
}
.blog--contents ul + h3 {
  margin-top: 40px;
}

.blog--subcontents {
  background: #fff;
  width: 308px;
}
@media screen and (max-width: 767px) {
  .blog--subcontents {
    display: none;
  }
}

.blog--bnr {
  width: 550px;
  height: auto;
  margin: 164px auto;
}
@media screen and (max-width: 767px) {
  .blog--bnr {
    width: 89.33%;
    height: auto;
    margin: 88px auto 100px auto;
  }
}

.blog--bnr-list {
  margin-bottom: 56px;
}
.blog--bnr-list li + li {
  margin-top: 20px;
}
.blog--bnr-list li a {
  text-align: center;
  line-height: 113px;
  color: #fff;
  background: #9f9f9f;
  display: block;
  width: 308px;
  height: 113px;
}

.blog--frequentlyread {
  padding-top: 48px;
}

.blog--frequentlyread-title {
  font-size: 16px;
  color: #000;
}

.blog--frequentlyread-list {
  width: 308px;
  margin-top: 18px;
}
.blog--frequentlyread-list li {
  display: flex;
  justify-content: flex-start;
  position: relative;
}
.blog--frequentlyread-list li:hover img {
  transform: scale(1.1);
}
@media screen and (max-width: 767px) {
  .blog--frequentlyread-list li:hover img {
    transform: none;
  }
}
.blog--frequentlyread-list li a {
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  position: absolute;
  z-index: 1;
}
.blog--frequentlyread-list li + li {
  margin-top: 12px;
}

.blog--frequentlyread-list li * {
  box-sizing: border-box;
  transition: all 0.25s ease;
}

.blog--frequentlyread-list-title {
  width: 188px;
  font-size: 16px;
  color: #9f9f9f;
  margin-left: 15px;
}

.blog--frequentlyread-list-thumbnail {
  width: 105px;
  height: 65px;
  overflow: hidden;
}

.blog--frequentlyread-bottom-list {
  display: flex;
  justify-content: space-between;
  margin-top: 61px;
}
@media screen and (max-width: 767px) {
  .blog--frequentlyread-bottom-list {
    flex-direction: column;
    margin-top: 83px;
  }
}

.blog--frequentlyread-bottom-card {
  width: 328px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .blog--frequentlyread-bottom-card {
    width: 100%;
  }
}
.blog--frequentlyread-bottom-card a {
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  position: absolute;
  z-index: 1;
}
.blog--frequentlyread-bottom-card:hover img {
  transform: scale(1.1);
}
@media screen and (max-width: 767px) {
  .blog--frequentlyread-bottom-card:hover img {
    transform: none;
  }
}

.blog--frequentlyread-bottom-thumbnail {
  display: block;
  width: 328px;
  height: 213px;
  border-bottom-right-radius: 30px;
  overflow: hidden;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .blog--frequentlyread-bottom-thumbnail {
    width: 100%;
    height: auto;
    aspect-ratio: 335/218;
  }
}

.blog--frequentlyread-bottom-caption {
  display: flex;
  justify-content: flex-start;
  margin-bottom: 10px;
}

.blog--frequentlyread-bottom-title {
  font-size: 16px;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .blog--frequentlyread-bottom-title {
    font-size: 16px;
    font-size: 4.2666666667vw;
  }
}

.blog--frequentlyread-bottom-wrapper {
  width: 1048px;
  margin: 0 auto 160px auto;
}
@media screen and (max-width: 767px) {
  .blog--frequentlyread-bottom-wrapper {
    width: 89.33%;
    margin: 0 auto;
  }
}

.page-template-page-blog-index .breadcrumbs {
  display: none;
}
@media screen and (max-width: 767px) {
  .page-template-page-blog-index .breadcrumbs {
    display: block;
  }
}
.page-template-page-blog-index .breadcrumbs-blog {
  font-size: 12px;
  color: #9f9f9f;
  position: absolute;
  top: -40px;
  left: 0;
}
.page-template-page-blog-index .breadcrumbs-blog a {
  color: #9f9f9f;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .page-template-page-blog-index .breadcrumbs-blog {
    display: none;
  }
}

.blog--subcontents.is-fixed {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
}

.wp-block-image {
  margin: 10px 0;
}

.single-post .wp-block-embed__wrapper {
  text-align: center;
}

.single-post iframe {
  margin-left: auto;
  margin-right: auto;
  background: #fff;
  border: 10px solid #f0f3f5;
  margin: 10px 0;
}
@media screen and (max-width: 767px) {
  .single-post iframe {
    width: 100%;
  }
}

/* Contact
   ========================================================================== */
.contact--contents {
  width: 100%;
  margin-top: 60px;
  padding-bottom: 0px;
}
@media screen and (max-width: 767px) {
  .contact--contents {
    padding-bottom: 0px;
  }
}

.contact--contents-inner {
  width: 630px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .contact--contents-inner {
    width: 100%;
  }
}

.contact--form_wrapper {
  width: 630px;
  margin: 42px auto 171px auto;
}
@media screen and (max-width: 767px) {
  .contact--form_wrapper {
    width: 89.33%;
    margin: 54px auto 0 auto;
  }
}

.page-template-page-contact .breadcrumbs {
  width: 630px;
}
@media screen and (max-width: 767px) {
  .page-template-page-contact .breadcrumbs {
    width: 89.33%;
  }
}

.contact--contents-iframe {
  width: 630px;
  height: 920px;
  border: none;
}
@media screen and (max-width: 767px) {
  .contact--contents-iframe {
    width: 100%;
    height: 940px;
  }
}

/* Contact
   ========================================================================== */
.request--contents {
  width: 100%;
  margin-top: 60px;
  padding-bottom: 0px;
}
@media screen and (max-width: 767px) {
  .request--contents {
    padding-bottom: 0;
  }
}

.request--contents-inner {
  width: 630px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .request--contents-inner {
    width: 100%;
  }
}

.request--form_wrapper {
  width: 630px;
  margin: 42px auto 171px auto;
}
@media screen and (max-width: 767px) {
  .request--form_wrapper {
    width: 89.33%;
    margin: 54px auto 0 auto;
  }
}

.page-template-page-document-request .breadcrumbs {
  width: 630px;
}
@media screen and (max-width: 767px) {
  .page-template-page-document-request .breadcrumbs {
    width: 89.33%;
  }
}

.request--contents-iframe {
  width: 630px;
  height: 920px;
  border: none;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .request--contents-iframe {
    width: 100%;
    height: 940px;
  }
}

/* White-paper
   ========================================================================== */
.single--white-paper-wrapper {
  display: flex;
  justify-content: space-between;
  width: 1200px;
  margin: 10px auto 152px auto;
}
@media screen and (max-width: 767px) {
  .single--white-paper-wrapper {
    width: 89.33%;
    flex-direction: column;
    margin: 0px auto 0 auto;
  }
}

.single--white-paper-body {
  padding-top: 50px;
  width: 681px;
}
@media screen and (max-width: 767px) {
  .single--white-paper-body {
    width: 100%;
  }
}
.single--white-paper-body p {
  font-size: 16px;
}
@media screen and (max-width: 767px) {
  .single--white-paper-body p {
    font-size: 16px;
    font-size: 4.2666666667vw;
  }
}

.single-caption-wrapper,
.blog--caption-wrapper {
  display: flex;
  justify-content: flex-start;
  margin-bottom: 52px;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .single-caption-wrapper,
  .blog--caption-wrapper {
    margin-bottom: 43px;
  }
  .single-entry-mobile {
    font-size: 16px;
    font-size: 4.2666666667vw;
  }
}

.post-type-archive-white-paper .breadcrumbs {
  display: none;
}
.post-type-archive-white-paper .breadcrumbs-white-paper {
  font-size: 12px;
  color: #9f9f9f;
  position: absolute;
  top: -40px;
  left: 0;
}
.post-type-archive-white-paper .breadcrumbs-white-paper a {
  color: #9f9f9f;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .post-type-archive-white-paper .breadcrumbs-white-paper {
    display: none;
  }
}

/* Success Story
   ========================================================================== */
.success-story--single-thumbnail {
  margin: 0 0 20px 0;
}
@media screen and (max-width: 767px) {
  .success-story--single-thumbnail {
    width: 100%;
    height: auto;
  }
}

.success-story--effect {
  text-align: center;
  font-size: 24px;
  font-weight: normal;
  border-bottom: 1px solid #ccc;
  margin-top: 40px;
  margin-left: 76px;
  padding-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .success-story--effect {
    width: 89.33%;
    margin: 40px auto 0 auto;
  }
}

.success-story--effect-wrapper {
  text-align: center;
  margin-bottom: 160px;
}

/* Case Study
   ========================================================================== */
.case-study--closing-message-wrapper {
  margin-top: 80px;
  margin-bottom: 160px;
}

.case-study--closing-message-title {
  text-align: center;
  font-size: 24px;
}
@media screen and (max-width: 767px) {
  .case-study--closing-message-title {
    width: 89.33%;
    margin-left: auto;
    margin-right: auto;
  }
}

/* Documents
   ========================================================================== */
.guidelines--contents,
.site-policy--contents,
.privacy-policy--contents {
  width: 740px;
  margin: 60px auto 160px auto;
}
@media screen and (max-width: 767px) {
  .guidelines--contents,
  .site-policy--contents,
  .privacy-policy--contents {
    width: 89.33%;
  }
}
.guidelines--contents h2,
.site-policy--contents h2,
.privacy-policy--contents h2 {
  font-size: 32px;
  text-align: center;
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  .guidelines--contents h2,
  .site-policy--contents h2,
  .privacy-policy--contents h2 {
    font-size: 32px;
    font-size: 8.5333333333vw;
  }
}
.guidelines--contents h3,
.site-policy--contents h3,
.privacy-policy--contents h3 {
  font-size: 18px;
  margin-bottom: 24px;
}
@media screen and (max-width: 767px) {
  .guidelines--contents h3,
  .site-policy--contents h3,
  .privacy-policy--contents h3 {
    font-size: 18px;
    font-size: 4.8vw;
  }
}
.guidelines--contents h4,
.site-policy--contents h4,
.privacy-policy--contents h4 {
  font-size: 16px;
  margin-bottom: 16px;
}
@media screen and (max-width: 767px) {
  .guidelines--contents h4,
  .site-policy--contents h4,
  .privacy-policy--contents h4 {
    font-size: 16px;
    font-size: 4.2666666667vw;
  }
}
.guidelines--contents p,
.site-policy--contents p,
.privacy-policy--contents p {
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .guidelines--contents p,
  .site-policy--contents p,
  .privacy-policy--contents p {
    font-size: 14px;
    font-size: 3.7333333333vw;
  }
}
.guidelines--contents p + h3,
.site-policy--contents p + h3,
.privacy-policy--contents p + h3 {
  margin-top: 40px;
}
.guidelines--contents p + h4,
.site-policy--contents p + h4,
.privacy-policy--contents p + h4 {
  margin-top: 40px;
}
.guidelines--contents ul,
.site-policy--contents ul,
.privacy-policy--contents ul {
  font-size: 14px;
  margin: 8px 0;
}
@media screen and (max-width: 767px) {
  .guidelines--contents ul,
  .site-policy--contents ul,
  .privacy-policy--contents ul {
    font-size: 14px;
    font-size: 3.7333333333vw;
  }
}
.guidelines--contents ul li,
.site-policy--contents ul li,
.privacy-policy--contents ul li {
  text-indent: -0.5em;
  margin-left: 1em;
  margin-bottom: 4px;
}
.guidelines--contents ul + h3,
.site-policy--contents ul + h3,
.privacy-policy--contents ul + h3 {
  margin-top: 40px;
}
.guidelines--contents ul + h4,
.site-policy--contents ul + h4,
.privacy-policy--contents ul + h4 {
  margin-top: 40px;
}
.guidelines--contents ol,
.site-policy--contents ol,
.privacy-policy--contents ol {
  font-size: 14px;
  margin: 8px 0;
}
@media screen and (max-width: 767px) {
  .guidelines--contents ol,
  .site-policy--contents ol,
  .privacy-policy--contents ol {
    font-size: 14px;
    font-size: 3.7333333333vw;
  }
}
.guidelines--contents ol li,
.site-policy--contents ol li,
.privacy-policy--contents ol li {
  text-indent: -0.5em;
  margin-left: 1em;
  margin-bottom: 4px;
}
.guidelines--contents ol + h3,
.site-policy--contents ol + h3,
.privacy-policy--contents ol + h3 {
  margin-top: 40px;
}
.guidelines--contents ol + h4,
.site-policy--contents ol + h4,
.privacy-policy--contents ol + h4 {
  margin-top: 40px;
}
.guidelines--contents dl,
.site-policy--contents dl,
.privacy-policy--contents dl {
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .guidelines--contents dl,
  .site-policy--contents dl,
  .privacy-policy--contents dl {
    font-size: 14px;
    font-size: 3.7333333333vw;
  }
}
.guidelines--contents dl + h3,
.site-policy--contents dl + h3,
.privacy-policy--contents dl + h3 {
  margin-top: 40px;
}
.guidelines--contents dl + h4,
.site-policy--contents dl + h4,
.privacy-policy--contents dl + h4 {
  margin-top: 40px;
}
.guidelines--contents dl dt,
.site-policy--contents dl dt,
.privacy-policy--contents dl dt {
  margin-bottom: 8px;
}
.guidelines--contents dl dd,
.site-policy--contents dl dd,
.privacy-policy--contents dl dd {
  margin-bottom: 16px;
}

.page-template-page-contents-guideline .breadcrumbs,
.page-template-page-site-tos .breadcrumbs,
.page-template-page-privacy-policy .breadcrumbs {
  width: 740px;
}
@media screen and (max-width: 767px) {
  .page-template-page-contents-guideline .breadcrumbs,
  .page-template-page-site-tos .breadcrumbs,
  .page-template-page-privacy-policy .breadcrumbs {
    width: 89.33%;
    margin-left: auto;
    margin-right: auto;
  }
}

.site-policy--contents ol li,
.privacy-policy--contents ol li {
  list-style-type: decimal;
}
.site-policy--contents dl,
.privacy-policy--contents dl {
  margin-left: 20px;
}
.site-policy--contents > ol > li,
.privacy-policy--contents > ol > li {
  margin-bottom: 16px;
}
.site-policy--contents > ol > li > ol > li,
.privacy-policy--contents > ol > li > ol > li {
  text-indent: 0;
}
.site-policy--contents > ol > li > ol > li > ol > li,
.privacy-policy--contents > ol > li > ol > li > ol > li {
  text-indent: 0;
}
.site-policy--contents .site-policy--title,
.privacy-policy--contents .site-policy--title {
  display: block;
  font-size: 14px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .site-policy--contents .site-policy--title,
  .privacy-policy--contents .site-policy--title {
    font-size: 14px;
    font-size: 3.7333333333vw;
  }
}

.privacy-policy--read-header {
  margin-bottom: 40px;
}

.privacy-policy--contents ol > li {
  text-indent: 0;
}
.privacy-policy--contents ol > li > ol > li {
  text-indent: 0;
}
.privacy-policy--contents ol > li > ul > li {
  text-indent: 0;
  list-style-type: circle;
  margin-bottom: 16px;
}
.privacy-policy--contents ol > li > ul > li > ul > li {
  text-indent: 0;
}
.privacy-policy--contents .privacy-policy-over {
  text-align: right;
  margin-top: 32px;
}

/* Error
   ========================================================================== */
.notfound--wrapper {
  width: 732px;
  margin: 176px auto 0 auto;
}
@media screen and (max-width: 767px) {
  .notfound--wrapper {
    width: 89.33%;
    margin: 120px auto 0 auto;
  }
}

.notfound--title {
  text-align: center;
  font-family: "Montserrat", sans-serif;
  font-weight: bold;
  font-size: 62px;
  color: #0075a2;
}
@media screen and (max-width: 767px) {
  .notfound--title {
    font-size: 48px;
    font-size: 12.8vw;
    line-height: 1.2;
    margin-bottom: 16px;
  }
}

.notfound--subtitle {
  text-align: center;
  font-size: 28px;
  font-weight: normal;
  margin-bottom: 34px;
}
@media screen and (max-width: 767px) {
  .notfound--subtitle {
    font-size: 20px;
    font-size: 5.3333333333vw;
  }
}

.error404 .btn--large {
  width: 100%;
}

.notfound--read {
  text-align: center;
  font-size: 16px;
  margin-bottom: 53px;
}
@media screen and (max-width: 767px) {
  .notfound--read {
    text-align: left;
    font-size: 14px;
    font-size: 3.7333333333vw;
  }
}
