@charset "UTF-8";
/**
 * Foundation for Sites by ZURB
 * Version 6.3.1
 * foundation.zurb.com
 * Licensed under MIT Open Source
 */
/*! normalize-scss | MIT/GPLv2 License | bit.ly/normalize-scss */
/* Document
========================================================================== */
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&family=Poppins:wght@400;700&display=swap");
@import url("https://cdn.jsdelivr.net/npm/yakuhanjp@3.2.0/dist/css/yakuhanjp.min.css");
html {
  font-family: sans-serif;
  line-height: 1.15;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%; }

/* Sections
========================================================================== */
body {
  margin: 0; }

article, aside, footer, header, nav, section {
  display: block; }

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

/* Grouping content
========================================================================== */
figcaption, figure {
  display: block; }

figure {
  margin: 1em 40px; }

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

main {
  display: block; }

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

/* Links
========================================================================== */
a {
  background-color: transparent;
  -webkit-text-decoration-skip: objects; }

a:active, a:hover {
  outline-width: 0; }

/* Text-level semantics
========================================================================== */
abbr[title] {
  border-bottom: none;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted; }

b, strong {
  font-weight: inherit; }

b, strong {
  font-weight: bolder; }

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

dfn {
  font-style: italic; }

mark {
  background-color: #ff0;
  color: #000; }

small {
  font-size: 80%; }

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

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

ul, li, ol, dt, dd {
  list-style: none; }

/* Embedded content
========================================================================== */
audio, video {
  display: inline-block; }

audio:not([controls]) {
  display: none;
  height: 0; }

img {
  border-style: none; }

svg:not(:root) {
  overflow: hidden; }

/* Forms
========================================================================== */
button, input, optgroup, select, textarea {
  font-family: sans-serif;
  font-size: 100%;
  line-height: 1.15;
  margin: 0; }

button {
  overflow: visible; }

button, select {
  text-transform: none; }

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

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

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

input {
  overflow: visible; }

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

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

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

[type="search"]::-webkit-search-cancel-button, [type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

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

fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em; }

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

progress {
  display: inline-block;
  vertical-align: baseline; }

textarea {
  overflow: auto; }

/* Interactive
========================================================================== */
details {
  display: block; }

summary {
  display: list-item; }

menu {
  display: block; }

/* Scripting
========================================================================== */
canvas {
  display: inline-block; }

template {
  display: none; }

/* Hidden
========================================================================== */
[hidden] {
  display: none; }

.foundation-mq {
  font-family: "small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em"; }

html {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  font-size: 100%; }

*, *::before, *::after {
  -webkit-box-sizing: inherit;
          box-sizing: inherit; }

body {
  margin: 0;
  padding: 0;
  background: #fefefe;
  font-family: "Helvetica Neue", Helvetica, Roboto, Arial, sans-serif;
  font-weight: normal;
  line-height: 1.5;
  color: #0a0a0a;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

img {
  display: inline-block;
  vertical-align: middle;
  max-width: 100%;
  height: auto;
  -ms-interpolation-mode: bicubic; }

textarea {
  height: auto;
  min-height: 50px;
  border-radius: 0; }

select {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  border-radius: 0; }

.map_canvas img, .map_canvas embed, .map_canvas object, .mqa-display img, .mqa-display embed, .mqa-display object {
  max-width: none !important; }

button {
  padding: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 0;
  border-radius: 0;
  background: transparent;
  line-height: 1; }

[data-whatinput='mouse'] button {
  outline: 0; }

pre {
  overflow: auto; }

/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
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; }

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block; }

body {
  line-height: 1; }

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

/* clearfix */
/* 基本タグのフォントサイズを指定（12px -> 120% or 1.2em ） */
html {
  line-height: 1.6; }
  @media screen and (min-width: 960px) {
    html {
      font-size: 16px; } }
  @media screen and (max-width: 959px) {
    html {
      font-size: 14px; } }

h1, h2, h3, h4, h5, h6, input, button, textarea, select, p, th, td, address, li, dt, dd {
  font-weight: 400;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 1px; }

/* =========================================================
	element style
========================================================= */
html, body {
  height: 100%; }

body {
  color: #2e2b28;
  font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif; }

input, textarea, button {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif; }

a {
  color: #000; }

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

@media screen and (min-width: 960px) {
  .media-PC {
    display: block; } }
@media screen and (max-width: 959px) {
  .media-PC {
    display: none !important; } }

@media screen and (min-width: 960px) {
  .media-Tablet {
    display: none !important; } }
@media screen and (max-width: 959px) {
  .media-Tablet {
    display: block; } }

@media screen and (min-width: 768px) {
  .media-NoSP {
    display: block; } }
@media screen and (max-width: 767px) {
  .media-NoSP {
    display: none; } }

@media screen and (min-width: 768px) {
  .media-SP {
    display: none; } }
@media screen and (max-width: 767px) {
  .media-SP {
    display: block; } }

.fr {
  float: right; }

.fl {
  float: left; }

.imgC, .tC {
  text-align: center; }

.imgC {
  display: block;
  margin-left: auto;
  margin-right: auto; }

.tR {
  text-align: right; }

div.center {
  text-align: center; }

.map {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 56.25%;
  overflow: hidden; }
  .map iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }

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

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

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

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

.mt5 {
  margin-top: 5px !important; }

.mb5 {
  margin-bottom: 5px !important; }

.pt5 {
  padding-top: 5px !important; }

.pb5 {
  padding-bottom: 5px !important; }

.mt10 {
  margin-top: 10px !important; }

.mb10 {
  margin-bottom: 10px !important; }

.pt10 {
  padding-top: 10px !important; }

.pb10 {
  padding-bottom: 10px !important; }

.mt15 {
  margin-top: 15px !important; }

.mb15 {
  margin-bottom: 15px !important; }

.pt15 {
  padding-top: 15px !important; }

.pb15 {
  padding-bottom: 15px !important; }

.mt20 {
  margin-top: 20px !important; }

.mb20 {
  margin-bottom: 20px !important; }

.pt20 {
  padding-top: 20px !important; }

.pb20 {
  padding-bottom: 20px !important; }

.mt25 {
  margin-top: 25px !important; }

.mb25 {
  margin-bottom: 25px !important; }

.pt25 {
  padding-top: 25px !important; }

.pb25 {
  padding-bottom: 25px !important; }

.mt30 {
  margin-top: 30px !important; }

.mb30 {
  margin-bottom: 30px !important; }

.pt30 {
  padding-top: 30px !important; }

.pb30 {
  padding-bottom: 30px !important; }

.mt35 {
  margin-top: 35px !important; }

.mb35 {
  margin-bottom: 35px !important; }

.pt35 {
  padding-top: 35px !important; }

.pb35 {
  padding-bottom: 35px !important; }

.mt40 {
  margin-top: 40px !important; }

.mb40 {
  margin-bottom: 40px !important; }

.pt40 {
  padding-top: 40px !important; }

.pb40 {
  padding-bottom: 40px !important; }

.mt45 {
  margin-top: 45px !important; }

.mb45 {
  margin-bottom: 45px !important; }

.pt45 {
  padding-top: 45px !important; }

.pb45 {
  padding-bottom: 45px !important; }

.mt50 {
  margin-top: 50px !important; }

.mb50 {
  margin-bottom: 50px !important; }

.pt50 {
  padding-top: 50px !important; }

.pb50 {
  padding-bottom: 50px !important; }

.mr0 {
  margin-right: 0 !important; }

.pr0 {
  padding-right: 0 !important; }

.clear {
  clear: both; }

.clear-fix {
  zoom: 1; }
  .clear-fix:before, .clear-fix:after {
    content: "";
    display: table;
    height: 0;
    visibility: hidden; }
  .clear-fix:after {
    clear: both; }

.table {
  width: 100%; }
  .table tr {
    border-top: solid 1px #e5e5e5; }
    .table tr th {
      width: 150px;
      padding: 20px;
      font-weight: bold;
      font-size: 14px; }
      @media screen and (max-width: 959px) {
        .table tr th {
          width: 120px;
          text-align: left; } }
    .table tr td {
      padding: 20px 0;
      font-size: 14px;
      line-height: 1.6; }
    .table tr:last-child {
      border-bottom: solid 1px #e5e5e5; }
    .table tr:nth-child(odd) {
      background: #fafafa; }
  @media screen and (max-width: 959px) {
    .table tr {
      padding: 10px; }
      .table tr th {
        padding: 20px 10px 0 10px; }
      .table tr td {
        padding: 5px 10px 20px 10px; }
    .table td, .table th {
      display: block; } }

/* =========================================================
	general
========================================================= */
/* text */
a, li {
  text-decoration: none; }

p.left {
  text-align: left; }
p.right {
  text-align: right; }
p.center {
  text-align: center; }
p.attention {
  text-indent: -1em;
  padding-left: 1em;
  margin-top: 10px;
  font: normal 0.8em/2 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif !important;
  opacity: 0.8; }

span.keep {
  word-break: keep-all; }

a.bold {
  font-weight: bold; }

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

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

.btn {
  text-align: center;
  margin-top: 40px; }
  @media screen and (max-width: 959px) {
    .btn {
      margin-top: 20px; } }
  .btn.right {
    text-align: right; }
    @media screen and (max-width: 767px) {
      .btn.right {
        padding-right: 20px; } }
  .btn a {
    display: inline-block;
    position: relative;
    font: bold 12px/1 "Poppins", sans-serif;
    letter-spacing: .13em;
    color: #004EA2;
    padding: 0 40px 8px 0;
    border-bottom: 2px solid #004EA2;
    -webkit-transition: opacity .15s ease;
    transition: opacity .15s ease; }
    .btn a:before {
      content: "";
      position: absolute;
      bottom: -2px;
      right: -2px;
      display: block;
      width: 15px;
      height: 12px;
      border-bottom: 12px solid #004EA2;
      border-right: 15px solid transparent; }
    .btn a:after {
      content: "";
      position: absolute;
      bottom: -13px;
      right: -8px;
      display: block;
      width: 32px;
      height: 32px;
      border-radius: 16px;
      background: rgba(0, 78, 162, 0.1); }
    .btn a:hover {
      opacity: .3; }
  .btn--large {
    width: 100%;
    margin-top: 50px;
    text-align: center; }
    .btn--large a {
      max-width: 560px;
      width: 100%;
      height: 145px;
      display: -webkit-inline-box;
      display: -ms-inline-flexbox;
      display: inline-flex;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      background: #46B446; }
      .btn--large a p {
        font: bold 30px/1 "Poppins", sans-serif;
        letter-spacing: .23em;
        color: white; }
      .btn--large a span {
        color: white;
        margin-top: 10px;
        font: normal 12px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
        letter-spacing: .23em; }
      .btn--large a:hover {
        opacity: .6; }
    @media screen and (max-width: 959px) {
      .btn--large {
        margin-top: 30px; }
        .btn--large a {
          height: 100px; }
          .btn--large a p {
            font-size: 24px; } }

.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; }
  @media screen and (max-width: 959px) {
    .flex {
      -ms-flex-wrap: wrap;
          flex-wrap: wrap; } }
  .flex__img {
    width: 50%; }
    @media screen and (max-width: 959px) {
      .flex__img {
        width: 100%; } }
  .flex__txt {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    width: 50%;
    padding: 50px 0 50px 50px; }
    @media screen and (min-width: 959px) and (max-width: 1340px) {
      .flex__txt {
        padding: 30px; } }
    @media screen and (max-width: 959px) {
      .flex__txt {
        width: 100%;
        padding: 30px 0 0; } }
    .flex__txt p {
      font: normal 16px/2 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
      color: #333;
      letter-spacing: .08em; }
      @media screen and (max-width: 959px) {
        .flex__txt p {
          font-size: 14px; } }
  .flex.rev .flex__txt {
    padding: 50px 50px 50px 0; }
    @media screen and (min-width: 959px) and (max-width: 1340px) {
      .flex.rev .flex__txt {
        padding: 30px; } }
    @media screen and (max-width: 959px) {
      .flex.rev .flex__txt {
        padding: 30px 0; } }

.heading {
  position: relative; }
  .heading__enttl {
    display: block;
    position: relative;
    padding-left: 20px;
    margin-bottom: 10px;
    color: #004EA2;
    font: normal 14px/1 "Poppins", sans-serif;
    letter-spacing: 0.15em;
    z-index: 1; }
    .heading__enttl::before {
      content: "";
      position: absolute;
      top: 7px;
      left: 3px;
      display: block;
      width: 10px;
      height: 1px;
      background: #004EA2; }
    @media screen and (max-width: 959px) {
      .heading__enttl {
        font: normal 10px/1 "Poppins", sans-serif;
        margin-bottom: 5px; }
        .heading__enttl::before {
          top: 5px; } }
  .heading__title {
    position: relative;
    font: bold 30px/1.67 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    color: #333;
    margin-bottom: 30px;
    letter-spacing: .08em;
    z-index: 1; }
    .heading__title.blue {
      color: #004EA2; }
    @media screen and (max-width: 959px) {
      .heading__title {
        font-size: 20px;
        margin-bottom: 10px; } }
  .heading .behind {
    position: absolute;
    left: -8px;
    bottom: -60px;
    color: white;
    font: bold 114px/1 "Poppins", sans-serif;
    z-index: 0; }
    @media screen and (max-width: 959px) {
      .heading .behind {
        font-size: 50px;
        bottom: -30px;
        left: 10px; } }
  .heading02 {
    margin-bottom: 50px;
    text-align: center; }
    .heading02__enttl {
      display: block;
      text-align: center;
      font: normal 14px/1 "Poppins", sans-serif;
      color: white;
      letter-spacing: .12em;
      margin-bottom: 10px; }
    .heading02__title {
      text-align: center;
      color: white;
      font: bold 30px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
      letter-spacing: .08em; }
    @media screen and (max-width: 959px) {
      .heading02 {
        margin-bottom: 30px; }
        .heading02__enttl {
          font-size: 12px;
          margin-bottom: 5px; }
        .heading02__title {
          font-size: 20px; } }
  .heading03 {
    font: bold 35px/1.5 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    letter-spacing: .08em;
    margin-bottom: 50px; }
    .heading03.center {
      text-align: center; }
    @media screen and (max-width: 959px) {
      .heading03 {
        font-size: 20px;
        margin-bottom: 30px;
        padding: 0 20px; } }
    .heading03.nocolor {
      color: #2e2b28; }
      .heading03.nocolor:first-letter {
        color: #2e2b28; }
  .heading04 {
    position: relative;
    margin-bottom: 30px; }
    .heading04__enttl {
      position: absolute;
      top: -25px;
      left: -40px;
      font: normal 110px/1 "Poppins", sans-serif;
      color: #333;
      opacity: 0.1;
      letter-spacing: .13em; }
    .heading04__title {
      font: bold 30px/1.67 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
      color: #333;
      letter-spacing: .08em; }
    @media screen and (max-width: 959px) {
      .heading04__enttl {
        font-size: 50px;
        top: -15px;
        left: 10px; }
      .heading04__title {
        font-size: 20px;
        padding-left: 20px; } }
  .heading05 {
    position: relative;
    text-align: center;
    font: bold 20px/1.6 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    color: #004EA2;
    margin-bottom: 50px; }
    .heading05:before {
      content: "";
      width: 100%;
      height: 1px;
      display: block;
      position: absolute;
      bottom: -20px;
      left: 0;
      background: #e5e5e5; }

.content p, .content--w900 p, .content--w1200 p {
  font: normal 16px/2 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
  color: #333;
  letter-spacing: .08em; }
  @media screen and (max-width: 959px) {
    .content p, .content--w900 p, .content--w1200 p {
      font-size: 14px; } }
.content + .img, .content--w900 + .img, .content--w1200 + .img {
  margin-top: 40px; }
.content--w900 {
  max-width: 900px;
  width: 100%;
  margin: 0 auto; }
  @media screen and (max-width: 959px) {
    .content--w900 {
      padding: 0 20px; }
      .content--w900 p br {
        display: none; } }
.content--w1200 {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto; }
  @media screen and (min-width: 959px) and (max-width: 1340px) {
    .content--w1200 {
      padding: 0 20px; } }
  @media screen and (max-width: 959px) {
    .content--w1200 {
      padding: 0 20px; }
      .content--w1200 p br {
        display: none; } }

.section + .section {
  margin-top: 100px; }
  @media screen and (max-width: 959px) {
    .section + .section {
      margin-top: 60px; } }

.list-type {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between; }
  .list-type .item {
    width: calc((100% - 60px)/3); }
    .list-type .item__img {
      margin-bottom: 15px; }
    .list-type .item__title {
      margin-bottom: 10px; }
      .list-type .item__title h4 {
        font: bold 18px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
        color: #004EA2; }
    .list-type .item__text p {
      font: normal 14px/2 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif; }
  @media screen and (max-width: 959px) {
    .list-type {
      -ms-flex-wrap: wrap;
          flex-wrap: wrap; }
      .list-type .item {
        width: 100%; }
        .list-type .item + .item {
          margin-top: 40px; } }
.list-anchor {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between; }
  .list-anchor li {
    width: calc((100% - 60px)/4); }
    .list-anchor li a {
      position: relative;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      width: 100%;
      height: 70px;
      border: 1px solid #ddd;
      font: normal 14px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
      letter-spacing: .2em; }
      .list-anchor li a:before {
        content: "";
        position: absolute;
        right: 0;
        bottom: 0;
        display: block;
        width: 10px;
        height: 10px;
        border-right: 10px solid #004EA2;
        border-top: 10px solid transparent; }
      .list-anchor li a:hover {
        background: #fafafa; }
    .list-anchor li:nth-child(2) a::before {
      border-right: 10px solid #FF6600; }
    .list-anchor li:nth-child(4) a::before {
      border-right: 10px solid #edb918; }
    .list-anchor li:nth-child(3) a::before {
      border-right: 10px solid #46B446; }
  @media screen and (max-width: 959px) {
    .list-anchor {
      -ms-flex-wrap: wrap;
          flex-wrap: wrap; }
      .list-anchor li {
        width: 100%; }
        .list-anchor li a {
          height: 50px; }
        .list-anchor li + li {
          margin-top: 10px; } }
.list-card {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between; }
  @media screen and (max-width: 959px) {
    .list-card {
      padding: 0 20px;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap; } }
  .list-card .card {
    position: relative;
    width: 380px;
    height: 570px;
    -webkit-box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
            box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
    background-size: cover;
    background-position: center;
    background-image: url(/common/images/noimage.jpg);
    /*
    &:nth-child(1) { background-image: url(/images/index/interview01.jpg); }
    &:nth-child(2) { background-image: url(/images/index/interview02.jpg); }
    &:nth-child(3) { background-image: url(/images/index/interview03.jpg); }
    @include mediaTablet {
    	&:nth-child(1) { background-image: url(/images/index/interview01-sp.jpg); }
    	&:nth-child(2) { background-image: url(/images/index/interview02-sp.jpg); }
    	&:nth-child(3) { background-image: url(/images/index/interview03-sp.jpg); }
    }*/ }
    @media screen and (min-width: 959px) and (max-width: 1340px) {
      .list-card .card {
        width: calc((100% - 40px)/3);
        height: 400px; } }
    @media screen and (max-width: 959px) {
      .list-card .card {
        width: 100%;
        height: 37vw; }
        .list-card .card + .card {
          margin-top: 10px; } }
    .list-card .card a {
      display: block;
      width: 100%;
      height: 100%; }
    .list-card .card:hover {
      opacity: .6; }
    .list-card .card__title {
      position: absolute;
      left: 0;
      bottom: 30px;
      width: 360px;
      padding: 30px 20px;
      background: rgba(0, 78, 162, 0.7); }
      @media screen and (min-width: 959px) and (max-width: 1340px) {
        .list-card .card__title {
          width: 100%; } }
      @media screen and (max-width: 959px) {
        .list-card .card__title {
          left: auto;
          right: 0;
          top: 0;
          height: 100%;
          width: 120px;
          padding: 13vw 0 0 26px; }
          .list-card .card__title:before {
            content: "";
            display: block;
            width: 40px;
            height: 37vw;
            position: absolute;
            top: 0;
            left: -40px;
            border-top: 37vw solid rgba(0, 78, 162, 0.7);
            border-left: 40px solid transparent; } }
      .list-card .card__title h3 {
        font: bold 20px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
        margin-bottom: 10px;
        color: white; }
        @media screen and (max-width: 959px) {
          .list-card .card__title h3 {
            font-size: 16px;
            margin-bottom: 3px; } }
      .list-card .card__title span {
        position: relative;
        font: normal 12px/1 "Poppins", sans-serif;
        color: white;
        padding-left: 18px; }
        .list-card .card__title span::before {
          content: "";
          display: block;
          position: absolute;
          top: 50%;
          -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
          width: 10px;
          height: 1px;
          background: white; }
        @media screen and (max-width: 959px) {
          .list-card .card__title span {
            font-size: 10px;
            letter-spacing: 0;
            padding-left: 1px; }
            .list-card .card__title span::before {
              display: none;
              width: 5px; } }
  @media screen and (max-width: 767px) {
    .list-card.long {
      padding: 0; } }
  @media screen and (min-width: 960px) {
    .list-card.long .card {
      width: calc(50% - 20px); } }
@media screen and (max-width: 959px) {
  .list-block {
    padding: 0 20px; } }
.list-block .block a {
  position: relative;
  display: block;
  width: 100%;
  height: 400px;
  background-size: cover;
  -webkit-transition: -webkit-transform .5s ease, -webkit-box-shadow .5s ease;
  transition: -webkit-transform .5s ease, -webkit-box-shadow .5s ease;
  transition: transform .5s ease, box-shadow .5s ease;
  transition: transform .5s ease, box-shadow .5s ease, -webkit-transform .5s ease, -webkit-box-shadow .5s ease;
  -webkit-transform-origin: center;
          transform-origin: center;
  -webkit-box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
          box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); }
  @media screen and (min-width: 959px) and (max-width: 1340px) {
    .list-block .block a {
      height: 28vw; } }
  @media screen and (max-width: 959px) {
    .list-block .block a {
      height: calc((100vw - 40px) * 2 / 3); } }
  .list-block .block a::before {
    content: "";
    display: block;
    width: 100%;
    height: 224px;
    position: absolute;
    bottom: 0;
    left: 0;
    background-image: url(/images/index/crosstalk-grad.png); }
  .list-block .block a:hover {
    -webkit-transform: scale(1.01);
            transform: scale(1.01);
    -webkit-box-shadow: 0px 6px 10px rgba(0, 0, 0, 0.2);
            box-shadow: 0px 6px 10px rgba(0, 0, 0, 0.2); }
.list-block .block:nth-child(1) a {
  background-image: url(/images/index/crosstalk01.jpg?2); }
.list-block .block:nth-child(2) a {
  background-image: url(/images/index/crosstalk02.jpg?2); }
.list-block .block:nth-child(3) a {
  background-image: url(/images/index/crosstalk03.jpg); }
@media screen and (max-width: 959px) {
  .list-block .block:nth-child(1) a {
    background-image: url(/images/index/crosstalk01-sp.jpg?2); }
  .list-block .block:nth-child(2) a {
    background-image: url(/images/index/crosstalk02-sp.jpg?2); }
  .list-block .block:nth-child(3) a {
    background-image: url(/images/index/crosstalk03-sp.jpg); } }
.list-block .block.crosstalk01 a {
  background-image: url(/images/index/crosstalk01.jpg?2); }
.list-block .block.crosstalk02 a {
  background-image: url(/images/index/crosstalk02.jpg?2); }
.list-block .block.crosstalk03 a {
  background-image: url(/images/index/crosstalk03.jpg); }
@media screen and (max-width: 959px) {
  .list-block .block.crosstalk01 a {
    background-image: url(/images/index/crosstalk01-sp.jpg?2); }
  .list-block .block.crosstalk02 a {
    background-image: url(/images/index/crosstalk02-sp.jpg?2); }
  .list-block .block.crosstalk03 a {
    background-image: url(/images/index/crosstalk03-sp.jpg); } }
.list-block .block + .block {
  margin-top: 40px; }
  @media screen and (max-width: 959px) {
    .list-block .block + .block {
      margin-top: 20px; } }
.list-block .block__title {
  position: absolute;
  left: 0;
  bottom: 0;
  padding: 40px; }
  .list-block .block__title span {
    color: white;
    font: bold 40px/1 "Poppins", sans-serif; }
  .list-block .block__title h3 {
    color: white;
    margin-top: 10px;
    font: bold 16px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif; }
  @media screen and (max-width: 959px) {
    .list-block .block__title {
      padding: 20px; }
      .list-block .block__title span {
        font-size: 18px; }
      .list-block .block__title h3 {
        margin-top: 5px;
        font-size: 12px; } }
.list-sdgs {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 50px; }
  @media screen and (max-width: 959px) {
    .list-sdgs {
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
      padding: 0 20px; } }
  .list-sdgs .sdgs__item {
    width: calc((100% - 60px)/4);
    padding: 30px 20px;
    border-radius: 3px;
    border: 1px solid rgba(0, 78, 162, 0.2);
    background: rgba(0, 78, 162, 0.05); }
    @media screen and (max-width: 959px) {
      .list-sdgs .sdgs__item {
        width: 100%; }
        .list-sdgs .sdgs__item + .sdgs__item {
          margin-top: 30px; } }
  .list-sdgs .sdgs__title {
    text-align: center;
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-bottom: 3px double rgba(0, 78, 162, 0.2); }
    .list-sdgs .sdgs__title span {
      display: block;
      text-align: center;
      font: normal 40px/1 "Poppins", sans-serif;
      color: #004EA2; }
    .list-sdgs .sdgs__title h4 {
      margin-top: 10px;
      font: bold 18px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif; }
  .list-sdgs .sdgs__list li {
    text-indent: -1em;
    padding-left: 1em;
    font: normal 14px/1.5 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif; }
    .list-sdgs .sdgs__list li + li {
      margin-top: 10px; }
      @media screen and (max-width: 959px) {
        .list-sdgs .sdgs__list li + li {
          margin-top: 5px; } }
  .list-sdgs .sdgs__img {
    margin-top: 20px; }
.list-target {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between; }
  @media screen and (max-width: 959px) {
    .list-target {
      -ms-flex-wrap: wrap;
          flex-wrap: wrap; } }
  .list-target .target {
    width: calc(50% - 20px); }
    @media screen and (max-width: 959px) {
      .list-target .target {
        width: 100%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex; } }
    .list-target .target__img {
      margin-bottom: 20px; }
      @media screen and (max-width: 959px) {
        .list-target .target__img {
          margin-bottom: 10px;
          width: 140px; } }
    .list-target .target__name p {
      color: #004EA2; }
      .list-target .target__name p span {
        display: inline-block;
        padding: 8px 10px 10px;
        font-size: 13px;
        letter-spacing: .2em;
        background: #004EA2;
        color: white;
        margin-right: 10px;
        vertical-align: 1px; }
        .list-target .target__name p span.purc {
          background: #FF6600; }
        .list-target .target__name p span.is {
          background: #46B446; }
        .list-target .target__name p span.logi {
          background: #edb918; }
      .list-target .target__name p small {
        font: bold 18px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
        color: #2e2b28; }
      @media screen and (max-width: 959px) {
        .list-target .target__name p span {
          font-size: 10px; }
        .list-target .target__name p small {
          font-size: 14px; } }
    @media screen and (max-width: 959px) {
      .list-target .target__main {
        margin-left: 10px;
        padding-top: 22px; } }
    .list-target .target__info p {
      margin-top: 10px;
      font: bold 14px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
      opacity: .6; }
      @media screen and (max-width: 959px) {
        .list-target .target__info p {
          font-size: 10px; } }
  .list-target.col3 .target {
    width: calc((100% - 40px)/3); }
    @media screen and (max-width: 959px) {
      .list-target.col3 .target {
        width: 100%; } }

.gridblock, .gridblock--r {
  display: grid;
  grid-template-columns: 2fr 1fr;
  -webkit-column-gap: 20px;
          column-gap: 20px;
  row-gap: 20px; }
  @media screen and (max-width: 959px) {
    .gridblock, .gridblock--r {
      grid-template-columns: 1fr;
      row-gap: 10px;
      -webkit-column-gap: 10px;
              column-gap: 10px; } }
  .gridblock > div, .gridblock--r > div {
    background: white;
    padding: 30px; }
    @media screen and (max-width: 959px) {
      .gridblock > div, .gridblock--r > div {
        padding: 30px 20px; } }
  @media screen and (min-width: 960px) {
    .gridblock .large, .gridblock--r .large {
      grid-row-start: 1;
      grid-row-end: 3; }
      .gridblock .large--r, .gridblock--r .large--r {
        grid-row-start: 1;
        grid-row-end: 3;
        grid-column-end: 3; } }
  .gridblock + .gridblock__r, .gridblock--r + .gridblock__r, .gridblock + .gridblock, .gridblock--r + .gridblock, .gridblock + .gridblock--r, .gridblock--r + .gridblock--r {
    margin-top: 20px; }
    @media screen and (max-width: 959px) {
      .gridblock + .gridblock__r, .gridblock--r + .gridblock__r, .gridblock + .gridblock, .gridblock--r + .gridblock, .gridblock + .gridblock--r, .gridblock--r + .gridblock--r {
        margin-top: 10px; } }
  .gridblock--r {
    grid-template-columns: 1fr 2fr; }
    @media screen and (max-width: 959px) {
      .gridblock--r {
        grid-template-columns: 1fr; } }

.data {
  -webkit-transition: -webkit-transform .5s ease;
  transition: -webkit-transform .5s ease;
  transition: transform .5s ease;
  transition: transform .5s ease, -webkit-transform .5s ease;
  -webkit-transform: perspective(4000px) rotateX(-90deg);
          transform: perspective(4000px) rotateX(-90deg);
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
  -webkit-transform-origin: center bottom;
          transform-origin: center bottom; }
  .data.inview {
    -webkit-transform: perspective(4000px) rotateX(0);
            transform: perspective(4000px) rotateX(0); }
  .data p {
    font: normal 14px/1 "Poppins", sans-serif;
    color: #004EA2; }
  .data h3 {
    font: bold 20px/1.6 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    color: #004EA2;
    margin-bottom: 20px; }
  .data__img {
    text-align: center; }
  .data__figure {
    position: relative; }
  .data#data01 .data__figure {
    position: relative; }
    .data#data01 .data__figure .bars {
      display: block;
      position: absolute;
      bottom: 0;
      left: 0;
      -webkit-transition: opacity 1.5s ease, -webkit-transform 1.5s ease;
      transition: opacity 1.5s ease, -webkit-transform 1.5s ease;
      transition: transform 1.5s ease, opacity 1.5s ease;
      transition: transform 1.5s ease, opacity 1.5s ease, -webkit-transform 1.5s ease;
      -webkit-transform-origin: center bottom;
              transform-origin: center bottom;
      -webkit-transform: scaleY(0);
              transform: scaleY(0);
      opacity: 0; }
    .data#data01 .data__figure img {
      vertical-align: bottom; }
    .data#data01 .data__figure.inview .bars {
      -webkit-transform: scaleY(1);
              transform: scaleY(1);
      opacity: 1; }
  .data#data02 .data__icon {
    width: 40%; }
  .data#data02 .data__info {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 55%; }
  .data#data02 .data__number {
    position: absolute;
    top: 0;
    left: 45%;
    font-size: 35px;
    font-weight: bold; }
    .data#data02 .data__number span {
      font-size: 50px;
      margin-right: 5px; }
    @media screen and (min-width: 959px) and (max-width: 1340px) {
      .data#data02 .data__number {
        font-size: 20px; }
        .data#data02 .data__number span {
          font-size: 33px; } }
  .data#data03 .data__icon {
    width: 40%; }
  .data#data03 .data__number {
    position: absolute;
    left: 45%;
    bottom: 0;
    font-size: 50px;
    font-weight: bold; }
    .data#data03 .data__number span {
      display: block;
      font-size: 76px;
      margin-bottom: 5px; }
    @media screen and (min-width: 959px) and (max-width: 1340px) {
      .data#data03 .data__number {
        font-size: 33px; }
        .data#data03 .data__number span {
          font-size: 50px; } }
    @media screen and (max-width: 767px) {
      .data#data03 .data__number {
        left: 50%; } }
  @media screen and (min-width: 959px) and (max-width: 1340px) {
    .data#data04 .data__figure {
      margin-top: 60px; } }
  .data#data04 .data__icon {
    width: 45%; }
  .data#data04 .data__number {
    position: absolute;
    left: 50%;
    bottom: 0; }
    .data#data04 .data__number p {
      font-size: 80px;
      font-weight: bold;
      letter-spacing: 0.1em; }
      @media screen and (min-width: 959px) and (max-width: 1340px) {
        .data#data04 .data__number p {
          font-size: 60px; } }
    @media screen and (max-width: 767px) {
      .data#data04 .data__number {
        left: 55%; } }
  .data#data04 .data__info {
    padding-left: 10px; }
    @media screen and (min-width: 959px) and (max-width: 1340px) {
      .data#data04 .data__info {
        padding-left: 5px; } }
    .data#data04 .data__info p {
      font-size: 16px;
      letter-spacing: 0.2em; }
      .data#data04 .data__info p span {
        font-size: 20px; }
      @media screen and (min-width: 959px) and (max-width: 1340px) {
        .data#data04 .data__info p {
          font-size: 14px; }
          .data#data04 .data__info p span {
            font-size: 18px; } }
  .data#data05 .data__icon {
    width: 45%; }
  .data#data05 .data__number {
    position: absolute;
    left: 50%;
    bottom: 30px;
    font-size: 25px;
    font-weight: bold;
    line-height: 50px; }
    .data#data05 .data__number span {
      font-size: 50px;
      margin: 0 5px; }
    @media screen and (min-width: 959px) and (max-width: 1340px) {
      .data#data05 .data__number {
        font-size: 16px; }
        .data#data05 .data__number span {
          font-size: 28px; } }
  .data#data06 .data__figure {
    position: relative;
    text-align: center; }
    .data#data06 .data__figure .bars {
      position: absolute;
      right: 0;
      left: 0;
      margin: 0 auto;
      -webkit-transition: opacity 1.5s ease, -webkit-transform 1s ease;
      transition: opacity 1.5s ease, -webkit-transform 1s ease;
      transition: transform 1s ease, opacity 1.5s ease;
      transition: transform 1s ease, opacity 1.5s ease, -webkit-transform 1s ease;
      -webkit-transform-origin: center;
              transform-origin: center;
      opacity: 0;
      -webkit-transform: scale(0.6);
              transform: scale(0.6); }
    .data#data06 .data__figure.inview .bars {
      -webkit-transform: scale(1);
              transform: scale(1);
      opacity: 1; }
  .data#data07 .data__figure {
    position: relative; }
    .data#data07 .data__figure .bars {
      position: absolute;
      bottom: 0;
      left: 0;
      -webkit-transition: opacity 1.5s ease, -webkit-transform 0.5s ease;
      transition: opacity 1.5s ease, -webkit-transform 0.5s ease;
      transition: transform 0.5s ease, opacity 1.5s ease;
      transition: transform 0.5s ease, opacity 1.5s ease, -webkit-transform 0.5s ease;
      -webkit-transform-origin: left center;
              transform-origin: left center;
      -webkit-transform: scaleX(0);
              transform: scaleX(0);
      opacity: 0;
      z-index: -1; }
    .data#data07 .data__figure.inview .bars {
      -webkit-transform: scaleX(1);
              transform: scaleX(1);
      opacity: 1; }
  .data#data08 .data__icon {
    width: 45%; }
  .data#data08 .data__number {
    position: absolute;
    left: 50%;
    bottom: 30px;
    font-size: 25px;
    font-weight: bold;
    line-height: 50px; }
    .data#data08 .data__number strong {
      font-size: 50px;
      margin: 0 5px; }
      .data#data08 .data__number strong span {
        font-size: 60px; }
    @media screen and (min-width: 959px) and (max-width: 1340px) {
      .data#data08 .data__number {
        font-size: 20px; }
        .data#data08 .data__number strong {
          font-size: 30px; }
          .data#data08 .data__number strong span {
            font-size: 40px; } }
  .data#data09 .data__icon {
    width: 45%; }
  .data#data09 .data__number {
    position: absolute;
    left: 50%;
    bottom: 10px;
    font-size: 25px;
    font-weight: bold;
    line-height: 50px; }
    .data#data09 .data__number span {
      font-size: 50px;
      margin: 0 10px; }
    @media screen and (min-width: 959px) and (max-width: 1340px) {
      .data#data09 .data__number {
        bottom: 0;
        font-size: 16px; }
        .data#data09 .data__number span {
          font-size: 30px;
          margin: 0 3px; } }

.article {
  padding: 150px 0; }
  @media screen and (max-width: 959px) {
    .article {
      padding: 80px 0; } }
  .article.colored {
    background-color: #F5F8FB; }
  .article.colored--mc {
    background-color: #004EA2; }
  .article__title {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
    text-align: left; }
    @media screen and (min-width: 959px) and (max-width: 1340px) {
      .article__title {
        padding-left: 20px; } }
    @media screen and (max-width: 959px) {
      .article__title {
        padding: 0 20px; } }
    .article__title .inner {
      position: relative;
      display: inline-block; }
      .article__title .inner .enttl {
        display: inline-block;
        font: 100 70px/1 "Poppins", sans-serif;
        color: #004EA2;
        margin-bottom: 30px; }
        .article__title .inner .enttl strong {
          font-weight: bold; }
        @media screen and (max-width: 959px) {
          .article__title .inner .enttl {
            font-size: 35px;
            margin-bottom: 10px; } }
      .article__title .inner h2 {
        font: normal 20px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
        color: #004EA2; }
        @media screen and (max-width: 959px) {
          .article__title .inner h2 {
            font-size: 12px; } }
      .article__title .inner::before {
        content: "";
        position: absolute;
        right: 0;
        bottom: 40px;
        height: 3px;
        width: 100vw;
        background-color: #004EA2; }
        @media screen and (max-width: 959px) {
          .article__title .inner::before {
            bottom: 18px;
            height: 2px; } }
    .article__title.rev .inner h2 {
      font: bold 40px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
      letter-spacing: .1em;
      margin-bottom: 50px; }
      @media screen and (max-width: 959px) {
        .article__title.rev .inner h2 {
          font-size: 20px;
          margin-bottom: 10px;
          line-height: 1.4; } }
    .article__title.rev .inner .enttl {
      font-size: 20px;
      margin-bottom: 0;
      padding-left: 3px; }
      @media screen and (max-width: 959px) {
        .article__title.rev .inner .enttl {
          font-size: 12px; } }
    .article__title + .article__main {
      margin-top: 60px; }
      @media screen and (max-width: 959px) {
        .article__title + .article__main {
          margin-top: 40px; } }
  .article__main {
    position: relative;
    max-width: 1200px;
    width: 100%;
    margin: 0 auto; }
    @media screen and (min-width: 959px) and (max-width: 1340px) {
      .article__main {
        padding: 0 20px; } }
    .article__main p + p.cate {
      margin-top: 30px; }
    .article__main p.cate span {
      display: inline-block;
      padding: 4px 10px 6px;
      font-size: 12px;
      font-weight: bold;
      letter-spacing: .2em;
      background: #004EA2;
      color: white;
      margin-right: 10px;
      vertical-align: 1px; }
      .article__main p.cate span.purc {
        background: #FF6600; }
      .article__main p.cate span.is {
        background: #46B446; }
      .article__main p.cate span.logi {
        background: #edb918; }
    .article__main p.cate + p {
      margin-top: 15px; }
    .article__main.wide {
      max-width: none; }

.contents {
  max-width: 900px;
  width: 100%;
  margin: 0 auto; }
  .contents p {
    font: normal 16px/2 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    letter-spacing: .08em; }
    .contents p + p {
      margin-top: 30px; }
  @media screen and (max-width: 959px) {
    .contents {
      margin: 10px auto; }
      .contents p {
        font-size: 14px; }
        .contents p + p {
          margin-top: 10px; } }

.insertimg.right, #type-page .right.type__headimg {
  text-align: right; }
.insertimg img, #type-page .type__headimg img {
  width: calc(50% + 600px); }

.box {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto 50px; }
  @media screen and (max-width: 959px) {
    .box {
      margin: 0 auto 10px; } }

@media screen and (max-width: 959px) {
  .cnt-entry {
    padding: 80px 20px; } }
.cnt-entry__btns {
  max-width: 1140px;
  width: 100%;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; }
  @media screen and (min-width: 966px) and (max-width: 1260px) {
    .cnt-entry__btns {
      max-width: 860px; } }
  @media screen and (max-width: 959px) {
    .cnt-entry__btns {
      max-width: 100%;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap; } }
  .cnt-entry__btns .btn--large a {
    position: relative; }
    .cnt-entry__btns .btn--large a > p {
      position: absolute;
      left: 0;
      right: 0;
      margin: 0 auto;
      top: 50%;
      -webkit-transform: translateY(-50%);
              transform: translateY(-50%);
      font-size: 100px;
      opacity: .05;
      color: black; }
    @media screen and (min-width: 966px) and (max-width: 1260px) {
      .cnt-entry__btns .btn--large a {
        max-width: 420px;
        height: 125px; }
        .cnt-entry__btns .btn--large a > p {
          font-size: 80px; } }
    @media screen and (max-width: 959px) {
      .cnt-entry__btns .btn--large a > p {
        font-size: 70px; } }
  @media screen and (max-width: 959px) {
    .cnt-entry__btns .btn--large.career {
      margin-top: 10px; } }
  .cnt-entry__btns .btn--large.career a {
    background-color: #43B1AD; }
    .cnt-entry__btns .btn--large.career a > p {
      color: white;
      opacity: .1; }

/* =========================================================
	animation
========================================================= */
.fadeUp, .fadeUp--d01, .fadeUp--d02, .fadeUp--d03 {
  -webkit-animation-name: fadeUpAnime;
          animation-name: fadeUpAnime;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  opacity: 0; }
  .fadeUp--d01 {
    -webkit-animation-delay: 0s;
            animation-delay: 0s; }
  .fadeUp--d02 {
    -webkit-animation-delay: 0.6s;
            animation-delay: 0.6s; }
  .fadeUp--d03 {
    -webkit-animation-delay: 1.2s;
            animation-delay: 1.2s; }

@-webkit-keyframes fadeUpAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(10px);
            transform: translateY(10px); }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0); } }

@keyframes fadeUpAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(10px);
            transform: translateY(10px); }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0); } }
.crosstalk__auth {
  max-width: 940px;
  margin: 0 auto;
  padding: 0 20px;
  margin-top: 120px; }
  @media screen and (max-width: 959px) {
    .crosstalk__auth {
      margin-top: 60px; } }

/* =========================================================
	#wrapper
========================================================= */
html {
  /*
  @include mediaPC {
  	min-width: 1340px;
  }
  */ }

/* =========================================================
 underpage
========================================================= */
/* =========================================================
	pagetitle
========================================================= */
.pagetitle {
  position: relative;
  width: 100%;
  height: 400px;
  background-position: center;
  background-size: cover; }
  .pagetitle__title {
    position: absolute;
    left: 0;
    right: 0;
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
    bottom: -69px; }
    .pagetitle__title p {
      display: inline-block;
      background: #004EA2;
      color: white;
      font: bold 80px/1.2 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
      letter-spacing: .1em;
      padding: 0 20px 10px 20px;
      -webkit-animation-name: fadeUpAnime;
              animation-name: fadeUpAnime;
      -webkit-animation-duration: 0.5s;
              animation-duration: 0.5s;
      -webkit-animation-fill-mode: forwards;
              animation-fill-mode: forwards;
      -webkit-animation-timing-function: ease-in-out;
              animation-timing-function: ease-in-out;
      opacity: 0; }
    .pagetitle__title h1 {
      display: inline-block;
      background: #004EA2;
      color: white;
      font: bold 20px/1.2 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
      letter-spacing: .1em;
      padding: 0 20px 10px 26px;
      -webkit-animation-name: fadeUpAnime;
              animation-name: fadeUpAnime;
      -webkit-animation-duration: 0.5s;
              animation-duration: 0.5s;
      -webkit-animation-fill-mode: forwards;
              animation-fill-mode: forwards;
      -webkit-animation-timing-function: ease-in-out;
              animation-timing-function: ease-in-out;
      opacity: 0; }
    .pagetitle__title span.category {
      display: inline-block;
      padding: 12px 20px 15px 26px;
      background: white;
      color: #004EA2;
      font: bold 16px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
      -webkit-animation-name: fadeUpAnime;
              animation-name: fadeUpAnime;
      -webkit-animation-duration: 0.5s;
              animation-duration: 0.5s;
      -webkit-animation-fill-mode: forwards;
              animation-fill-mode: forwards;
      -webkit-animation-timing-function: ease-in-out;
              animation-timing-function: ease-in-out;
      opacity: 0; }
  .pagetitle.tinterview {
    height: calc(100vh - 80px);
    position: relative; }
    .pagetitle.tinterview:before {
      content: "";
      display: block;
      background: rgba(0, 0, 0, 0.05);
      width: 100%;
      height: 100%;
      position: absolute; }
    @media screen and (max-width: 959px) {
      .pagetitle.tinterview.crosstalk {
        height: 53vw; } }
  .pagetitle .tinterview__main {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto; }
    @media screen and (min-width: 959px) and (max-width: 1340px) {
      .pagetitle .tinterview__main {
        padding: 0 20px; } }
  .pagetitle .tinterview__title p.read {
    font: bold 16px/1 "Poppins", sans-serif;
    color: #004EA2;
    margin-bottom: 40px; }
  .pagetitle .tinterview__title h1 {
    font: bold 25px/2 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    letter-spacing: .2em;
    color: white; }
  @media screen and (max-width: 959px) {
    .pagetitle .tinterview__title {
      padding-left: 20px; }
      .pagetitle .tinterview__title p.read {
        font-size: 12px;
        margin-bottom: 20px; }
      .pagetitle .tinterview__title h1 {
        font-size: 20px;
        line-height: 1.6; } }
  .pagetitle .tinterview__auth {
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    margin-top: 70px;
    padding: 30px 40px;
    background: white; }
    .pagetitle .tinterview__auth .cat {
      display: inline-block;
      padding: 8px 20px 11px;
      background: #004EA2;
      color: white;
      font: normal 14px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
      letter-spacing: .08em; }
    .pagetitle .tinterview__auth .name {
      margin: 15px 0 15px;
      font: bold 24px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif; }
      .pagetitle .tinterview__auth .name small {
        padding-left: 10px;
        font: normal 14px/1 "Poppins", sans-serif; }
    .pagetitle .tinterview__auth .date {
      font: bold 14px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
      opacity: 0.4; }
    @media screen and (max-width: 959px) {
      .pagetitle .tinterview__auth {
        margin-top: 25px;
        padding: 30px 40px 0 20px; }
        .pagetitle .tinterview__auth .cat {
          padding: 6px 10px 8px;
          font-size: 12px; }
        .pagetitle .tinterview__auth .name {
          margin: 10px 0 0;
          font-size: 20px; }
        .pagetitle .tinterview__auth .date {
          font-size: 12px; } }
  .pagetitle .tinterview__cttitle {
    background: #004EA2;
    text-align: center;
    padding: 40px;
    position: relative;
    top: 60px; }
    .pagetitle .tinterview__cttitle .num {
      display: inline-block;
      padding: 10px 20px 8px;
      color: #004EA2;
      background: white;
      font: bold 16px/1 "Poppins", sans-serif;
      letter-spacing: 0.2em; }
    .pagetitle .tinterview__cttitle .name {
      color: white;
      margin: 20px auto;
      font: bold 40px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
      letter-spacing: 0.2em; }
      .pagetitle .tinterview__cttitle .name span {
        font-size: 0.7em;
        vertical-align: 4px; }
    .pagetitle .tinterview__cttitle .cat {
      color: white;
      font: normal 16px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif; }
      .pagetitle .tinterview__cttitle .cat span {
        font-size: 0.8em;
        vertical-align: 1px; }
  @media screen and (max-width: 959px) {
    .pagetitle {
      margin-top: 46px;
      height: 250px; }
      .pagetitle .header__logo {
        display: none; }
      .pagetitle__title {
        bottom: -16px; }
        .pagetitle__title p {
          font-size: 27px;
          padding-bottom: 4px; }
        .pagetitle__title h1 {
          font-size: 14px;
          padding-bottom: 10px;
          padding-left: 21px; }
        .pagetitle__title span.category {
          font-size: 12px;
          padding: 8px 15px 9px 21px; } }

.tinterview--sp .tinterview__title {
  padding: 20px 20px;
  background: white; }
  .tinterview--sp .tinterview__title h1 {
    text-align: center;
    color: #004EA2;
    font: bold 14px/2.2 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    letter-spacing: .08em; }
.tinterview--sp .tinterview__cttitle {
  padding: 30px 20px;
  background: #004EA2;
  text-align: center; }
  .tinterview--sp .tinterview__cttitle .num {
    display: inline-block;
    padding: 10px 20px 8px;
    color: #004EA2;
    background: white;
    font: bold 10px/1 "Poppins", sans-serif;
    letter-spacing: 0.2em; }
  .tinterview--sp .tinterview__cttitle .name {
    color: white;
    margin: 15px auto;
    font: bold 25px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    letter-spacing: 0.2em; }
    .tinterview--sp .tinterview__cttitle .name span {
      display: block;
      font-size: 0.7em;
      vertical-align: 4px;
      margin: 5px 0; }
  .tinterview--sp .tinterview__cttitle .cat {
    color: white;
    font: normal 14px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif; }
    .tinterview--sp .tinterview__cttitle .cat span {
      font-size: 0.8em;
      vertical-align: 1px; }

/* 画像登録所 */
#error-page .pagetitle {
  background-image: url(/images/pagetitle/data.jpg); }

#message-page .pagetitle {
  background-image: url(/images/pagetitle/message.jpg); }

#growth-page .pagetitle {
  background-image: url(/images/pagetitle/growth.jpg); }

#brand-page .pagetitle {
  background-image: url(/images/pagetitle/brand.jpg); }

#type-page .pagetitle {
  background-image: url(/images/pagetitle/type.jpg?2); }

#proper-page .pagetitle {
  background-image: url(/images/pagetitle/proper.jpg); }

#welfare-page .pagetitle {
  background-image: url(/images/pagetitle/welfare.jpg); }

#education-page .pagetitle {
  background-image: url(/images/pagetitle/education.jpg); }

#data-page .pagetitle {
  background-image: url(/images/pagetitle/data.jpg); }

#interview-page .pagetitle {
  background-image: url(/images/pagetitle/interview.jpg); }

#interview-page.cnt-interview01 .pagetitle {
  background-image: url(/images/pagetitle/interview01.jpg); }

#interview-page.cnt-interview02 .pagetitle {
  background-image: url(/images/pagetitle/interview02.jpg); }

#interview-page.cnt-interview03 .pagetitle {
  background-image: url(/images/pagetitle/interview03.jpg); }

#crosstalk-page .pagetitle {
  background-image: url(/images/pagetitle/crosstalk.jpg); }

#crosstalk-page.underpage-talk01 .pagetitle {
  background-image: url(/images/pagetitle/crosstalk01.jpg?2); }

#crosstalk-page.underpage-talk03 .pagetitle {
  background-image: url(/images/pagetitle/crosstalk02.jpg?2); }

#crosstalk-page.underpage-talk02 .pagetitle {
  background-image: url(/images/pagetitle/crosstalk03.jpg?2); }

#careerplan-page .pagetitle {
  background-image: url(/images/pagetitle/careerplan.jpg); }

#news-page .pagetitle {
  background-image: url(/images/pagetitle/news.jpg); }

@media screen and (max-width: 959px) {
  #interview-page .pagetitle {
    background-image: url(/images/pagetitle/interview-sp.jpg); }

  #brand-page .pagetitle {
    background-image: url(/images/pagetitle/brand-sp.jpg); }

  #crosstalk-page .pagetitle {
    background-image: url(/images/pagetitle/crosstalk-sp.jpg); }

  #welfare-page .pagetitle {
    background-image: url(/images/pagetitle/welfare-sp.jpg); }

  #careerplan-page .pagetitle {
    background-image: url(/images/pagetitle/careerplan-sp.jpg); }

  #news-page .pagetitle {
    background-image: url(/images/pagetitle/news-sp.jpg); } }
/* =========================================================
	header
========================================================= */
.header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99;
  width: 100%; }
  .header__line {
    position: relative;
    background: #004EA2;
    width: 100%;
    height: 16px; }
    @media screen and (max-width: 959px) {
      .header__line {
        height: 8px; } }
    .header__line::before {
      content: "";
      position: absolute;
      top: 0;
      left: -2.25%;
      display: block;
      width: 22%;
      height: 100%;
      background: #46B446;
      -webkit-transform: skewX(-45deg);
              transform: skewX(-45deg); }
  .header__logo {
    position: relative;
    width: 100%;
    max-width: 1400px;
    padding: 70px 100px;
    margin: 0 auto;
    z-index: 1; }
    @media screen and (max-width: 959px) {
      .header__logo {
        padding: 20px 20px; }
        .header__logo a {
          display: block;
          width: 80px; } }
  .header__main {
    position: absolute;
    top: 0;
    right: 0;
    width: 100px;
    height: 100vh;
    background: #02458E;
    overflow: hidden; }
    @media screen and (max-width: 959px) {
      .header__main {
        top: 8px;
        width: 100%;
        height: 54px;
        background: white; } }
  @media screen and (max-width: 959px) {
    .header__cv {
      padding: 7px;
      position: absolute;
      top: 0;
      right: 54px;
      height: 100%;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex; }
      .header__cv a {
        padding: 0 15px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        position: relative;
        background: #46B446;
        -webkit-transition: background-color .15s ease;
        transition: background-color .15s ease;
        z-index: 1;
        margin-left: 7px; }
        .header__cv a p {
          display: block;
          font: bold 11px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
          color: white;
          text-align: center;
          letter-spacing: 0; }
          .header__cv a p span {
            display: block;
            margin-top: 2px;
            font: normal 10px/1.4 "Poppins", sans-serif;
            letter-spacing: 0.12em; }
        .header__cv a.career {
          background: #43B1AD; } }
  @media screen and (min-width: 960px) {
    .header__cv {
      padding: 20px;
      position: relative; }
      .header__cv a {
        display: block;
        position: relative;
        width: 100%;
        -webkit-transition: background-color .15s ease;
        transition: background-color .15s ease; }
        .header__cv a span {
          position: absolute;
          bottom: 40px;
          left: 16px;
          font: 600 16px/1.4 "Poppins", sans-serif;
          color: white;
          letter-spacing: .25em;
          -webkit-transform: rotate(90deg);
                  transform: rotate(90deg); }
        .header__cv a:hover {
          opacity: .6; }
        .header__cv a:nth-child(2) {
          margin-top: -10px; } }
  .header__btn {
    display: block;
    width: 18px;
    height: 30px;
    cursor: pointer; }
    @media screen and (min-width: 960px) {
      .header__btn {
        position: absolute;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%); } }
    .header__btn span {
      position: absolute;
      display: block;
      height: 30px;
      width: 2px;
      background: white;
      -webkit-transition: all .25s ease;
      transition: all .25s ease; }
      @media screen and (min-width: 960px) {
        .header__btn span {
          top: 0; }
          .header__btn span:nth-child(1) {
            left: 0; }
          .header__btn span:nth-child(2) {
            right: 8px; }
          .header__btn span:nth-child(3) {
            right: 0; } }
    .header__btn.on span:nth-of-type(1) {
      -webkit-transform: translateX(8px) rotate(45deg);
              transform: translateX(8px) rotate(45deg); }
    .header__btn.on span:nth-of-type(2) {
      opacity: 0; }
    .header__btn.on span:nth-of-type(3) {
      -webkit-transform: translateX(-8px) rotate(-45deg);
              transform: translateX(-8px) rotate(-45deg); }
    @media screen and (max-width: 959px) {
      .header__btn {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        background: #02458E;
        height: 54px;
        width: 54px;
        position: absolute;
        top: 0;
        right: 0;
        z-index: 3; }
        .header__btn div {
          position: relative;
          width: 30px;
          height: 18px;
          top: -3px; }
          .header__btn div span {
            width: 30px;
            height: 2px;
            left: 0; }
            .header__btn div span:nth-child(1) {
              top: 0; }
            .header__btn div span:nth-child(2) {
              top: 8px; }
            .header__btn div span:nth-child(3) {
              top: 16px; }
        .header__btn.on span:nth-of-type(1) {
          -webkit-transform: translateY(8px) rotate(45deg);
                  transform: translateY(8px) rotate(45deg); }
        .header__btn.on span:nth-of-type(2) {
          opacity: 0; }
        .header__btn.on span:nth-of-type(3) {
          -webkit-transform: translateY(-8px) rotate(-45deg);
                  transform: translateY(-8px) rotate(-45deg); } }
  .header__name {
    position: absolute;
    bottom: 0;
    right: 46px;
    width: 180px;
    text-align: right;
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
    -webkit-transform-origin: right;
            transform-origin: right; }
    .header__name p {
      color: white;
      font: normal 10px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
      letter-spacing: .08em; }
      .header__name p.en {
        font: bold 12px/1 "Poppins", sans-serif;
        letter-spacing: .35em;
        margin-bottom: 4px; }
    @media screen and (max-width: 959px) {
      .header__name {
        display: none; } }
  .header__menu {
    position: fixed;
    top: 16px;
    left: 0;
    opacity: 0;
    pointer-events: none;
    width: calc(100% - 100px);
    height: calc(100vh - 16px);
    background: white;
    -webkit-transition: opacity .15s ease;
    transition: opacity .15s ease;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex; }
    .header__menu .sitenav {
      pointer-events: none; }
    .header__menu.on {
      opacity: 1;
      pointer-events: all; }
      .header__menu.on .sitenav {
        pointer-events: all; }
        .header__menu.on .sitenav > li {
          -webkit-animation-name: fadeUpAnime;
                  animation-name: fadeUpAnime;
          -webkit-animation-duration: 0.5s;
                  animation-duration: 0.5s;
          -webkit-animation-fill-mode: forwards;
                  animation-fill-mode: forwards;
          -webkit-animation-timing-function: ease-in-out;
                  animation-timing-function: ease-in-out;
          opacity: 0; }
          .header__menu.on .sitenav > li:nth-child(1) {
            -webkit-animation-delay: 0.1s;
                    animation-delay: 0.1s; }
          .header__menu.on .sitenav > li:nth-child(2) {
            -webkit-animation-delay: 0.2s;
                    animation-delay: 0.2s; }
          .header__menu.on .sitenav > li:nth-child(3) {
            -webkit-animation-delay: 0.3s;
                    animation-delay: 0.3s; }
          .header__menu.on .sitenav > li:nth-child(4) {
            -webkit-animation-delay: 0.4s;
                    animation-delay: 0.4s; }
          .header__menu.on .sitenav > li:nth-child(5) {
            -webkit-animation-delay: 0.5s;
                    animation-delay: 0.5s; }
          .header__menu.on .sitenav > li:nth-child(6) {
            -webkit-animation-delay: 0.6s;
                    animation-delay: 0.6s; }
          .header__menu.on .sitenav > li:nth-child(7) {
            -webkit-animation-delay: 0.7s;
                    animation-delay: 0.7s; }
          .header__menu.on .sitenav > li:nth-child(8) {
            -webkit-animation-delay: 0.8s;
                    animation-delay: 0.8s; }
          .header__menu.on .sitenav > li:nth-child(9) {
            -webkit-animation-delay: 0.9s;
                    animation-delay: 0.9s; }
      .header__menu.on .menu__copy img {
        -webkit-animation-name: fadeUpAnime;
                animation-name: fadeUpAnime;
        -webkit-animation-duration: 1s;
                animation-duration: 1s;
        -webkit-animation-fill-mode: forwards;
                animation-fill-mode: forwards;
        -webkit-animation-timing-function: ease-in-out;
                animation-timing-function: ease-in-out;
        opacity: 0; }
        .header__menu.on .menu__copy img:nth-child(1) {
          -webkit-animation-delay: 0.2s;
                  animation-delay: 0.2s; }
        .header__menu.on .menu__copy img:nth-child(2) {
          -webkit-animation-delay: 0.8s;
                  animation-delay: 0.8s; }
        .header__menu.on .menu__copy img:nth-child(3) {
          -webkit-animation-delay: 1.4s;
                  animation-delay: 1.4s; }
        @media screen and (max-width: 1400px) {
          .header__menu.on .menu__copy img {
            height: 50px; } }
        @media screen and (max-width: 959px) {
          .header__menu.on .menu__copy img {
            height: 30px; } }
    @media screen and (max-width: 959px) {
      .header__menu {
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
        top: 62px;
        width: 100%;
        height: calc(100% - 54px); } }

@media screen and (max-width: 959px) {
  .menu__logo {
    display: none; } }
.menu__left {
  width: 50%;
  border: 1px solid #e5e5e5;
  text-align: right; }
  @media screen and (max-width: 959px) {
    .menu__left {
      width: 100%;
      border: none; } }
  .menu__left .inner {
    display: inline-block;
    max-width: 700px;
    width: 100%;
    text-align: left;
    padding: 70px 0 70px 100px; }
    @media screen and (max-width: 1340px) {
      .menu__left .inner {
        padding: 70px 0 70px 40px; } }
    @media screen and (max-width: 959px) {
      .menu__left .inner {
        padding: 30px 0 30px;
        max-width: 218px;
        margin: 0 auto;
        display: block; } }
.menu__right {
  width: 50%;
  overflow-y: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none; }
  .menu__right::-webkit-scrollbar {
    display: none; }
  @media screen and (max-width: 959px) {
    .menu__right {
      width: 100%;
      height: calc(100% - 190px); } }
.menu__copy img {
  display: block; }
  .menu__copy img + img {
    margin-top: 50px; }
@media screen and (min-width: 960px) {
  .menu__copy {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%); } }
@media screen and (max-width: 959px) {
  .menu__copy img {
    height: 30px; }
    .menu__copy img + img {
      margin-top: 20px; } }

.sitenav {
  padding: 70px; }
  @media screen and (max-width: 959px) {
    .sitenav {
      padding: 20px 20px 100px;
      background: rgba(0, 78, 162, 0.05); } }
  .sitenav > li {
    border-bottom: 1px solid #e5e5e5; }
    .sitenav > li .title {
      padding-bottom: 30px; }
      @media screen and (max-width: 959px) {
        .sitenav > li .title {
          padding-bottom: 20px; } }
      .sitenav > li .title a {
        display: block;
        -webkit-transition: opacity .5s ease;
        transition: opacity .5s ease;
        cursor: pointer; }
        .sitenav > li .title a:hover {
          opacity: .4; }
      .sitenav > li .title p:not([class]) {
        font: bold 30px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
        letter-spacing: .2em;
        color: #004EA2;
        margin-bottom: 10px; }
        @media screen and (min-width: 959px) and (max-width: 1340px) {
          .sitenav > li .title p:not([class]) {
            font-size: 25px; } }
        @media screen and (max-width: 959px) {
          .sitenav > li .title p:not([class]) {
            font-size: 16px;
            margin-bottom: 5px; } }
      .sitenav > li .title p.en {
        font: 100 16px/1 "Poppins", sans-serif;
        opacity: .2;
        padding-left: 1px; }
        @media screen and (max-width: 959px) {
          .sitenav > li .title p.en {
            font-size: 12px; } }
    .sitenav > li .parent a {
      position: relative; }
      .sitenav > li .parent a::before {
        content: "+";
        display: block;
        position: absolute;
        top: 50%;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
        right: 0;
        font: normal 30px/1 "Poppins", sans-serif;
        color: #004EA2; }
        @media screen and (max-width: 959px) {
          .sitenav > li .parent a::before {
            display: none; } }
    .sitenav > li .parent.on a::before {
      content: "-"; }
    .sitenav > li .child {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      opacity: 0;
      height: 0;
      -webkit-transition: all 0.15s ease;
      transition: all 0.15s ease; }
      .sitenav > li .child.on {
        opacity: 1;
        height: -webkit-max-content;
        height: -moz-max-content;
        height: max-content;
        pointer-events: all;
        padding-bottom: 30px; }
      @media screen and (min-width: 960px) {
        .sitenav > li .child {
          pointer-events: none; } }
      @media screen and (min-width: 959px) and (max-width: 1340px) {
        .sitenav > li .child {
          -ms-flex-wrap: wrap;
              flex-wrap: wrap; } }
      @media screen and (max-width: 959px) {
        .sitenav > li .child {
          -ms-flex-wrap: wrap;
              flex-wrap: wrap;
          opacity: 1;
          height: -webkit-max-content;
          height: -moz-max-content;
          height: max-content;
          padding-bottom: 10px; } }
      .sitenav > li .child__item {
        max-width: 200px;
        width: calc((100% - 60px)/4); }
        @media screen and (min-width: 959px) and (max-width: 1340px) {
          .sitenav > li .child__item {
            width: calc((100% - 20px)/2);
            margin-bottom: 20px; }
            .sitenav > li .child__item:nth-child(2n - 1) {
              margin-left: 0 !important; } }
        @media screen and (max-width: 959px) {
          .sitenav > li .child__item {
            width: calc((100% - 20px)/2);
            margin-bottom: 20px; }
            .sitenav > li .child__item:nth-child(2n - 1) {
              margin-left: 0 !important; } }
        .sitenav > li .child__item .img {
          margin-bottom: 10px; }
          .sitenav > li .child__item .img img {
            max-width: 100%; }
        .sitenav > li .child__item p {
          display: block;
          font: normal 12px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
          color: #333;
          letter-spacing: 0.08em; }
          @media screen and (max-width: 959px) {
            .sitenav > li .child__item p {
              font-size: 12px; } }
        .sitenav > li .child__item + .child__item {
          margin-left: 20px; }
        .sitenav > li .child__item a {
          display: block; }
          .sitenav > li .child__item a:hover {
            opacity: .6; }
    .sitenav > li + li {
      margin-top: 30px; }
      @media screen and (max-width: 959px) {
        .sitenav > li + li {
          margin-top: 20px; } }

/* =========================================================
	footer
========================================================= */
.footer {
  padding-top: 130px;
  background: #002C5B; }
  @media screen and (min-width: 959px) and (max-width: 1340px) {
    .footer {
      padding-left: 20px;
      padding-right: 20px; } }
  @media screen and (max-width: 959px) {
    .footer {
      padding-top: 60px; } }
  .footer__nav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
    padding-bottom: 50px;
    border-bottom: 1px solid #244A72; }
    @media screen and (max-width: 959px) {
      .footer__nav {
        display: none; } }
  .footer__info {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
    padding-bottom: 130px;
    padding-top: 50px; }
    @media screen and (max-width: 959px) {
      .footer__info {
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
        padding: 0 20px 80px 20px; } }
  .footer__official {
    padding-top: 34px;
    margin-left: 30px; }
    .footer__official a {
      display: block;
      position: relative;
      padding-left: 20px;
      font: normal 12px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
      color: white; }
      .footer__official a:before {
        content: "";
        position: absolute;
        top: 50%;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
        left: 0;
        width: 10px;
        height: 1px;
        background: white; }
      .footer__official a:hover {
        text-decoration: underline; }
  .footer__copy {
    position: absolute;
    right: 0;
    bottom: 130px; }
    .footer__copy p {
      font: normal 10px/1 "Poppins", sans-serif;
      opacity: .7;
      color: white; }
    @media screen and (max-width: 959px) {
      .footer__copy {
        bottom: 60px;
        right: auto;
        left: 20px; } }
  .footer__bnr {
    margin-left: 30px; }
    @media screen and (max-width: 959px) {
      .footer__bnr {
        margin-left: 0;
        margin-top: 20px; } }

@media screen and (max-width: 959px) {
  .fsitenav {
    display: none; } }
.fsitenav .title {
  margin-bottom: 25px; }
  .fsitenav .title p {
    font: bold 18px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    color: white;
    margin-bottom: 10px; }
  .fsitenav .title span {
    font: normal 12px/1 "Poppins", sans-serif;
    color: white; }
  .fsitenav .title.islink:hover {
    opacity: .6; }
.fsitenav .childlist {
  margin-top: 15px; }
  .fsitenav .childlist .citem {
    margin-bottom: 15px; }
    .fsitenav .childlist .citem a {
      display: block;
      padding-left: 20px;
      position: relative;
      color: white;
      font: normal 12px/1.4 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif; }
      .fsitenav .childlist .citem a:before {
        content: "";
        width: 10px;
        height: 1px;
        background: white;
        display: block;
        position: absolute;
        top: 50%;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
        left: 0; }
      .fsitenav .childlist .citem a:hover {
        text-decoration: underline; }
  .fsitenav .childlist .childlist .citem {
    margin-bottom: 5px; }
    .fsitenav .childlist .childlist .citem a {
      padding-left: 40px; }
      .fsitenav .childlist .childlist .citem a:before {
        left: 20px; }

/* =========================================================
	main
========================================================= */
.main {
  position: relative;
  top: 16px;
  left: 0;
  z-index: 1;
  width: calc(100% - 100px); }
  @media screen and (max-width: 959px) {
    .main {
      width: 100%; } }

/* =========================================================
	mv
========================================================= */
.mv {
  width: 100%; }
  .mv img {
    -o-object-fit: fill;
       object-fit: fill; }

/* home page
========================================================= */
#home-page .mv {
  position: relative;
  background: #ddd;
  width: 100%;
  height: calc(100vh - 16px); }
  #home-page .mv::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.2);
    z-index: 1; }
  @media screen and (max-width: 959px) {
    #home-page .mv {
      top: 46px;
      height: 113.5vw;
      max-height: calc(100vh - 16px); } }
  #home-page .mv__copy {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 100%;
    max-width: 1400px;
    padding: 0 100px;
    z-index: 2; }
    @media screen and (max-width: 959px) {
      #home-page .mv__copy {
        padding: 0 20px; } }
    #home-page .mv__copy img {
      display: block; }
      @media screen and (max-width: 959px) {
        #home-page .mv__copy img {
          height: 40px; } }
      #home-page .mv__copy img + img {
        margin-top: 60px; }
        @media screen and (max-width: 959px) {
          #home-page .mv__copy img + img {
            margin-top: 40px; } }
  #home-page .mv__slide {
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 0; }
    @media screen and (max-width: 959px) {
      #home-page .mv__slide {
        height: 113.5vw;
        max-height: calc(100vh - 16px); } }
    #home-page .mv__slide .swiper-slide {
      overflow: hidden; }
    #home-page .mv__slide .slide01, #home-page .mv__slide .slide02, #home-page .mv__slide .slide03, #home-page .mv__slide .slide04 {
      width: 100%;
      height: 100%;
      background-size: cover;
      background-position: center;
      -webkit-transform-origin: center;
              transform-origin: center; }
    #home-page .mv__slide .slide01 {
      background-image: url(/images/index/mv01.jpg); }
    #home-page .mv__slide .slide02 {
      background-image: url(/images/index/mv02.jpg); }
    #home-page .mv__slide .slide03 {
      background-image: url(/images/index/mv03.jpg); }
    #home-page .mv__slide .slide04 {
      background-image: url(/images/index/mv04.jpg); }
    @media screen and (max-width: 959px) {
      #home-page .mv__slide .slide01 {
        background-image: url(/images/index/mv01-sp.jpg); }
      #home-page .mv__slide .slide02 {
        background-image: url(/images/index/mv02-sp.jpg); }
      #home-page .mv__slide .slide03 {
        background-image: url(/images/index/mv03-sp.jpg); }
      #home-page .mv__slide .slide04 {
        background-image: url(/images/index/mv04-sp.jpg); } }
  #home-page .mv .swiper-slide-active .slide-img,
  #home-page .mv .swiper-slide-duplicate-active .slide-img,
  #home-page .mv .swiper-slide-prev .slide-img {
    -webkit-transform-origin: center;
            transform-origin: center;
    -webkit-animation: zoomUp 10s linear 0s 1 normal both;
            animation: zoomUp 10s linear 0s 1 normal both; }
@-webkit-keyframes zoomUp {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1); }
  100% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1); } }
@keyframes zoomUp {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1); }
  100% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1); } }
#home-page .cnt-recruitconcept {
  padding: 130px 0;
  background: #004EA2;
  text-align: center; }
  @media screen and (max-width: 959px) {
    #home-page .cnt-recruitconcept {
      padding: 130px 0 80px; } }
  #home-page .cnt-recruitconcept .copy {
    margin-bottom: 50px; }
    #home-page .cnt-recruitconcept .copy img {
      margin: 0 auto; }
    @media screen and (max-width: 959px) {
      #home-page .cnt-recruitconcept .copy {
        margin-bottom: 30px;
        padding: 0 20px; }
        #home-page .cnt-recruitconcept .copy img {
          width: 240px; } }
  #home-page .cnt-recruitconcept p {
    font: normal 18px/2.5 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    letter-spacing: .15em;
    color: white; }
    #home-page .cnt-recruitconcept p + p {
      margin-top: 20px; }
    @media screen and (max-width: 959px) {
      #home-page .cnt-recruitconcept p {
        font-size: 16px;
        line-height: 2; }
        #home-page .cnt-recruitconcept p + p {
          margin-top: 10px; } }
#home-page .cnt-message .block {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  padding: 150px 0; }
  @media screen and (min-width: 959px) and (max-width: 1340px) {
    #home-page .cnt-message .block {
      padding: 150px 20px; } }
  @media screen and (max-width: 959px) {
    #home-page .cnt-message .block {
      padding: 80px 20px; } }
#home-page .cnt-aboutus .aboutus__text {
  position: absolute;
  top: 0;
  left: 0;
  width: 400px; }
  @media screen and (min-width: 959px) and (max-width: 1340px) {
    #home-page .cnt-aboutus .aboutus__text {
      left: 20px; } }
  @media screen and (max-width: 959px) {
    #home-page .cnt-aboutus .aboutus__text {
      position: relative;
      width: 100%;
      padding: 0 20px; } }
  #home-page .cnt-aboutus .aboutus__text a {
    color: #004EA2;
    text-decoration: underline; }
    #home-page .cnt-aboutus .aboutus__text a:hover {
      opacity: .6; }
#home-page .cnt-aboutus .aboutus__scroll {
  position: relative;
  top: 20px;
  left: 0px;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  margin-left: calc(50% - 160px);
  font: bold 14px/1 "Poppins", sans-serif;
  color: #004EA2;
  /*下からの距離が変化して丸の全体が上から下に動く*/
  /*上から下にかけて丸が透過→不透明→透過する*/ }
  @media screen and (min-width: 959px) and (max-width: 1340px) {
    #home-page .cnt-aboutus .aboutus__scroll {
      margin-left: 420px; } }
  @media screen and (max-width: 959px) {
    #home-page .cnt-aboutus .aboutus__scroll {
      margin-left: 0;
      left: 10px; } }
  #home-page .cnt-aboutus .aboutus__scroll:before {
    content: "";
    position: absolute;
    bottom: -3px;
    left: 0;
    width: 20px;
    height: 20px;
    border-radius: 10px;
    background: #004EA2;
    -webkit-animation: circlemove 2s ease-in-out infinite, cirlemovehide 2s ease-out infinite;
            animation: circlemove 2s ease-in-out infinite, cirlemovehide 2s ease-out infinite; }
  #home-page .cnt-aboutus .aboutus__scroll:after {
    content: "";
    display: block;
    position: absolute;
    left: 70px;
    top: 6px;
    width: 100px;
    height: 1px;
    background: rgba(0, 78, 162, 0.3); }
@-webkit-keyframes circlemove {
  0% {
    left: 70px; }
  100% {
    left: 160px; } }
@keyframes circlemove {
  0% {
    left: 70px; }
  100% {
    left: 160px; } }
@-webkit-keyframes cirlemovehide {
  0% {
    opacity: 0; }
  50% {
    opacity: 1; }
  80% {
    opacity: 0.9; }
  100% {
    opacity: 0; } }
@keyframes cirlemovehide {
  0% {
    opacity: 0; }
  50% {
    opacity: 1; }
  80% {
    opacity: 0.9; }
  100% {
    opacity: 0; } }
#home-page .cnt-aboutus .aboutus__nav {
  display: block;
  margin-left: calc(50% - 160px);
  width: calc(50% + 160px);
  overflow-x: scroll;
  padding-top: 30px; }
  #home-page .cnt-aboutus .aboutus__nav::-webkit-scrollbar {
    background: white; }
  #home-page .cnt-aboutus .aboutus__nav::-webkit-scrollbar-track {
    background: white; }
  #home-page .cnt-aboutus .aboutus__nav::-webkit-scrollbar-thumb {
    background: #004EA2; }
  #home-page .cnt-aboutus .aboutus__nav::-webkit-scrollbar-button {
    display: none; }
  @media screen and (min-width: 959px) and (max-width: 1340px) {
    #home-page .cnt-aboutus .aboutus__nav {
      margin-left: 420px; } }
  @media screen and (max-width: 959px) {
    #home-page .cnt-aboutus .aboutus__nav {
      margin-left: 0;
      margin-top: 20px;
      width: 100%; } }
#home-page .cnt-aboutus .aboutus__contents {
  width: 1330px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 10px 120px 30px 10px; }
  @media screen and (max-width: 959px) {
    #home-page .cnt-aboutus .aboutus__contents {
      margin: 0 auto;
      width: 650px;
      padding: 10px 10px 30px 10px; } }
  #home-page .cnt-aboutus .aboutus__contents .item {
    position: relative;
    width: 380px;
    height: 570px;
    -webkit-box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
            box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
    background-size: cover; }
    @media screen and (max-width: 959px) {
      #home-page .cnt-aboutus .aboutus__contents .item {
        width: 200px;
        height: 300px; } }
    #home-page .cnt-aboutus .aboutus__contents .item:nth-child(1) {
      background-image: url(/images/index/aboutus01.jpg); }
    #home-page .cnt-aboutus .aboutus__contents .item:nth-child(2) {
      background-image: url(/images/index/aboutus02.jpg); }
    #home-page .cnt-aboutus .aboutus__contents .item:nth-child(3) {
      background-image: url(/images/index/aboutus03.jpg); }
    #home-page .cnt-aboutus .aboutus__contents .item a {
      display: block;
      width: 100%;
      height: 100%; }
    #home-page .cnt-aboutus .aboutus__contents .item:hover {
      opacity: .6; }
    #home-page .cnt-aboutus .aboutus__contents .item__title {
      position: absolute;
      left: 0;
      bottom: 30px;
      width: 360px;
      padding: 30px 20px;
      background: rgba(0, 78, 162, 0.7); }
      #home-page .cnt-aboutus .aboutus__contents .item__title h3 {
        font: bold 20px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
        margin-bottom: 10px;
        color: white; }
      #home-page .cnt-aboutus .aboutus__contents .item__title span {
        position: relative;
        font: normal 12px/1 "Poppins", sans-serif;
        color: white;
        padding-left: 18px; }
        #home-page .cnt-aboutus .aboutus__contents .item__title span::before {
          content: "";
          display: block;
          position: absolute;
          top: 50%;
          -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
          width: 10px;
          height: 1px;
          background: white; }
      @media screen and (max-width: 959px) {
        #home-page .cnt-aboutus .aboutus__contents .item__title {
          width: 200px;
          padding: 15px 10px;
          bottom: 15px; }
          #home-page .cnt-aboutus .aboutus__contents .item__title h3 {
            font-size: 14px;
            margin-bottom: 5px; }
          #home-page .cnt-aboutus .aboutus__contents .item__title span {
            font-size: 10px; }
            #home-page .cnt-aboutus .aboutus__contents .item__title span::before {
              left: 0; } }
#home-page .cnt-works .flex__img {
  width: 62.5%; }
  @media screen and (min-width: 959px) and (max-width: 1340px) {
    #home-page .cnt-works .flex__img {
      width: 50%; } }
  @media screen and (max-width: 959px) {
    #home-page .cnt-works .flex__img {
      width: 100%;
      padding: 0 0 30px 40px; } }
#home-page .cnt-works .flex__txt {
  width: 37.5%; }
  @media screen and (min-width: 959px) and (max-width: 1340px) {
    #home-page .cnt-works .flex__txt {
      width: 50%; } }
  @media screen and (max-width: 959px) {
    #home-page .cnt-works .flex__txt {
      width: 100%;
      padding: 0 20px; } }
@media screen and (max-width: 959px) {
  #home-page .cnt-works .flex.rev .flex__img {
    width: 100%;
    padding: 0 40px 30px 0; } }
@media screen and (max-width: 959px) {
  #home-page .cnt-people .heading {
    padding-left: 20px;
    margin-bottom: 20px; }
  #home-page .cnt-people .btn {
    padding-right: 20px; } }
#home-page .cnt-recruit .flex {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between; }
  @media screen and (max-width: 959px) {
    #home-page .cnt-recruit .flex {
      padding: 0 20px; } }
  #home-page .cnt-recruit .flex__box {
    position: relative;
    width: calc(50% - 20px); }
    @media screen and (max-width: 959px) {
      #home-page .cnt-recruit .flex__box {
        width: 100%; }
        #home-page .cnt-recruit .flex__box + .flex__box {
          margin-top: 10px; } }
    #home-page .cnt-recruit .flex__box a {
      position: relative;
      display: block;
      width: 100%;
      height: 100%; }
      #home-page .cnt-recruit .flex__box a:before {
        content: "";
        display: block;
        width: 100%;
        height: 123px;
        position: absolute;
        bottom: 0;
        left: 0;
        background-image: url(/images/index/recruit-grad.png); }
      #home-page .cnt-recruit .flex__box a:hover {
        opacity: .6; }
    #home-page .cnt-recruit .flex__box .box__title {
      position: absolute;
      bottom: 20px;
      left: 20px; }
      #home-page .cnt-recruit .flex__box .box__title h3 {
        font: bold 20px/1.6 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
        color: white; }
      #home-page .cnt-recruit .flex__box .box__title span {
        font: normal 16px/1 "Poppins", sans-serif;
        color: white; }
      @media screen and (max-width: 959px) {
        #home-page .cnt-recruit .flex__box .box__title {
          bottom: 10px;
          left: 10px; }
          #home-page .cnt-recruit .flex__box .box__title h3 {
            font-size: 16px; }
          #home-page .cnt-recruit .flex__box .box__title span {
            font-size: 10px; } }

/* message page
========================================================= */
@media screen and (max-width: 959px) {
  #message-page .cnt-message {
    padding-top: 0; } }
#message-page .message__copy {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; }
  @media screen and (max-width: 959px) {
    #message-page .message__copy {
      -ms-flex-wrap: wrap;
          flex-wrap: wrap; } }
#message-page .message__img {
  width: calc(50% + 200px); }
  @media screen and (max-width: 959px) {
    #message-page .message__img {
      width: 100%; } }
#message-page .message__txt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: calc(50% - 100px); }
  #message-page .message__txt .inner {
    margin-left: -150px; }
    #message-page .message__txt .inner p {
      padding-left: 5px;
      margin: 30px 0 15px;
      font-size: 13px;
      line-height: 1.6; }
    #message-page .message__txt .inner .auth {
      padding-left: 5px; }
  @media screen and (min-width: 959px) and (max-width: 1340px) {
    #message-page .message__txt .inner {
      margin-left: -90px;
      width: 350px; } }
  @media screen and (max-width: 959px) {
    #message-page .message__txt {
      width: 100%; }
      #message-page .message__txt .inner {
        margin: 0 auto;
        text-align: center; }
        #message-page .message__txt .inner p {
          font-size: 10px;
          margin: 20px 0 10px; }
        #message-page .message__txt .inner img {
          margin: 0 auto; } }
#message-page .message__contents {
  max-width: 900px;
  width: 100%;
  margin: 0 auto;
  padding: 100px 0; }
  @media screen and (min-width: 959px) and (max-width: 1340px) {
    #message-page .message__contents {
      padding: 100px 20px; } }
  #message-page .message__contents h3 {
    font: bold 35px/1.5 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    letter-spacing: .08em;
    margin-bottom: 50px; }
    #message-page .message__contents h3:first-letter {
      color: #004EA2; }
  #message-page .message__contents p {
    font: normal 18px/2 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    letter-spacing: .08em; }
    #message-page .message__contents p + p {
      margin-top: 30px; }
  @media screen and (max-width: 959px) {
    #message-page .message__contents {
      padding: 40px 20px; }
      #message-page .message__contents h3 {
        font-size: 20px; }
      #message-page .message__contents p {
        font-size: 16px; }
        #message-page .message__contents p + p {
          margin-top: 15px; } }
#message-page .message__insertimg.right {
  text-align: right; }
#message-page .message__insertimg img {
  width: 80%; }
  @media screen and (max-width: 959px) {
    #message-page .message__insertimg img {
      width: calc(100% - 20px); } }

/* growth page
========================================================= */
#growth-page .cnt-history .contents {
  margin: 100px auto; }
  @media screen and (max-width: 959px) {
    #growth-page .cnt-history .contents {
      margin: 50px auto; } }
#growth-page .article__main .block {
  padding: 0 20px; }
#growth-page .history__outline {
  position: relative; }
  #growth-page .history__outline h4 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font: bold 20px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    letter-spacing: .1em;
    color: white;
    background: #004EA2;
    padding: 15px 30px;
    border-radius: 3px;
    margin-bottom: 30px; }
    #growth-page .history__outline h4 small {
      font: normal 0.75em/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
      margin-right: 28px;
      vertical-align: 1px; }
      #growth-page .history__outline h4 small span {
        font-size: 0.75em;
        display: inline-block;
        top: -1px;
        position: relative;
        opacity: .8;
        font-weight: bold;
        letter-spacing: 0.43em; }
    #growth-page .history__outline h4 span.found {
      font: bold 0.75em/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
      color: #004EA2;
      background: white;
      padding: 5px 10px 7px;
      vertical-align: 1px;
      border-radius: 2px;
      margin-right: 10px;
      position: relative;
      top: -10px; }
    #growth-page .history__outline h4 strong {
      margin-left: 10px; }
  #growth-page .history__outline:after {
    content: "";
    display: block;
    width: 6px;
    height: 95.5%;
    position: absolute;
    top: 0;
    left: 114px;
    background: rgba(0, 78, 162, 0.1);
    z-index: -1; }
  @media screen and (max-width: 959px) {
    #growth-page .history__outline {
      padding: 0 20px; }
      #growth-page .history__outline h4 {
        padding: 5px 10px;
        font-size: 14px;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap; }
        #growth-page .history__outline h4 > div {
          width: 100%;
          margin-left: 10px;
          padding-top: 10px;
          margin-bottom: 5px; }
        #growth-page .history__outline h4 small {
          margin-right: 10px; }
        #growth-page .history__outline h4 strong {
          width: 100%;
          line-height: 1.4;
          padding-bottom: 10px; }
      #growth-page .history__outline:after {
        width: 3px;
        left: 94px;
        height: 95%; } }
#growth-page .history__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; }
  #growth-page .history__item dt {
    position: relative;
    padding-top: 7px;
    width: 150px;
    padding-left: 20px;
    font: normal 16px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif; }
    #growth-page .history__item dt small {
      margin-top: 7px;
      font: bold 0.75em/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
      opacity: 0.8;
      display: block; }
    #growth-page .history__item dt:after {
      content: "";
      position: absolute;
      top: 11px;
      right: 26px;
      display: block;
      background: #004EA2;
      width: 14px;
      height: 14px;
      border-radius: 7px; }
    @media screen and (max-width: 959px) {
      #growth-page .history__item dt {
        font-size: 14px;
        width: 94px;
        padding-left: 0; }
        #growth-page .history__item dt:after {
          top: 10px;
          right: 13px;
          width: 10px;
          height: 10px;
          border-radius: 5px; } }
  #growth-page .history__item dd {
    width: calc( 100% - 150px );
    font: normal 16px/1.8 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    border-bottom: 1px dotted #ddd;
    padding-bottom: 30px;
    padding-top: 4px; }
    #growth-page .history__item dd strong {
      display: block;
      color: #004EA2;
      font-weight: bold; }
    @media screen and (max-width: 959px) {
      #growth-page .history__item dd {
        padding-bottom: 15px;
        width: calc( 100% - 94px );
        padding-top: 0;
        font-size: 14px; }
        #growth-page .history__item dd strong {
          font-size: 16px; } }
  #growth-page .history__item + .history__item {
    margin-top: 25px; }
    @media screen and (max-width: 959px) {
      #growth-page .history__item + .history__item {
        margin-top: 10px; } }
@media screen and (min-width: 959px) and (max-width: 1340px) {
  #growth-page .cnt-works .flex {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between; } }
#growth-page .cnt-works .flex__img {
  width: 62.5%; }
  @media screen and (min-width: 959px) and (max-width: 1340px) {
    #growth-page .cnt-works .flex__img {
      width: 48%; } }
  @media screen and (max-width: 959px) {
    #growth-page .cnt-works .flex__img {
      width: 100%;
      display: none; } }
#growth-page .cnt-works .flex__txt {
  width: 37.5%; }
  @media screen and (min-width: 959px) and (max-width: 1340px) {
    #growth-page .cnt-works .flex__txt {
      width: 48%;
      padding: 0; } }
  @media screen and (max-width: 959px) {
    #growth-page .cnt-works .flex__txt {
      width: 100%; }
      #growth-page .cnt-works .flex__txt .content, #growth-page .cnt-works .flex__txt .content--w900, #growth-page .cnt-works .flex__txt .content--w1200 {
        padding: 0 20px; } }
#growth-page .cnt-works .slider-growth {
  max-width: 400px;
  margin-top: 30px; }
  @media screen and (max-width: 959px) {
    #growth-page .cnt-works .slider-growth {
      max-width: 100vw; } }

/* growth page
========================================================= */
#type-page .type__header {
  position: relative;
  margin-top: 100px;
  margin-bottom: 50px; }
#type-page .type__headimg img {
  width: calc(50% + 525px); }
  @media screen and (max-width: 959px) {
    #type-page .type__headimg img {
      width: 100%;
      height: 250px;
      -o-object-fit: cover;
         object-fit: cover; } }
#type-page .type__title {
  bottom: 0;
  position: absolute;
  left: 0;
  right: 0;
  max-width: 1200px;
  width: 100%;
  margin: 0 auto; }
  #type-page .type__title h2 {
    position: absolute;
    bottom: 50px;
    display: inline-block;
    color: white;
    font: bold 20px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    letter-spacing: .2em;
    padding: 10px 20px 16px 22px;
    background: #004EA2; }
  #type-page .type__title p {
    position: absolute;
    bottom: 85px;
    display: inline-block;
    color: white;
    font: bold 50px/1 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    letter-spacing: .2em;
    padding: 10px 20px 16px 22px;
    background: #004EA2; }
  @media screen and (max-width: 959px) {
    #type-page .type__title {
      bottom: -68px; }
      #type-page .type__title h2 {
        font-size: 14px; }
      #type-page .type__title p {
        font-size: 30px; } }
  #type-page .type__title h2, #type-page .type__title p {
    left: 0; }
  #type-page .type__title.right h2, #type-page .type__title.right p {
    right: 0;
    left: auto; }
  #type-page .type__title.right p {
    padding: 10px 13px 16px 22px; }
#type-page .section + .section {
  margin-top: 150px; }
  @media screen and (max-width: 959px) {
    #type-page .section + .section {
      margin-top: 80px; } }
@media screen and (max-width: 959px) {
  #type-page .cnt-people .btn {
    padding-right: 20px; } }
#type-page #purchase .type__title h2 {
  background: #FF6600; }
#type-page #purchase .type__title p {
  background: #FF6600; }
#type-page #purchase .list-type .item__title h4,
#type-page #purchase .heading05 {
  color: #FF6600; }
#type-page #logi .type__title h2 {
  background: #edb918; }
#type-page #logi .type__title p {
  background: #edb918; }
#type-page #logi .list-type .item__title h4,
#type-page #logi .heading05 {
  color: #edb918; }
#type-page #inside-sales .type__title h2 {
  background: #46B446; }
#type-page #inside-sales .type__title p {
  background: #46B446; }
#type-page #inside-sales .list-type .item__title h4,
#type-page #inside-sales .heading05 {
  color: #46B446; }

/* brand page
========================================================= */
@media screen and (max-width: 959px) {
  #welfare-page .cnt-brand .content, #welfare-page .cnt-brand .content--w900, #welfare-page .cnt-brand .content--w1200,
  #brand-page .cnt-brand .content,
  #brand-page .cnt-brand .content--w900,
  #brand-page .cnt-brand .content--w1200 {
    padding: 0 20px; } }
@media screen and (max-width: 959px) {
  #welfare-page .cnt-brand .btn,
  #brand-page .cnt-brand .btn {
    padding: 0 20px; } }

/* careerplan page
========================================================= */
#careerplan-page .cnt-careerstep .heading03 {
  margin-top: 50px;
  margin-bottom: 20px; }
#careerplan-page .cnt-careerstep .img {
  max-width: 760px;
  margin: 0 auto; }
#careerplan-page .table th {
  width: 300px;
  font-size: 16px;
  color: #004EA2;
  vertical-align: middle; }
  @media screen and (max-width: 959px) {
    #careerplan-page .table th {
      width: 100%;
      text-align: center; } }
#careerplan-page .table td p.attention {
  font-size: 0.8em; }
@media screen and (max-width: 959px) {
  #careerplan-page .table td {
    width: 100%;
    text-align: center; } }

/* data page
========================================================= */
#data-page .article__title {
  margin-top: 50px; }
  #data-page .article__title h2,
  #data-page .article__title span {
    color: white; }
  #data-page .article__title .inner::before {
    background: white; }
#data-page .cnt-data {
  padding: 200px 0 50px; }
  @media screen and (max-width: 959px) {
    #data-page .cnt-data {
      padding: 40px 0 0; } }

/* proper page
========================================================= */
#proper-page .cnt-recruitconcept {
  padding: 130px 0;
  background: #004EA2;
  text-align: center; }
  @media screen and (max-width: 959px) {
    #proper-page .cnt-recruitconcept {
      padding: 130px 0 80px; } }
  #proper-page .cnt-recruitconcept .copy {
    margin-bottom: 50px; }
    #proper-page .cnt-recruitconcept .copy img {
      margin: 0 auto; }
    @media screen and (max-width: 959px) {
      #proper-page .cnt-recruitconcept .copy {
        margin-bottom: 30px;
        padding: 0 20px; }
        #proper-page .cnt-recruitconcept .copy img {
          width: 240px; } }
  #proper-page .cnt-recruitconcept p {
    font: normal 18px/2.5 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
    letter-spacing: .15em;
    color: white; }
    #proper-page .cnt-recruitconcept p + p {
      margin-top: 20px; }
    @media screen and (max-width: 959px) {
      #proper-page .cnt-recruitconcept p {
        font-size: 16px;
        line-height: 2; }
        #proper-page .cnt-recruitconcept p + p {
          margin-top: 10px; } }
#proper-page .table th {
  font: bold 16px/2 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif; }
  @media screen and (max-width: 959px) {
    #proper-page .table th {
      width: 100%; } }
#proper-page .table td a {
  font: normal 16px/2 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
  text-decoration: underline; }
#proper-page .table td p.attention {
  font: normal 14px/2 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
  color: red; }
#proper-page .table td p span {
  display: block;
  font-weight: bold;
  color: #004EA2; }
#proper-page .table td p + a, #proper-page .table td p + p {
  margin-top: 20px; }
#proper-page .table td .fr {
  float: right;
  width: 120px;
  margin: 10px 20px 0; }

/* education page
========================================================= */
#education-page .cnt-iga .img img {
  max-width: 600px; }
  @media screen and (max-width: 959px) {
    #education-page .cnt-iga .img img {
      max-width: calc(100% - 40px);
      margin: 0 auto; } }
#education-page .cnt-iga .heading03 {
  margin-bottom: 30px; }
#education-page .cnt-education .table {
  background: white;
  max-width: 600px;
  margin: 0 auto; }
  @media screen and (max-width: 959px) {
    #education-page .cnt-education .table {
      text-align: center;
      width: calc(100% - 40px); } }
  #education-page .cnt-education .table th {
    width: 240px;
    vertical-align: middle;
    color: #004EA2;
    border-right: 1px solid #eee; }
    @media screen and (max-width: 959px) {
      #education-page .cnt-education .table th {
        width: 100%;
        padding: 15px;
        text-align: center;
        border-right: 0;
        border-bottom: 1px solid rgba(0, 78, 162, 0.1); } }
  #education-page .cnt-education .table td {
    padding-left: 20px;
    padding-right: 20px; }
    @media screen and (max-width: 959px) {
      #education-page .cnt-education .table td {
        padding: 10px; } }
  #education-page .cnt-education .table tr {
    border: 0 !important; }
    @media screen and (max-width: 959px) {
      #education-page .cnt-education .table tr {
        border-top: 10px solid #F5F8FB !important; } }
#education-page .education__copy {
  position: relative;
  max-width: 1200px;
  margin: 0 auto; }
@media screen and (min-width: 960px) {
  #education-page .education__txt {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    padding: 50px 30px 40px;
    left: 50px;
    background: white; }
    #education-page .education__txt .inner p {
      margin-top: 30px;
      font-size: 14px;
      line-height: 1.6; } }
@media screen and (max-width: 959px) {
  #education-page .education__txt {
    text-align: center;
    margin-top: 30px; }
    #education-page .education__txt img {
      display: inline-block; }
    #education-page .education__txt .inner p {
      padding-top: 15px;
      font-size: 12px;
      line-height: 1.6; } }

#interview-page .insertimg img, #interview-page #type-page .type__headimg img, #type-page #interview-page .type__headimg img {
  width: auto; }
  @media screen and (min-width: 960px) {
    #interview-page .insertimg img, #interview-page #type-page .type__headimg img, #type-page #interview-page .type__headimg img {
      max-width: calc(50% + 600px); } }
  @media screen and (min-width: 959px) and (max-width: 1340px) {
    #interview-page .insertimg img, #interview-page #type-page .type__headimg img, #type-page #interview-page .type__headimg img {
      max-width: calc(100% + 40px);
      margin-left: -20px; } }
  @media screen and (max-width: 959px) {
    #interview-page .insertimg img, #interview-page #type-page .type__headimg img, #type-page #interview-page .type__headimg img {
      max-width: 100%; } }

#crosstalk-page .cnt-otherinterview .heading02__enttl,
#interview-page .cnt-otherinterview .heading02__enttl {
  color: #004EA2; }
#crosstalk-page .cnt-otherinterview .heading02__title,
#interview-page .cnt-otherinterview .heading02__title {
  color: #2e2b28; }
#crosstalk-page .list-block,
#interview-page .list-block {
  padding: 0; }

/* top news /news page */
.news .section {
  width: 82%;
  margin-left: 40px; }
  @media screen and (max-width: 1200px) and (min-width: 960px) {
    .news .section {
      width: 76%; } }
  @media screen and (max-width: 959px) {
    .news .section {
      width: 100%;
      margin-left: 0;
      margin-top: 40px;
      padding-right: 20px;
      padding-left: 20px; } }
.news__article-title {
  width: 18% !important; }
  @media screen and (max-width: 1200px) and (min-width: 960px) {
    .news__article-title {
      width: 24% !important; } }
  @media screen and (max-width: 959px) {
    .news__article-title {
      width: 100% !important; } }
.news__item {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 20px 90px 20px 40px;
  border-bottom: 1px solid rgba(0, 78, 162, 0.3); }
  .news__item:first-child {
    border-top: 1px solid rgba(0, 78, 162, 0.3); }
  @media screen and (max-width: 959px) {
    .news__item {
      padding: 20px 40px 20px 0px; } }
.news__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center; }
.news__thumb {
  width: 200px;
  height: 150px;
  margin-right: 40px;
  background-color: #F5F5F5; }
  .news__thumb img {
    -o-object-fit: contain;
       object-fit: contain;
    width: 100%;
    height: 100%; }
  @media screen and (max-width: 959px) {
    .news__thumb {
      margin-right: 20px;
      width: 160px;
      height: 90px; } }
.news__ttl {
  width: calc(100% - 240px); }
  .news__ttl p {
    font: normal 20px/2 "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif; }
    @media screen and (max-width: 959px) {
      .news__ttl p {
        font-size: 14px; } }
  @media screen and (max-width: 959px) {
    .news__ttl {
      width: 70%; } }
.news__arrow {
  width: 40px;
  border-bottom: 2px solid #004EA2;
  position: absolute;
  top: 50%;
  right: 40px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%); }
  @media screen and (max-width: 959px) {
    .news__arrow {
      right: 0; } }
  .news__arrow::after {
    content: "";
    position: absolute;
    bottom: -13px;
    right: -8px;
    display: block;
    width: 32px;
    height: 32px;
    border-radius: 16px;
    background: rgba(0, 78, 162, 0.1); }
  .news__arrow::before {
    content: "";
    position: absolute;
    bottom: -2px;
    right: -2px;
    display: block;
    width: 15px;
    height: 12px;
    border-bottom: 12px solid #004EA2;
    border-right: 15px solid transparent; }

#news-page .section {
  width: 100%;
  margin: 0 auto; }
#news-page .news__list-thumb {
  width: 200px;
  height: 150px;
  margin-right: 40px;
  background-color: #F5F5F5; }
  #news-page .news__list-thumb img {
    -o-object-fit: contain;
       object-fit: contain;
    width: 100%;
    height: 100%; }
  @media screen and (max-width: 959px) {
    #news-page .news__list-thumb {
      margin-right: 20px;
      width: 160px;
      height: 90px; } }
#news-page .news__thumb {
  max-width: 600px;
  max-height: 800px;
  width: 100%;
  height: 100%;
  margin: 0 auto 40px auto;
  text-align: center;
  background-color: transparent; }
  @media screen and (max-width: 959px) {
    #news-page .news__thumb {
      width: 100%;
      max-width: 500px;
      max-height: 500px;
      margin-bottom: 20px; } }
  #news-page .news__thumb img {
    -o-object-fit: contain;
       object-fit: contain;
    width: auto;
    height: auto; }
#news-page .news__txt {
  /*h4 {
      font: bold 16px/1.6 $base-font;
      margin-bottom: 20px;
      padding: 0px 10px 0px 20px;
      position: relative;
      &::after {
          content: "";
          width: 2px;
          height: 100%;
          left: 0;
          top: 0;
          background-color: $mc;
          position: absolute;
      }
  }
  h5 {
      font-size: 16px;
      font-weight: bold;
      margin-bottom: 10px;
  }*/ }
  #news-page .news__txt b, #news-page .news__txt strong {
    font-weight: bold; }
  #news-page .news__txt a {
    color: blue; }
  #news-page .news__txt h3, #news-page .news__txt h4, #news-page .news__txt h5 {
    margin-top: 40px; }
  #news-page .news__txt img {
    margin: 15px auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    max-width: 500px; }
  @media screen and (max-width: 959px) {
    #news-page .news__txt {
      /*h3 {
          font-size: 18px;
      }
      h4 {
          font-size: 18px;
      }
      h5 {
          font-size: 14px;
          font-weight: bold;
      }*/ }
      #news-page .news__txt h3, #news-page .news__txt h4, #news-page .news__txt h5 {
        margin-top: 40px; }
      #news-page .news__txt p + img,
      #news-page .news__txt img,
      #news-page .news__txt h3 + p,
      #news-page .news__txt h4 + p,
      #news-page .news__txt h5 + p {
        margin-top: 15px; }
      #news-page .news__txt p + p {
        margin-top: 15px; }
      #news-page .news__txt img {
        width: 100%;
        max-width: 100%; } }
#news-page .wp-pagenavi {
  text-align: center;
  margin: 40px auto; }
  #news-page .wp-pagenavi a {
    font-family: "Poppins", sans-serif; }
  #news-page .wp-pagenavi .wp-pagenavi a:hover, #news-page .wp-pagenavi .wp-pagenavi span.current {
    border-color: #004EA2 !important; }

.js-scroll {
  opacity: 0;
  margin-top: 50px;
  -webkit-transition: margin-top 1s ease, opacity 1s ease, background-color 1s ease, -webkit-box-shadow 1s ease;
  transition: margin-top 1s ease, opacity 1s ease, background-color 1s ease, -webkit-box-shadow 1s ease;
  transition: margin-top 1s ease, opacity 1s ease, box-shadow 1s ease, background-color 1s ease;
  transition: margin-top 1s ease, opacity 1s ease, box-shadow 1s ease, background-color 1s ease, -webkit-box-shadow 1s ease; }
  .js-scroll.fade_on {
    margin-top: 0;
    opacity: 1; }

.js-scroll2 {
  opacity: 0;
  -webkit-transform: translateY(50px);
          transform: translateY(50px);
  -webkit-transition: opacity 1s ease, -webkit-transform 1s ease;
  transition: opacity 1s ease, -webkit-transform 1s ease;
  transition: transform 1s ease, opacity 1s ease;
  transition: transform 1s ease, opacity 1s ease, -webkit-transform 1s ease; }
  .js-scroll2.fade_on {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 1; }

.fadeInBottom {
  -webkit-transform: translate3d(0, 50px, 0);
          transform: translate3d(0, 50px, 0);
  opacity: 0; }
  .fadeInBottom.is-show, .is-show .fadeInBottom {
    -webkit-animation-name: fadeInBottom;
            animation-name: fadeInBottom;
    -webkit-animation-duration: .5s;
            animation-duration: .5s;
    -webkit-animation-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955);
            animation-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955); }

@-webkit-keyframes fadeInBottom {
  0% {
    -webkit-transform: translate3d(0, 50px, 0);
            transform: translate3d(0, 50px, 0);
    opacity: 0; }
  50% {
    opacity: .2; }
  100% {
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
    opacity: 1; } }

@keyframes fadeInBottom {
  0% {
    -webkit-transform: translate3d(0, 50px, 0);
            transform: translate3d(0, 50px, 0);
    opacity: 0; }
  50% {
    opacity: .2; }
  100% {
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
    opacity: 1; } }
.anime-elm {
  -webkit-animation-fill-mode: both;
          animation-fill-mode: both; }
  .anime-elm.no02 {
    -webkit-animation-delay: 0.3s;
            animation-delay: 0.3s; }
  .anime-elm.no03 {
    -webkit-animation-delay: 0.6s;
            animation-delay: 0.6s; }
  .anime-elm.no04 {
    -webkit-animation-delay: 0.9s;
            animation-delay: 0.9s; }
  .anime-elm.no05 {
    -webkit-animation-delay: 1.2s;
            animation-delay: 1.2s; }
  .anime-elm.no06 {
    -webkit-animation-delay: 1.5s;
            animation-delay: 1.5s; }
  .anime-elm.no07 {
    -webkit-animation-delay: 1.8s;
            animation-delay: 1.8s; }

.wp-pagenavi {
  text-align: center;
  margin-top: 30px; }
  .wp-pagenavi span, .wp-pagenavi a {
    border-color: rgba(0, 78, 162, 0.3) !important;
    color: #004EA2; }
    .wp-pagenavi span.current, .wp-pagenavi a.current {
      color: white;
      background: #004EA2; }

#js-fade {
  position: fixed;
  z-index: 9999;
  background: white;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh; }

@media print {
  * html body {
    zoom: .7; } }
