.c-card--sa .c-card__link:before {
  padding: .5em 2em;
  background: rgba(255, 255, 255, 0.2);
  border: 1px solid #fff;
  font-size: 1.4rem;
  text-align: center;
  word-break: keep-all
}

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

body {
  line-height: 1
}

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

nav ul {
  list-style: none
}

blockquote, q {
  quotes: none
}

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

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent
}

ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none
}

mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold
}

del {
  text-decoration: line-through
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help
}

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

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0
}

input, select {
  vertical-align: middle
}

* {
  box-sizing: border-box
}

html {
  font-size: 62.5%;
  color: #3f2b00;
  font-family: "Noto Sans Japanese", "\6E38\30B4\30B7\30C3\30AF", YuGothic, "\30D2\30E9\30AE\30CE\89D2\30B4   Pro W3", "Hiragino Kaku Gothic Pro", "\30E1\30A4\30EA\30AA", Meiryo, "\FF2D\FF33   \FF30\30B4\30B7\30C3\30AF", sans-serif;
  background: white;
  -webkit-font-smoothing: antialiased
}

body {
  font-size: 1.6rem;
  line-height: 1.5;
  animation: fade-in 1s ease
}

@keyframes fade-in {
  0% {
    opacity: 0
  }

  100% {
    opacity: 1
  }
}

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

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

a {
  color: inherit;
  text-decoration: none
}

p+p {
  margin-top: 1em
}

small {
  font-size: 80%
}

.slide-in {
  opacity: 0;
  transform: translate3d(0, 20px, 0);
  transition: all .8s ease
}

.slide-in.active {
  opacity: 1;
  transform: translate3d(0, 0, 0)
}

.o-header {
  z-index: 200;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  padding: 1em 0;
  color: #fff
}

@media only screen and (max-width: 767px) {
  .o-header {
    position: fixed;
    padding: .5em 0;
    transition: all .3s ease
  }

  .o-header.bg-active {
    background: #31424e;
    box-shadow: 0px 1px 10px rgba(0, 0, 0, 0.5)
  }
}

.o-header a {
  color: #fff;
  text-decoration: none
}

.o-header__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 1em;
  display: flex;
  justify-content: space-between
}

.o-header__logo-area {
  display: flex;
  align-items: center
}

@media only screen and (max-width: 767px) {
  .o-header__logo-area {
    width: 40%
  }

  .o-header__logo-area img {
    width: 100%;
    height: auto;
    vertical-align: middle
  }
}

.o-nav {
  font-size: 80px;
  padding: 0.5em 1em;
  margin: 0 auto;
  width: 2500px;
  text-align: right;
}

@media only screen and (max-width: 767px) {
  .o-nav {
    box-sizing: border-box;
    width: 100%;
    font-size: 16px;
  }
}

.o-nav__list {
  display: flex;
  align-items: center;
  height: 100%
}

.o-nav__item {
  position: relative
}

.o-nav__item:hover .o-nav__child-list, .o-nav__item:focus .o-nav__child-list {
  height: auto;
  opacity: 1;
  visibility: visible;
  white-space: nowrap
}

.o-nav__item+.o-nav__item {
  margin-left: 1.5em
}

.o-nav__child-list {
  position: absolute;
  top: 100%;
  right: 0;
  margin: 0;
  padding: .5em 0;
  visibility: hidden;
  opacity: 0;
  height: 0;
  text-align: right;
  transition: opacity .2s ease
}

.o-nav__child-list li+li {
  margin-top: .5em
}

.o-nav__link {
  position: relative
}

.o-nav__link:after {
  position: absolute;
  display: inline-block;
  content: "";
  top: 100%;
  left: 0;
  width: 100%;
  height: 1px;
  background: #fff;
  opacity: 0;
  transition: opacity .2s ease
}

.o-nav__link:hover:after, .o-nav__link:focus:after, .o-nav__link--current:after {
  opacity: 1
}

.o-mobile-nav {
  z-index: 100;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: translate3d(0, 0, 0);
  transition: transform .3s ease;
  background: #31424e;
  color: #fff
}

.o-mobile-nav a {
  color: #fff;
  text-decoration: none
}

.o-mobile-nav[aria-hidden="true"] {
  transform: translate3d(100%, 0, 0)
}

.o-mobile-nav__button {
  display: none;
  width: 35px;
  height: 35px;
  margin: auto 0;
  background: url(../img/common/icon-menu.svg) no-repeat;
  background-size: contain;
  background-position: center;
  font: 0/0 a;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 0
}

@media only screen and (max-width: 1023px) {
  .o-mobile-nav__button {
    display: block
  }
}

.o-mobile-nav ul, .o-mobile-nav ol {
  list-style: none
}

.o-mobile-nav__list {
  max-height: 100%;
  padding: 3em 1em 1em;
  font-size: 2rem;
  overflow: auto
}

.o-mobile-nav__item+.o-mobile-nav__item {
  margin-top: .5em
}

.o-mobile-nav__child-list {
  padding-left: 1em;
  font-size: 1.8rem
}

.o-hero {
  position: relative;
  width: 100%;
  height: 850px;
  padding: 0 1em;
  background-color: #1e3545;
  background-image: url(../img/top/main.jpg);
  background-repeat: repeat, no-repeat;
  background-size: cover;
  background-position: top;
  color: #fff;
  overflow: hidden
}

@media only screen and (max-width: 760px) {
  .o-hero {
    height: auto
  }
}

.o-hero:before, .o-hero:after {
  position: absolute;
  display: block;
  content: "";
  width: 100%;
  height: 0
}

.o-hero:before {
  top: 0;
  left: 0;
  box-shadow: 0px 0px 100px 140px rgba(0, 0, 0, 0.4)
}

.o-hero:after {
  bottom: 0;
  left: 0;
  box-shadow: 0px 0px 120px 120px rgba(30, 53, 69, 0.8)
}

@media only screen and (max-width: 767px) {
  .o-hero:after {
    box-shadow: 0px 0px 40px 40px rgba(30, 53, 69, 0.8)
  }
}

.o-hero--child {
  height: auto
}

.o-hero--child:after {
  content: none
}

.o-hero--child .o-hero__inner {
  margin-top: 75px;
  margin-bottom: 6em
}

@media only screen and (max-width: 767px) {
  .o-hero--child .o-hero__inner {
    margin-top: 70px
  }
}

@media only screen and (max-width: 767px) {
  .o-hero--child .o-hero__title {
    font-size: 3.8rem
  }
}

@media only screen and (max-width: 767px) {
  .o-hero--child .o-hero__sub-title {
    display: block;
    margin: 0
  }
}

@media only screen and (max-width: 767px) {
  .o-hero--child .o-hero__description {
    font-size: 1.6rem;
    margin-top: 1em
  }
}

.o-hero__inner {
  position: relative;
  max-width: 1000px;
  margin: 0 auto
}

.o-hero__text {
  margin-top: 4em;
  font-size: 5rem;
  font-weight: 300;
  text-shadow: #1d282f 1px 1px 10px, #1d282f -1px 1px 10px, #1d282f 1px -1px 10px, #1d282f -1px -1px 10px
}

@media only screen and (max-width: 767px) {
  .o-hero__text {
    margin-bottom: 4em;
    font-size: 7.3vmin
  }
}

.o-hero__sub-text {
  font-size: 3rem
}

@media only screen and (max-width: 767px) {
  .o-hero__sub-text {
    font-size: 4vmin
  }
}

.o-hero__title {
  margin-top: 1em;
  font-size: 4.8rem;
  font-weight: 300;
  text-shadow: #1d282f 1px 1px 10px, #1d282f -1px 1px 10px, #1d282f 1px -1px 10px, #1d282f -1px -1px 10px
}

.o-hero__sub-title {
  margin-left: 1em;
  font-size: 50%;
  font-weight: 300
}

.o-hero__description {
  font-size: 1.8rem;
  text-shadow: #1d282f 1px 1px 10px, #1d282f -1px 1px 10px, #1d282f 1px -1px 10px, #1d282f -1px -1px 10px
}

.o-footer {
  width: 100%;
  background: #31424e;
  color: #fff
}

.o-footer a {
  color: #fff;
  text-decoration: none;
  transition: opacity .2s ease
}

.o-footer a:hover {
  opacity: .7
}

.o-footer__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 1em 1em;
  display: flex;
  align-items: center;
  justify-content: space-between
}

@media only screen and (max-width: 767px) {
  .o-footer__inner {
    padding: 1em
  }
}

.o-footer__info {
  font-size: 1.2rem
}

.o-footer-links {
  background: #1d282f;
  font-size: 1.2rem
}

.o-footer-links__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 1em;
  display: flex;
  justify-content: space-between
}

@media only screen and (max-width: 767px) {
  .o-footer-links__inner {
    justify-content: center;
    align-items: flex-end
  }
}

.o-footer-links__list {
  display: flex;
  list-style: none
}

@media only screen and (max-width: 767px) {
  .o-footer-links__list {
    display: none
  }
}

.o-footer-links__item {
  display: flex
}

.o-footer-links__item:before {
  position: relative;
  display: block;
  content: "";
  width: .5em;
  height: .5em;
  border-radius: 100%;
  margin: auto .5em auto 0;
  background: #fff
}

.o-footer-links__item+.o-footer-links__item {
  margin-left: 1em
}

@media only screen and (max-width: 767px) {
  .o-footer-links__item+.o-footer-links__item {
    margin-left: 0em
  }
}

.o-footer-links__copyright {
  font-size: 1rem
}

.o-footer-nav {
  display: flex;
  align-items: top;
  list-style: none;
  font-size: 1.2rem;
  font-weight: bold
}

@media only screen and (max-width: 767px) {
  .o-footer-nav {
    display: none
  }
}

.o-footer-nav__list {
  display: flex;
  align-items: center;
  height: 100%
}

.o-footer-nav__item {
  position: relative;
  margin: 0 2em
}

@media only screen and (max-width: 1023px) {
  .o-footer-nav__item {
    margin: 0 .5em
  }
}

.o-footer-nav__child-list {
  margin: 0;
  padding: .5em 0;
  list-style: none;
  font-weight: normal
}

.o-footer-nav__child-list li {
  position: relative;
  padding-left: 1em
}

.o-footer-nav__child-list li::before {
  position: absolute;
  display: inline-block;
  content: "\30FB";
  position: absolute;
  top: 0;
  left: 0
}

.o-footer-nav__child-list li+li {
  margin-top: .5em
}

.o-top {
  padding: 2em 1em 4em
}

.o-top--info {
  position: absolute;
  left: 50%;
  width: 100%;
  transform: translate3d(-50%, -100%, 0)
}

@media only screen and (max-width: 767px) {
  .o-top--info {
    background: #31424e;
    color: #fff;
    position: relative;
    left: 0;
    transform: none
  }
}

.o-top--vision {
  background: #1e3545;
  color: #fff;
  padding: 2em 0 0
}

.o-top--vision .o-top__inner {
  padding: 0 1em
}

.o-top--sa {
  background: #31424e;
  color: #fff
}

.o-top--recruit {
  background: #1e3545;
  color: #fff
}

.o-top--contact {
  background: #fff;
  text-align: center
}

.o-top--contact .c-button, .o-top--contact .c-note {
  margin-top: 1.5em
}

.o-top__inner {
  max-width: 1000px;
  margin: 0 auto
}

.o-top__block {
  margin-top: 2em
}

.o-top__block--small {
  margin-top: 1em
}

.o-top__title {
  font-size: 3.6rem;
  font-weight: 300;
  color: #fff;
  text-align: center
}

@media only screen and (max-width: 767px) {
  .o-top__title {
    font-size: 3rem
  }
}

.o-top__title--black {
  color: #000
}

.o-top__title--info {
  font-size: 3rem;
  border-bottom: 1px solid #fff;
  text-align: left;
  text-shadow: #1d282f 1px 1px 10px, #1d282f -1px 1px 10px, #1d282f 1px -1px 10px, #1d282f -1px -1px 10px
}

.o-top__lead {
  font-size: 1.8rem;
  color: #fff;
  text-align: center;
  margin-top: 2em
}

.o-top__lead--black {
  color: #000
}

.o-top__link--info {
  display: inline-block;
  padding: .25em 1em;
  background: #0083b4;
  font-size: 1.2rem;
  color: #fff;
  text-align: center;
  transition: opacity .2s ease
}

.o-top__link--info:hover {
  opacity: .8
}

.o-column {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  list-style: none
}

.o-column--2>* {
  width: calc(50% - 1em)
}

@media only screen and (max-width: 767px) {
  .o-column--2>* {
    width: 100%
  }
}

.o-column--2>*:nth-child(n+3) {
  margin-top: 2em
}

@media only screen and (max-width: 767px) {
  .o-column--2>*:not(:first-child) {
    margin-top: 2em
  }
}

.o-column--3>* {
  width: calc(33.3% - 1em)
}

@media only screen and (max-width: 767px) {
  .o-column--3>* {
    width: 100%
  }
}

.o-column--3>*:nth-child(n+4) {
  margin-top: 2em
}

@media only screen and (max-width: 767px) {
  .o-column--3>*:not(:first-child) {
    margin-top: 2em
  }
}

.o-column--4>* {
  width: calc(25% - 1em)
}

@media only screen and (max-width: 767px) {
  .o-column--4>* {
    width: 100%
  }
}

.o-column--4>*:nth-child(n+5) {
  margin-top: 2em
}

@media only screen and (max-width: 767px) {
  .o-column--4>*:not(:first-child) {
    margin-top: 1em
  }
}

@media only screen and (max-width: 767px) {
  .o-column--info .c-card+.c-card {
    margin-top: 2em
  }
}

.o-column--info>.c-card {
  width: calc(25% - 1em)
}

@media only screen and (max-width: 767px) {
  .o-column--info>.c-card {
    width: 100%
  }
}

.o-column--info>.c-card:nth-child(n+5) {
  display: none
}

.o-column--vision>* {
  flex: 1 1 33.3%
}

@media only screen and (max-width: 767px) {
  .o-column--vision>* {
    flex: 1 1 100%;
    width: 100%
  }
}

.o-column--rel {
  padding: 1.5em 0;
  border-top: 1px dashed #8e8e8e;
  border-bottom: 1px dashed #8e8e8e
}

.o-column--rel>* {
  width: calc(50% - 1em)
}

@media only screen and (max-width: 767px) {
  .o-column--rel>* {
    width: 100%
  }
}

@media only screen and (max-width: 767px) {
  .o-column--rel>*:not(:first-child) {
    margin-top: 1em
  }
}

@media only screen and (max-width: 767px) {
  .o-column--small>*:not(:first-child) {
    margin-top: .5em
  }
}

.o-page.o-page--white:nth-of-type(odd), .o-page.o-page--white:nth-of-type(even) {
  background: #fff;
  color: #000
}

.o-page.o-page--navy:nth-of-type(odd), .o-page.o-page--navy:nth-of-type(even) {
  background: #1e3545
}

.o-page.o-page--darken-navy:nth-of-type(odd), .o-page.o-page--darken-navy:nth-of-type(even) {
  background: #1d282f
}

.o-page {
  padding: 2em 1em;
  color: #fff
}

.o-page:nth-of-type(odd) {
  background: #1e3545
}

.o-page:nth-of-type(odd).o-page--info {
  background: #1d282f
}

.o-page:nth-of-type(even) {
  background: #1d282f
}

.o-page--governance {
  line-height: 2
}

.o-page__inner {
  max-width: 1000px;
  margin: 0 auto
}

.o-page__block {
  margin-top: 2em
}

.o-page__block--big {
  margin-top: 4em
}

.o-page__block--small {
  margin-top: 1em
}

.o-page__block--border {
  margin: 1.5em 0;
  padding: 1.5em 0;
  border-top: 1px dashed #ccc;
  border-bottom: 1px dashed #ccc
}

.o-page__nav {
  margin-top: 1em
}

.o-page__nav-list {
  list-style: none;
  display: flex;
  justify-content: center
}

.o-page__nav-item {
  margin: 0 1em
}

.o-page__nav-item a {
  text-decoration: underline
}

.o-page__main-title {
  font-size: 3rem;
  font-weight: 400;
  text-align: center
}

.o-page__main-lead {
  margin-top: 2em;
  text-align: center
}

.o-page__title {
  text-align: center;
  font-size: 1.8rem
}

.o-page__title--blue {
  text-align: left;
  font-size: 1.6rem;
  color: #4fcfff
}

.o-page__lead {
  margin-top: 1.5em
}

.o-page__button-area {
  margin-top: 2em;
  text-align: center
}

.o-page__content ol {
  counter-reset: section;
  list-style-type: none;
  margin-left: 2em
}

.o-page__content ol li {
  position: relative
}

.o-page__content ol li:before {
  counter-increment: section;
  content: counters(section, ".") ".";
  position: absolute;
  transform: translate3d(-100%, 0, 0)
}

.o-page__content ul {
  list-style: disc;
  margin-left: 1em
}

.o-page__content ul li:before {
  content: none
}

.o-page__content li {
  margin: 1em 0
}

.o-page__content .c-note--contact .c-note__inner {
  background: transparent;
  color: #fff
}

.o-post {
  background: #1e3545;
  padding: 2em 1em;
  color: #fff
}

.o-post__inner {
  max-width: 1000px;
  margin: 0 auto
}

.o-post__thumbnail {
  margin-bottom: 2em;
  text-align: center
}

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

.o-post__note {
  text-align: right;
  margin-bottom: 2em
}

.o-post__tag {
  margin-right: 1em
}

.o-post__interviewee {
  font-size: 1.3rem;
  text-align: right
}

.o-post__lead-title {
  font-size: 2rem;
  margin-bottom: 1.5em
}

.o-post__lead-text {
  font-size: 1.4rem
}

.o-post__content {
  font-size: 1.4rem
}

.o-post__content h4, .o-post__content .h4, .o-post__content .lead {
  margin-top: 3em;
  margin-bottom: 1em;
  font-size: 1.8rem;
  color: #74d9ff
}

.o-post__content p {
  margin: 1em 0
}

.o-post__content .answer, .o-post__content .interviewee {
  color: #afe9ff
}

.o-post__title {
  margin-bottom: 1em;
  font-size: 3rem;
  font-weight: 400;
  text-align: center
}

.o-post__button-area {
  margin-top: 2em;
  text-align: center
}

.c-card a {
  display: block;
  color: #fff;
  transition: opacity .2s ease
}

.c-card a:hover {
  opacity: .9
}

.c-card--info {
  background: #1e3545;
  color: #fff
}

.c-card--info .c-card__thumb {
  padding-top: 50%;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover
}

.c-card--info .c-card__text {
  padding: .5em
}

.c-card--info .c-card__title {
  height: 3em;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 1.4rem
}

.c-card--info .c-card__note {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: .25em
}

.c-card--info .c-card__tag {
  display: inline-block;
  min-width: 5em;
  background: #0083b4;
  font-size: 1rem;
  color: #fff;
  text-align: center
}

.c-card--info .c-card__time {
  font-size: 1.2rem
}

.c-card--interview {
  background: #fff;
  color: #000
}

.c-card--interview a {
  color: #000
}

.c-card--interview .c-card__thumb {
  padding-top: 50%;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover
}

.c-card--interview .c-card__text {
  padding: .5em
}

.c-card--interview .c-card__title {
  height: 3em;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 1.5rem;
  color: #0083b4
}

.c-card--interview .c-card__name {
  margin-top: .5em;
  padding-top: .5em;
  border-top: 1px solid rgba(30, 53, 69, 0.3);
  font-size: 1.3rem
}

.c-card--sa {
  position: relative;
  text-align: center
}

.c-card--sa .c-card__link {
  position: relative;
  display: block;
  padding-top: 50%;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  color: #fff
}

.c-card--sa .c-card__link:before {
  position: absolute;
  display: inline-block;
  content: "\8A73\3057\304F\306F\3053\3061\3089";
  z-index: 15;
  top: calc(50% - 1.5rem);
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
  opacity: 0;
  transition: opacity 0.3s ease
}

.c-card--sa .c-card__link:after {
  position: absolute;
  display: block;
  content: "";
  z-index: 5;
  top: 0;
  left: 0;
  width: 100%;
  height: calc(100% - 3rem);
  background-color: rgba(0, 0, 0, 0.8);
  opacity: 0;
  transition: opacity 0.3s ease
}

.c-card--sa .c-card__link:hover:before {
  opacity: 1
}

.c-card--sa .c-card__link:hover:after {
  opacity: 1
}

.c-card--sa .c-card__title {
  z-index: 10;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  background: rgba(0, 0, 0, 0.8);
  font-size: 2rem;
  line-height: 1.5;
  font-weight: 300
}

.c-card--sa .c-card__text {
  margin-top: 1em;
  text-align: left
}

.c-card--vision {
  position: relative;
  text-align: center;
  background-position: center;
  background-size: cover
}

.c-card--vision a {
  text-decoration: none
}

.c-card--vision01 {
  background-image: url(../img/top/vision-message.jpg)
}

.c-card--vision02 {
  background-image: url(../img/top/vision-mission.jpg)
}

.c-card--vision03 {
  background-image: url(../img/top/vision-company.png)
}

.c-card--vision .c-card__inner {
  position: relative;
  max-width: 600px;
  height: 100%;
  margin: auto;
  padding-top: 5em
}

.c-card--vision .c-card__link {
  display: block;
  height: 100%;
  padding: 10%;
  background-color: rgba(0, 0, 0, 0.5);
  text-align: center;
  color: #fff;
  transition: background-color .2s ease
}

@media only screen and (max-width: 1023px) {
  .c-card--vision .c-card__link {
    padding: 5% 10%
  }
}

.c-card--vision .c-card__link:hover {
  background-color: rgba(0, 0, 0, 0.7)
}

.c-card--vision .c-card__link:hover .c-card__title {
  top: 0;
  transform: translate3d(-50%, 0, 0)
}

.c-card--vision .c-card__link:hover .c-card__fade {
  opacity: 1;
  visibility: visible;
  transform: translate3d(0, 0, 0)
}

.c-card--vision .c-card__title {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  font-size: 3rem;
  font-weight: 400;
  text-align: center;
  letter-spacing: .1em;
  transform: translate3d(-50%, -50%, 0);
  transition: all .3s ease
}

.c-card--vision .c-card__title--en {
  display: block;
  font-size: 2.4rem;
  font-weight: 300;
  letter-spacing: 0
}

@media only screen and (max-width: 767px) {
  .c-card--vision .c-card__title {
    top: 0;
    transform: translate3d(-50%, 0, 0)
  }
}

.c-card--vision .c-card__fade {
  opacity: 0;
  visibility: hidden;
  transform: translate3d(0, 10%, 0);
  transition: all .3s ease
}

@media only screen and (max-width: 767px) {
  .c-card--vision .c-card__fade {
    opacity: 1;
    visibility: visible;
    transform: translate3d(0, 0, 0)
  }
}

.c-card--vision .c-card__text {
  margin-top: 2em;
  font-size: 1.4rem;
  text-align: left;
  letter-spacing: .1em
}

.c-card--vision .c-card__button {
  display: inline-block;
  padding: .5em 2em;
  margin-top: 2em;
  font-size: 1.4rem;
  text-align: center;
  background: rgba(255, 255, 255, 0.2);
  border: 1px solid #fff
}

.c-card--ghost {
  visibility: hidden !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important
}

.c-card--blue {
  padding: .5em 1em 0;
  border: 2px solid rgba(255, 255, 255, 0.4);
  border-radius: 20px;
  background: rgba(0, 131, 180, 0.3);
  text-align: center
}

.c-card--blue .c-card__title {
  color: #74d9ff;
  border-bottom: 1px solid rgba(255, 255, 255, 0.4)
}

.c-card--blue .c-card__text {
  text-align: center;
  padding: 1em 0;
  font-weight: 600
}

.c-card--simple .c-card__title {
  color: #4fcfff
}

.c-card--simple .c-card__text {
  margin-top: 1em
}

.c-rel {
  font-size: 1.4rem;
  text-align: left
}

.c-rel__title {
  position: relative;
  font-weight: 700;
  padding-left: 1em
}

.c-rel__title:before {
  position: absolute;
  display: block;
  content: "";
  top: calc(50% - .25em);
  left: 0;
  width: .5em;
  height: .5em;
  border-radius: 100%;
  background: #000
}

.c-rel__list {
  list-style: none
}

.c-rel__list--image {
  margin-top: 1em
}

.c-rel__list--image .c-rel__item {
  display: inline-block;
  margin-right: 1em
}

.c-note {
  text-align: center;
  font-size: 1.8rem
}

.c-note--contact {
  font-size: 1.4rem
}

.c-note--contact .c-note__inner {
  border: 0;
  padding: .5em 5em;
  background: #f6f6f6;
  color: #333
}

@media only screen and (max-width: 767px) {
  .c-note--contact .c-note__inner {
    padding: .5em
  }
}

.c-note--contact .c-note__inner p {
  margin: 0
}

.c-note--contact .c-note__title {
  font-size: 1.8rem;
  font-weight: 600
}

.c-note--contact2 {
  font-size: 1.4rem
}

.c-note--contact2 .c-note__inner {
  border: 0;
  padding: .5em 5em;
  color: #fff
}

@media only screen and (max-width: 767px) {
  .c-note--contact2 .c-note__inner {
    padding: .5em
  }
}

.c-note--contact2 .c-note__inner p {
  margin: 0
}

.c-note--contact2 .c-note__title {
  font-size: 1.8rem;
  font-weight: 600
}

.c-note__inner {
  display: inline-block;
  border: 1px solid #000;
  padding: 1em 2em
}

@media only screen and (max-width: 767px) {
  .c-note__inner {
    font-size: 90%;
    padding: 1em
  }
}

.c-button {
  display: inline-block;
  padding: .5em 1em
}

.c-button--blue {
  position: relative;
  background: #0083b4;
  color: #fff;
  border-bottom: 4px solid #005e81;
  transition: opacity .3s ease
}

.c-button--blue:hover {
  opacity: .8
}

.c-button--w30p {
  width: 30%
}

@media only screen and (max-width: 767px) {
  .c-button--w30p {
    width: 80%
  }
}

.c-breadcrumbs {
  list-style: none;
  display: flex;
  flex-wrap: wrap
}

.c-breadcrumbs a {
  color: #fff
}

.c-breadcrumbs__item {
  font-size: 1.2rem
}

.c-breadcrumbs__item:not(:last-child):after {
  position: relative;
  display: inline-block;
  content: "-";
  margin: 0 .5em
}

.c-table {
  text-align: center
}

.c-table--fixed {
  table-layout: fixed
}

.c-table td {
  border: 2px solid rgba(255, 255, 255, 0.4);
  border-radius: 20px;
  background: rgba(0, 131, 180, 0.3)
}

.c-flex-table__row {
  display: flex;
  justify-content: space-between
}

.c-flex-table__row+.c-flex-table__row {
  margin-top: .5em
}

.c-flex-table__item--fit {
  width: 100%
}

.c-flex-table__item--50p {
  width: calc(50% - .25em)
}

.c-flex-table__item--16p {
  width: calc(16.6% - .5em)
}

.c-flex-table__item--33p {
  width: calc(33.3% - .5em)
}

.c-flex-table__item--33p {
  width: calc(33.3% - .5em)
}

.c-flex-table__item--66p {
  width: calc(66.6% - .5em)
}

.c-flex-table__partition {
  width: calc(50% - .25em);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between
}

.c-flex-table__partition .c-flex-table__item--33p {
  width: calc(33.3% - .35em)
}

@media only screen and (max-width: 767px) {
  .c-flex-table__partition .c-flex-table__item--33p {
    width: 100%
  }

  .c-flex-table__partition .c-flex-table__item--33p:not(:first-child) {
    margin-top: .5em
  }
}

.c-flex-table__partition .c-flex-table__item--66p {
  width: calc(66.6% - .25em)
}

@media only screen and (max-width: 767px) {
  .c-flex-table__partition .c-flex-table__item--66p {
    width: 100%
  }

  .c-flex-table__partition .c-flex-table__item--66p:not(:first-child) {
    margin-top: .5em
  }
}

.c-company-table {
  border-collapse: separate;
  text-align: left;
  color: #000;
  font-size: 1.4rem
}

@media only screen and (max-width: 767px) {
  .c-company-table {
    display: block
  }

  .c-company-table thead, .c-company-table tbody, .c-company-table tr, .c-company-table th, .c-company-table td {
    display: block
  }
}

.c-company-table th, .c-company-table td {
  padding: .5em 1em
}

.c-company-table th {
  text-align: center;
  background: #dfdfdf;
  border: 1px solid #1e3545;
  min-width: 12em
}

.c-company-table td {
  background: #fff;
  border: 1px solid #1e3545;
  color: #333;
  line-height: 2
}

.c-history-table {
  text-align: center;
  font-size: 1.4rem
}

.c-history-table tbody {
  display: inline-table;
  text-align: left
}

.c-history-table td, .c-history-table td {
  padding: 1em 0
}

.c-history-table th {
  width: 7em
}

.c-history-table th span {
  border-bottom: 1px solid #fff
}

.c-bevel {
  z-index: 0;
  position: relative;
  display: flex;
  flex-direction: column;
  padding: .5em 1em;
  text-align: center
}

.c-bevel:before, .c-bevel:after {
  position: absolute;
  display: block;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.c-bevel:before {
  z-index: -2;
  background: linear-gradient(45deg, transparent .5em, #7d9aa9 .5em), linear-gradient(135deg, transparent .5em, #7d9aa9 .5em), linear-gradient(225deg, transparent .5em, #7d9aa9 .5em), linear-gradient(315deg, transparent .5em, #7d9aa9 .5em);
  background-position: bottom left, top left, top right, bottom right;
  background-size: 51% 51%;
  background-repeat: no-repeat
}

.c-bevel:after {
  z-index: -1;
  background: linear-gradient(45deg, transparent .5em, #144d6a .5em), linear-gradient(135deg, transparent .5em, #144d6a .5em), linear-gradient(225deg, transparent .5em, #144d6a .5em), linear-gradient(315deg, transparent .5em, #144d6a .5em);
  background-position: bottom 2px left 2px, top 2px left 2px, top 2px right 2px, bottom 2px right 2px;
  background-size: 51% 51%;
  background-repeat: no-repeat
}

.c-bevel--inline {
  flex-direction: row;
  justify-content: center
}

.c-bevel--inline .c-bevel__title {
  border: 0
}

.c-bevel--inline .c-bevel__text {
  margin: 0;
  padding: 0
}

.c-bevel--inline .c-bevel__text:before {
  position: relative;
  display: inline-block;
  content: "";
  top: 10%;
  width: 1px;
  height: 80%;
  margin: 0 .5em;
  background: #7d9aa9
}

.c-bevel__title {
  font-size: 1.6rem;
  color: #4fcfff;
  border-bottom: 1px solid #7d9aa9
}

.c-bevel__text {
  margin: auto 0;
  padding: .25em 0;
  font-size: 1.6rem;
  color: #fff
}

.c-ul {
  list-style: none
}

.c-ul li {
  position: relative;
  padding-left: 1em
}

.c-ul li:before {
  position: absolute;
  display: inline;
  content: "\30FB";
  left: 0
}

.c-link {
  position: relative;
  text-decoration: none
}

.c-link--01 {
  color: #0083b4;
  display: inline-block;
  padding-left: 1em
}

.c-link--01::before {
  position: absolute;
  display: block;
  content: "";
  top: calc(50% - .25em);
  left: 0;
  width: 0;
  height: 0;
  border: 0 solid transparent;
  border-top: 0.5em solid #0096ce;
  border-right: .5em solid transparent;
  transform: rotate(135deg)
}

.c-arrow {
  padding-left: 10%;
  background: url(../img/common/arrow-big.png) no-repeat;
  background-position: left center;
  background-size: 15% auto
}

@media only screen and (max-width: 767px) {
  .c-arrow {
    padding-left: 0;
    padding-top: 20%;
    background: url(../img/common/arrow-big-bottom.png) no-repeat;
    background-position: center top;
    background-size: auto 20%
  }
}

.c-form {
  max-width: 600px;
  margin: 0 auto
}

.c-form__field:not(:last-child) {
  margin-top: 1em
}

.c-form__footer {
  margin-top: 1em;
  text-align: center
}

.c-form label {
  display: inline-block;
  vertical-align: top;
  line-height: 2;
  cursor: pointer
}

@media only screen and (max-width: 767px) {
  .c-form label {
    width: 100%
  }
}

.c-form input[type="text"], .c-form input[type="email"], .c-form input[type="tel"] {
  width: calc(100% - 10em);
  line-height: 1.5;
  float: right
}

@media only screen and (max-width: 767px) {
  .c-form input[type="text"], .c-form input[type="email"], .c-form input[type="tel"] {
    width: 100%
  }
}

.c-form textarea {
  width: calc(100% - 10em);
  max-width: calc(100% - 10em);
  float: right
}

@media only screen and (max-width: 767px) {
  .c-form textarea {
    width: 100%;
    max-width: 100%
  }
}

.c-form input[type="submit"] {
  display: inline-block;
  margin-top: 1em;
  padding: .5em 1em;
  position: relative;
  background: #0083b4;
  color: #fff;
  border: 0;
  border-bottom: 4px solid #005e81;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  font-size: 1em;
  transition: opacity .3s ease
}

.c-form input[type="submit"]:hover {
  opacity: .8
}

.c-form a {
  color: #fff;
  text-decoration: underline
}

.c-pager {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  margin: 1em 0
}

.c-pager:empty {
  margin: 0
}

.c-pager a:after {
  position: relative;
  display: block;
  content: "";
  width: 100%;
  height: 1px;
  background: #fff
}

.c-pager .page-numbers {
  display: inline-block;
  margin: 1em
}

.c-pager .page-numbers.current {
  opacity: .5
}

.c-message {
  padding: 2em 0
}

.c-message:not(:first-of-type) {
  border-top: 1px dashed #8e8e8e
}

.c-message__name {
  font-size: 1.8rem;
  text-align: center
}

.c-message__voice {
  margin-top: 1em;
  font-size: 2.4rem;
  font-weight: 300;
  text-align: center
}

.c-message__text {
  margin-top: 2em;
  font-size: 1.4rem;
  line-height: 2
}

.c-message__sign {
  text-align: right
}

@media only screen and (max-width: 767px) {
  .c-message__sign {
    text-align: center
  }
}

.u-visibility-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px)
}

.u-button--totop {
  position: fixed;
  right: 20px;
  bottom: 20px;
  width: 38px;
  height: 38px;
  color: transparent;
  background: url(../img/common/to-top.png) no-repeat center;
  background-size: contain;
  transition: opacity .2s ease;
  font: 0/0 a
}

.u-button--totop:hover {
  opacity: .7
}

.u-text--white {
  color: #fff
}

.u-text--blue {
  color: #0083b4
}

.u-text--bold {
  font-weight: bold
}

.u-tac {
  text-align: center
}

@media only screen and (max-width: 1023px) {
  .u-tac--tablet {
    text-align: center
  }
}

@media only screen and (max-width: 767px) {
  .u-tac--sp {
    text-align: center
  }
}

.u-tar {
  text-align: right
}

.u-margin--top1em {
  margin-top: 1em
}

.u-margin--top2em {
  margin-top: 2em
}

.box1 {
  font-size: 50px;
  padding: 0.5em 1em;
  margin: 0 auto;
  font-weight: bold;
  width: 1500px;
  text-align: center;
}

@media only screen and (max-width: 767px) {
  .box1 {
    box-sizing: border-box;
    width: 100%;
    font-size: 13px
  }
}


.box2 {
  font-size: 50px;
  padding: 0.5em 1em;
  margin: 0 auto;
  font-weight: bold;
  width: 1500px;
  text-align: left;
  border: solid 3px #000000;
}

@media only screen and (max-width: 767px) {
  .box2 {
    box-sizing: border-box;
    width: 100%;
    font-size: 16px;
    border: solid;
    border-color: #FFFFFF;
  }
}


.box3 {
    font-size: 50px;
    padding: 0.5em 1em;
    margin: 0 auto;
    font-weight: bold;
    width: 1500px;
    text-align: left;
    border: solid 3px #000000;
}

@media only screen and (max-width: 767px) {
  .box3 {
    box-sizing: border-box;
    width: 100%;
    font-size: 16px;
    border: solid;
    border-color: #FFFFFF;
  }
}

.box4 {
    font-size: 50px;
    padding: 0.5em 1em;
    margin: 0 auto;
    font-weight: bold;
    width: 1500px;
    text-align: left;
    border: solid 3px #000000;

}

@media only screen and (max-width: 767px) {
  .box4 {
    box-sizing: border-box;
    width: 100%;
    font-size: 16px;
    border: solid;
    border-color: #FFFFFF;
  }
}

.box5 {
  font-size: 50px;
  padding: 0.5em 1em;
  margin: 0 auto;
  font-weight: bold;
  width: 1500px;
  text-align: left;
}

@media only screen and (max-width: 767px) {
  .box5 {
    box-sizing: border-box;
    width: 100%;
    font-size: 13px;
  }
}

.box6 {
    font-size: 50px;
    padding: 0.5em 1em;
    margin: 0 auto;
    font-weight: bold;
    width: 1500px;
    text-align: center;
}

@media only screen and (max-width: 767px) {
  .box6 {
    box-sizing: border-box;
    width: 100%;
    font-size: 13px;
  }
}
