@charset "UTF-8";
/* =========================================================
import
========================================================= */
/**
 * html5doctor.com Reset Stylesheet v1.6.1 (http://html5doctor.com/html-5-reset-stylesheet/)
 * Richard Clark (http://richclarkdesign.com)
 * http://cssreset.com
 */
@import url(https://fonts.googleapis.com/earlyaccess/notosansjp.css);
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent; }

body {
    line-height: 1; 
    overflow-x: hidden;
    position: relative;
    display: none;
}
body.top{

}
svg {
    display: block;
    width: 100%;
}
img {
  vertical-align: bottom; }

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

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

ol ol {
  list-style: decimal inside; }

blockquote, q {
  quotes: none; }

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

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent; }
a:hover{
    text-decoration: underline;
}
/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none; }

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold; }

del {
  text-decoration: line-through; }

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help; }
a{cursor: pointer;}
table {
  border-collapse: collapse;
  border-spacing: 0; }

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0; }

input, select {
  vertical-align: middle; }

textarea {
  resize: vertical; }
sup {
	font-size: 70%; 
	vertical-align: top;
	position: relative;
	top: -0.1em; 
}
/* =========================================================
common
========================================================= */
html {
  font-size: 62.5%;
  /*10px*/
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent; }
@media (max-width: 767px) {
    html {
        font-size: 50%; /*10px*/
    }
}

body {
  font-family: 'Noto Sans JP',"ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  font-size: 1.6rem;
  line-height: 2;
  color: #666;
  width: 100%; }
  @media (max-width: 767px) {
    body {
      font-size: 15px; } }


p {
    margin: 10px 0;
    overflow-wrap: break-word;
    word-wrap: break-word;
    line-height: 2
}
@media (max-width: 767px) {
    p {
        margin: 5px 0;
    } 
}

h2 {
  line-height: 1.0; }

a {
  text-decoration: none; 
  color: #5AC3F2; }

a:hover {
  color: #5AC3F2; }
  @media (max-width: 767px) {
    a:hover {
      color: #000; } }

a:active {
  color: #5AC3F2; }

a.link-ul {
  text-decoration: underline; }

a.link-ul:hover {
  text-decoration: none; }

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box; }

@media (max-width: 767px) {
  img {
    width: 100%;
    height: auto; } }

img.img_sp {
  max-width: 100%;
  height: auto;
  zoom: 1; }

.bold {
  font-weight: bold; }

.normal {
  font-weight: normal; }

.ta-c {
  text-align: center; }

.ta-r {
  text-align: right; }

.ta-l {
  text-align: left; }

.mt-1em {
  margin-top: 1em !important; }

.mt-2em {
  margin-top: 2em !important; }
.mt-3em {
  margin-top: 3em !important; }
.mt-4em {
  margin-top: 4em !important; }

.mb-1em {
  margin-bottom: 1em !important; }

.mb-2em {
  margin-bottom: 2em !important; }

.txt-in-1em {
  text-indent: 1em; }
.li-crc li{
  list-style: circle;
  margin-left: 1.5em;
}
.br-sp {
  display: none; }
  @media (max-width: 767px) {
    .br-sp {
      display: block; } }

.br-tbsp {
  display: none; }
  @media (max-width: 1100px) {
    .br-tbsp {
      display: block; } }

.br-tb {
  display: block; }
  @media (max-width: 1100px) {
    .br-tb {
      display: none; } }

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

.bdr_none {
  border-bottom: none !important; }
.bdr_btm{
  border-bottom: solid 1px #ccc;
  padding-bottom: 3.5em;
}
.img-auto{
  text-align: center;
}
.img-auto img,img.img-auto{
  width: auto;
  height: auto;
}
.fs-s{font-size: 12px;}
.fs12 {
  font-size: 1.2rem; }

.fs13 {
  font-size: 1.3rem; }

.fs14 {
  font-size: 1.4rem; }

.fs15 {
  font-size: 1.5rem; }

.fs16 {
  font-size: 1.6rem; }

.fs18 {
  font-size: 1.8rem; }

.fs20 {
  font-size: 2.0rem; }

.fs22 {
  font-size: 2.2rem; }

.fs24 {
  font-size: 2.4rem; }

.fs26 {
  font-size: 2.6rem; }

.fs28 {
  font-size: 2.8rem; }

.fs30 {
  font-size: 3.0rem; }

.fs34 {
  font-size: 3.4rem; }

.fs36 {
  font-size: 3.6rem; }

@media (max-width: 767px) {
  .fs12 {
    font-size: 12px; }

  .fs13 {
    font-size: 13px; }

  .fs14 {
    font-size: 14px; }

  .fs16 {
    font-size: 15px; }

  .fs18 {
    font-size: 16px; }

  .fs20 {
    font-size: 18px; }

  .fs22 {
    font-size: 20px; }

  .fs24 {
    font-size: 22px; }

  .fs26 {
    font-size: 24px; }

  .fs28 {
    font-size: 26px; }

  .fs30 {
    font-size: 28px; }

  .fs34 {
    font-size: 30px; }

  .fs36 {
    font-size: 32px; } 
    .fs-s{font-size: 10px;}
}
.mt0 {
  margin-top: 0 !important; }

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

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

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

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

.mt40 {
  margin-top: 40px !important; }
  @media (max-width: 767px) {
    .mt40 {
      margin-top: 20px !important; } }

.mt50 {
  margin-top: 50px !important; }
  @media (max-width: 767px) {
    .mt50 {
      margin-top: 25px !important; } }

.mt60 {
  margin-top: 60px !important; }
  @media (max-width: 767px) {
    .mt60 {
      margin-top: 30px !important; } }

.mt80 {
  margin-top: 80px !important; }
  @media (max-width: 767px) {
    .mt80 {
      margin-top: 30px !important; } }

.mt90 {
  margin-top: 90px !important; }
  @media (max-width: 767px) {
    .mt90 {
      margin-top: 30px !important; } }

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

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

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

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

.mb40 {
  margin-bottom: 40px !important; }
  @media (max-width: 767px) {
    .mb40 {
      margin-bottom: 20px !important; } }

.mb50 {
  margin-bottom: 50px !important; }
  @media (max-width: 767px) {
    .mb50 {
      margin-bottom: 25px !important; } }

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

.mb60 {
  margin-bottom: 60px !important; }
  @media (max-width: 767px) {
    .mb60 {
      margin-bottom: 30px !important; } }
.row{
  margin: 0;
}
.lh1 {line-height: 1; }
.lh14 {line-height: 1.4; }

.red {
  color: #e52d27; }

.blue {
  color: #004ea2; }
.green{
    color: #5AC3F2;
}
.black {
  color: black; }

.white {
  color: white; }
.flex{display: flex}

/* アニメーション */
.anime:hover {
  transition: 0.2s; }

.pr {
  position: relative; }

/* 角丸 */
.rad {
  border-radius: 6px; }

.radL {
  border-radius: 12px; }

.boxSdw {
  box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.1); }


.clear {
  clear: both; }

.container {
  width: 100%; }

.wrapper {
  width:100%;
  max-width:1100px;
  margin: 0 auto;
  padding: 80px 0; }
  @media (max-width: 1100px) {
    .wrapper {
      width: 100%;
      padding: 60px 20px; } }
  @media (max-width: 767px) {
    .wrapper {
      padding: 30px 10px; } }

#loader-bg {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0px;
    left: 0px;
    background: #fff;
    z-index: 10000;
    overflow: hidden;
    transition:all 1.4s ease
}
body.is-loaded{
    display: block;
}
/* =========================================================
LOADER
========================================================= */
@keyframes fadeOut {
    from {
        opacity: 1;
    }
    
    to {
        display: none;
        opacity: 0;
        z-index: -1;
    }
}

#loader {
    position: fixed;
    top:0;
    z-index: 100000;
    width: 100%;
    height: 100vh;
    background-color: #fff;
}
.is-end #loader {
    animation: fadeOut .4s forwards;
}

.sk-chase {
    width: 80px;
    height: 80px;
    position: absolute;
    animation: sk-chase 2.5s infinite linear both;
    top: calc(50% - 40px);
    right: 0;
    left: 0;
    margin: auto;
}

.sk-chase-dot {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0; 
  animation: sk-chase-dot 2.0s infinite ease-in-out both; 
}

.sk-chase-dot:before {
  content: '';
  display: block;
  width: 25%;
  height: 25%;
  background-color: #006BB9;
  border-radius: 100%;
  animation: sk-chase-dot-before 2.0s infinite ease-in-out both; 
}
.sk-chase-dot:nth-child(2)::before,.sk-chase-dot:nth-child(5)::before {
    background-color: #4BABDB;
}
.sk-chase-dot:nth-child(3)::before,.sk-chase-dot:nth-child(6)::before {
    background-color: #98C0E7;
}

.sk-chase-dot:nth-child(1) { animation-delay: -1.1s; }
.sk-chase-dot:nth-child(2) { animation-delay: -1.0s; }
.sk-chase-dot:nth-child(3) { animation-delay: -0.9s; }
.sk-chase-dot:nth-child(4) { animation-delay: -0.8s; }
.sk-chase-dot:nth-child(5) { animation-delay: -0.7s; }
.sk-chase-dot:nth-child(6) { animation-delay: -0.6s; }
.sk-chase-dot:nth-child(1):before { animation-delay: -1.1s; }
.sk-chase-dot:nth-child(2):before { animation-delay: -1.0s; }
.sk-chase-dot:nth-child(3):before { animation-delay: -0.9s; }
.sk-chase-dot:nth-child(4):before { animation-delay: -0.8s; }
.sk-chase-dot:nth-child(5):before { animation-delay: -0.7s; }
.sk-chase-dot:nth-child(6):before { animation-delay: -0.6s; }

@keyframes sk-chase {
  100% { transform: rotate(360deg); } 
}

@keyframes sk-chase-dot {
  80%, 100% { transform: rotate(360deg); } 
}

@keyframes sk-chase-dot-before {
  50% {
    transform: scale(0.4); 
  } 100%, 0% {
    transform: scale(1.0); 
  } 
}

/*HEADER*/
header{
    width: 100%;
    z-index: 90;
    position: absolute;
    top:0;
    left: 0;
    right: 0;
    padding: 0;
    opacity: 0;
}
.head__inner{
  background: white;
  height: 96px;
}
header.fixed{
  position: fixed;
}

#global-head {
  position: absolute;
  top:0;
  left: 0;
  z-index: 100;
  width: 30%;
  padding: 0 0 0 10px;
  height: 90px; 
  /*transition: all 0.3s ease;*/
}
#global-head .logo {
  margin: 15px 6px 4px 20px;
  position: relative;
 /*   opacity: 0;
  */z-index: 100;
}
.is-loaded #global-head .logo {
    opacity: 1;
}
#global-head .logo a{
  display: flex;
  align-items: center;
}
#global-head .logo a .site-neme{
    padding-left: 1em;
    font-size: 1.5rem;
    color: #666;
}
#global-head .logo a:hover,#global-head .logo a.hover{
    text-decoration: none;
}
#global-head .logo img,#global-head .logo svg{
  width: 72px;
}
.btn__mypage{
    margin-left: 20px;
}
.btn__mypage a{
    background: #EAF7FF;
      transition: all .3s ease;
}
.btn__entry a{
    color: white;
    position: relative;
    background:#5AC3F2;
}
.btn__entry a span{
    position: relative;
}
.btn__entry a::before {
    background: linear-gradient(135deg,#5FF4FF 0%, #AF76FC 100%);
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    transition: all 0.3s ease;
    width: 100%;
}
.btn__fb{ margin-left: 10px;}
.btn__fb a{transition: all .4s ease;}
.btn__fb a:hover{ opacity: .7;}
.btn__fb img{
    width: 33px;
    height: 33px;
}
.btn__fb span{display: none;}
.nav-list{
    opacity: 0;
}
.is-loaded .nav-list{
    opacity: 1;
}
.global-nav .nav-list .nav-item.btn__entry{
    margin-left:0.5em;
}
.global-nav .nav-list .nav-item.btn__entry a{
    color:white;
}
.global-nav .nav-list .nav-item.btn__mypage  a{
    padding: 0.6em 2em;
}
.global-nav .nav-list .nav-item.btn__entry a{
    padding: 0.6em 1em;    
}
.global-nav .nav-list .nav-item.btn__mypage a:hover {
    color: #fff;
    background: #5AC3F2;
}
.global-nav .nav-list .nav-item.btn__entry a:hover{color: white;}
.global-nav .nav-list .nav-item.btn__entry a:hover::before { opacity: 0;}
@media screen and (max-width: 400px) {
    #global-head .logo a .site-neme{
        font-size: 3.5vw;
    }
}

.global-nav .nav-list .nav-item a.link__off{
    pointer-events: none;
    color: #aaa;
    
}

/*　上に上がる動き　*/
#header.UpMove{
	animation: UpAnime 0.5s forwards;
}

@keyframes UpAnime{
  from {
    opacity: 1;
	transform: translateY(0);
  }
  to {
    opacity: 0;
	transform: translateY(-100px);
  }
}

/*　下に下がる動き　*/
#header.DownMove{
	animation: DownAnime 0.5s forwards;
}
@keyframes DownAnime{
  from {
  	opacity: 0;
	transform: translateY(-100px);
  }
  to {
  	opacity: 1;
	transform: translateY(0);
  }
}
@media (max-width: 1140px) {
    #global-head .logo img,#global-head .logo svg {
        max-width: 50px;
    }
}

@media (max-width: 767px) {
  header{height: 68px;}
  #global-head {
    height: auto; 
    width: 60%;
    padding: 5px 0 0 3vw;
  }
  #global-head .logo {
    margin: 7px 0 0; }
  #global-head .logo img,#global-head .logo svg {
    width:100%;
    height: auto;
  }
}
@media (max-width: 370px) {
  #global-head .logo img,#global-head .logo svg{
   width: 40vw; 
  }
  .logo-aside{
    padding: 1em;
    margin-left: 6px;
    font-size: 1vw;
  }
}

/* グローバルメニュー */
.global-nav {
    margin: 0;
    position: absolute;
    right: 18px;
    top: 0;
    width: 100%;
}

.global-nav .nav-list {
    display: flex;
    align-items: center;
    list-style: none;
    margin: 0;
    padding:25px 0 0 0;
    justify-content: flex-end;
    z-index: 1;
}

.global-nav .nav-list .nav-item {
    vertical-align: middle;
}

.global-nav .nav-list .nav-item a {
    color: #666;
    display: block;
    padding: 0.6em .8em;
    text-align: center;
    text-decoration: none;
    font-size: 14px;
    width: auto;
    font-weight: bold;
    cursor: pointer;
}

.global-nav .nav-list .nav-item:last-child a {
  }
.nav-sub__ttl{
    color: #5AC3F2;
    width:20%;
    text-align: center;
    font-size: 18px;
}
@media screen and (max-width: 1280px) {
    .global-nav .nav-list .nav-item a {
        padding: 0.6em 0.5em;
        font-size: 13px;
    }
}

/* サブナビゲーション */
@media screen and (min-width: 1141px) {
  
    .global-nav .nav-list .nav-item a.hover{
        color: #5AC3F2;
    }
    .nav-list {
        position: relative;
    }
  .nav-item_sub {
    background: #fff;
    right: 0;
    margin: 0;
    padding-top: 76px;
    opacity: 0;
    position: absolute;
    top: -500;
    transition: all 0.2s ease;
    visibility: hidden;
    width: calc(100% - 20px);
    z-index: -1;
  }
    .is-loaded .nav-item_sub {
        top: 0;
    }

    .nav-item_sub .inner {
        display: flex;
        margin: 0 auto;
        width: 100%;
        max-width: none;
        padding:30px;
    }

    .nav-item_sub .inner ul {
        width: 80%;
    }
    .nav-item_sub .inner ul li{
        padding: 0 6px;        
    }
    .nav-item_sub .inner ul li img{
        width: 100%;
        height: auto;
        max-width: 250px;
    }
    .nav-item_sub .inner ul li .txt{
        padding-top:10px;
        text-align: left;
        color: #666;
        position: relative;
    }
    .nav-item_sub .inner ul li .txt::after {
        position: absolute;
        content: '';
        display: block;
        top: 55%;
        right: 4px;
        width: 16px;
        height: 8px;
        background-position: 100% 50%;
        background-size: auto 100%;
        background-repeat: no-repeat;
        background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%0A%3C!--%20Generator%3A%20Adobe%20Illustrator%2027.1.1%2C%20SVG%20Export%20Plug-In%20.%20SVG%20Version%3A%206.00%20Build%200)%20%20--%3E%0A%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20x%3D%220px%22%0A%09%20y%3D%220px%22%20viewBox%3D%220%200%2016%207.9%22%20style%3D%22enable-background%3Anew%200%200%2016%207.9%3B%22%20xml%3Aspace%3D%22preserve%22%3E%0A%3Cstyle%20type%3D%22text%2Fcss%22%3E%0A%09.st0%7Bfill%3A%235AC3F2%3B%7D%0A%3C%2Fstyle%3E%0A%3Cpolygon%20class%3D%22st0%22%20points%3D%2215.8%2C4.7%208.5%2C0%208.5%2C3.3%200%2C3.3%200%2C4.7%208.5%2C4.7%208.5%2C4.7%20%22%2F%3E%0A%3C%2Fsvg%3E%0A');
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
        -webkit-transition: background .3s ease;
        transition: background .3s ease;
        transition: right .2s ease-out;
    }
    
    .nav-item_sub .inner ul li .txt span{
       font-size: 11px;
    }
    
    .global-nav .nav-list .nav-item_sub a {
        text-align: center;
        color: #5AC3F2;
    }
    .global-nav .nav-list .nav-item_sub a:hover .txt{
        color: #5AC3F2;
    }
    .global-nav .nav-list .nav-item_sub a:hover .txt::after{
        right: 0;
    }

  .is-loaded .nav-item:hover .nav-item_sub {
    opacity: 1;
    top:20px;
    visibility: visible;
  }
}

/* SP時：ハンバーガーメニューボタン */
.global-nav-icon {
  display: none;
}
.head-sp .nav-list-wrap{
    height: auto;
    opacity: 0;
    transition: opacity 0.2s ease;
}
.head-sp #global-head .logo{
    background: #fff;
}
.head-sp.open .nav-list-wrap{
    opacity: 1;
}

.head-sp .nav-item_sub > .flex{
    display: block;
}
.head-sp .nav-item_sub .inner{
    padding: 0;
}
.head-sp .global-nav-header {
    height: 50px;
}
.head-sp .global-nav .nav-list {
    background: #fff;/*rgba(0, 0, 0, 0.8);*/
    /*left: 50%;*/
    padding: 70px 20px 30px;
    /*position: absolute;
    transform: translate(-50%, 0%);*/
    width: 100%;
}
 .head-sp .global-nav .nav-list .nav-item{
     border-bottom: solid 1px #eee; 
     padding-bottom: 5px;
     margin-bottom: 5px;

}

.head-sp .nav-item_sub li a .imgWrap{
    display: none;
}
.head-sp .nav-sub__ttl{
    font-size: 14px;
    text-align: left;
    width: 100%;
}

.head-sp .global-nav .nav-list .nav-item a{
    padding: 0.3em 1em 0.3em 0;
}
.head-sp .global-nav .nav-list .nav-item > a {
    text-align: left;
    color: #5AC3F2;
}
.head-sp .global-nav .nav-list .nav-item > a.link__off,.head-sp .global-nav .nav-list .nav-item.btn__mypage a.link__off{
    color: #aaa!important;
}
.head-sp .global-nav .nav-list .nav-item_sub .txt{
    text-align: left;
}
.head-sp .global-nav .nav-list .nav-item_sub a{
    text-align: left;
    font-weight: normal;
}
.head-sp .global-nav .nav-list .nav-item.btn__entry{
    margin-left: 0;
}
.head-sp .global-nav .nav-list .nav-item.btn__entry > a{
    color: white;
}
.head-sp .global-nav .nav-list .nav-item:last-child a {
    border-bottom: none;
}

.head-sp .global-nav-icon {
    color: #999;
    cursor: pointer;
    display: inline-block;
    font-size: 28px;
    position: absolute;
    right: 5px;
    top: 15px;
    z-index: 2;
}
.head-sp #global-head{
z-index: 5500;
}
.head-sp #global-head .logo img,.head-sp #global-head .logo svg{
    max-width: 50px;
}


.head-sp .nav-item_sub {
    /*display: none;*/
}
.head-sp .nav-sub__ttl {
    display: none;
}
.open .global-nav {
    left: 0;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 5000;
    right: 0;
}

.head-sp .nav-list{
    height: 100%;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
}

.head-sp #global-head{
    width: 96%;
}
.head-sp .global-nav .nav-list .nav-item.btn__entry,
.head-sp .global-nav .nav-list .nav-item.btn__mypage{
    border-bottom: none;
    padding-bottom: 0;
}
.head-sp .global-nav .nav-list .nav-item.btn__entry a,
.head-sp .global-nav .nav-list .nav-item.btn__mypage a{
    text-align: center;
    margin: auto;
    padding: 1em 0;
}

.head-sp .btn__mypage{
    margin-left: 0;
    
}


@media screen and (max-width: 599px) {
    
    #global-head .logo{
        margin-top: 5px;
    }
    .head-sp .nav-item_sub > div > .flex{
        flex-direction: column;
    }
    .head-sp.open .global-nav .nav-list {
        overflow: auto;
        -webkit-overflow-scrolling: touch;
        height: 100vh;
        padding-bottom: 100px;
    }
    .head-sp .global-nav .nav-list .nav-item a{
        padding-bottom:0.3em; 
    }
  /*  body.open{
        position: fixed;
    }*/
   
}

/**-----------------------------------------**/







.menu-trigger {
  display: none;
  position: absolute;
  top: 15px;
  right: 20px;
  height: 46px;
  padding: 6px;
  z-index: 6000;
  transition: .2s ease; 
/*box-shadow: 0px 0px 0px 1px rgb(4 85 133 / 20%);*/
}
.menu-trigger.fixed{
  position: fixed;
}
.menu-trigger:hover {
  cursor: pointer;
}
  .nav-sp{display: none;}
  .nav-pc{display: block;}


@media (max-width: 1140px) {
    .head-sp .global-nav .nav-list{
        flex-wrap: wrap;
    }
    .btn__fb span{
        display: inline-block;
        color: #666;
        padding-left: 1em;
        font-weight: normal;
    }
    .head-sp .global-nav {right: 0;}
    .head-sp .global-nav .nav-list .nav-item.btn__fb{
        border-bottom: none;
        margin-top: 10px;
        margin-left: 0;
    }
    .head-sp .head__inner,.head__inner{
        height: 70px;
    }
    .menu-trigger {
        display: block;
        top: 12px;
        right: 22px;
    }
    .head-sp .global-nav .nav-list{
        align-items: flex-start;
        justify-content:space-between;
    }
    .head-sp .global-nav .nav-list .nav-item{
        width: 50%;
        border-bottom: none;
        margin-bottom: 20px;
    }

    .nav-sp{
        display: block;
        margin-bottom: 10px;
        padding-bottom: 20px;
        width: 100%!important;
    }
    .nav-sp ul{
        display: flex;
        justify-content: center;
        flex: wrap;
        width: 100%;
    }
    .nav-pc{display: none;}
    .nav-sp ul li{
        width: 50%;
    }
    .head-sp .global-nav .nav-list .nav-item.btn__entry a,
    .head-sp .global-nav .nav-list .nav-item.btn__mypage a{
        width: 100%;
        max-width: 100%;
        display: block;
    }
}


@media (max-width: 599px) {
    .head-sp .global-nav .nav-list{
        flex-wrap: nowrap;
    }
    .head-sp .global-nav .nav-list{
        flex-direction: column;
        justify-content: flex-start;
    }
    .head-sp .global-nav .nav-list .nav-item{
        width: 100%;
        border-bottom: solid 1px #eee;
        margin-bottom: 5px;
    }

    .nav-sp{
        border-bottom: solid 1px #eee;
    }
    .nav-sp ul{
        display: flex;
        justify-content: center;
        flex: wrap;
        width: 100%;
    }
    .nav-pc{display: none;}
   .head-sp .global-nav .nav-list .nav-sp .nav-item{
        width: 50%;
       padding: 0;
    }
    .head-sp .global-nav .nav-list .nav-item.btn__entry a,
    .head-sp .global-nav .nav-list .nav-item.btn__mypage a{
        width: 100%;
        max-width: 100%;
        display: block;
    }
}



  .menu-trigger > div {
    position: relative;
    width: 34px; }
  .menu-trigger span {
    width: 80%;
    height: 2px;
    left: 0;
    right: 0;
    margin: auto;
    display: block;
    background: #5AC3F2;
    position: absolute;
    transition: .2s ease; 
/*box-shadow: 0px 0px 0px 1px rgb(4 85 133 / 20%);*/
}

@media (max-width: 599px) {
    .menu-trigger {
      top: 12px;
      right: 10px; }
}
.menu-trigger span:nth-child(1),.head-sp .menu-trigger span:nth-child(1)  {
  top: 6px; }
.menu-trigger span:nth-child(2) {
  top: 14px; }
.menu-trigger span:nth-child(3),.head-sp .menu-trigger span:nth-child(3)  {
  top: 22px; }

.menu-trigger.hover span:nth-child(1){
  top: 10px;
}
.menu-trigger.hover span:nth-child(3)  {
  top: 18px;
}


.sp{display: none;}
.pc{display: block;}
@media (max-width: 767px) {
  .pc{display: none;}
  .sp{display: block;}
}
.sp-only {display: none !important; }
@media (max-width: 767px) {
.sp-only {display: block !important; } }

.sptab-only {display: none !important; }
@media (max-width: 1100px) {
.sptab-only {
display: block !important; } }

.open {/*overflow: hidden;*/}
.open #overlay {display: block; }


.open .menu-trigger span:nth-child(1) {
  top: 14px;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  transform: rotate(45deg); 
  width: 80%;
}

.open .menu-trigger span:nth-child(2) {
  width: 0;
  left: 50%;
}

.open .menu-trigger span:nth-child(3) {
  top: 14px;
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  transform: rotate(-45deg);
  width: 80%;
} 

#overlay {
  display: none;
  position: fixed;
  background: rgba(0, 0, 0, 0.6);
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1200; }



/* transition */
header,.nav li, .nav li a, .open {transition: all 0.3s ease;}

/* Fixed */

/*@media (min-width: 1100px) {
  #global-head.fixed {
    height: 70px; }

  #global-head.fixed .logo {
    margin-top: 5px; }
}*/
.top-fixed{
    position: fixed;
}
  

/* =========================================================
FOOTER
========================================================= */
#pagetop {
  width: 80px;
  height: 80px;
  text-align: center;
  background-color: #004692;
  padding: 0;
  float: right;
  overflow: hidden; }
  #pagetop a {
    display: block;
    letter-spacing: 1.2px;
    position: relative;
    color: #fff;
    font-size: 4.0rem; }
  @media screen and (max-width: 1100px) {
    #pagetop {
      width: 100%;
      float: none;
      height: 40px; }
      #pagetop a {
        font-size: 3.4rem;
        line-height: 1.4; } }

#pagetop:hover a {
  background-color: #02346a;
  -webkit-transition: all .3s;
  transition: all .3s; }
  
@media screen and (max-width: 1100px) {
  #pagetop:hover a {background-color: #004692; }
}

footer {
    background: #1C2A45;
    color:#D7D7DB;
}
footer a{
    color:#D7D7DB;
    font-size: 1.4rem;
}
footer .inner {
    max-width: 1280px;
    margin: auto;
    padding: 50px 0;
}
footer .foot__list01{
    align-items: flex-start;
}
footer .foot__list01 > li{
    padding-right: 4em;
}
footer a:hover{
    color: #fff;
}
footer .foot__list_wrap{
    margin-bottom: 2rem;
    width: 100%;
}
footer .fb{
    position: relative;
}
footer .fb::before{
    content: "";
    background: url(./../img/common/icon-fb-foot.svg) no-repeat;
    position: relative;
    display: inline-block;
    margin-right: 10px;
    width: 33px;
    height: 33px;
    top:1rem;
    left: 0;
    background-size: cover;
    
}

footer .copy{
    font-size: 1.3rem;
    text-align: right;
    margin-top: 1.5rem;
}

.foot_list_sub li a{
    font-size: 1.3rem;
    position: relative;
}
.foot_list_sub li a span{
    font-size: 1.1rem;
}
.foot_list_sub li{
    line-height: 1.2;
    margin-bottom: .8em;
}
footer .foot__list01{
    width: 100%;
}
 footer .foot__list01 > li{
    width: 15%;
}
footer .foot__list01 > li:nth-child(3){
    width: 22%
}
footer .foot__list01 > li:last-child{
    width: 33%;
     padding-right: 0;
}


@media (max-width: 1300px) {
  footer .inner{
    padding: 5% 4% 4%;
  } 
}

@media (max-width: 1180px) {
  footer .inner{
    padding: 5% 4% 4%;
  } 
    footer .copy{
        margin-top: 3rem;
    }
}
@media (max-width: 960px) {
    footer .align-items-center{
        align-items: flex-start!important;
    }
    footer .foot__list01{
        margin-bottom: 20px;
        width: 100%;
    }
    footer .foot__list01 > li{
        padding-right: 1.5em;
    }
}
@media (max-width: 767px) {
    footer a{
        font-size: 12px;
    }
    footer .fb::before{
        margin-right: 8px;
        width: 20px;
        height: 20px;
        top: 0.7rem;
    }
    footer .copy{
        margin-top: 4rem;
        text-align: center;
    }
}
@media (max-width: 599px) {
    footer .inner{
        padding: 7vw;
    }
    footer .foot__list01.flex{
        flex-wrap: wrap;
    }
    footer .foot__list01.flex > li{
        width: 48%;
        margin-bottom: 20px;
        padding-right: 2%;;
    }
    footer .foot__list01.flex > li:last-child{
        width: 100%;
    }
}



/* ##### Anime ##### */
.anim1, .anim2, .anim3 {
  opacity: 0; }

.anim, .anim02, .anim03, .anim04 {
  opacity: 0;
  transform: translate(0, 50px);
  transition: all 500ms; }

.animR {
  opacity: 0;
  transform: translate(100px, 0);
  transition: all 1000ms; }

.animL {
  opacity: 0;
  transform: translate(-100px, 0);
  transition: all 1000ms; }

/* 画面内に入った状態 */
.anim.scrollin {
  opacity: 1;
  transform: translate(0, 0);
  transition-delay: 0.3s; }

.anim02.scrollin {
  opacity: 1;
  transform: translate(0, 0);
  transition-delay: 0.1s; }

.anim03.scrollin {
  opacity: 1;
  transform: translate(0, 0);
  transition-delay: 0.2s; }

.anim04.scrollin {
  opacity: 1;
  transform: translate(0, 0);
  transition-delay: 0.3s; }

.animR.scrollin {
  opacity: 1;
  transform: translate(0, 0); }

.animL.scrollin {
  opacity: 1;
  transform: translate(0, 0); }

@media (max-width: 767px) {
  img[usemap] {
    border: none;
    height: auto;
    max-width: 100%;
    width: auto;
  }
}

.list-dot li{
  position: relative;
  padding-left: 1.2em;
  margin-bottom: .5em;
}
.list-dot li:before{
  content: "・";
  top:0;
  left: 0;
  position: absolute;
}


/* =========================================================
TOP
========================================================= */


/* ----- 背景用の動画ファイル ----- */
.wrap{
 /*   background: url(./../img/common/bg_video.png)repeat;*/
    width: 100%;
    position: relative;
    z-index: -1;
}
.wrap::before{
    content: "";
    position: absolute;
    width: 25%;
    height: 100%;
    background: white;
    top:0;
    left: 0;
    z-index: 500;
}
#bg-video{
    position: fixed;
    right: 0;
    bottom: 0;
    min-width: 90%;
    min-height: 100%;
    width: auto;
    height: auto;
    z-index: -100;
    background-size: cover;
}
#mvText{
    position: absolute;
    top:0%;
    left: 0;
    margin: auto;
    z-index: 10;
    /*height: 100vh;*/
    height: 880px;
    overflow: hidden;
    width: 100%;
    opacity: 0;
    transition: 1.8s opacity ease;
}

#mvText .mv-copy {
    margin: 29vh 0 0 5rem;
    position: relative;
    transition:all .4s ease;
}
.is-end #mvText{
    opacity: 1;
}
#mvText h1 {
    font-weight: bold;
    font-size: 34px;
    line-height: 212.5%;
    padding-top: .5em;
    transition:all .4s ease;
    
    display: inline-block;
    background: linear-gradient(90deg, #5FF4FF,#AF76FC);
    background: -webkit-linear-gradient(0deg, #5FF4FF,#AF76FC);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

#mvText .mv-copy .copy-en{
    position: relative;
}
.is-start #loader-bg{
    /*transform: translateX(100%);
    transition:transform 1.2s 0.5s cubic-bezier(.32,.43,.49,1.36)*/
    opacity: 0;
    
}
.is-end #loader-bg{
    display: none;
}

#mvText .mv-copy .copy-en img{
    width: 71vw;
    max-width: 580px;
}
.header-title{
     position: relative;
     z-index: 2;
     display: flex;
     width: 50%;
     justify-content: center;
     align-items: center;
     text-align:center;
     margin: auto;
}

/* ##### MVArea ##### */
#mvArea{
    width: 100%;
    /*height: 100vh;*/
    height:880px;
    padding: 90px 0 0;
    position: relative;
    z-index: 1;
    overflow-x: hidden;
    margin-left: auto;
}

#mvArea:before{
    content: "";
    position: fixed;
    bottom: 0;
    right: 0;
    min-width: 100%;
    MIN-height:100%;
    background: rgba(0,0,0,0.3);
    z-index: 5;
}
.mv{
    position: relative;
    z-index: 50;
}


@media (max-aspect-ratio: 16/9) {
    #bg-video,#mvArea:before{
        height: 100%;
        left: 50%;
        transform: translateX(-50%);
    }
    #bg-video{
        transform: translateX(-40%);  
    }
}

@media screen and (max-width: 1300px) {
    #bg-video {
        height: 100%;
        left: 50%;
        transform: translateX(-40%);
    }
}

@media screen and (max-width: 1140px) {
    #mvArea{
        padding: 70px 20px 0;  
    }
  
}
@media screen and (max-width: 1024px) {
    #mvArea,#mvText{
        height: 80vh;
    }
    #mvArea{
       padding-top: 70px; 
    }
    #mvText .mv-copy{
        margin-top: 30vh;
    }
}
@media (orientation: landscape) and (max-width: 900px) {
  #bg-video {
    height: auto;
  }
}
@media screen and (max-width: 959px) {

    .is-loaded #mvText .mv-copy .copy-en::before{
        animation:rightMoveS 1s both;
        animation-delay:.5s;
    }
    #mvText{
        position: static;
        height: auto;
        padding: 7vw 0;
    }
    .wrap{
        height: 77vw;
    }
    #mvText .mv-copy {
        margin: 10vw 0 0 7vw;
    }

    #bg-video {
        position: relative;
        transform: translateX(0);
        width: auto;
        min-width: 100%;
        height: 77vw;
        left: -15vw;
    }
    #mvArea{
        width: 100%;
        height: auto;
        padding: 0;
    }
    #mvArea:before{
        position: absolute;
        transform: translateX(0);
        top:0;
        left: 0;
        width: 100%;
        height: 100%;
    }
    .wrap::before{
        content: none;
    }
    #mvText h1{
        font-size: 2.2rem;
        padding-top: 1em;
    }
    #mvText .mv-copy .copy-en img{
        max-width: 480px;
    }
}
@media screen and (max-width: 767px) {
    #mvText .mv-copy{
        margin:15vw 0 0 7vw;
    }
    #mvText{
        padding: 13vw 0; 
    }
}




@keyframes rightMoveS {
  0% {
    transform: translateX(0);
      animation-timing-function: ease-in;
    }
  100% {
    transform: translateX(100vw);
    animation-timing-function: ease-out;
    }
}

@media screen and (max-width: 599px) {

}


@keyframes scrolling {
  0% {
    bottom: 70px;
    height: 0; }
  49% {
    bottom: 0;
    height: 70px; }
  51% {
    height: 70px; }
  70% {
    height: 70px; }
  100% {
    height: 0; }
}
 
.m-mainVisual-scroll_wrap {
    position: absolute;
    /*bottom: 4vh;*/
    top:770px;
    left: 3vw;
    z-index: 50;
    opacity: 0;
    transition: .3s 0s all ease-in;
    transform: translateY(30px);
    transition-delay: 1s;
 }
.is-end .m-mainVisual-scroll_wrap{
    opacity: 1;
    transform: translateY(0);
}
.scroll-down-box{
  display:block;
  position:relative;
  text-decoration:none;
}
.scroll-down-box .scroll-text{
  width:124px;
  height:auto;
  -webkit-animation: rotation 15s infinite linear;
  animation: rotation 15s infinite linear;
}
.scroll-down-box.alt .scroll-text{
  -webkit-animation: none;
  animation: none;
}
.scroll-down-box.alt:hover .scroll-text{
  -webkit-animation: rotation 10s infinite linear;
  animation: rotation 10s infinite linear;
}
.scroll-down-box .scroll-icon{
  width:20px;
  height:auto;
  position:absolute;
  top:50%;
  left:50%;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  -webkit-transition:all 0.2s ease-in;
  transition:all 0.2s ease-in;
}
.scroll-down-box.alt .scroll-icon{
  width:35px;
}
.scroll-down-box:hover .scroll-icon{
  -webkit-animation: move 1.5s infinite linear;
  animation: move 1.5s infinite linear;
}
.scroll-down-box.alt:hover .scroll-icon{
  -webkit-animation: none;
  animation: none;
}

@keyframes rotation {
		from {-webkit-transform: rotate(0deg); transform: rotate(0deg);}
		to {-webkit-transform: rotate(359deg); transform: rotate(359deg);}
}
@-webkit-keyframes rotation {
		from {-webkit-transform: rotate(0deg); transform: rotate(0deg);}
		to {-webkit-transform: rotate(359deg); transform: rotate(359deg);}
}

@keyframes move {
    0% {-ms-transform: translate(-50%,-50%); -webkit-transform: translate(-50%,-50%); transform: translate(-50%,-50%);}
    35% {-ms-transform: translate(-50%,-35%); -webkit-transform: translate(-50%,-35%); transform: translate(-50%,-35%);}
    90% {-ms-transform: translate(-50%,-60%); -webkit-transform: translate(-50%,-60%); transform: translate(-50%,-60%);}
    100% {-ms-transform: translate(-50%,-50%); -webkit-transform: translate(-50%,-50%); transform: translate(-50%,-50%);}
}
@-webkit-keyframes move {
    0% {-ms-transform: translate(-50%,-50%); -webkit-transform: translate(-50%,-50%); transform: translate(-50%,-50%);}
    35% {-ms-transform: translate(-50%,-35%); -webkit-transform: translate(-50%,-35%); transform: translate(-50%,-35%);}
    90% {-ms-transform: translate(-50%,-60%); -webkit-transform: translate(-50%,-60%); transform: translate(-50%,-60%);}
    100% {-ms-transform: translate(-50%,-50%); -webkit-transform: translate(-50%,-50%); transform: translate(-50%,-50%);}
}

@media screen and (max-width: 1024px){
    .m-mainVisual-scroll_wrap {
      display: none;
    }
 }
@media (orientation: landscape) and (max-width: 812px){
  body{
    font-size: 14px;
  }  
  .m-mainVisual-scroll{
    display: none;
  }
  #mvArea{
    height: 100vh;
  }
  #mvArea .mv-copy{
    padding-top: 0;
  }
  #mvArea .mv-copy h1{
    font-size:30px;
  }
  #mvArea .mv-copy p{
    font-size:13px;
  }

  #bg-video {
    width: 100%;
    left: 50%;
    transform: translateX(-50%);
    height: auto;
  }
}


.ff-en {font-family: 'Poppins', sans-serif;}
.wh-txt{color: white;}
.h2ttl{
  font-family: Poppins;
  font-weight: normal;
  font-size: 8rem;
  line-height: 1.2;
  text-align: left;
  color: #5AC3F2;
  position: relative;
}

.h2ttl_r{
  font-family: Poppins;
  font-weight: normal;
  font-size: 8rem;
  line-height: 1.2;
  text-align: right;
  color: #5AC3F2;
  position: relative;
}
.h2ttl__sub{
  font-weight: bold;
  font-size: 2.2rem;
  line-height: 13px;
  text-align: left;
  padding-top: 1.5em;
}
.h2ttl__sub__r{
  text-align: right;
}
  
main{background: white;}

.section{
    padding: 80px 0 100px;
    overflow: hidden;
}
.section_1st .contents_inner{
    padding-top: 0!important;
}
.section_end{
    padding-bottom: 200px;
}
#topics .section{
    padding: 70px 0 150px;
}
@media (max-width: 1550px) {
    .h2ttl,.h2ttl_r{
        font-size: 5vw;
    }
}
@media (max-width: 959px) {
    .h2ttl, .h2ttl_r{
        font-size: 7vw;
    }
    .h2ttl{
        line-height: 1.1;
        margin-left: 20px;
    }
    h2ttl_r{
        line-height: 1.1;
        margin-right: 20px;}
    .h2ttl__sub{
        font-size: 18px;
        margin-left: 20px;
    }
    h2ttl__sub__r{
        font-size: 18px;
        margin-right: 20px;}
}
@media (max-width: 767px) {
    .section{
        padding: 5vw 0;
    }
    .section_end{
        padding-bottom: 20vw;
    }
}
@media (max-width: 599px) {
    .section{ padding: 20vw 0; }
    .section_end{
        padding-bottom: 25vw;
    }
    .h2ttl,.h2ttl_r{
        font-size: 10vw;
        line-height: 1.3;;
    }
    .h2ttl{
        margin-left: 7vw;
    }
    .h2ttl_r{
        margin-right: 7vw;
    }
    .h2ttl__sub,.h2ttl__sub__r{
        font-size: 16px;
        padding-top: 1em;
        padding-bottom: 1em;
    }
    .h2ttl__sub{
        margin-left: 7vw;
    }
    .h2ttl__sub__r{
        margin-right: 7vw;
    }
}

/* =========================================================
TOP-company-msg
========================================================= */
#company-msg.section{
    padding-top: 170px;
    position: relative;
}
#company-msg.section:before{
    content: "";
    position: absolute;
    top: -15vw;
    right: -10vw;
    width: 38vw;
    height: 38vw;
    background: url(./../img/top/bg-circle.svg) no-repeat;
    z-index: 0;
    background-size: cover;
}
.company-msg-wrap {
  position: relative
}

.company-msg__inner {
    position: relative;
    max-width: 1800px;
    margin: auto;
}
.company-msg__flex {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    padding-top: 25px;
    margin-left: 5vw;
}

.company-msg__ttl{
  position: absolute;
  top:0;
  left: 5vw;
  text-align: left;
}
.company-msg__img{
  margin: 0 0 0 0;
  flex: 0 0 50%;
  display: flex;
  flex-wrap: wrap;
  overflow: hidden
}
.company-msg__img img {
  width: 100%;
  height: auto;/**25vw**/
}
.company-msg__content {
  position: relative;
  flex: 0 0 40%;
  margin: 0 0 160px
}
.company-msg__frame {
  max-width: 720px;
  padding: 7rem;
  box-sizing: border-box;
  transform: translateX(-5vw);
  background: #5AC3F2;
}
.company-msg-head__ja {
  margin-top: 40px;
  font-size: 5rem
}
.company-msg__txt {
  margin-top: 30px;
  font-size: 1.7rem
}
.company-msg__copy{
    color: white;
    font-size: 5rem;
    text-align: center;
    line-height: 1.3
}
.company-msg__subcopy{
  font-weight: bold;
  font-size: 2.2rem
}

.company-msg__btn{
    margin-top: 40px;
    text-align: right;
}
.arrow-btn__link {
    width: auto;
    position: relative;
    display: inline-block;
    border: 2px solid #fff;
    text-decoration: none;
    background: #fff;
    color: #5AC3F2;
    padding: 10px 50px;
    transition: all .3s ease;
    text-align: center;
}

.arrow-btn__link:after {
    position: absolute;
    content: '';
    display: block;
    top: 50%;
    right: 10px;
    width: 21px;
    height: 10px;
    background-position: 100% 50%;
    background-size: auto 100%;
    background-repeat: no-repeat;
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%0A%3C!--%20Generator%3A%20Adobe%20Illustrator%2027.1.1%2C%20SVG%20Export%20Plug-In%20.%20SVG%20Version%3A%206.00%20Build%200)%20%20--%3E%0A%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20x%3D%220px%22%0A%09%20y%3D%220px%22%20viewBox%3D%220%200%2016%207.9%22%20style%3D%22enable-background%3Anew%200%200%2016%207.9%3B%22%20xml%3Aspace%3D%22preserve%22%3E%0A%3Cstyle%20type%3D%22text%2Fcss%22%3E%0A%09.st0%7Bfill%3A%235AC3F2%3B%7D%0A%3C%2Fstyle%3E%0A%3Cpolygon%20class%3D%22st0%22%20points%3D%2215.8%2C4.7%208.5%2C0%208.5%2C3.3%200%2C3.3%200%2C4.7%208.5%2C4.7%208.5%2C4.7%20%22%2F%3E%0A%3C%2Fsvg%3E%0A');
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    -webkit-transition: background .3s ease;
    transition: background .3s ease;
    transition: right .2s ease-out;
}

.arrow-btn__link:hover {
    color: #fff;
    background: transparent;
    text-decoration: none;
}
.arrow-btn__link:hover::after {
    right: 3px;
}
.arrow-btn__link.link__off{
    pointer-events: none!important;
    text-align: center!important;
}
.arrow-btn__link.link__off:after{
    content: none!important;
}

.arrow-btn__link:hover:after {
    background-position: 100% 50%;
    background-size: auto 100%;
    background-repeat: no-repeat;
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2016%207.9%22%20style%3D%22enable-background%3Anew%200%200%2016%207.9%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23FFFFFF%3B%7D%3C%2Fstyle%3E%3Cpolygon%20class%3D%22st0%22%20points%3D%2215.8%2C4.7%208.5%2C0%208.5%2C3.3%200%2C3.3%200%2C4.7%208.5%2C4.7%208.5%2C4.7%20%22%2F%3E%3C%2Fsvg%3E')
}
@media (max-width: 1550px) {
    .company-msg__img{
        flex: 0 0 52%;
    }
    .company-msg__content {
        flex: 0 0 48%;
        margin-bottom: 8vw;
    }
    .company-msg__frame{
        padding: 6rem 4rem;
    }
    .company-msg__copy{
        font-size: 3.5vw;
    }
    .company-msg__subcopy{
        font-size: 1.7vw;
    }
}
@media (max-width: 1140px) {
    .arrow-btn__link:after {
        right: 1vw;
    }
    .company-msg__flex{
        padding-top: 0;
    }
}
@media (max-width: 959px) {
    .company-msg__copy{
        font-size: 5.5vw;
    }
    .company-msg__subcopy {
        font-size: 2.4vw;
    }
    #company-msg.section{
        padding-top: 15vw;
    }
    .company-msg__ttl{
        position: static;
    }
    .company-msg__flex{
        flex-direction: column-reverse;
        align-items: flex-start;
        margin-left: 0;
    }
    .company-msg__ttl{
        margin-bottom: 5vw;
    }
    .company-msg__frame{
        max-width:none;
        transform: translateX(0);
        width: 93vw;
        padding: 10vw 5vw 12vw;
    }
    .company-msg__copy{
        text-align: center;
    }
    .company-msg__copy img{
        max-width: 600px;
        width: 70%;
    }
    .company-msg__content{
        width: 100%;
        margin-bottom: 0;
    }
    .company-msg__btn{
        text-align: center;
    }
    .company-msg__img{
        width:93vw;
        margin-top: 0;
    }
    .company-msg__img img{
        width: 100%;
        height: auto;
    }
}

@media (max-width: 767px) {
    #company-msg.section{
        padding-top: 20vww;
    }
    .company-msg__copy{
        font-size: 4.2rem;
        line-height: 1.6;
    }
    .company-msg__flex{
        margin-right: 7vw;
        margin-left: 0;
    }
    .company-msg__frame{
        width: 93vw;
        transform: translateX(0);
    }
    .company-msg__img{
        margin-top: 0;
    }
}
@media (max-width: 599px) {
    .company-msg__copy{ font-size:8vw; }
    .company-msg__subcopy{font-size: 4vw;}
    #company-msg.section:before{
        top: 25vw;
        right: -22vw;
        width: 55vw;
        height: 55vw;
    }
    .arrow-btn__link:after {
        right: 3vw;
    }
    .company-msg__frame {
        padding: 10vw 6.3vw;
    }
    .company-msg__subcopy{
        font-size: 18px;
        margin-top:0;
    }
    .arrow-btn__link{
        width: 80%;
        max-width: 500px;
    }
}

/* =========================================================
TOP-about
========================================================= */
#about.section{
    padding-top: 10vw;
    padding-bottom: 12vw;
    position: relative;
}
.about__inner{
    max-width: 1521px;
    margin: auto;
}
.list-3__top {
    position: relative;
    margin: 0;
    width: 100%;
    padding-top: 50px;
}
#about.section::before{
    content: "";
    position: absolute;
    top:9vw;
    left: -15vw;
    width: 40vw;
    height: 40vw;
    background: url(./../img/top/bg-squre.svg) no-repeat;
    z-index: 0;
    background-size: cover;
}
.list-3__top ul{
    display: flex;
    justify-content: center;
    max-width: 1521px;
    margin: auto;
}

a .imgWrap{
    overflow: hidden;
    position: relative;
}
a .imgWrap::before,.imgWrap::before{
    content: "";
    position: absolute;
    top:0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg,rgba(43,111,106,0.3) 0%, rgba(0,3,101,0.3) 100%);
    
    transition: all .2s ease;
    z-index: 1;
}
a:hover .imgWrap::before{
    background:linear-gradient(135deg,rgba(43,111,106,0.0) 0%, rgba(0,3,101,0.0) 100%);
}
.list-3__top ul li {
    width: 33.3%;
    padding: 0;
    position: relative;
    overflow: hidden;
}
a .imgWrap img {
    display: block;
    width: 100%;
    height: auto;
    transition-duration: 0.3s;
}

.list-3__top ul li a .txtArea {
    position: absolute;
    top: 37%;
    left: 0;
    right: 0;
    margin: auto;
    text-align: center;
    width: 80%;
    z-index: 20; 
}
.list-3__top ul li a h4 {
    color: #fff;
    font-size: 2rem; 
}
.list-3__top ul li a p {
    color: #fff;
    margin: 0;
    font-size: 1.4rem;
}
.link-tri {
    width: 50px;
    height: 48px;
    margin: 0;
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 40;
    transition-duration: 0.5s; 
    background: white;
    transition: all .3s ease;
}
.link-tri:before{
  content:"";
  background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%0A%3C!--%20Generator%3A%20Adobe%20Illustrator%2027.1.1%2C%20SVG%20Export%20Plug-In%20.%20SVG%20Version%3A%206.00%20Build%200)%20%20--%3E%0A%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20x%3D%220px%22%0A%09%20y%3D%220px%22%20viewBox%3D%220%200%2016%207.9%22%20style%3D%22enable-background%3Anew%200%200%2016%207.9%3B%22%20xml%3Aspace%3D%22preserve%22%3E%0A%3Cstyle%20type%3D%22text%2Fcss%22%3E%0A%09.st0%7Bfill%3A%235AC3F2%3B%7D%0A%3C%2Fstyle%3E%0A%3Cpolygon%20class%3D%22st0%22%20points%3D%2215.8%2C4.7%208.5%2C0%208.5%2C3.3%200%2C3.3%200%2C4.7%208.5%2C4.7%208.5%2C4.7%20%22%2F%3E%0A%3C%2Fsvg%3E%0A');
    position: absolute;
    width: 18px;
    height: 10px;
    background-size: cover;
    right: 16px;
    bottom: 16px;
    transition-duration: 0.5s;
}
.link-tri:after{
    content:"";
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%0A%3C!--%20Generator%3A%20Adobe%20Illustrator%2027.1.1%2C%20SVG%20Export%20Plug-In%20.%20SVG%20Version%3A%206.00%20Build%200)%20%20--%3E%0A%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20x%3D%220px%22%0A%09%20y%3D%220px%22%20viewBox%3D%220%200%2016%207.9%22%20style%3D%22enable-background%3Anew%200%200%2016%207.9%3B%22%20xml%3Aspace%3D%22preserve%22%3E%0A%3Cstyle%20type%3D%22text%2Fcss%22%3E%0A%09.st0%7Bfill%3A%23FFFFFF%3B%7D%0A%3C%2Fstyle%3E%0A%3Cpolygon%20class%3D%22st0%22%20points%3D%2215.8%2C4.7%208.5%2C0%208.5%2C3.3%200%2C3.3%200%2C4.7%208.5%2C4.7%208.5%2C4.7%20%22%2F%3E%0A%3C%2Fsvg%3E%0A');
    position: absolute;
    width: 18px;
    height: 10px;
    background-size: cover;
    right: 30px;
    bottom: 16px;
    opacity:0;
    transition-duration: 0.5s;
}
ul li a .link-tri img {
  width: 18px;
  height: auto;
  position: relative;
  right: -3px;
  bottom: 7px;
  transition-duration: 0.3s;
}

.list-3__top ul li a p.mb-2em {
  margin-bottom: 2em; }
a:hover .imgWrap img{
  transform: scale(1.1);
  transition-duration: 0.3s;
}
a.hover .link-tri {
    background:#5AC3F2;
}
a.hover .link-tri:before{
    right: -5px;
    opacity: 0;
}
a.hover .link-tri:after{
  right: 16px;
  opacity:1;

}


.list-3__top a.link__off{
    pointer-events:none;
}
.list-3__top a:hover.link__off{
    pointer-events:none;
}
.list-3__top a.link__off .link-tri{
    display: none;
}
a.link__off:hover .imgWrap img{
  transform: scale(1);
}
a.link__off .imgWrap::before{
    background: rgba(0,0,0,0.6);
}
a.link__off p.txt__cs{
    font-size: 1.7rem;
    margin-top: 0.5em;
}
@media (max-width: 1550px) {
    .about__inner{
        padding: 0 5vw;
    }
    #about.section::before{
        top: 15vw;
    }
}

@media (max-width: 959px) {
    #about.section{
        padding-bottom: 6vw
    }
    #about .list-3__top::before{
        top:5%;
        width: 70vw;
        height: 60%;
    }
    .list-3__top{
        padding-top: 10%;
    }
    .list-3__top ul{
        flex-wrap: wrap;
        padding: 0;
        justify-content: flex-start;
    }
    .list-3__top ul li{
        width: 50%;
        margin: 0;
    }

    #about.section::before{
        top:7vw;
        left: -12vw;
        width: 50vw;
        height: 50vw;
    }
}

@media (max-width: 767px) {
    #about.section{
        padding: 20vw 0 0;
        margin-top: 15vw;
    }
    #about.section::before{
        left: -72vw;
        top:10vw;
        height: 100vw;
        width: 100vw;
    }
}
@media (max-width: 599px) {

    .inner{
        padding: 8% 0;
    }

    .list-3__top{
        width: 100%;
        margin: 0 auto;
        padding-top: 5%;
        padding-left: 7vw;
    }
    .list-3__top ul {
        flex-direction: column;
        padding: 0;
    }
    .list-3__top ul li{
        width: 100%;
        margin: 0;
        height: 50vw;
    }
    .list-3__top ul li img{
        display: none;
    }
    .list-3__top ul li a .imgWrap{
        height: 100%;
    }
    #about .list-3__top ul li:nth-child(1) a .imgWrap{
        background: url(../img/top/about01_sp.jpg) no-repeat;
        background-size: cover;
    }
    #about .list-3__top ul li:nth-child(2) a .imgWrap{
        background: url(../img/top/about02_sp.jpg) no-repeat;
        background-size: cover;
    }
    #about .list-3__top ul li:nth-child(3) a .imgWrap{
        background: url(../img/top/about03_sp.jpg) no-repeat;
        background-size: cover;
    }

  .ttlwrap{
    padding-top:50px;
    margin-bottom: 0;
  }
  .list-3__top ul li a h4{
    font-size: 26px;
  }
    
    
    
}
@media (max-width: 480px) {
  
  .list-3__top ul li a h4{
    font-size: 20px;
  }
}
    


/* =========================================================
TOP-balance
========================================================= */

.balance-wrap {
  position: relative
}
#balance.section{
    padding: 12vw 0 12vw;
}
#balance.section::before{
    content: "";
    position: absolute;
    top:2vw;
    right: -15vw;
    width: 40vw;
    height: 40vw;
    background: url(./../img/top/bg-ring.svg) no-repeat;
    z-index: 0;
    background-size: cover;
}

.balance__inner {
    position: relative;
    max-width: 1521px;
    margin: auto;
    display: flex;
    align-items: center;
}

.balance__ttl{
    width: 32%;
    padding-right: 60px;
}
.balance__img{
    width: 68%;
}
.balance__img img {
  width: 100%;
  height: auto;
}
.balance__content {
  position: relative;
  margin:0;
    top:-80px;
}
.balance__frame {
  width: 60vw;
  padding: 2vw 2vw 2vw 4vw;
  box-sizing: border-box;
  background: #5AC3F2;
}
.balance__flex {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
}
.balance__txt {
  margin-top: 10px;
  font-size: 1.7rem
}
.balance__copy{
    width: 200px;
}
.balance__copy img{
  width: 100%;
  height: auto;
}
.balance__txt__wrap{
    width: calc(100% - 380px);
    padding: 0 2em;
}
.balance__subcopy{
    margin-bottom: .6rem;
}
.balance__subtxt {
    margin-bottom: 1rem;
}

.balance__btn .arrow-btn__link{
    cursor: pointer;
    border: 2px solid #5AC3F2;
}
.balance__btn .arrow-btn__link:hover{
    background: #5AC3F2;
}

@media (max-width: 1550px) {
    .balance__inner{
        padding: 0 5vw;
    }
    #balance.section::before{
        top:4.5vw;
    }
    #balance.section{
        margin: 3vw 0;
    }
}
@media (max-width: 1200px) {
    .balance__frame{
        width: 80vw;
    }
    .balance__content{
        top:-0.5vw;
    }
}
@media (max-width: 959px) {
    #balance .h2ttl{
        margin-left: 0;
    }
    #balance.section{
        padding: 15vw 0 10vw;
        margin-top: 0;
    }
    #balance.section::before{
        width: 59vw;
        height: 59vw;
        right: -22vw;
        top:0;
    }
    .balance__inner{
        flex-direction: column;
    }
    .balance__ttl{
        width: 100%;
    }
    .balance__img{
        width: 100%;
    }
    .balance__subcopy{
        margin: 1rem 0 1rem;
    }
    .balance__subtxt{
        margin: 2.5vw 0 5vw;
    }
    .balance__btn{
        margin:auto;
    }
    .balance__img{
        margin-top: 8vw;
    }
    .balance__ttl{
        padding-right: 0;
    }
}
@media (max-width: 767px) {
    #balance.section::before{
        width: 59vw;
        height: 59vw;
        right: -22vw;
        top:16vw;
    }
    #balance.section{
        padding: 45vw 0 20vw;
        margin-top: 10vw;
    }
    .balance__subcopy{
        margin: 1rem 7vw 1rem;
    }
    .balance__subtxt{
        margin:0 7vw 7vw;
    }
}

 

/* =========================================================
TOP-human
========================================================= */
#human.section{
    position: relative;
}
.human__inner{
    max-width: 1521px;
    margin: auto;
}

#human.section::before{
    content: "";
    position: absolute;
    top:20rem;
    left: 4vw;
    width: 138px;
    height: 294px;
    background: url(./../img/top/bg-human-l.svg) no-repeat;
    z-index: 0;
    background-size: cover;
}
#human.section::after{
    content: "";
    position: absolute;
    top:43rem;
    right: 2vw;
    width: 144px;
    height: 261px;
    background: url(./../img/top/bg-human-r.svg) no-repeat;
    z-index: 0;
    background-size: cover;
}
.human-list__top{
    max-width: 1104px;
    margin: 2rem auto;
}
.human-list__top ul{
    display: flex;
    flex-wrap: wrap; 
    justify-content: space-between;
    position: relative;
    z-index: 5;
}
.human-list__top li{
    width: 480px;
    position: relative;
}
.human-list__top li a{
    position: relative;
    display: block;
}
.human-list__top li a::after{
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    bottom:-20px;
    right: -20px;
    background: linear-gradient(135deg,#5FF4FF 0%, #AF76FC 100%);
    z-index: -1;
}
.human-list__top li:nth-child(2){
    margin-top: 8rem;
}
.human-list__top li .txtArea{
    margin-top: 4rem;
    text-align: center;
}
.human-list__top li .txtArea h4{
    font-size: 2.2rem;
    color:#5AC3F2;
}
@media (max-width: 1700px) {
    #human.section::before{
        left: 1vw;
        top: 5vw;
        width: 110px;
        height: 235px;
    }
    #human.section::after{
        right: -4vw;
        bottom: 5vw;
        top: inherit;
        width: 115px;
        height: 208px;
    }
}

@media (max-width: 1550px) {
    .human__inner{
        padding: 0 5vw;
    }
    .human-list__top li{
        width: 44%;
    }
}
@media (max-width: 959px) {
    #human.section{
        padding-bottom: 12vw
    }
    #human .list-3__top::before{
        top:5%;
        width: 70vw;
        height: 60%;
    }
}

@media (max-width: 599px) {
    .human-list__top li{
        width: 84vw;
    }
    .human-list__top li:nth-child(2){
        margin-left: auto;
    }
    .human-list__top li:nth-child(2) a::after{
        right: inherit;
        left: -20px;
    }
    .human-list__top li .txtArea h4,.human-list__top li .txtArea p{
        text-align: left;
    }
    .human-list__top li .txtArea{
        margin-left: 7vw;
    }
    .human-list__top li:nth-child(2) .txtArea{
        margin-right: 7vw;
        margin-left: 0;
    }
}
@media (max-width: 480px) {
}
    


/* =========================================================
TOP-recruit
========================================================= */
#recruit.section{
    padding-bottom: 10vw;
}
.recruit__inner{
    position: relative;
}
.recruit-contents__inner{
    max-width: 1521px;
    margin: auto;
}
#recruit .list-3__top{
    padding-bottom: 60px;
}
.recruit__inner::before{
    content: "";
    position: absolute;
    bottom: 0;
    right: 0;
    width: 100%;
    height: 45%;
    background: linear-gradient(90deg,#5FF4FF 0%, #AF76FC 100%);
    z-index: 0;
}
.recruit__ttl{
    position: relative;
    text-align: left;
} 
.recruit__ttl .h2ttl,.recruit_u .recruit__ttl .h2ttl__sub{
    text-align: left!important;
}

.recruit-detail-link{
    position: relative;
    display: block;
}
.entry-btn-wh{
    text-align: center;
    margin-top: 3rem;
    width: 70%;
    margin: 3rem auto 0;
}
.entry-btn-wh .arrow-btn__link{
    display: block;
}
.human-sp-sparts01,.human-sp-sparts02{
    display: none;
}
@media (max-width: 1550px) {
    .recruit__inner{
        padding: 0 5vw;
    }
}

@media (max-width: 959px) {
    .recruit__inner::before{
        bottom:1%;
        width: 100%;
        height: 60%;
        width: 100%;
    }
     .recruit__ttl{
         position: static;
    }

    #recruit .list-3__top ul li:nth-child(1) a .imgWrap{
        background: url(../img/top/recruit01_sp.jpg) no-repeat;
        background-size: cover;
    }
    #recruit .list-3__top ul li:nth-child(2) a .imgWrap{
        background: url(../img/top/recruit02_sp.jpg) no-repeat;
        background-size: cover;
    }
    #recruit .list-3__top ul li:nth-child(3) a .imgWrap{
        background: url(../img/top/recruit03_sp.jpg) no-repeat;
        background-size: cover;
    }
    #recruit .list-3__top ul{
        justify-content: space-between;
    }
    #recruit .list-3__top ul li{
        margin-bottom: 50px;
        width: 48%;
    }
    #recruit .list-3__top{
        padding-bottom: 10px;
    }

}
@media (max-width: 767px) {
    #recruit.section{
        padding-bottom: 5vw;
    }
    #recruit .list-3__top{
        padding-left: 0;
    }
    .recruit__inner::before{
        content: none;
    }
    .entry-btn-wh{
        width: 100%;
    }
    #recruit .list-3__top ul li{
        width: 100%;
        margin: 0;
        height: auto;
        padding-left: 7vw;
        padding-right: 7vw;
        padding-bottom: 10vw;
        position: relative;
        margin-bottom: 6rem;
    }
    #recruit .list-3__top ul li::before{
        content: "";
        position: absolute;
        bottom: 0;
        right: 0;
        width: 100%;
        height: 50%;
        background: linear-gradient(90deg,#5FF4FF 0%, #AF76FC 100%);
        z-index: 0;
    }
    #recruit .list-3__top ul li a .imgWrap{
        height: 50vw;
    }
    .entry-btn-wh .arrow-btn__link{
        margin: auto;
    }
    #human.section::before,#human.section::after{content: none;}
    .human__ttl{position: relative;}
    .human__ttl::after{
        content: "";
        position: absolute;
        bottom: 2vw;
        left: 8vw;
        width: 63px;
        height: 49px;
        background: url(./../img/top/bg-human-sp01.svg) no-repeat;
        z-index: 0;
        background-size: cover;        
    }
    .human-sp-sparts01,.human-sp-sparts02{
        display: block;
    }
    .human-sp-sparts01{
        padding-left: 50vw;
    }
    .human-sp-sparts01 img{
        width: 89px;
        height: 44px;
    }
    .human-sp-sparts02{
        text-align: right;
        padding-right: 5vw;
    }
    .human-sp-sparts02 img{
        width: 153px;
        height: 54px;
    }
    #human .human__ttl{
        padding-bottom: 6rem;
    }
}

@media (max-width: 599px) {
    .recruit__inner{
        padding: 0;
    }
    #recruit .list-3__top ul li{
        padding-left: 5vw;
        padding-right:0;
    }
}


.inner{
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding:6% 0;
}
.inner.wideS{
  max-width: 750px;
}


#newsArea {
    background: #fff;
}
  #newsArea .postnews {
    width: 100%;
    max-width: 760px;
    margin: 30px auto;
    text-align: center; }
    #newsArea .postnews .post {
      clear: both;
      padding-bottom: 10px;
      margin-bottom: 0; }
      #newsArea .postnews .post p {
        margin: 0; }
      #newsArea .postnews .post .date {
        float: left;
        margin-right: 20px;
        margin-top: 14px; }
      #newsArea .postnews .post .newstxt {
        text-align: left;
        padding-top: 16px;
        padding-left: 120px; }
      #newsArea .postnews .post a {
        color: #111;
        transition: all .3s; 
}
#newsArea .postnews .post:hover {cursor: pointer; opacity: .6;}
#newsArea .postnews .post:hover a {opacity: .6;}
@media screen and (max-width: 767px) {
  #newsArea { }
  #newsArea .wrapper {
  padding: 45px 15px; }
  #newsArea .postnews {
  width: 100%; }
  #newsArea .postnews .post p {
    margin: 0; }
  #newsArea .postnews .post .date {
    float: none;
    margin-right: 0;
    text-align: left; }
  #newsArea .postnews .post .newstxt {
    padding-left: 0;
    padding-top: 5px;
    text-align: left; } 
}

.anim0 {
  opacity: 0; }

.li-2calm {
  display: table;
  border-collapse: separate;
  border-spacing: 30px 60px; }
  .li-2calm > li {
    display: table-cell;
    vertical-align: middle; }
  @media (max-width: 767px) {
    .li-2calm {
      border-spacing: 30px 0; }
      .li-2calm > li {
        display: block;
        width: 100%;
        padding: 20px; } }

@media (max-width: 767px) {
  .bdr-sp0_sp {
    border-spacing: 0 !important; } }


#fieldArea {
  background:#0868a0; 
 }
#fieldArea ul li{
  padding: 1%;
}
#fieldArea ul li a{
  color: #fff;
}
#fieldArea ul li .wrap{
  border: solid 1px #5396bd;
  background: none;
}
#fieldArea ul li .wrap .bdr-hover{
  position: relative;
}
#fieldArea ul li .wrap .bdr-hover .bdr-inner{
  padding: 10% 6%;
  background: #0868a0;
}

.bdr-hover::after ,
.bdr-hover::before,
.bdr-hover .bdr-inner::after ,
.bdr-hover .bdr-inner::before{
  background-color: #fff;
  content: '';
  display: block;
  position: absolute;
  z-index: 10;
  transition: all .3s ease;
  -webkit-transition: all .3s ease;
}
/* 左上へ配置 */
.bdr-hover::after {
    width: 0px;
    height: 1px;
    top: -1px;
    left: -1px;
}
/* 右下へ配置 */
.bdr-hover::before {
    width: 0px;
    height: 1px;
    right: -1px;
    bottom: -1px;
}
/* 左下へ配置 */
.bdr-hover .bdr-inner::after {
    width: 1px;
    height: 0px;
    left: -1px;
    bottom: -1px;
}
/* 右上へ配置 */
.bdr-hover .bdr-inner::before {
    width: 1px;
    height: 0px;
    top: -1px;
    right: -1px;
}

/* hover */
.bdr-hover:hover::after,
.bdr-hover:hover::before {
  width: 100%;
  width: calc(100% + 1px);
}
.bdr-hover:hover .bdr-inner::after,
.bdr-hover:hover .bdr-inner::before {
  height: 100%;
  height: calc(100% + 1px);
}

#fieldArea ul li p{
  border-top: solid 1px #5396bd;
  margin-top: 20px;
  padding-top: 25px;
}
#fieldArea ul li .bdr-hover:hover p{
  border-top: solid 1px #fff;
  transition: all .3s ease;
}
#fieldArea ul li h2{
  position: relative;
  font-size: 2rem;
  padding: 10px 0;
}
#fieldArea ul li h2::before{
  content: "";
  background: url(./../img/top/field_icon01.svg) no-repeat;
  width: 50px;
  height: 50px;
  position: relative;
  display: inline-block;
  vertical-align: middle;
  margin-right: 10px;
}
#fieldArea ul li.fa-ico02 h2::before{
  background: url(./../img/top/field_icon02.svg) no-repeat;
}
#fieldArea ul li.fa-ico03 h2::before{
  background: url(./../img/top/field_icon03.svg) no-repeat;
}

.link-tri-win {
  width: 0;
  height: 0;
  margin: 0;
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 40;
  transition-duration: 0.5s; 
}

.link-tri-win::before {
  content: "";
  border-left: 40px solid transparent;
  border-bottom: 40px solid #5396bd;
  position: absolute;
  top: -40px;
  left: -40px;
}
.link-tri-win::after {
  content: "";
  border-left: 39px solid transparent;
  border-bottom: 39px solid #0868a0;
  position: absolute;
  top: -39px;
  left: -39px;
  transition: all .3s ease;
}
.link-tri-win img{
  width:14px;
  height: 14px;
  position: absolute;
  top:-20px;
  right: 4px;
  z-index: 100;
}
#fieldArea ul li .bdr-hover:hover .link-tri-win::before {
  border-bottom: 39px solid #fff;
}

@media screen and (max-width: 767px) {
  #fieldArea ul li{
    margin-bottom: 20px;
  }
  .ttlwrap{margin-bottom: 20px;padding-top: 20px;}
  #fieldArea ul li h2::before{
    width: 7vw;
    height: 7vw;
  }
  #fieldArea ul li h2{
    font-size: 22px;
  }
  #fieldArea ul li .wrap .bdr-hover .bdr-inner{
    padding-top: 7%;
  }
}
@media screen and (max-width: 575px) {
  #fieldArea ul li h2{
    font-size: 20px;
  }
}

#contactArea {
   background: url(./../img/common/bg_contact.jpg) no-repeat;
   background-size:cover;
  position: relative;
}
#contactArea{
    padding: 3% 0;
}
#contactArea .inner{
    position: relative;
  z-index: 10;
}
a.btn-waku {
  display: inline-block;
  width: 200px;
  text-align: center;
  color: #004ea2;
  background-color: #fff;
  border: 1px solid #0080cb;
  padding: .4em 1.2em .3em;
  background-size: 200% 100%;
  background-image: linear-gradient(to right, transparent 50%, #0080cb 50%);
  transition: background-position 0.3s cubic-bezier(0.19, 1, 0.22, 1) 0.1s, color 0.5s ease 0s, background-color 0.5s ease;
  font-weight: bold;
  letter-spacing: 3px; }

a.btn-waku:hover {
  color: white;
  background-color: #0080cb;
  background-position: -100% 100%; }

#contactArea a.btn-waku {
    width: 100%;
    font-size: 3.6rem;
    color:#0080cb;
    font-weight: normal;
    line-height: 0.8;
    padding: 1em 1.2em .9em;
  box-shadow: 0px 0px 17px 2px rgba(0,0,0,0.2);

}
#contactArea a.btn-waku span{
    font-size: 1.4rem;
}
#contactArea a.btn-waku:hover { color: white; }

#contactArea .line{
    content: "";
    width: 2px;
    height: 40px;
    position: absolute;
    top: -20px;
    left: 0;
    right: 0;
    margin: auto;
    background: #48aeea;
    z-index: 100;
}
#contactArea a.btn-waku:hover .line{
    background: white;
}


@media screen and (max-width: 767px) {
  #mvArea .mv-copy{
    padding-left: 0;
  }
  #contactArea a.btn-waku{
    font-size: 24px;
  }
  #contactArea{
    padding: 5% 0;
  }
}



/* =========================================================

下層　共通

========================================================= */

/*パンくず*/
.topicpath {
    width: 100%;
    max-width: 1800px;
    margin: 10px auto;
    padding: 0 20px 10px;
    position: relative;
    text-align: right;
    z-index: 5;
}
.topicpath ol li {
  display: inline;
  list-style-type: none;
  color: #777;
  font-size: 1.2rem;
}
.topicpath ol li:after {
  content: " > ";
}
.topicpath ol li:last-child:after {
  content: "";
}
.topicpath ol li a {
  text-decoration: underline;
}
.topicpath ol li a:hover {
    text-decoration: none;
    color: #5AC3F2;
}

@media (max-width: 767px) {
  .topicpath ol li a:hover {
    text-decoration: none;
  }
  .topicpath {
    padding: 0 10px 5px;}
    .topicpath ol li {
      font-size: 12px;
    }
}

.inner_u{
    width: 100%;
    max-width: 1420px;
    margin: auto;
}
.h2ttl-wrap_u{
    margin-bottom: 120px;
}
.h2ttl_u{
    font-size: 4rem;
    color: #5AC3F2;
    margin-bottom: .6em;
    line-height: 1.6;
}
.h2ttl_u-multi{
    font-size: 3.6rem;
}
.h2ttl-wrap_u p{
    font-size: 2rem;
    width: 80%;
    max-width: 1000px;
    margin: auto;
}
.txtblc-flex .img img{
    width: 100%;
    max-width: 100%;
}
.txtblc-flex{
    display: flex;
    justify-content: space-between;
    margin-bottom: 160px;
}
.txtblc-flex p{
    line-height: 2.4;
}
.txtblc-flex-l .txt{
    width: 60%;
    padding-right: 120px;
}
.txtblc-flex-l .img{
    margin-right: -190px;
    width: calc(40% + 190px);
}

.txtblc-flex-r .txt{
    width: 60%;
    padding-left: 120px;
}
.txtblc-flex-r .img{
    margin-left: -190px;
    width: calc(40% + 190px);
}
.clr-shadow{position: relative;}
.clr-shadow::after{
    content: "";
    position: absolute;
    width: calc(100% + 30px);
    height: 80%;
    bottom:-30px;
    right: 0;
    background: linear-gradient(90deg,#5FF4FF 0%, #AF76FC 100%);
    z-index: -1;
}
.clr-shadow-r::after{
    left: 0;
    right: inherit;
}

.h3ttl-bar{
    font-size: 3.2rem;
    position: relative;
    margin-bottom: 0.6em;
}
.h3ttl-bar::before{
    content: "";
    position: relative;
    top: 4px;
    left: 0;
    width: 6px;
    height: 1em;
    background: linear-gradient(0deg,#5FF4FF 0%, #AF76FC 100%);
    margin-right: 0.5em;
    display: inline-block;
}
.h4ttl{
    font-size: 1.8rem;
    margin-top: 1.5em;
}
.h4ttl-bar{
    font-size: 2.2rem;
    color: #59C3F2;
    position: relative;
    margin-top: 1.5em;
    margin-bottom: 1em;
}
.h4ttl-bar::before{
    content: "";
    position: absolute;
    bottom: -4px;
    left: 0;
    width: 3em;
    height: 2px;
    background: linear-gradient(90deg,#5FF4FF 0%, #AF76FC 100%);
}
.recruit_u .recruit__ttl,.recruit_u .recruit__ttl .h2ttl,.recruit_u .recruit__ttl .h2ttl__sub{
    text-align: center;
} 
.recruit_u .recruit__ttl .h2ttl__sub{
    padding-top: 1em;
    padding-bottom: .5em;
}

.bg-ptcl-01,.bg-ptcl-02,.bg-ptcl-03-human,.bg-ptcl-02-btm{
    position: relative;
}
.bg-ptcl-01::before{
    content: "";
    position: absolute;
    width: 145px;
    height: 266px;
    top:0;
    left: 10vw;
    background: url(./../img/common/bg-ptcl-01.svg) no-repeat;
    background-size: cover;
}
.bg-ptcl-02::before{
    content: "";
    position: absolute;
    width: 145px;
    height: 266px;
    top:0;
    right: 10vw;
    background: url(./../img/common/bg-ptcl-02.svg) no-repeat;
    background-size: cover;
}

.bg-ptcl-02-btm::after{
    content: "";
    position: absolute;
    width: 256px;
    height: 119px;
    bottom:0;
    right: 10vw;
    background: url(./../img/common/bg-ptcl-02-btm.svg) no-repeat;
    background-size: cover;
}
.bg-ptcl-03-human::before{
    content: "";
    position: absolute;
    width: 199px;
    height: 195px;
    bottom:5vw;
    right: 10vw;
    background: url(./../img/common/bg-ptcl-03.svg) no-repeat;
    background-size: cover;
}
#contents_u .section.bg-ptcl-02-btm{
    padding-bottom: 160px;
}

@media (max-width: 1800px) {
    .txtblc-flex-l .img{
        margin-left: auto;
        margin-right: -8%;
        width: 48%
    }
    .txtblc-flex-r .img{
        margin-left:-8%;
        width: 48%
    }
}
@media (max-width: 1440px) {
    .inner_u{
        padding: 0 5vw;
    }
    .txtblc-flex-l .txt{
        padding-right: 7vw;
    }
    .txtblc-flex-r .txt{
        padding-left: 7vw;
    }
    .txtblc-flex-l .img{
        margin-right: -5vw;
        width: calc(40% + 5vw);
    }
    .txtblc-flex-r .img{
        margin-left: -5vw;
        width: calc(40% + 5vw);
    }
    
    .bg-ptcl-01::before{
        width: 10vw;
        height: 18.4vw;
        top:0;
        left: 5vw;
    }
    .bg-ptcl-02::before{
        width: 10vw;
        height: 18.4vw;
        top:0;
        right: 5vw;
    }
    .bg-ptcl-02-btm::after{
        width: 15vw;
        height: 7vw;
        bottom:0;
        right: 5vw;
    }
    .bg-ptcl-03-human::before{
       width: 13.8vw;
        height: 13.5vw;
        bottom:8vw;
        right: 5vw;
    }
    
    
}
@media (max-width: 960px) {
    #contents_u .section{
        padding: 60px 0;
    }
    #contents_u .section.bg-ptcl-02-btm{
        padding-bottom: 100px;
    }
    .clr-shadow::after{
        width: calc(100% + 20px);
        bottom: -20px;
    }
    .clr-shadow::after {
        width: calc(100% + 20px);
        bottom: -20px;
    }
    .txtblc-flex{
        flex-direction: column;
        margin-bottom: 100px;
    }
    .txtblc-flex-l {
        flex-direction: column-reverse;
    }
    .txtblc-flex-clm {
        flex-direction: column;
    }
    .txtblc-flex .txt{
        margin-top: 60px;
    }
    .txtblc-flex-l .txt{
        width: 100%;
        padding-right: 0;
    }
    .txtblc-flex-r .txt{
        width: 100%;
        padding-left: 0;
    }
    .txtblc-flex-l .img,.txtblc-flex-r .img{
        width: 100%;
        max-width: 600px;
    }
    .h2ttl-wrap_u{
        margin-bottom: 60px;
    }
    .txtblc-flex-clm .txt{
        margin-top: 0;
    }
    .h3ttl-bar{
        font-size: 3.1rem;
    }
    .h2ttl_u{
        font-size: 3.2rem
    }
    .bg-ptcl-03-human{
        padding-bottom: 90px;
    }
    .bg-ptcl-03-human::before{
        bottom: -54px;
        background: url(./../img/common/bg-ptcl-03_sp.svg) no-repeat;
        width: 133px;
        height: 76px;
        background-size: cover;
    }
}
@media (max-width: 767px) {
    .bg-ptcl-01 .h2ttl-wrap_u,
    .bg-ptcl-02 .h2ttl-wrap_u{
        margin-top: 4em;
        
    }
    .txtblc-flex{
        margin-bottom: 60px;
    }
    .bg-ptcl-01::before{
        width: 103px;
        height: 85px;
        top:0;
        left: 5vw;
        background: url(./../img/common/bg-ptcl-01_sp.svg) no-repeat;
        background-size: cover;
    }
    .bg-ptcl-02::before{
        width: 126px;
        height: 64px;
        top:0;
        right: 7vw;
        background: url(./../img/common/bg-ptcl-02_sp.svg) no-repeat;
        background-size: cover;
    }
    .bg-ptcl-02-btm::after{
        width: 126px;
        height:72px;
        bottom:0;
        right: 7vw;
        background: url(./../img/common/bg-ptcl-02-btm_sp.svg) no-repeat;
        background-size: cover;
    }
    #contents_u .section{
        padding: 10vw 0;
    }
    #contents_u .section.bg-ptcl-02-btm{
        padding-bottom: 20vw;
    }
    #contents_u .section.recruit_u{
        padding: 14vw 0 10vw;        
    }
    .h3ttl-bar{
        font-size: 2.5rem;
    }
    .h2ttl-wrap_u{
        margin-top: 30px;
    }
    .bg-ptcl-no .h2ttl-wrap_u{
        margin-top: 0;
    }
    .h2ttl-wrap_u p{
        width: 100%;
    }
}
@media (max-width: 599px) {
    .h2ttl_u{
        font-size: 2.8rem;
    }
    .h2ttl_u-multi{
        font-size: 2.4rem;
        font-size: 2;
    }
    .h3ttl-bar{
        font-size: 2.2rem;
    }
    .h3ttl-bar::before{
        top:2.5px;
    }
    .h2ttl-wrap_u{
        margin-top: 12vw;
        margin-bottom: 10vw;
    }
    .h4ttl-bar{
        font-size: 2rem;
    }
    .h4ttl{
        font-size: 1.9rem;
    }
    .bg-ptcl-no .h2ttl-wrap_u{
        margin-top: 0;
    }
}
#contents_u img{
    width: 100%;
    height: auto;
}
/* =========================================================

下層MV

========================================================= */
#mvArea_u{
    width: 100%;
    max-width: 1800px;
    margin: auto;
    padding: 100px 0 0;
    position: relative;
    z-index: 2;
}
#mvArea_u .bg-mv{
    width: 80%;
    height: 620px;
    z-index: -100;
    margin-left: auto;    
}
#mvArea_u .mv-human{
    background: url(./../img/human-resource/mv.jpg) no-repeat center center;
    background-size: cover;
}
#mvArea_u .mv-work{
    background: url(./../img/workstyle/mv.jpg) no-repeat center center;
    background-size: cover;
}
#mvArea_u .mv-sra{
    background: url(./../img/sra/mv.jpg) no-repeat center center;
    background-size: cover;
}
#mvArea_u .mv-sra-feature{
    background: url(./../img/sra/mv-feature.jpg) no-repeat center center;
    background-size: cover;
}
#mvArea_u .mv-sra-philosophy{
    background: url(./../img/sra/mv-philosophy.jpg) no-repeat center center;
    background-size: cover;
}
#mvArea_u .mv-sra-company{
    background: url(./../img/sra/mv-company.jpg) no-repeat center center;
    background-size: cover;
}
#mvArea_u .mv-personnel{
    background: url(./../img/personnel/mv.jpg) no-repeat center center;
    background-size: cover;
}
#mvArea_u .mv-info{
    background: url(./../img/information/mv.jpg) no-repeat center center;
    background-size: cover;
}
#mvArea_u .mv-info-graduetes{
    background: url(./../img/information/mv-graduates.jpg) no-repeat center center;
    background-size: cover;
}
#mvArea_u .mv-info-career{
    background: url(./../img/information/mv-career.jpg) no-repeat center center;
    background-size: cover;
}
#mvArea_u .mv-info-disability{
    background: url(./../img/information/mv-disability.jpg) no-repeat center center;
    background-size: cover;
}
.mv-copy_u{
    position: absolute;
    top:90px;
    bottom: 0;
    left: 0;
    align-items: center;
    z-index: 10;
}
.mv-copy-bg{
    background: #5AC3F2;
    padding: 80px 100px 80px 90px;
    position: relative;
}
.mv-copy-bg::after{
    content: "";
    position: absolute;
    width: calc(100% + 20px);
    height: 100%;
    top:20px;
    left: 0;
    background: linear-gradient(90deg,#5FF4FF 0%, #AF76FC 100%);
    z-index: -1;
}
.mv-copy_u h1{
    color: white;
    font-size:4.8rem;
    line-height: 1.6;
}
.mv-copy_u .ff-en{
    font-size: 1.6rem;
    color: white;
}


@media (max-width: 1280px) {
    .mv-copy_u h1{
        font-size:4.0rem;
    }
    .mv-copy-bg{
        padding: 5vw 9vw 5vw 8vw;
    }
}
@media (max-width: 1140px) {
    #mvArea_u{
        padding-top: 70px;
    }
}
@media (max-width: 960px) {
    #mvArea_u .bg-mv{
        width: 90%;
        height: 500px;
    }
    .mv-copy-bg::after{
        top:15px;
        width: calc(100% + 15px);
    }
}

@media (max-width: 767px) {
    #mvArea_u .bg-mv{
        width: 100%;
        height: 46vw;
    }
    .mv-copy-bg {
        padding: 4vw 8vw 4vw 6vw;
    }
    #mvArea_u{
        margin-bottom: 9vw;
    }
    .mv-copy_u{
        top:inherit;
        bottom: -4vw;
    }
    .mv-copy-bg::after{
        top:10px;
        width: calc(100% + 10px);
    }
    .mv-copy_u h1{
        font-size: 3.6rem;
    }
    .mv-copy_u .ff-en{
        font-size: 1.4rem;
    }
}



@media (max-width: 599px) {
    #mvArea_u{
        margin-bottom: 11vw;
    }
    #mvArea_u .mv-human{ background: url(./../img/human-resource/mv-sp.jpg) no-repeat center center; }
    #mvArea_u .mv-work{ background: url(./../img/workstyle/mv-sp.jpg) no-repeat center center; }
    #mvArea_u .mv-sra{ background: url(./../img/sra/mv-sp.jpg) no-repeat center center; }
    #mvArea_u .mv-sra-feature{ background: url(./../img/sra/mv-feature-sp.jpg) no-repeat center center; }
    #mvArea_u .mv-sra-philosophy{ background: url(./../img/sra/mv-philosophy-sp.jpg) no-repeat center center; }
    #mvArea_u .mv-sra-company{ background: url(./../img/sra/mv-company-sp.jpg) no-repeat center center; }
    #mvArea_u .mv-personnel{ background: url(./../img/personnel/mv-sp.jpg) no-repeat center center; }
    #mvArea_u .mv-info{ background: url(./../img/information/mv-sp.jpg) no-repeat center center; }
    #mvArea_u .mv-info-graduetes{ background: url(./../img/information/mv-graduates-sp.jpg) no-repeat center center; }
    #mvArea_u .mv-info-career{ background: url(./../img/information/mv-career-sp.jpg) no-repeat center center; }
    #mvArea_u .mv-info-disability{ background: url(./../img/information/mv-disability-sp.jpg) no-repeat center center; }
    #mvArea_u .bg-mv{
        height: 67vw;
        background-size: cover;
    }
    .mv-copy_u h1{
        font-size: 2.8rem;
    }
   .mv-copy_u .ff-en{
       font-size: 1.2rem;
    }
}

.tableArea a{
  text-decoration: underline;
  transition: all 0.2s ease;
}
.tableArea a:hover{
  text-decoration: none;
  opacity: .6;
}
.tableArea,.tableArea2 {
  width: 100%;
  margin: 20px auto; }
#topics .tableArea{
    margin: 40px auto;
}
.tableArea table ,.tableArea2 table {
  width: 100%;
  table-layout: fixed; }
.tableArea table tr th {
  border-top: ##dbdbdb solid 1px;
  border-bottom: #dbdbdb solid 1px;
  font-weight: bold;
  padding: 24px 0;
  word-break: break-all;
  line-height: 1.6;
  text-align: left;
  width: 22%;
}
.tableArea.thW table tr th {
  width: 30%;
}
.tableArea table tr td {
  border-top: #dbdbdb solid 1px;
  border-bottom: #dbdbdb solid 1px;
  padding: 24px;
  text-align: left;
  word-break: break-all;
  width: 78%;
  line-height: 1.8;
}
.tableArea table tr:first-child th,.tableArea table tr:first-child td {
    border-top: none;    
}
#topics .tableArea table tr:first-child th,#topics .tableArea table tr:first-child td,.table_1st_bdrtop table tr:first-child th,.table_1st_bdrtop table tr:first-child td{
    border-top: #dbdbdb solid 1px;   
}
.tableArea.thW table tr td {
  width: 70%;
}

.tableArea table tr td p {
margin-top: 0;
line-height: 1.8; }
#topics .tableArea table tr td a{
    color: #111;
}

.tableArea2{
  padding: 20px 40px; 
  background: #fff;
}
.tableArea2 table {
}
.tableArea2 table tr th {
  border-bottom: #ddd solid 1px;
  padding: 16px 0;
  font-weight: bold;
  word-break: break-all;
  line-height: 1.6;
  text-align: left;
}
.tableArea2 table tr td {
  border-bottom: #ddd solid 1px;
  padding: 24px;
  text-align: left;
  word-break: break-all;
  line-height: 1.8; 
}
.tableArea2 table tr:last-child td,.tableArea2 table tr:last-child th{
  border-bottom: none;
}
.note_mt{
    margin-top: 2em;
}

@media (max-width: 767px) {
    .tableArea {
        width: 100%;
        margin-top: 10px;
        margin-bottom: 0;
    }
     .tableArea table tr:first-child th{
         border-top: #dbdbdb solid 1px;
         padding-top: 15px;
      }
    .tableArea table tr th{
      width: 100%!important;
      display: block;
      padding: 10px 0;
      border-bottom: none;
    }
    .tableArea table tr td {
      width: 100%!important;
      display: block;
      padding: 0 0 20px;
      border-top: none;
    }
    .tableArea table tr td {
      margin-bottom: 10px;
    }
    /*.tableArea table tr th {
      border-bottom: #bdcdd6 solid 1px;
    }*/
      #topics .tableArea{
          margin-top: 10px;
      }
    #topics .tableArea table tr th{
        border-bottom: none;
        padding-bottom: 0;
        padding-top: 0;
    }
    #topics .tableArea table tr:first-child th{
      border-bottom:none;
        padding-bottom: 0;
        padding-top: 15px;
    }
    #topics .tableArea table tr:first-child td {
        border-top:none; 
       border-bottom:#dbdbdb solid 1px;
        padding-bottom: 20px;
    }
    #topics .tableArea table tr td {
        border-bottom:#dbdbdb solid 1px;
        padding-bottom: 20px;
    }
      
    .table_1st_bdrtop table tr:first-child th{
      margin-top: 10px;
    }
    .table_1st_bdrtop table tr:first-child td {
        border-top:none; 
    }
    .tableArea2{
      padding: 5px 20px
    }
    .tableArea2 table tr th {
      width: 40%;
    }
    .tableArea2 table tr td{
      width: 60%;
      padding: 18px 0 18px 10px;
    }
      .note_mt{
        margin-top: 1em;
      }

}
/* =========================================================

働く環境

========================================================= */
.subttl-en{
    font-size: 2.2rem;
}
    
.employee-list-bg{
      position: relative;  
}
.employee-list-bg::after{
    content: "";
    position: absolute;
    background: url(./../img/top/bg-ring.svg) no-repeat;
    width: 650px;
    height: 650px;
    background-size: cover;
    top:-5vw;
    right: -16vw;
    z-index: 0;
}
.employee-list{
    width: 100%;
    max-width: 1000px;
    margin: 30px auto;
    display: flex;
    flex-wrap: wrap;
    position: relative;
    justify-content: space-between;
    z-index: 1;
}

.employee-list > div{
    width: 48%;
    border: solid 1px #5AC3F2;
    padding: 20px 30px;
    margin: 15px 0;
    background: white;
}
.employee-list h4{
    font-size: 2.4rem;
    color: #5AC3F2;
    margin-bottom: .5em;
    text-align: center;
}
#numbers .h2ttl-wrap_u{
    margin-bottom: 50px!important;
}
.numbers-list{
    display: flex;
    justify-content: space-between;
    margin-bottom: 30px;
    flex-wrap: wrap;
}
.numbers-list > div{
    width: 23%;
    padding: 20px;
    margin-bottom: 30px;
}
.numbers-list-01 > div{ border: solid 1px #5AC3F2;}
.numbers-list-02 > div{ border: solid 1px #A5C8FE;}
.numbers-list-03 > div{ border: solid 1px #94A1FD;}
.numbers-list-04 > div{ border: solid 1px #A18DFD;}
.numbers-list-05 > div{ border: solid 1px #AE77FC;}
.numbers-list .blc-01{
    border-bottom: 2px solid red;
    border-image: linear-gradient(90deg,#AF76FC 0%, #5FF4FF 100%) 1;
    text-align: center;
}
.numbers-list .blc-01 .txt-num{
    font-weight: bold;
    font-size: 2rem;
    color:#5AC3F2;
    line-height: 1.4;
    padding-bottom: 10px;
}
.numbers-list .blc-01 .txt-num.ff-ja{
    padding-bottom: 2.5rem;
}
.numbers-list .blc-01 .txt-num span{
    font-size: 4rem;
}
.numbers-list .blc-01 .txt-num.ff-ja span{
    font-size: 3rem;
}
.numbers-list .blc-02 .img{
    width: 90%;
    max-width: 205px;
    text-align: center;
    margin: 15px auto;
}

@media (max-width: 1200px) {
    .numbers-list > div{
        width: 48.3%;
    }
}
@media (max-width: 767px) {
    .employee-list-bg::after{
        width: 100vw;
        height: 100vw;
        right: -40vw;
        top:-10vw;
    }
    .employee-list{
        margin-top: 50px;
        flex-direction: column;
    }
    .employee-list > div{
        width: 100%;
        margin: 2vw 0;
    }
    .numbers-list .blc-01 .txt-num{
        font-size: 1.7rem;
    }
   .numbers-list .blc-01 .txt-num span{
        font-size: 3.5rem;
    }
    .numbers-list .blc-01 .txt-num.ff-ja span{
        font-size: 2.8rem;
    }
    .numbers-list .blc-02 .img{
        max-width: 170px;
    }
}
@media (max-width: 599px) {
    .numbers-list > div{
        width: 49%;
        margin-bottom: 2%;
        padding: 3vw;
    }
    .numbers-list .blc-01 .txt-num{
        font-size:3.5vw;
    }
   .numbers-list .blc-01 .txt-num span{
        font-size: 6vw;
    }
    .numbers-list .blc-01 .txt-num.ff-ja span{
        font-size: 4.5vw;
    }
}
/* =========================================================

人材について

========================================================= */

#careerpath .h2ttl-wrap_u{
    margin-bottom: 40px;
}
.img-careerpath img{
    width: 100%;
    max-width: 960px;
    height: auto;
    margin: auto;
}
.blc-step{
    margin-bottom: 5rem;
}
.blc-step h4{
    font-size: 2.6rem;
    margin-bottom: .5em;
}
.blc-step h4 span{
    font-size: 1.8rem;
    
}
.blc-step h4 span.step-num{
    font-size: 2.6rem;
    color: #5AC3F2;
    margin-right: .8em;
}
.entry-btn_u {
    margin: 0;
    position: absolute;
    bottom: 20px;
    left: 20px;
    z-index: 40;
    transition-duration: 0.5s; 
    background: white;
    transition: all .3s ease;
}
.entry-btn_u.entry-btn-wh{
    width: calc(100% - 40px);
}
.recruit_u .arrow-btn__link{
    border: none;
}
.recruit_u a.recruit-detail-link:hover .arrow-btn__link,.recruit_u .arrow-btn__link:hover {
    color: #fff;
    background: #5AC3F2;
    text-decoration: none;
}
.recruit_u a.recruit-detail-link:hover .arrow-btn__link::after {
    right: 3px;
}
.recruit_u a.recruit-detail-link:hover .arrow-btn__link::after {
    background-position: 100% 50%;
    background-size: auto 100%;
    background-repeat: no-repeat;
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2016%207.9%22%20style%3D%22enable-background%3Anew%200%200%2016%207.9%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23FFFFFF%3B%7D%3C%2Fstyle%3E%3Cpolygon%20class%3D%22st0%22%20points%3D%2215.8%2C4.7%208.5%2C0%208.5%2C3.3%200%2C3.3%200%2C4.7%208.5%2C4.7%208.5%2C4.7%20%22%2F%3E%3C%2Fsvg%3E')
}
.img-curriculum{
    margin-top: 40px;
    margin-bottom: 80px;
}
.img-curriculum img.sp-only{
    max-width: 400px;
    margin: auto;
}
@media (max-width: 960px) {
    .img-curriculum{
        margin-top: 20px;
        margin-bottom: 40px;
    }
}
@media (max-width: 767px) {
    .img-curriculum{
        margin-bottom: 20px;
    }
}
@media (max-width: 599px) {
    .entry-btn_u.entry-btn-wh{
        width: calc(100% - 20px);
    }
    .entry-btn_u{
        bottom: 10px;
        left: 10px;
    }
}
/* =========================================================

SRAを知る

========================================================= */
.img-map{
    margin-top: 40px;
}
.since1967{
    font-size: 2.6rem;
}
#comapnydata{
    margin-bottom: 160px;
}
.map{
    margin: 30px auto 20px;
}
@media (max-width: 599px) {
    .img-map{
        margin-top: 20px;
    }
    .since1967{
        font-size: 1.8rem;
    }
}
/* =========================================================

社長メッセージ

========================================================= */
#message .h2ttl-wrap_u{
    margin-bottom: 80px;
}
.bg-msg-circle::after{
    content: "";
    position: absolute;
    bottom: 4vw;
    right: -10vw;
    width: 30vw;
    height: 30vw;
    background: url(./../img/top/bg-circle.svg) no-repeat;
    z-index: 0;
    background-size: cover;
}
.txtblc-flex-msg{
    display: flex;
    margin: 100px auto 60px;
    position: relative;
    z-index: 1;
}
.txtblc-flex-msg .txt{
    width:calc(100% - 500px);
    padding-right: 100px;
}
.txtblc-flex-msg .img{
    width: 500px;
}
.h3ttl-msg{
    font-size: 4rem;
    color: #59C3F2;
    line-height: 1.4;
    margin-bottom: .8em;
}
.president-name{
    margin-top: 20px;
    position: relative;
    padding-left: 15px;
    line-height: 1.6;
}
.president-name::before{
    content: "";
    position: absolute;
    top: 6px;
    left: 0;
    width: 6px;
    height: 3.7em;
    background: linear-gradient(0deg,#5FF4FF 0%, #AF76FC 100%);
    margin-right: 1em;
    display: inline-block;
}
.president-name .name{
    font-weight: bold;
    font-size: 2.8rem;
}
@media (max-width: 1400px) {
    .bg-msg-circle::after{
        width: 400px;
        height: 400px;
    }
    .txtblc-flex-msg .txt{
        width:64%;
        padding-right: 7%;
    }
    .txtblc-flex-msg .img{
        width: 36%;
    }
    .txtblc-flex-msg{
        margin-bottom: 0;
    }
}
@media (max-width: 1140px) {
    .bg-msg-circle::after{
        width: 350px;
        height: 350px;
        bottom:16vw;
    }
    #message .h2ttl-wrap_u{
        margin-bottom: 50px;
    }
}
@media (max-width: 960px){ 
    #message .h2ttl-wrap_u{
        margin-bottom: 40px;
    }
}
@media (max-width: 767px){ 
    .txtblc-flex-msg{
        flex-direction: column;
        margin-top: 10vw;
    }
    .txtblc-flex-msg .txt{
        width:100%;
        padding-right: 0;
    }
    .txtblc-flex-msg .img{
        width: 100%;
        margin: 5vw auto;
        padding: 0 20vw;
    }
    .txtblc-flex-msg .img img{

    }
    .bg-msg-circle::after{
        width: 50vw;
        height: 50vw;
        right: -15vw;
        bottom:0;
    }
}
@media (max-width: 599px){ 
    #message .h2ttl-wrap_u{
        margin-bottom: 10vw;
    }

    .txtblc-flex-msg .img{
        padding: 0 10vw;
    }
     .bg-msg-circle::after{
        width: 70vw;
        height: 70vw;
        right: -28vw;
        bottom:0;
    }
}
/* =========================================================

採用情報

========================================================= */
#recruit-info .inner_u{
    max-width: 1200px;
}
#saiyodata,#saiyodata-career{
    padding-bottom: 60px;
}
#saiyostep{
    padding-bottom: 60px;
}
.flow-img{
    margin: 30px auto;
}

@media (max-width: 767px){
    #saiyodata{
        padding-bottom: 0;
    }
    #saiyodata-career{
        padding-bottom: 40px;
    }
    #saiyostep{
        padding-bottom: 0;
    }
    .flow-img img{
        width: 80vw;
        max-width: 360px;
        margin: auto;
    }
}
@media (max-width: 599px){
    .flow-img img{
        width: 70vw;
        max-width: 300px;
    }

}
/* =========================================================
IE,EDGE
========================================================= */
/* IE */
@media screen and (min-width: 0\0) and (min-resolution: 0.001dpcm) {
  .anim {
    opacity: 1; }

  .anim1 {
    opacity: 1; }

  .anim2 {
    opacity: 1; }

  .anim3 {
    opacity: 1; }

  .anim02 {
    opacity: 1; }

  .anim03 {
    opacity: 1; }

  .anim04 {
    opacity: 1; } }
@media all and (-ms-high-contrast: none) {
  .btn {
    padding-top: 15px; }

  .btn a::after {
    top: -3px; }

  .btn-waku {
    padding-top: 15px; }

  .btn-waku a::after {
    top: -2px; } }


