@charset "UTF-8";

/* Reset */

/* CSS Remedy */
*,
::after,
::before {
  box-sizing: border-box;
}
html {
  line-sizing: normal;
}
body {
  margin: 0;
}
img {
  border-style: none;
}
[type="checkbox"],
[type="radio"] {
  box-sizing: border-box;
  padding: 0;
}

/* wp reset */
#primary {
  float: none;
  padding: 0;
  width: 100%;
}
#primary article.hentry {
  background: none;
  box-shadow: none;
  padding: 0;
}
.page-content,
.entry-content,
.entry-summary {
  margin: 0;
}
.veu_socialSet {
  margin-bottom: 0;
}
.veu_socialSet-position-after {
  margin-top: 0;
}
.veu_contentAddSection {
  display: block;
  clear: both;
  overflow: hidden;
  margin-top: 0;
  margin-bottom: 0;
}
button,
a.button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
  padding: 0;
}
.entry-header {
  height: auto;
  margin: 0 0 50px;
}
footer.entry-footer {
  display: none;
}
.comments-area {
  display: none;
}
.post-navigation {
  display: none;
}
.information-detail-wrap .entry-header {
  display: inline-block;
}
.header_none {
  display: none;
}

/* ------ */

img {
  max-width: 100%;
  height: auto;
}
ul,
li {
  list-style: none;
  margin: 0;
  padding: 0;
}
dl,
dt,
dd {
  margin: 0;
  padding: 0;
}
p {
  color: #333;
}
a,
a:focus {
  text-decoration: none;
  color: #444;
  transition: all 0.4s;
}
a img {
  border-style: none;
}
a:hover {
  opacity: 0.7;
  cursor: pointer;
}
html {
  overflow-x: hidden;
  line-height: 1.6;
  color: #444;
  font-size: 62.5%;
}
body {
  background: url("../images/common/bg_img.webp");
  background-size: 600px auto;
  margin: 0;
  padding: 0;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 1.6rem;
}
p {
  margin: 0;
}

.enTxt {
  font-family: "Alata", sans-serif;
}
.mincyo {
  font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

.alnL {
  text-align: left;
}
.alnR {
  text-align: right;
}
.alnC {
  text-align: center;
}
.relative {
  position: relative;
}
.attentionTxt {
  margin-left: 1em;
  text-indent: -1em;
}
.clear {
  clear: both;
  padding: 0;
}
.clearfix:after {
  content: "";
  clear: both;
  display: block;
}
.inner {
  margin: 0 auto;
  padding: 0 10px;
}
.wrapper {
  overflow: hidden;
}
.pcBlank {
  display: none;
}
.spBlank {
  display: block;
}

@media screen and (max-width: 1024px) {
  .inner {
    margin: 0 auto;
    padding: 0 20px;
  }
}

@media screen and (max-width: 768px) {
  .pcBlank {
    display: block;
  }
  .spBlank {
    display: none;
  }
  .inner {
    margin: 0 auto;
    padding: 0 15px;
  }
}

/* ==========================================================================
   Font size
   ========================================================================== */
* {
  --viewport-unit-converter: 1vw;
  --fz-from: var(--font-size-from, var(--min-font-size));
  --fz-to: var(--font-size-to, var(--max-font-size));
  --fz-slope: (var(--fz-to) - var(--fz-from)) / (var(--viewport-to) - var(--viewport-from)) * 100;
  --fz-intercept: (var(--viewport-to) * var(--fz-from) - var(--viewport-from) * var(--fz-to)) / (var(--viewport-to) - var(--viewport-from));
  --font-size: calc(var(--fz-slope) * var(--viewport-unit-converter) + var(--fz-intercept) * 1px);

  --min-fz-px: calc(var(--min-font-size) * 1px);
  --max-fz-px: calc(var(--max-font-size) * 1px);
  --clamp: clamp(var(--min-fz-px), var(--font-size), var(--max-fz-px));
  --max: var(--has-max, var(--min));
  --min: var(--has-min, var(--font-size));
  --has-max: min(var(--max-fz-px), var(--font-size));
  --has-min: max(var(--min-fz-px), var(--font-size));

  font-size: var(--clamp, var(--max));
}

/* ==========================================================================
   Header
   ========================================================================== */
.header-wrap {
  display: flex;
  justify-content: flex-end;
  width: 100%;
}
#header-block {
  position: fixed;
  width: 100%;
  z-index: 3;
}
.change-color {
  background-color: rgba(255, 255, 255, 0.8);
}
.header-inner {
  display: flex;
  justify-content: flex-end;
  padding: 0;
  margin: 0 auto;
  /* max-width: 1200px; */
  width: 100%;
  position: relative;
}
.headerTop {
  margin: 40px auto 0 30px;
  display: flex;
}
.headerTop h1 {
  margin: 8px 0 0 20px;
}
.headerTop img {
  z-index: 99;
}

@media screen and (max-width: 768px) {
  .headerTop {
    margin: 30px auto 0 30px;
  }
  .headerTop h1 {
    margin: 0 0 0 16px;
    z-index: 99;
  }
  .headerTop h1 img {
    height: auto;
    width: 140px;
  }
  .headerIcon {
    height: auto;
    width: 20px;
  }
}
@media screen and (max-width: 480px) {
  .headerTop {
    margin: 30px auto 0 20px;
  }
}

/* ==========================================================================
   Common
   ========================================================================== */

.mainTitleWrap {
  background-color: #efbf31;
  width: 100%;
  display: flex;
  justify-content: center;
}
.mainTitleCenter {
  max-width: 1200px;
  padding: 120px 0 20px;
  width: 1200px;
}
.mainTitleCenter .top-sub-title {
  color: #fff;
  font-family: "Alata", sans-serif;
  font-size: 12rem;
  line-height: 1em;
  margin: 0;
}
.mainTitleSpace {
  flex: 1;
  min-width: 50px;
}
#wholeContents {
  display: flex;
  justify-content: center;
  width: 100%;
}
.wholeContentsLeft {
  flex: 1;
  min-width: 50px;
}
.wholeContentsCenter {
  max-width: 1200px;
}
.wholeContentsRight {
  background-color: #efbf31;
  flex: 1;
  min-width: 50px;
}
.wholeContentsCenter section {
  padding: 50px 100px 0;
}
.wholeContentsCenter section h1 {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 3rem;
  margin: 0;
}
.subTitleCaption {
  font-family: "Alata", sans-serif;
  font-size: 1.2rem;
  margin: 10px 0 60px;
}
.subNotes {
  font-size: 1.6rem;
  line-height: 2em;
}
.contentsLeftBox {
  background-color: #efbf31;
  height: 160px;
  width: 100%;
}
.contentsRightBox {
  background: url("../images/common/bg_img.webp");
  background-size: 600px auto;
  height: 500px;
  width: 100%;
}

@media screen and (max-width: 1024px) {
  .mainTitleCenter .top-sub-title {
    font-size: 10rem;
  }
  .wholeContentsCenter section {
    padding: 50px;
  }
  .wholeContentsCenter section h1 {
    font-size: 3.2rem;
  }
}

@media screen and (max-width: 768px) {
  .mainTitleCenter {
    max-width: 1200px;
    padding: 100px 0 20px;
    width: 1200px;
  }
  .mainTitleCenter .top-sub-title {
    font-size: 6.2rem;
  }
  .mainTitleSpace {
    min-width: 20px;
  }
  .wholeContentsLeft {
    min-width: 20px;
  }
  .wholeContentsRight {
    min-width: 20px;
  }
  .wholeContentsCenter section {
    padding: 30px 40px;
  }
  .wholeContentsCenter section h1 {
    font-size: 2.6rem;
  }
  .subTitleCaption {
    margin: 10px 0 40px;
  }
  .subNotes {
    font-size: 1.4rem;
  }
  .contentsLeftBox {
    height: 120px;
  }
  .contentsRightBox {
    height: 300px;
  }
}

@media screen and (max-width: 480px) {
  .mainTitleCenter .top-sub-title {
    font-size: 5rem;
  }
  .mainTitleSpace {
    min-width: 10px;
  }
  .wholeContentsLeft {
    min-width: 10px;
  }
  .wholeContentsRight {
    min-width: 10px;
  }
  .wholeContentsCenter section {
    padding: 30px 10px 20px;
  }
  .wholeContentsCenter section h1 {
    font-size: 2.4rem;
    width: 100%;
  }
  .subTitleCaption {
    margin: 10px 0 30px;
  }
}

/* ==========================================================================
   Sub Header
   ========================================================================== */
.sub-header {
  margin: 0 auto;
  max-width: 1200px;
  padding: 160px 20px 0;
  text-align: center;
  position: relative;
}
.sub-header h1 {
  color: #1d2547;
  font-size: 4rem;
}
.sub-header .titleCaption {
  color: #1d2547;
  font-family: "Alata", sans-serif;
  font-size: 1.6rem;
  margin: 0 0 70px;
}
.sub-header span.page-title {
  color: #1d2547;
  display: inline-block;
  font-family: "Alata", sans-serif;
  font-size: 13rem;
  font-weight: bold;
  list-style: 1em;
  opacity: 0.1;
  position: absolute;
  top: 90px;
  left: 10px;
  text-align: left;
  width: 100%;
}

/* mail */
.icon-contact {
  border: 1px solid #fff;
  background-color: #efbf31;
  border-radius: 50%;
  height: 42px;
  width: 42px;
  text-align: center;
  margin: 0 24px;
  position: absolute;
  top: 170px;
  right: 18px;
  transition: all 0.4s;
}
.icon-contact a {
  display: block;
  padding: 7px;
}
/*フッターまでスクロールしたら消す*/
.is-hidden {
  visibility: hidden;
  opacity: 0;
}

@media screen and (max-width: 768px) {
  .sub-header {
    padding: 80px 20px 0;
  }
  .sub-header h1 {
    font-size: 2rem;
  }
  .sub-header .titleCaption {
    font-size: 1.4rem;
    margin: 0 0 40px;
  }
  .sub-header span.page-title {
    font-size: 6rem;
    top: 45px;
    left: 10px;
  }

  .icon-contact {
    height: 34px;
    width: 34px;
    margin: 0 24px;
    top: 100px;
    right: 4px;
  }
  .icon-contact a {
    padding: 0;
  }
  .icon-contact img {
    height: auto;
    width: 14px;
    margin: 11px 0 0;
  }
}

/* ==========================================================================
   Navigation 外観
   ========================================================================== */
.globalnavcontainer {
  display: flex;
  justify-content: space-between;
}
.navImgWrap {
  background: url(../images/common/bg_nav.jpg) no-repeat;
  background-size: cover;
  border-bottom-right-radius: 50px;
  height: 100vh;
  width: 44%;
}
.inner-nav-wrap {
  padding: 100px 50px;
  width: 50%;
}
.inner-nav-wrap ul li a {
  display: flex;
  align-items: center;
}
.inner-nav-no {
  color: #333;
  font-family: "Alata", sans-serif;
  font-size: 8rem;
  line-height: 1em;
  position: relative;
  margin: 0;
  width: 30%;
}
.inner-nav-no span {
  color: #999;
  font-size: 1.6rem;
  position: absolute;
  left: 20px;
}
.inner-nav-title {
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 3rem;
  font-weight: bold;
}
.smallNav {
  margin: 50px 0;
}
.smallNav p {
  color: #fff;
  font-size: 1.6rem;
  line-height: 2.4em;
}
.smallNav p a {
  border-bottom: 2px dotted #505050;
}
.smallNav p a:hover {
  border-bottom: 2px dotted #b4b4b4;
}

@media screen and (max-width: 1024px) {
  .navImgWrap {
    width: 34%;
  }
  .inner-nav-wrap {
    padding: 100px 50px 100px 0;
    width: 60%;
  }
  .inner-nav-no {
    font-size: 6rem;
    width: 26%;
  }
  .inner-nav-title {
    font-size: 2.6rem;
  }
}

@media screen and (max-width: 768px) {
  .navImgWrap {
    display: none;
  }
  .inner-nav-wrap {
    padding: 120px 30px 80px;
    width: 100%;
  }
  .inner-nav-no {
    font-size: 5rem;

    width: 24%;
  }
  .inner-nav-no span {
    font-size: 1.2rem;
  }
  .inner-nav-title {
    font-size: 2.2rem;
  }
  .smallNav {
    margin: 50px 0;
  }
  .smallNav p {
    font-size: 1.4rem;
  }
}

/* ==========================================================================
   Navigation
   ========================================================================== */

header {
  height: 54px;
  position: relative;
  width: 100%;
}
header h1 {
  margin: 0;
  position: relative;
  width: 100%;
  z-index: 99;
}
header h1 img {
  height: auto;
  width: 100%;
}
.navBg {
  border-bottom: none;
  padding: 0;
}
.nav-button-wrap {
  background-color: #fff;
  display: block;
  position: absolute;
  right: 20px;
  top: 30px;
  z-index: 1000;
  cursor: pointer;
  padding: 30px;
  height: 85px;
  border-radius: 50%;
  width: 85px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .nav-button-wrap {
    background-color: #fff;
    display: block;
    position: absolute;
    right: 20px;
    top: 30px;
    z-index: 1000;
    cursor: pointer;
    padding: 25px;
    height: 50px;
    border-radius: 50%;
    width: 50px;
    text-align: center;
  }
}
.globalnav {
  display: none;
}
.globalnav .close {
  display: none;
}
nav.globalnav-wrap .globalnav ul li.dropdown-btn {
  border-left: none;
  padding: 0 0 30px;
  text-align: left;
  width: 100%;
}
.globalnav .dropdown-btn:first-child {
  border-top: none;
}
p.navGakkaName {
  background: #147ec3;
  border: none;
  border-bottom: none;
  color: #fff;
  font-size: 83%;
  padding: 5px 0;
}
.globalnav .dropdown {
  font-weight: normal;
  visibility: visible;
  opacity: 1;
  box-shadow: none;
  padding: 0;
  margin: 15px 0 0;
}
.globalnav ul {
  color: #fff;
  display: inline;
  padding: 20px 0;
}
.globalnav .dropdown li {
  margin: 0;
  padding: 0;
  font-size: 500%;
}
.globalnav .dropdown li a {
  color: #fff;
}
nav a {
  color: #fff;
}
nav a:visited {
  color: #fff;
}
nav a:active {
  color: #fff;
}
.globalnav .dropdown li:first-child {
  border-top: 1px solid #004ea2;
}
.globalnav .dropdown li:last-child {
  border-bottom: none;
}
.globalnav-wrap.open .globalnav li .dropdown li {
  font-size: 83%;
}
.globalnav-wrap.open .globalnav {
  display: block;
  padding: 0;
  position: fixed;
  left: 0;
  top: 0;
  background-color: rgba(34, 34, 34, 1);
  width: 100%;
  height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  z-index: 98;
}
.globalnav-wrap.open .globalnav li {
  font-size: 1.6rem;
  display: block;
  margin: 0;
  padding: 10px 0 20px;
}
.globalnav-wrap.open .globalnav li img {
  vertical-align: bottom;
}
.globalnav-wrap.open .globalnav li:hover {
  background: transparent;
}
.globalnav-wrap.open .globalnav li a {
  padding: 0;
}
.globalnav-wrap.open .globalnav .dropdown {
  border-top: 1px solid #fff;
  display: block;
  position: static;
  background: transparent;
}
.globalnav li.dropdown-btn .dropdown ul.navGakka li a {
  padding: 0 0 0 20px;
}
/* .nav-button {border: 1px solid #333333;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
} */
.nav-button,
.nav-button span {
  display: inline-block;
  transition: all 0.3s;
}
.nav-button {
  z-index: 20;
  width: 24px;
  height: 22px;
  position: relative;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.nav-button span {
  border-radius: 50%;
  position: absolute;
  left: 0;
  background-color: #222;
  transform: rotate(0.05deg);
}
.nav-button span:nth-of-type(1) {
  width: 3px;
  height: 3px;
  top: 2px;
}
.nav-button span:nth-of-type(2) {
  width: 3px;
  height: 3px;
  top: 12px;
}
.nav-button span:nth-of-type(3) {
  width: 3px;
  height: 3px;
  bottom: -3px;
}
.nav-button span:nth-of-type(4) {
  width: 3px;
  height: 3px;
  top: 2px;
  left: 11px;
}
.nav-button span:nth-of-type(5) {
  width: 3px;
  height: 3px;
  top: 12px;
  left: 11px;
}
.nav-button span:nth-of-type(6) {
  width: 3px;
  height: 3px;
  bottom: -3px;
  left: 11px;
}
.nav-button span:nth-of-type(7) {
  width: 3px;
  height: 3px;
  top: 2px;
  left: auto;
  right: 0;
}
.nav-button span:nth-of-type(8) {
  width: 3px;
  height: 3px;
  top: 12px;
  left: auto;
  right: 0;
}
.nav-button span:nth-of-type(9) {
  width: 3px;
  height: 3px;
  bottom: -3px;
  left: auto;
  right: 0;
}

.active .nav-button span:nth-of-type(1) {
  width: 100%;
  height: 1px;
  background-color: #000;
  transform: translateX(1px) translateY(10px) rotate(-45deg);
}
.active .nav-button span:nth-of-type(2) {
  opacity: 0;
}
.active .nav-button span:nth-of-type(3) {
  width: 100%;
  height: 1px;
  background-color: #000;
  transform: translateX(1px) translateY(-12px) rotate(45deg);
}
.active .nav-button span:nth-of-type(4) {
  opacity: 0;
}
.active .nav-button span:nth-of-type(5) {
  opacity: 0;
}
.active .nav-button span:nth-of-type(6) {
  opacity: 0;
}
.active .nav-button span:nth-of-type(7) {
  opacity: 0;
}
.active .nav-button span:nth-of-type(8) {
  opacity: 0;
}
.active .nav-button span:nth-of-type(9) {
  opacity: 0;
}

@media screen and (max-width: 768px) {
  .nav-button {
    z-index: 20;
    width: 2px;
    height: 2px;
    position: relative;
  }
  .nav-button span {
    position: absolute;
    left: 0;
    background-color: #000;
  }
  .nav-button span:nth-of-type(1) {
    width: 2px;
    height: 2px;
    top: 0;
  }
  .nav-button span:nth-of-type(2) {
    width: 2px;
    height: 2px;
    top: -8px;
    left: -8px;
  }
  .nav-button span:nth-of-type(3) {
    width: 2px;
    height: 2px;
    bottom: -8px;
    left: -8px;
  }
  .nav-button span:nth-of-type(4) {
    width: 2px;
    height: 2px;
    top: -8px;
    left: 0;
  }
  .nav-button span:nth-of-type(5) {
    width: 2px;
    height: 2px;
    top: 0;
    left: -8px;
  }
  .nav-button span:nth-of-type(6) {
    width: 2px;
    height: 2px;
    bottom: 0;
    left: 8px;
  }
  .nav-button span:nth-of-type(7) {
    width: 2px;
    height: 2px;
    top: -8px;
    left: auto;
    right: -8px;
  }
  .nav-button span:nth-of-type(8) {
    width: 2px;
    height: 2px;
    top: 8px;
    left: auto;
    right: 0;
  }
  .nav-button span:nth-of-type(9) {
    width: 2px;
    height: 2px;
    bottom: -8px;
    left: auto;
    right: -8px;
  }

  .active .nav-button span:nth-of-type(1) {
    width: 18px;
    height: 1px;
    background-color: #000;
    transform: translateX(-8px) translateY(0px) rotate(-45deg);
  }
  .active .nav-button span:nth-of-type(2) {
    opacity: 0;
  }
  .active .nav-button span:nth-of-type(3) {
    width: 18px;
    height: 1px;
    background-color: #000;
    transform: translateY(-9px) rotate(45deg);
  }
  .active .nav-button span:nth-of-type(4) {
    opacity: 0;
  }
  .active .nav-button span:nth-of-type(5) {
    opacity: 0;
  }
  .active .nav-button span:nth-of-type(6) {
    opacity: 0;
  }
  .active .nav-button span:nth-of-type(7) {
    opacity: 0;
  }
  .active .nav-button span:nth-of-type(8) {
    opacity: 0;
  }
  .active .nav-button span:nth-of-type(9) {
    opacity: 0;
  }
}
.navLine {
  border-bottom: 1px solid #fff;
  padding: 15px 0 0;
}

.spNavAdd {
  display: inline-block;
  margin: 40px 0 0;
}
.spNavAdd p {
  color: #1d2547;
  font-size: 1.4rem;
  line-height: 2em;
  font-weight: normal;
}
.spNavAdd .spNavBn {
  margin: 24px 0;
}
.spNavAdd small {
  color: #1d2547;
  font-size: 1.2rem;
  margin: 5px 0 0;
}
.spNavAdd .footerIcon {
  margin: 0;
}

#recruitBtn {
  font-size: 1.4rem;
  white-space: nowrap;
  margin-top: 20px;
  text-align: center;
}
#recruitBtn a {
  background-color: #1d2547;
  border-radius: 0;
  color: #fff;
  display: block;
  padding: 10px;
}

.navFadeUp {
  animation-name: fadeSideAnime;
  animation-duration: 0.5s;
  animation-fill-mode: forwards;
  opacity: 0;
}
@keyframes fadeSideAnime {
  from {
    opacity: 0;
    transform: translateX(100px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@media screen and (max-width: 480px) {
  header h1 {
    position: relative;
    width: 80%;
    z-index: 3;
  }
  header h1 img {
    height: auto;
    width: 100%;
  }
}

.naviBannerWrap {
  display: flex;
  justify-content: flex-start;
}
.iconKosodateNavi {
  border-radius: 6px;
  height: auto;
  margin-bottom: 16px;
  width: 50px;
}

/* ==========================================================================
   Breadcrumb
   ========================================================================== */
.breadcrumb-area {
  color: #fff;
  display: flex;
  justify-content: flex-end;
  font-size: 1.2rem;
  margin: 30px 0 0;
}
.breadcrumb-area a {
  color: #fff;
}
.breadcrumb-area::before {
  content: url(../images/common/icon_home.svg);
  padding: 0 10px 0 0;
}
.current-item {
  margin: 0 12px;
}

.breadcrumb-area a {
  margin: 0 12px;
}
.breadcrumb-area a.home {
  margin: 0 12px 0 0;
}

@media screen and (max-width: 768px) {
  .breadcrumb-area {
    font-size: 1.1rem;
  }
  .current-item {
    margin: 0 10px;
  }
  .breadcrumb-area a {
    margin: 0 10px;
  }
  .breadcrumb-area a.home {
    margin: 0 10px 0 0;
  }
}

/* ==========================================================================
   Contact
   ========================================================================== */
.top-contact {
  /* background: url(../images/top/bg_dot.png);
  background-size: 9px auto; */
  background: rgba(0, 0, 0, 0.3);
  width: 100%;
  padding: 150px 0;
}
.sub-contact {
  background: url(../images/common/bg_contact_n.jpg) no-repeat center bottom;
  background-size: cover;
  padding: 200px 0;
}

.contact-btn {
  background-color: #fff;
  display: flex;
  margin: 0 auto;
  text-align: center;
  width: 50%;
}
.contact-caption {
  color: #000;
  font-family: "Alata", sans-serif;
  font-size: 2rem;
  line-height: 1em;
  margin: 0 0 20px;
}
.contact-title {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 3rem;
  font-weight: bold;
  line-height: 1em;
  margin: 0 0 20px;
}
.contact-footer-txt {
  font-size: 1.4rem;
}
.contact-btn a {
  display: block;
  padding: 60px 0;
  align-self: center;
  width: 100%;
}
.contact-btn a:hover {
  background-color: #222;
  opacity: 1;
}
.contact-btn a:hover p {
  color: #dcdcdc;
}

@media screen and (max-width: 1024px) {
  .contact-btn {
    width: 60%;
  }
  .sub-contact {
    padding: 120px 0;
  }
}

@media screen and (max-width: 768px) {
  .top-contact {
    width: 100%;
    padding: 100px 0;
  }
  .sub-contact {
    padding: 100px 0;
  }
  .contact-title {
    margin: 0 0 16px;
  }
  .top-contact {
    height: auto;
  }
  .top-contact-img {
    height: auto;
  }
  .contact-title {
    font-size: 2rem;
    margin: 0 0 16px;
  }
  .contact-btn {
    width: 80%;
    bottom: -90px;
  }
  .contact-caption {
    font-size: 1.2rem;
    margin: 0 0 12px;
  }
  .contact-btn a {
    padding: 30px 0;
  }
  .contact-footer-txt {
    font-size: 1.2rem;
  }
}

/* ==========================================================================
   Img Nav
   ========================================================================== */
.img-nav {
  background: url("../images/common/bg_img.webp");
  background-size: 600px auto;
  padding: 160px 0 3px;
  width: 100%;
}
.img-nav .inner {
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  width: 100%;
  padding: 0;
}
.img-nav-inner {
  height: 600px;
  width: 33.2%;
}
.img-nav-inner a {
  display: block;
}
.bg-img-nav {
  display: flex;
  align-items: center;
  background-color: rgba(0, 0, 0, 0.5);
  height: 600px;
}
.img-nav-inner a:hover {
  background-color: rgba(0, 0, 0, 0);
}
.img-nav-business {
  background: url(../images/common/nav_business.webp) no-repeat center center;
  background-size: cover;
}
.img-nav-company {
  background: url(../images/common/nav_company_nn.jpg) no-repeat center center;
  background-size: cover;
}
.img-nav-recruit {
  background: url(../images/common/nav_recruit_n.jpg) no-repeat center center;
  background-size: cover;
}
.img-nav-title {
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 3rem;
  font-weight: bold;
}
.img-nav-caption {
  color: #fff;
  font-family: "Alata", sans-serif;
  font-size: 2rem;
}
.img-nav-txt {
  padding: 0 0 0 30px;
  text-align: left;
}

@media screen and (max-width: 1024px) {
  .img-nav {
    padding: 40px 0 3px;
    width: 100%;
  }
  .img-nav-inner {
    height: 450px;
  }
  .bg-img-nav {
    height: 450px;
  }
  .img-nav-title {
    font-size: 2.6rem;
  }
  .img-nav-caption {
    font-size: 1.8rem;
  }
}

@media screen and (max-width: 768px) {
  .img-nav {
    padding: 40px 0 0;
  }
  .img-nav-inner a {
    display: block;
  }
  .img-nav .inner {
    flex-wrap: wrap;
    padding-bottom: 0;
  }
  .img-nav-inner {
    height: 200px;
    width: 100%;
    margin: 0 0 3px;
  }
  .bg-img-nav {
    background-color: rgba(0, 0, 0, 0.5);
    height: 200px;
  }
  .img-nav-title {
    font-size: 2.2rem;
  }
  .img-nav-caption {
    font-size: 1.4rem;
  }
  .img-nav-txt {
    padding: 0 0 0 30px;
  }
  .img-nav-company {
    background: url(../images/common/nav_company_n_sp.webp) no-repeat center center;
    background-size: cover;
  }
  .img-nav-recruit {
    background: url(../images/common/nav_recruit_n_sp.webp) no-repeat center center;
    background-size: cover;
  }
}

@media screen and (max-width: 480px) {
  .img-nav-inner {
    height: 180px;
  }
  .bg-img-nav {
    height: 180px;
  }
  .img-nav-title {
    font-size: 1.8rem;
  }
  .img-nav-caption {
    font-size: 1.2rem;
  }
}

/* ==========================================================================
   Footer
   ========================================================================== */

footer {
  background-color: #222;
  width: 100%;
  margin: 0 auto;
  padding: 160px 0 100px;
}
footer .inner {
  max-width: 1200px;
  padding: 0 20px;
  position: relative;
}
.footer-inner {
  display: flex;
  justify-content: space-between;
}
.footerRight {
  text-align: right;
  align-self: center;
}
footer small {
  color: #fff;
  font-size: 1.2rem;
  padding: 0;
}
.footerLogo {
  display: flex;
  height: auto;
  margin: 0 0 55px;
}
.footerLogo div {
  align-items: center;
}
.footerLogoSmall {
  margin: 8px 0 0 16px;
}

.footerNavList ul {
  display: flex;
  justify-content: flex-end;
  margin: 0 0 25px;
}
.footerNavList ul li {
  margin: 0 0 0 35px;
}
.footerNavList ul li:first-child {
  margin: 0;
}
.footerNavList ul li a {
  color: #fff;
}
ul.footerMainNav li {
  font-size: 1.4rem;
}
ul.footerSubNav li {
  font-size: 1.2rem;
}
.footerBannerWrap {
  display: flex;
  justify-content: flex-end;
}
.iconKosodate {
  border-radius: 6px;
  height: auto;
  margin-bottom: 16px;
  width: 50px;
}

@media screen and (max-width: 1024px) {
  .footer-inner {
    align-items: center;
    flex-wrap: wrap;
  }
  .footerLeft {
    width: 100%;
  }
  .footerRight {
    width: 100%;
  }
  .footerLogo {
    margin: 0 0 20px;
  }
  .footerCr {
    width: 100%;
  }
  .footerCr small {
    display: inline-block;
    text-align: right;
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  footer {
    padding: 60px 0;
  }
  footer .inner {
    padding: 0 40px;
    position: relative;
  }
  .footer-inner {
    display: flex;
    justify-content: space-between;
  }
  .footerRight {
    text-align: left;
    align-self: center;
  }
  footer small {
    color: #fff;
    font-size: 1.2rem;
    padding: 0;
  }
  .footerLogo {
    flex-wrap: wrap;
    height: auto;
    margin: 0 0 24px;
  }
  .footerLogo div {
    text-align: center;
    width: 100%;
  }
  .footerLogoImg {
    margin: 0 0 0 16px;
  }
  .footerLogoSmall {
    margin: 8px 0 0;
  }
  .footerLeft {
    border-bottom: 1px solid #444;
  }
  .footerNavList {
    border-bottom: 1px solid #444;
    margin: 30px 0;
    padding: 0 0 30px;
  }
  .footerNavList ul {
    justify-content: flex-start;
    flex-wrap: wrap;
    margin: 0;
  }
  .footerNavList ul li {
    margin: 0;
    width: 100%;
  }
  .footerNavList ul li:first-child {
    margin: 10px 0;
  }
  .footerNavList ul li a {
    color: #fff;
  }
  ul.footerMainNav {
    border-bottom: 1px solid #444;
    padding: 0 0 30px;
    margin: 0 0 30px;
  }
  ul.footerMainNav li {
    font-size: 1.4rem;
    width: 100%;
    margin: 10px 0;
  }
  ul.footerSubNav li {
    font-size: 1.2rem;
    margin: 10px 0;
  }
  .footerCr small {
    text-align: center;
  }
}

/* ==========================================================================
   Go Top
   ========================================================================== */
.gotop {
  background-color: #333;
  border-radius: 50%;
  color: #fff;
  display: block;
  font-size: 1.6rem;
  position: absolute;
  top: -185px;
  right: 20px;
  text-align: center;
  padding: 10px 15px;
  height: 48px;
  width: 48px;
}
a.gotop:hover {
  color: #fff;
  opacity: 1;
  padding: 5px 15px 15px;
}
a.gotop:link {
  color: #fff;
}
a.gotop:visited {
  color: #fff;
}
a.gotop:active {
  color: #fff;
}

@media screen and (max-width: 768px) {
  .gotop {
    top: -80px;
    right: 20px;
  }
}

/* ==========================================================================
   Delay
   ========================================================================== */

.delay-time01 {
  animation-delay: 0.1s;
}
.delay-time02 {
  animation-delay: 0.2s;
}
.delay-time03 {
  animation-delay: 0.3s;
}
.delay-time04 {
  animation-delay: 0.4s;
}
.delay-time05 {
  animation-delay: 0.5s;
}
.delay-time06 {
  animation-delay: 0.6s;
}
.delay-time07 {
  animation-delay: 0.7s;
}
.delay-time08 {
  animation-delay: 0.8s;
}
.delay-time09 {
  animation-delay: 0.9s;
}
.delay-time10 {
  animation-delay: 1s;
}
.delay-time12 {
  animation-delay: 1.2s;
}
.delay-time14 {
  animation-delay: 1.4s;
}
.delay-time16 {
  animation-delay: 1.6s;
}

/* ==========================================================================
   8-5
   ========================================================================== */

/*========= レイアウトのためのCSS ===============*/

/* p{
	margin: 20px;
	font-size: 20px;
	overflow: hidden;/*左右アニメーションで画面からはみ出る際に出る横スクロールバーを隠す*/
/* } */

/*========= 流れるテキスト ===============*/

/*全共通*/

.slide-in {
  overflow: hidden;
  display: inline-block;
}

.slide-in_inner {
  display: inline-block;
}

/* 上下のアニメーション*/
.downAnime {
  opacity: 0; /* 事前に透過0 にして消しておく*/
}

.slideAnimeDownUp {
  animation-name: slideTextY100;
  animation-duration: 0.8s;
  animation-fill-mode: forwards;
  opacity: 0;
}

@keyframes slideTextY100 {
  from {
    transform: translateY(100%); /* 要素を上の枠外に移動*/
    opacity: 0;
  }
  to {
    transform: translateY(0); /* 要素を元の位置に移動*/
    opacity: 1;
  }
}

.slideAnimeUpDown {
  animation-name: slideTextY-100;
  animation-duration: 0.8s;
  animation-fill-mode: forwards;
  opacity: 0;
}

@keyframes slideTextY-100 {
  from {
    transform: translateY(-100%); /* 要素を下の枠外に移動*/
    opacity: 0;
  }
  to {
    transform: translateY(0); /* 要素を元の位置に移動*/
    opacity: 1;
  }
}

/* fade */
.scroll_fadein {
  opacity: 0;
}

.fadein_animation_start {
  animation-name: fadein_animation;
  animation-delay: 0.3s;
  animation-duration: 1s;
  animation-fill-mode: both;
}

@keyframes fadein_animation {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
    transform: translate(0);
  }
}
.slideup {
  transform: translateY(50px);
}
.slideleft {
  transform: translateX(50px);
}
.slideright {
  transform: translateX(-50px);
}
.titleLsp {
  letter-spacing: 0.1em;
}
