html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section, main {
  display: block
}

body {
  line-height: 1;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%
}

ol, ul {
  list-style: none
}

blockquote, q {
  quotes: none
}

blockquote:before, blockquote:after, q:before, q:after {
  content: '';
  content: none
}

table {
  border-collapse: collapse;
  border-spacing: 0
}

input[type="submit"]::-moz-focus-inner, button::-moz-focus-inner {
  border: 0px
}

a:focus, input, textarea, button {
  outline: none
}

a {
  background: none
}

textarea {
  overflow: auto
}

img {
  border: none;
  vertical-align: bottom
}

html {
  font-size: 87.5%
}

@media screen and (min-width: 1500px) {
  html {
    font-size: 93.75%
  }
}

body {
  color: #1a1a1a;
  font-family: 'Open Sans', Arial, Roboto, "Droid Sans", "游ゴシック体", YuGothic, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 1px;
  text-align: justify;
  text-justify: inter-ideograph;
  -webkit-tap-highlight-color: transparent;
  -webkit-font-smoothing: subpixel-antialiased;
  min-width: 320px;
  overflow-y: scroll
}

@media screen and (max-width: 959px) {
  body {
    line-height: 1.9
  }
}

@media screen and (max-width: 399px) {
  body {
    letter-spacing: 0.5px
  }
}

html, body {
  width: 100%;
  height: 100%
}

a {
  color: #1a1a1a;
  text-decoration: none
}

b, strong, em {
  font-weight: 600
}

img {
  /*vertical-align: middle;
  width: 100%;
  height: auto;
  display: block;
  margin: 0 auto*/
}

* {
  box-sizing: border-box;
  background-repeat: none
}

.include-svg {
  display: none
}

.cf:before, .cf:after {
  content: "";
  display: table
}

.cf:after {
  clear: both
}

textarea, input[type="text"], input[type="submit"], select, button {
  color: #1a1a1a;
  font-family: 'Open Sans', Arial, Roboto, "Droid Sans", "游ゴシック体", YuGothic, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: .1em;
  padding: 0;
  background-color: transparent;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 0;
  border: none;
  display: block
}

input[type="text"], textarea {
  font-size: 16px;
  line-height: 1;
  width: 100%;
  height: 50px;
  padding: 0 15px;
  background-color: #fff;
  border: 1px solid #313131
}

textarea {
  line-height: 1.8;
  height: 20em;
  padding: 15px
}

input[type="checkbox"], input[type="radio"] {
  vertical-align: middle;
  width: 1rem;
  height: 1rem;
  margin-right: .5em;
  display: inline-block;
  vertical-align: baseline
}

input[type="submit"] {
  color: #fff;
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  letter-spacing: 1px;
  border: none;
  background-color: transparent;
  cursor: pointer;
  display: inline-block
}

@media screen and (max-width: 959px) {
  input[type="submit"] {
    line-height: 1.9
  }
}

@media screen and (max-width: 799px) {
  input[type="submit"] {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  input[type="submit"] {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  input[type="submit"] {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  input[type="submit"] {
    line-height: 1.9
  }
}

@media screen and (max-width: 399px) {
  input[type="submit"] {
    letter-spacing: 0.5px
  }
}

select {
  font-size: 0.933rem;
  font-weight: 700;
  letter-spacing: 1px;
  width: 100%;
  cursor: pointer
}

@media screen and (max-width: 399px) {
  select {
    letter-spacing: 0.5px
  }
}

.l-wrapper {
  width: 100%;
  margin: 0 auto;
  max-width: 2560px;
  padding-top: 0px;
  visibility: hidden
}

@media screen and (max-width: 959px) {
  .l-wrapper {
    padding-top: 60px
  }
}

body._loadend .l-wrapper {
  visibility: visible
}

body._navopen .l-wrapper {
  position: fixed
}

.l-line {
  padding: 1px 0;
  margin: -1px 0
}

.l-line._gray {
  background-color: #f5f5f5
}

.l-line._blue {
  background-color: #dcedec
}

.l-container {
  max-width: 1800px;
  margin: 9vw auto;
  padding: 0 12vw
}

@media screen and (min-width: 1800px) {
  .l-container {
    margin: 162px auto;
    padding: 0 216px
  }
}

@media screen and (max-width: 1199px) {
  .l-container {
    padding: 0 8vw
  }
}

@media screen and (max-width: 959px) {
  .l-container {
    padding: 0 6vw !important
  }
}

@media screen and (max-width: 399px) {
  .l-container {
    margin: 36px auto;
    padding: 0 20px !important
  }
}

.l-container._wide {
  padding: 0 5vw
}

@media screen and (min-width: 1800px) {
  .l-container._wide {
    padding: 0 90px
  }
}

.l-container._narrow {
  padding: 0 20vw
}

@media screen and (min-width: 1800px) {
  .l-container._narrow {
    padding: 0 360px
  }
}

.l-narrowbox {
  padding: 0 8vw
}

@media screen and (min-width: 1800px) {
  .l-narrowbox {
    padding: 0 144px
  }
}

@media screen and (max-width: 959px) {
  .l-narrowbox {
    padding: 0
  }
}

.l-widebox {
  margin: 0 -7vw
}

@media screen and (min-width: 1800px) {
  .l-widebox {
    margin: 0 -126px
  }
}

@media screen and (max-width: 1199px) {
  .l-widebox {
    margin: 0 -3vw
  }
}

@media screen and (max-width: 959px) {
  .l-widebox {
    margin: 0
  }
}

.l-space {
  margin-bottom: 9vw
}

@media screen and (min-width: 1800px) {
  .l-space {
    margin-bottom: 162px
  }
}

@media screen and (max-width: 399px) {
  .l-space {
    margin-bottom: 36px
  }
}

.l-space__sm {
  margin-bottom: 5vw
}

@media screen and (min-width: 1800px) {
  .l-space__sm {
    margin-bottom: 90px
  }
}

@media screen and (max-width: 399px) {
  .l-space__sm {
    margin-bottom: 20px
  }
}

@media screen and (max-width: 399px) {
  .l-space__sm {
    margin-bottom: 7vw
  }
}

@media screen and (max-width: 399px) and (min-width: 1800px) {
  .l-space__sm {
    margin-bottom: 126px
  }
}

@media screen and (max-width: 399px) and (max-width: 399px) {
  .l-space__sm {
    margin-bottom: 28px
  }
}

.l-space__xs {
  margin-bottom: 3vw
}

@media screen and (min-width: 1800px) {
  .l-space__xs {
    margin-bottom: 54px
  }
}

@media screen and (max-width: 399px) {
  .l-space__xs {
    margin-bottom: 12px
  }
}

.l-space__lg {
  margin-bottom: 11vw
}

@media screen and (min-width: 1800px) {
  .l-space__lg {
    margin-bottom: 198px
  }
}

@media screen and (max-width: 399px) {
  .l-space__lg {
    margin-bottom: 44px
  }
}

.l-space-top {
  margin-top: 9vw
}

@media screen and (min-width: 1800px) {
  .l-space-top {
    margin-top: 162px
  }
}

@media screen and (max-width: 399px) {
  .l-space-top {
    margin-top: 36px
  }
}

.l-space-top__sm {
  margin-top: 5vw
}

@media screen and (min-width: 1800px) {
  .l-space-top__sm {
    margin-top: 90px
  }
}

@media screen and (max-width: 399px) {
  .l-space-top__sm {
    margin-top: 20px
  }
}

.l-space-top__xs {
  margin-top: 3vw
}

@media screen and (min-width: 1800px) {
  .l-space-top__xs {
    margin-top: 54px
  }
}

@media screen and (max-width: 399px) {
  .l-space-top__xs {
    margin-top: 12px
  }
}

.l-space-top__lg {
  margin-top: 11vw
}

@media screen and (min-width: 1800px) {
  .l-space-top__lg {
    margin-top: 198px
  }
}

@media screen and (max-width: 399px) {
  .l-space-top__lg {
    margin-top: 44px
  }
}

.l-grids {
  display: flex;
  flex-wrap: wrap;
  margin: -1.8vw
}

@media screen and (min-width: 1800px) {
  .l-grids {
    margin: -32.4px
  }
}

@media screen and (max-width: 399px) {
  .l-grids {
    margin: -8px
  }
}

.l-grids._flip {
  flex-direction: row-reverse
}

.l-grids._vcenter {
  align-items: center
}

.l-grids._center {
  justify-content: center
}

.l-grids._gap-sm {
  margin: -.7vw
}

@media screen and (min-width: 1800px) {
  .l-grids._gap-sm {
    margin: -12.6px
  }
}

@media screen and (max-width: 799px) {
  .l-grids._gap-sm {
    margin: -1.8vw
  }
}

@media screen and (max-width: 399px) {
  .l-grids._gap-sm {
    margin: -8px
  }
}

.l-grids._gap-lg {
  margin: -5.3vw
}

@media screen and (min-width: 1800px) {
  .l-grids._gap-lg {
    margin: -95.4px
  }
}

@media screen and (max-width: 959px) {
  .l-grids._gap-lg {
    margin: -3.8vw
  }
}

@media screen and (max-width: 799px) {
  .l-grids._gap-lg {
    margin: -2.8vw
  }
}

@media screen and (max-width: 399px) {
  .l-grids._gap-lg {
    margin: -8px
  }
}

.l-grids._gap-none {
  margin: 0
}

.l-grids>* {
  padding: 1.8vw
}

@media screen and (min-width: 1800px) {
  .l-grids>* {
    padding: 32.4px
  }
}

@media screen and (max-width: 399px) {
  .l-grids>* {
    padding: 8px
  }
}

.l-grids._gap-sm>* {
  padding: .7vw
}

@media screen and (min-width: 1800px) {
  .l-grids._gap-sm>* {
    padding: 12.6px
  }
}

@media screen and (max-width: 799px) {
  .l-grids._gap-sm>* {
    padding: 1.8vw
  }
}

@media screen and (max-width: 399px) {
  .l-grids._gap-sm>* {
    padding: 8px
  }
}

.l-grids._gap-lg>* {
  padding: 5.3vw
}

@media screen and (min-width: 1800px) {
  .l-grids._gap-lg>* {
    padding: 95.4px
  }
}

@media screen and (max-width: 959px) {
  .l-grids._gap-lg>* {
    padding: 3.8vw
  }
}

@media screen and (max-width: 799px) {
  .l-grids._gap-lg>* {
    padding: 2.8vw
  }
}

@media screen and (max-width: 399px) {
  .l-grids._gap-lg>* {
    padding: 8px
  }
}

.l-grids._gap-none>* {
  padding: 0
}

.l-grid-1of2 {
  width: 50%
}

.l-grid-1of3 {
  width: 33.333%
}

.l-grid-2of3 {
  width: 66.666%
}

.l-grid-1of4 {
  width: 25%
}

.l-grid-1of5 {
  width: 20%
}

.l-grid-1of6 {
  width: 16.666%
}

@media screen and (max-width: 1199px) {
  ._lg-1of3 {
    width: 33.333%
  }
}

@media screen and (max-width: 959px) {
  ._md-1of1 {
    width: 100%
  }
}

@media screen and (max-width: 959px) {
  .l-grids>*+._md-1of1._space {
    padding-top: 3vw
  }
  .l-grids>*+._md-1of1._space__lg {
    padding-top: 5vw
  }
}

@media screen and (max-width: 399px) {
  .l-grids>*+._md-1of1._space {
    padding-top: 18px
  }
  .l-grids>*+._md-1of1._space__lg {
    padding-top: 30px
  }
}

@media screen and (max-width: 959px) {
  ._md-1of2 {
    width: 50%
  }
}

@media screen and (max-width: 799px) {
  ._sm-1of1 {
    width: 100%
  }
}

@media screen and (max-width: 799px) {
  .l-grids>*+._sm-1of1._space {
    padding-top: 3vw
  }
  .l-grids>*+._sm-1of1._space__lg {
    padding-top: 5vw
  }
}

@media screen and (max-width: 399px) {
  .l-grids>*+._sm-1of1._space {
    padding-top: 18px
  }
  .l-grids>*+._sm-1of1._space__lg {
    padding-top: 30px
  }
}

@media screen and (max-width: 799px) {
  ._sm-1of2 {
    width: 50%
  }
}

@media screen and (max-width: 599px) {
  ._xs-1of1 {
    width: 100%
  }
}

@media screen and (max-width: 599px) {
  .l-grids>*+._xs-1of1._space {
    padding-top: 3vw
  }
  .l-grids>*+._xs-1of1._space__lg {
    padding-top: 5vw
  }
}

@media screen and (max-width: 399px) {
  .l-grids>*+._xs-1of1._space {
    padding-top: 18px
  }
  .l-grids>*+._xs-1of1._space__lg {
    padding-top: 30px
  }
}

@media screen and (max-width: 599px) {
  ._xs-1of3 {
    width: 33.333%
  }
}

@media screen and (max-width: 599px) {
  ._xs-2of3 {
    width: 66.666%
  }
}

@media screen and (max-width: 599px) {
  ._xs-1of2 {
    width: 50%
  }
}

@media screen and (max-width: 399px) {
  ._xxs-1of1 {
    width: 100%
  }
}

@media screen and (max-width: 399px) {
  .l-grids>*+._xxs-1of1._space {
    padding-top: 18px
  }
  .l-grids>*+._xxs-1of1._space__lg {
    padding-top: 30px
  }
}

@media screen and (max-width: 399px) {
  ._xxs-1of2 {
    width: 50%
  }
}

.l-columns {
  display: flex;
  justify-content: space-between;
  flex-direction: row-reverse
}

.l-columns._flip {
  flex-direction: row
}

@media screen and (max-width: 959px) {
  .l-columns {
    flex-wrap: wrap;
    flex-direction: column-reverse
  }
}

.l-column-main {
  width: 70%;
  flex-grow: 1;
  margin-left: 6%
}

@media screen and (max-width: 959px) {
  .l-column-main {
    width: 100%;
    margin-left: 0
  }
}

.l-column-sub {
  width: 24%;
  flex-shrink: 0;
  max-width: 350px;
  min-width: 280px
}

@media screen and (max-width: 959px) {
  .l-column-sub {
    width: 100%;
    max-width: none;
    min-width: 0;
    margin-bottom: 7vw
  }
}

@media screen and (max-width: 959px) and (min-width: 1800px) {
  .l-column-sub {
    margin-bottom: 126px
  }
}

@media screen and (max-width: 959px) and (max-width: 399px) {
  .l-column-sub {
    margin-bottom: 28px
  }
}

.h-logo>a, .h-gnav>li>a, .h-subnav>li>a {
  line-height: 69px !important
}

.h-header {
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
  box-shadow: 0 1px 20px rgba(0, 0, 0, 0.05);
  visibility: hidden
}

.h-header:before, .h-header:after {
  content: "";
  width: 100%;
  height: 370px;
  background-color: #fff;
  position: fixed;
  top: -300px;
  z-index: -1
}

@media screen and (max-width: 959px) {
  .h-header:before, .h-header:after {
    height: 360px;
    z-index: 0
  }
}

.h-header:after {
  height: 0;
  top: 0;
  z-index: -2
}

body._loadend .h-header {
  visibility: visible
}

body._navopen .h-header {
  position: absolute
}

body._navopen .h-header:after {
  height: 300px;
  transition: height .2s
}

.h-header__inner {
  display: flex;
  margin: 0 auto;
  max-width: 2560px;
  background-color: #fff
}

.h-logo {
  width: 100px;
  height: 70px;
  position: relative;
  z-index: 1
}

@media screen and (max-width: 959px) {
  .h-logo {
    width: 20%;
    min-width: 120px;
    height: 60px
  }
}

@media screen and (max-width: 959px) {
  body._navopen .h-logo {
    position: fixed
  }
}

.h-logo>a {
  display: block;
  height: 100%;
  padding: 8px 25%;
  background-color: #1a1a1a
}

.h-logo>.c-svg>span {
  padding-bottom: 0;
  height: 100%
}

.h-logo svg {
  fill: #fff
}

.h-navouter {
  flex-grow: 1;
  display: flex;
  min-width: 320px
}

@media screen and (max-width: 959px) {
  .h-navouter {
    display: block;
    width: 100%;
    position: absolute;
    top: 60px;
    left: 0;
    z-index: -1;
    transform: translate(0, -102%);
    transition: transform .2s
  }
  .h-navouter._active {
    transform: translate(0, 0)
  }
}

.h-gnav {
  display: flex;
  flex-grow: 4;
  max-width: 1800px;
  background-color: #fff;
  border-bottom: 1px solid #d4d4d4
}

@media screen and (max-width: 959px) {
  .h-gnav {
    display: block
  }
}

.h-gnav>li {
  flex-grow: 1;
  border-right: 1px solid #d4d4d4
}

@media screen and (max-width: 959px) {
  .h-gnav>li {
    border-right: none;
    border-top: 1px solid #d4d4d4
  }
}

.h-gnav>li>a {
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  text-align: center;
  display: block;
  padding-bottom: 1px;
  margin-bottom: -1px;
  position: relative
}

@media screen and (max-width: 959px) {
  .h-gnav>li>a {
    line-height: 1.9
  }
}

@media screen and (max-width: 959px) {
  .h-gnav>li>a {
    font-size: 14px;
    font-size: 1rem;
    line-height: 2;
    line-height: 60px !important;
    text-align: left;
    padding: 0 3em 0 2em;
    padding: 0 3em 0 calc(3vw + 12px);
    margin-bottom: 0;
    position: relative
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .h-gnav>li>a {
    line-height: 1.9
  }
}

@media screen and (min-width: 960px) {
  .h-gnav>li>a:after {
    content: "";
    width: 0;
    height: 3px;
    background-color: #1476c7;
    position: absolute;
    left: 0;
    bottom: 0;
    transition: width .2s
  }
}

@media screen and (min-width: 960px) {
  .h-gnav>li>a._current:after {
    width: 100%
  }
}

@media screen and (min-width: 960px) {
  .h-gnav>li>a._active:before {
    content: "";
    width: 100%;
    height: 3px;
    background-color: #fff;
    position: absolute;
    left: 0;
    bottom: 0
  }
}

html.no-touchevents .h-gnav>li:hover>a {
  text-decoration: underline
}

@media screen and (max-width: 959px) {
  .h-gnav>li>a:before, .h-gnav>li>a:after {
    content: "";
    width: 12px;
    height: 2px;
    background-color: #1476c7;
    position: absolute;
    top: 50%;
    right: 25px;
    transition: all .2s
  }
}

@media screen and (max-width: 959px) {
  .h-gnav>li>a:after {
    transform: rotate(90deg)
  }
}

.h-gnav>li>a._open:before {
  width: 14px;
  transform: rotate(45deg)
}

.h-gnav>li>a._open:after {
  width: 14px;
  transform: rotate(-45deg)
}

@media screen and (max-width: 959px) {
  .h-gnav>li:nth-child(3)>a:before {
    content: "";
    width: 6px;
    height: 6px;
    border: 3px #1476c7;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
    position: absolute;
    top: 50%;
    right: 27px;
    background-color: transparent;
    transform: scaleX(0.8) translate(0, -50%) rotate(45deg)
  }
}

@media screen and (max-width: 959px) {
  .h-gnav>li:nth-child(3)>a:after {
    content: none
  }
}

.h-gnavsub {
  width: 100%;
  position: absolute;
  z-index: -2;
  left: 0;
  background-color: #fff;
  transform: translate(0, -102%)
}

@media screen and (min-width: 960px) {
  .h-gnavsub {
    height: auto !important
  }
}

@media screen and (max-width: 959px) {
  .h-gnavsub {
    position: relative;
    z-index: 1;
    transform: translate(0, 0);
    background-color: #f5f5f5;
    overflow: hidden;
    height: 0;
    transition: height .2s
  }
}

@media screen and (min-width: 960px) {
  body._loadend .h-gnavsub {
    transition: transform 0.15s 0.1s cubic-bezier(0.55, 0.05, 0.35, 1)
  }
}

@media screen and (min-width: 960px) {
  .h-gnav>li>a._active+.h-gnavsub {
    transform: translate(0, 0);
    transition-duration: .3s
  }
}

.h-gnavsub__inner {
  padding: 2.5em 7vw 3.5em;
  padding: 2vw 7vw;
  border: 1px #d4d4d4;
  border-style: solid none
}

@media screen and (min-width: 1800px) {
  .h-gnavsub__inner {
    padding: -36px -126px
  }
}

@media screen and (max-width: 959px) {
  .h-gnavsub__inner {
    padding: 2vw 3vw;
    border-style: solid none none
  }
}

@media screen and (max-width: 599px) {
  .h-gnavsub__inner {
    padding: 3vw 5vw
  }
}

@media screen and (max-width: 399px) {
  .h-gnavsub__inner {
    padding: 3vw calc(3vw + 12px)
  }
}

.h-gnavsub .c-linktxt-A {
  font-size: 14px;
  font-size: 1rem;
  line-height: 1.7
}

@media screen and (max-width: 959px) {
  .h-gnavsub .c-linktxt-A {
    line-height: 1.5
  }
}

@media screen and (max-width: 959px) {
  .h-gnavsub .c-linktxt-A {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 1.7
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .h-gnavsub .c-linktxt-A {
    line-height: 1.5
  }
}

@media screen and (max-width: 959px) {
  .h-gnavsub .c-linktxt-A:before {
    margin-top: -5px
  }
}

@media screen and (max-width: 799px) {
  .h-gnavsub .c-linktxt-A {
    padding: .5em 0 .5em 12px
  }
  .h-gnavsub .c-linktxt-A:before {
    margin-top: -4px
  }
}

.h-gnavsub__title>.c-linktxt-A {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.4
}

@media screen and (max-width: 959px) {
  .h-gnavsub__title>.c-linktxt-A {
    line-height: 1.2
  }
}

@media screen and (max-width: 959px) {
  .h-gnavsub__title>.c-linktxt-A {
    font-size: 14px;
    font-size: 1rem;
    line-height: 2;
    display: block;
    border-bottom: 1px solid #d4d4d4;
    margin-bottom: 1vw
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .h-gnavsub__title>.c-linktxt-A {
    line-height: 1.9
  }
}

@media screen and (max-width: 399px) {
  .h-gnavsub__title>.c-linktxt-A {
    padding: .5em 0 .5em 12px;
    margin-bottom: 3vw
  }
}

.h-gnavsub__nav {
  display: flex;
  flex-wrap: wrap;
  margin: -.5em -2vw 0
}

.h-gnavsub__nav._products {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1fr;
  grid-template-columns: 1fr 1fr
}

.h-gnavsub__nav._products>li:nth-child(1) {
  grid-row: 1 / span 2;
  -ms-grid-column: 1;
  -ms-grid-row: 1;
  -ms-grid-row-span: 2
}

.h-gnavsub__nav._products>li:nth-child(2) {
  -ms-grid-column: 2;
  -ms-grid-row: 1
}

.h-gnavsub__nav._products>li:nth-child(3) {
  -ms-grid-column: 2;
  -ms-grid-row: 2
}

.h-gnavsub__nav._products>li:nth-child(4) {
  -ms-grid-column: 1;
  -ms-grid-row: 3
}

.h-gnavsub__nav._products>li:nth-child(5) {
  -ms-grid-column: 2;
  -ms-grid-row: 3
}

@media screen and (max-width: 599px) {
  .h-gnavsub__nav._products>li:nth-child(1) {
    grid-row: 1 / span 4;
    -ms-grid-column: 1;
    -ms-grid-row: 1;
    -ms-grid-row-span: 4
  }
  .h-gnavsub__nav._products>li:nth-child(2) {
    -ms-grid-column: 2;
    -ms-grid-row: 1
  }
  .h-gnavsub__nav._products>li:nth-child(3) {
    -ms-grid-column: 2;
    -ms-grid-row: 2
  }
  .h-gnavsub__nav._products>li:nth-child(4) {
    -ms-grid-column: 2;
    -ms-grid-row: 3
  }
  .h-gnavsub__nav._products>li:nth-child(5) {
    -ms-grid-column: 2;
    -ms-grid-row: 4
  }
}

@media screen and (min-width: 1800px) {
  .h-gnavsub__nav {
    margin: -0.5em -36px
  }
}

@media screen and (max-width: 959px) {
  .h-gnavsub__nav {
    margin-top: 0
  }
  .h-gnavsub__nav._about {
    margin-top: -2vw
  }
}

@media screen and (max-width: 399px) {
  .h-gnavsub__nav {
    display: block !important
  }
  .h-gnavsub__nav._about {
    margin-top: -1vw
  }
}

.h-gnavsub__nav-item {
  margin: 1.5em 2vw 0;
  border-top: 1px solid #d4d4d4;
  display: flex
}

@media screen and (min-width: 1800px) {
  .h-gnavsub__nav-item {
    margin: 1.5em 36px 0
  }
}

@media screen and (max-width: 959px) {
  .h-gnavsub__nav-item {
    border-top: none;
    margin-top: 2vw
  }
}

@media screen and (max-width: 399px) {
  .h-gnavsub__nav-item {
    width: auto !important
  }
}

.h-gnavsub__nav._about>.h-gnavsub__nav-item {
  width: calc(33.333% - 4vw)
}

.h-gnavsub__nav._about>.h-gnavsub__nav-item._banner>a {
  display: block;
  width: 70%;
  max-width: 280px
}

.h-gnavsub__nav._about>.h-gnavsub__nav-item._banner>a>img {
  border: 1px solid #1a1a1a
}

@media screen and (max-width: 1199px) {
  .h-gnavsub__nav._about>.h-gnavsub__nav-item._banner>a {
    width: 80%
  }
}

@media screen and (max-width: 799px) {
  .h-gnavsub__nav._about>.h-gnavsub__nav-item._banner>a {
    width: 100%;
    max-width: 200px
  }
}

@media screen and (max-width: 599px) {
  .h-gnavsub__nav._about>.h-gnavsub__nav-item._banner>a {
    width: 110%;
    max-width: none;
    margin-left: -5%;
    margin-right: -5%
  }
}

@media screen and (max-width: 399px) {
  .h-gnavsub__nav._about>.h-gnavsub__nav-item._banner>a {
    width: 200px;
    margin: 10px auto
  }
}

.h-gnavsub__nav._company>.h-gnavsub__nav-item {
  width: calc(33.333% - 4vw)
}

@media screen and (min-width: 400px) {
  .h-gnavsub__nav._company>.h-gnavsub__nav-item:nth-child(1) {
    order: 1
  }
  .h-gnavsub__nav._company>.h-gnavsub__nav-item:nth-child(2) {
    order: 2
  }
  .h-gnavsub__nav._company>.h-gnavsub__nav-item:nth-child(3) {
    order: 4
  }
  .h-gnavsub__nav._company>.h-gnavsub__nav-item:nth-child(4) {
    order: 5
  }
  .h-gnavsub__nav._company>.h-gnavsub__nav-item:nth-child(5) {
    order: 3
  }
}

.h-gnavsub__nav-item>div, .h-gnavsub__nav-item>a {
  width: 100%;
  display: flex;
  padding-top: 20px
}

@media screen and (max-width: 959px) {
  .h-gnavsub__nav-item>div, .h-gnavsub__nav-item>a {
    padding-top: 0
  }
}

.h-gnavsub__nav-item>a {
  align-items: center
}

.h-gnavsub__nav-item>div>figure, .h-gnavsub__nav-item>a>figure {
  flex-shrink: 0;
  width: 25%
}

@media screen and (max-width: 959px) {
  .h-gnavsub__nav-item>div>figure, .h-gnavsub__nav-item>a>figure {
    width: 12vw
  }
}

@media screen and (max-width: 599px) {
  .h-gnavsub__nav-item>div>figure, .h-gnavsub__nav-item>a>figure {
    display: none
  }
}

.h-gnavsub__nav-item>div>div, .h-gnavsub__nav-item>a>div {
  padding: 0 0 0 20px;
  margin-top: -.5em
}

@media screen and (max-width: 959px) {
  .h-gnavsub__nav-item>div>div, .h-gnavsub__nav-item>a>div {
    padding: 0 0 0 15px
  }
}

@media screen and (max-width: 599px) {
  .h-gnavsub__nav-item>div>div, .h-gnavsub__nav-item>a>div {
    width: 100%;
    padding-left: 0;
    margin-top: 0
  }
}

.h-gnavsub__nav-item .c-linktxt-A {
  margin: .8em 0 -1em
}

@media screen and (max-width: 959px) {
  .h-gnavsub__nav-item .c-linktxt-A {
    margin-top: .8em
  }
}

@media screen and (max-width: 599px) {
  .h-gnavsub__nav-item .c-linktxt-A {
    margin: 2vw 0 0
  }
}

.h-gnavsub__nav-item .c-linktxt-A:first-child {
  margin-top: 0
}

.h-gnavsub__nav-item .c-linktxt-A._wiresystem {
  display: table
}

.h-gnavsub__nav-item ul {
  text-align: left;
  margin-left: 1em
}

.h-gnavsub__nav-item li {
  line-height: 1
}

.h-gnavsub__nav-item li>a {
  color: #767676;
  font-size: 13px;
  font-size: .92857rem;
  line-height: 1.6;
  display: inline-block;
  padding: .2em .5em .2em 15px;
  position: relative
}

@media screen and (max-width: 959px) {
  .h-gnavsub__nav-item li>a {
    line-height: 1.4
  }
}

.h-gnavsub__nav-item li>a:hover {
  color: #1a1a1a;
  text-decoration: underline
}

.h-gnavsub__nav-item li>a:hover>span {
  text-decoration: underline
}

.h-gnavsub__nav-item li>a:before {
  content: "";
  width: 7px;
  height: 1px;
  background-color: #1476c7;
  position: absolute;
  top: 1.1em;
  left: 0
}

@media screen and (max-width: 959px) {
  .h-gnavsub__nav-item li>a:before {
    top: 1em
  }
}

.h-gnavsub__nav-item ul.wire-others>li:first-child {
  margin: .8em 0
}

@media screen and (max-width: 599px) {
  .h-gnavsub__nav-item ul.wire-others>li:first-child {
    margin: 2vw 0
  }
}

@media screen and (max-width: 799px) {
  .h-gnavsub__nav-item .c-linkicon {
    display: none
  }
}

.h-subnav {
  display: flex;
  justify-content: flex-end;
  flex-grow: 1;
  background-color: #fff;
  border-bottom: 1px solid #d4d4d4
}

@media screen and (max-width: 959px) {
  .h-subnav {
    flex-wrap: wrap;
    justify-content: flex-start
  }
}

@media screen and (max-width: 959px) {
  .h-subnav>li {
    width: 50%;
    border: 1px #d4d4d4;
    border-style: none solid solid none
  }
}

@media screen and (min-width: 960px) {
  .h-subnav>li:nth-child(3) {
    display: none
  }
}

.h-subnav>li:nth-last-child(2n+1) {
  border-right: none
}

.h-subnav>li:nth-last-child(-n+2) {
  border-bottom: none
}

.h-subnav>li>a {
  font-size: 12px;
  font-size: .85714rem;
  line-height: 2;
  display: block;
  padding: 0 1vw
}

@media screen and (max-width: 959px) {
  .h-subnav>li>a {
    line-height: 1.9
  }
}

@media screen and (max-width: 959px) {
  .h-subnav>li>a {
    line-height: 50px !important;
    padding: 0 1em 0 3em !important
  }
}

.h-subnav>li:last-child>a {
  color: #fff;
  margin: 0 0 -1px 1vw
}

@media screen and (min-width: 960px) {
  .h-subnav>li:last-child>a {
    text-align: center !important;
    width: 140px;
    background-color: #1476c7;
    padding-bottom: 1px
  }
  .h-subnav>li:last-child>a:before {
    position: static;
    display: inline-block;
    margin-right: 8px
  }
}

@media screen and (max-width: 959px) {
  .h-subnav>li:last-child>a {
    color: #1a1a1a;
    background-color: transparent;
    margin: 0
  }
}

@media screen and (min-width: 960px) {
  html.no-touchevents .h-subnav>li:last-child>a:hover {
    color: #fff
  }
}

@media screen and (max-width: 959px) {
  .h-subnav>li>a:before {
    left: 2em !important
  }
}

.h-subnav>li:last-child>a:before {
  left: 2vw;
  border-color: #82bff2
}

@media screen and (max-width: 959px) {
  .h-subnav>li:last-child>a:before {
    border-color: #1476c7
  }
}

@media screen and (min-width: 960px) {
  .h-subnav>li._contact {
    align-self: center
  }
  .h-subnav>li._contact>a {
    color: #fff;
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2;
    line-height: 3 !important;
    padding-left: 30px;
    padding-right: 20px;
    background-color: #1476c7;
    border-radius: 2em
  }
}

@media screen and (min-width: 960px) and (max-width: 959px) {
  .h-subnav>li._contact>a {
    line-height: 1.9
  }
}

@media screen and (min-width: 960px) {
  html.no-touchevents .h-subnav>li._contact>a:hover {
    color: #fff
  }
  .h-subnav>li._contact>a:before {
    left: 15px;
    border-color: #82bff2
  }
}

.h-gnavtrigger {
  text-indent: 100px;
  white-space: nowrap;
  overflow: hidden;
  width: 60px;
  height: 60px;
  background-color: #fff;
  position: absolute;
  top: 0;
  right: 0;
  cursor: pointer;
  display: none
}

@media screen and (max-width: 959px) {
  .h-gnavtrigger {
    display: block
  }
}

body._navopen .h-gnavtrigger {
  position: fixed
}

.h-gnavtrigger>span {
  width: 30px;
  height: 2px;
  background-color: #0C0C0C;
  margin-top: 0;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: width .25s
}

body._navopen .h-gnavtrigger>span {
  width: 0
}

.h-gnavtrigger:before, .h-gnavtrigger:after {
  content: "";
  height: 2px;
  background-color: #0C0C0C;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: all .2s
}

.h-gnavtrigger:before {
  width: 20px;
  margin: -10px 0 0 -5px
}

.h-gnavtrigger:after {
  width: 24px;
  margin: 10px 0 0 -3px
}

body._navopen .h-gnavtrigger:before {
  width: 30px;
  margin: 0;
  transform: translate(-50%, -50%) rotate(45deg)
}

body._navopen .h-gnavtrigger:after {
  width: 30px;
  margin: 0;
  transform: translate(-50%, -50%) rotate(-45deg)
}

.h-header__bcg, .h-gnav__bcg {
  width: 100%;
  height: 0;
  background-color: rgba(0, 0, 0, 0.5);
  position: fixed;
  top: 0;
  left: 0;
  z-index: -3;
  opacity: 0;
  transition: opacity .2s 0s, height 0s .3s
}

@media screen and (min-width: 960px) {
  .h-header__bcg {
    display: none
  }
}

@media screen and (max-width: 959px) {
  .h-gnav__bcg {
    display: none
  }
}

.h-gnav._active+.h-gnav__bcg, body._navopen .h-header__bcg {
  opacity: 1;
  height: 100%;
  transition: opacity .2s .1s, height 0s 0s
}

.f-footer {
  padding-top: 1px;
  background-color: #313131
}

.f-footer__inner {
  padding: 7vw
}

@media screen and (min-width: 1800px) {
  .f-footer__inner {
    padding: 90px
  }
}

@media screen and (max-width: 399px) {
  .f-footer__inner {
    padding: 30px 25px
  }
}

.f-title>.c-svg {
  width: 140px;
  margin: 0 auto;
  margin-bottom: 3vw
}

@media screen and (min-width: 1800px) {
  .f-title>.c-svg {
    margin-bottom: 54px
  }
}

@media screen and (max-width: 399px) {
  .f-title>.c-svg {
    margin-bottom: 12px
  }
}

@media screen and (max-width: 959px) {
  .f-title>.c-svg {
    width: 20%;
    max-width: 130px;
    min-width: 80px
  }
}

.f-title svg {
  fill: #fff
}

.f-title>.c-title-C {
  color: #fff;
  font-size: 22px;
  font-size: 1.57143rem;
  line-height: 1.8;
  margin-bottom: 3vw
}

@media screen and (max-width: 959px) {
  .f-title>.c-title-C {
    line-height: 1.6
  }
}

@media screen and (min-width: 1800px) {
  .f-title>.c-title-C {
    margin-bottom: 54px
  }
}

@media screen and (max-width: 399px) {
  .f-title>.c-title-C {
    margin-bottom: 12px
  }
}

@media screen and (max-width: 959px) {
  .f-title>.c-title-C {
    font-size: 18px;
    font-size: 1.28571rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .f-title>.c-title-C {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .f-title>.c-title-C {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 2;
    margin-bottom: 20px
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .f-title>.c-title-C {
    line-height: 1.9
  }
}

.f-title>.c-title-C>span {
  background-color: #313131
}

.f-title>.c-title-C:before {
  background-color: #767676
}

.f-address {
  color: #fff;
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  text-align: center;
  margin-bottom: 5vw
}

@media screen and (max-width: 959px) {
  .f-address {
    line-height: 1.9
  }
}

@media screen and (min-width: 1800px) {
  .f-address {
    margin-bottom: 90px
  }
}

@media screen and (max-width: 399px) {
  .f-address {
    margin-bottom: 20px
  }
}

@media screen and (max-width: 599px) {
  .f-address {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .f-address {
    line-height: 1.9
  }
}

.f-address>li+li {
  margin-top: .8em
}

.f-address>li>b {
  margin-right: 1em
}

@media screen and (max-width: 1199px) {
  .f-address>li>b {
    display: block;
    margin-right: 0
  }
}

.f-address>li>span {
  display: inline-block
}

@media screen and (max-width: 799px) {
  .f-address>li>span {
    display: block
  }
}

@media screen and (min-width: 600px) {
  .f-address>li>br {
    display: none
  }
}

.f-nav {
  display: flex;
  flex-wrap: wrap;
  text-align: left;
  max-width: 100em;
  margin: 0 auto
}

@media screen and (min-width: 1200px) {
  .f-nav {
    padding-left: 5%
  }
}

@media screen and (max-width: 799px) {
  .f-nav {
    display: block
  }
}

.f-nav__column {
  width: 25%
}

@media screen and (max-width: 799px) {
  .f-nav__column {
    display: none
  }
}

.f-nav__column:nth-child(2) {
  width: 50%
}

.f-nav__item {
  margin: 12px 0 0 20px
}

.f-nav__item:first-child {
  margin-top: 0
}

.f-nav__column:first-child>.f-nav__item {
  margin-left: 0
}

.f-nav__item>ul, .f-nav__item>div>ul {
  margin: 5px 0 0 1em
}

.f-nav__item>div {
  display: flex
}

.f-nav__item>div>ul {
  width: 50%
}

.f-nav__item>div>ul>li+li {
  margin-top: 15px
}

.f-nav__item>div>ul>li+li._nomt {
  margin-top: 0
}

.f-nav__item a {
  color: #838383;
  font-size: 12px;
  font-size: .85714rem;
  line-height: 2;
  line-height: 1.6;
  display: inline-block;
  padding-left: 15px;
  position: relative;
  transition: color .1s
}

@media screen and (max-width: 959px) {
  .f-nav__item a {
    line-height: 1.9
  }
}

html.no-touchevents .f-nav__item a:hover {
  color: #fff;
  text-decoration: underline
}

html.no-touchevents .f-nav__item a:hover>span {
  text-decoration: underline
}

.f-nav__item>a {
  color: #fff;
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  line-height: 1.6
}

@media screen and (max-width: 959px) {
  .f-nav__item>a {
    line-height: 1.9
  }
}

.f-nav__item a:before {
  content: "";
  width: 5px;
  height: 5px;
  border: 3px #767676;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
  position: absolute;
  top: .4em;
  left: 0
}

.f-nav__item ul ul a:before {
  height: 2px;
  border: none;
  background-color: #767676;
  transform: none;
  top: .7em
}

.f-nav__item a>span {
  display: inline-block
}

.f-nav__item .wire-others>li:first-child {
  margin: .8em 0
}

.f-nav__banner {
  display: flex;
  justify-content: center;
  width: 65%;
  max-width: 500px;
  margin-top: 3vw
}

@media screen and (min-width: 1800px) {
  .f-nav__banner {
    margin-top: 54px
  }
}

@media screen and (max-width: 399px) {
  .f-nav__banner {
    margin-top: 12px
  }
}

@media screen and (max-width: 959px) {
  .f-nav__banner {
    margin-left: auto;
    margin-right: auto
  }
}

@media screen and (max-width: 799px) {
  .f-nav__banner {
    width: auto;
    max-width: 400px
  }
}

.f-nav__banner>li {
  width: 50%;
  padding: 0 10px
}

@media screen and (max-width: 599px) {
  .f-nav__banner>li {
    padding: 0 7px
  }
}

.f-subfooter {
  background-color: #1a1a1a
}

.f-subfooter__inner {
  padding: 10px 30px;
  display: flex;
  align-items: center;
  flex-direction: row-reverse
}

@media screen and (max-width: 959px) {
  .f-subfooter__inner {
    text-align: center;
    display: block;
    padding: 20px 30px
  }
}

.f-subfooter__globalbtn {
  margin-right: -1em;
  margin-left: 1.5vw
}

@media screen and (min-width: 1800px) {
  .f-subfooter__globalbtn {
    margin-left: 27px
  }
}

@media screen and (max-width: 959px) {
  .f-subfooter__globalbtn {
    margin: 10px auto 15px;
    display: table
  }
}

.f-subfooter__sns {
  display: flex;
  align-items: center
}

@media screen and (max-width: 959px) {
  .f-subfooter__sns {
    justify-content: center
  }
}

.f-subfooter__sns:before {
  content: "Follow Us";
  color: #767676;
  font-size: 12px;
  font-size: .85714rem;
  line-height: 2;
  display: inline-block;
  margin-right: 1vw
}

@media screen and (max-width: 959px) {
  .f-subfooter__sns:before {
    line-height: 1.9
  }
}

@media screen and (min-width: 1800px) {
  .f-subfooter__sns:before {
    margin-right: 18px
  }
}

@media screen and (max-width: 1199px) {
  .f-subfooter__sns:before {
    content: none
  }
}

.f-subfooter__sns>li>.c-svg {
  width: 44px;
  padding: 10px
}

.f-subfooter__sns svg {
  fill: #767676;
  transition: fill .1s
}

html.no-touchevents .f-subfooter__sns>li>.c-svg:hover svg {
  fill: #fff
}

.f-subfooter__nav {
  display: flex;
  flex-grow: 1
}

@media screen and (max-width: 959px) {
  .f-subfooter__nav {
    flex-wrap: wrap;
    justify-content: center;
    margin: 5px 0
  }
}

.f-subfooter__nav>li {
  margin-left: 2vw
}

@media screen and (min-width: 1800px) {
  .f-subfooter__nav>li {
    margin-left: 36px
  }
}

@media screen and (max-width: 959px) {
  .f-subfooter__nav>li {
    margin: 0 .5em
  }
}

.f-subfooter__nav>li>a {
  color: #767676;
  font-size: 12px;
  font-size: .85714rem;
  line-height: 2;
  font-weight: 600;
  transition: color .1s
}

@media screen and (max-width: 959px) {
  .f-subfooter__nav>li>a {
    line-height: 1.9
  }
}

@media screen and (max-width: 959px) {
  .f-subfooter__nav>li>a {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .f-subfooter__nav>li>a {
    line-height: 1.9
  }
}

html.no-touchevents .f-subfooter__nav>li>a:hover {
  color: #fff;
  text-decoration: underline
}

.f-subfooter__copy {
  color: #767676;
  font-size: 11px;
  font-size: .78571rem;
  line-height: 2;
  margin-top: .2em
}

@media screen and (max-width: 959px) {
  .f-subfooter__copy {
    line-height: 1.9
  }
}

.c-linktxt-A._sm, .contact-form__form-dlist input[type="file"] {
  font-family: 'Open Sans', Arial, Roboto, "Droid Sans", "游ゴシック体", YuGothic, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
  font-weight: 400
}

input[type="submit"], .h-gnav>li>a, .f-nav__item>a, .c-title, .c-title-A, .c-title-B, .c-title-C, .c-titleset-A>.c-title+.c-subtitle, .c-titleset-B>.c-title, .c-titleset-B>.c-title+.c-subtitle, .c-linktxt-A, .c-linktxt-B, .c-linkset-B>li b, .c-button-A, .c-button-B, .c-submit-A, .c-globalbtn>button, .c-pagenav-A>h2, .c-table-A th, .about-vision__txt, .products-header, .company-identity__list, .contact-form__form-catalog>.mwform-checkbox-field .mwform-checkbox-field-text, .contact-form__form-dlist>dt, .hspr-pattern__nav>li>a, .hspr-pattern__fig-item, .hspr-pattern__tab>li>a {
  font-family: 'Open Sans', Arial, Roboto, "Droid Sans", 見出ゴMB31, MidashiGoPro-MB31, "游ゴシック体", YuGothic, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
  font-weight: 700
}

.c-title {
  font-size: 25px;
  font-size: 1.78571rem;
  line-height: 1.6;
  text-align: left
}

@media screen and (max-width: 959px) {
  .c-title {
    line-height: 1.4
  }
}

@media screen and (max-width: 959px) {
  .c-title {
    font-size: 22px;
    font-size: 1.57143rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .c-title {
    font-size: 20px;
    font-size: 1.42857rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 399px) {
  .c-title {
    font-size: 18px;
    font-size: 1.28571rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .c-title {
    line-height: 1.6
  }
}

.c-title-A {
  font-size: 33px;
  font-size: 2.35714rem;
  line-height: 1.6;
  text-align: center;
  margin-bottom: 5vw;
  display: block
}

@media screen and (max-width: 959px) {
  .c-title-A {
    line-height: 1.4
  }
}

@media screen and (min-width: 1800px) {
  .c-title-A {
    margin-bottom: 90px
  }
}

@media screen and (max-width: 399px) {
  .c-title-A {
    margin-bottom: 20px
  }
}

@media screen and (max-width: 959px) {
  .c-title-A {
    font-size: 30px;
    font-size: 2.14286rem;
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .c-title-A {
    line-height: 1.4
  }
}

@media screen and (max-width: 799px) {
  .c-title-A {
    font-size: 28px;
    font-size: 2rem;
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-title-A {
    line-height: 1.4
  }
}

@media screen and (max-width: 599px) {
  .c-title-A {
    font-size: 24px;
    font-size: 1.71429rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-title-A {
    line-height: 1.6
  }
}

@media screen and (max-width: 399px) {
  .c-title-A {
    font-size: 20px;
    font-size: 1.42857rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .c-title-A {
    line-height: 1.6
  }
}

.c-title-A:before {
  content: "";
  width: 1px;
  height: 50px;
  background-color: #1a1a1a;
  display: block;
  margin: 0 auto 25px
}

@media screen and (max-width: 799px) {
  .c-title-A:before {
    height: 40px;
    margin-bottom: 20px
  }
}

@media screen and (max-width: 599px) {
  .c-title-A:before {
    height: 35px;
    margin-bottom: 12px
  }
}

.c-title-B {
  font-size: 33px;
  font-size: 2.35714rem;
  line-height: 1.6;
  text-align: center;
  margin-bottom: 5vw;
  display: block
}

@media screen and (max-width: 959px) {
  .c-title-B {
    line-height: 1.4
  }
}

@media screen and (min-width: 1800px) {
  .c-title-B {
    margin-bottom: 90px
  }
}

@media screen and (max-width: 399px) {
  .c-title-B {
    margin-bottom: 20px
  }
}

@media screen and (max-width: 959px) {
  .c-title-B {
    font-size: 30px;
    font-size: 2.14286rem;
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .c-title-B {
    line-height: 1.4
  }
}

@media screen and (max-width: 799px) {
  .c-title-B {
    font-size: 24px;
    font-size: 1.71429rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-title-B {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .c-title-B {
    font-size: 20px;
    font-size: 1.42857rem;
    line-height: 1.8;
    margin-bottom: 7vw
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-title-B {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) and (min-width: 1800px) {
  .c-title-B {
    margin-bottom: 126px
  }
}

@media screen and (max-width: 599px) and (max-width: 399px) {
  .c-title-B {
    margin-bottom: 28px
  }
}

@media screen and (max-width: 399px) {
  .c-title-B {
    font-size: 18px;
    font-size: 1.28571rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .c-title-B {
    line-height: 1.6
  }
}

.c-title-B._sm {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8
}

@media screen and (max-width: 959px) {
  .c-title-B._sm {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .c-title-B._sm {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-title-B._sm {
    line-height: 1.6
  }
}

.c-title-B:after {
  content: "";
  width: 30px;
  height: 5px;
  background-color: #1a1a1a;
  display: block;
  margin: 20px auto 0
}

@media screen and (max-width: 799px) {
  .c-title-B:after {
    height: 4px;
    margin-top: 15px
  }
}

@media screen and (max-width: 599px) {
  .c-title-B:after {
    width: 25px;
    height: 3px;
    margin-top: 12px
  }
}

.c-title-C {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 30px;
  text-align: center;
  margin-bottom: 5vw;
  position: relative;
  display: block
}

@media screen and (max-width: 959px) {
  .c-title-C {
    line-height: 29.9px
  }
}

@media screen and (min-width: 1800px) {
  .c-title-C {
    margin-bottom: 90px
  }
}

@media screen and (max-width: 399px) {
  .c-title-C {
    margin-bottom: 20px
  }
}

@media screen and (max-width: 599px) {
  .c-title-C {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-title-C {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .c-title-C {
    font-size: 14px;
    font-size: 1rem;
    line-height: 25px
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-title-C {
    line-height: 24.9px
  }
}

.c-title-C>span {
  display: inline-block;
  padding: 0 2em;
  background-color: #fff;
  position: relative
}

@media screen and (max-width: 599px) {
  .c-title-C>span {
    padding: 0 1.2em
  }
}

.l-line .c-title-C>span {
  background-color: #f5f5f5
}

.l-line._blue .c-title-C>span {
  background-color: #dcedec
}

.c-title-C:before {
  content: "";
  width: 100%;
  height: 1px;
  background-color: #d4d4d4;
  position: absolute;
  top: 50%;
  left: 0
}

.c-titleset-A {
  text-align: center;
  margin: 7vw auto
}

@media screen and (min-width: 1800px) {
  .c-titleset-A {
    margin: 126px auto
  }
}

@media screen and (max-width: 399px) {
  .c-titleset-A {
    margin: 36px auto 30px
  }
}

.c-titleset-A+main>.l-container:first-child {
  margin-top: 0
}

.c-titleset-A>.c-title {
  font-size: 33px;
  font-size: 2.35714rem;
  line-height: 1.6;
  text-align: center
}

@media screen and (max-width: 959px) {
  .c-titleset-A>.c-title {
    line-height: 1.4
  }
}

@media screen and (max-width: 959px) {
  .c-titleset-A>.c-title {
    font-size: 28px;
    font-size: 2rem;
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .c-titleset-A>.c-title {
    line-height: 1.4
  }
}

@media screen and (max-width: 599px) {
  .c-titleset-A>.c-title {
    font-size: 24px;
    font-size: 1.71429rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-titleset-A>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 399px) {
  .c-titleset-A>.c-title {
    font-size: 20px;
    font-size: 1.42857rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .c-titleset-A>.c-title {
    line-height: 1.6
  }
}

.c-titleset-A>.c-title+p {
  margin-top: 3vw
}

@media screen and (min-width: 1800px) {
  .c-titleset-A>.c-title+p {
    margin-top: 54px
  }
}

@media screen and (max-width: 399px) {
  .c-titleset-A>.c-title+p {
    margin-top: 12px
  }
}

.c-titleset-A>.c-title+.c-subtitle {
  color: #1476c7;
  margin-top: 1em
}

@media screen and (max-width: 599px) {
  .c-titleset-A>.c-title+.c-subtitle {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-titleset-A>.c-title+.c-subtitle {
    line-height: 1.9
  }
}

.c-titleset-B {
  margin-bottom: 5vw
}

@media screen and (min-width: 1800px) {
  .c-titleset-B {
    margin-bottom: 90px
  }
}

@media screen and (max-width: 399px) {
  .c-titleset-B {
    margin-bottom: 20px
  }
}

.c-titleset-B>.c-title {
  font-size: 33px;
  font-size: 2.35714rem;
  line-height: 1.6;
  text-align: center;
  display: block
}

@media screen and (max-width: 959px) {
  .c-titleset-B>.c-title {
    line-height: 1.4
  }
}

@media screen and (max-width: 959px) {
  .c-titleset-B>.c-title {
    font-size: 28px;
    font-size: 2rem;
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .c-titleset-B>.c-title {
    line-height: 1.4
  }
}

@media screen and (max-width: 599px) {
  .c-titleset-B>.c-title {
    font-size: 24px;
    font-size: 1.71429rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-titleset-B>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 399px) {
  .c-titleset-B>.c-title {
    font-size: 20px;
    font-size: 1.42857rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .c-titleset-B>.c-title {
    line-height: 1.6
  }
}

.c-titleset-B>.c-title+.c-subtitle {
  color: #1476c7;
  text-align: center;
  display: block;
  margin-top: 1em
}

@media screen and (max-width: 599px) {
  .c-titleset-B>.c-title+.c-subtitle {
    margin-top: .7em
  }
}

.c-textset-A {
  display: block
}

.c-textset-A._tclw {
  color: #fff
}

.c-textset-A>.c-img-ratio, .c-textset-A>figure {
  margin-bottom: 30px
}

@media screen and (max-width: 799px) {
  .c-textset-A>.c-img-ratio, .c-textset-A>figure {
    margin-bottom: 20px
  }
}

.c-textset-A>.c-title {
  margin-bottom: .5em
}

@media screen and (max-width: 959px) {
  .c-textset-A>.c-title {
    font-size: 22px;
    font-size: 1.57143rem;
    line-height: 1.8;
    margin-bottom: .3em
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .c-textset-A>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .c-textset-A>.c-title {
    font-size: 18px;
    font-size: 1.28571rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-textset-A>.c-title {
    line-height: 1.6
  }
}

.c-textset-A>.c-title._lg {
  font-size: 33px;
  font-size: 2.35714rem;
  line-height: 1.6
}

@media screen and (max-width: 959px) {
  .c-textset-A>.c-title._lg {
    line-height: 1.4
  }
}

@media screen and (max-width: 959px) {
  .c-textset-A>.c-title._lg {
    font-size: 28px;
    font-size: 2rem;
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .c-textset-A>.c-title._lg {
    line-height: 1.4
  }
}

@media screen and (max-width: 799px) {
  .c-textset-A>.c-title._lg {
    font-size: 24px;
    font-size: 1.71429rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-textset-A>.c-title._lg {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .c-textset-A>.c-title._lg {
    font-size: 22px;
    font-size: 1.57143rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-textset-A>.c-title._lg {
    line-height: 1.6
  }
}

@media screen and (max-width: 399px) {
  .c-textset-A>.c-title._lg {
    font-size: 20px;
    font-size: 1.42857rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .c-textset-A>.c-title._lg {
    line-height: 1.6
  }
}

.c-textset-A>.c-title._xl {
  font-size: 40px;
  font-size: 2.85714rem;
  line-height: 1.6
}

@media screen and (max-width: 959px) {
  .c-textset-A>.c-title._xl {
    line-height: 1.4
  }
}

@media screen and (max-width: 959px) {
  .c-textset-A>.c-title._xl {
    font-size: 30px;
    font-size: 2.14286rem;
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .c-textset-A>.c-title._xl {
    line-height: 1.4
  }
}

@media screen and (max-width: 599px) {
  .c-textset-A>.c-title._xl {
    font-size: 24px;
    font-size: 1.71429rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-textset-A>.c-title._xl {
    line-height: 1.6
  }
}

.c-textset-A>.c-title._xxl {
  font-size: 50px;
  font-size: 3.57143rem;
  line-height: 1.4;
  margin-bottom: .7em
}

@media screen and (max-width: 959px) {
  .c-textset-A>.c-title._xxl {
    line-height: 1.2
  }
}

@media screen and (max-width: 959px) {
  .c-textset-A>.c-title._xxl {
    font-size: 40px;
    font-size: 2.85714rem;
    line-height: 1.6;
    margin-bottom: .5em
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .c-textset-A>.c-title._xxl {
    line-height: 1.4
  }
}

@media screen and (max-width: 799px) {
  .c-textset-A>.c-title._xxl {
    font-size: 30px;
    font-size: 2.14286rem;
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-textset-A>.c-title._xxl {
    line-height: 1.4
  }
}

@media screen and (max-width: 599px) {
  .c-textset-A>.c-title._xxl {
    font-size: 24px;
    font-size: 1.71429rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-textset-A>.c-title._xxl {
    line-height: 1.6
  }
}

.c-textset-A>.c-title:before {
  content: attr(data-en);
  font-size: 14px;
  font-size: 1rem;
  line-height: 2;
  font-weight: 400;
  display: block;
  margin-bottom: 10px
}

@media screen and (max-width: 959px) {
  .c-textset-A>.c-title:before {
    line-height: 1.9
  }
}

@media screen and (max-width: 959px) {
  .c-textset-A>.c-title:before {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2;
    margin-bottom: 7px
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .c-textset-A>.c-title:before {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .c-textset-A>.c-title:before {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2;
    margin-bottom: 3px
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-textset-A>.c-title:before {
    line-height: 1.9
  }
}

.c-textset-A>.c-title+p {
  padding-left: 70px;
  margin-bottom: 1.7em;
  position: relative
}

@media screen and (max-width: 1199px) {
  .c-textset-A>.c-title+p {
    padding-left: 50px
  }
}

@media screen and (max-width: 959px) {
  .c-textset-A>.c-title+p {
    padding-left: 0
  }
}

@media screen and (max-width: 799px) {
  .c-textset-A>.c-title+p {
    margin-bottom: 1.3em
  }
}

.c-textset-A>.c-title+p:before {
  content: "";
  width: 50px;
  height: 1px;
  background-color: #1a1a1a;
  position: absolute;
  top: .95em;
  left: 0
}

@media screen and (max-width: 1199px) {
  .c-textset-A>.c-title+p:before {
    width: 35px
  }
}

@media screen and (max-width: 959px) {
  .c-textset-A>.c-title+p:before {
    content: none
  }
}

.c-textset-A._tclw>.c-title+p:before {
  background-color: #fff
}

.c-textset-A>*:last-child {
  margin-bottom: 0 !important
}

.c-textset-A .c-button-A, .c-textset-A .c-button-B {
  margin-left: 70px
}

@media screen and (max-width: 1199px) {
  .c-textset-A .c-button-A, .c-textset-A .c-button-B {
    margin-left: 50px
  }
}

@media screen and (max-width: 959px) {
  .c-textset-A .c-button-A, .c-textset-A .c-button-B {
    margin-left: 0
  }
}

.c-textset-B {
  display: block
}

.c-textset-B>.c-img-ratio, .c-textset-B>figure {
  margin-bottom: 20px
}

@media screen and (max-width: 959px) {
  .c-textset-B>.c-img-ratio, .c-textset-B>figure {
    margin-bottom: 18px
  }
}

@media screen and (max-width: 799px) {
  .c-textset-B>.c-img-ratio, .c-textset-B>figure {
    margin-bottom: 12px
  }
}

.c-textset-B>.c-title {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8;
  margin-bottom: 1.5em
}

@media screen and (max-width: 959px) {
  .c-textset-B>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) {
  .c-textset-B>.c-title {
    margin-bottom: 1em
  }
}

@media screen and (max-width: 799px) {
  .c-textset-B>.c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8;
    margin-bottom: .8em
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-textset-B>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .c-textset-B>.c-title {
    font-size: 14px;
    font-size: 1rem;
    line-height: 2;
    margin-bottom: .8em
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-textset-B>.c-title {
    line-height: 1.9
  }
}

.c-textset-B._sm>.c-title {
  margin-bottom: .2em
}

.c-textset-B._sm>.c-title+p {
  color: #767676;
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2
}

@media screen and (max-width: 959px) {
  .c-textset-B._sm>.c-title+p {
    line-height: 1.9
  }
}

.c-textset-B>.c-title+p, .c-textset-B>p._mb {
  margin-bottom: 25px
}

@media screen and (max-width: 799px) {
  .c-textset-B>.c-title+p, .c-textset-B>p._mb {
    margin-bottom: 15px
  }
}

.c-textset-B>*:last-child {
  margin-bottom: 0 !important
}

.c-text-sm {
  color: #767676;
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2
}

@media screen and (max-width: 959px) {
  .c-text-sm {
    line-height: 1.9
  }
}

@media screen and (max-width: 799px) {
  .c-text-sm {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2;
    letter-spacing: 0
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-text-sm {
    line-height: 1.9
  }
}

@media screen and (max-width: 399px) {
  .c-text-sm {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .c-text-sm {
    line-height: 1.9
  }
}

.c-linktxt {
  text-decoration: underline
}

.c-linktxt-A {
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  line-height: 1.8;
  text-align: left !important;
  display: inline-block;
  padding: .5em 0 .5em 15px;
  position: relative;
  transition: color .1s
}

@media screen and (max-width: 959px) {
  .c-linktxt-A {
    line-height: 1.9
  }
}

@media screen and (max-width: 799px) {
  .c-linktxt-A {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-linktxt-A {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .c-linktxt-A {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-linktxt-A {
    line-height: 1.9
  }
}

.c-linktxt-A._icon {
  padding-left: 25px
}

.c-linktxt-A._sm {
  color: #767676;
  font-weight: 400;
  text-decoration: underline
}

.c-linktxt-A._nouline {
  text-decoration: none
}

@media screen and (max-width: 799px) {
  .c-linktxt-A {
    padding: .3em 0 .3em 10px
  }
}

html.no-touchevents a.c-linktxt-A:hover, html.no-touchevents a:hover .c-linktxt-A, html.no-touchevents a.c-linktxt-A:hover>*, html.no-touchevents a:hover .c-linktxt-A>* {
  color: #1a1a1a;
  text-decoration: underline
}

.c-linktxt-A>.c-svg {
  width: 18px;
  position: absolute;
  top: .7em;
  left: 0
}

@media screen and (max-width: 799px) {
  .c-linktxt-A>.c-svg {
    top: .5em
  }
}

@media screen and (max-width: 599px) {
  .c-linktxt-A>.c-svg {
    top: .45em
  }
}

.c-linktxt-A>.c-svg svg {
  fill: #1476c7
}

.c-linktxt-A:before {
  content: "";
  width: 6px;
  height: 6px;
  border: 3px #1476c7;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
  position: absolute;
  top: 50%;
  left: 0;
  margin-top: -5px
}

@media screen and (max-width: 799px) {
  .c-linktxt-A:before {
    width: 4px;
    height: 4px;
    border: 3px #1476c7;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
    margin-top: -4px
  }
}

@media screen and (max-width: 599px) {
  .c-linktxt-A:before {
    margin-top: -3px
  }
}

.c-linktxt-A._icon:before {
  content: none
}

.c-linktxt-B {
  line-height: 1.8;
  text-align: left !important;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 0 13px 50px;
  border: 1px #d4d4d4;
  border-style: solid none;
  position: relative
}

@media screen and (max-width: 1199px) {
  .c-linktxt-B {
    padding-left: 45px
  }
}

@media screen and (max-width: 959px) {
  .c-linktxt-B {
    padding-left: 35px
  }
}

@media screen and (max-width: 799px) {
  .c-linktxt-B {
    padding: 11px 0 11px 40px
  }
}

@media screen and (max-width: 599px) {
  .c-linktxt-B {
    padding-left: 35px;
    font-size: 13px;
    font-size: .92857rem;
    line-height: 1.7
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-linktxt-B {
    line-height: 1.5
  }
}

.c-linktxt-B._lg {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8;
  padding-top: 10px;
  padding-bottom: 10px
}

@media screen and (max-width: 959px) {
  .c-linktxt-B._lg {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) {
  .c-linktxt-B._lg {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-linktxt-B._lg {
    line-height: 1.6
  }
}

@media screen and (max-width: 399px) {
  .c-linktxt-B._lg {
    font-size: 14px;
    font-size: 1rem;
    line-height: 1.7
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .c-linktxt-B._lg {
    line-height: 1.5
  }
}

.c-linktxt-B._icon {
  padding-left: 40px
}

.c-linktxt-B._nb {
  border: none
}

html.no-touchevents .c-linktxt-B:hover, html.no-touchevents .c-linktxt-B:hover>span>* {
  text-decoration: underline
}

.c-linktxt-B>span>.c-svg {
  width: 18px;
  position: absolute;
  top: 50%;
  left: 10px;
  transform: translate(0, -50%)
}

.c-linktxt-B>span>.c-svg svg {
  fill: #1476c7
}

.c-linktxt-B>span>i {
  width: 2.5vw;
  height: 2.5vw;
  max-width: 38px;
  max-height: 38px;
  min-width: 25px;
  min-height: 25px;
  position: relative;
  border: 2px solid #1476c7;
  background-color: #1476c7;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
  overflow: hidden
}

.c-linktxt-B>span>i:after {
  content: "";
  width: 6px;
  height: 6px;
  border: 3px #fff;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -4px 0 0 -2px
}

@media screen and (max-width: 799px) {
  .c-linktxt-B>span>i:after {
    width: 4px;
    height: 4px;
    border: 3px #fff;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
    margin: -3px 0 0 -1px
  }
}

.c-linktxt-B>span>i:after {
  transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
  transition: opacity .15s, transform .15s
}

html.no-touchevents .c-linktxt-B:hover>span>i:after {
  opacity: 0;
  transform: scaleX(0.8) translate(50%, 0) rotate(45deg)
}

.c-linktxt-B>span>i:before {
  content: "";
  height: 100%;
  width: 150%;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1;
  opacity: 0;
  background-color: #fff;
  transform: translate(-110%, 0) skew(-35deg);
  transition: opacity .1s, transform .15s
}

html.no-touchevents .c-linktxt-B:hover>span>i:before {
  opacity: 1;
  transform: translate(10%, 0) skew(0deg)
}

.c-linktxt-B>span>i>i {
  width: 2.5vw;
  height: 2.5vw;
  max-width: 38px;
  max-height: 38px;
  min-width: 25px;
  min-height: 25px;
  position: relative;
  border: 2px solid transparent;
  background-color: transparent;
  border: none;
  position: absolute;
  top: -2px;
  left: -2px;
  z-index: 2;
  opacity: 0;
  transform: translate(-50%, 0);
  transition: opacity .15s, transform .25s
}

.c-linktxt-B>span>i>i:after {
  content: "";
  width: 6px;
  height: 6px;
  border: 3px #1476c7;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -4px 0 0 -2px
}

@media screen and (max-width: 799px) {
  .c-linktxt-B>span>i>i:after {
    width: 4px;
    height: 4px;
    border: 3px #1476c7;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
    margin: -3px 0 0 -1px
  }
}

html.no-touchevents .c-linktxt-B:hover>span>i>i {
  opacity: 1;
  transform: translate(0, 0)
}

.c-linktxt-B>figure {
  flex-shrink: 0;
  width: 80px;
  margin-left: 15px
}

@media screen and (max-width: 799px) {
  .c-linktxt-B>figure {
    width: 50px;
    margin-left: 10px
  }
}

.c-linkset-A {
  margin-top: 0;
  margin-bottom: 0
}

.c-linkset-A>li {
  padding-top: 0;
  padding-bottom: 0;
  margin-top: -1px
}

.c-linkset-A>li>* {
  height: 100%
}

.c-linkset-B {
  margin: 0
}

.c-linkset-B>li {
  text-align: center;
  padding: 0
}

.c-linkset-B>li+li {
  border-left: 1px solid #d4d4d4
}

.c-linkset-B>li>span {
  display: block;
  padding: 3vw
}

@media screen and (max-width: 599px) {
  .c-linkset-B>li>span {
    padding: 20px 15px
  }
}

@media screen and (max-width: 399px) {
  .c-linkset-B>li>span {
    padding: 10px 5px
  }
}

.c-linkset-B>li b {
  font-size: 16px;
  font-size: 1.14286rem;
  line-height: 1.8
}

@media screen and (max-width: 959px) {
  .c-linkset-B>li b {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .c-linkset-B>li b {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-linkset-B>li b {
    line-height: 1.9
  }
}

@media screen and (max-width: 399px) {
  .c-linkset-B>li b {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .c-linkset-B>li b {
    line-height: 1.9
  }
}

.c-linkset-B>li>a>b:before {
  content: "";
  width: 6px;
  height: 6px;
  border: 3px #1476c7;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
  display: inline-block;
  vertical-align: middle;
  margin: 0 5px 3px 0
}

@media screen and (max-width: 799px) {
  .c-linkset-B>li>a>b:before {
    width: 4px;
    height: 4px;
    border: 3px #1476c7;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleX(0.8) translate(-50%, 0) rotate(45deg)
  }
}

.c-linkset-B .c-svg {
  width: 5vw;
  max-width: 45px;
  min-width: 30px;
  margin: 0 auto 20px
}

@media screen and (max-width: 599px) {
  .c-linkset-B .c-svg {
    margin-bottom: 10px
  }
}

.c-linkset-B .c-svg svg {
  fill: #1a1a1a
}

.c-linkset-C {
  text-align: left
}

@media screen and (max-width: 799px) {
  .c-linkset-C {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 2
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-linkset-C {
    line-height: 1.9
  }
}

@media screen and (max-width: 399px) {
  .c-linkset-C {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .c-linkset-C {
    line-height: 1.9
  }
}

.c-linkset-C>li {
  display: inline-block;
  margin-right: 1em
}

.c-linkset-C>li:last-child {
  margin-right: 0
}

.c-linkset-C>li>a {
  text-decoration: underline
}

.c-linkicon__parent {
  position: relative;
  display: block;
  overflow: hidden
}

.c-linkicon__parent._zoom {
  overflow: visible
}

.c-linkicon {
  width: 2.5vw;
  height: 2.5vw;
  max-width: 38px;
  max-height: 38px;
  min-width: 25px;
  min-height: 25px;
  position: relative;
  border: 2px solid #1476c7;
  background-color: #1476c7;
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 1;
  overflow: hidden;
  transform: translate(0, 0);
  transition: transform .2s
}

.c-linkicon:after {
  content: "";
  width: 6px;
  height: 6px;
  border: 3px #fff;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -4px 0 0 -2px
}

@media screen and (max-width: 799px) {
  .c-linkicon:after {
    width: 4px;
    height: 4px;
    border: 3px #fff;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
    margin: -3px 0 0 -1px
  }
}

.c-linkicon._sm {
  width: 1.8vw;
  height: 1.8vw;
  min-width: 23px;
  min-height: 23px
}

.c-linkicon._lg {
  width: 4vw;
  height: 4vw;
  max-width: 50px;
  max-height: 50px
}

@media screen and (max-width: 959px) {
  .c-linkicon._md-lg {
    width: 4vw;
    height: 4vw
  }
}

html.no-touchevents a:hover .c-linkicon:not(._movie) {
  transform: translate(120%, 0) skew(-15deg)
}

.c-linkicon._zoom {
  width: 1.8vw;
  height: 1.8vw;
  min-width: 23px;
  min-height: 23px;
  background-color: #9a9a9a;
  border-color: #9a9a9a
}

.c-linkicon._zoom:after {
  content: none
}

.c-linkicon._zoom>span {
  padding: 22%
}

.c-linkicon._zoom svg {
  fill: #fff
}

.c-linkicon._movie {
  bottom: 50%;
  right: 50%;
  transform: translate(50%, 50%)
}

.c-linkicon._movie:after {
  width: 0;
  height: 0;
  border: .5vw solid transparent;
  border-left: .7vw solid #fff;
  margin: 0 0 0 4px;
  transform: translate(-50%, -50%)
}

@media screen and (min-width: 1500px) {
  .c-linkicon._movie:after {
    border-width: 7.5px;
    border-left-width: 10.5px
  }
}

@media screen and (max-width: 959px) {
  .c-linkicon._movie:after {
    margin-left: 3px
  }
}

@media screen and (max-width: 799px) {
  .c-linkicon._movie:after {
    border-width: 4.8px;
    border-left-width: 6.4px
  }
}

.c-button-A, .c-button-B, .c-submit-A {
  color: #fff;
  font-size: 13px;
  font-size: .92857rem;
  line-height: 54px;
  text-align: left !important;
  display: inline-block;
  min-width: 200px;
  height: 58px;
  border: 2px solid #1476c7;
  background-color: #1476c7;
  position: relative;
  overflow: hidden;
  cursor: pointer
}

@media screen and (max-width: 959px) {
  .c-button-A, .c-button-B, .c-submit-A {
    line-height: 53.9px
  }
}

@media screen and (max-width: 799px) {
  .c-button-A, .c-button-B, .c-submit-A {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 46px;
    min-width: 160px;
    height: 50px
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-button-A, .c-button-B, .c-submit-A {
    line-height: 45.9px
  }
}

@media screen and (max-width: 599px) {
  .c-button-A, .c-button-B, .c-submit-A {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 42px;
    height: 46px
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-button-A, .c-button-B, .c-submit-A {
    line-height: 41.9px
  }
}

.c-button-A._tall, ._tall.c-button-B, .c-submit-A._tall {
  line-height: 66px;
  height: 70px
}

@media screen and (max-width: 799px) {
  .c-button-A._tall, ._tall.c-button-B, .c-submit-A._tall {
    line-height: 58px;
    height: 62px
  }
}

@media screen and (max-width: 599px) {
  .c-button-A._tall, ._tall.c-button-B, .c-submit-A._tall {
    line-height: 52px;
    height: 56px
  }
}

.c-button-A._wide, ._wide.c-button-B, .c-submit-A._wide {
  min-width: 260px
}

@media screen and (max-width: 799px) {
  .c-button-A._wide, ._wide.c-button-B, .c-submit-A._wide {
    min-width: 200px
  }
}

.c-button-A._flip, ._flip.c-button-B, .c-submit-A._flip {
  border-width: 1px;
  color: #1a1a1a;
  background-color: #fff
}

.c-button-A:before, .c-button-B:before, .c-submit-A:before {
  content: "";
  height: 100%;
  width: 150%;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2;
  background-color: #fff;
  opacity: 0;
  transform: translate(-70%, 0) skew(-25deg);
  transition: opacity .2s, transform .25s
}

html.no-touchevents .c-button-A:hover:before, html.no-touchevents .c-button-B:hover:before, html.no-touchevents .c-submit-A:hover:before {
  opacity: 1;
  transform: translate(10%, 0) skew(0deg)
}

.c-button-A._flip:after, ._flip.c-button-B:after {
  box-sizing: border-box;
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  border: 0px solid #1476c7;
  top: 0;
  left: 0;
  z-index: 5;
  transition: border-width .1s
}

html.no-touchevents .c-button-A._flip:hover:after, html.no-touchevents ._flip.c-button-B:hover:after {
  border-width: 1px
}

.c-button-A>span, .c-button-B>span, .c-submit-A>span {
  display: block;
  padding: 0 35px 0 20px;
  position: relative;
  z-index: 1;
  transform: translate(0, 0);
  transition: opacity .25s, transform .25s
}

@media screen and (max-width: 799px) {
  .c-button-A>span, .c-button-B>span, .c-submit-A>span {
    padding: 0 20px 0 15px
  }
}

html.no-touchevents .c-button-A:hover>span, html.no-touchevents .c-button-B:hover>span, html.no-touchevents .c-submit-A:hover>span {
  opacity: 0;
  transform: translate(50%, 0)
}

.c-button-A>i, .c-button-B>i, .c-submit-A>i {
  color: #1476c7;
  width: 100%;
  height: 100%;
  padding: 0 35px 0 20px;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
  opacity: 0;
  transform: translate(-50%, 0);
  transition: opacity .15s, transform .25s
}

@media screen and (max-width: 799px) {
  .c-button-A>i, .c-button-B>i, .c-submit-A>i {
    padding: 0 20px 0 15px
  }
}

html.no-touchevents .c-button-A:hover>i, html.no-touchevents .c-button-B:hover>i, html.no-touchevents .c-submit-A:hover>i {
  opacity: 1;
  transform: translate(0, 0)
}

.c-button-A._flip>span, ._flip.c-button-B>span, .c-button-A._flip>i, ._flip.c-button-B>i {
  padding-top: 1px
}

.c-button-A>span:after, .c-button-B>span:after, .c-submit-A>span:after, .c-button-A>i:after, .c-button-B>i:after, .c-submit-A>i:after {
  content: "";
  width: 6px;
  height: 6px;
  border: 3px #fff;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
  position: absolute;
  top: 50%;
  right: 15px;
  margin-top: -4px
}

@media screen and (max-width: 799px) {
  .c-button-A>span:after, .c-button-B>span:after, .c-submit-A>span:after, .c-button-A>i:after, .c-button-B>i:after, .c-submit-A>i:after {
    width: 4px;
    height: 4px;
    border: 3px #fff;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
    right: 10px;
    margin-top: -3px
  }
}

.c-button-A._flip._down>span:after, ._flip._down.c-button-B>span:after, .c-button-A._flip._down>i:after, ._flip._down.c-button-B>i:after {
  width: 6px;
  height: 6px;
  border: 3px #1476c7;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleY(0.8) translate(-50%, 0) rotate(135deg)
}

@media screen and (max-width: 799px) {
  .c-button-A._flip._down>span:after, ._flip._down.c-button-B>span:after, .c-button-A._flip._down>i:after, ._flip._down.c-button-B>i:after {
    width: 4px;
    height: 4px;
    border: 3px #1476c7;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleY(0.8) translate(-50%, 0) rotate(135deg)
  }
}

.c-button-A._flip>span:after, ._flip.c-button-B>span:after, .c-button-A>i:after, .c-button-B>i:after, .c-submit-A>i:after {
  width: 6px;
  height: 6px;
  border: 3px #1476c7;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(45deg)
}

@media screen and (max-width: 799px) {
  .c-button-A._flip>span:after, ._flip.c-button-B>span:after, .c-button-A>i:after, .c-button-B>i:after, .c-submit-A>i:after {
    width: 4px;
    height: 4px;
    border: 3px #1476c7;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleX(0.8) translate(-50%, 0) rotate(45deg)
  }
}

.c-button-A .c-svg, .c-button-B .c-svg {
  width: 20px;
  display: inline-block;
  vertical-align: middle;
  margin: 0 10px 4px 0
}

@media screen and (max-width: 799px) {
  .c-button-A .c-svg, .c-button-B .c-svg {
    width: 18px;
    margin-right: 5px
  }
}

.c-button-A>span .c-svg svg, .c-button-B>span .c-svg svg {
  fill: #1476c7
}

.c-button-A>i .c-svg svg, .c-button-B>i .c-svg svg {
  fill: #1476c7
}

.c-button-B {
  color: #1a1a1a;
  background-color: #fff;
  cursor: pointer
}

.c-button-B:after {
  border-color: #1476c7
}

.c-button-B._down:after {
  width: 6px;
  height: 6px;
  border: 3px #1476c7;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleY(0.8) translate(-50%, 0) rotate(135deg)
}

@media screen and (max-width: 799px) {
  .c-button-B._down:after {
    width: 4px;
    height: 4px;
    border: 3px #1476c7;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleY(0.8) translate(-50%, 0) rotate(135deg)
  }
}

.c-button-B>.c-svg {
  width: 20px;
  display: inline-block;
  vertical-align: middle;
  margin: 0 10px 4px 0
}

@media screen and (max-width: 799px) {
  .c-button-B>.c-svg {
    width: 18px;
    margin-right: 5px
  }
}

.c-button-B>.c-svg svg {
  fill: #1476c7
}

.c-buttonset-A {
  text-align: center;
  margin-bottom: -7px
}

.c-buttonset-A>li {
  display: inline-block;
  margin: 0 7px 7px
}

.c-globalbtn {
  position: relative
}

html.no-touchevents .c-globalbtn:hover>button {
  color: #fff
}

html.no-touchevents .c-globalbtn:hover>button svg {
  fill: #fff
}

.c-globalbtn>button {
  color: #d4d4d4;
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  letter-spacing: 1px;
  line-height: 1.4;
  width: 100%;
  padding: .7em .5em;
  transition: color .1s
}

@media screen and (max-width: 959px) {
  .c-globalbtn>button {
    line-height: 1.9
  }
}

.c-globalbtn>button .c-svg {
  width: 24px;
  margin: 0 10px 1px 0;
  display: inline-block;
  vertical-align: middle
}

.c-globalbtn>button .c-svg svg {
  fill: #d4d4d4;
  transition: fill .1s
}

.c-globalbtn>select {
  color: transparent;
  font-size: 16px;
  background-color: transparent;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  outline: none;
  padding: 1em;
  outline: none
}

@media screen and (max-width: 959px) {
  .c-globalbtn>select {
    width: 100%;
    left: 0
  }
}

.c-globalbtn>select option {
  color: #1a1a1a
}

@media all and (-ms-high-contrast: none) {
  .c-globalbtn>select {
    opacity: 0
  }
}

.c-img-ratio {
  text-align: left;
  display: block;
  width: 100%;
  height: 0;
  padding-bottom: 61.8%;
  position: relative
}

.c-img-ratio._r1to1 {
  padding-bottom: 100%
}

.c-img-ratio._r2to1 {
  padding-bottom: 50%
}

.c-img-ratio._r16to9 {
  padding-bottom: 56.25%
}

.c-img-ratio._r3to2 {
  padding-bottom: 66.666%
}

.c-img-ratio._r3to4 {
  padding-bottom: 133.333%
}

.c-img-ratio._r4to3 {
  padding-bottom: 75%
}

.c-img-ratio._full {
  height: 100%;
  padding-bottom: 0
}

.c-img-ratio._auto {
  height: auto;
  padding-bottom: 0 !important
}

.c-img-ratio>span {
  position: absolute;
  width: 100%;
  height: 100%
}

.c-img-ratio._auto>span {
  position: relative;
  width: 100%;
  height: auto
}

.c-img-ratio>*>img {
  width: 100%;
  height: 100%;
  object-fit: cover
}

html.no-object-fit .c-img-ratio>*>img {
  height: auto
}

.c-img-ratio._top>*>img {
  object-position: 50% 0
}

.c-img-ratio._bottom>*>img {
  object-position: 50% 100%
}

.c-img-ratio._left>*>img {
  object-position: 0 50%
}

.c-img-ratio._right>*>img {
  object-position: 100% 50%
}

.c-img-ratio._top_left>*>img {
  object-position: 0 0
}

.c-img-ratio._top_right>*>img {
  object-position: 100% 0
}

.c-img-ratio._bottom_left>*>img {
  object-position: 0 100%
}

.c-img-ratio._bottom_right>*>img {
  object-position: 100% 100%
}

.c-img-ratio+figcaption:not(.c-imgcredit), .c-imgcaption {
  color: #767676;
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  text-align: left;
  margin-top: 1em
}

@media screen and (max-width: 959px) {
  .c-img-ratio+figcaption:not(.c-imgcredit), .c-imgcaption {
    line-height: 1.9
  }
}

@media screen and (max-width: 799px) {
  .c-img-ratio+figcaption:not(.c-imgcredit), .c-imgcaption {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2;
    margin-top: .7em
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-img-ratio+figcaption:not(.c-imgcredit), .c-imgcaption {
    line-height: 1.9
  }
}

.c-svg {
  text-align: left;
  display: block;
  width: 100%
}

.c-svg>span {
  display: block;
  width: 100%;
  padding-bottom: 100%;
  margin-left: auto;
  margin-right: auto;
  position: relative
}

.c-svg>span>svg {
  width: 100%;
  height: 100%;
  position: absolute
}

.c-img-hover {
  display: block;
  overflow: hidden;
  transition: background-color 0s 1s
}

html.no-touchevents a:hover .c-img-hover, html.no-touchevents .support-movie__card:hover .c-img-hover {
  background-color: #1a1a1a;
  transition-delay: 0s
}

.c-img-hover>span {
  display: block;
  opacity: 1;
  transition: opacity 0.2s, transform 1s cubic-bezier(0.14, 0, 0, 1)
}

html.no-touchevents a:hover .c-img-hover>span, html.no-touchevents .support-movie__card:hover .c-img-hover>span {
  opacity: .7;
  transform: scale(1.1)
}

.c-banner-A, .c-banner-B {
  font-feature-settings: "palt" 1;
  letter-spacing: 1px;
  text-align: left;
  height: 135px;
  max-width: 744px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  align-items: center;
  border: 1px solid #1476c7;
  overflow: hidden;
  position: relative;
  transition: box-shadow .1s
}

@media screen and (max-width: 799px) {
  .c-banner-A, .c-banner-B {
    height: 120px
  }
}

@media screen and (max-width: 599px) {
  .c-banner-A, .c-banner-B {
    height: 90px
  }
}

.c-banner-A._sm, ._sm.c-banner-B {
  height: 80px
}

html.no-touchevents .c-banner-A:hover, html.no-touchevents .c-banner-B:hover {
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.1)
}

.c-banner-A:after, .c-banner-B:after {
  box-sizing: border-box;
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  border: 0px solid #1476c7;
  top: 0;
  left: 0;
  transition: border-width .1s
}

html.no-touchevents .c-banner-A:hover:after, html.no-touchevents .c-banner-B:hover:after {
  border-width: 1px
}

.c-banner-A>.c-svg, .c-banner-B>.c-svg {
  width: 40px;
  margin: 0 25px 0 50px;
  flex-grow: 0;
  flex-shrink: 0
}

@media screen and (max-width: 959px) {
  .c-banner-A>.c-svg, .c-banner-B>.c-svg {
    width: 30px;
    margin: 0 15px 0 20px
  }
}

@media screen and (max-width: 399px) {
  .c-banner-A>.c-svg, .c-banner-B>.c-svg {
    width: 20px;
    margin: 0 10px
  }
}

.c-banner-A._sm>.c-svg, ._sm.c-banner-B>.c-svg {
  width: 20px;
  margin: 0 10px 0 20px
}

@media screen and (max-width: 959px) {
  .c-banner-A._sm>.c-svg, ._sm.c-banner-B>.c-svg {
    margin: 0 10px
  }
}

.c-banner-A>.c-svg svg, .c-banner-B>.c-svg svg {
  fill: #1476c7
}

.c-banner-A__txt {
  width: 50%;
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  line-height: 1.8;
  flex-grow: 1;
  flex-shrink: 1;
  padding-right: 10px
}

@media screen and (max-width: 959px) {
  .c-banner-A__txt {
    line-height: 1.9
  }
}

@media screen and (max-width: 799px) {
  .c-banner-A__txt {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-banner-A__txt {
    line-height: 1.9
  }
}

.c-banner-A__txt>.c-title {
  font-size: 20px;
  font-size: 1.42857rem;
  line-height: 1.6
}

@media screen and (max-width: 959px) {
  .c-banner-A__txt>.c-title {
    line-height: 1.4
  }
}

@media screen and (max-width: 799px) {
  .c-banner-A__txt>.c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-banner-A__txt>.c-title {
    line-height: 1.4
  }
}

.c-banner-A._sm .c-banner-A__txt>.c-title, ._sm.c-banner-B .c-banner-A__txt>.c-title {
  font-size: 16px;
  font-size: 1.14286rem;
  line-height: 1.8;
  line-height: 1.4;
  letter-spacing: 0;
  margin-bottom: 0
}

@media screen and (max-width: 959px) {
  .c-banner-A._sm .c-banner-A__txt>.c-title, ._sm.c-banner-B .c-banner-A__txt>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) {
  .c-banner-A._sm .c-banner-A__txt>.c-title, ._sm.c-banner-B .c-banner-A__txt>.c-title {
    font-size: 14px;
    font-size: 1rem;
    line-height: 2
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-banner-A._sm .c-banner-A__txt>.c-title, ._sm.c-banner-B .c-banner-A__txt>.c-title {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .c-banner-A._sm .c-banner-A__txt>.c-title, ._sm.c-banner-B .c-banner-A__txt>.c-title {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-banner-A._sm .c-banner-A__txt>.c-title, ._sm.c-banner-B .c-banner-A__txt>.c-title {
    line-height: 1.9
  }
}

.c-banner-A .c-banner-A__txt>.c-title>i, .c-banner-B .c-banner-A__txt>.c-title>i {
  display: inline-block
}

.c-banner-A__txt>.c-title+* {
  margin-top: 5px
}

@media screen and (max-width: 799px) {
  .c-banner-A__txt>.c-title+* {
    margin-top: 3px
  }
}

.c-banner-A._shopping>.c-banner-A__txt, ._shopping.c-banner-B>.c-banner-A__txt {
  letter-spacing: 0
}

.c-banner-A._shopping>.c-banner-A__txt>.c-title>span, ._shopping.c-banner-B>.c-banner-A__txt>.c-title>span {
  font-size: 16px;
  font-size: 1.14286rem;
  line-height: 1.8;
  display: block;
  margin-bottom: 3px
}

@media screen and (max-width: 959px) {
  .c-banner-A._shopping>.c-banner-A__txt>.c-title>span, ._shopping.c-banner-B>.c-banner-A__txt>.c-title>span {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) {
  .c-banner-A._shopping>.c-banner-A__txt>.c-title>span, ._shopping.c-banner-B>.c-banner-A__txt>.c-title>span {
    font-size: 14px;
    font-size: 1rem;
    line-height: 2
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-banner-A._shopping>.c-banner-A__txt>.c-title>span, ._shopping.c-banner-B>.c-banner-A__txt>.c-title>span {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .c-banner-A._shopping>.c-banner-A__txt>.c-title>span, ._shopping.c-banner-B>.c-banner-A__txt>.c-title>span {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-banner-A._shopping>.c-banner-A__txt>.c-title>span, ._shopping.c-banner-B>.c-banner-A__txt>.c-title>span {
    line-height: 1.9
  }
}

.c-banner-A._shopping .c-banner-A__ys, ._shopping.c-banner-B .c-banner-A__ys {
  color: #767676;
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  font-weight: 600;
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 10
}

@media screen and (max-width: 959px) {
  .c-banner-A._shopping .c-banner-A__ys, ._shopping.c-banner-B .c-banner-A__ys {
    line-height: 1.9
  }
}

@media screen and (max-width: 799px) {
  .c-banner-A._shopping .c-banner-A__ys, ._shopping.c-banner-B .c-banner-A__ys {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-banner-A._shopping .c-banner-A__ys, ._shopping.c-banner-B .c-banner-A__ys {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .c-banner-A._shopping .c-banner-A__ys, ._shopping.c-banner-B .c-banner-A__ys {
    display: none
  }
}

@media screen and (min-width: 800px) {
  .c-banner-A._shopping .c-banner-A__ys>br, ._shopping.c-banner-B .c-banner-A__ys>br {
    display: none
  }
}

@media screen and (max-width: 599px) {
  .c-banner-A._support>.c-banner-A__txt, ._support.c-banner-B>.c-banner-A__txt {
    margin-right: 30px
  }
}

.c-banner-A._support>.c-banner-A__txt>*, ._support.c-banner-B>.c-banner-A__txt>* {
  display: inline-block
}

@media screen and (max-width: 599px) {
  .c-banner-A._support>.c-banner-A__txt>*, ._support.c-banner-B>.c-banner-A__txt>* {
    display: block
  }
}

.c-banner-A._support>.c-banner-A__txt>.c-title, ._support.c-banner-B>.c-banner-A__txt>.c-title {
  margin-right: 1em
}

.c-banner-A._support>.c-banner-A__txt>ul, ._support.c-banner-B>.c-banner-A__txt>ul {
  font-weight: 600;
  display: block;
  margin-top: 10px;
  margin-right: 60px
}

@media screen and (max-width: 799px) {
  .c-banner-A._support>.c-banner-A__txt>ul, ._support.c-banner-B>.c-banner-A__txt>ul {
    margin-top: 3px
  }
}

@media screen and (max-width: 599px) {
  .c-banner-A._support>.c-banner-A__txt>ul, ._support.c-banner-B>.c-banner-A__txt>ul {
    display: none
  }
}

.c-banner-A._support>.c-banner-A__txt>ul>li, ._support.c-banner-B>.c-banner-A__txt>ul>li {
  display: inline-block;
  padding-right: 30px;
  position: relative
}

.c-banner-A._support>.c-banner-A__txt>ul>li:after, ._support.c-banner-B>.c-banner-A__txt>ul>li:after {
  content: "";
  width: 1px;
  height: 120%;
  background-color: #1a1a1a;
  position: absolute;
  right: 15px;
  top: 50%;
  transform: translate(0, -50%)
}

.c-banner-A._support>.c-banner-A__txt>ul>li:last-child, ._support.c-banner-B>.c-banner-A__txt>ul>li:last-child {
  padding-right: 0
}

.c-banner-A._support>.c-banner-A__txt>ul>li:last-child:after, ._support.c-banner-B>.c-banner-A__txt>ul>li:last-child:after {
  content: none
}

.c-banner-A__img {
  width: 240px;
  height: 100%;
  margin-right: 120px;
  flex-grow: 0;
  flex-shrink: 0
}

@media screen and (max-width: 799px) {
  .c-banner-A__img {
    width: 180px;
    margin-right: 40px
  }
}

@media screen and (max-width: 599px) {
  .c-banner-A__img {
    width: 120px !important;
    margin-right: 0 !important
  }
}

.c-banner-A._sm>.c-banner-A__img, ._sm.c-banner-B>.c-banner-A__img {
  width: 40%;
  height: auto;
  max-height: 80px;
  margin-right: 40px;
  align-self: flex-end
}

@media screen and (max-width: 799px) {
  .c-banner-A._sm>.c-banner-A__img, ._sm.c-banner-B>.c-banner-A__img {
    width: 35%;
    margin-right: 30px
  }
}

.c-banner-A._shopping>.c-banner-A__img, ._shopping.c-banner-B>.c-banner-A__img {
  margin-right: 140px
}

@media screen and (max-width: 799px) {
  .c-banner-A._shopping>.c-banner-A__img, ._shopping.c-banner-B>.c-banner-A__img {
    width: 180px !important
  }
}

@media screen and (max-width: 399px) {
  .c-banner-A._shopping>.c-banner-A__img, ._shopping.c-banner-B>.c-banner-A__img {
    width: 120px !important
  }
}

.c-banner-A._yahoo>.c-svg, ._yahoo.c-banner-B>.c-svg {
  width: 100px;
  margin: 0 25px 0 30px
}

@media screen and (max-width: 599px) {
  .c-banner-A._yahoo>.c-svg, ._yahoo.c-banner-B>.c-svg {
    margin-left: 20px
  }
}

@media screen and (max-width: 399px) {
  .c-banner-A._yahoo>.c-svg, ._yahoo.c-banner-B>.c-svg {
    width: 70px;
    margin: 0 15px 0 10px
  }
}

.c-banner-A._yahoo>.c-banner-A__txt, ._yahoo.c-banner-B>.c-banner-A__txt {
  width: 100%
}

.c-banner-A._yahoo>.c-banner-A__txt>.c-title, ._yahoo.c-banner-B>.c-banner-A__txt>.c-title {
  letter-spacing: 0;
  white-space: nowrap
}

@media screen and (max-width: 599px) {
  .c-banner-A._yahoo>.c-banner-A__txt, ._yahoo.c-banner-B>.c-banner-A__txt {
    padding-right: 40px
  }
}

.c-banner-A._yahoo>.c-banner-A__img, ._yahoo.c-banner-B>.c-banner-A__img {
  width: 150px;
  margin-right: 80px
}

@media screen and (max-width: 799px) {
  .c-banner-A._yahoo>.c-banner-A__img, ._yahoo.c-banner-B>.c-banner-A__img {
    margin-right: 40px
  }
}

@media screen and (max-width: 599px) {
  .c-banner-A._yahoo>.c-banner-A__img, ._yahoo.c-banner-B>.c-banner-A__img {
    display: none
  }
}

@media screen and (max-width: 799px) {
  .c-banner-B {
    height: 125px
  }
}

.c-banner-B__img {
  flex-shrink: 0;
  width: 200px;
  height: 100%;
  margin-right: 40px
}

@media screen and (max-width: 959px) {
  .c-banner-B__img {
    margin-right: 30px
  }
}

@media screen and (max-width: 799px) {
  .c-banner-B__img {
    margin-right: 20px
  }
}

.c-banner-B__txt {
  font-size: 13px;
  font-size: .92857rem;
  line-height: 1.8;
  flex-grow: 1;
  padding-right: 60px
}

@media screen and (max-width: 959px) {
  .c-banner-B__txt {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .c-banner-B__txt {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 1.8;
    padding-right: 30px
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-banner-B__txt {
    line-height: 1.6
  }
}

.c-banner-B__txt>.c-title {
  font-size: 20px;
  font-size: 1.42857rem;
  line-height: 1.6;
  margin-bottom: 5px
}

@media screen and (max-width: 959px) {
  .c-banner-B__txt>.c-title {
    line-height: 1.4
  }
}

@media screen and (max-width: 599px) {
  .c-banner-B__txt>.c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-banner-B__txt>.c-title {
    line-height: 1.4
  }
}

@media screen and (max-width: 599px) {
  .c-banner-D {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-banner-D {
    line-height: 1.9
  }
}

.c-banner-D .c-title {
  margin-bottom: 20px
}

@media screen and (max-width: 799px) {
  .c-banner-D .c-title {
    margin-bottom: 15px
  }
}

@media screen and (max-width: 599px) {
  .c-banner-D .c-title {
    margin-bottom: 10px
  }
}

.c-banner-D__btn {
  text-align: right
}

.c-card-A {
  display: block;
  background-color: #fff;
  padding: 25px;
  height: 100%
}

@media screen and (max-width: 959px) {
  .c-card-A {
    padding: 20px
  }
}

@media screen and (max-width: 799px) {
  .c-card-A {
    padding: 15px
  }
}

.c-card-A>figure {
  margin: -25px -25px 25px
}

@media screen and (max-width: 959px) {
  .c-card-A>figure {
    margin: -20px -20px 20px
  }
}

@media screen and (max-width: 799px) {
  .c-card-A>figure {
    margin: -15px -15px 15px
  }
}

.c-card-A>.c-title {
  font-size: 16px;
  font-size: 1.14286rem;
  line-height: 1.8
}

@media screen and (max-width: 959px) {
  .c-card-A>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) {
  .c-card-A>.c-title {
    font-size: 14px;
    font-size: 1rem;
    line-height: 2;
    line-height: 1.6 !important
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-card-A>.c-title {
    line-height: 1.9
  }
}

.c-card-A>.c-title+p {
  color: #767676;
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  margin-top: 1em
}

@media screen and (max-width: 959px) {
  .c-card-A>.c-title+p {
    line-height: 1.9
  }
}

@media screen and (max-width: 799px) {
  .c-card-A>.c-title+p {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2;
    margin-top: .5em !important
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-card-A>.c-title+p {
    line-height: 1.9
  }
}

.c-card-A>.c-linkset-A {
  margin-top: .5em
}

.c-card-B {
  display: flex;
  align-items: center;
  background-color: #fff;
  height: 100%
}

.c-card-B>figure {
  width: 40%;
  min-width: 120px;
  max-width: 150px;
  height: 100%
}

.c-card-B .c-img-ratio {
  padding-bottom: 0;
  height: 100%;
  min-height: 150px
}

@media screen and (max-width: 959px) {
  .c-card-B .c-img-ratio {
    min-height: 120px
  }
}

.c-card-B>div {
  flex-grow: 1;
  text-align: left;
  width: 60%;
  padding: 1.5em calc(4vw + 10px) 1.5em 20px
}

@media screen and (max-width: 959px) {
  .c-card-B>div {
    padding-right: 40px
  }
}

.c-card-B>div>.c-text-sm {
  line-height: 1.8
}

.c-card-B>div>.c-title {
  font-size: 16px;
  font-size: 1.14286rem;
  line-height: 1.8;
  line-height: 1.6;
  margin-right: -3.5vw;
  margin-bottom: .3em
}

@media screen and (max-width: 959px) {
  .c-card-B>div>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) {
  .c-card-B>div>.c-title {
    margin-right: -20px
  }
}

@media screen and (max-width: 799px) {
  .c-card-B>div>.c-title {
    font-size: 14px;
    font-size: 1rem;
    line-height: 2;
    line-height: 1.6 !important
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-card-B>div>.c-title {
    line-height: 1.9
  }
}

.c-card-C {
  height: 100%;
  padding: 3vw;
  background-color: #f5f5f5
}

@media screen and (min-width: 1800px) {
  .c-card-C {
    padding: 54px
  }
}

@media screen and (max-width: 599px) {
  .c-card-C {
    padding: 15px
  }
}

.c-card-C__num {
  font-weight: 600;
  line-height: 28px;
  text-align: center;
  display: block;
  width: 30px;
  height: 30px;
  border-radius: 100%;
  background-color: transparent;
  border: 1px solid #1a1a1a;
  margin: 0 auto 1.5em
}

@media screen and (max-width: 799px) {
  .c-card-C__num {
    margin-bottom: 15px
  }
}

@media screen and (max-width: 599px) {
  .c-card-C__num {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 25px;
    width: 26px;
    height: 26px;
    border-radius: 100%;
    background-color: transparent;
    margin-bottom: 10px
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-card-C__num {
    line-height: 24.9px
  }
}

.c-card-C>.c-title {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.6;
  text-align: center;
  margin-bottom: .5em
}

@media screen and (max-width: 959px) {
  .c-card-C>.c-title {
    line-height: 1.4
  }
}

@media screen and (max-width: 799px) {
  .c-card-C>.c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.7
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-card-C>.c-title {
    line-height: 1.5
  }
}

@media screen and (max-width: 599px) {
  .c-card-C>.c-title {
    font-size: 15px;
    font-size: 1.07143rem;
    line-height: 1.7
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-card-C>.c-title {
    line-height: 1.5
  }
}

.c-column-sub__pulldown-trigger {
  display: block;
  margin: -1vw auto 0
}

@media screen and (min-width: 960px) {
  .c-column-sub__pulldown-trigger {
    display: none
  }
}

.c-column-sub__pulldown-outer {
  overflow: hidden;
  height: 0;
  transition: height .3s
}

@media screen and (min-width: 960px) {
  .c-column-sub__pulldown-outer {
    height: auto !important
  }
}

.c-column-sub__pulldown-trigger._open+.c-column-sub__pulldown-outer {
  transition-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955)
}

@media screen and (max-width: 959px) {
  .c-column-sub__pulldown {
    padding-top: 1px;
    position: relative
  }
}

.c-column-sub__pulldown:before {
  content: "";
  border: 15px solid transparent;
  border-bottom: 20px solid #f5f5f5;
  position: absolute;
  top: -8px;
  left: 50%;
  margin-left: -15px
}

@media screen and (min-width: 960px) {
  .c-column-sub__pulldown:before {
    content: none
  }
}

@media screen and (max-width: 959px) {
  .c-column-sub__pulldown-inner {
    margin-top: 25px;
    overflow: hidden
  }
}

.c-contactbox {
  margin-top: 7vw
}

@media screen and (min-width: 1800px) {
  .c-contactbox {
    margin-top: 126px
  }
}

@media screen and (max-width: 399px) {
  .c-contactbox {
    margin-top: 28px
  }
}

@media screen and (max-width: 399px) {
  .c-contactbox {
    margin-top: 36px
  }
}

@media screen and (max-width: 599px) {
  .c-contactbox {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-contactbox {
    line-height: 1.9
  }
}

.c-contactbox>.c-title {
  text-align: center;
  margin-bottom: 3vw
}

@media screen and (min-width: 1800px) {
  .c-contactbox>.c-title {
    margin-bottom: 54px
  }
}

@media screen and (max-width: 399px) {
  .c-contactbox>.c-title {
    margin-bottom: 12px
  }
}

.c-contactbox__btn {
  text-align: right
}

@media screen and (max-width: 599px) {
  .c-contactbox__btn {
    text-align: center
  }
}

.c-contactbox__banner {
  margin-top: 5vw
}

@media screen and (min-width: 1800px) {
  .c-contactbox__banner {
    margin-top: 90px
  }
}

@media screen and (max-width: 399px) {
  .c-contactbox__banner {
    margin-top: 20px
  }
}

@media screen and (min-width: 1200px) {
  .c-contactbox__banner {
    margin-left: 3vw;
    margin-right: 3vw
  }
}

@media screen and (min-width: 1800px) {
  .c-contactbox__banner {
    margin-left: 54px;
    margin-right: 54px
  }
}

@media screen and (max-width: 399px) {
  .c-contactbox__banner {
    margin-top: 24px
  }
}

.c-contactbox .c-card-B .c-title {
  font-size: 20px;
  font-size: 1.42857rem;
  line-height: 1.8
}

@media screen and (max-width: 959px) {
  .c-contactbox .c-card-B .c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 1199px) {
  .c-contactbox .c-card-B .c-title {
    font-size: 18px;
    font-size: 1.28571rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 1199px) and (max-width: 959px) {
  .c-contactbox .c-card-B .c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) {
  .c-contactbox .c-card-B .c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-contactbox .c-card-B .c-title {
    line-height: 1.6
  }
}

.c-dlist-A {
  text-align: left;
  position: relative
}

.c-dlist-A>dt {
  color: #767676;
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  width: 17%;
  padding: 15px 0 11px 10px;
  position: absolute
}

@media screen and (max-width: 959px) {
  .c-dlist-A>dt {
    line-height: 1.9
  }
}

@media screen and (max-width: 799px) {
  .c-dlist-A>dt {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2;
    letter-spacing: 0
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-dlist-A>dt {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .c-dlist-A>dt {
    width: 7em;
    padding-left: 0
  }
}

@media screen and (max-width: 399px) {
  .c-dlist-A._xxs-column>dt {
    width: auto !important;
    padding: 9px 0 0;
    position: relative
  }
}

@media screen and (max-width: 599px) {
  .c-dlist-A>dt:first-child {
    border-top: 1px solid #d4d4d4
  }
}

.c-dlist-A>dd {
  font-weight: 600;
  padding: 13px 0 11px 20%;
  border-top: 1px solid #d4d4d4
}

.c-dlist-A>dd:last-child {
  border-bottom: 1px solid #d4d4d4
}

@media screen and (max-width: 599px) {
  .c-dlist-A>dd {
    padding-left: 7em
  }
}

@media screen and (max-width: 399px) {
  .c-dlist-A._xxs-column>dd {
    padding: 0 0 7px !important;
    border-top: none;
    border-bottom: 1px solid #d4d4d4
  }
}

@media screen and (max-width: 599px) {
  .c-dlist-A>dt._double>span {
    display: block
  }
  .c-dlist-A>dt._double+dd {
    min-height: 5em
  }
}

@media screen and (max-width: 399px) {
  .c-dlist-A>dt._double>span {
    display: inline
  }
  .c-dlist-A>dt._double+dd {
    min-height: 0
  }
}

.c-dlist-A>dd._narrow {
  position: relative
}

@media screen and (max-width: 399px) {
  .c-dlist-A>dd._narrow {
    padding-top: 7px !important
  }
}

.c-dlist-A>dd._narrow:before {
  content: "";
  width: 20%;
  height: 3px;
  background-color: #fff;
  position: absolute;
  top: -2px;
  left: 0
}

.l-line._gray .c-dlist-A>dd._narrow:before {
  background-color: #f5f5f5
}

@media screen and (max-width: 599px) {
  .c-dlist-A>dd._narrow:before {
    width: 7em
  }
}

@media screen and (max-width: 399px) {
  .c-dlist-A>dd._narrow:before {
    content: none
  }
}

.c-hero-A {
  font-weight: 600;
  padding: 0;
  margin: 0;
  position: relative;
  display: flex
}

.c-hero-A._center {
  align-items: center
}

.c-hero-A:before {
  content: "";
  width: 0;
  height: 42vw
}

@media screen and (min-width: 1800px) {
  .c-hero-A:before {
    height: 756px
  }
}

@media screen and (max-width: 799px) {
  .c-hero-A:before {
    height: 60vw
  }
}

.c-hero-A._xs:before {
  height: 33vw
}

@media screen and (min-width: 1800px) {
  .c-hero-A._xs:before {
    height: 594px
  }
}

@media screen and (max-width: 799px) {
  .c-hero-A._xs:before {
    height: 50vw
  }
}

.c-hero-A._sm:before {
  height: 39vw
}

@media screen and (min-width: 1800px) {
  .c-hero-A._sm:before {
    height: 702px
  }
}

@media screen and (max-width: 799px) {
  .c-hero-A._sm:before {
    height: 50vw
  }
}

.c-hero-A._lg:before {
  height: 55vw
}

@media screen and (min-width: 1800px) {
  .c-hero-A._lg:before {
    height: 990px
  }
}

@media screen and (max-width: 799px) {
  .c-hero-A._lg:before {
    height: 70vw
  }
}

@media screen and (max-width: 599px) {
  .c-hero-A._lg:before {
    height: 100vw
  }
}

.c-hero-A>.l-container {
  width: 100%;
  max-width: none;
  position: relative;
  z-index: 1
}

.c-hero-A .c-hero__txt {
  width: 50%;
  padding-right: 5.3vw;
  text-shadow: 0 1px 2px rgba(255, 255, 255, 0.5), 0 -1px 2px rgba(255, 255, 255, 0.5)
}

.c-hero-A .c-hero__txt._flip {
  margin-left: auto;
  padding-right: 0;
  padding-left: 5.3vw
}

@media screen and (min-width: 1800px) {
  .c-hero-A .c-hero__txt {
    padding-right: 95.4px
  }
}

@media screen and (max-width: 799px) {
  .c-hero-A .c-hero__txt {
    width: 60%
  }
}

@media screen and (max-width: 599px) {
  .c-hero-A .c-hero__txt {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-hero-A .c-hero__txt {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .c-hero-A .c-hero__txt {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-hero-A .c-hero__txt {
    line-height: 1.9
  }
}

.c-hero-A .c-hero__txt._tclw {
  color: #fff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2), 0 -1px 2px rgba(0, 0, 0, 0.2)
}

@media screen and (max-width: 599px) {
  .c-hero-A:not(._center) .c-hero__txt>.c-title {
    margin-right: -50%
  }
}

@media screen and (max-width: 599px) {
  .c-hero-A:not(._center) .c-hero__txt._flip>.c-title {
    margin-right: 0
  }
}

.c-hero-A._center .c-hero__txt {
  width: 100%;
  padding-right: 0;
  text-align: center
}

.c-hero-A._center .c-hero__txt>.c-title {
  font-size: 60px;
  font-size: 4.28571rem;
  line-height: 1.4;
  text-align: center
}

@media screen and (max-width: 959px) {
  .c-hero-A._center .c-hero__txt>.c-title {
    line-height: 1.2
  }
}

@media screen and (max-width: 959px) {
  .c-hero-A._center .c-hero__txt>.c-title {
    font-size: 50px;
    font-size: 3.57143rem;
    line-height: 1.4
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .c-hero-A._center .c-hero__txt>.c-title {
    line-height: 1.2
  }
}

@media screen and (max-width: 799px) {
  .c-hero-A._center .c-hero__txt>.c-title {
    font-size: 42px;
    font-size: 3rem;
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-hero-A._center .c-hero__txt>.c-title {
    line-height: 1.4
  }
}

@media screen and (max-width: 599px) {
  .c-hero-A._center .c-hero__txt>.c-title {
    font-size: 35px;
    font-size: 2.5rem;
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-hero-A._center .c-hero__txt>.c-title {
    line-height: 1.4
  }
}

@media screen and (max-width: 399px) {
  .c-hero-A._center .c-hero__txt>.c-title {
    font-size: 30px;
    font-size: 2.14286rem;
    line-height: 1.6
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .c-hero-A._center .c-hero__txt>.c-title {
    line-height: 1.4
  }
}

.c-hero-A._center .c-hero__txt>.c-title>span {
  display: inline-block
}

.c-hero-A>.c-hero__img, .c-hero-A>.c-hero__img>.c-hero__img-item {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0
}

.c-hero-B {
  display: flex;
  background-color: #dcedec
}

@media screen and (max-width: 599px) {
  .c-hero-B {
    display: block;
    padding: 1px 0;
    margin: -1px 0
  }
}

.c-hero-B>.c-hero__txt {
  width: 50%;
  padding-right: 5.3vw
}

@media screen and (min-width: 1800px) {
  .c-hero-B>.c-hero__txt {
    padding-right: 95.4px
  }
}

@media screen and (max-width: 599px) {
  .c-hero-B>.c-hero__txt {
    width: 100%
  }
}

.c-hero-B._flip>.c-hero__txt {
  padding-left: 5.3vw
}

@media screen and (min-width: 1800px) {
  .c-hero-B._flip>.c-hero__txt {
    padding-left: 95.4px
  }
}

@media screen and (max-width: 599px) {
  .c-hero-B>.c-hero__txt>.c-title {
    text-align: center;
    margin-bottom: .7em
  }
}

.c-hero-B>.c-hero__img {
  width: 50%;
  padding-bottom: 42%;
  position: relative;
  align-self: stretch
}

@media screen and (min-width: 1800px) {
  .c-hero-B>.c-hero__img {
    padding-bottom: 756px
  }
}

@media screen and (max-width: 599px) {
  .c-hero-B>.c-hero__img {
    width: 100%;
    padding-bottom: 60% !important
  }
}

.c-hero-B._sm>.c-hero__img {
  padding-bottom: 39%
}

@media screen and (min-width: 1800px) {
  .c-hero-B._sm>.c-hero__img {
    padding-bottom: 702px
  }
}

.c-hero-B>.c-hero__img>.c-img-ratio {
  position: absolute
}

.c-hero-C {
  display: flex;
  align-items: center
}

.c-hero-C._flip {
  flex-direction: row-reverse
}

.c-hero-C._gray {
  background-color: #f5f5f5
}

@media screen and (max-width: 599px) {
  .c-hero-C._gray {
    padding-bottom: 9vw
  }
  .c-hero-C._gray:before {
    content: none
  }
}

@media screen and (max-width: 399px) {
  .c-hero-C._gray {
    padding-bottom: 36px
  }
}

@media screen and (max-width: 599px) {
  .c-hero-C {
    padding: 9vw 6vw 0;
    margin: 9vw 0;
    position: relative;
    flex-direction: row-reverse
  }
  .c-hero-C:before {
    content: "";
    width: 88vw;
    height: 1px;
    background-color: #d4d4d4;
    position: absolute;
    top: 0;
    left: 6vw
  }
}

@media screen and (max-width: 399px) {
  .c-hero-C {
    padding: 36px 25px 0;
    margin: 36px 0
  }
  .c-hero-C:before {
    width: calc(100% - 50px);
    left: 25px
  }
}

.c-hero-C>.c-hero__img {
  width: 50%;
  padding-bottom: 42%;
  position: relative;
  align-self: stretch
}

@media screen and (min-width: 1800px) {
  .c-hero-C>.c-hero__img {
    padding-bottom: 756px
  }
}

@media screen and (max-width: 599px) {
  .c-hero-C>.c-hero__img {
    width: 35%;
    padding-bottom: 35%;
    margin-left: 5%;
    align-self: flex-start;
    flex-shrink: 0
  }
}

@media screen and (max-width: 399px) {
  .c-hero-C>.c-hero__img {
    margin-left: 15px
  }
}

.c-hero-C>.c-hero__img>.c-img-ratio {
  position: absolute
}

.c-hero-C>.c-hero__txt {
  width: 50%
}

@media screen and (max-width: 599px) {
  .c-hero-C>.c-hero__txt {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2;
    width: 60%;
    margin: -.7em 0 0;
    padding: 0 !important
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-hero-C>.c-hero__txt {
    line-height: 1.9
  }
}

.c-hero-C:not(._flip)>.c-hero__txt {
  padding-left: 5.3vw
}

@media screen and (min-width: 1800px) {
  .c-hero-C:not(._flip)>.c-hero__txt {
    padding-left: 95.4px
  }
}

.c-hero-C._flip>.c-hero__txt {
  padding-right: 5.3vw
}

@media screen and (min-width: 1800px) {
  .c-hero-C._flip>.c-hero__txt {
    padding-right: 95.4px
  }
}

.c-hoverpanel {
  transition: box-shadow .1s
}

html.no-touchevents .c-hoverpanel:hover {
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.15)
}

.c-imgcredit__parent {
  position: relative
}

.c-imgcredit {
  color: #fff;
  font-size: 11px;
  font-size: .78571rem;
  line-height: 1.5;
  font-weight: 400;
  letter-spacing: 0;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5), 0 -1px 2px rgba(0, 0, 0, 0.3);
  position: absolute;
  width: calc(100% - 30px);
  left: 15px;
  bottom: 10px
}

@media screen and (max-width: 959px) {
  .c-imgcredit {
    line-height: 1.3
  }
}

@media screen and (max-width: 799px) {
  .c-imgcredit {
    font-size: 10px;
    font-size: .71429rem;
    line-height: 1.5
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-imgcredit {
    line-height: 1.3
  }
}

.c-island-A, .c-banner-D {
  background-color: #fff;
  border: 1px solid #fff;
  padding: 3vw 4.5vw
}

.c-island-A._border, .c-banner-D {
  border: 1px solid #1476c7
}

@media screen and (min-width: 1800px) {
  .c-island-A, .c-banner-D {
    padding: 54px 81px
  }
}

@media screen and (max-width: 599px) {
  .c-island-A, .c-banner-D {
    padding: 25px 20px
  }
}

.c-list-A>li {
  padding-left: 1.5rem;
  position: relative
}

@media screen and (max-width: 959px) {
  .c-list-A>li {
    padding-left: 1.2rem
  }
}

.c-list-A._sm>li {
  color: #767676;
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2
}

@media screen and (max-width: 959px) {
  .c-list-A._sm>li {
    line-height: 1.9
  }
}

@media screen and (max-width: 799px) {
  .c-list-A._sm>li {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-list-A._sm>li {
    line-height: 1.9
  }
}

.c-list-A>li+li {
  margin-top: .5em
}

@media screen and (max-width: 959px) {
  .c-list-A>li+li {
    margin-top: .3em
  }
}

.c-list-A>li:before {
  content: "";
  width: 5px;
  height: 5px;
  background-color: #1476c7;
  position: absolute;
  top: .8em;
  left: .3em
}

@media screen and (max-width: 799px) {
  .c-list-A>li:before {
    top: .65em
  }
}

.c-movie-A {
  display: block;
  width: 100%;
  max-width: 600px
}

.c-movie-A>span {
  display: block;
  width: 100%;
  height: 0;
  padding-bottom: 56.25%;
  max-height: 300px;
  position: relative
}

.c-movie-A>span>iframe {
  position: absolute;
  width: 100%;
  height: 100%
}

.c-pagefooter-A {
  text-align: center
}

@media screen and (max-width: 599px) {
  .c-pagefooter-A {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-pagefooter-A {
    line-height: 1.9
  }
}

.c-pagefooter-A>*:last-child {
  margin-top: 2em
}

@media screen and (max-width: 599px) {
  .c-pagefooter-A>*:last-child {
    margin-top: 1.5em
  }
}

.c-pagination__outer {
  text-align: center;
  position: relative;
  margin-bottom: -2em
}

.c-pagination__outer:before {
  content: "";
  width: 100%;
  height: 1px;
  background-color: #d4d4d4;
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0
}

@media screen and (max-width: 599px) {
  .c-pagination__outer:before {
    margin-top: .5em
  }
}

.c-pagination {
  padding: 3em 0;
  position: relative
}

@media screen and (max-width: 599px) {
  .c-pagination {
    padding-top: 4em
  }
}

.c-pagination__inner {
  display: inline-block;
  background-color: #fff
}

.c-pagination__inner>.num {
  font-size: 14px;
  font-size: 1rem;
  line-height: 48px;
  font-weight: 600;
  width: 50px;
  height: 50px;
  display: inline-block;
  vertical-align: middle;
  margin-right: -1px;
  background-color: #fff;
  border: 1px solid #d4d4d4;
  transition: all .1s
}

@media screen and (max-width: 959px) {
  .c-pagination__inner>.num {
    line-height: 47.9px
  }
}

@media screen and (max-width: 799px) {
  .c-pagination__inner>.num {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 40px;
    width: 42px;
    height: 42px
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-pagination__inner>.num {
    line-height: 39.9px
  }
}

@media screen and (max-width: 399px) {
  .c-pagination__inner>.num {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 32px;
    width: 34px;
    height: 34px
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .c-pagination__inner>.num {
    line-height: 31.9px
  }
}

html.no-touchevents .c-pagination__inner>a.num:hover {
  color: #fff;
  background-color: #1476c7
}

.c-pagination__inner>strong.num {
  background-color: #f5f5f5
}

.c-pagination__inner>i {
  display: inline-block;
  margin: 0 1vw
}

.c-pagination__inner>.c-linktxt-A {
  font-size: 15px;
  font-size: 1.07143rem;
  line-height: 2;
  position: absolute;
  right: 0;
  top: 0
}

@media screen and (max-width: 959px) {
  .c-pagination__inner>.c-linktxt-A {
    line-height: 1.9
  }
}

@media screen and (max-width: 799px) {
  .c-pagination__inner>.c-linktxt-A {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 2
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-pagination__inner>.c-linktxt-A {
    line-height: 1.9
  }
}

.c-pagination__inner>.c-linktxt-A:first-child {
  left: 0;
  right: auto
}

.c-pagination__inner>.c-linktxt-A:last-child {
  padding-left: 0;
  padding-right: 15px
}

.c-pagination__inner>.c-linktxt-A:last-child:before {
  content: none
}

.c-pagination__inner>.c-linktxt-A:last-child:after {
  content: "";
  width: 6px;
  height: 6px;
  border: 3px #1476c7;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
  position: absolute;
  top: 50%;
  right: -7px;
  margin-top: -5px
}

.c-pagination__inner>.c-linktxt-A:first-child:before {
  width: 6px;
  height: 6px;
  border: 3px #1476c7;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(-135deg)
}

@media screen and (max-width: 799px) {
  .c-pagination__inner>.c-linktxt-A:first-child:before {
    margin-top: -5px
  }
}

.c-pagenav-A {
  max-width: 1600px
}

.c-pagenav-A>h2 {
  text-align: center;
  padding: 10px 0;
  background-color: #f5f5f5;
  margin-bottom: 3vw
}

@media screen and (min-width: 1800px) {
  .c-pagenav-A>h2 {
    margin-bottom: 54px
  }
}

@media screen and (max-width: 399px) {
  .c-pagenav-A>h2 {
    margin-bottom: 12px
  }
}

@media screen and (max-width: 599px) {
  .c-pagenav-A>h2 {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2;
    padding: 7px 0
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-pagenav-A>h2 {
    line-height: 1.9
  }
}

@media screen and (max-width: 399px) {
  .c-pagenav-A>h2 {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .c-pagenav-A>h2 {
    line-height: 1.9
  }
}

.c-pagenav-A__nav {
  margin-bottom: 5vw
}

@media screen and (min-width: 1800px) {
  .c-pagenav-A__nav {
    margin-bottom: 90px
  }
}

@media screen and (max-width: 399px) {
  .c-pagenav-A__nav {
    margin-bottom: 20px
  }
}

@media screen and (max-width: 399px) {
  .c-pagenav-A__nav {
    margin-bottom: 30px
  }
}

@media screen and (max-width: 599px) {
  .c-pagenav-A__nav a {
    border-top: none
  }
}

.c-productslist-A+.c-productslist-A {
  margin-top: 5vw
}

@media screen and (min-width: 1800px) {
  .c-productslist-A+.c-productslist-A {
    margin-top: 90px
  }
}

@media screen and (max-width: 399px) {
  .c-productslist-A+.c-productslist-A {
    margin-top: 20px
  }
}

@media screen and (max-width: 599px) {
  .c-productslist-A+.c-productslist-A {
    margin-top: 6vw
  }
}

@media screen and (max-width: 599px) and (min-width: 1800px) {
  .c-productslist-A+.c-productslist-A {
    margin-top: 108px
  }
}

@media screen and (max-width: 599px) and (max-width: 399px) {
  .c-productslist-A+.c-productslist-A {
    margin-top: 24px
  }
}

@media screen and (max-width: 599px) {
  .c-productslist-A .l-grid-1of2 {
    width: 100% !important
  }
}

.c-productslist-A .l-grid-1of2:first-child {
  width: 40%;
  max-width: 500px
}

@media screen and (max-width: 959px) {
  .c-productslist-A .l-grid-1of2:first-child {
    width: 35%;
    max-width: none
  }
}

.c-productslist-A .l-grid-1of2:last-child {
  width: 60%;
  flex-grow: 1
}

@media screen and (max-width: 599px) {
  .c-productslist-A .l-grid-1of2:last-child {
    margin-top: -10px
  }
}

.c-productslist-A__img {
  display: flex;
  margin-top: 20px
}

.c-productslist-A__img>* {
  width: 50%
}

.c-productslist-A .c-dlist-A>dt {
  font-size: 12px;
  font-size: .85714rem;
  line-height: 2;
  width: 7em
}

@media screen and (max-width: 959px) {
  .c-productslist-A .c-dlist-A>dt {
    line-height: 1.9
  }
}

.c-productslist-A .c-dlist-A>dt:first-child {
  border-top: none
}

@media screen and (max-width: 599px) {
  .c-productslist-A .c-dlist-A>dt {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-productslist-A .c-dlist-A>dt {
    line-height: 1.9
  }
}

@media screen and (max-width: 399px) {
  .c-productslist-A .c-dlist-A>dt {
    width: 6em
  }
}

.c-productslist-A .c-dlist-A>dd {
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  padding-left: 7em
}

@media screen and (max-width: 959px) {
  .c-productslist-A .c-dlist-A>dd {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .c-productslist-A .c-dlist-A>dd {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-productslist-A .c-dlist-A>dd {
    line-height: 1.9
  }
}

@media screen and (max-width: 399px) {
  .c-productslist-A .c-dlist-A>dd {
    padding-left: 6em
  }
}

.c-productslist-A .c-dlist-A>dd:first-of-type {
  border-top: none
}

.c-productslist-A .c-text-sm {
  margin-top: 1.5em
}

@media screen and (max-width: 599px) {
  .c-productslist-A .c-text-sm {
    margin-top: 1.2em
  }
}

.c-productslist-B {
  display: flex
}

.c-productslist-B>figure {
  width: 100px;
  margin-right: 20px;
  flex-shrink: 0
}

@media screen and (max-width: 599px) {
  .c-productslist-B>figure {
    width: 90px
  }
}

@media screen and (max-width: 399px) {
  .c-productslist-B>figure {
    width: 70px;
    margin-right: 15px
  }
}

.c-productslist-B>div {
  width: 100%;
  flex-shrink: 1
}

.c-productslist-B>div>p {
  text-align: left;
  padding: 11px 10px;
  border-bottom: 1px solid #d4d4d4
}

.c-productslist-B>div>p:first-child {
  padding: 0;
  border: none
}

.c-productslist-C {
  display: flex
}

.c-productslist-C__img {
  width: 100px;
  flex-shrink: 0
}

@media screen and (max-width: 599px) {
  .c-productslist-C__img {
    width: 80px
  }
}

@media screen and (max-width: 399px) {
  .c-productslist-C__img {
    width: 70px
  }
}

.c-productslist-C__txt {
  width: 100%;
  flex-shrink: 1;
  margin-left: 20px
}

@media screen and (max-width: 399px) {
  .c-productslist-C__txt {
    margin-left: 15px
  }
}

.c-productslist-C__txt>.c-title {
  font-size: 14px;
  font-size: 1rem;
  line-height: 2;
  border: 1px #d4d4d4;
  border-style: solid none;
  padding: 13px 10px 11px
}

@media screen and (max-width: 959px) {
  .c-productslist-C__txt>.c-title {
    line-height: 1.9
  }
}

.c-productslist-C__txt>.c-text-sm {
  padding: 10px 10px 0
}

.c-productslist-C__txt>div {
  text-align: right;
  margin-top: 25px
}

@media screen and (max-width: 799px) {
  .c-productslist-C__txt>div {
    margin-top: 15px
  }
}

.c-productslist-C__txt>.c-text-sm+div {
  margin-top: 15px
}

@media screen and (max-width: 599px) {
  .c-productslist-C__txt>.c-text-sm+div {
    margin-top: 10px
  }
}

@media screen and (min-width: 800px) {
  .c-productslist-C__txt .c-button-A, .c-productslist-C__txt .c-button-B {
    min-width: 160px;
    line-height: 48px;
    height: 50px
  }
}

.c-productslist-C__btnset {
  line-height: 0;
  padding-left: 1px;
  margin: 20px 0
}

.c-productslist-C__btnset>li {
  display: inline-block;
  margin: 0 0 -1px -1px
}

@media screen and (max-width: 599px) {
  .c-productslist-C__btnset .c-button-A, .c-productslist-C__btnset .c-button-B {
    min-width: 120px
  }
}

.c-productslist-D__item {
  display: flex;
  align-items: stretch;
  flex-direction: row-reverse;
  padding-top: 10px;
  border-top: 1px solid #d4d4d4
}

@media screen and (max-width: 599px) {
  .c-productslist-D__item {
    display: block
  }
}

.c-productslist-D__item>._body {
  width: 100%;
  flex-grow: 1;
  flex-shrink: 1
}

.c-productslist-D__item>._body>h3 {
  margin-top: -10px
}

.c-productslist-D__item>._body>h3>.c-linktxt-B {
  border-top: none
}

.c-productslist-D__item>._body>._img-sub {
  width: 100%;
  max-width: 500px;
  margin: 5% auto 0
}

@media screen and (max-width: 599px) {
  .c-productslist-D__item>._body>._img-sub {
    max-width: 350px;
    margin: 20px auto
  }
}

.c-productslist-D__item>._img-main {
  width: 47%;
  min-width: 120px;
  margin-right: 5.6%;
  flex-shrink: 0
}

@media screen and (min-width: 1500px) {
  .c-productslist-D__item>._img-main {
    width: 52%
  }
}

@media screen and (max-width: 959px) {
  .c-productslist-D__item>._img-main {
    min-width: 100px
  }
}

@media screen and (max-width: 599px) {
  .c-productslist-D__item>._img-main {
    width: 100%;
    max-width: 350px;
    margin: 0 auto
  }
}

.c-productslist-D__item>._img-main>span {
  display: block;
  padding-bottom: 15px
}

.c-productslist-D__item+.c-productslist-D__item {
  margin-top: 5vw
}

@media screen and (min-width: 1800px) {
  .c-productslist-D__item+.c-productslist-D__item {
    margin-top: 90px
  }
}

@media screen and (max-width: 399px) {
  .c-productslist-D__item+.c-productslist-D__item {
    margin-top: 20px
  }
}

.c-pulldown-A__outer {
  height: 0;
  overflow: hidden;
  transition: height .3s
}

@media screen and (max-width: 1199px) {
  .c-pulldown-A__outer {
    margin-bottom: 4vw
  }
}

@media screen and (max-width: 1199px) and (min-width: 1800px) {
  .c-pulldown-A__outer {
    margin-bottom: 72px
  }
}

@media screen and (max-width: 1199px) and (max-width: 399px) {
  .c-pulldown-A__outer {
    margin-bottom: 16px
  }
}

.c-pulldown-A {
  padding-top: 1px;
  padding-bottom: 1px
}

.c-pulldown-A__inner {
  background-color: #f5f5f5;
  margin-top: calc( 100px - 5vw);
  margin-bottom: 6vw;
  position: relative;
  display: flex;
  flex-wrap: wrap
}

@media screen and (min-width: 1800px) {
  .c-pulldown-A__inner {
    margin-bottom: 108px
  }
}

@media screen and (max-width: 399px) {
  .c-pulldown-A__inner {
    margin-bottom: 24px
  }
}

@media screen and (min-width: 1800px) {
  .c-pulldown-A__inner {
    margin-top: 20px
  }
}

@media screen and (max-width: 1199px) {
  .c-pulldown-A__inner {
    margin-bottom: 2vw
  }
}

@media screen and (max-width: 1199px) and (min-width: 1800px) {
  .c-pulldown-A__inner {
    margin-bottom: 36px
  }
}

@media screen and (max-width: 1199px) and (max-width: 399px) {
  .c-pulldown-A__inner {
    margin-bottom: 8px
  }
}

@media screen and (max-width: 959px) {
  .c-pulldown-A__inner {
    margin-top: 25px
  }
}

.c-pulldown-A__inner>div {
  margin: 0 30px 20px 0
}

@media screen and (max-width: 959px) {
  .c-pulldown-A__inner>div {
    margin-right: 0
  }
}

.c-pulldown-A__inner>div:last-child {
  margin-bottom: 0
}

.c-pulldown-A__inner:before {
  content: "";
  border: 15px solid transparent;
  border-bottom: 20px solid #f5f5f5;
  position: absolute;
  top: -35px;
  right: 85px
}

@media screen and (max-width: 799px) {
  .c-pulldown-A__inner:before {
    right: 65px
  }
}

.c-pulldown-A__inner .c-title {
  font-size: 20px;
  font-size: 1.42857rem;
  line-height: 1.8;
  margin-bottom: .5em
}

@media screen and (max-width: 959px) {
  .c-pulldown-A__inner .c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) {
  .c-pulldown-A__inner .c-title {
    font-size: 18px;
    font-size: 1.28571rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .c-pulldown-A__inner .c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) {
  .c-pulldown-A__inner .c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-pulldown-A__inner .c-title {
    line-height: 1.6
  }
}

.c-searchform-A {
  position: relative
}

.c-searchform-A>dt {
  cursor: pointer;
  width: 34px;
  height: 34px;
  padding: 5px;
  position: absolute;
  z-index: 1;
  top: 50%;
  left: 12px;
  transform: translate(0, -50%)
}

@media screen and (max-width: 959px) {
  .c-searchform-A>dt {
    width: 28px !important;
    height: 28px !important;
    left: 10px !important
  }
}

.c-searchform-A._sm>dt {
  width: 30px;
  height: 30px;
  left: 7px
}

.c-searchform-A>dt svg {
  fill: #1476c7
}

.c-searchform-A input[type='text'] {
  height: 58px;
  padding: 0 90px 0 50px;
  border: 1px solid #1476c7
}

.c-searchform-A input[type='text']:focus {
  border-width: 2px
}

@media screen and (max-width: 959px) {
  .c-searchform-A input[type='text'] {
    padding-left: 40px
  }
}

@media screen and (max-width: 799px) {
  .c-searchform-A input[type='text'] {
    height: 48px !important
  }
}

.c-searchform-A._sm input[type='text'] {
  height: 52px;
  padding: 0 10px 0 40px
}

.c-searchform-A .c-submit-A {
  text-align: center !important;
  width: 70px;
  height: 58px;
  min-width: 0;
  position: absolute;
  top: 0;
  right: 0
}

@media screen and (max-width: 799px) {
  .c-searchform-A .c-submit-A {
    line-height: 46px !important;
    height: 48px !important
  }
}

.c-searchform-A._sm .c-submit-A {
  line-height: 48px;
  height: 52px;
  width: 50px
}

.c-searchform-A .c-submit-A>span, .c-searchform-A .c-submit-A>i {
  padding: 0
}

.c-searchform-A .c-submit-A>span:after, .c-searchform-A .c-submit-A>i:after {
  content: none
}

.c-slider-A {
  position: relative
}

.c-slider-A__outer {
  overflow: hidden;
  margin: 0 -1.8vw
}

@media screen and (min-width: 1800px) {
  .c-slider-A__outer {
    margin: 0 -32.4px
  }
}

@media screen and (max-width: 399px) {
  .c-slider-A__outer {
    margin: 0 -8px
  }
}

.c-slider-A__outer._gap-sm {
  margin: 0 -.7vw
}

@media screen and (min-width: 1800px) {
  .c-slider-A__outer._gap-sm {
    margin: 0 -12.6px
  }
}

@media screen and (max-width: 799px) {
  .c-slider-A__outer._gap-sm {
    margin: 0 -1.8vw
  }
}

@media screen and (max-width: 399px) {
  .c-slider-A__outer._gap-sm {
    margin: 0 -8px
  }
}

.c-slider-A__base {
  transform: translate3d(0, 0, 0);
  position: relative
}

.c-slider-A__base._move {
  transition: transform .3s
}

.c-slider-A__base>.l-grids {
  margin: 0
}

.c-slider-A__base>.l-grids>* {
  padding-top: 0;
  padding-bottom: 0
}

.c-slider-A__nav {
  line-height: 40px;
  text-align: center;
  height: 40px;
  margin-top: 2vw;
  position: relative
}

@media screen and (min-width: 1800px) {
  .c-slider-A__nav {
    margin-top: 36px
  }
}

@media screen and (max-width: 399px) {
  .c-slider-A__nav {
    margin-top: 8px
  }
}

.c-slider-A__arrow {
  width: 40px;
  height: 40px;
  position: absolute;
  top: 50%;
  right: 0;
  z-index: 10;
  margin-top: -20px;
  cursor: pointer
}

.c-slider-A__arrow:after {
  content: "";
  width: 10px;
  height: 10px;
  border: 5px #1476c7;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -7px 0 0 -2px
}

@media screen and (max-width: 599px) {
  .c-slider-A__arrow:after {
    width: 8px;
    height: 8px;
    border: 4px #1476c7;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
    margin: -5px 0 0 4px
  }
}

.c-slider-A__arrow._prev {
  left: 0;
  right: auto
}

.c-slider-A__arrow._prev:after {
  width: 10px;
  height: 10px;
  border: 5px #1476c7;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(-135deg);
  margin: -7px 0 0 2px
}

@media screen and (max-width: 599px) {
  .c-slider-A__arrow._prev:after {
    width: 8px;
    height: 8px;
    border: 4px #1476c7;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleX(0.8) translate(-50%, 0) rotate(-135deg);
    margin: -5px 0 0 -4px
  }
}

.c-slider-A__ind>i {
  width: 20px;
  height: 20px;
  display: inline-block;
  vertical-align: middle;
  position: relative;
  cursor: pointer
}

.c-slider-A__ind>i:after {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 100%;
  background-color: #d4d4d4;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%)
}

.c-slider-A__ind>i._active:after {
  background-color: #1476c7
}

.c-slider-B {
  position: relative
}

.c-slider-B__outer {
  overflow: hidden
}

.c-slider-B__base {
  transform: translate3d(0, 0, 0)
}

.c-slider-B__base._move {
  transition: transform .3s
}

.c-slider-B__base>.l-grids {
  margin: 0
}

.c-slider-B__item {
  text-align: center;
  width: 100%;
  flex-shrink: 0;
  padding-top: 0;
  padding-bottom: 0
}

.c-slider-B__item>figcaption {
  margin-top: 1em
}

.c-slider-B__arrow {
  width: 60px;
  height: 60px;
  background-color: #fff;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  right: 10vw;
  z-index: 10;
  cursor: pointer;
  transform: translate(50%, -50%);
  transition: background-color .15s
}

@media screen and (max-width: 959px) {
  .c-slider-B__arrow {
    width: 45px;
    height: 45px;
    right: 8vw
  }
}

@media screen and (max-width: 599px) {
  .c-slider-B__arrow {
    width: 40px;
    height: 40px;
    right: 30px
  }
}

.c-slider-B__arrow:after {
  content: "";
  width: 10px;
  height: 10px;
  border: 5px #1476c7;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -7px 0 0 -3px;
  transition: border-color .15s
}

@media screen and (max-width: 599px) {
  .c-slider-B__arrow:after {
    width: 6px;
    height: 6px;
    border: 4px #1476c7;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
    margin: -5px 0 0 -2px
  }
}

html.no-touchevents .c-slider-B__arrow:hover {
  background-color: #1476c7
}

html.no-touchevents .c-slider-B__arrow:hover:after {
  border-color: #fff
}

.c-slider-B._cap .c-slider-B__arrow {
  margin-top: -20px
}

.c-slider-B__arrow._prev {
  left: 10vw;
  right: auto;
  transform: translate(-50%, -50%)
}

@media screen and (max-width: 959px) {
  .c-slider-B__arrow._prev {
    left: 8vw
  }
}

@media screen and (max-width: 599px) {
  .c-slider-B__arrow._prev {
    left: 30px
  }
}

.c-slider-B__arrow._prev:after {
  width: 10px;
  height: 10px;
  border: 5px #1476c7;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(-135deg);
  margin: -7px 0 0 0
}

@media screen and (max-width: 599px) {
  .c-slider-B__arrow._prev:after {
    width: 6px;
    height: 6px;
    border: 4px #1476c7;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleX(0.8) translate(-50%, 0) rotate(-135deg);
    margin: -5px 0 0 0
  }
}

.c-slider-C {
  position: relative
}

.c-slider-C__outer {
  overflow: hidden
}

.c-slider-C__base {
  transform: translate3d(0, 0, 0)
}

.c-slider-C__base._move {
  transition: transform .3s
}

.c-slider-C__base>.l-grids {
  margin: 0
}

.c-slider-C__item {
  text-align: center;
  width: 100%;
  flex-shrink: 0;
  padding: 0
}

.c-slider-C__nav {
  line-height: 40px;
  text-align: center;
  height: 40px;
  position: relative;
  margin-top: 10px
}

.c-slider-C__arrow {
  width: 40px;
  height: 40px;
  position: absolute;
  top: 50%;
  right: 0;
  z-index: 10;
  margin-top: -20px;
  cursor: pointer
}

.c-slider-C__arrow:after {
  content: "";
  width: 10px;
  height: 10px;
  border: 3px #767676;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -7px 0 0 -2px
}

@media screen and (max-width: 959px) {
  .c-slider-C__arrow:after {
    width: 8px;
    height: 8px;
    border: 3px #767676;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
    margin: -5px 0 0 4px
  }
}

.c-slider-C__arrow._prev {
  left: 0;
  right: auto
}

.c-slider-C__arrow._prev:after {
  width: 10px;
  height: 10px;
  border: 3px #767676;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(-135deg);
  margin: -7px 0 0 2px
}

@media screen and (max-width: 959px) {
  .c-slider-C__arrow._prev:after {
    width: 8px;
    height: 8px;
    border: 3px #767676;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleX(0.8) translate(-50%, 0) rotate(-135deg);
    margin: -5px 0 0 -4px
  }
}

.c-slider-C__ind>i {
  width: 20px;
  height: 20px;
  display: inline-block;
  vertical-align: middle;
  position: relative;
  cursor: pointer
}

.c-slider-C__ind>i:after {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 100%;
  background-color: #d4d4d4;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%)
}

.c-slider-C__ind>i._active:after {
  background-color: #1476c7
}

.c-splash {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1000;
  background-color: #fff;
  visibility: hidden
}

body._loadstart .c-splash {
  visibility: visible;
  transition: visibility 0s .5s
}

body._loadend .c-splash {
  transform: translate(120%, 0);
  visibility: hidden;
  transition: visibility 1.35s, transform 0.85s 0.5s cubic-bezier(0.77, 0, 0.175, 1)
}

.c-splash__elm {
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 1;
  opacity: 0;
  animation: a-splash__elm 1.5s forwards
}

body._loadstart .c-splash__elm {
  opacity: 1;
  transition: opacity 1.5s 1s
}

.c-splash__loader {
  width: 1px;
  height: 140px;
  background-color: transparent;
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  margin-top: -65px;
  opacity: 1;
  animation: a-splash__loader1 .8s backwards infinite
}

body._loadend .c-splash__loader {
  opacity: 0;
  transition: opacity .2s
}

@keyframes a-splash__loader1 {
  0% {
    transform: rotate(0deg)
  }
  100% {
    transform: rotate(-360deg)
  }
}

.c-splash__loader:after {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: #1a1a1a;
  position: absolute;
  bottom: 0;
  left: -3px;
  animation: a-splash__loader2 .8s backwards infinite
}

@keyframes a-splash__loader2 {
  0% {
    opacity: 1;
    transform: scale(1);
    border-radius: 50%
  }
  50% {
    opacity: 1;
    transform: scale(1.5);
    border-radius: 0
  }
  100% {
    opacity: 0;
    transform: scale(1);
    border-radius: 50%
  }
}

.c-splash__logo {
  width: 80px;
  height: 80px;
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 1;
  opacity: 1;
  transform-origin: 0 0;
  transform: translate(-50%, -50%)
}

body._loadend .c-splash__logo {
  opacity: 0;
  transform: scale(0.5) translate(-50%, -50%);
  transition: opacity 0.3s 0.2s, transform 0.3s 0.2s cubic-bezier(0.175, 0.885, 0.32, 1.15)
}

@media screen and (max-width: 599px) {
  .c-table-A__outer {
    overflow: scroll;
    padding-bottom: 5px
  }
  .c-table-A__outer>.c-table-A {
    min-width: 500px
  }
}

.c-table-A__outer-caption, .hr-structure__caption, .hr-pattern__caption {
  display: none
}

@media screen and (max-width: 599px) {
  .c-table-A__outer-caption, .hr-structure__caption, .hr-pattern__caption {
    display: block;
    margin-bottom: 10px
  }
}

.c-table-A {
  width: 100%;
  background-color: #fff;
  table-layout: fixed
}

.c-table-A th, .c-table-A td {
  text-align: center;
  vertical-align: middle;
  border: 1px solid #d4d4d4;
  padding: 10px
}

.c-table-A th:first-child, .c-table-A td:first-child {
  border-left: none
}

.c-table-A th:last-child, .c-table-A td:last-child {
  border-right: none
}

@media screen and (max-width: 599px) {
  .c-table-A th, .c-table-A td {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 2;
    padding: 5px
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-table-A th, .c-table-A td {
    line-height: 1.9
  }
}

.c-table-A th {
  font-size: 13px;
  font-size: .92857rem;
  line-height: 1.8;
  background-color: #f5f5f5
}

@media screen and (max-width: 959px) {
  .c-table-A th {
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) {
  .c-table-A th {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .c-table-A th {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .c-table-A th {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 1.7
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .c-table-A th {
    line-height: 1.5
  }
}

.c-taglist-A {
  margin: 0 -5px -10px
}

.c-textset-B+.c-taglist-A {
  margin-top: 10px
}

.c-taglist-A>li {
  line-height: 1;
  display: inline-block;
  margin: 0 3px 10px
}

@media screen and (max-width: 959px) {
  .c-taglist-A>li {
    margin: 0 2px 7px
  }
}

.c-taglist-A>li>a {
  font-size: 12px;
  font-size: .85714rem;
  line-height: 1.5;
  letter-spacing: 0;
  display: block;
  padding: 7px 15px;
  border: 2px solid #d4d4d4;
  background-color: #fff;
  border-radius: 20px;
  cursor: pointer
}

@media screen and (max-width: 959px) {
  .c-taglist-A>li>a {
    line-height: 1.3
  }
}

@media screen and (max-width: 799px) {
  .c-taglist-A>li>a {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 1.5;
    padding: 5px 12px
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .c-taglist-A>li>a {
    line-height: 1.3
  }
}

.c-taglist-A>li>a._active, html.no-touchevents .c-taglist-A>li>a:hover {
  border-color: #1476c7
}

.top-hero._center .c-hero__txt {
  padding-bottom: 5vw;
  padding-right: 0;
  opacity: 0
}

@media screen and (min-width: 1800px) {
  .top-hero._center .c-hero__txt {
    padding-bottom: 90px
  }
}

@media screen and (max-width: 399px) {
  .top-hero._center .c-hero__txt {
    padding-bottom: 20px
  }
}

.top-hero._center .c-hero__txt>.c-title>span {
  display: block
}

@media screen and (max-width: 799px) {
  .top-hero._center .c-hero__txt {
    padding-bottom: 0
  }
}

body._loadend .top-hero .c-hero__txt {
  opacity: 1;
  transition: opacity 0.3s 0.5s
}

.top-hero .c-hero__img {
  z-index: 0;
  overflow: hidden
}

body._loadend .top-hero .c-hero__img {
  background-color: #1a1a1a;
  transition: background-color 0s 2s
}

.top-hero .c-hero__img-item {
  z-index: 1;
  transform: translate(50px, 0) scale(1.03);
  opacity: 0
}

.top-hero .c-hero__img-item._active {
  z-index: 3;
  transform: translate(0, 0) scale(1);
  opacity: 1;
  transition: opacity 1s .2s, transform 1s .2s;
  transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1)
}

.top-hero .c-hero__img-item._gone {
  z-index: 2;
  transform: translate(0, 0) scale(0.9);
  opacity: 0;
  transition: opacity .3s .1s, transform .4s 0s;
  transition-timing-function: cubic-bezier(0.55, 0.085, 0.68, 0.53)
}

.top-hero .c-hero__img-item>.c-img-ratio {
  transform: scale(1.07);
  transition: transform 7s linear
}

.top-hero .c-hero__img-item._active>.c-img-ratio {
  transform: scale(1)
}

.top-hero_globalbtn {
  width: 140px;
  background-color: #1a1a1a;
  position: absolute;
  top: 0;
  right: 0
}

@media screen and (max-width: 799px) {
  .top-hero_globalbtn {
    width: 130px
  }
}

@media screen and (max-width: 399px) {
  .top-hero_globalbtn {
    width: 120px
  }
}

html.no-touchevents .top-hero_globalbtn:hover>button {
  text-decoration: underline
}

.top-hero_globalbtn>button {
  color: #fff;
  font-size: 12px;
  font-size: .85714rem;
  line-height: 2;
  padding: 1em .5em
}

@media screen and (max-width: 959px) {
  .top-hero_globalbtn>button {
    line-height: 1.9
  }
}

@media screen and (max-width: 799px) {
  .top-hero_globalbtn>button {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .top-hero_globalbtn>button {
    line-height: 1.9
  }
}

.top-hero_globalbtn>button .c-svg {
  width: 16px
}

.top-hero_globalbtn>button .c-svg svg {
  fill: #fff
}

.top-recommend .c-card-A>.c-title+p {
  margin-top: .3em
}

@media screen and (max-width: 799px) {
  .top-news .c-textset-A {
    display: flex;
    justify-content: space-between
  }
}

.top-news__dlist {
  margin-left: -3vw
}

@media screen and (min-width: 1800px) {
  .top-news__dlist {
    margin-left: -54px
  }
}

@media screen and (max-width: 1199px) {
  .top-news__dlist {
    margin-left: -6vw
  }
}

@media screen and (max-width: 799px) {
  .top-news__dlist {
    margin-left: 0
  }
}

@media screen and (max-width: 599px) {
  .top-news__dlist {
    border-top: 1px solid #d4d4d4
  }
}

.top-news__dlist>dt {
  color: #767676;
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  position: absolute;
  padding: 15px 0 0 20px
}

@media screen and (max-width: 959px) {
  .top-news__dlist>dt {
    line-height: 1.9
  }
}

@media screen and (max-width: 959px) {
  .top-news__dlist>dt {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2;
    padding-left: 0
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .top-news__dlist>dt {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .top-news__dlist>dt {
    padding-top: 11px
  }
}

.top-news__dlist>dd {
  border-top: 1px solid #d4d4d4
}

.top-news__dlist>dd:last-child {
  border-bottom: 1px solid #d4d4d4
}

@media screen and (max-width: 599px) {
  .top-news__dlist>dd {
    border-top: none;
    border-bottom: 1px solid #d4d4d4
  }
}

.top-news__dlist>dd>a {
  display: block;
  padding: 13px 50px 11px 9em;
  position: relative;
  z-index: 1
}

@media screen and (max-width: 959px) {
  .top-news__dlist>dd>a {
    padding-left: 7.5em
  }
}

@media screen and (max-width: 799px) {
  .top-news__dlist>dd>a {
    padding-right: 35px
  }
}

@media screen and (max-width: 599px) {
  .top-news__dlist>dd>a {
    padding: calc(13px + 1.5em) 25px 11px 0
  }
}

.top-news__dlist>dd>a:hover {
  text-decoration: underline
}

.top-news__dlist>dd>a:after {
  content: "";
  width: 6px;
  height: 6px;
  border: 3px #1476c7;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
  position: absolute;
  top: 50%;
  right: 15px;
  margin-top: -4px
}

@media screen and (max-width: 799px) {
  .top-news__dlist>dd>a:after {
    width: 4px;
    height: 4px;
    border: 3px #1476c7;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleX(0.8) translate(-50%, 0) rotate(45deg);
    right: 5px
  }
}

.top-instagram>.c-title {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8;
  text-align: center
}

@media screen and (max-width: 959px) {
  .top-instagram>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) {
  .top-instagram>.c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .top-instagram>.c-title {
    line-height: 1.6
  }
}

.top-instagram__item>.c-text-sm {
  font-size: 15px;
  font-size: 1.07143rem;
  line-height: 2;
  text-align: center;
  display: block;
  margin-top: .6em
}

@media screen and (max-width: 959px) {
  .top-instagram__item>.c-text-sm {
    line-height: 1.9
  }
}

@media screen and (max-width: 799px) {
  .top-instagram__item>.c-text-sm {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 2;
    margin-top: .3em
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .top-instagram__item>.c-text-sm {
    line-height: 1.9
  }
}

.top-instagram__item>.c-text-sm>.c-svg {
  width: 1em;
  display: inline-block;
  margin: 0 .5em -2px 0
}

@media screen and (max-width: 799px) {
  .top-instagram__item>.c-text-sm>.c-svg {
    margin-right: .3em
  }
}

.about-hero {
  margin-top: 5vw
}

@media screen and (min-width: 1800px) {
  .about-hero {
    margin-top: 90px
  }
}

.about-vision>.c-title-A>span {
  margin-left: 1em
}

@media screen and (max-width: 1199px) {
  .about-vision>.c-title-A>span {
    margin-left: 0;
    display: block
  }
}

@media screen and (max-width: 959px) {
  .about-vision>.c-title-A>span {
    margin-left: 1em;
    display: inline
  }
}

@media screen and (max-width: 799px) {
  .about-vision>.c-title-A>span {
    margin-left: 0;
    display: block
  }
}

.about-vision__txt {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8;
  line-height: 2.2
}

@media screen and (max-width: 959px) {
  .about-vision__txt {
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) {
  .about-vision__txt {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8;
    line-height: 2 !important
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .about-vision__txt {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .about-vision__txt {
    font-size: 14px;
    font-size: 1rem;
    line-height: 2;
    line-height: 1.8 !important
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .about-vision__txt {
    line-height: 1.9
  }
}

.about-vision__txt>p+p {
  margin-top: 2em
}

.history-header {
  margin-bottom: -6vw
}

@media screen and (max-width: 599px) {
  .history-header {
    margin-bottom: 9vw
  }
  .history-header .c-textset-A, .history-header .c-title {
    text-align: center
  }
}

@media screen and (max-width: 399px) {
  .history-header {
    margin-bottom: 36px
  }
}

.history-header__img {
  margin-right: -4vw
}

@media screen and (min-width: 1800px) {
  .history-header__img {
    margin-right: -72px
  }
}

@media screen and (max-width: 599px) {
  .history-header__img {
    margin-right: 0
  }
}

.history-list__list {
  overflow: hidden;
  position: relative;
  z-index: 1
}

@media screen and (max-width: 599px) {
  .history-list__list {
    margin-top: 9vw
  }
}

@media screen and (max-width: 399px) {
  .history-list__list {
    margin-top: 36px
  }
}

.history-list__list:before {
  content: "";
  width: 2px;
  height: 10000px;
  background-color: #d4d4d4;
  position: absolute;
  top: 0;
  left: 50%;
  z-index: -1
}

@media screen and (max-width: 599px) {
  .history-list__list:before {
    left: 2em
  }
}

@media screen and (max-width: 399px) {
  .history-list__list:before {
    left: 1.7em
  }
}

.history-list__list>dt {
  color: #1a1a1a;
  font-size: 40px;
  font-size: 2.85714rem;
  line-height: 1.6;
  text-align: center;
  clear: both;
  width: 3em;
  margin: 0 auto;
  padding: 10px 0;
  background-color: #f5f5f5;
  position: relative;
  z-index: 100
}

@media screen and (max-width: 959px) {
  .history-list__list>dt {
    line-height: 1.4
  }
}

@media screen and (max-width: 959px) {
  .history-list__list>dt {
    font-size: 32px;
    font-size: 2.28571rem;
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .history-list__list>dt {
    line-height: 1.4
  }
}

@media screen and (max-width: 599px) {
  .history-list__list>dt {
    width: auto;
    font-size: 22px;
    font-size: 1.57143rem;
    line-height: 1.8;
    position: absolute;
    left: 0;
    padding: 5px 0;
    margin-top: -10px !important
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .history-list__list>dt {
    line-height: 1.6
  }
}

@media screen and (max-width: 399px) {
  .history-list__list>dt {
    font-size: 18px;
    font-size: 1.28571rem;
    line-height: 1.8;
    margin-top: -7px !important
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .history-list__list>dt {
    line-height: 1.6
  }
}

.history-list__list>dd+dt {
  margin-top: 7%
}

.history-list__list>dd {
  color: #767676;
  width: 35%;
  margin-top: -4em;
  float: right;
  position: relative;
  z-index: 1
}

@media screen and (max-width: 599px) {
  .history-list__list>dd {
    width: auto;
    margin-top: 0;
    margin-bottom: 6vw;
    padding-left: 6em;
    float: none !important;
    overflow: hidden
  }
}

@media screen and (max-width: 399px) {
  .history-list__list>dd {
    margin-bottom: 25px;
    padding-left: 5em
  }
}

.history-list__list>dd:nth-of-type(2n+1) {
  float: left
}

.history-list__list>dd>img {
  display: block;
  margin: -10% 0 1em
}

@media screen and (max-width: 599px) {
  .history-list__list>dd>img {
    width: 40%;
    margin: 0 0 0 15px;
    float: right
  }
}

@media screen and (max-width: 399px) {
  .history-list__list>dd>img {
    width: 100%;
    margin: 0 0 15px;
    float: none
  }
}

.feature-hero .c-hero__txt>.c-title {
  min-width: 12em
}

@media screen and (max-width: 599px) {
  .feature-hero .c-hero__txt>.c-title {
    min-width: auto
  }
}

.about-feature .c-title {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8
}

@media screen and (max-width: 959px) {
  .about-feature .c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) {
  .about-feature .c-title {
    font-size: 14px;
    font-size: 1rem;
    line-height: 2
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .about-feature .c-title {
    line-height: 1.9
  }
}

@media screen and (max-width: 399px) {
  .about-feature .c-title {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 2
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .about-feature .c-title {
    line-height: 1.9
  }
}

.about-feature__item:first-child {
  border-bottom: 1px solid #d4d4d4;
  margin-bottom: 5vw;
  padding-bottom: 5vw
}

@media screen and (min-width: 1800px) {
  .about-feature__item:first-child {
    margin-bottom: 90px
  }
}

@media screen and (max-width: 399px) {
  .about-feature__item:first-child {
    margin-bottom: 20px
  }
}

@media screen and (min-width: 1800px) {
  .about-feature__item:first-child {
    padding-bottom: 90px
  }
}

@media screen and (max-width: 399px) {
  .about-feature__item:first-child {
    padding-bottom: 20px
  }
}

.about-feature__img {
  height: 500px;
  position: relative;
  overflow: hidden;
  opacity: 0;
  transform: translate(10%, 0)
}

@media screen and (max-width: 959px) {
  .about-feature__img {
    height: 400px
  }
}

@media screen and (max-width: 599px) {
  .about-feature__img {
    height: 300px
  }
}

@media screen and (max-width: 399px) {
  .about-feature__img {
    height: 250px
  }
}

.js-sa-elm._active .about-feature__img {
  opacity: 1;
  transform: translate(0, 0);
  transition: opacity 0.1s, transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.05)
}

.about-feature__img-inner {
  width: 100%;
  height: 500px;
  position: absolute;
  transform-origin: 50% 0
}

@media screen and (max-width: 959px) {
  .about-feature__img-inner {
    transform: scale(0.8)
  }
}

@media screen and (max-width: 599px) {
  .about-feature__img-inner {
    transform: scale(0.6)
  }
}

@media screen and (max-width: 399px) {
  .about-feature__img-inner {
    transform: scale(0.5)
  }
}

.about-feature__img-inner>span, .about-feature__img-inner>span>span {
  display: block;
  background-image: url(../images/about/about-feature_img01.png);
  background-size: 500px 550px;
  position: absolute;
  top: 0;
  left: 50%;
  opacity: 0
}

#ft1-img__wire {
  width: 14px;
  height: 550px;
  top: auto;
  margin-left: -6px;
  bottom: 420px;
  z-index: -1
}

#ft1-img__grip {
  width: 73px;
  height: 270px;
  top: 160px;
  margin-left: -36px;
  background: none
}

#ft1-img__grip-cap {
  width: 46px;
  height: 110px;
  margin-left: -23px;
  background-position: -50px 0;
  opacity: 1
}

#ft1-img__grip-ball__left, #ft1-img__grip-ball__right {
  width: 22px;
  height: 22px;
  top: 75px;
  margin-left: -22px;
  border-radius: 50%;
  border: 2px dotted #000;
  background: none;
  opacity: 1
}

#ft1-img__grip-ball__right {
  margin-left: 0
}

#ft1-img__grip-spring {
  width: 52px;
  height: 69px;
  top: 109px;
  margin-left: -26px;
  background-position: -100px 0;
  transform-origin: 50% 100%;
  opacity: 1
}

#ft1-img__grip-base {
  width: 61px;
  height: 19px;
  top: 177px;
  margin-left: -31px;
  background-position: -50px -150px;
  opacity: 1
}

#ft1-img__grip-shell {
  width: 73px;
  height: 214px;
  top: auto;
  bottom: 0;
  margin-left: -37px;
  background-position: -50px -200px;
  opacity: 1
}

#ft1-img__grip-arrow1 {
  width: 27px;
  height: 27px;
  top: -30px;
  margin-left: 40px;
  background-position: -350px -250px
}

#ft1-img__grip-arrow2 {
  width: 29px;
  height: 84px;
  top: 130px;
  margin-left: -100px;
  background-position: -400px -200px
}

#about-feature__img1._step1 #ft1-img__wire {
  opacity: 1;
  transform: translate(0, 400px);
  transition: opacity 0.3s 0.5s, transform 0.6s 1s cubic-bezier(0.55, 0.085, 0.68, 0.53)
}

#ft1-img__grip {
  transform: translate(0, 30px)
}

#about-feature__img1._step1 #ft1-img__grip {
  opacity: 1;
  transform: translate(0, 0);
  transition: opacity .3s .5s, transform .3s .5s
}

#about-feature__img1._step1 #ft1-img__grip-cap {
  transform: translate(0, 10px);
  transition: transform .2s 1.3s linear
}

#about-feature__img1._step1 #ft1-img__grip-ball__left {
  transform: translate(-4px, 17px);
  transition: transform .2s 1.3s linear
}

#about-feature__img1._step1 #ft1-img__grip-ball__right {
  transform: translate(4px, 17px);
  transition: transform .2s 1.3s linear
}

#about-feature__img1._step1 #ft1-img__grip-spring {
  transform: scaleY(0.85);
  transition: transform .2s 1.3s linear
}

#about-feature__img1._step2 #ft1-img__grip-arrow1 {
  opacity: 1;
  transition: opacity .3s;
  animation: ft1-img__arrow2-1 .4s .5s forwards
}

@keyframes ft1-img__arrow2-1 {
  0% {
    transform: translate(0, 0)
  }
  100% {
    transform: translate(-7px, 25px)
  }
}

#about-feature__img1._step2 #ft1-img__grip-cap {
  transform: translate(0, 40px);
  transition: transform .4s .5s
}

#about-feature__img1._step2 #ft1-img__grip-ball__left {
  transform: translate(-7px, 36px);
  transition: transform .4s .5s
}

#about-feature__img1._step2 #ft1-img__grip-ball__right {
  transform: translate(7px, 36px);
  transition: transform .4s .5s
}

#about-feature__img1._step2 #ft1-img__grip-spring {
  transform: scaleY(0.4);
  transition: transform .4s .5s
}

#about-feature__img1._step3 #ft1-img__grip-arrow2 {
  opacity: 1;
  transition: opacity .2s .3s
}

#about-feature__img1._step3 #ft1-img__grip {
  animation: ft1-img__grip-1 0.5s 0.7s alternate 4 cubic-bezier(0.455, 0.03, 0.515, 0.955)
}

@keyframes ft1-img__grip-1 {
  0% {
    transform: translate(0, 0)
  }
  100% {
    transform: translate(0, -80px)
  }
}

#ft2-img__ceiling, #ft2-img__floor {
  width: 283px;
  height: 164px;
  top: 5px;
  margin-left: -141px;
  background-position: -200px 0
}

#ft2-img__floor {
  top: auto;
  bottom: 5px;
  z-index: -1
}

#ft2-img__rail {
  width: 216px;
  height: 130px;
  top: 18px;
  margin-left: -110px;
  background-position: -200px -400px;
  z-index: 1
}

#ft2-img__system {
  width: 140px;
  height: 409px;
  top: 45px;
  margin-left: -70px;
  background: none
}

#ft2-img__arrow1 {
  width: 29px;
  height: 84px;
  top: 235px;
  margin-left: -120px;
  background-position: -400px -200px
}

#ft2-img__wire-left, #ft2-img__wire-right {
  width: 7px;
  height: 333px;
  top: auto;
  bottom: 0;
  margin-left: -70px;
  background-position: -150px -100px;
  opacity: 1
}

#ft2-img__wire-right {
  top: 0;
  margin-left: 60px
}

#ft2-img__panel {
  width: 140px;
  height: 192px;
  top: 130px;
  left: 0;
  background-position: -200px -200px;
  opacity: 1
}

#ft2-img__tensioner-left, #ft2-img__tensioner-right {
  width: 9px;
  height: 19px;
  top: auto;
  bottom: 0;
  margin-left: -71px;
  background-position: -350px -200px
}

#ft2-img__tensioner-right {
  margin-left: 59px;
  bottom: 75px
}

#ft2-img__arrow3-left, #ft2-img__arrow3-right {
  width: 27px;
  height: 28px;
  top: auto;
  bottom: 15px;
  margin-left: -55px;
  background-position: -350px -250px
}

#ft2-img__arrow3-right {
  margin-left: 77px;
  bottom: 90px
}

#ft2-img__arrow2 {
  width: 73px;
  height: 55px;
  top: 20px;
  margin-left: -100px;
  background-position: -50px -450px
}

#ft2-img__ceiling {
  transform: translate(0, -20px)
}

#about-feature__img2._step1 #ft2-img__ceiling {
  opacity: 1;
  transform: translate(0, 0);
  transition: opacity .3s .5s, transform .3s .5s
}

#ft2-img__system {
  transform: translate(0, 20px)
}

#about-feature__img2._step1 #ft2-img__system {
  opacity: 1;
  transform: translate(0, 0);
  transition: opacity .2s .6s, transform .2s .6s
}

#about-feature__img2._step1 #ft2-img__arrow1 {
  opacity: 1;
  transition: opacity .2s 1.3s
}

#about-feature__img2._step1 #ft2-img__arrow1, #about-feature__img2._step1 #ft2-img__panel {
  animation: ft2-img__panel-1 0.5s 1.6s alternate 4 cubic-bezier(0.455, 0.03, 0.515, 0.955)
}

@keyframes ft2-img__panel-1 {
  0% {
    transform: translate(0, 0)
  }
  100% {
    transform: translate(0, -60px)
  }
}

#ft2-img__rail {
  transform: translate(-50px, 30px)
}

#about-feature__img2._step2 #ft2-img__rail {
  opacity: 1;
  transform: translate(0, 0);
  transition: opacity .3s .3s, transform .3s .6s
}

#about-feature__img2._step2 #ft2-img__arrow2 {
  opacity: 1;
  transition: opacity .2s .8s
}

#about-feature__img2._step2 #ft2-img__arrow2, #about-feature__img2._step2 #ft2-img__system {
  animation: ft2-img__system-1 0.45s 1.2s alternate 4 cubic-bezier(0.455, 0.03, 0.515, 0.955)
}

@keyframes ft2-img__system-1 {
  0% {
    transform: translate(0, 0)
  }
  100% {
    transform: translate(30px, -18px)
  }
}

#about-feature__img2._step3 #ft2-img__arrow1, #about-feature__img2._step3 #ft2-img__arrow2 {
  opacity: 0;
  transition: opacity .2s .3s
}

#about-feature__img2._step3 #ft2-img__rail {
  opacity: 0;
  transform: translate(-50px, 30px);
  transition: opacity .3s .4s, transform .3s .3s
}

#ft2-img__tensioner-left, #ft2-img__tensioner-right {
  transform: translate(0, -10px)
}

#about-feature__img2._step3 #ft2-img__tensioner-left, #about-feature__img2._step3 #ft2-img__tensioner-right {
  opacity: 1;
  transform: translate(0, 0);
  transition: opacity .3s 1.5s, transform .3s 1.5s
}

#ft2-img__arrow3-left, #ft2-img__arrow3-right {
  transform: translate(20px, -20px)
}

#about-feature__img2._step3 #ft2-img__arrow3-left, #about-feature__img2._step3 #ft2-img__arrow3-right {
  opacity: 1;
  transform: translate(0, 0);
  transition: opacity .3s 1.2s, transform .3s 1.2s
}

#ft2-img__floor {
  transform: translate(0, 20px)
}

#about-feature__img2._step3 #ft2-img__floor {
  opacity: 1;
  transform: translate(0, 0);
  transition: opacity .3s .3s, transform .3s .3s
}

.awards-list__item+.awards-list__item {
  margin-top: 4vw
}

@media screen and (min-width: 1800px) {
  .awards-list__item+.awards-list__item {
    margin-top: 72px
  }
}

@media screen and (max-width: 399px) {
  .awards-list__item+.awards-list__item {
    margin-top: 16px
  }
}

@media screen and (max-width: 399px) {
  .awards-list__item+.awards-list__item {
    margin-top: 25px
  }
}

.awards-list__item>header {
  border: 1px #d4d4d4;
  border-style: solid none;
  display: flex;
  justify-content: space-between;
  align-items: center
}

@media screen and (max-width: 799px) {
  .awards-list__item>header {
    display: block
  }
}

@media screen and (max-width: 399px) {
  .awards-list__item>header {
    border-bottom: none;
    margin-bottom: -25px
  }
}

.awards-list__item>header>.c-title {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8;
  flex-grow: 1;
  padding: 10px 1em 10px 10px
}

@media screen and (max-width: 959px) {
  .awards-list__item>header>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) {
  .awards-list__item>header>.c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8;
    padding: 12px 0
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .awards-list__item>header>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 399px) {
  .awards-list__item>header>.c-title {
    font-size: 15px;
    font-size: 1.07143rem;
    line-height: 2;
    text-align: center;
    padding: 15px 0
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .awards-list__item>header>.c-title {
    line-height: 1.9
  }
}

.awards-list__item figure {
  margin-top: 15px
}

@media screen and (max-width: 399px) {
  .awards-list__dlist {
    margin-top: -10px
  }
}

.awards-list__dlist>* {
  padding: 10px 10px 8px;
  border-bottom: 1px solid #d4d4d4
}

@media screen and (max-width: 799px) {
  .awards-list__dlist>* {
    padding-right: 0
  }
}

@media screen and (max-width: 399px) {
  .awards-list__dlist>* {
    padding: 0;
    border: none
  }
}

.awards-list__dlist>*:last-child {
  border-bottom: none
}

.awards-list__dlist>dt {
  font-weight: 600;
  text-align: left
}

@media screen and (max-width: 399px) {
  .awards-list__dlist>dt {
    padding: 5px 0
  }
}

.awards-list__dlist>dd {
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  padding: 13px 10px 11px
}

@media screen and (max-width: 959px) {
  .awards-list__dlist>dd {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .awards-list__dlist>dd {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .awards-list__dlist>dd {
    line-height: 1.9
  }
}

.awards-list__logo {
  text-align: right;
  margin: 15px 10px 0
}

@media screen and (max-width: 599px) {
  .awards-list__logo {
    margin-left: -50%
  }
}

@media screen and (max-width: 399px) {
  .awards-list__logo {
    margin-left: 0
  }
}

.awards-list__logo>li {
  display: inline-block;
  height: 5vw;
  min-height: 35px;
  max-height: 50px;
  margin-left: 15px
}

.awards-list__logo>li:first-child {
  margin-left: 0
}

.awards-list__logo>li>img {
  width: auto;
  height: 100%
}

@media screen and (max-width: 599px) {
  .products-top>.c-hero-C {
    padding-top: 0;
    padding-bottom: 9vw
  }
  .products-top>.c-hero-C:before {
    top: auto;
    bottom: 0
  }
}

@media screen and (max-width: 399px) {
  .products-top>.c-hero-C {
    padding-top: 0;
    padding-bottom: 36px
  }
}

.products-top>.c-hero-C ._btn {
  display: flex;
  line-height: 0
}

@media screen and (max-width: 399px) {
  .products-top>.c-hero-C ._btn {
    width: 167%
  }
}

.products-top>.c-hero-C ._btn>.c-button-A, .products-top>.c-hero-C ._btn>.c-button-B {
  width: 50%;
  max-width: 200px;
  min-width: 0
}

.products-top>.c-hero-C ._btn>.c-button-A._flip, .products-top>.c-hero-C ._btn>._flip.c-button-B {
  margin-left: -1px
}

.products-header {
  background-color: #f5f5f5
}

.products-header>div {
  margin: 0 auto;
  padding: 0 8.5vw;
  display: flex;
  justify-content: space-between;
  align-items: center
}

@media screen and (min-width: 1800px) {
  .products-header>div {
    padding: 0 153px
  }
}

@media screen and (max-width: 1199px) {
  .products-header>div {
    padding: 0 6vw
  }
}

@media screen and (max-width: 959px) {
  .products-header>div {
    padding: 0 4vw
  }
}

@media screen and (max-width: 599px) {
  .products-header>div {
    flex-direction: column
  }
}

.products-header__title {
  font-size: 15px;
  font-size: 1.07143rem;
  line-height: 50px
}

@media screen and (max-width: 959px) {
  .products-header__title {
    line-height: 49.9px
  }
}

@media screen and (max-width: 799px) {
  .products-header__title {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 50px
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .products-header__title {
    line-height: 49.9px
  }
}

@media screen and (max-width: 599px) {
  .products-header__title {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2;
    text-align: center;
    line-height: 1.8;
    padding: 12px 0 10px;
    width: 100%;
    border-bottom: 1px solid #d4d4d4
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .products-header__title {
    line-height: 1.9
  }
}

.products-header__nav {
  line-height: 50px;
  display: flex
}

@media screen and (max-width: 959px) {
  .products-header__nav {
    margin-right: -1em
  }
}

@media screen and (max-width: 799px) {
  .products-header__nav {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 50px
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .products-header__nav {
    line-height: 49.9px
  }
}

@media screen and (max-width: 399px) {
  .products-header__nav {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 40px
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .products-header__nav {
    line-height: 39.9px
  }
}

.products-header__nav>li>a {
  display: block;
  padding: 0 2em;
  position: relative
}

.products-header__nav>li>a:after {
  content: "";
  width: 0;
  height: 3px;
  background-color: #1476c7;
  position: absolute;
  bottom: 0;
  left: 0;
  transition: width .2s
}

@media screen and (max-width: 959px) {
  .products-header__nav>li>a {
    padding-left: 1.5em;
    padding-right: 1.5em
  }
}

html.no-touchevents .products-header__nav>li>a:hover:after {
  width: 100%
}

.products-header__nav>li._active>a:after {
  width: 100%
}

.products-search._sm>.c-hero__img {
  padding-bottom: 35%
}

@media screen and (min-width: 1500px) {
  .products-search._sm>.c-hero__img {
    padding-bottom: 525px
  }
}

@media screen and (max-width: 599px) {
  .products-search._sm>.c-hero__img {
    padding-bottom: 40% !important
  }
}

@media screen and (max-width: 599px) {
  .hr-products-search._sm>.c-hero__img {
    padding-bottom: 35% !important
  }
}

.products-search .c-hero__txt {
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2
}

@media screen and (max-width: 959px) {
  .products-search .c-hero__txt {
    line-height: 1.9
  }
}

@media screen and (max-width: 959px) {
  .products-search .c-hero__txt {
    width: 70%;
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .products-search .c-hero__txt {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .products-search .c-hero__txt {
    width: 100%
  }
}

.products-search .c-title {
  font-size: 22px;
  font-size: 1.57143rem;
  line-height: 1.8
}

@media screen and (max-width: 959px) {
  .products-search .c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) {
  .products-search .c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .products-search .c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 399px) {
  .products-search .c-title {
    font-size: 15px;
    font-size: 1.07143rem;
    line-height: 2
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .products-search .c-title {
    line-height: 1.9
  }
}

.products-search .c-searchform-A {
  margin: 1em 0 2em
}

@media screen and (max-width: 959px) {
  .products-search .c-searchform-A {
    margin: 1em 0 1.5em
  }
}

.products-search__links {
  margin: 1em 0 0 5px
}

@media screen and (min-width: 800px) {
  .products-search__links>li+li {
    margin-top: -.5em
  }
}

.products-search__links>li:last-child {
  margin-left: -7px
}

.products-search__links>li .c-linktxt-A._icon {
  padding-left: 22px
}

@media screen and (max-width: 599px) {
  .products-search__links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin: 1em -10px 0 !important
  }
  .products-search__links>li {
    margin: 0 7px !important
  }
}

.products-search__question {
  text-align: right;
  margin: 3vw auto -5vw
}

@media screen and (min-width: 1800px) {
  .products-search__question {
    margin: 54px auto -90px
  }
}

.products-category__section+.products-category__section {
  margin-top: 9vw
}

@media screen and (min-width: 1800px) {
  .products-category__section+.products-category__section {
    margin-top: 162px
  }
}

@media screen and (max-width: 399px) {
  .products-category__section+.products-category__section {
    margin-top: 36px
  }
}

.products-category__section>header {
  display: flex;
  justify-content: space-between;
  margin-bottom: 4vw
}

@media screen and (min-width: 1800px) {
  .products-category__section>header {
    margin-bottom: 72px
  }
}

@media screen and (max-width: 399px) {
  .products-category__section>header {
    margin-bottom: 16px
  }
}

@media screen and (max-width: 399px) {
  .products-category__section>header {
    display: block
  }
  .products-category__section>header>.c-title {
    margin-bottom: 5px
  }
}

@media screen and (max-width: 599px) {
  .products-category__section._picturerail>header {
    display: block
  }
}

.products-category__links {
  text-align: right
}

.products-category__alllinks {
  text-align: right;
  transform: translate(0, -50%)
}

.c-column-sub__pulldown-inner>*:last-child {
  margin-bottom: 0
}

.products-list__filter {
  padding: 2vw;
  background-color: #f5f5f5;
  margin-bottom: 20px
}

.products-list__filter>.c-title {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8;
  margin-bottom: 1em
}

@media screen and (max-width: 959px) {
  .products-list__filter>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) {
  .products-list__filter>.c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8;
    margin-bottom: 1em
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .products-list__filter>.c-title {
    line-height: 1.6
  }
}

@media screen and (min-width: 1800px) {
  .products-list__filter {
    padding: 36px
  }
}

@media screen and (max-width: 959px) {
  .products-list__filter {
    padding: 3vw
  }
}

@media screen and (max-width: 799px) {
  .products-list__filter {
    padding: 20px
  }
}

@media screen and (max-width: 599px) {
  .products-list__filter {
    margin-bottom: 15px
  }
}

@media screen and (max-width: 959px) {
  .products-list__filter>.c-title {
    display: none
  }
}

.products-list__filter-item>.c-title {
  font-size: 16px;
  font-size: 1.14286rem;
  line-height: 1.8;
  margin: 1.5em 0 .7em
}

@media screen and (max-width: 959px) {
  .products-list__filter-item>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) {
  .products-list__filter-item>.c-title {
    font-size: 15px;
    font-size: 1.07143rem;
    line-height: 2;
    margin: 1em 0 .5em
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .products-list__filter-item>.c-title {
    line-height: 1.9
  }
}

@media screen and (max-width: 799px) {
  .products-list__filter-item>.c-title {
    font-size: 14px;
    font-size: 1rem;
    line-height: 2
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .products-list__filter-item>.c-title {
    line-height: 1.9
  }
}

@media screen and (max-width: 959px) {
  .products-list__filter-item:first-of-type>.c-title {
    margin-top: 0
  }
}

.products-list__filter-item._outer {
  overflow: hidden;
  padding: 0 10px;
  margin: 0 -10px
}

.products-list__filter-item._outer .products-list__filter-list__outer {
  display: none
}

.products-list__filter-item._outer .products-list__filter-list__outer._active {
  display: block
}

.products-list__filter-list {
  text-align: left;
  margin: 0 -5px -10px
}

.products-list__filter-list>li {
  line-height: 1;
  display: inline-block;
  margin: 0 3px 10px
}

@media screen and (max-width: 959px) {
  .products-list__filter-list>li {
    margin: 0 2px 7px
  }
}

.products-list__filter-list>li>label {
  font-size: 12px;
  font-size: .85714rem;
  line-height: 1.5;
  letter-spacing: 0;
  display: block;
  padding: 7px 15px;
  border: 2px solid #d4d4d4;
  background-color: #fff;
  border-radius: 20px;
  cursor: pointer
}

@media screen and (max-width: 959px) {
  .products-list__filter-list>li>label {
    line-height: 1.3
  }
}

@media screen and (max-width: 799px) {
  .products-list__filter-list>li>label {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 1.5;
    padding: 5px 12px
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .products-list__filter-list>li>label {
    line-height: 1.3
  }
}

.products-list__filter-list>li>input:checked+label, html.no-touchevents .products-list__filter-list>li>label:hover {
  border-color: #1476c7
}

.products-list__filter-list>li>input[type="checkbox"], .products-list__filter-list>li>input[type="radio"] {
  position: absolute;
  left: -2em
}

.products-list__filter-qa {
  margin-top: .5em
}

.products-list__filter-btn {
  text-align: center;
  margin-top: 2em
}

.products-list__filter._hspr .products-list__filter-btn {
  margin-top: 1.5em
}

@media screen and (max-width: 959px) {
  .products-list__filter._hspr .products-list__filter-btn {
    margin-top: 1.2em
  }
}

.products-list__banner {
  margin-bottom: 20px
}

@media screen and (max-width: 959px) {
  .products-list__banner._hspr {
    width: 40%;
    display: none;
    float: left;
    margin: 0 5% 0 0
  }
  .products-list__banner._hspr:first-of-type {
    display: block
  }
}

@media screen and (max-width: 599px) {
  .products-list__banner._hspr {
    width: 100%;
    float: none;
    margin: 0 auto 10px
  }
}

@media screen and (max-width: 959px) {
  .products-list__banner._hr {
    max-width: 500px;
    margin: 0 auto
  }
}

.products-list__links {
  padding-left: 10px;
  overflow: auto
}

.products-list__links .c-linktxt-A._icon {
  padding-left: 22px;
  margin-left: -7px
}

.products-list__links>li:nth-child(2) {
  margin-bottom: .5em
}

@media screen and (max-width: 959px) {
  .products-detail__img {
    display: flex
  }
}

@media screen and (max-width: 959px) {
  .products-detail__img>figure {
    width: 50%
  }
}

.products-detail__img>figure+figure {
  margin-top: 20px
}

@media screen and (max-width: 959px) {
  .products-detail__img>figure+figure {
    margin-top: 0;
    margin-left: 3.6vw
  }
}

.products-detail .c-title {
  padding: 10px;
  border-top: 1px solid #d4d4d4
}

@media screen and (max-width: 599px) {
  .products-detail .c-title {
    padding-left: 0;
    padding-right: 0
  }
}

@media screen and (max-width: 599px) {
  .products-detail .c-dlist-A>dt {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .products-detail .c-dlist-A>dt {
    line-height: 1.9
  }
}

@media screen and (max-width: 399px) {
  .products-detail .c-dlist-A>dt {
    width: 6em
  }
}

@media screen and (max-width: 599px) {
  .products-detail .c-dlist-A>dd {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .products-detail .c-dlist-A>dd {
    line-height: 1.9
  }
}

@media screen and (max-width: 399px) {
  .products-detail .c-dlist-A>dd {
    padding-left: 6em
  }
}

.products-detail__caption, .products-remarks__island>p {
  padding: 23px 10px 0
}

@media screen and (max-width: 599px) {
  .products-detail__caption, .products-remarks__island>p {
    padding: 15px 0
  }
}

.products-detail__caption img, .products-remarks__island>p img {
  max-width: 100%;
  width: auto;
  display: block;
  margin: .5em 0
}

.products-detail__caption a, .products-remarks__island>p a {
  text-decoration: underline
}

.products-detail__caption>.c-title, .products-remarks__island>p>.c-title {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8;
  display: inline-block;
  padding: 0;
  margin: 2em 0 1em;
  border: none
}

@media screen and (max-width: 959px) {
  .products-detail__caption>.c-title, .products-remarks__island>p>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) {
  .products-detail__caption>.c-title, .products-remarks__island>p>.c-title {
    font-size: 17px;
    font-size: 1.21429rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .products-detail__caption>.c-title, .products-remarks__island>p>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) {
  .products-detail__caption>.c-title, .products-remarks__island>p>.c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .products-detail__caption>.c-title, .products-remarks__island>p>.c-title {
    line-height: 1.6
  }
}

.products-detail__caption>.c-title:first-child, .products-remarks__island>p>.c-title:first-child {
  margin-top: 0
}

.products-detail__reproduction {
  text-align: left;
  font-size: 12px;
  font-size: .85714rem;
  line-height: 2;
  margin-top: 3em
}

@media screen and (max-width: 959px) {
  .products-detail__reproduction {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .products-detail__reproduction {
    margin-top: 0
  }
}

.products-sku._single .l-grid-1of2 {
  width: 100%
}

.products-remarks {
  margin-top: -3vw
}

@media screen and (min-width: 1800px) {
  .products-remarks {
    margin-top: -54px
  }
}

@media screen and (max-width: 399px) {
  .products-remarks {
    margin-top: -12px
  }
}

.products-remarks__island {
  background-color: #fff;
  border: 1px solid #fff;
  padding: 3.5em 4em;
  border: 1px solid #d4d4d4;
  max-width: 1200px;
  margin: 0 auto
}

@media screen and (max-width: 959px) {
  .products-remarks__island {
    padding: 2.5em 3em
  }
}

@media screen and (max-width: 599px) {
  .products-remarks__island {
    padding: 2em
  }
}

.products-remarks__island>p {
  padding: 0
}

.products-related__item {
  display: flex;
  align-items: flex-start;
  background-color: #fff;
  padding: 20px
}

@media screen and (max-width: 599px) {
  .products-related__item {
    padding: 15px
  }
}

.products-related__item>figure {
  width: 100px;
  height: auto;
  flex-shrink: 0
}

@media screen and (max-width: 599px) {
  .products-related__item>figure {
    width: 80px
  }
}

@media screen and (max-width: 399px) {
  .products-related__item>figure {
    width: 60px
  }
}

.products-related__item>figure>.c-linkicon {
  max-width: 30px;
  max-height: 30px
}

.products-related__item-txt {
  width: 90%;
  flex-shrink: 1;
  margin-left: 20px
}

@media screen and (max-width: 399px) {
  .products-related__item-txt {
    margin-left: 12px
  }
}

.products-related__item-txt>.c-title {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8;
  margin-top: -.3em
}

@media screen and (max-width: 959px) {
  .products-related__item-txt>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) {
  .products-related__item-txt>.c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .products-related__item-txt>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 399px) {
  .products-related__item-txt>.c-title {
    font-size: 14px;
    font-size: 1rem;
    line-height: 2
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .products-related__item-txt>.c-title {
    line-height: 1.9
  }
}

.products-related__item-txt>.c-title+p {
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  text-align: left;
  font-weight: 600;
  margin-bottom: .5em
}

@media screen and (max-width: 959px) {
  .products-related__item-txt>.c-title+p {
    line-height: 1.9
  }
}

@media screen and (max-width: 799px) {
  .products-related__item-txt>.c-title+p {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .products-related__item-txt>.c-title+p {
    line-height: 1.9
  }
}

.products-related__item-txt>.c-text-sm {
  line-height: 1.8
}

.products-exampletitle {
  position: relative;
  margin-bottom: 6vw
}

@media screen and (min-width: 1800px) {
  .products-exampletitle {
    margin-bottom: 108px
  }
}

@media screen and (max-width: 399px) {
  .products-exampletitle {
    margin-bottom: 24px
  }
}

.products-exampletitle .c-button-A, .products-exampletitle .c-button-B {
  position: absolute;
  top: -4vw;
  right: 5vw
}

@media screen and (min-width: 1800px) {
  .products-exampletitle .c-button-A, .products-exampletitle .c-button-B {
    top: -72px;
    right: 90px
  }
}

@media screen and (max-width: 959px) {
  .products-exampletitle .c-button-A, .products-exampletitle .c-button-B {
    position: relative;
    top: auto;
    right: auto;
    display: block;
    margin: 0 0 0 auto;
    margin-top: -3vw
  }
}

@media screen and (max-width: 959px) and (min-width: 1800px) {
  .products-exampletitle .c-button-A, .products-exampletitle .c-button-B {
    margin-top: -54px
  }
}

@media screen and (max-width: 959px) and (max-width: 399px) {
  .products-exampletitle .c-button-A, .products-exampletitle .c-button-B {
    margin-top: -12px
  }
}

@media screen and (max-width: 599px) {
  .products-exampletitle .c-button-A, .products-exampletitle .c-button-B {
    margin-top: -1vw
  }
}

@media screen and (max-width: 599px) and (min-width: 1800px) {
  .products-exampletitle .c-button-A, .products-exampletitle .c-button-B {
    margin-top: -18px
  }
}

@media screen and (max-width: 599px) and (max-width: 399px) {
  .products-exampletitle .c-button-A, .products-exampletitle .c-button-B {
    margin-top: -4px
  }
}

.products-exampletitle .c-taglist-A {
  text-align: left
}

@media screen and (max-width: 959px) {
  .products-examplelist .c-taglist-A {
    margin-bottom: 5px
  }
}

@media screen and (max-width: 959px) {
  .products-examplelist .c-taglist-A>li {
    margin: 0 2px 5px
  }
}

.products-examplelist .c-taglist-A>li>a {
  font-size: 11px;
  font-size: .78571rem;
  line-height: 1.5;
  padding: 5px 10px
}

@media screen and (max-width: 959px) {
  .products-examplelist .c-taglist-A>li>a {
    line-height: 1.3
  }
}

@media screen and (max-width: 959px) {
  .products-examplelist .c-taglist-A>li>a {
    font-size: 10px;
    font-size: .71429rem;
    line-height: 1.5
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .products-examplelist .c-taglist-A>li>a {
    line-height: 1.3
  }
}

.products-exampledetailtitle {
  margin-bottom: 6vw
}

@media screen and (min-width: 1800px) {
  .products-exampledetailtitle {
    margin-bottom: 108px
  }
}

@media screen and (max-width: 399px) {
  .products-exampledetailtitle {
    margin-bottom: 24px
  }
}

.products-exampledetailtitle .c-taglist-A {
  text-align: center;
  margin-top: 1em
}

@media screen and (max-width: 599px) {
  .products-exampledetailbanner {
    margin-top: 30px
  }
}

@media screen and (max-width: 599px) {
  .products-exampledetailrelated .l-grid-1of3:nth-child(3) {
    display: none
  }
}

.support-movie__card {
  cursor: pointer
}

.support-movie__btn {
  text-align: right;
  margin-top: 20px
}

.company-message>.l-narrowbox>p {
  margin-bottom: 2.5em;
  line-height: 2.2
}

@media screen and (max-width: 599px) {
  .company-message>.l-narrowbox>p {
    margin-bottom: 2em;
    line-height: 2
  }
}

.company-message>.l-narrowbox>p:last-child {
  text-align: center;
  margin-top: 5em
}

@media screen and (max-width: 599px) {
  .company-message>.l-narrowbox>p:last-child {
    margin-top: 2.5em
  }
}

.company-message>.l-narrowbox>p:last-child>span {
  display: block;
  margin-top: 2em
}

@media screen and (max-width: 599px) {
  .company-message>.l-narrowbox>p:last-child>span {
    margin-top: .5em
  }
}

.company-identity__list {
  font-size: 16px;
  font-size: 1.14286rem;
  line-height: 1.8;
  counter-reset: num
}

@media screen and (max-width: 959px) {
  .company-identity__list {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .company-identity__list {
    font-size: 15px;
    font-size: 1.07143rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .company-identity__list {
    line-height: 1.9
  }
}

.company-identity__list>li+li {
  margin-top: 2em
}

@media screen and (max-width: 799px) {
  .company-identity__list>li+li {
    margin-top: 1.5em
  }
}

.company-identity__list>li {
  padding-left: 50px;
  position: relative
}

.company-identity__list>li:before {
  counter-increment: num 1;
  content: counter(num);
  font-size: 14px;
  font-size: 1rem;
  line-height: 28px;
  text-align: center;
  width: 30px;
  height: 30px;
  border-radius: 100%;
  background-color: transparent;
  border: 1px solid #1a1a1a;
  position: absolute;
  left: 0;
  top: 50%;
  margin-top: -15px
}

@media screen and (max-width: 959px) {
  .company-identity__list>li:before {
    line-height: 27.9px
  }
}

@media screen and (max-width: 799px) {
  .company-identity__list>li:before {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 28px
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .company-identity__list>li:before {
    line-height: 27.9px
  }
}

.company-overview .c-dlist-A>dd:last-child {
  border-bottom: none
}

.company-tiersbanner .c-banner-B {
  border-color: #1a1a1a
}

@media screen and (max-width: 399px) {
  .company-tiersbanner .c-banner-B {
    height: 150px
  }
}

.company-tiersbanner .c-banner-B:after {
  border-color: #1a1a1a
}

.company-tiersbanner .c-linkicon {
  background-color: #1a1a1a;
  border-color: #1a1a1a
}

.recruit-requirements__dlist>dt {
  width: 20%
}

.recruit-requirements__dlist>dd {
  padding-left: 24%
}

.recruit-entry>.c-island-A+.c-island-A, .recruit-entry>.c-banner-D+.c-island-A, .recruit-entry>.c-island-A+.c-banner-D, .recruit-entry>.c-banner-D+.c-banner-D {
  margin-top: 10px
}

@media screen and (max-width: 599px) {
  .recruit-entry>.c-island-A+.c-island-A, .recruit-entry>.c-banner-D+.c-island-A, .recruit-entry>.c-island-A+.c-banner-D, .recruit-entry>.c-banner-D+.c-banner-D {
    padding-bottom: 25px
  }
}

@media screen and (max-width: 799px) {
  .recruit-entry .c-title {
    font-size: 18px;
    font-size: 1.28571rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .recruit-entry .c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .recruit-entry .c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8;
    margin-bottom: -5px
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .recruit-entry .c-title {
    line-height: 1.6
  }
}

.recruit-entry__entry>p {
  text-align: left;
  margin-bottom: 20px
}

.recruit-entry__entry>p>b {
  font-size: 15px;
  font-size: 1.07143rem;
  line-height: 2;
  display: block;
  margin-bottom: 5px
}

@media screen and (max-width: 959px) {
  .recruit-entry__entry>p>b {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .recruit-entry__entry>p>b {
    font-size: 14px;
    font-size: 1rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .recruit-entry__entry>p>b {
    line-height: 1.9
  }
}

.access-info__map {
  padding-bottom: 50%;
  position: relative;
  margin-bottom: 20px
}

@media screen and (max-width: 599px) {
  .access-info__map {
    padding-bottom: 65%;
    margin-bottom: 15px
  }
}

.access-info__map>div {
  width: 100%;
  height: 100%;
  position: absolute;
  background-color: #f5f5f5
}

.access-info__fig {
  margin-bottom: 20px
}

@media screen and (max-width: 599px) {
  .access-info__fig {
    margin-bottom: 15px
  }
}

.access-info__fig+p {
  text-align: left;
  margin-bottom: 5px
}

.showroom-contact__num {
  margin: .8em -10px .3em
}

@media screen and (max-width: 799px) {
  .showroom-contact__num {
    text-align: center;
    margin-top: .8em
  }
}

@media screen and (max-width: 599px) {
  .showroom-contact__num {
    margin-top: .5em
  }
}

.showroom-contact__num>li {
  display: inline-block;
  margin: 3px 10px
}

.showroom-contact__num+p {
  text-align: left
}

@media screen and (max-width: 799px) {
  .showroom-contact__num+p {
    text-align: center
  }
}

.showroom-streetview {
  width: 100%;
  padding-bottom: 62.5%;
  position: relative
}

.showroom-streetview>div {
  width: 100%;
  height: 100%;
  position: absolute
}

.showroom-streetview>div>iframe {
  width: 100%;
  height: 100%;
  border: 0
}

.showroom-summary>p>a {
  text-decoration: underline
}

.showroom-summary>p+p {
  margin-top: 1em
}

.showroom-summary>.awards-list__logo {
  text-align: center;
  margin-top: 3vw
}

@media screen and (min-width: 1800px) {
  .showroom-summary>.awards-list__logo {
    margin-top: 54px
  }
}

@media screen and (max-width: 399px) {
  .showroom-summary>.awards-list__logo {
    margin-top: 12px
  }
}

@media screen and (max-width: 799px) {
  .showroom-summary>.awards-list__logo {
    margin: 2em 0 0 0
  }
}

.showroom-access__info._tokyo {
  margin-bottom: 0
}

.showroom-access__map {
  padding-bottom: 40%;
  position: relative
}

@media screen and (max-width: 599px) {
  .showroom-access__map {
    padding-bottom: 65%
  }
}

.showroom-access__map>div {
  width: 100%;
  height: 100%;
  position: absolute;
  background-color: #f5f5f5
}

@media screen and (max-width: 599px) {
  .showroom-access__info .c-title {
    margin-top: 10px
  }
}

.showroom-access__info .c-list-A {
  margin: 10px 0
}

.contact-method__list>li+li {
  margin-top: 20px
}

@media screen and (max-width: 599px) {
  .contact-method__list>li+li {
    margin-top: 10px
  }
}

.contact-method__list>li>.c-banner-B {
  background-color: #fff
}

@media screen and (max-width: 959px) {
  .contact-method__list>li>.c-banner-B>.c-banner-B__img {
    width: 150px
  }
}

@media screen and (max-width: 799px) {
  .contact-method__list>li>.c-banner-B {
    height: 150px
  }
}

@media screen and (max-width: 599px) {
  .contact-method__list>li>.c-banner-B {
    height: auto
  }
  .contact-method__list>li>.c-banner-B>.c-banner-B__txt {
    padding: 15px 40px 15px 20px
  }
  .contact-method__list>li>.c-banner-B>.c-banner-B__img {
    display: none
  }
}

.contact-method__list>li>.c-banner-A, .contact-method__list>li>.c-banner-B {
  background-color: #fff
}

.contact-type__list>li {
  font-size: 14px;
  font-size: 1rem;
  line-height: 2
}

@media screen and (max-width: 959px) {
  .contact-type__list>li {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .contact-type__list>li+li {
    border-left: none;
    border-top: 1px solid #d4d4d4
  }
}

.contact-type__list>li.l-grid-1of3:first-child {
  border: 2px solid #1476c7
}

@media screen and (max-width: 959px) {
  .contact-type__list>li.l-grid-1of3:first-child {
    margin-bottom: 3vw
  }
}

@media screen and (max-width: 599px) {
  .contact-type__list>li.l-grid-1of3:first-child {
    margin-bottom: 10px
  }
}

.contact-type__list>li.l-grid-1of3:first-child .c-button-A, .contact-type__list>li.l-grid-1of3:first-child .c-button-B {
  margin-bottom: .3em
}

@media screen and (max-width: 1199px) {
  .contact-type__list>li.l-grid-1of3:first-child .c-button-A, .contact-type__list>li.l-grid-1of3:first-child .c-button-B {
    min-width: 200px
  }
}

@media screen and (max-width: 959px) {
  .contact-type__list>li.l-grid-1of3:first-child .c-button-A, .contact-type__list>li.l-grid-1of3:first-child .c-button-B {
    min-width: 260px
  }
}

@media screen and (max-width: 599px) {
  .contact-type__list>li.l-grid-1of3:first-child .c-button-A, .contact-type__list>li.l-grid-1of3:first-child .c-button-B {
    min-width: 200px
  }
}

.contact-type__list>li.l-grid-1of3:nth-child(2) {
  border-left: none
}

@media screen and (max-width: 599px) {
  .contact-type__list>li.l-grid-1of3:nth-child(2) {
    border-top: none
  }
}

.contact-type__list>li>span>b {
  margin-bottom: 1em;
  display: block
}

.contact-type__list-num, .showroom-contact__num {
  font-size: 16px;
  font-size: 1.14286rem;
  line-height: 1.8;
  font-weight: 600;
  margin-bottom: .5em
}

@media screen and (max-width: 959px) {
  .contact-type__list-num, .showroom-contact__num {
    line-height: 1.6
  }
}

.contact-type__list-num>li>span, .showroom-contact__num>li>span {
  font-size: 25px;
  font-size: 1.78571rem;
  line-height: 1.6;
  display: inline-block
}

@media screen and (max-width: 959px) {
  .contact-type__list-num>li>span, .showroom-contact__num>li>span {
    line-height: 1.4
  }
}

.contact-inquiry-example .l-grid-1of2:first-child {
  position: relative
}

@media screen and (max-width: 599px) {
  .contact-inquiry-example .l-grid-1of2:first-child {
    padding-bottom: 35px
  }
}

.contact-inquiry-example .l-grid-1of2:first-child:after {
  content: "";
  border: 10px solid transparent;
  border-left: 12px solid #1476c7;
  position: absolute;
  right: 0;
  top: 45%;
  transform: translate(16px, -50%)
}

@media screen and (max-width: 599px) {
  .contact-inquiry-example .l-grid-1of2:first-child:after {
    border: 10px solid transparent;
    border-top: 12px solid #1476c7;
    right: auto;
    top: auto;
    left: 50%;
    bottom: 0;
    transform: translate(-50%, 0)
  }
}

.contact-inquiry-products .c-card-A {
  padding: 0
}

.contact-inquiry-products .c-card-A>figure {
  margin: 0 0 10px
}

.contact-form__form._confirm {
  max-width: 1600px
}

.contact-form__form._confirm .c-title-C {
  display: none
}

.contact-form__form-item, .contact-form__form._confirm .contact-form__form-item:last-of-type {
  margin-bottom: 9vw
}

@media screen and (min-width: 1800px) {
  .contact-form__form-item, .contact-form__form._confirm .contact-form__form-item:last-of-type {
    margin-bottom: 162px
  }
}

@media screen and (max-width: 399px) {
  .contact-form__form-item, .contact-form__form._confirm .contact-form__form-item:last-of-type {
    margin-bottom: 36px
  }
}

.contact-form__form._confirm .contact-form__form-item, .contact-form__form._confirm .contact-form__form-item:last-of-type {
  margin-bottom: 5vw
}

@media screen and (min-width: 1800px) {
  .contact-form__form._confirm .contact-form__form-item, .contact-form__form._confirm .contact-form__form-item:last-of-type {
    margin-bottom: 90px
  }
}

@media screen and (max-width: 399px) {
  .contact-form__form._confirm .contact-form__form-item, .contact-form__form._confirm .contact-form__form-item:last-of-type {
    margin-bottom: 20px
  }
}

.contact-form__form-item>.c-title {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8;
  text-align: center;
  margin-bottom: 3vw
}

@media screen and (max-width: 959px) {
  .contact-form__form-item>.c-title {
    line-height: 1.6
  }
}

@media screen and (min-width: 1800px) {
  .contact-form__form-item>.c-title {
    margin-bottom: 54px
  }
}

@media screen and (max-width: 399px) {
  .contact-form__form-item>.c-title {
    margin-bottom: 12px
  }
}

.contact-form__form-item>.c-title>span>b {
  font-size: 14px;
  font-size: 1rem;
  line-height: 2
}

@media screen and (max-width: 959px) {
  .contact-form__form-item>.c-title>span>b {
    line-height: 1.9
  }
}

@media screen and (max-width: 799px) {
  .contact-form__form-item>.c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8;
    margin-bottom: 5vw
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .contact-form__form-item>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) and (min-width: 1800px) {
  .contact-form__form-item>.c-title {
    margin-bottom: 90px
  }
}

@media screen and (max-width: 799px) and (max-width: 399px) {
  .contact-form__form-item>.c-title {
    margin-bottom: 20px
  }
}

@media screen and (max-width: 399px) {
  .contact-form__form-item>.c-title {
    font-size: 15px;
    font-size: 1.07143rem;
    line-height: 2
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .contact-form__form-item>.c-title {
    line-height: 1.9
  }
}

.contact-form__form._confirm .contact-form__form-item>.c-title {
  margin-bottom: 2em;
  padding-bottom: 1em;
  border-bottom: 1px solid #1a1a1a
}

@media screen and (max-width: 959px) {
  .contact-form__form._confirm .contact-form__form-item>.c-title {
    margin-bottom: 15px;
    padding-bottom: 10px
  }
}

@media screen and (max-width: 799px) {
  .contact-form__form._confirm .contact-form__form-item>.c-title {
    font-size: 15px;
    font-size: 1.07143rem;
    line-height: 2
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .contact-form__form._confirm .contact-form__form-item>.c-title {
    line-height: 1.9
  }
}

@media screen and (max-width: 399px) {
  .contact-form__form._confirm .contact-form__form-item>.c-title {
    font-size: 14px;
    font-size: 1rem;
    line-height: 2
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .contact-form__form._confirm .contact-form__form-item>.c-title {
    line-height: 1.9
  }
}

.contact-form__form._confirm .contact-form__form-item>.c-title>span {
  display: none
}

.contact-form__input>.error {
  color: red !important;
  font-weight: 600;
  display: block
}

.contact-form__input>.error:first-of-type {
  margin-top: .5em
}

.contact-form__form._confirm .contact-form__input {
  min-height: 2em
}

.contact-form__form._confirm .contact-form__input._center {
  text-align: center
}

.contact-form__form._input .contact-form__form-checklist {
  text-align: left;
  margin: 0 -5px
}

.contact-form__form._input .contact-form__form-checklist._center {
  text-align: center
}

.contact-form__form._input .contact-form__form-checklist>.error {
  margin-top: .5em
}

@media screen and (max-width: 599px) {
  .contact-form__form._input .contact-form__form-dlist._survey .contact-form__form-checklist {
    text-align: center
  }
}

.contact-form__form-checklist>span {
  line-height: 1;
  display: inline-block;
  margin: 0 3px 10px;
  margin-left: 5px !important
}

@media screen and (max-width: 959px) {
  .contact-form__form-checklist>span {
    margin: 0 2px 7px
  }
}

@media screen and (max-width: 799px) {
  .contact-form__form-checklist>span {
    margin-left: 3px !important
  }
}

html.touchevents .contact-form__form-checklist>span>label>* {
  pointer-events: none
}

.contact-form__form-checklist .mwform-checkbox-field-text, .contact-form__form-checklist .mwform-radio-field-text {
  font-size: 12px;
  font-size: .85714rem;
  line-height: 1.5;
  letter-spacing: 0;
  display: block;
  padding: 7px 15px;
  border: 2px solid #d4d4d4;
  background-color: #fff;
  border-radius: 20px;
  cursor: pointer;
  padding: 12px 20px;
  border-radius: 24px
}

@media screen and (max-width: 959px) {
  .contact-form__form-checklist .mwform-checkbox-field-text, .contact-form__form-checklist .mwform-radio-field-text {
    line-height: 1.3
  }
}

@media screen and (max-width: 799px) {
  .contact-form__form-checklist .mwform-checkbox-field-text, .contact-form__form-checklist .mwform-radio-field-text {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 1.5;
    padding: 5px 12px
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .contact-form__form-checklist .mwform-checkbox-field-text, .contact-form__form-checklist .mwform-radio-field-text {
    line-height: 1.3
  }
}

@media screen and (max-width: 799px) {
  .contact-form__form-checklist .mwform-checkbox-field-text, .contact-form__form-checklist .mwform-radio-field-text {
    padding: 10px 18px
  }
}

.contact-form__form-checklist input:checked+span, html.no-touchevents .contact-form__form-checklist .mwform-checkbox-field-text:hover, html.no-touchevents .contact-form__form-checklist .mwform-radio-field-text:hover {
  border-color: #1476c7
}

.contact-form__form-checklist input {
  position: absolute;
  left: -2em
}

.contact-form__form._input .contact-form__form-catalog {
  display: flex;
  flex-wrap: wrap;
  margin: -.7vw
}

.contact-form__form._input .contact-form__form-catalog._center {
  justify-content: center
}

@media screen and (min-width: 1800px) {
  .contact-form__form._input .contact-form__form-catalog {
    margin: -12.6px
  }
}

.contact-form__form-catalog>.mwform-checkbox-field {
  width: 40%;
  max-width: 500px;
  min-height: 140px;
  padding: .7vw;
  margin: 0 !important
}

@media screen and (min-width: 1800px) {
  .contact-form__form-catalog>.mwform-checkbox-field {
    padding: 12.6px
  }
}

@media screen and (max-width: 799px) {
  .contact-form__form-catalog>.mwform-checkbox-field {
    width: 50%;
    min-height: 120px
  }
}

@media screen and (max-width: 599px) {
  .contact-form__form-catalog>.mwform-checkbox-field {
    width: 100%;
    min-height: 100px
  }
}

.contact-form__form-catalog>.mwform-checkbox-field .mwform-checkbox-field-text {
  font-size: 14px;
  font-size: 1rem;
  line-height: 2;
  text-align: left;
  line-height: 1.8 !important;
  height: 100%;
  padding: 20px 100px 20px 30px;
  border-radius: 10px;
  background: url(../images/catalog/catalog-cover_products01.jpg) no-repeat 95% 50%;
  background-size: 80px auto
}

@media screen and (max-width: 959px) {
  .contact-form__form-catalog>.mwform-checkbox-field .mwform-checkbox-field-text {
    line-height: 1.9
  }
}

@media screen and (max-width: 959px) {
  .contact-form__form-catalog>.mwform-checkbox-field .mwform-checkbox-field-text {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 2;
    padding: 15px 100px 15px 20px
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .contact-form__form-catalog>.mwform-checkbox-field .mwform-checkbox-field-text {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .contact-form__form-catalog>.mwform-checkbox-field .mwform-checkbox-field-text {
    background-position: 98% 50%;
    padding-right: 90px
  }
}

@media screen and (max-width: 399px) {
  .contact-form__form-catalog>.mwform-checkbox-field .mwform-checkbox-field-text {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2;
    background-size: 70px auto;
    padding: 12px 80px 12px 15px
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .contact-form__form-catalog>.mwform-checkbox-field .mwform-checkbox-field-text {
    line-height: 1.9
  }
}

.contact-form__form-catalog__txt {
  text-align: center;
  margin-top: 2em
}

@media screen and (max-width: 599px) {
  .contact-form__form-catalog__txt {
    text-align: left
  }
  .contact-form__form-catalog__txt>br {
    display: none
  }
}

.contact-form__form._confirm .contact-form__form-catalog__txt {
  display: none
}

.contact-form__form-catalog>.mwform-checkbox-field:nth-child(2) .mwform-checkbox-field-text {
  background-image: url(../images/catalog/catalog-cover_tg01.jpg)
}

.contact-form__form-catalog>.mwform-checkbox-field:nth-child(3) .mwform-checkbox-field-text {
  background-image: url(../images/catalog/catalog-cover_global01.jpg)
}

.contact-form__form-catalog>.mwform-checkbox-field:nth-child(4) .mwform-checkbox-field-text {
  background-image: url(../images/catalog/catalog-cover_light01.jpg)
}

.contact-form__form-catalog>.mwform-checkbox-field:nth-child(5) .mwform-checkbox-field-text {
  background-image: url(../images/catalog/catalog-cover_industrial01.jpg)
}

.contact-form__required {
  color: red;
  font-weight: 600
}

.contact-form__form._confirm .contact-form__required {
  display: none
}

.contact-form__form._confirm .contact-form__form-dlist {
  margin-top: -2em
}

@media screen and (max-width: 959px) {
  .contact-form__form._confirm .contact-form__form-dlist {
    margin-top: -1em
  }
}

@media screen and (max-width: 799px) {
  .contact-form__form._confirm .contact-form__form-dlist {
    margin-top: 0
  }
}

.contact-form__form-dlist>dt {
  line-height: 1.6;
  position: absolute;
  padding: 3.2em 0 0 5%
}

@media screen and (max-width: 1199px) {
  .contact-form__form-dlist>dt {
    padding-left: 2%
  }
}

@media screen and (max-width: 799px) {
  .contact-form__form-dlist>dt {
    position: static;
    padding: 0 !important
  }
}

.contact-form__form-dlist._personal>dt:nth-of-type(2), .contact-form__form-dlist._personal>dt:nth-of-type(5), .contact-form__form-dlist._personal>dt:nth-of-type(10) {
  padding-top: 1.2em
}

.contact-form__form-dlist._survey>dt {
  padding-top: .7em
}

@media screen and (max-width: 799px) {
  .contact-form__form-dlist._survey>dt {
    text-align: center;
    margin-bottom: 10px;
    padding-bottom: 10px !important;
    border-bottom: 1px solid #d4d4d4
  }
}

.contact-form__form._confirm .contact-form__form-dlist>dt {
  padding-top: 2.3em
}

@media screen and (max-width: 799px) {
  .contact-form__form._confirm .contact-form__form-dlist>dt {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .contact-form__form._confirm .contact-form__form-dlist>dt {
    line-height: 1.9
  }
}

.contact-form__form._confirm .contact-form__form-dlist._personal>dt:nth-of-type(2), .contact-form__form._confirm .contact-form__form-dlist._personal>dt:nth-of-type(5), .contact-form__form._confirm .contact-form__form-dlist._personal>dt:nth-of-type(10) {
  padding-top: .4em
}

@media screen and (max-width: 799px) {
  .contact-form__form._confirm .contact-form__form-dlist>dt {
    text-align: left !important;
    padding: 15px 0 0 !important;
    margin-bottom: 0 !important;
    border-bottom: none;
    border-top: 1px solid #d4d4d4
  }
  .contact-form__form._confirm .contact-form__form-dlist>dt:first-child {
    border-top: none;
    padding-top: 0 !important
  }
}

@media screen and (max-width: 799px) {
  .contact-form__form-dlist>dt>br {
    display: none
  }
}

.contact-form__form._confirm .contact-form__form-dlist>dt>span {
  display: none
}

.contact-form__form-dlist>dd, .contact-form__form._confirm .contact-form__form-dlist>dd {
  padding: 2em 10% 2em 30%;
  border-top: 1px solid #d4d4d4
}

@media screen and (max-width: 1199px) {
  .contact-form__form-dlist>dd, .contact-form__form._confirm .contact-form__form-dlist>dd {
    padding-right: 5%;
    padding-left: 16em
  }
}

@media screen and (max-width: 959px) {
  .contact-form__form-dlist>dd, .contact-form__form._confirm .contact-form__form-dlist>dd {
    padding-right: 0
  }
}

@media screen and (max-width: 799px) {
  .contact-form__form-dlist>dd, .contact-form__form._confirm .contact-form__form-dlist>dd {
    padding: 5px 0 10px !important;
    border-top: none
  }
  .contact-form__form-dlist>dd:last-child, .contact-form__form._confirm .contact-form__form-dlist>dd:last-child {
    padding-bottom: 0 !important
  }
}

.contact-form__form-dlist._personal>dd:last-child {
  border-bottom: 1px solid #d4d4d4
}

@media screen and (max-width: 799px) {
  .contact-form__form-dlist._personal>dd:last-child {
    border-bottom: none
  }
}

.contact-form__form-dlist._personal>dd:nth-of-type(2), .contact-form__form-dlist._personal>dd:nth-of-type(5), .contact-form__form-dlist._personal>dd.contact-form__address, .contact-form__form-dlist._survey>dd {
  border-top: none;
  padding-top: 0
}

.contact-form__form-dlist._survey>dd:last-child {
  padding-bottom: 0
}

.contact-form__form._confirm .contact-form__form-dlist>dd:nth-of-type(1) {
  border-top: none
}

.contact-form__form._confirm .contact-form__form-dlist._personal>dd:last-child {
  border-bottom: none;
  padding-bottom: 0
}

.contact-form__form-dlist>dd>ul {
  margin-top: 1em
}

.contact-form__form-dlist>dd>ul>li {
  line-height: 1.6;
  text-indent: -1em;
  padding-left: 1em;
  margin-top: .5em
}

.contact-form__form._confirm .contact-form__form-dlist>dd>ul {
  display: none
}

.contact-form__form-dlist>dd.contact-form__name>i {
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  letter-spacing: 0;
  display: inline-block;
  margin: 12px .5em 0 0
}

@media screen and (max-width: 959px) {
  .contact-form__form-dlist>dd.contact-form__name>i {
    line-height: 1.9
  }
}

@media screen and (max-width: 959px) {
  .contact-form__form-dlist>dd.contact-form__name>i {
    margin-top: 14px
  }
}

.contact-form__form-dlist>dd.contact-form__name>.contact-form__input {
  display: inline-block;
  vertical-align: top;
  margin-right: 1em
}

@media screen and (max-width: 399px) {
  .contact-form__form-dlist>dd.contact-form__name>.contact-form__input {
    margin-right: .6em
  }
}

.contact-form__form-dlist>dd.contact-form__name>.contact-form__input:last-child {
  margin-right: 0 !important
}

.contact-form__form-dlist>dd.contact-form__name>.contact-form__input>input {
  width: 10em
}

@media screen and (max-width: 599px) {
  .contact-form__form-dlist>dd.contact-form__name>.contact-form__input>input {
    width: 8em
  }
}

@media screen and (max-width: 399px) {
  .contact-form__form-dlist>dd.contact-form__name>.contact-form__input>input {
    width: 6em
  }
}

.contact-form__form._confirm .contact-form__form-dlist>dd.contact-form__name>i {
  display: none
}

.contact-form__form._confirm .contact-form__form-dlist>dd.contact-form__name>.contact-form__input {
  margin-right: .5em
}

.contact-form__form-dlist>dd.contact-form__address {
  display: flex;
  align-items: center
}

.contact-form__form-dlist>dd.contact-form__address>i {
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  letter-spacing: 0;
  line-height: 1.4 !important;
  margin-right: 1em;
  flex-shrink: 0
}

@media screen and (max-width: 959px) {
  .contact-form__form-dlist>dd.contact-form__address>i {
    line-height: 1.9
  }
}

@media screen and (min-width: 600px) {
  .contact-form__form-dlist>dd.contact-form__address>i>br {
    display: none
  }
}

.contact-form__form._confirm .contact-form__form-dlist>dd.contact-form__address>i {
  display: none
}

.contact-form__form._confirm .contact-form__form-dlist>dd.contact-form__address+dd.contact-form__address {
  margin-top: -2em
}

@media screen and (max-width: 799px) {
  .contact-form__form._confirm .contact-form__form-dlist>dd.contact-form__address+dd.contact-form__address {
    margin-top: -15px
  }
}

.contact-form__form-dlist input[type="text"], .contact-form__form-dlist textarea {
  border: 2px solid #d4d4d4;
  border-radius: 5px;
  max-width: 40em
}

@media screen and (max-width: 799px) {
  .contact-form__form-dlist input[type="text"], .contact-form__form-dlist textarea {
    max-width: none
  }
}

.contact-form__form-dlist input[type="text"]:focus, .contact-form__form-dlist textarea:focus {
  border-color: #1476c7
}

.contact-form__form-dlist input[name="電話番号"] {
  max-width: 20em
}

.contact-form__form-dlist input[name="郵便番号"], .contact-form__form-dlist input[name="都道府県"], .contact-form__form-dlist input[name="市区町村"] {
  max-width: 10em
}

@media screen and (max-width: 799px) {
  dt.contact-form__files-ttl {
    border-top: 1px solid #d4d4d4 !important;
    padding-top: 10px !important
  }
}

.contact-form__form-dlist input[type="file"] {
  font-weight: 700;
  width: auto
}

@media screen and (max-width: 399px) {
  .contact-form__form-dlist input[type="file"] {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .contact-form__form-dlist input[type="file"] {
    line-height: 1.9
  }
}

.mwform-file-delete {
  line-height: .7;
  letter-spacing: 0;
  text-align: center;
  width: 1.3em;
  display: inline-block;
  padding: .3em;
  background-color: #d4d4d4;
  border-radius: 50%;
  margin-left: .5em
}

.contact-form__files>.contact-form__input {
  min-height: 0 !important;
  margin-bottom: 1em
}

.contact-form__files>.contact-form__input a {
  text-decoration: underline
}

.contact-form__form._confirm .contact-form__files>.contact-form__input {
  margin-bottom: .5em
}

@media screen and (max-width: 399px) {
  .contact-form__form._confirm .contact-form__files>.contact-form__input {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .contact-form__form._confirm .contact-form__files>.contact-form__input {
    line-height: 1.9
  }
}

.mw-wp-form_file>a:before {
  content: "添付ファイルを"
}

.contact-form__submit {
  display: flex;
  justify-content: center
}

.contact-form__submit>li {
  text-align: center;
  margin: 0 10px
}

@media screen and (max-width: 599px) {
  .contact-form__submit>li {
    margin: 0 5px
  }
}

@media screen and (max-width: 399px) {
  .contact-form__form._confirm .contact-form__submit>li>.c-submit-A {
    min-width: 130px
  }
}

.contact-form__submit>li:first-child>.c-submit-A {
  background-color: #767676;
  border-color: #767676
}

.contact-form__submit>li:first-child>.c-submit-A>i {
  color: #767676
}

.contact-form__submit>li:first-child>.c-submit-A>i:after {
  width: 6px;
  height: 6px;
  border: 3px #767676;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleX(0.8) translate(-50%, 0) rotate(45deg)
}

@media screen and (max-width: 799px) {
  .contact-form__submit>li:first-child>.c-submit-A>i:after {
    width: 4px;
    height: 4px;
    border: 3px #767676;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleX(0.8) translate(-50%, 0) rotate(45deg)
  }
}

.contact-form__form._input .contact-form__submit>li:first-child {
  display: none
}

.contact-form__catalog-outer {
  height: 0;
  overflow: hidden;
  transition: height .3s
}

.contact-form__catalog-outer._open {
  transition-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955)
}

.contact-form__form._confirm .contact-form__catalog-outer {
  height: auto
}

.contact-form__catalog-inner {
  padding-bottom: 1px
}

.contact-complete {
  text-align: center
}

.contact-complete>.c-title {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8;
  text-align: center;
  margin-bottom: 1.5em
}

@media screen and (max-width: 959px) {
  .contact-complete>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .contact-complete>.c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .contact-complete>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 399px) {
  .contact-complete>.c-title {
    font-size: 15px;
    font-size: 1.07143rem;
    line-height: 2
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .contact-complete>.c-title {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .faq-list {
    margin-bottom: 50px
  }
}

.faq-list__item {
  border: 1px #d4d4d4;
  border-style: solid none
}

.faq-list__item+.faq-list__item {
  margin-top: -1px
}

.faq-list__item-answer__trigger>.c-linktxt-B {
  font-size: 16px;
  font-size: 1.14286rem;
  line-height: 1.8;
  padding-top: 20px;
  padding-bottom: 20px;
  cursor: pointer
}

@media screen and (max-width: 959px) {
  .faq-list__item-answer__trigger>.c-linktxt-B {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) {
  .faq-list__item-answer__trigger>.c-linktxt-B {
    font-size: 15px;
    font-size: 1.07143rem;
    line-height: 2;
    padding-top: 15px;
    padding-bottom: 15px
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .faq-list__item-answer__trigger>.c-linktxt-B {
    line-height: 1.9
  }
}

@media screen and (max-width: 399px) {
  .faq-list__item-answer__trigger>.c-linktxt-B {
    font-size: 14px;
    font-size: 1rem;
    line-height: 2
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .faq-list__item-answer__trigger>.c-linktxt-B {
    line-height: 1.9
  }
}

.faq-list__item-answer {
  height: 0;
  overflow: hidden;
  transition: height .2s
}

.faq-list__item-answer__trigger._open+.faq-list__item-answer {
  transition-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955)
}

.faq-list__item-answer__trigger._open>.c-linktxt-B>span>i:after {
  transform: scaleY(0.8) translate(-50%, -50%) rotate(135deg);
  margin: -2px 0 0
}

.faq-list__item-answer__inner {
  padding: 0 0 20px 50px
}

@media screen and (max-width: 1199px) {
  .faq-list__item-answer__inner {
    padding-left: 45px
  }
}

@media screen and (max-width: 799px) {
  .faq-list__item-answer__inner {
    padding: 0 0 15px 40px;
    margin-top: -5px
  }
}

.faq-list__item-answer__inner>p>a {
  text-decoration: underline
}

.faq-list .l-column-sub {
  position: relative
}

.faq-list__cat {
  padding: 2vw;
  background-color: #f5f5f5
}

.faq-list__cat>.c-title {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8;
  margin-bottom: 1em
}

@media screen and (max-width: 959px) {
  .faq-list__cat>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) {
  .faq-list__cat>.c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8;
    margin-bottom: 1em
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .faq-list__cat>.c-title {
    line-height: 1.6
  }
}

@media screen and (min-width: 1800px) {
  .faq-list__cat {
    padding: 36px
  }
}

@media screen and (max-width: 959px) {
  .faq-list__cat {
    padding: 3vw
  }
}

@media screen and (max-width: 799px) {
  .faq-list__cat {
    padding: 20px
  }
}

@media screen and (max-width: 959px) {
  .faq-list__cat>.c-title {
    display: none
  }
}

.faq-list__cat-list {
  margin: 0 -5px -5px
}

.faq-list__cat-list>li {
  line-height: 1;
  display: inline-block;
  margin: 0 3px 10px
}

@media screen and (max-width: 959px) {
  .faq-list__cat-list>li {
    margin: 0 2px 7px
  }
}

.faq-list__cat-list>li>a {
  font-size: 12px;
  font-size: .85714rem;
  line-height: 1.5;
  letter-spacing: 0;
  display: block;
  padding: 7px 15px;
  border: 2px solid #d4d4d4;
  background-color: #fff;
  border-radius: 20px;
  cursor: pointer
}

@media screen and (max-width: 959px) {
  .faq-list__cat-list>li>a {
    line-height: 1.3
  }
}

@media screen and (max-width: 799px) {
  .faq-list__cat-list>li>a {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 1.5;
    padding: 5px 12px
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .faq-list__cat-list>li>a {
    line-height: 1.3
  }
}

.faq-list__cat-list>li>a._active, html.no-touchevents .faq-list__cat-list>li>a:hover {
  border-color: #1476c7
}

.news-item {
  position: relative
}

.news-item>.c-title-B {
  text-align: left
}

.news-item>.c-title-B:after {
  margin-left: 0
}

.news-item+.news-item {
  padding-top: 9vw
}

@media screen and (min-width: 1800px) {
  .news-item+.news-item {
    padding-top: 162px
  }
}

@media screen and (max-width: 399px) {
  .news-item+.news-item {
    padding-top: 36px
  }
}

@media screen and (max-width: 959px) {
  .news-item+.news-item {
    padding-top: 9vw !important
  }
}

@media screen and (max-width: 599px) {
  .news-item+.news-item {
    padding-top: 36px !important
  }
}

.news-item+.news-item:before {
  content: "";
  width: 76%;
  height: 1px;
  background-color: #d4d4d4;
  position: absolute;
  top: 0;
  left: 12%
}

@media screen and (max-width: 959px) {
  .news-item+.news-item:before {
    width: 88%;
    left: 6%
  }
}

@media screen and (max-width: 959px) {
  .news-item>.c-text-sm {
    margin-top: -2vw
  }
}

@media screen and (max-width: 399px) {
  .news-item>.c-text-sm {
    margin-top: -8px
  }
}

.news-item>p>.c-title {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8;
  display: inline-block;
  margin: 2em 0 1em
}

@media screen and (max-width: 959px) {
  .news-item>p>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) {
  .news-item>p>.c-title {
    font-size: 17px;
    font-size: 1.21429rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .news-item>p>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) {
  .news-item>p>.c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .news-item>p>.c-title {
    line-height: 1.6
  }
}

.news-item>p>a {
  color: #767676;
  text-decoration: underline
}

html.no-touchevents .news-item>p>a:hover {
  color: #1a1a1a
}

.news-item>p>img {
  max-width: 100%;
  width: auto;
  display: block;
  margin: .5em 0
}

.privacy-article>*+* {
  margin-top: 5vw
}

@media screen and (min-width: 1800px) {
  .privacy-article>*+* {
    margin-top: 90px
  }
}

@media screen and (max-width: 399px) {
  .privacy-article>*+* {
    margin-top: 20px
  }
}

.privacy-article .c-title {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8;
  margin-bottom: .5em
}

@media screen and (max-width: 959px) {
  .privacy-article .c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .privacy-article .c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .privacy-article .c-title {
    line-height: 1.6
  }
}

.privacy-article__dlist {
  padding-left: 2em;
  counter-reset: num
}

@media screen and (max-width: 799px) {
  .privacy-article__dlist {
    padding-left: 1.5em
  }
}

.privacy-article__dlist>dt:before {
  counter-increment: num 1;
  content: counter(num) ".";
  position: absolute;
  margin-left: -2em
}

@media screen and (max-width: 799px) {
  .privacy-article__dlist>dt:before {
    margin-left: -1.5em
  }
}

.privacy-article__dlist>dt {
  margin-top: 1.5em
}

@media screen and (max-width: 799px) {
  .privacy-article__dlist>dt {
    margin-top: 1em
  }
}

.privacy-article__olist {
  padding-left: 2em;
  counter-reset: num
}

@media screen and (max-width: 799px) {
  .privacy-article__olist {
    padding-left: 1.5em
  }
}

.privacy-article__olist>li:before {
  counter-increment: num 1;
  content: counter(num) ".";
  position: absolute;
  margin-left: -2em
}

@media screen and (max-width: 799px) {
  .privacy-article__olist>li:before {
    margin-left: -1.5em
  }
}

.privacy-article__olist>li {
  margin-top: 1.5em
}

@media screen and (max-width: 799px) {
  .privacy-article__olist>li {
    margin-top: 1em
  }
}

.terms-article>*+* {
  margin-top: 5vw
}

@media screen and (min-width: 1800px) {
  .terms-article>*+* {
    margin-top: 90px
  }
}

@media screen and (max-width: 399px) {
  .terms-article>*+* {
    margin-top: 20px
  }
}

.terms-article .c-title {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8;
  margin-bottom: .5em
}

@media screen and (max-width: 959px) {
  .terms-article .c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .terms-article .c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .terms-article .c-title {
    line-height: 1.6
  }
}

.terms-article>.c-list-A>li+li {
  margin-top: 1.5em
}

@media screen and (max-width: 799px) {
  .terms-article>.c-list-A>li+li {
    margin-top: 1em
  }
}

.terms-contact__txt {
  text-align: left
}

@media screen and (max-width: 599px) {
  .terms-contact__txt {
    text-align: center
  }
}

.terms-contact__txt>b {
  font-size: 15px;
  font-size: 1.07143rem;
  line-height: 2;
  display: block;
  margin-bottom: 3px
}

@media screen and (max-width: 959px) {
  .terms-contact__txt>b {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .terms-contact__txt>b {
    font-size: 14px;
    font-size: 1rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .terms-contact__txt>b {
    line-height: 1.9
  }
}

.terms-contact__txt>span {
  display: inline-block
}

.hspr-lead>.c-hero__img {
  padding-bottom: 32.8%
}

.hspr-lead>.c-textset-A>p {
  padding-left: 0
}

.hspr-lead>.c-textset-A>p:before {
  content: none
}

.hspr-pattern__line {
  padding-bottom: 0;
  margin-bottom: 0;
  border-bottom: 1px solid #d4d4d4
}

.hspr-pattern {
  margin-bottom: 0;
  position: relative
}

.hspr-pattern__nav {
  display: flex;
  justify-content: space-around;
  padding-bottom: 20px
}

@media screen and (max-width: 399px) {
  .hspr-pattern__nav>li:last-child {
    display: none
  }
}

.hspr-pattern__nav>li>a {
  font-size: 13px;
  font-size: .92857rem;
  line-height: 1.6;
  text-align: center;
  display: block;
  margin: 0 auto;
  width: 100px;
  height: 100px;
  border-radius: 100%;
  background-color: #fff;
  position: relative;
  transition: all .15s
}

@media screen and (max-width: 959px) {
  .hspr-pattern__nav>li>a {
    line-height: 1.4
  }
}

.hspr-pattern__nav>li>a:after {
  transition: all .15s
}

@media screen and (max-width: 799px) {
  .hspr-pattern__nav>li>a {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 1.6;
    letter-spacing: 0;
    width: 80px;
    height: 80px
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .hspr-pattern__nav>li>a {
    line-height: 1.4
  }
}

@media screen and (max-width: 599px) {
  .hspr-pattern__nav>li>a {
    font-size: 10px;
    font-size: .71429rem;
    line-height: 1.6;
    width: 65px;
    height: 65px
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .hspr-pattern__nav>li>a {
    line-height: 1.4
  }
}

html.no-touchevents .hspr-pattern__nav>li>a:hover {
  color: #fff;
  background-color: #1476c7
}

html.no-touchevents .hspr-pattern__nav>li>a:hover:after {
  border-top-color: #1476c7
}

.hspr-pattern._active-1>.hspr-pattern__nav>li:nth-child(1)>a, .hspr-pattern._active-2>.hspr-pattern__nav>li:nth-child(2)>a, .hspr-pattern._active-3>.hspr-pattern__nav>li:nth-child(3)>a, .hspr-pattern._active-4>.hspr-pattern__nav>li:nth-child(4)>a {
  color: #fff;
  background-color: #1476c7
}

.hspr-pattern._active-1>.hspr-pattern__nav>li:nth-child(1)>a:after, .hspr-pattern._active-2>.hspr-pattern__nav>li:nth-child(2)>a:after, .hspr-pattern._active-3>.hspr-pattern__nav>li:nth-child(3)>a:after, .hspr-pattern._active-4>.hspr-pattern__nav>li:nth-child(4)>a:after {
  border-top-color: #1476c7
}

.hspr-pattern__nav>li>a:after {
  content: "";
  border: 10px solid transparent;
  border-top: 18px solid #fff;
  position: absolute;
  bottom: -24px;
  left: 50%;
  margin-left: -10px
}

@media screen and (max-width: 799px) {
  .hspr-pattern__nav>li>a:after {
    bottom: -20px
  }
}

.hspr-pattern__nav>li:last-child>a:after {
  content: none
}

.hspr-pattern__nav>li:last-child>a:before {
  content: "";
  width: 6px;
  height: 6px;
  border: 3px #1476c7;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleY(0.8) translate(-50%, 0) rotate(135deg);
  position: absolute;
  bottom: 15px;
  left: 50%;
  transition: all .15s
}

@media screen and (max-width: 799px) {
  .hspr-pattern__nav>li:last-child>a:before {
    width: 4px;
    height: 4px;
    border: 2px #1476c7;
    border-style: solid solid none none;
    transform-origin: 50% 50%;
    transform: scaleY(0.8) translate(-50%, 0) rotate(135deg);
    bottom: 8px
  }
}

html.no-touchevents .hspr-pattern__nav>li:last-child>a:hover:before {
  border-color: #fff
}

.hspr-pattern__nav>li>a>span {
  width: 100%;
  position: absolute;
  top: 52%;
  left: 50%;
  transform: translate(-50%, -50%)
}

.hspr-pattern__img {
  width: 15%;
  position: absolute;
  right: 0;
  margin: 2% 5% 0 0;
  overflow: hidden
}

@media screen and (max-width: 1499px) {
  .hspr-pattern__img {
    width: 18%
  }
}

@media screen and (max-width: 1199px) {
  .hspr-pattern__img {
    margin-right: 3%
  }
}

@media screen and (max-width: 399px) {
  .hspr-pattern__img {
    display: none
  }
}

.hspr-pattern__img>li {
  width: 100%;
  position: absolute;
  top: 0;
  transform: translate(100%, 0)
}

.hspr-pattern__img>li._active {
  position: relative;
  z-index: 1;
  transform: translate(0, 0) !important;
  transition: transform .3s
}

.hspr-pattern__img>li._gone {
  transition: transform .2s
}

.hspr-pattern__fig {
  height: 360px;
  margin: 3vw auto 5vw;
  margin-right: 20%;
  display: flex;
  justify-content: space-between;
  position: relative
}

@media screen and (min-width: 1800px) {
  .hspr-pattern__fig {
    margin: 54px auto 90px;
    margin-right: 20%
  }
}

@media screen and (max-width: 799px) {
  .hspr-pattern__fig {
    height: 300px;
    margin-top: 10px;
    margin-bottom: 10px
  }
}

@media screen and (max-width: 599px) {
  .hspr-pattern__fig {
    height: 260px
  }
}

@media screen and (max-width: 399px) {
  .hspr-pattern__fig {
    height: 280px;
    margin-right: 0
  }
}

.hspr-pattern__fig>div {
  width: 48.5%;
  height: 100%;
  position: relative;
  z-index: 1;
  overflow: hidden
}

.hspr-pattern__fig>div:before, .hspr-pattern__fig>div:after {
  content: "";
  width: 0;
  height: 100%;
  border: 1px dashed #1a1a1a;
  position: absolute;
  z-index: -1;
  top: 0;
  left: 25%
}

.hspr-pattern__fig>div:after {
  height: 45%;
  left: 75%
}

.hspr-pattern__fig-item {
  font-size: 13px;
  font-size: .92857rem;
  line-height: 1.8;
  letter-spacing: 0;
  text-align: center;
  width: 47%;
  padding: 13px 10px;
  border: 1px solid #1a1a1a;
  border-radius: 5px;
  background-color: #fff;
  position: absolute;
  left: 0
}

@media screen and (max-width: 959px) {
  .hspr-pattern__fig-item {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) {
  .hspr-pattern__fig-item {
    padding: 8px 5px;
    font-size: 11px;
    font-size: .78571rem;
    line-height: 1.7
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .hspr-pattern__fig-item {
    line-height: 1.5
  }
}

@media screen and (max-width: 599px) {
  .hspr-pattern__fig-item {
    padding: 8px 5px;
    font-size: 10px;
    font-size: .71429rem;
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .hspr-pattern__fig-item {
    line-height: 1.4
  }
}

.hspr-pattern__fig-item._ceiling {
  width: 100%;
  top: 0
}

.hspr-pattern__fig-item._mid {
  top: 50%;
  margin-top: -35px
}

.hspr-pattern__fig-item._mid+.hspr-pattern__fig-item._mid {
  left: auto;
  right: 0
}

.hspr-pattern__fig-item._floor {
  bottom: 0
}

.hspr-pattern__fig-item>span {
  display: block;
  position: relative
}

.hspr-pattern__fig-item>span:first-child {
  margin-bottom: 26px
}

.hspr-pattern__fig-item>span:first-child:before {
  content: "";
  width: 100%;
  height: 1px;
  background-color: #1a1a1a;
  position: absolute;
  bottom: -13px;
  left: 0
}

.hspr-pattern__fig-item>span:first-child:after {
  content: "";
  width: 40px;
  height: 10px;
  background-color: #fff;
  position: absolute;
  bottom: -17px;
  left: 50%;
  margin-left: -20px
}

@media screen and (max-width: 799px) {
  .hspr-pattern__fig-item>span:first-child:after {
    width: 30px;
    margin-left: -15px
  }
}

.hspr-pattern__fig-item>span:last-child:before, .hspr-pattern__fig-item>span:last-child:after {
  content: "";
  width: 14px;
  height: 4px;
  background-color: #1a1a1a;
  position: absolute;
  top: -15px;
  left: 50%;
  margin-left: -7px
}

@media screen and (max-width: 799px) {
  .hspr-pattern__fig-item>span:last-child:before, .hspr-pattern__fig-item>span:last-child:after {
    width: 10px;
    height: 2px;
    margin-left: -4px
  }
}

.hspr-pattern__fig-item>span:last-child:after {
  width: 4px;
  height: 14px;
  top: -20px;
  left: 50%;
  margin-left: -2px
}

@media screen and (max-width: 799px) {
  .hspr-pattern__fig-item>span:last-child:after {
    width: 2px;
    height: 10px;
    top: -19px;
    margin-left: 0
  }
}

.hspr-pattern__cover {
  width: calc(23% + 1.6vw);
  height: calc(100% + 70px);
  position: absolute;
  z-index: 10;
  top: -20px;
  left: 0;
  overflow: hidden;
  margin-left: -.8vw;
  transition: left .2s
}

@media screen and (max-width: 799px) {
  .hspr-pattern__cover {
    top: -10px;
    height: calc(100% + 40px)
  }
}

.hspr-pattern._active-1 .hspr-pattern__cover {
  left: 0
}

.hspr-pattern._active-2 .hspr-pattern__cover {
  left: 25.7%
}

.hspr-pattern._active-3 .hspr-pattern__cover {
  left: 51.4%
}

.hspr-pattern._active-4 .hspr-pattern__cover {
  left: 77.1%
}

.hspr-pattern__cover>span {
  display: block;
  width: 100%;
  height: calc(100% - 40px);
  background-color: rgba(20, 118, 199, 0.1)
}

.hspr-pattern__cover>span:after {
  content: "";
  border: 150px solid transparent;
  border-top: 40px solid rgba(20, 118, 199, 0.1);
  position: absolute;
  left: 50%;
  bottom: -150px;
  margin-left: -150px
}

.hspr-pattern__tab {
  padding-top: 30px;
  margin-bottom: -1px;
  display: flex
}

@media screen and (min-width: 1500px) {
  .hspr-pattern__tab {
    padding-top: 0
  }
}

.hspr-pattern__tab>li {
  width: 20%;
  margin-left: -1px
}

@media screen and (max-width: 399px) {
  .hspr-pattern__tab>li {
    width: 25%
  }
}

.hspr-pattern__tab>li>a {
  font-size: 13px;
  font-size: .92857rem;
  line-height: 1.6;
  line-height: 1.6;
  text-align: center;
  display: flex;
  align-items: center;
  height: 100%;
  padding: 18px 5px;
  background-color: #fff;
  border: 1px solid #d4d4d4;
  position: relative
}

@media screen and (max-width: 959px) {
  .hspr-pattern__tab>li>a {
    line-height: 1.4
  }
}

.hspr-pattern__tab>li>a>span {
  width: 100%;
  display: inline-block
}

.hspr-pattern__tab>li>a:after {
  content: "";
  width: 0;
  height: 4px;
  background-color: #1476c7;
  position: absolute;
  top: 0;
  left: 0;
  transition: width .2s
}

@media screen and (max-width: 599px) {
  .hspr-pattern__tab>li>a {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .hspr-pattern__tab>li>a {
    line-height: 1.4
  }
}

html.no-touchevents .hspr-pattern__tab>li>a:hover:after {
  width: 100%
}

.hspr-pattern._active-1>.hspr-pattern__tab>li:nth-child(1)>a, .hspr-pattern._active-2>.hspr-pattern__tab>li:nth-child(2)>a, .hspr-pattern._active-3>.hspr-pattern__tab>li:nth-child(3)>a, .hspr-pattern._active-4>.hspr-pattern__tab>li:nth-child(4)>a {
  border-bottom-color: #fff
}

.hspr-pattern._active-1>.hspr-pattern__tab>li:nth-child(1)>a:after, .hspr-pattern._active-2>.hspr-pattern__tab>li:nth-child(2)>a:after, .hspr-pattern._active-3>.hspr-pattern__tab>li:nth-child(3)>a:after, .hspr-pattern._active-4>.hspr-pattern__tab>li:nth-child(4)>a:after {
  width: 100%
}

.hspr-pattern__banner {
  margin-top: 0
}

.hspr-summary__outer {
  position: relative;
  overflow: hidden
}

.hspr-summary {
  position: absolute;
  top: 0;
  transform: translate(100%, 0)
}

.hspr-summary._active {
  position: relative;
  z-index: 1;
  transform: translate(0, 0) !important;
  transition: transform .3s
}

.hspr-summary._gone {
  transition: transform .2s
}

.hspr-summary__txt .c-textset-B+.c-textset-B {
  margin-top: 2em
}

@media screen and (max-width: 799px) {
  .hspr-summary .l-grid-1of3>.c-title {
    text-align: center
  }
  .hspr-summary .l-grid-1of3>.c-title>br {
    display: none
  }
}

.hspr-products-search__img {
  width: 100%;
  max-width: 800px;
  height: 100%;
  position: absolute
}

.hspr-products-search__img>img {
  position: absolute
}

.hspr-products-search__img>._img1 {
  bottom: 0;
  left: 0;
  width: 23%;
  max-width: 180px;
  margin: 0 0 13% 10%
}

@media screen and (max-width: 959px) {
  .hspr-products-search__img>._img1 {
    width: 32%;
    margin-left: 0;
    min-width: 100px
  }
}

@media screen and (max-width: 599px) {
  .hspr-products-search__img>._img1 {
    width: 20%;
    margin: 0 0 11% 12%;
    min-width: 0
  }
}

.hspr-products-search__img>._img2 {
  left: 0;
  top: 0;
  width: 17%;
  max-width: 130px;
  margin: -10% 0 0 27%
}

@media screen and (max-width: 959px) {
  .hspr-products-search__img>._img2 {
    width: 23%;
    margin-left: 12%;
    min-width: 70px
  }
}

@media screen and (max-width: 599px) {
  .hspr-products-search__img>._img2 {
    width: 15%;
    margin: -5% 0 0 42%;
    min-width: 0
  }
}

.hspr-products-search__img>._img3 {
  top: 0;
  right: 0;
  width: 20%;
  max-width: 150px;
  margin: 12% 20% 0 0
}

@media screen and (max-width: 959px) {
  .hspr-products-search__img>._img3 {
    width: 28%;
    margin: 17% 15% 0 0;
    min-width: 82px
  }
}

@media screen and (max-width: 599px) {
  .hspr-products-search__img>._img3 {
    width: 18%;
    margin: -5% 12% 0 0;
    min-width: 0
  }
}

.hspr-products-category .l-columns {
  flex-direction: row-reverse
}

@media screen and (max-width: 959px) {
  .hspr-products-category .l-column-main {
    width: 70%;
    margin-left: 6%
  }
}

.hspr-products-category .l-column-sub {
  margin-bottom: 0
}

@media screen and (max-width: 959px) {
  .hspr-products-category .l-column-sub {
    width: 24%
  }
}

.hspr-products-category__img {
  height: 100%;
  padding: 2vw;
  background-color: #f5f5f5
}

.hspr-products-category__img>.c-title {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8;
  margin-bottom: 1em
}

@media screen and (max-width: 959px) {
  .hspr-products-category__img>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) {
  .hspr-products-category__img>.c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8;
    margin-bottom: 1em
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .hspr-products-category__img>.c-title {
    line-height: 1.6
  }
}

@media screen and (min-width: 1800px) {
  .hspr-products-category__img {
    padding: 36px
  }
}

@media screen and (max-width: 959px) {
  .hspr-products-category__img {
    padding: 3vw
  }
}

@media screen and (max-width: 799px) {
  .hspr-products-category__img {
    padding: 20px
  }
}

@media screen and (max-width: 799px) {
  .hspr-products-category__img {
    padding: 10px 3px
  }
}

.hspr-products-category__img-inner {
  overflow: hidden;
  height: calc( 100vh - 130px);
  min-height: 350px
}

.hspr-products-category__img-inner>div {
  min-width: 100px;
  max-width: 200px;
  height: 100%;
  margin: 0 auto;
  position: relative
}

.hspr-products-category__img-inner>div:before, .hspr-products-category__img-inner>div:after {
  content: "";
  width: 1px;
  height: 100%;
  background-color: #676767;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-3px, 0)
}

.hspr-products-category__img-inner>div:after {
  transform: translate(2px, 0)
}

.hspr-products-category__img-inner>div>img {
  position: absolute;
  z-index: 1
}

.hspr-products-category__img-inner>div>._img2 {
  top: 42%;
  transform: translate(0, -50%)
}

.hspr-products-category__img-inner>div>._img3 {
  bottom: 0
}

@media screen and (max-width: 799px) {
  .hspr-guide-wire .l-grid-1of2:first-child {
    padding-bottom: 0
  }
  .hspr-guide-wire .l-grid-1of2:last-child {
    padding-top: 0;
    margin-top: -1px
  }
  .hspr-guide-wire .l-grid-1of2:last-child .hspr-guide-wire__table tr:first-child {
    display: none
  }
}

.hspr-guide-wire__table th, .hspr-guide-wire__table td {
  font-weight: 600;
  width: 30%
}

.hspr-guide-wire__table th:first-child, .hspr-guide-wire__table td:first-child {
  width: 25%
}

.hspr-guide-wire__table th:last-child, .hspr-guide-wire__table td:last-child {
  width: 45%
}

.hspr-guide-wire__caption {
  font-weight: 600;
  text-align: center;
  margin: 7vw auto
}

@media screen and (min-width: 1800px) {
  .hspr-guide-wire__caption {
    margin: 126px auto
  }
}

@media screen and (max-width: 959px) {
  .hspr-guide-howto {
    min-height: 400px
  }
}

.hspr-guide-howto__title {
  width: 43%;
  min-width: 36em;
  height: 65%;
  min-height: 250px;
  background-color: #fff;
  position: absolute;
  top: 50%;
  left: 5vw;
  transform: translate(0, -50%)
}

@media screen and (min-width: 1800px) {
  .hspr-guide-howto__title {
    left: 90px
  }
}

@media screen and (max-width: 799px) {
  .hspr-guide-howto__title {
    width: 88%;
    min-width: 0;
    max-width: 36em;
    height: auto;
    min-height: 0;
    top: auto;
    left: 50%;
    bottom: 6vw;
    transform: translate(-50%, 0)
  }
}

@media screen and (max-width: 399px) {
  .hspr-guide-howto__title {
    bottom: 24px
  }
}

.hspr-guide-howto__title>div {
  width: 100%;
  position: absolute;
  top: 50%;
  transform: translate(0, -50%)
}

@media screen and (max-width: 799px) {
  .hspr-guide-howto__title>div {
    position: static;
    transform: none;
    padding: 20px 10px
  }
}

@media screen and (max-width: 799px) {
  .hspr-guide-howto__title>div>.c-title-B {
    font-size: 14px;
    font-size: 1rem;
    line-height: 2
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .hspr-guide-howto__title>div>.c-title-B {
    line-height: 1.9
  }
}

.hspr-guide-howto__title>div>.c-title {
  text-align: center;
  line-height: 1.4
}

@media screen and (max-width: 799px) {
  .hspr-guide-howto__title>div>.c-title {
    letter-spacing: 0
  }
}

@media screen and (max-width: 399px) {
  .hspr-guide-howto__title>div>.c-title>span {
    display: block
  }
  .hspr-guide-howto__title>div>.c-title>span>br {
    display: none
  }
}

@media screen and (min-width: 600px) {
  .hspr-guide-example>.c-title-C>span>br {
    display: none
  }
}

.hspr-purpose-sign__table td {
  vertical-align: top;
  padding: 20px 20px 15px
}

@media screen and (max-width: 799px) {
  .hspr-purpose-sign__table td {
    padding: 10px
  }
}

.hspr-purpose-sign__table td figcaption {
  color: #1a1a1a;
  font-weight: 600;
  line-height: 1.4;
  margin-top: .8em;
  white-space: nowrap
}

html.no-touchevents .hspr-purpose-sign__table a:hover>figcaption {
  text-decoration: underline
}

.hspr-purpose-sign__table._lots td>figure {
  margin: 0 auto;
  width: 90%
}

@media screen and (min-width: 800px) {
  .hspr-purpose-sign__table._lots td>figure {
    width: 80%
  }
}

.hspr-purpose-sign__table._lots td>figure figcaption {
  white-space: normal
}

.hspr-scene-gallerylist__list {
  margin-top: 2em
}

@media screen and (max-width: 959px) {
  .hspr-scene-gallerylist__list {
    margin-top: 1.5em
  }
}

.hspr-scene-gallerylist__list>li {
  text-align: left;
  padding: 13px 10px 11px;
  border-bottom: 1px solid #d4d4d4
}

.hspr-scene-gallerylist__list>li:first-child {
  border-top: 1px solid #d4d4d4
}

.hspr-scene-gallerylist__list>li>b {
  display: inline-block
}

@media screen and (max-width: 599px) {
  .hspr-scene-gallerylist__list>li>b {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 2;
    display: block
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .hspr-scene-gallerylist__list>li>b {
    line-height: 1.9
  }
}

.hspr-scene-gallerylist__list>li>span {
  font-size: 13px;
  font-size: .92857rem;
  line-height: 2;
  display: inline-block
}

@media screen and (max-width: 959px) {
  .hspr-scene-gallerylist__list>li>span {
    line-height: 1.9
  }
}

@media screen and (max-width: 799px) {
  .hspr-scene-gallerylist__list>li>span {
    font-size: 12px;
    font-size: .85714rem;
    line-height: 2
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .hspr-scene-gallerylist__list>li>span {
    line-height: 1.9
  }
}

@media screen and (max-width: 599px) {
  .hspr-scene-gallerylist__list>li>span {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2;
    display: block
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .hspr-scene-gallerylist__list>li>span {
    line-height: 1.9
  }
}

@media screen and (max-width: 959px) {
  .hspr-scene-gallerylist__img {
    width: 70%;
    max-width: 250px;
    margin: 0 auto -3vw
  }
}

@media screen and (max-width: 399px) {
  .hspr-scene-gallerylist__img {
    width: 80%;
    max-width: 200px;
    margin-bottom: -12px
  }
}

@media screen and (max-width: 959px) {
  .hspr-picturerail-lead .l-grids:last-child {
    margin-top: 2vw
  }
}

@media screen and (max-width: 599px) {
  .hspr-picturerail-lead .l-grids:last-child {
    margin-top: 15px
  }
}

.hspr-picturerail-lineup .c-card-A {
  padding-bottom: 50px;
  position: relative
}

@media screen and (max-width: 799px) {
  .hspr-picturerail-lineup .c-card-A {
    padding-bottom: 40px
  }
}

.hspr-picturerail-lineup .c-card-A:after {
  content: "";
  width: 8px;
  height: 8px;
  border: 3px #1476c7;
  border-style: solid solid none none;
  transform-origin: 50% 50%;
  transform: scaleY(0.8) translate(-50%, 0) rotate(135deg);
  position: absolute;
  left: 50%;
  bottom: 22px;
  margin-left: -4px
}

@media screen and (max-width: 799px) {
  .hspr-picturerail-lineup .c-card-A:after {
    bottom: 19px
  }
}

.hspr-picturerail-lineup .c-card-A>.c-title {
  text-align: center
}

@media screen and (max-width: 599px) {
  .hspr-picturerail-lineup .c-card-A>.c-title {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .hspr-picturerail-lineup .c-card-A>.c-title {
    line-height: 1.9
  }
}

@media screen and (min-width: 400px) {
  .hspr-picturerail-lineup .c-title-C>span>br {
    display: none
  }
}

@media screen and (max-width: 799px) {
  .hspr-picturerail-type__example {
    display: flex
  }
}

@media screen and (max-width: 399px) {
  .hspr-picturerail-type__example {
    display: block
  }
}

.hspr-picturerail-type__example>* {
  margin-right: 3vw
}

@media screen and (min-width: 1800px) {
  .hspr-picturerail-type__example>* {
    margin-right: 54px
  }
}

@media screen and (max-width: 799px) {
  .hspr-picturerail-type__example>* {
    width: 50%;
    margin-right: 0;
    padding-right: 1.8vw
  }
}

@media screen and (max-width: 399px) {
  .hspr-picturerail-type__example>* {
    width: auto;
    padding: 0 !important
  }
}

@media screen and (max-width: 799px) {
  .hspr-picturerail-type__example._single {
    margin-bottom: -20px
  }
  .hspr-picturerail-type__example._single>* {
    width: 100%;
    max-width: 500px;
    margin: 0 auto;
    padding-right: 0
  }
}

.hspr-picturerail-type__example>*+* {
  margin-top: 20px
}

@media screen and (max-width: 799px) {
  .hspr-picturerail-type__example>*+* {
    margin-top: 0 !important;
    padding-right: 0;
    padding-left: 1.8vw
  }
}

@media screen and (max-width: 399px) {
  .hspr-picturerail-type__example>*+* {
    margin-top: 20px !important
  }
}

.hspr-picturerail-type__example>figure+.c-textset-B {
  margin-top: 40px
}

.hspr-picturerail-type__list-lead {
  margin-bottom: 35px
}

@media screen and (max-width: 959px) {
  .hspr-picturerail-type__list-lead {
    margin-bottom: 25px
  }
}

.hspr-picturerail-type__list-lead>.c-title {
  font-size: 18px;
  font-size: 1.28571rem;
  line-height: 1.8;
  margin-bottom: 1em
}

@media screen and (max-width: 959px) {
  .hspr-picturerail-type__list-lead>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 959px) {
  .hspr-picturerail-type__list-lead>.c-title {
    font-size: 17px;
    font-size: 1.21429rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 959px) and (max-width: 959px) {
  .hspr-picturerail-type__list-lead>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 799px) {
  .hspr-picturerail-type__list-lead>.c-title {
    font-size: 16px;
    font-size: 1.14286rem;
    line-height: 1.8
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .hspr-picturerail-type__list-lead>.c-title {
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) {
  .hspr-picturerail-type__list-lead>.c-title {
    font-size: 15px;
    font-size: 1.07143rem;
    line-height: 2;
    line-height: 1.6
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .hspr-picturerail-type__list-lead>.c-title {
    line-height: 1.9
  }
}

.hspr-picturerail-type__list>.c-productslist-B+.c-productslist-B {
  margin-top: 35px
}

@media screen and (max-width: 959px) {
  .hspr-picturerail-type__list>.c-productslist-B+.c-productslist-B {
    margin-top: 25px
  }
}

.hspr-picturerail-type__list>.c-productslist-B>div>p {
  border-bottom: none;
  padding-bottom: 0
}

.hr-structure__table th {
  width: 40%
}

.hr-structure__table th:first-child {
  width: 20%
}

.hr-structure__table td {
  text-align: left;
  vertical-align: top;
  padding: 20px
}

@media screen and (max-width: 799px) {
  .hr-structure__table td {
    padding: 10px
  }
}

.hr-structure__table td:first-child {
  text-align: center;
  vertical-align: middle;
  padding: 10px
}

@media screen and (max-width: 799px) {
  .hr-structure__table td:first-child {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2;
    padding: 5px
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .hr-structure__table td:first-child {
    line-height: 1.9
  }
}

.hr-structure__table td>*+* {
  margin-top: 1em
}

.hr-structure__table img {
  max-width: 200px
}

@media screen and (max-width: 959px) {
  .hr-structure__table ._md-1of1+._md-1of1 {
    padding-top: 0
  }
}

@media screen and (max-width: 599px) {
  .hr-structure__table ._xs-1of1+._xs-1of1 {
    padding-top: 0
  }
}

@media screen and (max-width: 959px) {
  .hr-structure__table-img, .hr-structure__table-img2 {
    max-width: 200px;
    margin: 0 auto
  }
}

@media screen and (max-width: 599px) {
  .hr-structure__table-img, .hr-structure__table-img2 {
    max-width: 150px
  }
}

@media screen and (max-width: 599px) {
  .hr-structure__table-img2 {
    padding: 0 5%
  }
}

.hr-pattern__table th:nth-child(2), .hr-pattern__table th:nth-child(4) {
  width: 34%
}

@media screen and (max-width: 799px) {
  .hr-pattern__table th:nth-child(2), .hr-pattern__table th:nth-child(4) {
    width: 34.5%
  }
}

@media screen and (max-width: 599px) {
  .hr-pattern__table th:nth-child(2), .hr-pattern__table th:nth-child(4) {
    width: 34.2%
  }
}

.hr-pattern__table th:nth-child(3) {
  width: 18.2%
}

@media screen and (max-width: 799px) {
  .hr-pattern__table th:nth-child(3) {
    width: 17.2%
  }
}

@media screen and (max-width: 599px) {
  .hr-pattern__table th:nth-child(3) {
    width: 17.8%
  }
}

.hr-pattern__table td {
  vertical-align: top;
  padding: 20px 20px 10px
}

@media screen and (max-width: 799px) {
  .hr-pattern__table td {
    padding: 10px
  }
}

.hr-pattern__table td:first-child {
  padding: 10px;
  vertical-align: middle
}

@media screen and (max-width: 799px) {
  .hr-pattern__table td:first-child {
    font-size: 11px;
    font-size: .78571rem;
    line-height: 2;
    padding: 5px
  }
}

@media screen and (max-width: 799px) and (max-width: 959px) {
  .hr-pattern__table td:first-child {
    line-height: 1.9
  }
}

.hr-pattern__table figcaption {
  color: #1a1a1a;
  font-weight: 600;
  margin-top: .5em;
  white-space: nowrap
}

html.no-touchevents .hr-pattern__table a:hover>figcaption {
  text-decoration: underline
}

.hr-products-search__img {
  width: 100%;
  max-width: 800px;
  height: 100%;
  position: absolute
}

.hr-products-search__img>img {
  position: absolute
}

.hr-products-search__img>._img1 {
  top: 0;
  left: 0;
  width: 35%;
  margin: 25% 0 0 10%
}

@media screen and (max-width: 959px) {
  .hr-products-search__img>._img1 {
    width: 45%;
    margin: 30% 0 0 0;
    min-width: 125px
  }
}

@media screen and (max-width: 599px) {
  .hr-products-search__img>._img1 {
    width: 28%;
    margin: 9% 0 0 7%;
    min-width: 0
  }
}

.hr-products-search__img>._img2 {
  left: 0;
  top: 0;
  width: 33%;
  margin: -5% 0 0 30%
}

@media screen and (max-width: 959px) {
  .hr-products-search__img>._img2 {
    width: 42%;
    min-width: 130px
  }
}

@media screen and (max-width: 599px) {
  .hr-products-search__img>._img2 {
    width: 27%;
    margin: -3% 0 0 38%;
    min-width: 0
  }
}

.hr-products-search__img>._img3 {
  bottom: 0;
  right: 0;
  width: 33%;
  margin: 0 17% 12% 0
}

@media screen and (max-width: 959px) {
  .hr-products-search__img>._img3 {
    width: 46%;
    margin: 0 12% 12% 0;
    min-width: 125px
  }
}

@media screen and (max-width: 599px) {
  .hr-products-search__img>._img3 {
    width: 27%;
    margin: 0 7% 5% 0;
    min-width: 0
  }
}

.hr-products-category__img {
  padding: 3vw 7vw;
  background-color: #f5f5f5;
  margin-top: 4vw
}

@media screen and (min-width: 1800px) {
  .hr-products-category__img {
    margin-top: 72px
  }
}

@media screen and (max-width: 399px) {
  .hr-products-category__img {
    margin-top: 16px
  }
}

@media screen and (min-width: 1800px) {
  .hr-products-category__img {
    padding: 54px 126px
  }
}

@media screen and (max-width: 799px) {
  .hr-products-category__img {
    padding: 3vw 2vw
  }
}

.hr-products-category__img>div {
  max-width: 900px;
  margin: 0 auto
}

@media screen and (max-width: 959px) {
  .hr-products-category__img._img2 {
    padding: 3vw 5vw
  }
}

@media screen and (max-width: 599px) {
  .hr-products-category__img._img2 {
    padding: 5vw
  }
}

@media screen and (max-width: 599px) {
  .hr-products-category__img._img2>div {
    max-width: 240px
  }
}

@media screen and (max-width: 599px) {
  .u-fs-13__xs {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 2
  }
}

@media screen and (max-width: 599px) and (max-width: 959px) {
  .u-fs-13__xs {
    line-height: 1.9
  }
}

@media screen and (max-width: 399px) {
  .u-fs-13__xxs {
    font-size: 13px;
    font-size: .92857rem;
    line-height: 2
  }
}

@media screen and (max-width: 399px) and (max-width: 959px) {
  .u-fs-13__xxs {
    line-height: 1.9
  }
}

.u-tal-l {
  text-align: left
}

.u-tal-r {
  text-align: right
}

.u-tal-c {
  text-align: center
}

.u-tal-j {
  text-align: justify;
  text-justify: inter-ideograph
}

@media screen and (max-width: 959px) {
  .u-tal-l__md {
    text-align: left
  }
}

@media screen and (max-width: 959px) {
  .u-tal-r__md {
    text-align: right
  }
}

@media screen and (max-width: 959px) {
  .u-tal-c__md {
    text-align: center
  }
}

@media screen and (max-width: 959px) {
  .u-tal-j__md {
    text-align: justify;
    text-justify: inter-ideograph
  }
}

@media screen and (max-width: 799px) {
  .u-tal-l__sm {
    text-align: left
  }
}

@media screen and (max-width: 799px) {
  .u-tal-r__sm {
    text-align: right
  }
}

@media screen and (max-width: 799px) {
  .u-tal-c__sm {
    text-align: center
  }
}

@media screen and (max-width: 799px) {
  .u-tal-j__sm {
    text-align: justify;
    text-justify: inter-ideograph
  }
}

@media screen and (max-width: 599px) {
  .u-tal-l__xs {
    text-align: left
  }
}

@media screen and (max-width: 599px) {
  .u-tal-r__xs {
    text-align: right
  }
}

@media screen and (max-width: 599px) {
  .u-tal-c__xs {
    text-align: center
  }
}

@media screen and (max-width: 599px) {
  .u-tal-j__xs {
    text-align: justify;
    text-justify: inter-ideograph
  }
}

@media screen and (max-width: 399px) {
  .u-tal-l__xxs {
    text-align: left
  }
}

@media screen and (max-width: 399px) {
  .u-tal-r__xxs {
    text-align: right
  }
}

@media screen and (max-width: 399px) {
  .u-tal-c__xxs {
    text-align: center
  }
}

@media screen and (max-width: 399px) {
  .u-tal-j__xxs {
    text-align: justify;
    text-justify: inter-ideograph
  }
}

.u-tcl-black, .u-tcl-black a {
  color: #1a1a1a
}

.u-tcl-bgray, .u-tcl-bgray a {
  color: #767676
}

.u-tcl-red, .u-tcl-red a {
  font-weight: 700;
  color: red
}

.u-fw-n {
  font-weight: 400
}

.u-fw-b {
  font-weight: 700
}

.u-mt-0 {
  margin-top: 0
}

.u-mt-1em {
  margin-top: 1em
}

.u-mt-2em {
  margin-top: 2em
}

.u-mb-0 {
  margin-bottom: 0
}

.u-mb-1em {
  margin-bottom: 1em
}

.u-mb-2em {
  margin-bottom: 2em
}

.u-dp-ib {
  display: inline-block
}

.u-dp-b {
  display: block
}

.u-dp-no {
  display: none
}

@media screen and (max-width: 599px) {
  .u-dp-ib__xs {
    display: inline-block
  }
}

@media screen and (max-width: 599px) {
  .u-dp-i__xs {
    display: inline
  }
}

@media screen and (max-width: 599px) {
  .u-dp-no__xs {
    display: none
  }
}

.u-pos-r {
  position: relative
}

.u-pos-a {
  position: absolute
}

@media screen and (max-width: 959px) {
  .u-nobr__md {
    display: none
  }
}

@media screen and (max-width: 799px) {
  .u-nobr__sm {
    display: none
  }
}

@media screen and (max-width: 599px) {
  .u-nobr__xs {
    display: none
  }
}

@media screen and (min-width: 800px) {
  .u-br__sm {
    display: none
  }
}

@media screen and (min-width: 600px) {
  .u-br__xs {
    display: none
  }
}

img[data-action="zoom"] {
  cursor: pointer;
  cursor: -webkit-zoom-in;
  cursor: -moz-zoom-in
}

.zoom-img, .zoom-img-wrap {
  position: relative;
  z-index: 666;
  transition: all 300ms
}

img.zoom-img {
  cursor: pointer;
  cursor: -webkit-zoom-out;
  cursor: -moz-zoom-out
}

.zoom-overlay {
  z-index: 420;
  background: #fff;
  background: rgba(255, 255, 255, 0.6);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
  filter: "alpha(opacity=0)";
  opacity: 0;
  transition: opacity 300ms
}

.zoom-overlay-open .zoom-overlay {
  filter: "alpha(opacity=100)";
  opacity: 1
}

.zoom-overlay-open, .zoom-overlay-transitioning {
  cursor: default
}

@keyframes modal-video {
  from {
    opacity: 0
  }
  to {
    opacity: 1
  }
}

@keyframes modal-video-inner {
  from {
    transform: translate(0, 70px)
  }
  to {
    transform: translate(0, 0)
  }
}

.modal-video {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.9);
  z-index: 1000000;
  cursor: pointer;
  opacity: 1;
  animation-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  animation-duration: .2s;
  animation-name: modal-video;
  transition: opacity .2s cubic-bezier(0.25, 0.46, 0.45, 0.94)
}

.modal-video-close {
  opacity: 0
}

.modal-video-close .modal-video-movie-wrap {
  transform: translate(0, 100px)
}

.modal-video-body {
  max-width: 940px;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  display: table
}

@media all and (orientation: landscape) {
  .modal-video-body {
    width: 80%
  }
}

.modal-video-inner {
  display: table-cell;
  vertical-align: middle;
  width: 100%;
  height: 100%
}

.modal-video-movie-wrap {
  width: 100%;
  height: 0;
  position: relative;
  padding-bottom: 56.25%;
  background-color: #000;
  animation-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  animation-duration: .2s;
  animation-name: modal-video-inner;
  transform: translate(0, 0);
  transition: transform .2s cubic-bezier(0.25, 0.46, 0.45, 0.94)
}

.modal-video-movie-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.modal-video-close-btn {
  position: absolute;
  z-index: 2;
  top: -35px;
  right: -35px;
  display: inline-block;
  width: 35px;
  height: 35px;
  overflow: hidden;
  border: none;
  background: transparent
}

.modal-video-close-btn:before {
  transform: rotate(45deg)
}

.modal-video-close-btn:after {
  transform: rotate(-45deg)
}

.modal-video-close-btn:before, .modal-video-close-btn:after {
  content: '';
  position: absolute;
  height: 2px;
  width: 100%;
  top: 50%;
  left: 0;
  margin-top: -1px;
  background: #fff;
  border-radius: 5px;
  margin-top: -6px
}

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

.slick-list {
  position: relative;
  display: block;
  overflow: hidden;
  margin: 0;
  padding: 0;
  z-index: 1
}

.slick-list:focus {
  outline: none
}

.slick-list.dragging {
  cursor: pointer;
  cursor: hand
}

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

.slick-track {
  position: relative;
  top: 0;
  left: 0;
  display: block
}

.slick-track:before, .slick-track:after {
  display: table;
  content: ''
}

.slick-track:after {
  clear: both
}

.slick-loading .slick-track {
  visibility: hidden
}

.slick-slide {
  display: none;
  float: left;
  height: 100%;
  min-height: 1px
}

[dir='rtl'] .slick-slide {
  float: right
}

.slick-slide img {
  display: block
}

.slick-slide.slick-loading img {
  display: none
}

.slick-slide.dragging img {
  pointer-events: none
}

.slick-initialized .slick-slide {
  display: block
}

.slick-loading .slick-slide {
  visibility: hidden
}

.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent
}

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