@charset "UTF-8";
/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */
html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
}

h1 {
  font-size: 2em;
}

hr {
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}

pre {
  font-family: monospace, monospace;
  font-size: 1em;
}

a {
  background-color: transparent;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted;
}

b,
strong {
  font-weight: bolder;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

img {
  border-style: none;
}

button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

[type=button],
[type=reset],
[type=submit],
button {
  -webkit-appearance: button;
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring,
button:-moz-focusring {
  outline: 1px dotted ButtonText;
}

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

legend {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type=checkbox],
[type=radio] {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

details {
  display: block;
}

summary {
  display: list-item;
}

[hidden],
template {
  display: none;
}

@-ms-viewport {
  width: device-width;
}
html {
  -ms-overflow-style: scrollbar;
}

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

html {
  font-size: 62.5%;
}

body,
html {
  overflow-x: hidden;
}

body {
  position: relative;
  color: #212121;
  line-height: 1;
  font-size: 1.6rem;
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "MS Pゴシック", "MS PGothic", sans-serif;
}

body.scroll-off {
  overflow: hidden;
}

body.loading * {
  -webkit-transition: none !important;
  transition: none !important;
}

h1,
h2,
h3,
h4,
h5,
h6,
p {
  margin: 0;
  font-weight: 400;
}

ul {
  padding: 0;
  list-style: none;
}

dd,
dl,
dt,
figure,
ul {
  margin: 0;
}

address {
  font-style: normal;
}

a {
  color: #212121;
  text-decoration: none;
}

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

.container {
  width: 100%;
  padding-right: 15px;
  padding-left: 15px;
  margin-right: auto;
  margin-left: auto;
}

@media (min-width: 576px) {
  .container {
    max-width: 540px;
  }
}
@media (min-width: 768px) {
  .container {
    max-width: 720px;
  }
}
@media (min-width: 1024px) {
  .container {
    max-width: 1054px;
  }
}
.container-fluid {
  width: 100%;
  padding-right: 15px;
  padding-left: 15px;
  margin-right: auto;
  margin-left: auto;
}

.anchor-hash {
  display: block;
  visibility: hidden;
  position: relative;
  top: -150px;
}

@media screen and (max-width: 768px) {
  .anchor-hash {
    top: -72px;
  }
}
.lg-show {
  display: none;
}

@media screen and (max-width: 1024px) {
  .lg-show {
    display: inline;
  }
}
.md-show {
  display: none;
}

.md-hide {
  display: inline;
}

@media screen and (max-width: 768px) {
  .md-show {
    display: inline;
  }

  .md-hide {
    display: none;
  }
}
.xs-show {
  display: none;
}

@media screen and (max-width: 350px) {
  .xs-show {
    display: inline;
  }
}
@media screen and (min-width: 769px) {
  .u-view-sp {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .u-view-upper-tb {
    display: none;
  }
}
#pjax-wrapper {
  overflow-x: hidden;
}

.section {
  padding: 72px 0;
}

.section-top {
  padding-top: 72px;
}

.section-top-s {
  padding: 24px 0 72px;
}

.section-bottom {
  padding-bottom: 72px;
}

.bg-grey {
  background-color: #f5f5f5;
}

@media screen and (max-width: 768px) {
  .section,
.section-top-s {
    padding: 36px 0;
  }

  .section-top {
    padding-top: 36px;
  }

  .section-bottom {
    padding-bottom: 36px;
  }
}
.g-heading-1 {
  font-size: 2.8rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
  margin-bottom: 30px;
  letter-spacing: -0.05em;
}

.g-heading-1.is-white {
  color: #fff;
}

.g-heading-1 small {
  display: block;
  font-size: 2rem;
  text-align: center;
}

.g-subheading {
  text-align: center;
  margin: 30px 0;
  line-height: 1.5;
}

.g-subheading--left {
  text-align: left;
}

.g-showcase {
  position: relative;
  height: 556px;
  overflow: hidden;
}

.g-showcase__background {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50%;
}

@media screen and (max-width: 768px) {
  .g-showcase {
    height: 356px;
  }
}
.g-kv {
  position: relative;
  height: 356px;
  overflow: hidden;
}
@media (min-width: 768.02px) {
  .g-kv {
    height: 612px;
  }
}
.g-kv__background {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-repeat: repeat-x;
  background-size: auto 100%;
  background-position: center;
}
.g-kv__ttl {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  max-width: max-content;
  max-height: max-content;
}
.mce-content-body {
  margin-bottom: 0;
}

.mce-content-body p {
  margin-bottom: 0.5em;
}

.mce-content-body img {
  width: auto;
  height: auto;
  max-width: 100%;
}

.mce-content-body strong {
  font-weight: 700;
}

.mce-content-body em {
  font-style: italic;
}

.mce-content-body hr {
  border: none;
  border-top: 1px solid #ddd;
  height: 1px;
  color: #fff;
  margin: 15px 0;
}

.mce-content-body a {
  color: #c4017e;
  text-decoration: underline;
}

.mce-content-body h1 {
  font-size: 36px;
}

.mce-content-body h2 {
  font-size: 28px;
}

.mce-content-body h3 {
  font-size: 24px;
}

.mce-content-body h4 {
  font-size: 20px;
}

.mce-content-body h5 {
  font-size: 16px;
}

.mce-content-body h6 {
  font-size: 12px;
}

.mce-content-body h1,
.mce-content-body h2,
.mce-content-body h3,
.mce-content-body h4,
.mce-content-body h5,
.mce-content-body h6 {
  font-weight: 700;
  line-height: 1.8em;
}

.mce-content-body:after {
  content: "";
  clear: both;
  display: block;
}

@-webkit-keyframes fadeOut {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@-webkit-keyframes fadeIn {
  0% {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
[data-anim-type=fadein] {
  opacity: 0;
  -webkit-transition: opacity 0.75s ease-in-out;
  transition: opacity 0.75s ease-in-out;
}

[data-anim-type=fadein].is-anim-over {
  opacity: 1;
}

[data-anim-type=block-reveal-vert] {
  position: relative;
}

[data-anim-type=block-reveal-vert]:after {
  content: "";
  position: absolute;
  top: -3px;
  right: -3px;
  bottom: -3px;
  left: -3px;
  background-color: #fff;
  -webkit-transition: -webkit-transform 1.5s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: -webkit-transform 1.5s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 1.5s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 1.5s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 1.5s cubic-bezier(0.215, 0.61, 0.355, 1);
  -webkit-transform-origin: bottom;
  transform-origin: bottom;
  -webkit-transform: scaleY(1);
  transform: scaleY(1);
}

[data-anim-type=block-reveal-vert].ca-content__image {
  overflow: hidden;
}

[data-anim-type=block-reveal-vert].ca-content__image img {
  -webkit-transform: scale(1.25);
  transform: scale(1.25);
  -webkit-transition: -webkit-transform 2s;
  transition: -webkit-transform 2s;
  transition: transform 2s;
  transition: transform 2s, -webkit-transform 2s;
}

[data-anim-type=block-reveal-vert].ca-content__image:after {
  background-color: #f5f5f5;
}

[data-anim-type=block-reveal-vert].r-gallery__slider:after {
  background-color: #f5f5f5;
  z-index: 1;
}

[data-anim-type=block-reveal-vert] .products__background {
  -webkit-transform: scale(1.25);
  transform: scale(1.25);
}

[data-anim-type=block-reveal-vert].is-anim-over:after {
  -webkit-transform: scaleY(0);
  transform: scaleY(0);
}

[data-anim-type=block-reveal-vert].is-anim-over.ca-content__image img,
[data-anim-type=block-reveal-vert].is-anim-over .products__background {
  -webkit-transform: scale(1);
  transform: scale(1);
}

[data-anim-type=block-reveal-hor] {
  position: relative;
  overflow: hidden;
}

[data-anim-type=block-reveal-hor]:after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: #f5f5f5;
  -webkit-transition: -webkit-transform 1.25s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: -webkit-transform 1.25s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 1.25s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 1.25s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 1.25s cubic-bezier(0.215, 0.61, 0.355, 1);
  -webkit-transform-origin: right;
  transform-origin: right;
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  height: 101%;
}

[data-anim-type=block-reveal-hor].b-product__item:after,
[data-anim-type=block-reveal-hor].s-uniform__item:after {
  background-color: #fff;
}

[data-anim-type=block-reveal-hor] .b-product__imagebox img,
[data-anim-type=block-reveal-hor] .ca-item__imagebox img,
[data-anim-type=block-reveal-hor] .r-item__imagebox img,
[data-anim-type=block-reveal-hor] .s-uniform__imagebox img {
  -webkit-transform: scale(1.25);
  transform: scale(1.25);
}

[data-anim-type=block-reveal-hor].is-anim-over:after {
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
}

[data-anim-type=block-reveal-hor].is-anim-over .b-product__imagebox img,
[data-anim-type=block-reveal-hor].is-anim-over .ca-item__imagebox img,
[data-anim-type=block-reveal-hor].is-anim-over .r-item__imagebox img,
[data-anim-type=block-reveal-hor].is-anim-over .s-uniform__imagebox img {
  -webkit-transform: scale(1);
  transform: scale(1);
}

[data-anim-type=text] {
  overflow: hidden;
}

[data-anim-type=text] span {
  display: inline-block;
  -webkit-transform: translateY(120%);
  transform: translateY(120%);
  -webkit-transition: -webkit-transform 0.7s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: -webkit-transform 0.7s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 0.7s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 0.7s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.7s cubic-bezier(0.215, 0.61, 0.355, 1);
}

[data-anim-type=text].is-anim-over span {
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

[data-anim-type=infoblock] .g-infoblock__imagebox img {
  -webkit-transform: scale(1.2);
  transform: scale(1.2);
}

[data-anim-type=infoblock] .g-infoblock__imagebox:after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  -webkit-transform-origin: bottom;
  transform-origin: bottom;
  -webkit-transition: -webkit-transform 1.25s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: -webkit-transform 1.25s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 1.25s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 1.25s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 1.25s cubic-bezier(0.215, 0.61, 0.355, 1);
  background-color: #f5f5f5;
}

[data-anim-type=infoblock] .g-infoblock__link,
[data-anim-type=infoblock] .g-infoblock__textbox {
  opacity: 0;
  -webkit-transition: opacity 0.5s ease-in-out;
  transition: opacity 0.5s ease-in-out;
}

[data-anim-type=infoblock].is-anim-over .g-infoblock__imagebox img {
  -webkit-transform: scale(1);
  transform: scale(1);
}

[data-anim-type=infoblock].is-anim-over .g-infoblock__imagebox:after {
  -webkit-transform: scaleY(0);
  transform: scaleY(0);
}

[data-anim-type=infoblock].is-anim-over .g-infoblock__link,
[data-anim-type=infoblock].is-anim-over .g-infoblock__textbox {
  opacity: 1;
}

[data-anim-type=zoom-in] {
  -webkit-transition: -webkit-transform 2s;
  transition: -webkit-transform 2s;
  transition: transform 2s;
  transition: transform 2s, -webkit-transform 2s;
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}

[data-anim-type=zoom-in].is-anim-over {
  -webkit-transform: scale(1);
  transform: scale(1);
}

.g-header {
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  color: #fff;
  -webkit-transition: background-color 0.5s;
  transition: background-color 0.5s;
  z-index: 5;
}

.g-header--custom_black {
  background-color: rgba(255, 255, 255, 0.8);
}

.g-header--custom_black .g-header__logo--white {
  opacity: 0;
}

.g-header--custom_black .g-header__logo--black {
  opacity: 1;
}

.g-header--custom_black .g-header__phone-icon svg {
  fill: #212121;
}

.g-header--custom_black .g-header__phone-text {
  color: #212121;
}

.g-header__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 24px 32px;
}

@media all and (max-width: 1280px) {
  .g-header__container {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.g-header__logo {
  position: relative;
  max-width: 140px;
  height: 40px;
  width: 100%;
}

.g-header__logo a {
  display: block;
}

.g-header__logo svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 40px;
  fill: #fff;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}

.g-header__logo--black {
  opacity: 0;
}

.g-header__info,
.g-header__phone {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.g-header__phone {
  justify-content: center;
  width: 270px;
  height: 92px;
  border-radius: 4px;
  background: #fff;
  color: #212121;
  border: 1px solid;
}

@media all and (max-width: 1280px) {
  .g-header__phone {
    width: 200px;
  }

  .g-header .g-header__phone-txt span {
    font-size: 1.4rem;
  }

  .g-header .g-header__phone-text span {
    font-size: 1.6rem;
  }
}
.g-header__phone-icon {
  margin: 7px 10px 0;
}

.g-header__phone-icon svg {
  width: 20px;
  height: 20px;
  fill: #212121;
  -webkit-transition: fill 0.3s;
  transition: fill 0.3s;
}

.g-header__phone-text {
  font-size: 1.4rem;
  line-height: 1.25;
  -webkit-transition: color 0.3s;
  transition: color 0.3s;
}

.g-header__phone-text span {
  font-weight: 700;
  font-size: 2.4rem;
}

.g-header__phone-text small {
  display: block;
  font-size: 1.6rem;
}

.g-header__contact {
  width: 164px;
  margin-left: 40px;
}

@media all and (max-width: 1280px) {
  .g-header__contact {
    margin-left: 20px;
  }
}
.g-header__contact-link {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 100%;
  padding: 10px 15px;
  color: #fff;
  text-align: center;
  background-color: #0068b7;
  border-radius: 4px;
  overflow: hidden;
  -webkit-transition: -webkit-box-shadow 0.2s;
  transition: -webkit-box-shadow 0.2s;
  transition: box-shadow 0.2s;
  transition: box-shadow 0.2s, -webkit-box-shadow 0.2s;
  z-index: 1;
}

.g-header__contact-link:before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: #5695ea;
  z-index: -1;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: right;
  transform-origin: right;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}

.g-header__contact-link:hover {
  -webkit-box-shadow: 0 2px 20px -5px #5696ea;
  box-shadow: 0 2px 20px -5px #5696ea;
}

.g-header__contact-link:hover:before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transform-origin: left;
  transform-origin: left;
}

.g-header__contact-icon {
  margin: 2px 10px 0 0;
}

.g-header__contact-icon svg {
  width: 20px;
  height: 16px;
  fill: #fff;
}

@media screen and (max-width: 768px) {
  .g-header__container {
    padding: 16px;
  }

  .g-header__info {
    display: none;
  }
}
@media screen and (max-width: 576px) {
  .g-header__logo {
    max-width: 140px;
  }
}
.g-nav--custom_black .g-nav__link {
  color: #212121;
}

.g-nav--custom_black .g-nav__link:after {
  background-color: #17304c;
}

.g-nav__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.g-nav__item {
  width: 100%;
}

.g-nav__item--current .g-nav__link:after {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
}

.g-nav__link {
  position: relative;
  display: block;
  text-align: center;
  padding: 18px 0 28px;
  font-weight: 700;
  color: #fff;
  -webkit-transition: color 0.3s;
  transition: color 0.3s;
}

.g-nav__link:after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 4px;
  background-color: #fff;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: right;
  transform-origin: right;
  -webkit-transition: background-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, -webkit-transform 0.3s;
  transition: transform 0.3s, background-color 0.3s;
  transition: transform 0.3s, background-color 0.3s, -webkit-transform 0.3s;
}

.g-nav__link:hover:after {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transform-origin: left;
  transform-origin: left;
}

@media screen and (max-width: 1024px) {
  .g-nav__list {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .g-nav__item {
    width: auto;
  }

  .g-nav__link {
    padding: 20px 15px;
  }
}
@media screen and (max-width: 768px) {
  .g-nav {
    display: none;
  }
}
.g-btn {
  max-width: 330px;
  width: 100%;
}
.g-btn-wid {
  max-width: 400px;
}

.g-btn--centered {
  margin: 0 auto;
}

.g-btn--white .g-btn__link {
  color: #fff;
  border: 1px solid #fff;
}

.g-btn--white .g-btn__link:before {
  background-color: #fff;
}

.g-btn--white .g-btn__link:focus,
.g-btn--white .g-btn__link:hover {
  color: #212121;
  border: 1px solid #fff;
  -webkit-box-shadow: 0 2px 15px -8px #fff;
  box-shadow: 0 2px 15px -8px #fff;
}

.g-btn--white .g-btn__link:focus .g-btn__icon svg,
.g-btn--white .g-btn__link:hover .g-btn__icon svg {
  fill: #212121;
}

.g-btn--white .g-btn__icon svg {
  fill: #fff;
}

.g-btn__link {
  position: relative;
  display: block;
  font-size: 1.4rem;
  padding: 15px;
  text-align: center;
  border: 1px solid #212121;
  border-radius: 4px;
  overflow: hidden;
  z-index: 1;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.g-btn__link:before {
  content: "";
  position: absolute;
  top: -3px;
  right: -3px;
  bottom: -3px;
  left: -3px;
  background-color: #0068b7;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: right;
  transform-origin: right;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  z-index: -1;
}

.g-btn__link:focus,
.g-btn__link:hover {
  color: #fff;
  border-color: #0068b7;
  -webkit-box-shadow: 0 2px 15px -8px #0068b7;
  box-shadow: 0 2px 15px -8px #0068b7;
}

.g-btn__link:focus:before,
.g-btn__link:hover:before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transform-origin: left;
  transform-origin: left;
}

.g-btn__link:focus .g-btn__icon svg,
.g-btn__link:hover .g-btn__icon svg {
  fill: #fff;
}

.g-btn__icon {
  position: absolute;
  top: 50%;
  right: 16px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.g-btn__icon svg {
  fill: #212121;
  width: 14px;
  height: 11px;
  -webkit-transition: fill 0.3s;
  transition: fill 0.3s;
}

.g-cta {
  padding: 72px 0;
}

.g-cta__buttonwrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.g-cta__btn {
  max-width: 500px;
  width: 100%;
}

.g-cta__btn--phone {
  margin-right: 30px;
}

.g-cta__btn--contact .g-cta__link {
  background-color: #0068b7;
}

.g-cta__btn--contact .g-cta__link:focus,
.g-cta__btn--contact .g-cta__link:hover {
  -webkit-box-shadow: 0 2px 20px -5px #5696ea;
  box-shadow: 0 2px 20px -5px #5696ea;
}

.g-cta__btn--contact .g-cta__link:focus:before,
.g-cta__btn--contact .g-cta__link:hover:before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transform-origin: left;
  transform-origin: left;
}

.g-cta__link {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 100%;
  height: 120px;
  line-height: 120px;
  background-color: #f5f5f5;
  border-radius: 4px;
  -webkit-transition: -webkit-box-shadow 0.3s;
  transition: -webkit-box-shadow 0.3s;
  transition: box-shadow 0.3s;
  transition: box-shadow 0.3s, -webkit-box-shadow 0.3s;
  overflow: hidden;
  z-index: 1;
}

.g-cta__link:before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: #5695ea;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: right;
  transform-origin: right;
  -webkit-transition: -webkit-transform 0.35s;
  transition: -webkit-transform 0.35s;
  transition: transform 0.35s;
  transition: transform 0.35s, -webkit-transform 0.35s;
  z-index: -1;
}

.g-cta__phone {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  line-height: 1.25;
  color: #212121;
}

.g-cta__phone-icon {
  margin-right: 10px;
}

.g-cta__phone-icon svg {
  width: 20px;
  height: 20px;
  fill: #212121;
}

.g-cta__phone-number span {
  display: block;
  font-size: 2.4rem;
  font-weight: 700;
}

.g-cta__phone-number small {
  font-size: 1.6rem;
}

.g-cta__contact {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  color: #fff;
  line-height: 1;
}

.g-cta__contact-icon {
  margin-right: 10px;
}

.g-cta__contact-icon svg {
  width: 20px;
  height: 16px;
  fill: #fff;
}

.g-cta__contact-text {
  font-size: 1.8rem;
}

.g-cta__contact-arrow {
  position: absolute;
  top: 50%;
  right: 16px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.g-cta__contact-arrow svg {
  width: 14px;
  height: 11px;
  fill: #fff;
}

@media screen and (max-width: 768px) {
  .g-cta__buttonwrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }

  .g-cta__btn:first-child {
    margin-right: 0;
    margin-bottom: 16px;
  }

  .g-cta__link {
    height: 95px;
    line-height: 95px;
  }
}
@media screen and (max-width: 576px) {
  .g-cta {
    padding: 36px 0;
  }

  .g-cta_02 {
    padding: 0 !important;
  }
}
.g-footer {
  padding: 72px 0;
  background-color: #f5f5f5;
}

.g-footer__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.g-footer__info {
  max-width: 320px;
  width: 100%;
  padding-right: 80px;
}

.g-footer__logo {
  margin-bottom: 15px;
}

.g-footer__logo svg {
  width: 140px;
  height: 40px;
  fill: #212121;
}

.g-footer__address {
  font-size: 1.4rem;
  line-height: 1.5;
  margin-bottom: 48px;
}

.g-footer__social {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.g-footer__social-item {
  position: relative;
  margin-right: 32px;
}

.g-footer__social-item:last-child {
  margin-right: 0;
}

.g-footer__social-link svg {
  width: 32px;
  height: 32px;
  fill: #212121;
  -webkit-transition: fill 0.3s;
  transition: fill 0.3s;
}

.g-footer__social-link--fb:focus svg,
.g-footer__social-link--fb:hover svg {
  fill: #3b5998;
}

.g-footer__social-link--tw:focus svg,
.g-footer__social-link--tw:hover svg {
  fill: #1da1f2;
}

.g-footer__social-link--ig svg {
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}

.g-footer__social-link--ig:focus svg:first-child,
.g-footer__social-link--ig:hover svg:first-child,
.g-footer__social-link--ig svg:last-child {
  opacity: 0;
}

.g-footer__social-link--ig:focus svg:last-child,
.g-footer__social-link--ig:hover svg:last-child {
  opacity: 1;
}

.g-footer__sitemap {
  width: calc(100% - 320px);
}

.g-footer__sitemap-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 54px;
}

.g-footer__sitemap-col {
  width: 33.333%;
}

.g-footer__sitemap-list {
  line-height: 1.5;
  margin-bottom: 10px;
}

.g-footer__sitemap-item:before {
  content: "・";
}

.g-footer__sitemap-item--main {
  font-weight: 700;
  line-height: 1.5;
}

.g-footer__sitemap-item--main:before {
  content: "";
}

.g-footer__sitemap-link {
  position: relative;
  display: inline-block;
  font-size: 1.4rem;
}

.g-footer__sitemap-link:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #212121;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: right;
  transform-origin: right;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}

.g-footer__sitemap-link:focus:after,
.g-footer__sitemap-link:hover:after {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transform-origin: left;
  transform-origin: left;
}

.g-footer__copy {
  width: 100%;
  color: #616161;
  font-size: 1.2rem;
  text-align: center;
}

@media screen and (max-width: 1024px) {
  .g-footer__container {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .g-footer__info {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
    width: 100%;
    text-align: center;
    padding-right: 0;
    margin-bottom: 50px;
  }

  .g-footer__social {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .g-footer__sitemap {
    width: 100%;
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }

  .g-footer__copy {
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 3;
    order: 3;
  }
}
@media screen and (max-width: 768px) {
  .g-footer {
    padding: 72px 0 96px;
  }

  .g-footer__sitemap-row {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

  .g-footer__sitemap-col {
    width: 100%;
  }

  .g-footer__sitemap-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
  }

  .g-footer__sitemap-item,
.g-footer__sitemap-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }

  .g-footer__sitemap-item {
    max-width: 250px;
    width: 100%;
  }

  .g-footer__sitemap-item--main {
    position: relative;
    top: 25px;
    max-width: 100%;
  }

  .g-footer__sitemap-item--main .g-footer__sitemap-link {
    width: auto;
  }

  .g-footer__sitemap-link {
    width: calc(100% - 16px);
  }
}
@media screen and (max-width: 576px) {
  .g-footer {
    padding: 36px 0 96px;
  }

  .g-footer__sitemap-item {
    max-width: 140px;
  }

  .g-footer__sitemap-item--main {
    max-width: 100%;
  }
}
@media screen and (max-width: 350px) {
  .g-footer__sitemap-item--long {
    top: 38px;
    line-height: 0.75;
  }
}
.g-panel {
  position: fixed;
  left: 0;
  bottom: 0;
  width: 100%;
  display: none;
  background-color: #fff;
  z-index: 4;
}

.g-panel__item {
  position: relative;
  width: 34%;
}

.g-panel__item:first-child .g-panel__icon,
.g-panel__item:first-child .g-panel__text {
  position: relative;
  top: 5px;
}

.g-panel__item:nth-child(2):after,
.g-panel__item:nth-child(2):before {
  content: "";
  position: absolute;
  top: 8px;
  width: 1px;
  height: 56px;
  background-color: #e0e0e0;
}

.g-panel__item:nth-child(2):before {
  left: 0;
}

.g-panel__item:nth-child(2):after {
  right: 0;
}

.g-panel__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 72px;
}

.g-panel__icon {
  margin-bottom: 7px;
}

.g-panel__text {
  display: block;
  text-align: center;
  font-size: 1.1rem;
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .g-panel {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
.g-menu {
  display: none;
  position: fixed;
  width: 100%;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: #17304c;
  overflow: hidden;
  -webkit-transform: translateX(100%);
  transform: translateX(100%);
  -webkit-transition: -webkit-transform 0.4s ease-out;
  transition: -webkit-transform 0.4s ease-out;
  transition: transform 0.4s ease-out;
  transition: transform 0.4s ease-out, -webkit-transform 0.4s ease-out;
  z-index: 10;
}

.g-menu__inner {
  position: relative;
  height: 100%;
  padding: 64px 42px;
  overflow: hidden;
}

.g-menu__list {
  margin-bottom: 32px;
}

.g-menu__item {
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}

.g-menu__item:first-child {
  border-top: 1px solid rgba(255, 255, 255, 0.2);
}

.g-menu__link {
  display: block;
  padding: 16px;
  color: #fff;
}

.g-menu__buttonwrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0 -6px;
}

.g-menu__btn {
  width: 50%;
  margin: 0 6px;
}

.g-menu__btn--phone .g-menu__btn-link {
  background-color: rgba(255, 255, 255, 0.2);
}

.g-menu__btn--contact .g-menu__btn-link {
  background-color: #0068b7;
}

.g-menu__btn-link {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 56px;
  font-size: 1.1rem;
  font-weight: 700;
  color: #fff;
  border-radius: 8px;
}

.g-menu__btn-icon {
  margin-right: 6px;
}

.g-menu__btn-icon svg {
  fill: #fff;
}

.g-menu__close {
  margin: 24px 0 0;
}

.g-menu__close,
.g-menu__close-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.g-menu__close-link {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 62px;
  height: 62px;
  color: #fff;
  background-color: rgba(0, 0, 0, 0.9);
  border-radius: 50%;
  -webkit-transform: translateY(120px);
  transform: translateY(120px);
  opacity: 0;
  -webkit-transition: opacity 0.3s, -webkit-transform 0.5s ease-out;
  transition: opacity 0.3s, -webkit-transform 0.5s ease-out;
  transition: transform 0.5s ease-out, opacity 0.3s;
  transition: transform 0.5s ease-out, opacity 0.3s, -webkit-transform 0.5s ease-out;
  -webkit-transition-delay: 0.35s, 0.35s;
  transition-delay: 0.35s, 0.35s;
}

.g-menu__close-icon {
  margin-bottom: 10px;
}

.g-menu__close-icon span {
  display: block;
  width: 14px;
  height: 2px;
  background-color: #fff;
}

.g-menu__close-icon span:first-child {
  -webkit-transform: rotate(45deg) translateY(1px);
  transform: rotate(45deg) translateY(1px);
}

.g-menu__close-icon span:last-child {
  -webkit-transform: rotate(-45deg) translateY(-1px);
  transform: rotate(-45deg) translateY(-1px);
}

.g-menu__close-text {
  font-size: 1.1rem;
  font-weight: 700;
}

.g-menu.g-menu--active {
  -webkit-transform: translateX(0);
  transform: translateX(0);
}

.g-menu.g-menu--active .g-menu__inner {
  overflow: scroll;
}

.g-menu.g-menu--active .g-menu__close-link {
  -webkit-transform: translateY(0);
  transform: translateY(0);
  opacity: 1;
}

.mv {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  height: 363px;
  overflow: hidden;
}

.mv__container {
  padding: 56px 15px;
}

.mv__background {
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50%;
  z-index: -1;
}

.mv__heading {
  font-size: 3.2rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
}

.mv__heading small {
  display: block;
  font-size: 1.8rem;
}

@media screen and (max-width: 768px) {
  .mv {
    height: 250px;
  }
}
.g-breadcrumbs {
  font-size: 1.4rem;
  padding: 20px 0;
}

.g-breadcrumbs__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.g-breadcrumbs__container > span a {
  position: relative;
  display: inline-block;
}

.g-breadcrumbs__container > span a:before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -3px;
  display: block;
  height: 1px;
  width: 100%;
  background-color: #212121;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: right;
  transform-origin: right;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}

.g-breadcrumbs__container > span a:hover:before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transform-origin: left;
  transform-origin: left;
}

.g-breadcrumbs__icon {
  width: 18px;
  height: 18px;
  margin: 0 10px;
  background-image: url(../img/common/icon-angle-right.svg);
  background-repeat: no-repeat;
  background-size: 18px 18px;
  background-position: 50%;
}

@media screen and (max-width: 768px) {
  .g-breadcrumbs {
    display: none;
  }
}
.g-infoblock {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
  margin-bottom: 75px;
}

.g-infoblock__imagebox {
  position: relative;
  overflow: hidden;
}

.g-infoblock__imagebox img {
  -webkit-transition: -webkit-transform 2s;
  transition: -webkit-transform 2s;
  transition: transform 2s;
  transition: transform 2s, -webkit-transform 2s;
}

.g-infoblock__link,
.g-infoblock__textbox {
  position: relative;
  display: block;
  max-width: 850px;
  width: 100%;
  padding: 40px;
  margin: -100px auto 0;
  background-color: #fff;
  z-index: 2;
}

.g-infoblock__link .g-infoblock__title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.g-infoblock__link .g-infoblock__icon {
  margin-left: 15px;
}

.g-infoblock__link:hover .g-infoblock__icon-circle {
  stroke-dashoffset: 0;
  fill: #0068b7;
  -webkit-transition: stroke-dashoffset 0.5s, fill 0.3s 0.3s;
  transition: stroke-dashoffset 0.5s, fill 0.3s 0.3s;
}

.g-infoblock__link:hover .g-infoblock__icon-arrow {
  fill: #fff;
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}

.g-infoblock__link:hover + .g-infoblock__imagebox img {
  -webkit-transform: scale(1.07);
  transform: scale(1.07);
}

.g-infoblock__title {
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
  margin-bottom: 20px;
}

.g-infoblock__title-small {
  display: block;
  font-size: 2rem;
}

.g-infoblock__title-main {
  font-size: 2.8rem;
}

.g-infoblock__icon {
  position: relative;
  width: 48px;
  height: 48px;
  display: inline-block;
}

.g-infoblock__icon-circle {
  width: 48px;
  height: 48px;
  position: absolute;
  top: 0;
  left: 0;
  fill: transparent;
  stroke: #0068b7;
  stroke-width: 1;
  stroke-dasharray: 132 132;
  stroke-dashoffset: 132;
  -webkit-transition: stroke-dashoffset 0.5s;
  transition: stroke-dashoffset 0.5s;
  -webkit-transform: rotate(-90deg);
  transform: rotate(-90deg);
}

.g-infoblock__icon-arrow {
  fill: #212121;
  width: 20px;
  height: 15px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-transition: fill 0.3s;
  transition: fill 0.3s;
}

.g-infoblock__text {
  text-align: center;
  line-height: 1.5;
}

.g-infoblock__btn {
  margin-top: 30px;
}

@media screen and (max-width: 1024px) {
  .g-infoblock__link,
.g-infoblock__textbox {
    margin: 0 auto;
  }
}
@media screen and (max-width: 768px) {
  .g-infoblock {
    margin-bottom: 36px;
  }

  .g-infoblock__textbox {
    padding: 24px 16px;
  }

  .g-infoblock__link {
    padding: 16px 24px 24px;
  }

  .g-infoblock__link .g-infoblock__title {
    margin-bottom: 10px;
  }

  .g-infoblock__title-small {
    font-size: 1.6rem;
  }

  .g-infoblock__title-main {
    font-size: 2rem;
  }

  .g-infoblock__icon {
    margin-left: 10px;
  }

  .g-infoblock__icon-circle {
    display: none;
  }

  .g-infoblock__text {
    text-align: left;
  }

  .g-infoblock__btn {
    margin-top: 20px;
  }
}
.g-form form {
  margin: 50px 0;
}

.g-form__inner {
  padding: 50px 40px;
  margin: 60px 0;
  background-color: #f5f5f5;
}

.g-form__row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 30px 20px 30px 10px;
  border-bottom: 1px dashed #a6a6a6;
}

.g-form__label {
  width: 340px;
}

.g-form__label--required label:before {
  content: "必須";
  background-color: #b7000d;
}

.g-form__label--optional label:before {
  content: "任意";
  background-color: #0068b7;
}

.g-form__label label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-weight: 700;
}

.g-form__label label:before {
  display: block;
  width: 65px;
  padding: 5px;
  margin-right: 20px;
  text-align: center;
  color: #fff;
}

.g-form__inputfield {
  width: calc(100% - 340px);
}

.g-form__inputfield textarea {
  width: 100%;
  padding: 10px;
  background-color: #fff;
  border: 1px solid #ccc;
  line-height: 1.5;
  -webkit-transition: border 0.3s, -webkit-box-shadow 0.2s;
  transition: border 0.3s, -webkit-box-shadow 0.2s;
  transition: border 0.3s, box-shadow 0.2s;
  transition: border 0.3s, box-shadow 0.2s, -webkit-box-shadow 0.2s;
}

.g-form__inputfield textarea:focus {
  border: 1px solid #5695ea;
  -webkit-box-shadow: 0 0 1px rgba(86, 149, 234, 0.5);
  box-shadow: 0 0 1px rgba(86, 149, 234, 0.5);
}

.g-form__inputfield--vertical {
  line-height: 1.5;
}

.g-form__inputfield--vertical .mwform-radio-field {
  display: block;
  margin-left: 10px;
}

.g-form__inputwrap {
  margin-bottom: 20px;
}

.g-form__inputwrap:last-child {
  margin-bottom: 0;
}

.g-form__inputrow {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.g-form__radio {
  display: inline-block;
  margin-top: 5px;
}

.g-form__radio:first-child {
  margin-right: 50px;
}

.g-form__birthday-item {
  position: relative;
  width: 135px;
  padding-right: 33px;
}

.g-form__birthday-item span:not(.error) {
  position: absolute;
  right: 9px;
  top: 12px;
  display: inline-block;
}

.g-form__birthday .g-form__input {
  width: 80px;
}

.g-form__input {
  width: 310px;
  height: 40px;
  line-height: 40px;
  padding: 0 10px;
  background-color: #fff;
  border: 1px solid #ccc;
  -webkit-transition: border 0.3s, -webkit-box-shadow 0.2s;
  transition: border 0.3s, -webkit-box-shadow 0.2s;
  transition: border 0.3s, box-shadow 0.2s;
  transition: border 0.3s, box-shadow 0.2s, -webkit-box-shadow 0.2s;
}

.g-form__input--small {
  width: 200px;
}

.g-form__input--big {
  width: 100%;
}

.g-form__input + .error {
  margin-top: 5px;
}

.g-form__input:focus {
  border: 1px solid #5695ea;
  -webkit-box-shadow: 0 0 1px rgba(86, 149, 234, 0.5);
  box-shadow: 0 0 1px rgba(86, 149, 234, 0.5);
}

.g-form__text {
  margin-bottom: 10px;
}

.g-form__privacy-title {
  display: block;
  text-align: center;
  margin-bottom: 30px;
}

.g-form__privacy-wrap {
  max-width: 830px;
  width: 100%;
  height: 150px;
  padding: 20px;
  line-height: 1.5;
  margin: 0 auto 50px;
  background-color: #fff;
  border: 1px solid #ccc;
  overflow-y: scroll;
}

.g-form__privacy-wrap .p-privacy__block,
.g-form__privacy-wrap .p-privacy__subtitle {
  margin: 0 0 32px;
}

.g-form__privacy-consent {
  text-align: center;
  margin: 30px 0;
}

.g-form__privacy-label {
  cursor: pointer;
}

.g-form__privacy-label input {
  margin-right: 5px;
}

.g-form__submit {
  display: block;
  max-width: 410px;
  width: 100%;
  margin: 30px auto 80px;
}

.g-form__submit button {
  display: block;
  width: 100%;
  position: relative;
  text-align: center;
  padding: 20px 15px;
  background-color: #fff;
  border: 1px solid #212121;
  border-radius: 4px;
  overflow: hidden;
  z-index: 1;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  cursor: pointer;
}

.g-form__submit button:before {
  content: "";
  position: absolute;
  top: -3px;
  right: -3px;
  bottom: -3px;
  left: -3px;
  background-color: #0068b7;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: right;
  transform-origin: right;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  z-index: -1;
}

.g-form__submit button:focus,
.g-form__submit button:hover {
  color: #fff;
  border-color: #0068b7;
  -webkit-box-shadow: 0 2px 15px -8px #0068b7;
  box-shadow: 0 2px 15px -8px #0068b7;
}

.g-form__submit button:focus:before,
.g-form__submit button:hover:before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transform-origin: left;
  transform-origin: left;
}

@media screen and (max-width: 1024px) {
  .g-form__label {
    width: 270px;
  }

  .g-form__inputfield {
    width: calc(100% - 270px);
  }
}
@media screen and (max-width: 768px) {
  .g-form__inner {
    padding: 30px 20px;
    margin: 40px 0;
  }

  .g-form__row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    padding: 20px 10px;
  }

  .g-form__label {
    width: 100%;
    margin-bottom: 10px;
  }

  .g-form__inputfield {
    width: 100%;
  }

  .g-form__inputwrap {
    margin-bottom: 10px;
  }

  .g-form__input {
    width: 100%;
  }

  .g-form__birthday {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }

  .g-form__birthday-item {
    width: 100%;
    padding-right: 0;
    margin-bottom: 5px;
  }

  .g-form__birthday-item .g-form__input {
    width: calc(100% - 30px);
  }
}
.g-table {
  max-width: 850px;
  width: 100%;
  margin: 64px auto 32px;
}

.g-table__row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 24px 24px 24px 0;
  border-bottom: 1px solid #e0e0e0;
}

.g-table__row:first-child {
  border-top: 1px solid #e0e0e0;
}

.g-table__def {
  width: 170px;
}

.g-table__data,
.g-table__def {
  padding-left: 24px;
  line-height: 1.5;
}

.g-table__data {
  width: calc(100% - 170px);
}

@media screen and (max-width: 768px) {
  .g-table {
    margin: 32px auto;
  }

  .g-table__row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    padding: 0;
  }

  .g-table__data,
.g-table__def {
    width: 100%;
  }

  .g-table__def {
    padding: 12px;
    text-align: center;
    font-weight: 700;
    border-bottom: 1px solid #e0e0e0;
  }

  .g-table__data {
    padding: 16px 12px;
  }
}
.g-pagination__next,
.g-pagination__prev {
  width: 18px;
  height: 14px;
  fill: #212121;
}

.g-pagination__prev {
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
}

.g-pagination .screen-reader-text {
  display: none;
}

.g-pagination .nav-links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.g-pagination .page-numbers {
  width: 40px;
  height: 40px;
  line-height: 40px;
  text-align: center;
}

.g-pagination .page-numbers.current {
  color: #fff;
  background-color: #212121;
}

.swiper-container {
  margin: 0 auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  z-index: 1;
}

.swiper-container-no-flexbox .swiper-slide {
  float: left;
}

.swiper-container-vertical > .swiper-wrapper {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
}

.swiper-container-android .swiper-slide,
.swiper-wrapper {
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}

.swiper-container-multirow > .swiper-wrapper {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.swiper-container-free-mode > .swiper-wrapper {
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
  margin: 0 auto;
}

.swiper-slide {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
}

.swiper-slide-invisible-blank {
  visibility: hidden;
}

.swiper-container-autoheight,
.swiper-container-autoheight .swiper-slide {
  height: auto;
}

.swiper-container-autoheight .swiper-wrapper {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-transition-property: height, -webkit-transform;
  transition-property: height, -webkit-transform;
  transition-property: transform, height;
  transition-property: transform, height, -webkit-transform;
}

.swiper-container-3d {
  -webkit-perspective: 1200px;
  perspective: 1200px;
}

.swiper-container-3d .swiper-cube-shadow,
.swiper-container-3d .swiper-slide,
.swiper-container-3d .swiper-slide-shadow-bottom,
.swiper-container-3d .swiper-slide-shadow-left,
.swiper-container-3d .swiper-slide-shadow-right,
.swiper-container-3d .swiper-slide-shadow-top,
.swiper-container-3d .swiper-wrapper {
  -webkit-transform-style: preserve-3d;
  transform-style: preserve-3d;
}

.swiper-container-3d .swiper-slide-shadow-bottom,
.swiper-container-3d .swiper-slide-shadow-left,
.swiper-container-3d .swiper-slide-shadow-right,
.swiper-container-3d .swiper-slide-shadow-top {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10;
}

.swiper-container-3d .swiper-slide-shadow-left {
  background-image: -webkit-gradient(linear, right top, left top, from(rgba(0, 0, 0, 0.5)), to(transparent));
  background-image: linear-gradient(270deg, rgba(0, 0, 0, 0.5), transparent);
}

.swiper-container-3d .swiper-slide-shadow-right {
  background-image: -webkit-gradient(linear, left top, right top, from(rgba(0, 0, 0, 0.5)), to(transparent));
  background-image: linear-gradient(90deg, rgba(0, 0, 0, 0.5), transparent);
}

.swiper-container-3d .swiper-slide-shadow-top {
  background-image: -webkit-gradient(linear, left bottom, left top, from(rgba(0, 0, 0, 0.5)), to(transparent));
  background-image: linear-gradient(0deg, rgba(0, 0, 0, 0.5), transparent);
}

.swiper-container-3d .swiper-slide-shadow-bottom {
  background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.5)), to(transparent));
  background-image: linear-gradient(180deg, rgba(0, 0, 0, 0.5), transparent);
}

.swiper-container-wp8-horizontal,
.swiper-container-wp8-horizontal > .swiper-wrapper {
  -ms-touch-action: pan-y;
  touch-action: pan-y;
}

.swiper-container-wp8-vertical,
.swiper-container-wp8-vertical > .swiper-wrapper {
  -ms-touch-action: pan-x;
  touch-action: pan-x;
}

.swiper-button-next,
.swiper-button-prev {
  position: absolute;
  top: 50%;
  width: 27px;
  height: 44px;
  margin-top: -22px;
  z-index: 10;
  cursor: pointer;
  background-size: 27px 44px;
  background-position: 50%;
  background-repeat: no-repeat;
}

.swiper-button-next.swiper-button-disabled,
.swiper-button-prev.swiper-button-disabled {
  opacity: 0.35;
  cursor: auto;
  pointer-events: none;
}

.swiper-button-prev,
.swiper-container-rtl .swiper-button-next {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 27 44'%3E%3Cpath fill='%230068B7' d='M0 22 22 0l2.1 2.1L4.2 22l19.9 19.9L22 44 0 22z'/%3E%3C/svg%3E");
  left: 10px;
  right: auto;
}

.swiper-button-next,
.swiper-container-rtl .swiper-button-prev {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 27 44'%3E%3Cpath fill='%230068B7' d='M27 22 5 44l-2.1-2.1L22.8 22 2.9 2.1 5 0l22 22z'/%3E%3C/svg%3E");
  right: 10px;
  left: auto;
}

.swiper-button-prev.swiper-button-white,
.swiper-container-rtl .swiper-button-next.swiper-button-white {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 27 44'%3E%3Cpath d='M0 22L22 0l2.1 2.1L4.2 22l19.9 19.9L22 44 0 22z' fill='%23fff'/%3E%3C/svg%3E");
}

.swiper-button-next.swiper-button-white,
.swiper-container-rtl .swiper-button-prev.swiper-button-white {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 27 44'%3E%3Cpath d='M27 22L5 44l-2.1-2.1L22.8 22 2.9 2.1 5 0l22 22z' fill='%23fff'/%3E%3C/svg%3E");
}

.swiper-button-prev.swiper-button-black,
.swiper-container-rtl .swiper-button-next.swiper-button-black {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 27 44'%3E%3Cpath d='M0 22L22 0l2.1 2.1L4.2 22l19.9 19.9L22 44 0 22z'/%3E%3C/svg%3E");
}

.swiper-button-next.swiper-button-black,
.swiper-container-rtl .swiper-button-prev.swiper-button-black {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 27 44'%3E%3Cpath d='M27 22L5 44l-2.1-2.1L22.8 22 2.9 2.1 5 0l22 22z'/%3E%3C/svg%3E");
}

.swiper-button-lock {
  display: none;
}

.swiper-pagination {
  position: absolute;
  text-align: center;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  z-index: 10;
}

.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}

.swiper-container-horizontal > .swiper-pagination-bullets,
.swiper-pagination-custom,
.swiper-pagination-fraction {
  bottom: 10px;
  left: 0;
  width: 100%;
}

.swiper-pagination-bullets-dynamic {
  overflow: hidden;
  font-size: 0;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  -webkit-transform: scale(0.33);
  transform: scale(0.33);
  position: relative;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active,
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  -webkit-transform: scale(1);
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  -webkit-transform: scale(0.66);
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  -webkit-transform: scale(0.33);
  transform: scale(0.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  -webkit-transform: scale(0.66);
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  -webkit-transform: scale(0.33);
  transform: scale(0.33);
}

.swiper-pagination-bullet {
  width: 8px;
  height: 8px;
  display: inline-block;
  border-radius: 100%;
  background: #000;
  opacity: 0.2;
}

button.swiper-pagination-bullet {
  border: none;
  margin: 0;
  padding: 0;
  -webkit-box-shadow: none;
  box-shadow: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}

.swiper-pagination-bullet-active {
  opacity: 1;
  background: #007aff;
}

.swiper-container-vertical > .swiper-pagination-bullets {
  right: 10px;
  top: 50%;
  -webkit-transform: translate3d(0, -50%, 0);
  transform: translate3d(0, -50%, 0);
}

.swiper-container-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 6px 0;
  display: block;
}

.swiper-container-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 8px;
}

.swiper-container-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  display: inline-block;
  -webkit-transition: top 0.2s, -webkit-transform 0.2s;
  transition: top 0.2s, -webkit-transform 0.2s;
  transition: transform 0.2s, top 0.2s;
  transition: transform 0.2s, top 0.2s, -webkit-transform 0.2s;
}

.swiper-container-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 4px;
}

.swiper-container-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  white-space: nowrap;
}

.swiper-container-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  -webkit-transition: left 0.2s, -webkit-transform 0.2s;
  transition: left 0.2s, -webkit-transform 0.2s;
  transition: transform 0.2s, left 0.2s;
  transition: transform 0.2s, left 0.2s, -webkit-transform 0.2s;
}

.swiper-container-horizontal.swiper-container-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  -webkit-transition: right 0.2s, -webkit-transform 0.2s;
  transition: right 0.2s, -webkit-transform 0.2s;
  transition: transform 0.2s, right 0.2s;
  transition: transform 0.2s, right 0.2s, -webkit-transform 0.2s;
}

.swiper-pagination-progressbar {
  background: rgba(0, 0, 0, 0.25);
  position: absolute;
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: #007aff;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  -webkit-transform: scale(0);
  transform: scale(0);
  -webkit-transform-origin: left top;
  transform-origin: left top;
}

.swiper-container-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  -webkit-transform-origin: right top;
  transform-origin: right top;
}

.swiper-container-horizontal > .swiper-pagination-progressbar,
.swiper-container-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
  width: 100%;
  height: 4px;
  left: 0;
  top: 0;
}

.swiper-container-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.swiper-container-vertical > .swiper-pagination-progressbar {
  width: 4px;
  height: 100%;
  left: 0;
  top: 0;
}

.swiper-pagination-white .swiper-pagination-bullet-active {
  background: #fff;
}

.swiper-pagination-progressbar.swiper-pagination-white {
  background: rgba(255, 255, 255, 0.25);
}

.swiper-pagination-progressbar.swiper-pagination-white .swiper-pagination-progressbar-fill {
  background: #fff;
}

.swiper-pagination-black .swiper-pagination-bullet-active {
  background: #000;
}

.swiper-pagination-progressbar.swiper-pagination-black {
  background: rgba(0, 0, 0, 0.25);
}

.swiper-pagination-progressbar.swiper-pagination-black .swiper-pagination-progressbar-fill {
  background: #000;
}

.swiper-pagination-lock {
  display: none;
}

.swiper-container-fade.swiper-container-free-mode .swiper-slide {
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}

.swiper-container-fade .swiper-slide {
  pointer-events: none;
  -webkit-transition-property: opacity;
  transition-property: opacity;
}

.swiper-container-fade .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-container-fade .swiper-slide-active,
.swiper-container-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.hero {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: calc(100vh - 200px);
  top: 200px;
  margin-bottom: 300px;
}

.hero__tagline {
  text-align: center;
  color: #fff;
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.5;
}

.hero__slider {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

.hero__slider .swiper-pagination {
  bottom: 32px;
}

.hero__slider .swiper-pagination-bullet {
  position: relative;
  width: 112px;
  height: 4px;
  margin: 0 15px !important;
  background: #e0e0e0;
  border-radius: 0;
  opacity: 1;
  overflow: hidden;
}

.hero__slider .swiper-pagination-bullet-active:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #5695ea;
  -webkit-transform: translateX(-100%);
  transform: translateX(-100%);
  -webkit-animation: sliderBullet 2.85s forwards;
  animation: sliderBullet 2.85s forwards;
}

.hero__image,
.hero__slide,
.hero__sliderwrap {
  height: 100%;
}

.hero__slide {
  overflow: hidden;
}

.hero__slide.swiper-slide-active .hero__image,
.hero__slide.swiper-slide-duplicate-active .hero__image {
  -webkit-transform: scale(1);
  transform: scale(1);
}

.hero__image {
  background-size: cover;
  background-repeat: no-repeat;
  /*background-position: 50%;*/
  background-position: top;
  -webkit-transform: scale(1.075);
  transform: scale(1.075);
  -webkit-transition: -webkit-transform 2.5s;
  transition: -webkit-transform 2.5s;
  transition: transform 2.5s;
  transition: transform 2.5s, -webkit-transform 2.5s;
}

.hero__scroll {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: absolute;
  color: #fff;
  bottom: 30px;
  right: 30px;
}

.hero__scroll-text {
  font-size: 1.2rem;
  font-weight: 700;
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
  text-transform: uppercase;
}

.hero__scroll-track {
  width: 2px;
  height: 100px;
  margin-top: 30px;
  overflow: hidden;
}

.hero__scroll-track span {
  display: block;
  width: 100%;
  height: 90px;
  background: #fff;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0, rgba(0, 0, 0, 0.1)), to(#fff));
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.1) 0, #fff);
  -webkit-animation: animLine 2s ease-in-out infinite;
  animation: animLine 2s ease-in-out infinite;
}

@-webkit-keyframes animLine {
  0% {
    -webkit-transform: translateY(-100px);
    transform: translateY(-100px);
  }
  to {
    -webkit-transform: translateY(100px);
    transform: translateY(100px);
  }
}
@keyframes animLine {
  0% {
    -webkit-transform: translateY(-100px);
    transform: translateY(-100px);
  }
  to {
    -webkit-transform: translateY(100px);
    transform: translateY(100px);
  }
}
@-webkit-keyframes sliderBullet {
  0% {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
  }
  to {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}
@keyframes sliderBullet {
  0% {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
  }
  to {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}
@media screen and (max-width: 768px) {
  .hero {
    height: 65vh;
    top: 72px;
    margin-bottom: 100px;
  }

  .hero__slider .swiper-pagination-bullet {
    width: 56px;
    margin: 0 8px !important;
  }

  .hero__scroll {
    display: none;
  }
}
@media screen and (max-width: 576px) {
  .hero__tagline {
    font-size: 2.4rem;
  }
}
.about {
  position: relative;
}

.about__container {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  height: 100%;
}

.about__textbox {
  max-width: 544px;
  width: 100%;
  margin: 0 auto;
  color: #fff;
  z-index: 1;
}

.about__title {
  font-size: 2.4rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 20px;
}

.about__text,
.about__title {
  line-height: 1.5;
}

.about__bg {
  position: absolute;
  top: 0;
  left: 15px;
  height: calc(100vh - 144px);
  max-width: 544px;
  width: 100%;
}

.about__bg-textbox {
  max-width: 320px;
  width: 100%;
  color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  z-index: 3;
}

.about__bg-title {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 15px;
}

.about__bg-text {
  line-height: 1.5;
  margin-bottom: 36px;
}

.about__bg-imagebox {
  position: relative;
  height: 100%;
  background-color: #361300;
  overflow: hidden;
}

.about__bg-imagewrap {
  position: absolute;
  height: 100%;
  width: 100%;
  overflow: hidden;
  opacity: 0;
  -webkit-transition: opacity 0.5s;
  transition: opacity 0.5s;
}

.about__bg-imagewrap--current {
  opacity: 1;
}

.about__bg-imagewrap--current .about__bg-image {
  -webkit-transform: scale(1);
  transform: scale(1);
}

.about__bg-image {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  height: 100%;
  background-position: 50%;
  background-size: cover;
  background-repeat: no-repeat;
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
  -webkit-transition: -webkit-transform 1s;
  transition: -webkit-transform 1s;
  transition: transform 1s;
  transition: transform 1s, -webkit-transform 1s;
}

.about__info {
  max-width: 544px;
  width: 100%;
  z-index: 1;
}

.about__info-block {
  padding: 120px 0;
}

.about__info-image {
  margin-bottom: 32px;
}

.about__info-textbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  line-height: 1.5;
}

.about__info-textwrap {
  max-width: 320px;
  width: 100%;
}

@media screen and (max-width: 1024px) {
  .about__container {
    position: static;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }

  .about__bg {
    max-width: 100%;
    height: 100vh;
    left: 0;
  }

  .about__bg-imagebox {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
  }

  .about__bg-textbox {
    display: none;
  }

  .about__info {
    margin: 0 auto;
  }

  .about__info-textbox {
    color: #fff;
  }

  .about__info-textwrap {
    max-width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .about__info-block {
    padding: 32px 0;
  }

  .about__info-image {
    margin-bottom: 24px;
  }
}
.products {
  padding-bottom: 0;
}

.products__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 72px 0 0;
}

.products__item {
  width: 34%;
  height: 556px;
}

.products__item,
.products__link {
  position: relative;
  overflow: hidden;
}

.products__link {
  height: 100%;
  padding: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  -webkit-box-shadow: inset 0 -150px 60px -25px rgba(0, 0, 0, 0.25);
  box-shadow: inset 0 -150px 60px -25px rgba(0, 0, 0, 0.25);
  -webkit-transition: -webkit-box-shadow 0.5s;
  transition: -webkit-box-shadow 0.5s;
  transition: box-shadow 0.5s;
  transition: box-shadow 0.5s, -webkit-box-shadow 0.5s;
}

.products__link:focus,
.products__link:hover {
  -webkit-box-shadow: inset 0 -150px 60px -25px rgba(0, 0, 0, 0.35);
  box-shadow: inset 0 -150px 60px -25px rgba(0, 0, 0, 0.35);
}

.products__link:focus .products__icon-circle,
.products__link:hover .products__icon-circle {
  stroke-dashoffset: 0;
  fill: #fff;
  -webkit-transition: stroke-dashoffset 0.5s, fill 0.3s 0.3s;
  transition: stroke-dashoffset 0.5s, fill 0.3s 0.3s;
}

.products__link:focus .products__icon-arrow,
.products__link:hover .products__icon-arrow {
  fill: #212121;
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}

.products__link:focus .products__background,
.products__link:hover .products__background {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
  -webkit-transition: -webkit-transform 3s;
  transition: -webkit-transform 3s;
  transition: transform 3s;
  transition: transform 3s, -webkit-transform 3s;
}

.products__background {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50%;
  z-index: -1;
  -webkit-transition: -webkit-transform 1.5s;
  transition: -webkit-transform 1.5s;
  transition: transform 1.5s;
  transition: transform 1.5s, -webkit-transform 1.5s;
}

.products__textbox {
  text-align: center;
}

.products__title {
  color: #fff;
  font-size: 2rem;
  font-weight: 700;
  text-align: left;
  line-height: 1.5;
  margin-bottom: 10px;
}

.products__icon {
  position: relative;
  width: 48px;
  height: 48px;
  display: inline-block;
}

.products__icon-circle {
  width: 48px;
  height: 48px;
  position: absolute;
  top: 0;
  left: 0;
  fill: transparent;
  stroke: #fff;
  stroke-width: 1;
  stroke-dasharray: 132 132;
  stroke-dashoffset: 132;
  -webkit-transition: stroke-dashoffset 0.5s;
  transition: stroke-dashoffset 0.5s;
  -webkit-transform: rotate(-90deg);
  transform: rotate(-90deg);
}

.products__icon-arrow {
  fill: #fff;
  width: 20px;
  height: 15px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-transition: fill 0.3s;
  transition: fill 0.3s;
}

@media screen and (max-width: 1024px) {
  .products__link {
    padding: 20px;
  }
}
@media screen and (max-width: 768px) {
  .products__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }

  .products__item {
    width: 100%;
    height: 434px;
  }

  .products__link {
    padding: 28px;
  }
}
@media screen and (max-width: 576px) {
  .products__list {
    margin: 36px 0;
  }
}
.news {
  background-color: #f5f5f5;
}

.news__list {
  max-width: 850px;
  width: 100%;
  margin: 72px auto;
}

.news__item {
  border-bottom: 1px solid #e0e0e0;
}

.news__item:first-child {
  border-top: 1px solid #e0e0e0;
}

.news__link {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 24px 24px 24px 0;
  line-height: 1.5;
  -webkit-transition: color 0.3s;
  transition: color 0.3s;
  z-index: 1;
}

.news__link:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  background-color: #ebebeb;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: right;
  transform-origin: right;
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
  z-index: -1;
}

.news__link:focus:after,
.news__link:hover:after {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transform-origin: left;
  transform-origin: left;
}

.news__date {
  width: 128px;
  text-align: center;
}

.news__title {
  width: calc(100% - 128px);
}

.news__title,
.news__title h3 {
  font-size: 1.6rem;
}

@media screen and (max-width: 768px) {
  .news__link {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    padding: 16px;
  }

  .news__date {
    width: 100%;
    text-align: left;
    margin-bottom: 5px;
  }

  .news__title {
    width: 100%;
  }
}
@media screen and (max-width: 576px) {
  .news__list {
    margin: 36px 0;
  }
}
.recruit {
  position: relative;
  padding: 120px 0;
  color: #fff;
}

.recruit__background {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50%;
  background-attachment: fixed;
  z-index: -1;
}

.recruit .g-btn {
  margin-top: 48px;
}

@media screen and (max-width: 1024px) {
  .recruit__background {
    background-attachment: scroll;
  }
}
@media screen and (max-width: 576px) {
  .recruit {
    padding: 60px 0;
  }
}
.b-textbox {
  position: relative;
  padding: 40px 33px;
  margin: -100px 0 0;
  background-color: #fff;
  z-index: 1;
}

.b-textbox__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 40px -16px 0;
}

.b-textbox__item {
  width: 33.333%;
  padding: 0 16px;
}

.b-textbox__imagebox {
  margin-bottom: 24px;
}

.b-textbox__imagebox img {
  width: 100%;
}

.b-textbox__title {
  font-size: 1.6rem;
  font-weight: 700;
  margin-bottom: 16px;
}

.b-textbox__text {
  line-height: 1.5;
  margin-bottom: 32px;
}

.b-textbox__gallery {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0 -16px;
}

.b-textbox__gallery-item {
  max-width: 460px;
  width: 100%;
  padding: 0 16px 32px;
}

.b-textbox__gallery-item img {
  width: 100%;
}

.b-textbox__measurements {
  max-width: 850px;
  width: 100%;
  margin: 0 auto 48px;
}

.b-textbox__heading {
  font-size: 2rem;
  font-weight: 700;
  padding-bottom: 12px;
  margin-bottom: 32px;
  border-bottom: 4px solid #e0e0e0;
}

.b-textbox__row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 16px;
}

.b-textbox__col {
  width: 50%;
}

.b-textbox__detail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.b-textbox__detail span {
  display: inline-block;
  width: 48px;
  height: 48px;
  line-height: 48px;
  font-size: 1.2rem;
  text-align: center;
  margin-right: 15px;
  border: 1px solid #212121;
  border-radius: 50%;
}

.b-textbox__note {
  font-size: 1.4rem;
  line-height: 1.5;
}

@media screen and (max-width: 1024px) {
  .b-textbox {
    padding: 32px 24px;
  }

  .b-textbox__list {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 20px 0;
  }

  .b-textbox__item {
    width: 100%;
    padding: 16px 0;
  }

  .b-textbox__gallery-item {
    max-width: none;
    width: 50%;
  }
}
@media screen and (max-width: 768px) {
  .b-textbox .g-heading-1 {
    font-size: 2rem;
    margin-bottom: 20px;
  }

  .b-textbox .g-subheading {
    margin: 20px 0;
    text-align: left;
  }

  .b-textbox__text {
    margin-bottom: 20px;
  }

  .b-textbox__gallery {
    margin-bottom: 32px;
  }

  .b-textbox__gallery-item {
    width: 100%;
    padding: 8px;
  }

  .b-textbox__measurements {
    margin: 0 auto 32px;
  }

  .b-textbox__row {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

  .b-textbox__col {
    width: 100%;
    margin-bottom: 10px;
  }
}
.b-point__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 64px -16px;
}

.b-point__item {
  max-width: 264px;
  width: 100%;
  margin: 0 12px;
}

.b-point__icon {
  position: relative;
  text-align: center;
}

.b-point__icon svg {
  width: 45px;
  height: 56px;
  fill: #212121;
}

.b-point__icon:after {
  content: "";
  display: block;
  width: 140px;
  height: 2px;
  margin: 0 auto 20px;
  background-color: #212121;
}

.b-point__title {
  font-size: 2rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 20px;
}

.b-point__text {
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  .b-point__list {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 32px 0;
  }

  .b-point__item {
    max-width: none;
    width: 50%;
    padding: 12px;
    margin: 0;
  }

  .b-point__icon:after {
    width: 100%;
  }
}
.b-product__list {
  padding-top: 38px;
}

.b-product__item {
  padding: 32px;
  background-color: #fff;
}

.b-product__item + .b-product__item {
  margin-top: 32px;
}

.b-product__tagline {
  display: block;
  text-align: center;
  font-size: 2rem;
  font-weight: 700;
  padding-bottom: 12px;
  margin-bottom: 32px;
  border-bottom: 4px solid #e0e0e0;
  line-height: 1.5;
}

.b-product__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0 -16px;
}

.b-product__imagebox,
.b-product__textbox {
  width: 50%;
  padding: 0 16px;
}

.b-product__title {
  font-weight: 700;
  margin-bottom: 16px;
}

.b-product__text {
  line-height: 1.5;
  margin-bottom: 24px;
}

.b-product__detail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 24px;
}

.b-product__detail p {
  display: inline-block;
  width: calc(100% - 48px);
  font-weight: 700;
  line-height: 1.5;
}

.b-product__detail span {
  display: inline-block;
  width: 48px;
  height: 48px;
  line-height: 48px;
  font-size: 1.2rem;
  font-weight: 400;
  text-align: center;
  margin-right: 15px;
  border: 1px solid #212121;
  border-radius: 50%;
}

.b-product__price span {
  font-weight: 700;
}

.b-product__btn {
  max-width: 464px;
  margin-top: 32px;
}

.b-product__btn .g-btn__icon {
  right: 48px;
}

.b-product__btn .g-btn__icon svg {
  width: 11px;
  height: 14px;
}

@media screen and (max-width: 768px) {
  .b-product__item {
    padding: 24px;
  }

  .b-product__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin: 0;
  }

  .b-product__imagebox {
    width: 100%;
    padding: 0;
    margin-bottom: 24px;
  }

  .b-product__textbox {
    width: 100%;
    padding: 0;
  }

  .b-product__tagline {
    margin-bottom: 12px;
  }

  .b-product__detail,
.b-product__text {
    margin-bottom: 16px;
  }

  .b-product__btn .g-btn__link {
    line-height: 1.5;
  }

  .b-product__btn .g-btn__icon {
    right: 12px;
  }
}
.c-message__content {
  max-width: 850px;
  width: 100%;
  margin: 0 auto;
}

.c-message__image {
  margin: 72px 0 40px;
}

.c-message__image img {
  width: 100%;
}

.c-message__text {
  margin-bottom: 24px;
  line-height: 1.5;
}

.c-message__signature {
  text-align: right;
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  .c-message__image {
    margin: 32px 0 20px;
  }

  .c-message__content .g-heading-1 {
    font-size: 2rem;
    margin-bottom: 20px;
  }
}
.c-slider {
  max-width: 850px;
  margin: 0 auto 64px;
}

@media screen and (max-width: 768px) {
  .c-slider {
    margin: 0 auto 32px;
  }
}
.c-office__list {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0 -16px;
}

.c-office__item,
.c-office__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.c-office__item {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  width: 50%;
  padding: 16px;
}

.c-office__item--fullwidth {
  width: 100%;
}

.c-office__item--fullwidth .c-office__frame {
  height: 600px;
}

.c-office__frame {
  height: 300px;
}

.c-office__textbox {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding: 32px;
  background-color: #fff;
}

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

.c-office__col {
  width: 50%;
}

.c-office__col:first-of-type {
  padding-right: 64px;
}

.c-office__title {
  width: 100%;
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 12px;
}

.c-office__text {
  line-height: 1.5;
}

.c-office__text svg {
  margin-right: 5px;
  fill: #212121;
  width: 13px;
  height: 16px;
}

@media screen and (max-width: 768px) {
  .c-office__list {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

  .c-office__item {
    width: 100%;
  }

  .c-office__item--fullwidth .c-office__frame {
    height: 300px;
  }

  .c-office__col {
    width: 100%;
  }

  .c-office__col::first-of-type {
    padding-right: 0;
  }

  .c-office__textbox {
    padding: 16px;
  }
}
.s-textbox {
  position: relative;
  padding: 40px 33px;
  margin: -100px 0 0;
  background-color: #fff;
  z-index: 1;
}
.s-textbox--mt0 {
  margin-top: 0;
}

.s-textbox__slider {
  position: relative;
/*  max-width: 496px;*/
  max-width: 896px;
  width: 100%;
  margin: 40px auto 0;
}

.s-textbox__slide img {
  width: 100%;
}

.s-textbox__next,
.s-textbox__prev {
  width: 18px;
  height: 32px;
  background-size: 18px 32px;
}

.s-textbox__prev {
  left: -40px;
}

.s-textbox__next {
  right: -40px;
}

.s-textbox__title {
  display: block;
  max-width: 850px;
  width: 100%;
  font-size: 2rem;
  font-weight: 700;
  padding: 10px 0;
  margin: 0 auto 32px;
  border-bottom: 4px solid #e0e0e0;
}

.s-textbox__list {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  max-width: 850px;
  width: 100%;
  margin: 0 auto;
}

.s-textbox__item,
.s-textbox__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.s-textbox__item {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 50%;
  padding: 8px 16px;
}

.s-textbox__number {
  width: 48px;
  height: 48px;
  line-height: 48px;
  margin-right: 10px;
  text-align: center;
  border: 1px solid #212121;
  border-radius: 50%;
}

.s-textbox__number,
.s-textbox__text {
  display: inline-block;
  font-weight: 700;
}

.s-textbox__text {
  width: calc(100% - 48px);
  line-height: 1.5;
}

@media screen and (max-width: 1024px) {
  .s-textbox {
    padding: 32px 24px;
  }
}
@media screen and (max-width: 768px) {
  .s-textbox .g-heading-1 {
    font-size: 2rem;
    margin-bottom: 20px;
  }

  .s-textbox .g-subheading {
    margin: 20px 0;
    text-align: left;
  }

  .s-textbox__list {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

  .s-textbox__item {
    width: 100%;
    padding: 4px 0;
  }

  .s-textbox__title {
    margin: 0 auto 16px;
  }

  .s-textbox__next,
.s-textbox__prev {
    width: 14px;
    height: 24px;
    background-size: 14px 24px;
  }

  .s-textbox__next {
    right: -17px;
  }

  .s-textbox__prev {
    left: -17px;
  }
}
.s-uniform__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 64px -16px 40px;
}

.s-uniform__item {
  width: 33.333%;
  padding: 0 16px;
}

.s-uniform__imagebox {
  margin-bottom: 24px;
  overflow: hidden;
}

.s-uniform__imagebox img {
  width: 100%;
  -webkit-transition: -webkit-transform 1.25s;
  transition: -webkit-transform 1.25s;
  transition: transform 1.25s;
  transition: transform 1.25s, -webkit-transform 1.25s;
}

.s-uniform__title {
  font-size: 1.6rem;
  font-weight: 700;
  margin-bottom: 16px;
}

.s-uniform__text {
  line-height: 1.5;
}

.s-uniform__option {
  padding: 32px;
  background-color: #f5f5f5;
  border: 1px solid #e0e0e0;
}

.s-uniform__option strong {
  display: block;
  line-height: 1.5;
  margin-bottom: 12px;
}

.s-uniform__row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.s-uniform__col {
  width: 50%;
}

@media screen and (max-width: 1024px) {
  .s-uniform__row {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

  .s-uniform__col {
    width: 100%;
    margin-bottom: 10px;
  }

  .s-uniform__col:last-child,
.s-uniform__col:last-child strong {
    margin-bottom: 0;
  }
}
@media screen and (max-width: 768px) {
  .s-uniform__list {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 32px 0;
  }

  .s-uniform__item {
    width: 100%;
    padding: 16px 0;
  }

  .s-uniform__title {
    margin-bottom: 8px;
  }

  .s-uniform__option {
    padding: 24px;
  }
}
.s-feature__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 64px -16px 40px;
}

.s-feature__item {
  width: 50%;
  padding: 16px;
}

.s-feature__imagebox img {
  width: 100%;
}

.s-feature__textbox {
  padding: 32px;
  background-color: #f5f5f5;
}

.s-feature__title {
  font-size: 1.6rem;
  font-weight: 700;
  margin-bottom: 16px;
}

.s-feature__text {
  line-height: 1.5;
  margin-bottom: 16px;
}

.s-feature__table {
  padding: 16px;
  border: 1px solid #e0e0e0;
}

.s-feature__row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 4px 0;
}

.s-feature__def {
  width: 70px;
}

.s-feature__data {
  width: calc(100% - 70px);
}

@media screen and (max-width: 768px) {
  .s-feature__list {
    margin: 32px 0 0;
  }

  .s-feature__item {
    width: 100%;
    padding: 16px 0;
  }

  .s-feature__textbox {
    padding: 24px 16px;
  }

  .s-feature__row {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

  .s-feature__data,
.s-feature__def {
    width: 100%;
    padding: 8px 0;
  }

  .s-feature__def {
    text-align: center;
    font-weight: 700;
    border-top: 1px solid #e0e0e0;
    border-bottom: 1px solid #e0e0e0;
  }
}
.s-catalog__anchors {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: 24px;
}

.s-catalog__anchor {
  width: 20%;
  margin-bottom: 10px;
  border-right: 1px solid #e0e0e0;
}

.s-catalog__anchor:last-child {
  border-right: none;
}

.s-catalog__anchor a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
  font-size: 1.4rem;
  padding: 20px 10px;
  line-height: 1.25;
  overflow: hidden;
  z-index: 1;
}

.s-catalog__anchor a:before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: #ebebeb;
  -webkit-transform: scaleY(0);
  transform: scaleY(0);
  -webkit-transform-origin: bottom;
  transform-origin: bottom;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  z-index: -1;
}

.s-catalog__anchor a:hover:before {
  -webkit-transform: scaleY(1);
  transform: scaleY(1);
  -webkit-transform-origin: top;
  transform-origin: top;
}

.s-catalog__anchor svg {
  width: 20px;
  height: 20px;
  margin-left: 5px;
  fill: #212121;
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}

.s-catalog__list {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0 -32px;
}

.s-catalog__item,
.s-catalog__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.s-catalog__item {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  max-width: 264px;
  width: 100%;
  padding: 16px 32px;
}

.s-catalog__image {
  margin-bottom: 12px;
}

@media (-ms-high-contrast: active), (-ms-high-contrast: none) {
  .s-catalog__image {
    max-height: 300px;
  }
}
.s-catalog__image img {
  width: 100%;
  height: auto;
}

.s-catalog__link a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-size: 1.4rem;
  padding: 12px 0;
  color: #0068b7;
  -webkit-transition: color 0.3s;
  transition: color 0.3s;
}

.s-catalog__link a:hover {
  color: #212121;
}

.s-catalog__link a:hover svg {
  fill: #212121;
}

.s-catalog__link span {
  margin-right: 20px;
}

.s-catalog__link svg {
  width: 14px;
  height: 14px;
  fill: #0068b7;
  -webkit-transition: fill 0.3s;
  transition: fill 0.3s;
}

.s-catalog__btn {
  margin-top: auto;
}

@media screen and (max-width: 1024px) {
  .s-catalog__anchor {
    width: 25%;
  }

  .s-catalog__anchor:nth-child(4n) {
    border-right: none;
  }

  .s-catalog__item {
    max-width: 250px;
  }
}
@media screen and (max-width: 768px) {
  .s-catalog__anchor {
    width: 50%;
  }

  .s-catalog__anchor:nth-child(2n) {
    border-right: none;
  }

  .s-catalog__anchor a {
    padding: 20px 30px 20px 10px;
  }

  .s-catalog__anchor svg {
    position: absolute;
    top: 32%;
    right: 10px;
    margin-left: 0;
  }

  .s-catalog__list {
    margin: 0 -8px;
  }

  .s-catalog__item {
    max-width: none;
    width: 50%;
    padding: 16px 8px;
  }

  .s-catalog__link span {
    display: inline-block;
    width: calc(100% - 14px);
  }
}
.ca-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 60px -16px 72px;
}

.ca-listwrap {
  display: none;
}

.ca-listwrap--active {
  display: block;
  -webkit-animation: listFadeIn 1s forwards;
  animation: listFadeIn 1s forwards;
}

@-webkit-keyframes listFadeIn {
  0% {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes listFadeIn {
  0% {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.ca-item {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  max-width: 526px;
  width: 100%;
  padding: 16px;
}

.ca-item,
.ca-item__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
}

.ca-item__link {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-flex: 1;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto;
}

.ca-item__link:focus .ca-item__imagebox img,
.ca-item__link:hover .ca-item__imagebox img {
  -webkit-transform: scale(1.05);
  transform: scale(1.05);
}

.ca-item__link:focus .ca-item__icon-circle,
.ca-item__link:hover .ca-item__icon-circle {
  stroke: #0068b7;
  stroke-dashoffset: 0;
  fill: #0068b7;
  -webkit-transition: stroke-dashoffset 0.5s, fill 0.3s 0.25s;
  transition: stroke-dashoffset 0.5s, fill 0.3s 0.25s;
}

.ca-item__link:focus .ca-item__icon-arrow,
.ca-item__link:hover .ca-item__icon-arrow {
  fill: #fff;
  -webkit-transition-delay: 0.25s;
  transition-delay: 0.25s;
}

.ca-item__imagebox {
  width: 100%;
  overflow: hidden;
}

.ca-item__imagebox img {
  width: 100%;
  height: auto;
  -webkit-transition: -webkit-transform 1s;
  transition: -webkit-transform 1s;
  transition: transform 1s;
  transition: transform 1s, -webkit-transform 1s;
}

.ca-item__textbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-flex: 1;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto;
  background-color: #fff;
  padding: 32px;
}

.ca-item__title {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
}

.ca-item__title small {
  position: relative;
  display: inline-block;
  font-size: 1.4rem;
  margin-bottom: 10px;
}

.ca-item__title span {
  display: block;
}

.ca-item__icon {
  position: relative;
  display: block;
  margin: auto 0 0 auto;
  width: 36px;
  height: 36px;
}

.ca-item__icon-circle {
  width: 36px;
  height: 36px;
  position: absolute;
  top: 0;
  left: 0;
  fill: transparent;
  stroke: #212121;
  stroke-width: 1;
  stroke-dasharray: 132 132;
  stroke-dashoffset: 132;
  -webkit-transition: stroke-dashoffset 0.5s;
  transition: stroke-dashoffset 0.5s;
  -webkit-transform: rotate(-90deg);
  transform: rotate(-90deg);
}

.ca-item__icon-arrow {
  fill: #212121;
  width: 14px;
  height: 11px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-transition: fill 0.3s;
  transition: fill 0.3s;
}

@media screen and (max-width: 1024px) {
  .ca-item {
    max-width: 360px;
  }
}
@media screen and (max-width: 768px) {
  .ca-list {
    margin: 60px 0 72px;
  }

  .ca-item {
    max-width: 100%;
    padding: 0 0 16px;
  }
}
@media screen and (max-width: 576px) {
  .ca-list {
    margin: 36px 0 24px;
  }

  .ca-item__textbox {
    padding: 16px;
  }

  .ca-item__title {
    font-size: 1.6rem;
  }

  .ca-item__title small {
    font-size: 1.2rem;
  }
}
.ca-cat__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.ca-cat__item {
  min-width: 127px;
  padding: 0 4px 8px;
}

.ca-cat__item--active .ca-cat__link {
  color: #fff;
  border: 1px solid #0068b7;
}

.ca-cat__item--active .ca-cat__link:before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
}

.ca-cat__link {
  position: relative;
  display: block;
  font-size: 1.4rem;
  padding: 6px 10px;
  text-align: center;
  border-radius: 4px;
  border: 1px solid #212121;
  -webkit-transition: color 0.3s, border 0.3s;
  transition: color 0.3s, border 0.3s;
  overflow: hidden;
  z-index: 1;
}

.ca-cat__link:before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: #0068b7;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: right;
  transform-origin: right;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  z-index: -1;
}

.ca-cat__link:hover {
  color: #fff;
  border: 1px solid #0068b7;
}

.ca-cat__link:hover:before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transform-origin: left;
  transform-origin: left;
}

.ca-content__image {
  text-align: center;
}

.ca-content__image img {
  width: 100%;
  height: auto;
}

.ca-content__textbox {
  max-width: 850px;
  width: 100%;
  margin: 0 auto -64px;
  padding: 36px;
  line-height: 1.5;
  background-color: #fff;
  -webkit-transform: translateY(-100px);
  transform: translateY(-100px);
}

.ca-content__table {
  margin-bottom: 64px;
}

@media screen and (max-width: 1024px) {
  .ca-content__textbox {
    margin: 0 auto;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}
@media screen and (max-width: 768px) {
  .ca-content__textbox {
    padding: 24px;
  }

  .ca-content__table {
    margin-bottom: 32px;
  }
}
.n-archive {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.n-main {
  max-width: 672px;
  width: 100%;
  padding-right: 32px;
}

.n-list {
  margin-bottom: 48px;
}

@media screen and (max-width: 1024px) {
  .n-archive {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

  .n-main {
    max-width: none;
    padding-right: 0;
  }
}
.n-item {
  margin-bottom: 16px;
}

.n-item__link {
  position: relative;
  display: block;
  padding: 32px 32px 16px;
  background-color: #f5f5f5;
  overflow: hidden;
  z-index: 1;
}

.n-item__link:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  background-color: #ebebeb;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: right;
  transform-origin: right;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  z-index: -1;
}

.n-item__link:hover:before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transform-origin: left;
  transform-origin: left;
}

.n-item__link:hover .n-item__icon-circle {
  stroke: #0068b7;
  stroke-dashoffset: 0;
  fill: #0068b7;
  -webkit-transition: stroke-dashoffset 0.5s, fill 0.3s 0.25s;
  transition: stroke-dashoffset 0.5s, fill 0.3s 0.25s;
}

.n-item__link:hover .n-item__icon-arrow {
  fill: #fff;
  -webkit-transition-delay: 0.25s;
  transition-delay: 0.25s;
}

.n-item__meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: 16px;
}

.n-item__cat {
  display: inline-block;
  min-width: 90px;
  font-size: 1.4rem;
  padding: 6px 4px;
  color: #fff;
  background-color: #212121;
}

.n-item__title {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
}

.n-item__icon {
  position: relative;
  display: block;
  margin-top: 16px;
  margin-left: auto;
  width: 36px;
  height: 36px;
}

.n-item__icon-circle {
  width: 36px;
  height: 36px;
  position: absolute;
  top: 0;
  left: 0;
  fill: transparent;
  stroke: #212121;
  stroke-width: 1;
  stroke-dasharray: 132 132;
  stroke-dashoffset: 132;
  -webkit-transition: stroke-dashoffset 0.5s;
  transition: stroke-dashoffset 0.5s;
  -webkit-transform: rotate(-90deg);
  transform: rotate(-90deg);
}

.n-item__icon-arrow {
  fill: #212121;
  width: 14px;
  height: 11px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-transition: fill 0.3s;
  transition: fill 0.3s;
}

@media screen and (max-width: 768px) {
  .n-item__link {
    padding: 24px 16px 16px;
  }

  .n-item__icon {
    margin-top: 0;
  }
}
.n-sidebar {
  max-width: 320px;
  width: 100%;
}

@media screen and (max-width: 1024px) {
  .n-sidebar {
    max-width: none;
  }
}
.n-aside {
  margin-bottom: 64px;
}

.n-aside__heading {
  font-size: 2rem;
  font-weight: 700;
  padding-bottom: 12px;
  border-bottom: 4px solid #e0e0e0;
}

.n-aside__item {
  border-bottom: 1px solid #e0e0e0;
}

.n-aside__link,
.n-aside a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 16px 8px;
  line-height: 1.5;
  z-index: 1;
}

.n-aside__link:before,
.n-aside a:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  background-color: #f5f5f5;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: right;
  transform-origin: right;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  z-index: -1;
}

.n-aside__link:hover:before,
.n-aside a:hover:before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transform-origin: left;
  transform-origin: left;
}

.n-aside__title {
  font-size: 1.6rem;
  font-weight: 400;
}

.n-aside__icon {
  fill: #212121;
  width: 14px;
  height: 11px;
  margin-left: 24px;
}

@media screen and (max-width: 768px) {
  .n-aside {
    margin-bottom: 32px;
  }

  .n-aside:last-child {
    margin-bottom: 0;
  }
}
.n-single {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.n-content {
  max-width: 672px;
  width: 100%;
  padding-right: 32px;
}

.n-content__meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: 16px;
}

.n-content__cat {
  display: inline-block;
  min-width: 90px;
  font-size: 1.4rem;
  padding: 6px 4px;
  color: #fff;
  background-color: #212121;
}

.n-content__title {
  font-size: 2.8rem;
  font-weight: 700;
  margin-bottom: 32px;
  line-height: 1.5;
}

.n-content__body {
  line-height: 1.5;
}

.n-content__footer {
  padding: 64px 0 0;
  margin: 64px 0 0;
  border-top: 1px solid #212121;
}

@media screen and (max-width: 1024px) {
  .n-single {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

  .n-content {
    max-width: none;
    padding-right: 0;
  }

  .n-content__footer {
    padding: 32px 0 0;
    margin: 32px 0 0;
  }

  .n-content__footer .g-btn {
    margin-bottom: 48px;
  }
}
.r-hero {
  position: relative;
  height: calc(100vh - 200px);
  top: 200px;
  margin-bottom: 300px;
}

.r-hero__background {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50%;
}

@media screen and (max-width: 768px) {
  .r-hero {
    height: 220px;
    top: 72px;
    margin-bottom: 72px;
  }
}
.r-gallery {
  position: relative;
}

.r-gallery__thumbnails {
  position: relative;
  max-width: 850px;
  width: 100%;
  margin: -100px auto 0;
  padding: 32px;
  background-color: #fff;
  z-index: 2;
}

.r-gallery__thumblist {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0 -8px;
}

.r-gallery__thumbitem {
  max-width: 200px;
  width: 100%;
  padding: 8px;
  cursor: pointer;
  overflow: hidden;
}

.r-gallery__thumbitem img {
  -webkit-transition: -webkit-transform 1s;
  transition: -webkit-transform 1s;
  transition: transform 1s;
  transition: transform 1s, -webkit-transform 1s;
}

.r-gallery__thumbitem:hover img {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}

.r-gallery__thumbinner {
  overflow: hidden;
}

@media screen and (max-width: 1024px) {
  .r-gallery__thumbnails {
    margin: 0 auto;
  }

  .r-gallery__thumblist {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .r-gallery__thumbitem {
    max-width: none;
    width: 33.333%;
  }
}
@media screen and (max-width: 768px) {
  .r-gallery__thumbnails {
    padding: 16px;
  }

  .r-gallery__thumbitem {
    width: 50%;
  }
}
.r-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 60px -16px 72px;
}

.r-item {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  max-width: 514px;
  width: 100%;
  padding: 16px;
}

.r-item,
.r-item__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
}

.r-item__link {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-flex: 1;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto;
}

.r-item__link:focus .r-item__imagebox img,
.r-item__link:hover .r-item__imagebox img {
  -webkit-transform: scale(1.05);
  transform: scale(1.05);
}

.r-item__link:focus .r-item__icon,
.r-item__link:hover .r-item__icon {
  background-color: #0068b7;
  border: 1px solid #0068b7;
}

.r-item__link:focus .r-item__icon svg,
.r-item__link:hover .r-item__icon svg {
  fill: #fff;
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
}

.r-item__imagebox {
  width: 100%;
  overflow: hidden;
}

.r-item__imagebox img {
  width: 100%;
  height: auto;
  -webkit-transition: -webkit-transform 1s;
  transition: -webkit-transform 1s;
  transition: transform 1s;
  transition: transform 1s, -webkit-transform 1s;
}

.r-item__textbox {
  position: relative;
  -webkit-box-flex: 1;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto;
  background-color: #fff;
  padding: 32px;
}

.r-item__title {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 12px;
}

.r-item__name {
  display: block;
  font-size: 1.6rem;
  font-weight: 700;
  margin-bottom: 8px;
}

.r-item__position {
  font-size: 1.4rem;
}

.r-item__icon {
  position: absolute;
  right: 32px;
  bottom: 32px;
  width: 36px;
  height: 36px;
  line-height: 46px;
  text-align: center;
  border: 1px solid #212121;
  border-radius: 50%;
  overflow: hidden;
  -webkit-transition: background-color 0.3s, border 0.3s;
  transition: background-color 0.3s, border 0.3s;
}

.r-item__icon svg {
  width: 24px;
  height: 24px;
  fill: #212121;
  -webkit-transition: fill 0.3s, -webkit-transform 0.3s;
  transition: fill 0.3s, -webkit-transform 0.3s;
  transition: transform 0.3s, fill 0.3s;
  transition: transform 0.3s, fill 0.3s, -webkit-transform 0.3s;
}

.r-item__text {
  display: none;
}

@media screen and (max-width: 1024px) {
  .r-item {
    max-width: 360px;
  }
}
@media screen and (max-width: 768px) {
  .r-list {
    margin: 36px 0 24px;
  }

  .r-item {
    max-width: 100%;
    padding: 0 0 16px;
  }

  .r-item__textbox {
    padding: 16px;
  }

  .r-item__title {
    font-size: 1.6rem;
  }

  .r-item__name {
    font-size: 1.4rem;
  }
}
.r-overlay {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  padding: 155px 0 0;
  background-color: rgba(250, 250, 250, 0.9);
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity 0.5s, visibility 0.5s;
  transition: opacity 0.5s, visibility 0.5s;
  z-index: 11;
}

.r-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.r-overlay__container {
  margin: 0;
}

.r-overlay__card {
  position: relative;
  max-width: 560px;
  width: 100%;
  max-height: calc(90vh - 155px);
  padding: 32px;
  margin: 0 auto;
  background-color: #fff;
  overflow-x: auto;
}

.r-overlay__close {
  position: absolute;
  top: 32px;
  right: 32px;
  width: 32px;
  height: 32px;
  text-align: center;
  line-height: 44px;
  background-color: #212121;
  border-radius: 50%;
  cursor: pointer;
}

.r-overlay__close svg {
  width: 24px;
  height: 24px;
  fill: #fff;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  -webkit-transition: -webkit-transform 0.35s;
  transition: -webkit-transform 0.35s;
  transition: transform 0.35s;
  transition: transform 0.35s, -webkit-transform 0.35s;
}

.r-overlay__close:hover svg {
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
}

.r-overlay__image {
  text-align: center;
  margin-bottom: 32px;
}

.r-overlay__title {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 12px;
}

.r-overlay__name {
  display: block;
  font-weight: 700;
  margin-bottom: 8px;
}

.r-overlay__position {
  display: block;
  font-size: 1.4rem;
  margin-bottom: 24px;
}

.r-overlay__text {
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  .r-overlay {
    padding: 80px 0 0;
  }

  .r-overlay__card {
    padding: 16px;
  }

  .r-overlay__close {
    top: 16px;
    right: 16px;
  }

  .r-overlay__title {
    font-size: 1.6rem;
    padding-right: 36px;
  }

  .r-overlay__name {
    font-size: 1.4rem;
  }
}
.r-recruit__list {
  margin-bottom: 72px;
}

.r-recruit__item {
  margin-top: -1px;
}

.r-recruit__item.is-open .r-recruit__head svg {
  -webkit-transform: rotate(-90deg);
  transform: rotate(-90deg);
}

.r-recruit__head {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  font-size: 2rem;
  font-weight: 700;
  padding: 20px 32px;
  border-top: 1px solid #e0e0e0;
  border-bottom: 1px solid #e0e0e0;
  z-index: 1;
  overflow: hidden;
}

.r-recruit__head svg {
  width: 24px;
  height: 24px;
  fill: #212121;
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}

.r-recruit__head:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #f5f5f5;
  -webkit-transform: scaleY(0);
  transform: scaleY(0);
  -webkit-transform-origin: bottom;
  transform-origin: bottom;
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
  z-index: -1;
}

.r-recruit__head:hover:before {
  -webkit-transform: scaleY(1);
  transform: scaleY(1);
  -webkit-transform-origin: top;
  transform-origin: top;
}

.r-recruit__position {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
}

.r-recruit__body {
  max-height: 0;
  overflow: hidden;
  -webkit-transition: max-height 0.3s ease-in-out;
  transition: max-height 0.3s ease-in-out;
}

.r-recruit__row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: 24px 32px;
  border-bottom: 1px solid #e0e0e0;
  line-height: 1.5;
}

.r-recruit__row:last-child {
  border-bottom: none;
}

.r-recruit__def {
  width: 156px;
}

.r-recruit__desc {
  width: calc(100% - 156px);
}

@media screen and (max-width: 768px) {
  .r-recruit__head {
    font-size: 1.8rem;
    padding: 16px 24px;
  }

  .r-recruit__row {
    padding: 16px 24px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }

  .r-recruit__def {
    width: 100%;
    margin-bottom: 12px;
  }

  .r-recruit__desc {
    width: 100%;
  }
}
.p-privacy__subtitle {
  line-height: 1.5;
  margin-bottom: 100px;
}

.p-privacy__block + .p-privacy__block {
  margin-top: 100px;
}

.p-privacy__title {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 32px;
  padding-bottom: 10px;
  border-bottom: 4px solid #e0e0e0;
}

.p-privacy__text {
  line-height: 1.5;
}

.p-privacy__table {
  margin-top: 20px;
}

.p-privacy__table table {
  border-collapse: collapse;
}

.p-privacy__table table td {
  padding: 10px;
  border: 1px solid #e0e0e0;
  vertical-align: top;
  line-height: 1.8;
  word-break: break-all;
}

.p-privacy__table table td a {
  display: inline-block;
  color: #0168B7;
  text-decoration: underline;
  line-height: 1.3;
}

.p-privacy__table table td a:hover {
  text-decoration: none;
}

@media screen and (max-width: 768px) {
  .p-privacy__subtitle {
    margin-bottom: 50px;
  }

  .p-privacy__block + .p-privacy__block {
    margin-top: 50px;
  }

  .p-privacy__title {
    margin-bottom: 24px;
  }

  .p-privacy__table table tr,
.p-privacy__table table td {
    display: block;
  }

  .p-privacy__table table td {
    padding: 0;
    border: 0;
  }

  .p-privacy__table table td + td {
    padding: 0;
    border: 0;
    padding-bottom: 20px;
  }
}
.bnr__container {
  padding: 30px 15px;
}

.bnr__item {
  margin-top: 50px;
}

@media (min-width: 768px) {
  .bnr__container {
    padding: 60px 15px;
  }

  .bnr__container a {
    transition: all 0.3s ease;
  }

  .bnr__container a:hover {
    opacity: 0.7;
  }
}
@media (min-width: 1024px) {
  .bnr__container {
    padding: 72px 15px;
    max-width: 800px;
  }
}
/*  2020 collection 空調服
================================================== */
.c-list {
  padding-top: 40px;
  padding-bottom: 30px;
}

.c-list__item + .c-list__item {
  margin-top: 20px;
}

.c-list__img {
  position: relative;
  width: 100%;
}

.c-list__link {
  display: block;
  text-decoration: none;
}

.c-list__img-item {
  width: 100%;
}

.c-list__textbox {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
  padding: 40px 21px 20px;
  background: #212121;
  color: #fff;
  line-height: 1.5;
}

.c-list__textbox::before {
  position: absolute;
  top: 3px;
  right: 3px;
  left: 3px;
  bottom: 3px;
  display: block;
  content: "";
  border: 1px solid rgba(255, 255, 255, 0.5);
  pointer-events: none;
}

.c-list__label {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: absolute;
  top: -40px;
  right: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 80px;
  height: 80px;
  background: #5695EA;
  color: #fff;
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.6;
  text-align: center;
  border-radius: 50%;
}

.c-list__label.is-smnall {
  font-size: 1rem;
}

.c-list__head {
  margin-bottom: 16px;
  font-size: 1.7rem;
  line-height: 1.5;
  font-weight: 700;
}

.c-list__price {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: 14px;
}

.c-list__price-head {
  margin-bottom: 10px;
  font-size: 1rem;
  line-height: 1.5;
  letter-spacing: -0.05em;
}

.c-list__price-head-label {
  display: inline-block;
  margin-right: 5px;
  padding: 4px 4px 3px;
  vertical-align: middle;
  font-size: 1.1rem;
  line-height: 1.1;
  font-weight: 700;
  background: #fff;
  color: #212121;
}

.c-list__price-txt {
  font-size: 2rem;
  line-height: 1;
  font-weight: 700;
  color: #E8DC32;
}

.c-list__price-txt-small {
  font-size: 1.5rem;
}

@media (min-width: 768px) {
  .c-list {
    padding-top: 65px;
    padding-bottom: 50px;
    font-size: 1.4rem;
  }

  .c-list__link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-transition: opacity 0.2s;
    transition: opacity 0.2s;
  }

  .c-list__link:hover {
    opacity: 0.7;
  }

  .c-list__item + .c-list__item {
    margin-top: 60px;
  }

  .c-list__img {
    width: 50%;
  }

  .c-list__textbox {
    width: 50%;
    padding: 59px 21px 30px;
    min-height: 297px;
  }

  .c-list__label {
    top: -45px;
    right: 15px;
    width: 90px;
    height: 90px;
    font-size: 1.5rem;
  }

  .c-list__label.is-smnall {
    font-size: 1.1rem;
  }

  .c-list__price-txt {
    font-size: 3rem;
  }

  .c-list__price-txt-small {
    font-size: 2rem;
  }
}
@media (min-width: 1024px) {
  .c-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 0 -14px;
  }

  .c-list__item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    width: calc(50% - 30px);
    margin: 0 15px;
  }

  .c-list__item + .c-list__item {
    margin-top: 0;
  }

  .c-list__textbox {
    padding: 52px 15px 26px 25px;
  }

  .c-list__img-item {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;";
  }

  .c-list__label {
    padding: 5px 0 0;
  }
}
.c-mv {
  background: url("../img/campaign/bg_mv01_sp.png") no-repeat left top/cover;
  color: #fff;
}

.c-mv__container {
  position: relative;
  padding: 0;
}

.c-mv__container::before {
  position: relative;
  display: block;
  width: 100%;
  padding-top: 96%;
  content: "";
}

.c-mv__area-txt {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  right: 20px;
  width: calc(50% - 2px);
}

.c-mv__copy {
  margin-bottom: 14px;
  padding: 6px 0 4px;
  font-size: 1.4rem;
  line-height: 1.5;
  font-weight: 700;
  border-style: solid;
  border-width: 1px 0;
  text-align: center;
}

.c-mv__en {
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.29;
}

.c-mv__head {
  margin: 0 0 0 -4%;
  padding: 0 5px 0 0;
}

.c-mv__txt {
  font-size: 1.3rem;
  line-height: 1.5;
}

@media (min-width: 768px) {
  .c-mv {
    margin-top: 34px;
    background-image: url("../img/campaign/bg_mv01_pc.png");
    background-position: center top;
  }

  .c-mv__container::before {
    padding-top: 520px;
  }

  .c-mv__area-txt {
    right: 15px;
    width: 50%;
    padding: 0 0 5px;
  }

  .c-mv__copy {
    margin-bottom: 24px;
    padding: 6px 0 4px;
    font-size: 1.8rem;
  }

  .c-mv__en {
    font-size: 1.2rem;
    text-align: center;
  }

  .c-mv__head {
    position: relative;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 357px;
    margin: -8px auto 7px;
    padding: 0;
  }

  .c-mv__txt {
    font-size: 1.5rem;
  }

  .c-list__price-txt.is-block {
    width: 100%;
  }
}
@media (min-width: 1024px) {
  .c-mv__area-txt {
    width: calc(50% - 50px);
  }

  .c-mv__head {
    left: 0;
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}
.c-mv.campaign2 {
  background: url("../img/campaign2/bg_mv01_sp.png") no-repeat left top/cover;
  color: #fff;
}

.campaign2 .c-mv__area-txt {
  left: 20px;
  right: auto;
}

.campaign2 .c-mv__en {
  color: #CD391B;
}

@media (min-width: 768px) {
  .c-mv.campaign2 {
    margin-top: 34px;
    background-image: url("../img/campaign2/bg_mv01_pc.png");
    background-position: center top;
  }
}
.bnr_campaign2 .c-mv__container::before {
  padding-top: 65%;
}

.bnr_campaign2 .c-mv__txt {
  margin-right: -80%;
}

@media (min-width: 768px) {
  .bnr_campaign2.c-mv.campaign2 {
    background-image: url("../img/campaign2/bnr_pc.png");
  }

  .bnr_campaign2 .c-mv__container::before {
    padding-top: 260px;
  }

  .bnr_campaign2 .c-mv__en {
    text-align: left;
    padding-left: 12px;
    font-size: 1.5rem;
  }

  .bnr_campaign2 .c-mv__head {
    margin-left: -5px;
    width: 498px;
  }

  .bnr_campaign2 .c-mv__txt {
    margin-right: 0;
    padding-left: 12px;
  }

  .bnr_campaign2 .c-mv__area-txt {
    width: 100%;
    left: 40px;
  }

  .bnr__container a {
    display: block;
  }
}
/*  campaign3追加
================================================== */
.c-mv.campaign3 {
  background: url("../img/campaign3/bg_mv01_sp.jpg") no-repeat left top/cover;
  color: #fff;
}

@media (min-width: 768px) {
  .c-mv.campaign3 {
    margin-top: 34px;
    background-image: url("../img/campaign3/bg_mv01_pc.jpg");
    background-position: center top;
  }
}
.bnr_campaign3 .c-mv__area-txt {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  right: auto;
  left: auto;
  width: 100%;
  padding: 0 20px;
}

.bnr_campaign3 .c-mv__head {
  width: 220px;
  margin: 7px auto 12px;
  padding: 0;
}

.bnr_campaign3 .c-mv__en {
  text-align: center;
  color: #fff;
}

.bnr_campaign3.c-mv.campaign3 {
  background-image: url("../img/campaign3/bnr_sp.jpg");
}

.bnr_campaign3 .c-mv__container::before {
  padding-top: 65%;
}

.bnr_campaign3 .c-mv__container::before {
  padding-top: 65%;
}

@media (min-width: 768px) {
  .bnr_campaign3.c-mv.campaign3 {
    background-image: url("../img/campaign3/bnr_pc.jpg");
  }

  .bnr_campaign3 .c-mv__container::before {
    padding-top: 260px;
  }

  .bnr_campaign3 .c-mv__en {
    font-size: 1.4rem;
  }

  .bnr_campaign3 .c-mv__head {
    width: 376px;
    margin: 4px auto 18px;
  }

  .bnr_campaign3 .c-mv__txt {
    margin-right: 0;
    font-size: 2rem;
    letter-spacing: -0.08em;
    line-height: 1.3;
  }

  .bnr_campaign3 .c-mv__area-txt {
    width: 575px;
    padding: 0;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
  }

  .bnr__container a {
    display: block;
  }
}
/*  見出し英字追加
================================================== */
.g-heading-1-en {
  font-weight: 700;
  font-size: 1.4rem;
  text-align: center;
  line-height: 1.1;
}

/*  /case/カテゴリ表示追加
================================================== */
.ca-item__imagebox-cat {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  min-width: 127px;
  padding: 8px 4px;
  color: #fff;
  text-align: center;
}

.ca-item__imagebox-cat::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: -1;
  content: "";
  background: #E8BC00;
}

.ca-item__imagebox-cat.story {
  color: #212121;
}

.ca-item__imagebox-cat.introduce {
  color: #fff;
}

.ca-item__imagebox-cat.introduce::before {
  background: #0068b7;
}

.g-form__zip-btn {
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  border: 0;
  background: #333;
  color: #fff;
  width: 100px;
  height: 40px;
  font-family: inherit;
  vertical-align: top;
}

.g-form__input[name=postcode] {
  width: 100px;
}

/* column */
.con_wrap {
  overflow: hidden;
  border-bottom: solid 1px #ddd;
  margin: 30px 1%;
}

.con_wrap dl {
  margin: 0 auto 30px;
}

.con_wrap a {
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}

.con_wrap a img {
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
  width: 20%;
  height: auto;
  float: left;
  margin: 0 1% 15px 0;
}

.con_wrap dt.time {
  margin-bottom: 10px;
}

.con_wrap dt time {
  color: #000000;
  font-weight: bold;
}

.con_wrap dt.con_ttl {
  margin: 5px 5px 0;
  padding: 10px;
  font-weight: bold;
  font-size: 23px;
}

.con_wrap dd.con_txt {
  margin: 0 5px 0;
  padding: 10px 10px 15px;
}

.con_wrap a:hover,
.con_wrap a:active {
  opacity: 0.6;
  filter: alpha(opacity=60);
}

/* column detail */
.queryMain > p {
  font-size: 2em;
  line-height: 1.4;
  margin: 3em 0 4em;
  color: #333;
  letter-spacing: 0.02em;
  text-align: center;
  font-weight: bold;
}

.column_wrap .txtbox {
  margin: 1em 0 4em;
}

.column_wrap .txtbox p {
  margin-bottom: 2em;
  line-height: 160%;
  font-size: 110%;
}

.column_wrap .pageindex {
  width: 70%;
  margin: 1.5em auto 6em;
  padding: 1.5em 2.5em;
  background: #fff;
  border: 1px solid #A0A0A0;
  list-style-type: none;
}

/* breadcrumbs */
.g-breadcrumbs__container {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.g-breadcrumbs__container > span,
.g-breadcrumbs__container > div {
  display: inline-block;
  margin-bottom: 6px;
}

/* column detail */
.column_wrap {
  font-size: 1.6rem;
  line-height: 1.6;
}

.column_wrap p {
  margin-bottom: 2em;
  line-height: 160%;
  font-size: 110%;
}

.column_wrap a {
  color: #0068b7;
  text-decoration: none;
  cursor: pointer;
}

.column_wrap cite {
  font-style: italic;
}

.column_wrap h2 {
  font-size: 1.7em;
  line-height: 1.33;
  margin: 3em 0 1em;
  color: #333;
  border-bottom: 4px solid #e0e0e0;
  font-weight: bold;
  text-align: center;
  padding: 14px 0;
}

.column_wrap .aligncenter {
  text-align: center;
  margin: 2em 0;
}

.column_wrap .aligncenter img {
  width: 90%;
}

.column_wrap h3 {
  font-size: 1.5em;
  margin: 3em 0 1em;
  color: #333;
  font-weight: bold;
  text-align: center;
  display: block;
  padding: 15px 0;
  border-top: 1px solid #e0e0e0;
  border-bottom: 1px solid #e0e0e0;
}

.column_wrap .borderbox {
  margin: 0.5em auto 1em;
  padding: 1em;
  border: 1px solid #e0e0e0;
  width: 90%;
}

.column_wrap .borderbox.bg_blue {
  background: #ebf7ff !important;
}

.column_wrap p:last-child {
  margin-bottom: 0 !important;
}

.column_wrap .bgbox {
  margin: 0.5em auto 30px;
  padding: 1em;
  border: 1px solid #e0e0e0;
  width: 90%;
  background: #f5f5f5;
}

.column_wrap ul li {
  list-style: none !important;
  margin-bottom: 5px;
  text-indent: -1.5em;
  padding-left: 1em;
}

.column_wrap ul li::before {
  content: "・";
  color: #0068b7;
  font-size: 1.5em;
  line-height: 1em;
  vertical-align: middle;
}

#toc_container {
  width: 70%;
  margin: 1.5em auto 6em;
  padding: 1.5em 2.5em;
  background: #fff;
  border: 1px solid #A0A0A0;
  list-style-type: none;
}

#toc_container .toc_title {
  font-size: 27px;
  line-height: 1.33;
  margin-bottom: 1em;
  color: #333;
  font-weight: bold;
}

#toc_container ul {
  -webkit-padding-start: 40px;
  padding-inline-start: 40px;
  counter-reset: item;
  list-style-type: none;
}

#toc_container ul li ul {
  padding-left: 0;
}

#toc_container ul li {
  list-style: none !important;
}

#toc_container > ul > li:last-child {
  margin-left: 0;
}

#toc_container ul li:before {
  display: none;
}

#toc_container a {
  color: #0068b7;
  text-decoration: none;
  cursor: pointer;
  line-height: 35px !important;
}

.column_wrap img {
  height: auto;
}

.column_wrap table {
  width: 90%;
  min-width: 90%;
  margin: 1em auto 3em;
  border: 2px solid #aaa;
  border-collapse: collapse;
  table-layout: fixed;
}

.column_wrap .scroll {
  overflow: auto;
}

.column_wrap table th,
.column_wrap table td {
  border: 1px solid #aaa;
  padding: 1.8em;
  vertical-align: middle;
}

/* header */
.g-menu__buttonwrap {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: -6px;
}

.g-menu__btn {
  width: calc(50% - 12px);
  margin-bottom: 6px;
}

.g-menu__btn.is-large {
  width: calc(100% - 12px);
}

.g-header__contact {
  min-width: 164px;
  width: auto;
}

/* 取扱商品カタログ→作業着 */
.s-catalog__tabs {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  font-size: 14px;
  line-height: 1.57;
}

.s-catalog__tab {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 50%;
  margin-bottom: -1px;
  border: 1px solid #E0E0E0;
}

.s-catalog__tab:nth-child(even) {
  border-left: 0;
}

.s-catalog__tab a {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 57px;
  padding: 4px 11px 5px;
  line-height: 1.2;
}

.s-catalog__tab.ca-cat__item--active a {
  background: #0068B7;
  border-color: #0068B7;
  color: #fff;
}

.s-catalog__tab img {
  width: 30px;
  margin-right: 10px;
}

.s-catalog__tab span {
  width: calc(100% - 40px);
}

.s-catalog__tab-content {
  margin-top: 30px;
}

.s-catalog__tab-content.ca-listwrap--active {
  display: block;
}

.s-catalog__tab-content .section-bottom {
  padding-top: 36px;
}

/* #catalog-list {
    margin-top: 202px;
    padding-top: 202px;
} */

/* @media (max-width: 1023px) {
  #catalog-list {
    margin-top: 40px;
    padding-top: 40px;
  }
} */

.s-catalog__list02-description .s-catalog__list03-description {
  font-size: 16px;
  line-height: 1.5;
}

.s-catalog__list02 .s-catalog__list03 {
  margin-top: 30px;
  margin-bottom: -40px;
}

.s-catalog__list02-item {
  margin-bottom: 40px;
}

.s-catalog__list02-image img {
  height: auto;
}

.s-catalog__list02-area-txt {
  padding: 24px 0 0;
}

.s-catalog__list02-title {
  margin-bottom: 15px;
  font-size: 20px;
  line-height: 1.2;
  font-weight: 700;
}

.s-catalog__list02-text {
  font-size: 16px;
  line-height: 1.5;
}

.s-catalog__list02-btn-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 20px -5px -10px;
}

.s-catalog__list02-btn {
  width: calc(50% - 10px);
  margin: 0 5px 10px;
  font-size: 13px;
  line-height: 1.62;
}

.s-catalog__list02-btn-link {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 100%;
  height: 46px;
  border: 1px solid;
  border-radius: 4px;
}

.s-catalog__list02-btn.is-contact {
  width: calc(100% - 10px);
}

.s-catalog__list02-btn.is-contact .s-catalog__list02-btn-link {
  position: relative;
  background: #0068B7;
  color: #fff;
  /*ココロ追加*/
  height: 40px;
}

.s-catalog__list02-btn .s-catalog__list02-btn-link svg {
  width: 12px;
  height: 12px;
}

.s-catalog__list02-btn .s-catalog__list02-btn-link img {
  width: 14px;
  height: 14px;
}

.s-catalog__list02-btn.is-contact .s-catalog__list02-btn-link svg {
  fill: #fff;
}

.s-catalog__list02-btn.is-contact .s-catalog__list02-btn-link svg:nth-of-type(1) {
  width: 20px;
  height: 16px;
  margin-right: 10px;
}

.s-catalog__list02-btn.is-contact .s-catalog__list02-btn-link svg:nth-of-type(2) {
  position: absolute;
  top: 50%;
  right: 15px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 14px;
  height: 12px;
}

@media (max-width: 1023px) {
  .s-catalog__list02 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 0;
  }

  .s-catalog__list02-item {
    width: 48%;
    margin-right: 4%;
  }

  .s-catalog__list02-item:nth-of-type(2n) {
    margin-right: 0;
  }

  .s-catalog__list02-btn-list {
    margin-top: 15px;
  }

  .s-catalog__list02-btn {
    width: 100% !important;
    margin: 0 5px 10px;
    font-size: 13px;
  }

  .s-catalog__list02-btn-link {
    height: 39px;
  }

  .s-catalog__list02-title {
    font-size: 16px;
    margin-bottom: 10px;
  }

  .s-catalog__list02-text {
    font-size: 14px;
  }

  .s-catalog__list02-area-txt {
    padding-top: 18px;
  }

  .s-catalog__list02-btn.is-contact .s-catalog__list02-btn-link span {
    padding-right: 14px;
    font-size: 13px;
  }

  .s-catalog__list02-btn.is-contact .s-catalog__list02-btn-link svg:nth-of-type(1) {
    -webkit-transform: translateY(3px);
    transform: translateY(3px);
    margin-right: 5px;
    width: 16px;
  }

  .s-catalog__list02-btn.is-contact .s-catalog__list02-btn-link svg:nth-of-type(2) {
    right: 9px;
  }

  .s-catalog__list02-btn .s-catalog__list02-btn-link svg {
    width: 14px;
    height: 14px;
    -webkit-transform: translateY(3px);
    transform: translateY(3px);
  }

  .s-catalog__list02-btn .s-catalog__list02-btn-link img {
    -webkit-transform: translateY(-4px);
    transform: translateY(-4px);
    margin-right: 2px;
  }
}
@media (min-width: 1024px) {
  .s-catalog__tab {
    width: 20%;
    margin-bottom: 0;
  }

  .s-catalog__tab:nth-child(even) {
    border-left: 1px solid #E0E0E0;
  }

  .s-catalog__tab a {
    position: relative;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    height: 64px;
    padding: 5px 13px;
    text-align: center;
    line-height: 1.5;
    overflow: hidden;
    -webkit-transition: -webkit-box-shadow 0.2s;
    transition: -webkit-box-shadow 0.2s;
    transition: box-shadow 0.2s;
    transition: box-shadow 0.2s, -webkit-box-shadow 0.2s;
    transition: box-shadow 0.2s, -webkit-box-shadow 0.2s;
  }

  .s-catalog__tab a::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: #0068B7;
    z-index: -1;
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: right;
    transform-origin: right;
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
  }

  .s-catalog__tab a:hover {
    -webkit-box-shadow: 0 2px 20px -5px #5696ea;
    box-shadow: 0 2px 20px -5px #5696ea;
    color: #fff;
  }

  .s-catalog__tab a:hover::before {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
    -webkit-transform-origin: left;
    transform-origin: left;
  }

  .s-catalog__tab span {
    position: relative;
    z-index: 1;
  }

  .s-catalog__tab-content {
    margin-top: 28px;
  }

  .s-catalog__tab-content .section-bottom {
    padding-top: 98px;
  }

  .s-catalog__list02 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 68px -37px -40px;
    padding-bottom: 28px;
  }

  .s-catalog__list02-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    width: calc(50% - 74px);
    margin: 0 37px 40px;
  }

  .s-catalog__list02-image {
    width: calc(50% - 35px);
  }

  .s-catalog__list02-area-txt {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: calc(50% + 35px);
    padding: 0 0 0 10px;
  }

  .s-catalog__list02-title {
    margin-bottom: 13px;
    font-size: 18px;
  }

  .s-catalog__list02-text {
    font-size: 12px;
    line-height: 1.33;
  }

  .s-catalog__list02-btn-list {
    margin: 20px -3px -6px;
  }

  .s-catalog__list02-btn {
    /*width: calc(50% - 6px);*/
    width:100%;
    margin: 0 3px 6px;
    font-size: 10px;
  }

  .s-catalog__list02-btn-link {
    position: relative;
    height: 25px;
    overflow: hidden;
    -webkit-transition: -webkit-box-shadow 0.2s;
    transition: -webkit-box-shadow 0.2s;
    transition: box-shadow 0.2s;
    transition: box-shadow 0.2s, -webkit-box-shadow 0.2s;
    transition: box-shadow 0.2s, -webkit-box-shadow 0.2s;
  }

  .s-catalog__list02-btn-link span {
    position: relative;
    z-index: 1;
  }

  .s-catalog__list02-btn-link::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: #c7c7c7;
    opacity: 0.2;
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: right;
    transform-origin: right;
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
  }

  .s-catalog__list02-btn-link:hover {
    -webkit-box-shadow: 0 2px 20px -5px #5696ea;
    box-shadow: 0 2px 20px -5px #5696ea;
  }

  .s-catalog__list02-btn-link:hover::before {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
    -webkit-transform-origin: left;
    transform-origin: left;
  }

  .s-catalog__list02-btn.is-contact {
    width: calc(100% - 6px);
  }

  .s-catalog__list02-btn .s-catalog__list02-btn-link img,
.s-catalog__list02-btn .s-catalog__list02-btn-link svg {
    margin: 0 9px 0 6px;
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }

  .s-catalog__list02-btn.is-contact .s-catalog__list02-btn-link svg:nth-of-type(1) {
    width: 12px;
    height: 12px;
    -webkit-box-ordinal-group: 1;
    -ms-flex-order: 0;
    order: 0;
  }

  .s-catalog__list02-btn.is-contact .s-catalog__list02-btn-link svg:nth-of-type(2) {
    right: 10px;
    width: 8px;
    height: 8px;
  }
}
/* header */
.g-menu__btn-link img {
  display: inline-block;
  width: 16px;
  height: 16px;
  margin-right: 5px;
  vertical-align: middle;
}

.g-menu__btn.is-white .g-menu__btn-link {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border: 1px solid;
}

.g-header__contact.is-white .g-header__contact-link {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border: 1px solid #212121;
  background: #fff;
  color: #212121;
}

.g-header__contact.is-white .g-header__contact-link:before {
  background: #212121;
  opacity: 0.2;
}

.g-header__contact-link {
  padding: 10px 19px;
}

.g-header__contact-link img {
  display: inline-block;
  width: 16px;
  height: 16px;
  margin-right: 12px;
  vertical-align: middle;
}

/* .g-header:not(.g-header--custom_black) .g-header__contact.is-home .g-header__contact-link {
color: #fff;
border-color: #fff;
} */
.g-header:not(.g-header--custom_black) .g-header__contact.is-home .g-header__contact-link:before {
  background: #fff;
}

.g-header:not(.g-header--custom_black) .g-header__contact.is-home img:nth-of-type(2) {
  display: none;
}

.g-header.g-header--custom_black .g-header__contact.is-home img:nth-of-type(2) {
  display: none;
}

@media (min-width: 1024px) {
  .g-nav__item {
    position: relative;
    cursor: pointer;
  }

  .g-nav__child {
    position: absolute;
    top: 100%;
    left: 50%;
    width: 205px;
    margin-left: -102px;
    opacity: 0;
    /* padding-top: 20px; */
    pointer-events: none;
    -webkit-transition: opacity 0.2s;
    transition: opacity 0.2s;
    font-size: 14px;
  }

  .g-nav__item:hover .g-nav__child {
    opacity: 1;
    pointer-events: auto;
  }

  .g-nav__child-item + .g-nav__child-item {
    position: relative;
    z-index: 1;
    margin-top: -2px;
  }

  .g-nav__child-link {
    position: relative;
    overflow: hidden;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    color: #212121;
    height: 64px;
    border: 1px solid;
    border-color: #CCCCCC;
    text-align: center;
    background: #ffffff;
  }

  .g-nav:not(.g-nav--custom_black) .g-nav__link.is-home + .g-nav__child .g-nav__child-link {
    color: #fff;
  }

  .g-nav__child-link::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: #212121;
    opacity: 0.2;
    z-index: 0;
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: right;
    transform-origin: right;
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
  }

  .g-nav:not(.g-nav--custom_black) .g-nav__link.is-home .g-nav__child-link::before {
    background: #fff;
  }

  .g-nav__child-link:hover::before {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
    -webkit-transform-origin: left;
    transform-origin: left;
  }

  .g-nav__child-link span {
    position: relative;
    z-index: 1;
  }

  .g-nav__link-arw {
    position: relative;
    top: -2px;
    display: inline-block;
    margin-left: 8px;
    border-style: solid;
    vertical-align: middle;
    border-width: 8px 5px 0 5px;
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
    border-color: #212121 transparent transparent transparent;
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
  }

  .g-nav:not(.g-nav--custom_black) .g-nav__link.is-home .g-nav__link-arw {
    border-color: #fff transparent transparent transparent;
  }

  .g-nav__item:hover .g-nav__link-arw {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
  }
}
/* contact */
.g-form__attention {
  padding: 20px 60px;
  background: rgba(183, 0, 13, 0.07) url("../img/contact/ico_attention01.png") no-repeat left 15px top calc(50% - 12px)/80px;
}

.g-form__attention-title {
  margin-bottom: 11px;
  text-align: center;
  font-weight: 700;
  font-size: 18px;
  line-height: 1.67;
}

.g-form__attention-list {
  font-size: 16px;
  line-height: 1.5;
}

.g-form__attention-list-item {
  text-indent: -1em;
  padding-left: 1em;
}

.g-form__note {
  margin-top: 12px;
  font-size: 14px;
  line-height: 1.5;
}

.g-form__note {
  text-indent: -1em;
  padding-left: 1em;
}

.g-form__inputfield.add-zip {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 20px;
}

.c-form01__add-zip-ico {
  margin-right: 10px;
}

@media (min-width: 1024px) {
  .g-form__attention {
    padding: 20px 90px;
    background-position: left 30px top calc(50% - 12px);
    background-size: 120px;
  }
}
img {
  height: auto;
}

@media (min-width: 768px) {
  .g-form__inputfield.add-zip .g-form__input {
    width: 284px;
  }

  .g-form__inputfield.add-txt .g-form__input {
    width: 575px;
  }
}
/* 2021/03/19　追加分 */
.g-menu__btn--phone.is-full {
  width: 100%;
  margin-bottom: 15px;
}

.g-menu__btn-in a {
  display: block;
  border-radius: 4px;
  background: no-repeat center/cover;
  color: #fff;
  text-align: center;
}

.g-menu__btn-in-large {
  font-weight: 700;
  font-size: 1.3rem;
}

.g-menu__btn-in-small {
  margin-top: 5px;
  font-size: 1rem;
}

.g-menu__btn-in.is-contact a {
  margin-top: 13px;
}

@media (min-width: 576px) {
  .g-header__contact.is-flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 0 -5px 0 28px;
  }

  .g-header__contact-in {
    width: calc(50% - 10px);
    margin: 0 5px;
  }

  .g-header__contact-in a {
    display: block;
    border-radius: 4px;
    background: no-repeat center/cover;
    color: #fff;
    text-align: center;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }

  .g-header__contact-in a:hover {
    opacity: 0.8;
  }

  .g-header__contact-in-large {
    font-weight: 700;
    font-size: 1.4rem;
  }

  .g-header__contact-in-small {
    margin-top: 5px;
    font-size: 1.2rem;
  }

  .g-header__contact-in.is-catalog a {
    /* background-image: url(../img/common/bg_catalog01_pc.png); */
  }

  .g-header__contact-in.is-contact a {
    /* background-image: url(../img/common/bg_contact01_pc.png); */
  }
}
@media (min-width: 1024px) {
  /* .g-header__contact-in {
  width: 244px;
  } */
}
.g-cta__buttonwrap.is-col3 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0 -15px;
}

.g-cta__buttonwrap.is-col3 .g-cta__btn {
  width: calc(33.333% - 30px);
  margin: 0 15px;
}

.g-cta__buttonwrap.is-col3 .g-cta__btn a {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  text-align: center;
  height: auto;
  background: transparent;
}

.g-cta__buttonwrap.is-col3 .g-cta__btn a::before {
  content: none;
}

.g-cta__buttonwrap.is-col3 .g-cta__btn a:hover {
  opacity: 0.7;
}

.g-cta__buttonwrap.is-col3 .g-cta__btn--catalog a {
  /* background: url(../img/common/bnr_catalog01_pc.png) no-repeat center/cover; */
}

.g-cta__buttonwrap.is-col3 .g-cta__btn--contact a {
  /* background: url(../img/common/bnr_contact01_pc.png) no-repeat center/cover; */
}

.g-cta__buttonwrap.is-col3 .g-cta__contact-text {
  font-size: 2.4rem;
}

.g-cta__buttonwrap.is-col3 .g-cta__contact-text .is-small {
  font-size: 1.6rem;
}

@media screen and (max-width: 768px) {
  .u-view-pc {
    display: none;
  }
}
@media screen and (min-width: 769px) {
  .u-view-sp {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .g-cta__buttonwrap.is-col3 {
    margin: 0;
  }

  .g-cta__buttonwrap.is-col3 .g-cta__btn {
    width: 100%;
    margin: 0 0 15px;
  }

  .g-cta__buttonwrap.is-col3 .g-cta__btn--catalog a {
    /* background: url(../img/common/bnr_catalog01_sp.png) no-repeat center/cover; */
  }

  .g-cta__buttonwrap.is-col3 .g-cta__btn--contact a {
    /* background: url(../img/common/bnr_contact01_sp.png) no-repeat center/cover; */
  }

  .g-cta__buttonwrap.is-col3 .g-cta__contact {
    text-align: center;
  }

  .g-cta__buttonwrap.is-col3 .g-cta__contact-text {
    font-size: 2rem;
    font-weight: 700;
  }

  .g-cta__buttonwrap.is-col3 .g-cta__contact-text .is-small {
    font-size: 1.5rem;
    font-weight: 500;
  }
}
.columnsBnr {
  width: 768px;
  margin: 0 auto;
}

.columnsBnr-link {
  display: block;
  text-decoration: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.columnsBnr {
  width: 100%;
}

.columnsBnr-link {
  text-decoration: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

@media (min-width: 576px) {
  .columnsBnr {
    width: 768px;
    margin: 0 auto;
  }

  .columnsBnr-link {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }

  .columnsBnr-link:hover {
    opacity: 0.7;
  }
}
/* 2021/07/01　追加分 */
.home__contact-link {
  width: 235px;
  margin: 20px auto 0;
}

@media (max-width: 767px) {
  .g-panel__item.is-catalog .g-panel__link {
    background: #0068B7;
    color: #fff;
  }

  .g-panel__item.is-catalog .g-panel__link img {
    margin-top: 5px;
    margin-bottom: 8px;
  }

  .g-panel__item:nth-child(2):before {
    display: none;
  }

  .g-panel__item:nth-child(2):after {
    display: none;
  }
}
/* 2021/07/19　追加分 */
.tab-contents__item {
  display: none;
}

.tab-contents__item.is-show {
  display: block;
}

/* カタログ */
.s-catalog__list03 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.s-catalog__list03-item {
  width: calc(50% - 10px * 1/2);
  margin: 10px 10px 0 0;
  background: #f5f5f5;
  padding: 10px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
}

.s-catalog__list03-item:nth-of-type(2n) {
  margin-right: 0;
}

.s-catalog__list03-item:nth-of-type(-n + 2) {
  margin-top: 0;
}

.s-catalog__list03-item input {
  display: none;
}

.s-catalog__list03-item input + span::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  border: 3px solid transparent;
  cursor: pointer;
}

.s-catalog__list03-item input:checked + span::before {
  border-color: #0068b7;
}

.s-catalog__list03-item .mwform-checkbox-field-text {
  font-size: 16px;
  margin-bottom: 10px;
  line-height: 1.2;
  font-weight: 700;
  text-align: center;
  height: 38px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  overflow: hidden;
}

/* チェックボックス */
/* .s-catalog__list03-item::before {
content: "";
position: absolute;
display: block;
left: 50%;
bottom: 10px;
border: 1px solid;
-webkit-transform: translateX(-50%);
transform: translateX(-50%);
width: 22px;
height: 22px;
background: #fff;
} */
.s-catalog__list03-item input:checked + span::after {
  content: "";
  position: absolute;
  display: block;
  width: 14px;
  left: calc(50% - 7px);
  bottom: 18px;
  height: 10px;
  border-style: solid;
  border-width: 2px 2px 0 0;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
  border-color: #0068b7;
}

@media (min-width: 768px) {
  .s-catalog__list03-item {
    width: calc(25% - 20px * 3/4);
    margin: 20px 20px 0 0;
    padding: 10px;
  }

  .s-catalog__list03-item .mwform-checkbox-field-text {
    font-size: 20px;
    height: 50px;
  }

  .s-catalog__list03-item:nth-of-type(2n) {
    margin-right: 20px;
  }

  .s-catalog__list03-item:nth-of-type(-n + 2) {
    margin-top: 20px;
  }

  .s-catalog__list03-item:nth-of-type(4n) {
    margin-right: 0;
  }

  .s-catalog__list03-item:nth-of-type(-n + 4) {
    margin-top: 0;
  }

  .s-catalog__list03-item input + span::before {
    border-width: 5px;
  }

  .s-catalog__list03-item::before {
    bottom: 13px;
    width: 28px;
    height: 28px;
  }

  .s-catalog__list03-item input:checked + span::after {
    width: 16px;
    left: calc(50% - 8px);
    bottom: 23px;
    height: 11px;
    border-width: 3px 3px 0 0;
  }
}
/*  components
================================================== */
/*  .c-btn01
================================================== */
.c-btn01 {
  width: 325px;
  max-width: 100%;
  margin: 20px auto 0;
}

.c-btn01__link {
  position: relative;
  display: block;
  padding: 18px 33px;
  text-align: center;
  background: #fff;
  border-radius: 3px;
  line-height: 1.4;
  letter-spacing: -0.05em;
}

.c-btn01__txt {
  font-size: 1.7rem;
}

.c-btn01__txt:before {
  margin: -3px 8px 0 0;
  width: 19px;
  height: 16px;
  content: "";
  display: inline-block;
  vertical-align: middle;
  background: no-repeat center/contain;
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2238.806%22%20height%3D%2231.045%22%20viewBox%3D%220%200%2038.806%2031.045%22%3E%20%3Cg%20id%3D%22ico_mail01%22%20transform%3D%22translate(0%200)%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_669%22%20data-name%3D%22%E3%83%91%E3%82%B9%20669%22%20d%3D%22M366%2C90v31.045h38.806V90Zm32.182%2C3.881L385.4%2C106.659%2C372.624%2C93.881Zm-28.3%2C23.284V96.624L385.4%2C112.147l15.522-15.522v20.54Z%22%20transform%3D%22translate(-366%20-90)%22%20fill%3D%22%23212121%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E");
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.c-btn01__arw {
  position: absolute;
  top: 50%;
  right: 16px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.c-btn01__arw svg {
  fill: #0068b7;
  width: 14px;
  height: 11px;
  -webkit-transition: fill 0.3s;
  transition: fill 0.3s;
}

@media (min-width: 768px) {
  .c-btn01 {
    width: 498px;
    margin: 30px auto 0;
  }

  .c-btn01__link {
    padding: 47px 30px;
    overflow: hidden;
  }

  .c-btn01__link:before {
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 100%;
    content: "";
    background: #5695ea;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }

  .c-btn01__link:hover:before {
    width: 100%;
  }

  .c-btn01__link:hover .c-btn01__arw svg {
    fill: #fff;
  }

  .c-btn01__link:hover .c-btn01__txt {
    color: #fff;
  }

  .c-btn01__link:hover .c-btn01__txt:before {
    width: 19px;
    height: 16px;
    content: "";
    display: inline-block;
    vertical-align: middle;
    background: no-repeat center/contain;
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2238.806%22%20height%3D%2231.045%22%20viewBox%3D%220%200%2038.806%2031.045%22%3E%20%3Cg%20id%3D%22ico_mail01%22%20transform%3D%22translate(0%200)%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_669%22%20data-name%3D%22%E3%83%91%E3%82%B9%20669%22%20d%3D%22M366%2C90v31.045h38.806V90Zm32.182%2C3.881L385.4%2C106.659%2C372.624%2C93.881Zm-28.3%2C23.284V96.624L385.4%2C112.147l15.522-15.522v20.54Z%22%20transform%3D%22translate(-366%20-90)%22%20fill%3D%22%23fff%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E");
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }

  .c-btn01__txt {
    position: relative;
    font-size: 1.8rem;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }

  .c-btn01__txt:before {
    margin: -3px 8px 0 0;
    width: 19px;
    height: 16px;
    content: "";
    display: inline-block;
    vertical-align: middle;
    background: no-repeat center/contain;
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2238.806%22%20height%3D%2231.045%22%20viewBox%3D%220%200%2038.806%2031.045%22%3E%20%3Cg%20id%3D%22ico_mail01%22%20transform%3D%22translate(0%200)%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_669%22%20data-name%3D%22%E3%83%91%E3%82%B9%20669%22%20d%3D%22M366%2C90v31.045h38.806V90Zm32.182%2C3.881L385.4%2C106.659%2C372.624%2C93.881Zm-28.3%2C23.284V96.624L385.4%2C112.147l15.522-15.522v20.54Z%22%20transform%3D%22translate(-366%20-90)%22%20fill%3D%22%23212121%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E");
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }

  .c-btn01__arw {
    right: 20px;
  }
}
.c-btn02 {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  align-content: center;
  position: relative;
  width: 100%;
  max-width: 464px;
  min-height: 64px;
  margin-left: auto;
  margin-right: auto;
  padding: 5px 10px;
  background: #0068B7;
  color: #fff;
  font-size: 1.3rem;
  font-weight: 500;
  text-align: center;
  line-height: 1.3;
}
@media (min-width: 768.02px) {
  .c-btn02 {
    font-size: 16px;
  }
}
@media (any-hover: hover) {
  .c-btn02 {
    transition: box-shadow 0.2s ease;
    will-change: box-shadow;
  }
  .c-btn02::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: rgba(199, 199, 199, 0.2);
    transform: scaleX(0);
    transform-origin: right;
    transition: transform 0.3s ease;
    will-change: transform;
  }
  .c-btn02:hover {
    box-shadow: 0 2px 20px -5px #5696ea;
  }
  .c-btn02:hover::before {
    transform: scaleX(1);
    transform-origin: left;
  }
}
.c-btn02__inr {
  position: relative;
  z-index: 1;
}

.c-head01 {
  font-size: 1.7em;
  line-height: 1.33;
  margin-bottom: 1em;
  color: #333;
  border-bottom: 4px solid #e0e0e0;
  font-weight: bold;
  text-align: center;
  padding-bottom: 14px;
}

@media (min-width: 768px) {
  .c-head01 {
    margin-bottom: 38px;
  }
}
/* link
-------------------------------------- */
a.u-alpha {
  display: block;
  text-decoration: none;
}

@media (min-width: 768px) {
  a.u-alpha {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }

  a.u-alpha:hover {
    opacity: 0.7;
  }
}
/*  .columns-recommend
================================================== */
.columns-recommend {
  padding: 69px 0 74px;
  background: #f5f5f5;
}

.columns-recommend-list__item + .columns-recommend-list__item {
  margin-top: 57px;
}

.columns-recommend-list__area-txt {
  margin-top: 26px;
}

.columns-recommend-list__date {
  font-size: 1.5rem;
  font-weight: bold;
}

.columns-recommend-list__head {
  margin-top: 16px;
  font-size: 2.3rem;
  line-height: 1.5;
  font-weight: bold;
}

.columns-recommend-list__txt {
  margin-top: 18px;
  line-height: 1.5;
}

.columns-recommend-btn {
  margin-top: 59px;
}

@media (min-width: 768px) {
  .columns-recommend {
    padding: 95px 0 99px;
  }

  .columns-recommend-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

  .columns-recommend-list__item {
    width: 31.5%;
    margin-right: 2.75%;
  }

  .columns-recommend-list__item + .columns-recommend-list__item {
    margin-top: 0;
  }

  .columns-recommend-list__item:nth-child(3n) {
    margin-right: 0;
  }

  .columns-recommend-list__area-img {
    max-height: 100px;
    overflow: hidden;
  }

  .columns-recommend-list__area-txt {
    margin-top: 21px;
  }

  .columns-recommend-list__date {
    font-size: 1.3rem;
    font-weight: bold;
  }

  .columns-recommend-list__head {
    margin-top: 13px;
    font-size: 1.8rem;
  }

  .columns-recommend-list__txt {
    margin-top: 14px;
  }

  .columns-recommend-btn {
    margin-top: 54px;
  }
}
/*  .columns-bnr
================================================== */
.columns-bnr {
  padding-top: 75px;
}

@media (min-width: 768px) {
  .columns-bnr {
    padding-top: 101px;
  }
}
/*  .nos-feature
================================================== */
.nos-feature {
  padding: 34px 0 44px;
  background: #fff;
}

.nos-feature-list__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  line-height: 1.3;
}

.nos-feature-list__item + .nos-feature-list__item {
  margin-top: 40px;
}

.nos-feature-list__area-img {
  width: 33%;
  margin-right: 18px;
  overflow: hidden;
  border-radius: 50%;
}

.nos-feature-list__area-txt {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding-top: 5px;
}

.nos-feature-list__head {
  font-weight: bold;
  margin-bottom: 5px;
}

.nos-feature-list__head-num {
  position: relative;
  top: -2px;
  padding-right: 5px;
  font-size: 1.5rem;
  color: #5695ea;
}

.nos-feature-list__txt {
  font-size: 1.4rem;
  line-height: 1.6;
}

@media (min-width: 768px) {
  .nos-feature {
    padding: 78px 0;
  }

  .nos-feature-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-top: 66px;
  }

  .nos-feature-list__item {
    display: block;
    width: 29.3%;
    margin-right: 61px;
  }

  .nos-feature-list__item:nth-child(-n+2) {
    margin: 0 30px 0 30px;
  }

  .nos-feature-list__item + .nos-feature-list__item {
    margin-top: 0;
  }

  .nos-feature-list__item:nth-child(n+3) {
    margin-top: 56px;
  }

  .nos-feature-list__item:last-child {
    margin-right: 0;
  }

  .nos-feature-list__area-img {
    width: 157px;
    margin: 0 auto 20px;
  }

  .nos-feature-list__area-txt {
    padding-top: 0;
  }

  .nos-feature-list__head {
    margin: 0 0 10px -1em;
    text-align: center;
    font-size: 1.8rem;
  }

  .nos-feature-list__head-num {
    top: -1px;
    padding-right: 8px;
    font-size: 1.6rem;
  }

  .nos-feature-list__txt {
    text-align: left;
    font-size: 1.6rem;
  }
}
/*  .nos-flow
================================================== */
.nos-flow {
  padding: 50px 0 30px;
}

.nos-flow ol,
.nos-flow ul {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  font-style: normal;
  font-weight: 400;
  vertical-align: bottom;
  background: transparent;
  list-style: none;
}

.nos-flow-list__item {
  position: relative;
}

.nos-flow-list__item + .nos-flow-list__item {
  margin-top: 48px;
}

.nos-flow-list__item + .nos-flow-list__item:before {
  position: absolute;
  top: -32px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 18px 13.5px 0 13.5px;
  border-color: #5695ea transparent transparent transparent;
}

.nos-flow-list__item.has-no-txt .nos-flow-list-head {
  margin-bottom: 0;
}

.nos-flow-list__area-txt {
  padding: 17px 15px 24px;
  background: #fff;
  line-height: 1.5;
}

.nos-flow-list-head {
  position: relative;
  margin-bottom: 19px;
  padding: 3px 0 0 56px;
}

.nos-flow-list-head__num {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  left: 0;
  padding-top: 10px;
  width: 44px;
  height: 44px;
  font-size: 1.4rem;
  text-align: center;
  color: #fff;
  background: #5695ea;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border-radius: 50%;
  line-height: 1.1;
  font-weight: bold;
  letter-spacing: -0.08em;
}

.nos-flow-list-head__main {
  font-size: 2rem;
  font-weight: bold;
}

.nos-flow-list-child__item {
  position: relative;
  padding-left: 15px;
}

.nos-flow-list-child__item:before {
  position: absolute;
  top: 9px;
  left: 0;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  content: "";
  background: #5695ea;
}

.nos-flow-list-label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  padding: 5px 0 8px !important;
}

.nos-flow-list-label__item {
  padding: 5px 5px;
  font-size: 1.3rem;
  border: 1px solid;
  border-radius: 5px;
}

.nos-flow-list-label__item:not(:last-child) {
  margin-right: 5px;
}

.nos-flow-list__note {
  padding-left: 1em;
  text-indent: -1em;
  font-size: 1.3rem;
}

.nos-flow-list__option {
  display: inline-block;
  margin-top: 5px;
  padding: 5px 0 5px 10px;
  border-radius: 5px;
}

.nos-flow-list__option-bold {
  font-weight: bold;
}

.nos-flow-list-compare {
  margin-bottom: 10px !important;
}

.nos-flow-list-compare__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.nos-flow-list-compare__item + .nos-flow-list-compare__item {
  margin-top: 11px;
}

.nos-flow-list-compare__item.is-blue .nos-flow-list-compare__head {
  color: #5695ea;
}

.nos-flow-list-compare__item.is-blue .nos-flow-list-compare__area-list {
  border: 1px solid #5695ea;
}

.nos-flow-list-compare__head {
  width: 3em;
  padding-top: 10px;
  margin-right: 3px;
  font-weight: bold;
}

.nos-flow-list-compare__area-list {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding: 11px 15px;
  border: 1px solid #212121;
}

.nos-flow-list-compare-list__item {
  position: relative;
  padding-left: 11px;
  font-size: 1.4rem;
}

.nos-flow-list-compare-list__item + .nos-flow-list-compare-list__item {
  margin-top: 7px;
}

.nos-flow-list-compare-list__item:before {
  position: absolute;
  top: 7px;
  left: 0;
  width: 3px;
  height: 3px;
  border-radius: 50%;
  content: "";
  background: #5695ea;
}

.nos-flow-list__term {
  margin-top: 5px;
  font-size: 1.7rem;
  font-weight: bold;
  text-decoration: underline;
}

@media (min-width: 768px) {
  .nos-flow {
    padding: 70px 0 64px;
  }

  .nos-flow-list {
    margin: 70px 0 0 !important;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }

  .nos-flow-list__item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    width: 100%;
  }

  .nos-flow-list__item + .nos-flow-list__item {
    margin-top: 65px;
  }

  .nos-flow-list__item + .nos-flow-list__item:before {
    top: -46px;
    border-width: 24px 18px 0 18px;
  }

  .nos-flow-list__item.has-no-txt {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
    width: 31.2%;
  }

  .nos-flow-list__item.has-no-txt:before {
    top: 50%;
    left: auto;
    right: -30px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    border-width: 18px 0 18px 24px;
    border-color: transparent transparent transparent #5695ea;
  }

  .nos-flow-list__item.has-no-txt .nos-flow-list__area-img,
.nos-flow-list__item.has-no-txt .nos-flow-list__area-txt {
    width: 100%;
    margin: 0;
  }

  .nos-flow-list__item.has-no-txt .nos-flow-list__area-txt {
    padding: 29px 15px;
    min-height: 90px;
  }

  .nos-flow-list__item:last-child:before {
    content: none;
  }

  .nos-flow-list__area-img {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
    width: 44.5%;
    margin: 29px 0 0 -31px;
  }

  .nos-flow-list__area-txt {
    width: 58.5%;
    min-height: 255px;
    padding: 40px 40px 51px 31px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }

  .nos-flow-list-head {
    margin-bottom: 33px;
    padding: 4px 0 0 81px;
  }

  .nos-flow-list-head__num {
    padding-top: 15px;
    width: 58px;
    height: 58px;
    font-size: 1.6rem;
  }

  .nos-flow-list-child__item {
    padding-left: 22px;
  }

  .nos-flow-list-child__item:before {
    top: 9px;
    left: 4px;
    width: 5px;
    height: 5px;
  }

  .nos-flow-list-label {
    padding: 5px 0 8px !important;
  }

  .nos-flow-list-label__item {
    padding: 5px 5px;
    font-size: 1.4rem;
  }

  .nos-flow-list-label__item:not(:last-child) {
    margin-right: 5px;
  }

  .nos-flow-list__note {
    margin-top: 10px;
  }

  .nos-flow-list__option {
    margin-top: 10px;
    padding: 8px 0 5px 10px;
  }

  .nos-flow-list-compare {
    padding: 0 57px 0 0 !important;
    margin-bottom: 17px !important;
  }

  .nos-flow-list-compare__item + .nos-flow-list-compare__item {
    margin-top: 9px;
  }

  .nos-flow-list-compare__head {
    padding-top: 10px;
    margin-right: 3px;
  }

  .nos-flow-list-compare__area-list {
    padding: 14px 25px 14px 15px;
  }

  .nos-flow-list-compare-list.is-flex .nos-flow-list-compare-list__item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }

  .nos-flow-list-compare-list__item {
    padding-left: 15px;
  }

  .nos-flow-list-compare-list__item + .nos-flow-list-compare-list__item {
    margin-top: 2px;
  }

  .nos-flow-list-compare-list__item:before {
    top: 8px;
    left: 5px;
    width: 2px;
    height: 2px;
  }

  .nos-flow-list__term {
    margin-top: 10px;
  }
}
/*  .nos-notice
================================================== */
.nos-notice {
  padding: 10px 0 0;
}

.nos-notice-list {
  position: relative;
  margin: 0 -15px;
  padding: 24px 18px 30px;
  background: #faeded;
  z-index: 1;
}

.nos-notice-list:before {
  position: absolute;
  top: 54px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 119px;
  height: 105px;
  content: "";
  background: url(../img/nos/bg_notice01.png) no-repeat center/contain;
  z-index: -1;
}

.nos-notice-list__item {
  text-align: center;
  line-height: 1.5;
}

.nos-notice-list__item + .nos-notice-list__item {
  margin-top: 15px;
}

.nos-notice-list__head {
  margin-bottom: 14px;
  font-size: 1.7rem;
  font-weight: bold;
}

.nos-notice-list__txt.is-small {
  font-size: 1.4rem;
}

@media (min-width: 768px) {
  .nos-notice {
    padding: 19px 0 78px;
  }

  .nos-notice-list {
    margin: 0;
    padding: 26px 20px;
  }

  .nos-notice-list:before {
    top: 50%;
    left: 28px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 120px;
    height: 110px;
  }

  .nos-notice-list__item + .nos-notice-list__item {
    margin-top: 18px;
  }

  .nos-notice-list__head {
    margin-bottom: 10px;
    font-size: 1.8rem;
  }

  .nos-notice-list__txt.is-small {
    font-size: 1.6rem;
  }
}
/*  .nos-cv
================================================== */
.nos-cv {
  padding: 50px 0 58px;
  background: #0068b7;
}

.nos-cv-btn {
  margin-top: -12px;
}

@media (min-width: 768px) {
  .nos-cv {
    padding: 78px 0 72px;
  }

  .nos-cv-btn {
    margin-top: 36px;
  }
}
/*  .nos-mv
================================================== */
.nos-mv {
  margin-top: 75px;
  background: url(../img/nos/bg_main01_sp.png) no-repeat center top;
  background-size: cover;
}

.nos-mv__inner {
  padding: 50px 40px;
}

.nos-mv__header span {
  text-align: center;
  font-weight: bold;
  padding: 0 10px;
  line-height: 1.5;
}

.nos-mv__list {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 30px -5px 0;
  padding: 0;
}

.nos-mv__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: calc(50% - 10px);
  height: 85px;
  padding: 10px;
  margin: 0 5px;
  border-radius: 10px;
  background-color: #fff;
  border: 2px solid #0068B7;
  text-align: center;
  box-sizing: border-box;
}

.nos-mv__item:nth-child(n+3) {
  margin-top: 10px;
}

.nos-mv__item-num {
  display: block;
  margin-bottom: 5px;
  color: #0068B7;
  font-weight: bold;
  font-size: 1.5rem;
}

.nos-mv__item-txt {
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.3;
}

@media (max-width: 360px) {
  .nos-mv__inner {
    padding: 50px 20px;
  }

  .nos-mv__item-txt {
    font-size: 1.4rem;
  }
}
@media (min-width: 768px) {
  .nos-mv {
    margin-top: 200px;
    background-image: url(../img/nos/bg_main01_pc.png);
  }

  .nos-mv__inner {
    padding: 70px 40px;
  }

  .nos-mv__header {
    text-align: center;
  }

  .nos-mv__header span {
    padding: 0;
  }

  .nos-mv__list {
    max-width: 700px;
    margin: 35px auto 0;
    padding: 0;
  }

  .nos-mv__item {
    width: calc(25% - 20px);
    height: 157px;
    margin: 0 10px;
    border-radius: 50%;
  }

  .nos-mv__item:nth-child(n+3) {
    margin-top: 0;
  }

  .nos-mv__item-num {
    margin-bottom: 5px;
    font-size: 2rem;
  }

  .nos-mv__item-txt {
    font-size: 1.6rem;
  }
}
/*  .nos-about
================================================== */
.nos-about {
  background: #0068B7;
}

.nos-about__inner {
  position: relative;
  padding: 0 15px;
}

.nos-about__inner::before {
  position: absolute;
  content: "";
  bottom: 0;
  right: -30px;
  width: 55%;
  height: 380px;
  background: url(../img/nos/bg_about01.png) no-repeat right bottom;
  background-size: contain;
}

.nos-about__img {
  margin: 0 -15px;
}

.nos-about__area-txt {
  padding: 40px 0 48px;
  color: #fff;
}

.nos-about__head {
  margin-bottom: 20px;
  font-size: 2rem;
  font-weight: bold;
}

.nos-about__txt {
  line-height: 1.7;
}

@media (min-width: 768px) {
  .nos-about {
    overflow: hidden;
    position: relative;
  }

  .nos-about__inner::before {
    right: -30%;
    bottom: 0;
    height: 380px;
  }

  .nos-about__inner {
    width: 100%;
    padding: 30px 0 100px;
    margin-right: auto;
    margin-left: auto;
    max-width: 1020px;
    box-sizing: border-box;
  }

  .nos-about__wrap {
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
  }

  .nos-about__img {
    width: 78%;
    max-width: 800px;
    margin: 0 0 0 -280px;
  }

  .nos-about__area-txt {
    padding: 70px 0 50px 65px;
    width: 50%;
    box-sizing: border-box;
    background: none;
  }

  .nos-about__head {
    font-size: 2.8rem;
  }
}
/*  .nos-use
================================================== */
.nos-use {
  padding: 34px 0 50px;
}

.nos-use__head {
  padding: 0 20px;
}

.nos-use__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: flex-start;
  line-height: 1.3;
  margin: 0 -10px;
}

.nos-use__item {
  width: calc(50% - 20px);
  margin: 0 10px;
}

.nos-use__item:nth-child(n+3) {
  margin-top: 30px;
}

.nos-use__item-txt {
  margin-top: 17px;
  font-weight: bold;
  text-align: center;
}

@media (min-width: 768px) {
  .nos-use {
    padding: 70px 0 80px;
  }

  .nos-use__head {
    padding: 0;
  }

  .nos-use__list {
    margin: 65px -12px 0;
  }

  .nos-use__item {
    width: calc(25% - 24px);
    margin: 0 12px;
  }

  .nos-use__item:nth-child(n+3) {
    margin-top: 0;
  }

  .nos-use__item:nth-child(n+5) {
    margin-top: 30px;
  }

  .nos-use__item-txt {
    margin-top: 20px;
    font-size: 1.8rem;
  }

  .nos-use__list.is-3col .nos-use__item {
    width: calc(33.333% - 24px);
  }

  .nos-use__list.is-3col .nos-use__item:nth-child(n+5) {
    margin-top: 0;
  }

  .nos-use__list.is-3col .nos-use__item:nth-child(n+4) {
    margin-top: 30px;
  }
}
/*  .nos-reason
================================================== */
.nos-reason {
  padding: 48px 0 40px;
  background-color: #fff;
}

.nos-reason__set + .nos-reason__set {
  margin-top: 30px;
}

.nos-reason__img {
  margin: 0 -15px;
}

.nos-reason__area-txt {
  position: relative;
  z-index: 1;
  margin-top: -15px;
  padding: 40px 20px;
  background-color: #fff;
}

.nos-reason__sub {
  margin-bottom: 20px;
  text-align: center;
  font-weight: bold;
  font-size: 2rem;
}

.nos-reason__txt {
  line-height: 1.6;
}

@media (min-width: 768px) {
  .nos-reason {
    padding: 70px 0 80px;
  }

  .nos-reason__head {
    margin-bottom: 65px;
  }

  .nos-reason__set {
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
    align-items: flex-start;
  }

  .nos-reason__set + .nos-reason__set {
    margin-top: 65px;
  }

  .nos-reason__set:nth-of-type(even) {
    flex-direction: row-reverse;
  }

  .nos-reason__set:nth-of-type(even) .nos-reason__img {
    margin: 0 0 0 -160px;
  }

  .nos-reason__img {
    margin: 0 -160px 0 0;
    width: 67%;
  }

  .nos-reason__area-txt {
    width: 50%;
    margin-top: 30px;
    padding: 60px 40px;
  }

  .nos-reason__sub {
    margin-bottom: 23px;
    text-align: left;
    font-size: 2.8rem;
  }

  .nos-reason__txt {
    line-height: 1.5;
  }
}
#nos .g-breadcrumbs {
  color: #fff;
}

#nos .g-breadcrumbs a {
  color: #fff;
}

#nos .g-breadcrumbs__container > span a:before {
  background-color: #fff;
}

.s-steps {
  padding-top: 31px;
}
@media (min-width: 789px) {
  .s-steps {
    padding-top: 62px;
  }
}
.s-steps__lead {
  max-width: 862px;
  margin: 33px auto 0;
  text-align: center;
  line-height: 1.5;
}
.s-steps__content {
  padding-top: 61px;
  overflow: hidden;
}
.s-steps__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
@media (min-width: 576px) {
  .s-steps__list {
    margin: -28px -14px 0;
  }
}
@media (min-width: 768px) {
  .s-steps__list {
    margin: -28px -28px 0;
  }
}
.s-steps__step {
  position: relative;
  width: 100%;
}
@media (min-width: 576px) {
  .s-steps__step {
    width: 50%;
    padding: 28px 14px 0;
  }
}
@media (min-width: 768px) {
  .s-steps__step {
    padding: 28px 28px 0;
  }
}
@media (min-width: 1024px) {
  .s-steps__step {
    width: 25%;
  }
}
.s-steps__step:nth-child(n+2) {
  margin-top: 55px;
}
@media (min-width: 576px) {
  .s-steps__step:nth-child(n+2) {
    margin-top: 0;
  }
}
.s-steps__step:nth-child(n+2)::before {
  content: "";
  position: absolute;
  top: -35px;
  right: 0;
  left: 0;
  width: 15px;
  height: 18px;
  margin: auto;
  transform: rotate(90deg);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='15' height='18' viewBox='0 0 15 18'%3E%3Cpath fill='%230068B7' d='M15 9 0 17.6603V.3397L15 9Z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center center;
}
@media (min-width: 576px) {
  .s-steps__step:nth-child(n+2)::before {
    top: 150px;
    right: auto;
    left: -8px;
    margin: 0;
    transform: none;
  }
}
.s-steps__card {
  border: 1px solid #CFC8C8;
  height: 100%;
}
.s-steps__lbl, .s-steps__ttl {
  font-weight: bold;
  text-align: center;
}
.s-steps__lbl {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 37px;
  padding-top: 2px;
  background-color: #0068B7;
  color: #fff;
  font-size: 2.9rem;
  line-height: 1;
}
.s-steps__desc {
  padding: 9px 15px 12px;
  color: #212121;
}
.s-steps__img {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.s-steps__ttl {
  display: flex;
  flex-wrap: wrap;
  align-content: center;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  font-size: 1.6rem;
  line-height: 1.125;
}
.s-steps__p {
  margin-top: 8px;
  font-size: 1.4rem;
  line-height: 1.286;
}
.s-card {
  padding: 0 15px 39px;
  background-color: #f5f5f5;
  border: 1px solid #CFC8C8;
}
@media (min-width: 768.02px) {
  .s-card {
    padding: 0 30px 39px;
  }
}
.s-card:nth-child(n+2) {
  margin-top: 53px;
}
.s-card__hdr, .s-card__ttl, .s-card__price {
  font-size: 2rem;
  font-weight: bold;
  letter-spacing: -.07em;
}
.s-card__hdr {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  align-content: center;
  justify-content: center;
  min-height: 71px;
  padding-bottom: 5px 0;
  border-bottom: 1px solid #CFC8C8;
  text-align: center;
}
.s-card__main {
  padding-top: 19px;
}
@media (min-width: 768.02px) {
  .s-card__main {
    display: flex;
    justify-content: space-between;
  }
}
@media (min-width: 768.02px) {
  .s-card__vis {
    width: 48.2328%;
  }
}
.s-card__body {
  padding-top: 19px;
}
@media (min-width: 768.02px) {
  .s-card__body {
    width: 48.7526%;
    padding-top: 0;
  }
}
.s-card__ttl {
  padding-top: 5px;
  padding-bottom: 26px;
}
.s-card__p {
  font-size: 1.4rem;
  letter-spacing: -.0875em;
  line-height: 1.375;
}
@media (min-width: 768.02px) {
  .s-card__p {
    font-size: 1.6rem;
  }
}
.s-card__price {
  margin-top: 29px;
}
.s-card__tax {
  font-weight: normal;
}
.s-card__btn {
  margin-top: 31px;
}

.js-acc {
  cursor: pointer;
}
.js-acc + * {
  transition: 0.2s ease;
  transition-property: max-height, min-height, padding, opacity;
  will-change: max-height, min-height, padding, opacity;
  overflow: hidden;
}
.js-acc:not(.is-active) + * {
  max-height: 0;
  min-height: 0;
  padding-top: 0;
  padding-bottom: 0;
  opacity: 0;
}

.s-faq {
  padding-top: 47px;
}
@media (min-width: 768.02px) {
  .s-faq {
    padding-top: 94px;
  }
}
.s-faq__heading {
  margin-bottom: 18px;
}
.s-faq__qa {
  border-top: 1px solid #CFC8C8;
  border-bottom: 1px solid #CFC8C8;
}
.s-faq__q, .s-faq__a {
  display: flex;
  position: relative;
  line-height: 1.35;
}
.s-faq__q {
  display: flex;
  align-items: center;
  min-height: 100px;
  padding: 5px 30px 5px calc(2.8986% + 30px);
  z-index: 1;
  background-repeat: no-repeat;
  background-size: 31px auto;
  background-position: left top 30px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='31' height='40' fill='none' viewBox='0 0 31 40'%3E%3Cpath fill='%230068B7' d='m25.2207 34.999-.5059 3.6314c-1.1803.1686-2.4871.2529-3.9204.2529-2.2402 0-3.8662-.3613-4.8779-1.084-.8792-.6142-1.6019-1.6862-2.168-3.2158l-.813-2.168c-3.6253-.2649-6.4316-1.8307-8.4189-4.6972-1.7826-2.5775-2.6738-5.9138-2.6738-10.0088 0-4.9743 1.2887-8.7984 3.8662-11.4722 2.168-2.2643 4.9863-3.3965 8.4551-3.3965 4.0107 0 7.1181 1.4574 9.3222 4.372 1.9753 2.6017 2.9629 6.0764 2.9629 10.4244 0 4.1794-.9153 7.5698-2.7461 10.1714-1.5537 2.2041-3.6133 3.6133-6.1787 4.2275l.4878 1.4092c.3011.7588.7347 1.2767 1.3008 1.5537.5179.265 1.2827.3975 2.2944.3975 1.084 0 2.2884-.1325 3.6133-.3975ZM14.1641 6.7251c-2.3246 0-4.1011 1.0298-5.3296 3.0894-1.1322 1.8909-1.6983 4.5105-1.6983 7.8588 0 3.806.7287 6.6786 2.186 8.6177 1.2165 1.6139 2.8305 2.4209 4.8419 2.4209 2.3125 0 4.083-1.0539 5.3115-3.1616 1.1201-1.915 1.6802-4.5407 1.6802-7.877 0-3.83-.7227-6.6906-2.168-8.5815-1.1924-1.5778-2.8003-2.3667-4.8237-2.3667Z'/%3E%3C/svg%3E");
  border-bottom: 1px solid #fff;
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: -.0583em;
}
@media (min-width: 768.02px) {
  .s-faq__q {
    padding: 5px calc(7.2266% + 35px) 5px calc(11.0352% + 30px);
    background-position: left 5.5176% top 30px;
    font-size: 2.4rem;
  }
}
@media (any-hover: hover) {
  .s-faq__q {
    transition: background-color 0.2s ease;
    will-change: background-color;
  }
  .s-faq__q:not(.is-active):hover {
    background-color: #f5f5f5;
  }
}
.s-faq__q:nth-of-type(n+2) {
  border-top: 1px solid #CFC8C8;
}
.s-faq__q::before, .s-faq__q::after {
  content: /*""*/;
  display: flex;
  position: absolute;
  top: 49px;
  right: 0;
  width: 25px;
  height: 3px;
  background-color: #0068B7;
}
@media (min-width: 768.02px) {
  .s-faq__q::before, .s-faq__q::after {
    right: 7.2407%;
    width: 35px;
  }
}
.s-faq__q::after {
  transform: rotate(-90deg);
  transform-origin: center center;
  transition: transform 0.2s ease;
  will-change: transform;
}
.s-faq__q.is-active::after {
  transform: rotate(0deg);
}
.s-faq__a {
  padding-bottom: 29px;
}
@media (min-width: 768.02px) {
  .s-faq__a {
    padding: 0 7.2407% 29px 5.5284%;
  }
}

.original__heading {
  margin-bottom: 0;
}
.original__lead {
  margin: 20px 0 28px;
  text-align: center;
  line-height: 1.5;
}

.o-catalog {
  padding: 42px 0 22px;
}
@media (min-width: 789px) {
  .o-catalog {
    padding: 83px 0 43px;
  }
}
.o-catalog__lead {
  margin: 13px 0 38px;
  text-align: center;
  line-height: 1.5;
}

.wbr {
  display: inline-block;
}

/*202303_ココロ追加*/
/*PC*/
@media screen and (min-width: 768px) {
  .what_is {
    margin-left: 30%;
    padding-right: 20px;
    text-align: left;
  }

  .btn01 {
    float: left;
    margin-left: 8.5em;
    background: #0068b7;
  }

  .btn02 {
    float: right;
    margin-right: 8.5em;
    background: #0068b7;
  }

  .what_about {
    float: left;
    margin-left: 5.5em;
  }

  .n_item {
    text-align: center;
  }

  .cat_img {
    width: 17em !important;
    /*256px*/
    height: 29em;
    /*243.2px*/
    object-fit: cover;
  }

  .cat_img2 {
    width: 11em !important;
    /*160px*/
    height: 15.2em;
    /*163.2px*/
    object-fit: cover;
  }

  .s-uniform__item {
    text-align: -webkit-center;
  }

  .about_n {
    min-height: 305px;
  }

  .col_ct {
    margin-top: 50px;
  }

  .n_b_b {
    color: #fff;
    border: none;
  }

  .what_head {
    margin-bottom: 50px;
  }

  .jap_txt {
    text-align: left;
  }

  .btnb {
    margin-top: -50px;
  }
}
/*スマホ*/
@media screen and (max-width: 768px) {
  .btn01 {
    margin-bottom: 20px;
  }

  .what_about {
    text-align: center;
    margin-bottom: 30px;
  }

  .cat_img {
    width: 17em !important;
    /*256px*/
    height: 29em;
    /*243.2px*/
    object-fit: cover;
  }

  .cat_img2 {
    width: 11em !important;
    /*160px*/
    height: 15em;
    /*163.2px*/
    object-fit: cover;
  }

  .s-uniform__item {
    text-align: -webkit-center;
  }

  .what_is {
    padding: 16px 24px 24px;
    text-align: left;
  }

  .g-cta__link2 {
    height: 250px;
    background-color: #0068B7;
  }

  .list_sm {
    color: white !important;
  }

  .n_btn {
    width: 10em;
    margin: 5px;
    color: white;
  }

  .floa {
    float: left;
    margin-right: 9px;
  }

  .btn_align {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 20px;
  }

  .ne_btn {
    padding-right: none !important;
  }

  .ne_btn01 {
    padding-left: 1.2em;
  }

  .btn_tex {
    color: white;
  }

  .tex_pad {
    padding: 0px 10px;
  }

  .sp_btn_siz {
    width: 345px;
  }

  .n_b_b {
    color: #fff;
    background: #0068b7;
    border: none;
  }

  .jap_txt {
    text-align: left;
  }
}
/** PCでは幅500pxに固定 */
#toc_container {
  width: 500px;
}

/** スマホなどでは幅100%に固定 */
@media screen and (max-width: 750px) {
  #toc_container {
    width: 100%;
  }

  .container202::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: rgba(0, 0, 0, 0.5);
}
}

/** 商品カタログの人気商品画像よう */
.image-container {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
    max-width: 260px; /* 任意の幅に設定。幅が指定されているときにmargin: 0 auto;が効くようにする */
    margin: 0 auto; /* 中央に寄せる */
}

.image-container div {
    width: 48%;
    box-sizing: border-box;
    text-align: center;
}

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

.image-container p {
    margin-top: 10px;
}

/** 記事ページ内画像のPCとSP切り替え用 */
/*PCの場合*/
.pc	{ display:inline!important; }
.mb	{ display:none!important; }

@media screen and (max-width: 768px) {
/*タブレット、スマホの場合*/
.pc	{ display:none!important; }
.mb { display:inline!important; }
}
/** ヘッダーのメニューが改行されないようにする */
.g-nav__link {
  white-space: nowrap;
}
